feat: Добавлена операция CreateWebProject для vTiger webservice
- Упрощённая операция создания проекта: обязательно policy_number + contact_id
- Логика: если проект с таким полисом существует - возвращает ID БЕЗ обновления
- Если не существует - создаёт новый проект
- Поля:
* projectname: 'ERV {полис} цифровой адвокат'
* projectstatus: 'модерация'
* projecttype: 'ерв урегулирование'
* linktoaccountscontacts: привязка к контакту
* cf_1994: Заявитель (контрагент 67458)
* cf_1885: номер полиса
* cf_1887, cf_1889: периоды страхования (опционально)
- Возвращает JSON: {"project_id": "123", "is_new": true/false}
- Зарегистрировано в БД:
* vtiger_ws_operation (id: 51)
* vtiger_ws_operation_parameters (policy_number, contact_id, period_start, period_end)
- Логи: logs/CreateWebProject.log
- Протестировано: проект 396865 создан и повторно найден без дублирования
This commit is contained in:
122
include/Webservices/CreateWebProject.php
Normal file
122
include/Webservices/CreateWebProject.php
Normal file
@@ -0,0 +1,122 @@
|
|||||||
|
<?php
|
||||||
|
/*********************************************************************************
|
||||||
|
* API-интерфейс для создания Проекта из Web-формы (упрощённый)
|
||||||
|
* Обязательное поле: cf_1885 (номер полиса)
|
||||||
|
* Логика: если проект с таким полисом существует - возвращаем ID БЕЗ обновления
|
||||||
|
* Автор: Фёдор, 2025-11-01
|
||||||
|
********************************************************************************/
|
||||||
|
|
||||||
|
include_once 'include/Webservices/Query.php';
|
||||||
|
include_once 'modules/Users/Users.php';
|
||||||
|
require_once('include/Webservices/Utils.php');
|
||||||
|
require_once 'include/Webservices/Create.php';
|
||||||
|
require_once 'includes/Loader.php';
|
||||||
|
vimport ('includes.runtime.Globals');
|
||||||
|
vimport ('includes.runtime.BaseModel');
|
||||||
|
vimport ('includes.runtime.LanguageHandler');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Создание проекта из web-формы
|
||||||
|
* Если проект с таким номером полиса уже существует - просто возвращаем его ID
|
||||||
|
* @param string $policy_number - номер полиса (обязательное поле) - cf_1885
|
||||||
|
* @param string $contact_id - ID контакта для привязки (обязательное поле)
|
||||||
|
* @param string $period_start - дата начала страхования (опционально) - cf_1887
|
||||||
|
* @param string $period_end - дата окончания страхования (опционально) - cf_1889
|
||||||
|
* @return string - JSON: {"project_id": "123", "is_new": true/false}
|
||||||
|
*/
|
||||||
|
function vtws_createwebproject($policy_number, $contact_id, $period_start = '', $period_end = '', $user = false) {
|
||||||
|
|
||||||
|
$logstring = date("Y-m-d H:i:s").' '.json_encode($_REQUEST);
|
||||||
|
file_put_contents('logs/CreateWebProject.log', $logstring.PHP_EOL, FILE_APPEND);
|
||||||
|
|
||||||
|
// Проверка обязательных полей
|
||||||
|
if(empty($policy_number)){
|
||||||
|
$logstring = date("Y-m-d H:i:s").' Не указано обязательное поле: policy_number (cf_1885)';
|
||||||
|
file_put_contents('logs/CreateWebProject.log', $logstring.PHP_EOL, FILE_APPEND);
|
||||||
|
throw new WebServiceException(WebServiceErrorCode::$INVALIDID, "Не указан номер полиса");
|
||||||
|
}
|
||||||
|
|
||||||
|
if(empty($contact_id)){
|
||||||
|
$logstring = date("Y-m-d H:i:s").' Не указано обязательное поле: contact_id';
|
||||||
|
file_put_contents('logs/CreateWebProject.log', $logstring.PHP_EOL, FILE_APPEND);
|
||||||
|
throw new WebServiceException(WebServiceErrorCode::$INVALIDID, "Не указан ID контакта");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Валидация: убираем пробелы из номера полиса
|
||||||
|
$policy_number = trim($policy_number);
|
||||||
|
|
||||||
|
$logstring = date('Y-m-d H:i:s').' Ищем проект по policy_number='.$policy_number.PHP_EOL;
|
||||||
|
file_put_contents('logs/CreateWebProject.log', $logstring, FILE_APPEND);
|
||||||
|
|
||||||
|
global $adb, $current_user;
|
||||||
|
|
||||||
|
$isNew = false; // Флаг: создан ли проект сейчас
|
||||||
|
|
||||||
|
// Проверяем существование проекта по номеру полиса
|
||||||
|
$query = "SELECT p.projectid
|
||||||
|
FROM vtiger_project p
|
||||||
|
INNER JOIN vtiger_projectcf pcf ON p.projectid = pcf.projectid
|
||||||
|
LEFT JOIN vtiger_crmentity e ON e.crmid = p.projectid
|
||||||
|
WHERE e.deleted = 0 AND pcf.cf_1885 = ?
|
||||||
|
LIMIT 1";
|
||||||
|
$result = $adb->pquery($query, array($policy_number));
|
||||||
|
|
||||||
|
if ($adb->num_rows($result) > 0) {
|
||||||
|
// Проект существует - ПРОСТО ВОЗВРАЩАЕМ ID (НЕ обновляем!)
|
||||||
|
$output = $adb->query_result($result, 0, 'projectid');
|
||||||
|
$isNew = false;
|
||||||
|
$logstring = date('Y-m-d H:i:s').' ✅ Проект найден с id '.$output.' (БЕЗ обновления)'.PHP_EOL;
|
||||||
|
file_put_contents('logs/CreateWebProject.log', $logstring, FILE_APPEND);
|
||||||
|
} else {
|
||||||
|
// Проект НЕ существует - создаём новый
|
||||||
|
|
||||||
|
// Формируем название проекта
|
||||||
|
$projectname = 'ERV ' . $policy_number . ' цифровой адвокат';
|
||||||
|
|
||||||
|
$params = array (
|
||||||
|
'projectname' => $projectname,
|
||||||
|
'projectstatus' => 'модерация',
|
||||||
|
'projecttype' => 'ерв урегулирование',
|
||||||
|
'linktoaccountscontacts' => '12x'.$contact_id, // Привязка к контакту
|
||||||
|
'cf_1994' => '11x67458', // Заявитель (контрагент record=67458)
|
||||||
|
'cf_1885' => $policy_number, // Номер полиса
|
||||||
|
'assigned_user_id' => vtws_getWebserviceEntityId('Users', $current_user->id)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Дополнительные необязательные поля
|
||||||
|
if (!empty($period_start)) {
|
||||||
|
$params['cf_1887'] = $period_start; // Период страхования начало
|
||||||
|
}
|
||||||
|
if (!empty($period_end)) {
|
||||||
|
$params['cf_1889'] = $period_end; // Период страхования конец
|
||||||
|
}
|
||||||
|
|
||||||
|
$logstring = date('Y-m-d H:i:s').' Массив для создания Web Проекта: '.json_encode($params).PHP_EOL;
|
||||||
|
file_put_contents('logs/CreateWebProject.log', $logstring, FILE_APPEND);
|
||||||
|
|
||||||
|
try {
|
||||||
|
$project = vtws_create('Project', $params, $current_user);
|
||||||
|
$output = substr($project['id'], 3);
|
||||||
|
$isNew = true; // Проект только что создан!
|
||||||
|
$logstring = date('Y-m-d H:i:s').' ✅ Создан новый Web Проект с id '.$output.PHP_EOL;
|
||||||
|
file_put_contents('logs/CreateWebProject.log', $logstring, FILE_APPEND);
|
||||||
|
} catch (WebServiceException $ex) {
|
||||||
|
$logstring = date('Y-m-d H:i:s').' ❌ Ошибка создания: '.$ex->getMessage().PHP_EOL;
|
||||||
|
file_put_contents('logs/CreateWebProject.log', $logstring, FILE_APPEND);
|
||||||
|
throw $ex;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Возвращаем JSON с флагом is_new
|
||||||
|
$result = array(
|
||||||
|
'project_id' => $output,
|
||||||
|
'is_new' => $isNew
|
||||||
|
);
|
||||||
|
|
||||||
|
$logstring = date('Y-m-d H:i:s').' Return: '.json_encode($result).PHP_EOL;
|
||||||
|
file_put_contents('logs/CreateWebProject.log', $logstring, FILE_APPEND);
|
||||||
|
|
||||||
|
return json_encode($result);
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
|
||||||
Reference in New Issue
Block a user