public function get_mc_list_field() { $list = $_POST['list_id']; $form_id = $_POST['form_id']; $mailchimp = new RM_MailChimp_Service(); $form = new RM_Forms(); $form->load_from_db($form_id); $content = $mailchimp->mc_field_mapping($form_id, $form->form_options, $list); echo $content; die; }
function view($model, $service, $request, $params) { if (!$request instanceof RM_Request) { $postdata = file_get_contents("php://input"); $request = json_decode($postdata); if (isset($request->form_id) && (int) $request->form_id) { $model = new RM_Forms(); $model->load_from_db($request->form_id); $model->set((array) $request); $model->update_into_db(); echo 'saved'; } else { echo 'not saved'; } die; } if (isset($request->req['rm_form_id']) && (int) $request->req['rm_form_id']) { $data = new stdClass(); $view = $this->mv_handler->setView('form_view_sett'); $model->load_from_db($request->req['rm_form_id']); $data->model = $model; } else { $data = RM_UI_Strings::get('MSG_FS_NOT_AUTHORIZED'); $view = $this->mv_handler->setView('show_notice'); } $view->render($data); }
public function process($model, RM_Front_Form_Service $service, $request, $params) { $data = new stdClass(); if (isset($params['form_id']) && $params['form_id']) { $form = new RM_Forms(); $form->load_from_db($params['form_id']); //echo "<pre>",var_dump($form),die(); } else { return; } //Called from PayPal, straight to processing. if (isset($request->req['rm_pproc'])) { if ($request->req['rm_pproc'] == 'success' || $request->req['rm_pproc'] == 'cancel' || $request->req['rm_pproc'] == 'ipn') { //error_log('rm_pproc = '.$request->req['rm_pproc']); $paystate = $service->process_payment(null, null, $service, $request); $params['form'] = $form; $params['is_payment_form'] = true; $params['is_payment_done'] = true; /*else //Pending or cancelation cases { $params['form'] = $form; $params['is_payment_form'] = true; $params['is_payment_done'] = false; }*/ $service->save_form($request, $params); return; } } /* * If register form type then check if user exists */ $user_exists = false; if ($form->form_type == 1 && !is_user_logged_in()) { if ($service->user_exists($form, $request)) { $user_exists = true; } else { Form::clearErrors('form_' . $form->form_id); } } if (isset($request->req['stat_id'])) { $stat_id = $request->req['stat_id']; } else { $stat_id = null; } /* * Validates the form in case form is not expired. */ if ($this->mv_handler->validateForm('form_' . $form->form_id) && !$service->is_form_expired($form) && !$user_exists && !$service->is_browser_reload_duplication($stat_id)) { $params['form'] = $form; // echo "<pre>",var_dump($form),die(); if ($service->is_off_limit_submission($form->form_id)) { die(RM_UI_Strings::get("ALERT_SUBMISSIOM_LIMIT")); } $service->update_stat_entry($stat_id); if ($service->get_setting('enable_mailchimp') == 'yes') { $form_options_mc = $form->get_form_options(); //die; if ($form_options_mc->form_is_opt_in_checkbox == 1) { $should_subscribe = isset($request->req['rm_subscribe_mc']) && $request->req['rm_subscribe_mc'][0] == 1 ? 'yes' : 'no'; } else { $should_subscribe = 'yes'; } if ($should_subscribe == 'yes') { $mailchimp = new RM_MailChimp_Service(); $mc_member = new stdClass(); if (isset($request->req[$form_options_mc->mailchimp_mapped_email])) { $mc_member->email = $request->req[$form_options_mc->mailchimp_mapped_email]; if (isset($request->req[$form_options_mc->mailchimp_mapped_first_name])) { $mc_member->first_name = $request->req[$form_options_mc->mailchimp_mapped_first_name]; } else { $mc_member->first_name = NULL; } if (isset($request->req[$form_options_mc->mailchimp_mapped_last_name])) { $mc_member->last_name = $request->req[$form_options_mc->mailchimp_mapped_last_name]; } else { $mc_member->last_name = NULL; } $mailchimp->subscribe($mc_member, $form_options_mc->mailchimp_list); } } } if (isset($request->req['rm_payment_form'])) { //Do not register user if the payment+registration type form, wait for payment confirmation. $params['is_payment_form'] = true; $params['is_payment_done'] = false; $rd = $service->save_form($request, $params, true, false); //die("xx"); $res = $service->process_payment($form->get_form_id(), $rd, $service, $request); if ($res == 'zero_amount') { $params['is_payment_form'] = true; $params['is_payment_done'] = true; $params['za_user_id'] = $rd->user_id; $rd = $service->save_form($request, $params); //$submission_id = $rd->submission_id; } } else { $rd = $service->save_form($request, $params); $submission_id = $rd->submission_id; } } else { if (isset($request->req['rm_submission_id'])) { $submissions = new RM_Submissions(); $submissions->load_from_db($request->req['rm_submission_id']); } /* * Get all the fields associated with the Form */ $data->fields_data = $service->get_all_form_fields($params['form_id']); $i = 0; if (is_array($data->fields_data) || is_object($data->fields_data)) { foreach ($data->fields_data as $field_data) { $data->fields_data[$i++]->properties = $service->set_properties(maybe_unserialize($field_data->field_options)); } } $data->form = $form; $data->is_auto_generate = false; /* * Checking if password generation is configured */ if ($form->get_form_type() == 1) { $auto_generate = $service->get_setting('auto_generated_password'); if ($auto_generate == "yes") { $data->is_auto_generate = true; } } /* * Check if mailchimp is enabled in options */ if ($service->get_setting('enable_mailchimp') == 'yes') { $data->is_mailchimp_enabled = true; } else { $data->is_mailchimp_enabled = false; } /* * If user role are to be choosen by registrar */ /* echo '<pre>'; print_r($form); */ if (!empty($form->form_options->form_should_user_pick) || !(isset($form->form_user_role) && !empty($form->form_user_role))) { $role_pick = $form->form_options->form_should_user_pick; if ($role_pick) { global $wp_roles; $allowed_roles = array(); $default_wp_roles = $wp_roles->get_names(); $form_roles = $form->get_form_user_role(); if (is_array($form_roles) && count($form_roles) > 0) { foreach ($form_roles as $val) { if (array_key_exists($val, $default_wp_roles)) { $allowed_roles[$val] = $default_wp_roles[$val]; } } } $data->allowed_roles = $allowed_roles; $data->role_as = empty($form->form_options->form_user_field_label) ? RM_UI_Strings::get('LABEL_ROLE_AS') : $form->form_options->form_user_field_label; } } /* * Checking if form is expired */ $data->expired = $service->is_form_expired($form); $data->user_exists = $user_exists; if (isset($submissions)) { $data->submissions = $submissions; } $data->curr_symbol = $service->get_setting('currency_symbol'); $data->currency_pos = $service->get_setting('currency_symbol_position'); $data->stat_id = $service->create_stat_entry($params); if ($service->get_setting('theme') == 'matchmytheme') { $data->submit_btn_fgcolor = $form->form_options->form_submit_btn_color; $data->submit_btn_bgcolor = $form->form_options->form_submit_btn_bck_color; } else { $data->submit_btn_fgcolor = null; $data->submit_btn_bgcolor = null; } $data->expiry_details = $service->get_form_expiry_stats($form); $view = $this->mv_handler->setView("user_form", true); return $view->read($data); } }
public function manage($model, $service, $request, $params) { $data = new stdClass(); if (isset($request->req['rm_action'])) { if ($request->req['rm_action'] === 'delete') { $this->remove_field($model, $service, $request, $params); } elseif ($request->req['rm_action'] === 'add_page') { $data->current_page = $this->add_page($model, $service, $request, $params); } elseif ($request->req['rm_action'] === 'delete_page') { $this->delete_page($model, $service, $request, $params); } elseif ($request->req['rm_action'] === 'rename_page') { $this->rename_page($model, $service, $request, $params); } } if (isset($request->req['rm_form_id'])) { $fields_data = $service->get_all_form_fields($request->req['rm_form_id']); } else { die(RM_UI_Strings::get('MSG_NO_FORM_SELECTED')); } $data->fields_data = $fields_data; $data->forms = RM_Utilities::get_forms_dropdown($service); $data->field_types = RM_Utilities::get_field_types(); $data->form_id = $request->req['rm_form_id']; $form = new RM_Forms(); $form->load_from_db($data->form_id); $fopts = $form->get_form_options(); $g = array_keys($data->field_types); if ($data->fields_data && is_array($data->fields_data)) { foreach ($data->fields_data as $in => $out) { if (!in_array($out->field_type, $g)) { unset($data->fields_data[$in]); } } } if (!$fopts->form_pages) { $data->total_page = 1; $data->form_pages = array('Page 1'); } else { $data->total_page = count($fopts->form_pages); $data->form_pages = $fopts->form_pages; } if (!isset($data->current_page)) { $data->current_page = isset($request->req['rm_form_page_no']) ? $request->req['rm_form_page_no'] : 1; } $view = $this->mv_handler->setView("field_manager"); $view->render($data); }
public function view($model, RM_Services $service, $request, $params) { if (isset($request->req['rm_submission_id'])) { if (!$model->load_from_db($request->req['rm_submission_id'])) { $view = $this->mv_handler->setView('show_notice'); $data = RM_UI_Strings::get('MSG_DO_NOT_HAVE_ACCESS'); $view->render($data); } else { if (isset($request->req['rm_action']) && $request->req['rm_action'] == 'delete') { $request->req['rm_form_id'] = $model->get_form_id(); $request->req['rm_selected'] = $request->req['rm_submission_id']; $this->remove($model, $service, $request, $params); unset($request->req['rm_selected']); } else { $settings = new RM_Options(); $data = new stdClass(); $data->submission = $model; $data->payment = $service->get('PAYPAL_LOGS', array('submission_id' => $model->get_submission_id()), array('%d'), 'row', 0, 99999); if ($data->payment != null) { $data->payment->total_amount = $settings->get_formatted_amount($data->payment->total_amount, $data->payment->currency); if ($data->payment->log) { $data->payment->log = maybe_unserialize($data->payment->log); } } $data->notes = $service->get('NOTES', array('submission_id' => $model->get_submission_id()), array('%d'), 'results', 0, 99999, '*', null, true); $i = 0; if (is_array($data->notes)) { foreach ($data->notes as $note) { $data->notes[$i]->author = get_userdata($note->published_by)->display_name; if ($note->last_edited_by) { $data->notes[$i++]->editor = get_userdata($note->last_edited_by)->display_name; } else { $data->notes[$i++]->editor = null; } } } /* * Check submission type */ $form = new RM_Forms(); $form->load_from_db($model->get_form_id()); $form_type = $form->get_form_type() == "1" ? "Registration" : "Contact"; $data->form_type = $form_type; $data->form_type_status = $form->get_form_type(); //$data->form_name = $form->get_form_name(); $data->form_is_unique_token = $form->get_form_is_unique_token(); /* * User details if form is registration type */ if ($form->get_form_type() == "1") { $email = $model->get_user_email(); if ($email != "") { $user = get_user_by('email', $email); $data->user = $user; } } $view = $this->mv_handler->setView('view_submission'); $view->render($data); } } } else { throw new InvalidArgumentException(RM_UI_Strings::get('MSG_INVALID_SUBMISSION_ID')); } }
public function manage_form_page($action, $form_id, $page_no = null, $new_page_name = null) { $form = new RM_Forms(); $form->load_from_db($form_id); $fopts = $form->get_form_options(); $form_pages = $fopts->form_pages; switch ($action) { case 'add_page': if ($form_pages == null) { $form_pages = array('Page 1', 'Page 2'); } else { $total_page = count($form_pages); $new_page_no = $total_page + 1; $form_pages[] = 'Page ' . $new_page_no; } break; case 'delete_page': if ($form_pages == null || !$page_no) { return; } else { if ($page_no == 1) { return; } //can't delete first page. if (isset($form_pages[$page_no - 1])) { RM_DBManager::remove_fields_for_page($page_no, $form_id); unset($form_pages[$page_no - 1]); } } break; case 'rename_page': if ($form_pages == null || !$page_no || !$new_page_name) { return; } else { if (isset($form_pages[$page_no - 1])) { $form_pages[$page_no - 1] = $new_page_name; } } break; } $x = (object) array('form_pages' => $form_pages); $form->set_form_options($x); $form->update_into_db(); return count($form_pages); }
public function submissions($model, RM_Front_Service $service, $request, $params) { $i = 0; $user_email = $service->get_user_email(); //var_dump($user_email);die; if (null != $user_email) { if (isset($request->req['submission_id'])) { $submission = new RM_Submissions(); $submission->load_from_db($request->req['submission_id']); if ($submission->get_user_email() == $user_email) { $view = $this->mv_handler->setView('front_submission_data', true); $data = new stdClass(); $settings = new RM_Options(); $data->is_authorized = true; $data->submission = $submission; $data->payment = $service->get('PAYPAL_LOGS', array('submission_id' => $submission->get_submission_id()), array('%d'), 'row', 0, 99999); if ($data->payment != null) { $data->payment->total_amount = $settings->get_formatted_amount($data->payment->total_amount, $data->payment->currency); if ($data->payment->log) { $data->payment->log = maybe_unserialize($data->payment->log); } } $data->notes = $service->get('NOTES', array('submission_id' => $submission->get_submission_id(), 'status' => 'publish'), array('%d', '%s'), 'results', 0, 99999, '*', null, true); $i = 0; if (is_array($data->notes)) { foreach ($data->notes as $note) { $data->notes[$i]->author = get_userdata($note->published_by)->display_name; if ($note->last_edited_by) { $data->notes[$i++]->editor = get_userdata($note->last_edited_by)->display_name; } else { $data->notes[$i++]->editor = null; } } } /* * Check submission type */ $form = new RM_Forms(); $form->load_from_db($submission->get_form_id()); $form_type = $form->get_form_type() == "1" ? "Registration" : "Contact"; $data->form_type = $form_type; $data->form_type_status = $form->get_form_type(); $data->form_name = $form->get_form_name(); $data->form_is_unique_token = $form->get_form_is_unique_token(); /* * User details if form is registration type */ if ($form->get_form_type() == "1") { $email = $submission->get_user_email(); if ($email != "") { $user = get_user_by('email', $email); $data->user = $user; } } return $view->read($data); } else { $view = $this->mv_handler->setView('not_authorized', true); } $msg = RM_UI_Strings::get('MSG_INVALID_SUBMISSION_ID_FOR_EMAIL'); return $view->read($msg); } else { $data = new stdClass(); $data->is_authorized = true; $data->submissions = array(); $data->form_names = array(); $data->submission_exists = false; //data for user page $user = get_user_by('email', $user_email); if ($user instanceof WP_User) { $data->is_user = true; $data->user = $user; $data->custom_fields = $service->get_custom_fields($user_email); } else { $data->is_user = false; } //For pagination of submissions $entries_per_page_sub = 20; $req_page_sub = isset($request->req['rm_reqpage_sub']) && $request->req['rm_reqpage_sub'] > 0 ? $request->req['rm_reqpage_sub'] : 1; $offset_sub = ($req_page_sub - 1) * $entries_per_page_sub; $total_entries_sub = $service->get_submission_count($user_email); $submissions = $service->get_submissions_by_email($user_email, $entries_per_page_sub, $offset_sub); $submission_ids = array(); if ($submissions) { $data->submission_exists = true; foreach ($submissions as $submission) { $form_name = $service->get('FORMS', array('form_id' => $submission->form_id), array('%d'), 'var', 0, 1, 'form_name'); $data->submissions[$i] = new stdClass(); $data->submissions[$i]->submission_ids = array(); $data->submissions[$i]->submission_id = $submission->submission_id; $submission_ids[$i] = $submission->submission_id; $data->submissions[$i]->submitted_on = $submission->submitted_on; $data->submissions[$i]->form_name = $form_name; $data->form_names[$submission->submission_id] = $form_name; $i++; } $settings = new RM_Options(); $data->date_format = get_option('date_format'); $data->payments = $service->get_payments_by_submission_id($submission_ids, 999999, 0, null, true); $i = 0; if ($data->payments) { foreach ($data->payments as $p) { $data->payments[$i]->total_amount = $settings->get_formatted_amount($data->payments[$i]->total_amount, $data->payments[$i]->currency); $i++; } } //For pagination of payments $entries_per_page_pay = 20; $req_page_pay = isset($request->req['rm_reqpage_pay']) && $request->req['rm_reqpage_pay'] > 0 ? $request->req['rm_reqpage_pay'] : 1; $data->offset_pay = $offset_pay = ($req_page_pay - 1) * $entries_per_page_pay; $total_entries_pay = $i; $data->total_pages_pay = (int) ($total_entries_pay / $entries_per_page_pay) + ($total_entries_pay % $entries_per_page_pay == 0 ? 0 : 1); $data->curr_page_pay = $req_page_pay; $data->starting_serial_number_pay = $offset_pay + 1; $data->end_offset_this_page = $data->curr_page_pay < $data->total_pages_pay ? $data->offset_pay + $entries_per_page_pay : $total_entries_pay; //Pagination Ends payments //$data->rm_slug = $request->req['page']; //$data->stat_data = $service->get_form_stats($data->current_form_id, $offset, $entries_per_page); $data->total_pages_sub = (int) ($total_entries_sub / $entries_per_page_sub) + ($total_entries_sub % $entries_per_page_sub == 0 ? 0 : 1); $data->curr_page_sub = $req_page_sub; $data->starting_serial_number_sub = $offset_sub + 1; //Pagination Ends submissions $data->active_tab_index = isset($request->req['rm_tab']) ? (int) $request->req['rm_tab'] : 0; $view = $this->mv_handler->setView('front_submissions', true); return $view->read($data); } elseif ($data->is_user === true) { $data->payments = false; $data->submissions = false; $view = $this->mv_handler->setView('front_submissions', true); return $view->read($data); } else { $view = $this->mv_handler->setView('not_authorized', true); $msg = RM_UI_Strings::get('MSG_NO_SUBMISSION_FRONT'); return $view->read($msg); } } } else { $view = $this->mv_handler->setView('not_authorized', true); $msg = RM_UI_Strings::get('MSG_NOT_AUTHORIZED'); return $view->read($msg); } }