vtenext/modules/Webforms/capture.php
2021-04-28 20:10:26 +02:00

103 lines
3.6 KiB
PHP

<?php
/*************************************
* SPDX-FileCopyrightText: 2009-2020 Vtenext S.r.l. <info@vtenext.com>
* SPDX-License-Identifier: AGPL-3.0-only
************************************/
// Switch the working directory to base
chdir(dirname(__FILE__) . '/../..');
include_once 'include/Webservices/Create.php';
include_once 'modules/Webforms/model/WebformsModel.php';
include_once 'modules/Webforms/model/WebformsFieldModel.php';
include_once 'include/QueryGenerator/QueryGenerator.php';
class Webform_Capture {
function captureNow($request) {
$returnURL = false;
try {
if(!vtlib_isModuleActive('Webforms')) throw new Exception('webforms is not active');
$webform = Webforms_Model::retrieveWithPublicId(vtlib_purify($request['publicid']));
if (empty($webform)) throw new Exception("Webform not found.");
$returnURL = $webform->getReturnUrl();
// Retrieve user information
$user = CRMEntity::getInstance('Users');
$user->id=$user->getActiveAdminId();
$user->retrieve_entity_info($user->id, 'Users');
//crmv@39947
global $current_user;
$current_user = $user;
$current_user->id = $user->id;
//crmv@39947e
// Prepare the parametets
$parameters = array();
$webformFields = $webform->getFields();
foreach ($webformFields as $webformField) {
//crmv@32257 crmv@37463
$fieldData = $request[$webformField->getNeutralizedField()];
if(is_array($fieldData)){
$fieldData = implode(" |##| ", $fieldData);
}
$fieldData = strip_tags($fieldData);
// crmv@37463e
$parameters[$webformField->getFieldName()] = stripslashes($fieldData);
if(in_array($parameters[$webformField->getFieldName()],array('','--None--')) && $webformField->getDefaultValue() != null){
$parameters[$webformField->getFieldName()] = decode_html($webformField->getDefaultValue());
}
//crmv@32257e
//crmv@162158
require_once('modules/com_workflow/VTSimpleTemplate.inc');//crmv@207901
$vtSimpleTemplate = new VTSimpleTemplate($parameters[$webformField->getFieldName()]);
$parameters[$webformField->getFieldName()] = $vtSimpleTemplate->parseTemplate();
//crmv@162158e
if($webformField->getRequired()){
if(empty($parameters[$webformField->getFieldName()])) throw new Exception("Required fields not filled");
}
}
$parameters['assigned_user_id'] = vtws_getWebserviceEntityId('Users', $webform->getOwnerId());
// Create the record
$record=vtws_create($webform->getTargetModule(), $parameters, $user);
$this->sendResponse($returnURL, 'ok');
return;
} catch (Exception $e) {
$this->sendResponse($returnURL, false, $e->getMessage());
return;
}
}
protected function sendResponse($url, $success=false, $failure=false) {
if (empty($url)) {
if ($success) $response = Zend_Json::encode(array('success' => true, 'result' => $success));
else $response = Zend_Json::encode(array('success' => false, 'error' => array('message' => $failure)));
// Support JSONP
if (!empty($_REQUEST['callback'])) {
$callback = vtlib_purify($_REQUEST['callback']);
echo sprintf("%s(%s)", $callback, $response);
} else {
echo $response;
}
} else {
// crmv@177138 crmv@177927
$sep = (strpos($url,'?') !== false ? '&' : '?');
$scheme = parse_url($url, PHP_URL_SCHEME);
if(empty($scheme)) $url = 'http://'.$url;
header(sprintf("Location: %s{$sep}%s=%s", $url, ($success? 'success' : 'error'), ($success? $success: $failure)));
// crmv@177138e crmv@177927e
}
}
}
// NOTE: Take care of stripping slashes...
$webformCapture = new Webform_Capture();
$webformCapture->captureNow($_REQUEST);
?>