-
Notifications
You must be signed in to change notification settings - Fork 60
Expand file tree
/
Copy pathCFDBIntegrationFormidableForms.php
More file actions
92 lines (75 loc) · 2.78 KB
/
CFDBIntegrationFormidableForms.php
File metadata and controls
92 lines (75 loc) · 2.78 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
<?php
/*
"Contact Form to Database" Copyright (C) 2011-2016 Michael Simpson (email : michael.d.simpson@gmail.com)
This file is part of Contact Form to Database.
Contact Form to Database is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Contact Form to Database is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Contact Form to Database.
If not, see <http://www.gnu.org/licenses/>.
*/
class CFDBIntegrationFormidableForms {
/**
* @var CF7DBPlugin
*/
var $plugin;
/**
* @param $plugin CF7DBPlugin
*/
function __construct($plugin) {
$this->plugin = $plugin;
}
public function registerHooks() {
// https://formidablepro.com/knowledgebase/frm_after_create_entry/
add_action('frm_after_create_entry', array(&$this, 'saveFormData'), 30, 2);
}
/**
* @param int $entry_id
* @param int $form_id
* @return bool
*/
public function saveFormData($entry_id, $form_id) {
global $wpdb;
// Get form title
$sql = "SELECT name FROM {$wpdb->prefix}frm_forms WHERE id = %d";
$sql = $wpdb->prepare($sql, $form_id);
$title = $wpdb->get_var($sql);
if (!$title) {
return true;
}
// Get submission values
$sql = "SELECT f.name AS 'key', m.meta_value AS 'value' FROM {$wpdb->prefix}frm_item_metas m, {$wpdb->prefix}frm_fields f WHERE m.field_id = f.id AND m.item_id = %d";
$sql = $wpdb->prepare($sql, $entry_id);
$results = $wpdb->get_results($sql, ARRAY_A);
if (!$results) {
return true;
}
$postedData = array();
foreach ($results as $result) {
$key = $result['key'];
$value = $result['value'];
if (is_serialized($value)) {
$value = unserialize($value);
if (is_array($value)) {
$value = implode(',', $value);
} else {
$value = (string)$value; // shouldn't get here
}
}
$postedData[$key] = $value;
}
// Save submission
$data = (object)array(
'title' => $title,
'posted_data' => $postedData,
'uploaded_files' => array()); // todo
$this->plugin->saveFormData($data);
return true;
}
}