225 lines
No EOL
4.8 KiB
PHP
225 lines
No EOL
4.8 KiB
PHP
<?php
|
|
|
|
|
|
namespace CRM\TwingleCampaign\Models;
|
|
|
|
use CRM_TwingleCampaign_ExtensionUtil as E;
|
|
use DateTime;
|
|
use CRM\TwingleCampaign\Models\CustomField as CustomField;
|
|
|
|
include_once E::path() . '/CRM/TwingleCampaign/Upgrader/models/CustomField.php';
|
|
|
|
|
|
class TwingleProject {
|
|
|
|
private static $bInitialized = FALSE;
|
|
|
|
private $id;
|
|
|
|
private $project_id;
|
|
|
|
private $values;
|
|
|
|
private $timestamp;
|
|
|
|
private $settings;
|
|
|
|
private static $customFieldMapping;
|
|
|
|
/**
|
|
* TwingleProject constructor.
|
|
*
|
|
* @param array $values
|
|
*
|
|
* @throws \Exception
|
|
*/
|
|
public function __construct(array $values) {
|
|
|
|
$this->values = $values;
|
|
|
|
$this->project_id = $values['project_id'];
|
|
|
|
// Format data types of the values for import into CiviCRM
|
|
$this->formatForImport($values);
|
|
|
|
// Fetch custom field mapping once
|
|
self::init();
|
|
|
|
}
|
|
|
|
/**
|
|
* Get custom field mapping.
|
|
* This function will be fully executed only once, when the TwingleProject
|
|
* class gets instantiated for the first time.
|
|
*
|
|
* @throws \Exception
|
|
*/
|
|
private static function init() {
|
|
if (self::$bInitialized) {
|
|
return;
|
|
}
|
|
self::$customFieldMapping = CustomField::getMapping();
|
|
self::$bInitialized = TRUE;
|
|
}
|
|
|
|
/**
|
|
* Create the project as a campaign in CiviCRM if it does not exist
|
|
*
|
|
* @return array
|
|
* @throws \CiviCRM_API3_Exception
|
|
*/
|
|
public function create() {
|
|
|
|
// Translate $value keys to custom field names
|
|
$translatedValues = $this->translateValues();
|
|
|
|
// Create project if it does not exist yet and give back the result
|
|
if (!$this->exists()) {
|
|
$result = civicrm_api3('Campaign', 'create', $translatedValues);
|
|
$this->id = $result['id'];
|
|
$this->timestamp = $result['last_update'];
|
|
return [
|
|
'id' => $this->id,
|
|
'project_id' => $this->values['id'],
|
|
'state' => 'created',
|
|
];
|
|
}
|
|
// Give information back if project already exists
|
|
return [
|
|
'id' => is_array($this->id) ? implode(', ', $this->id) : $this->id,
|
|
'project_id' => $this->values['id'],
|
|
'state' => 'exists',
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Update an existing project
|
|
*
|
|
* @return array
|
|
* @throws \CiviCRM_API3_Exception
|
|
*/
|
|
public function update() {
|
|
// Translate $value keys to custom field names
|
|
$translatedValues = $this->translateValues();
|
|
|
|
$result = civicrm_api3('Campaign', 'create', $translatedValues);
|
|
return [
|
|
'title' => $this->values['title'],
|
|
'id' => $this->id,
|
|
'project_id' => $this->values['id'],
|
|
'state' => 'updated',
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Translate $value keys to custom field names
|
|
*
|
|
* @return array
|
|
*/
|
|
private function translateValues() {
|
|
$values = [];
|
|
foreach (TwingleProject::$customFieldMapping as $field => $custom) {
|
|
if (array_key_exists(
|
|
str_replace('twingle_project_', '', $field),
|
|
$this->values)
|
|
) {
|
|
$values[$custom] = $this->values[str_replace(
|
|
'twingle_project_',
|
|
'',
|
|
$field)];
|
|
}
|
|
}
|
|
// Add necessary attributes
|
|
$values['title'] = $this->values['name'];
|
|
$values['campaign_type_id'] = 'twingle_project';
|
|
return $values;
|
|
}
|
|
|
|
/**
|
|
* Formats values to import them as campaigns
|
|
*
|
|
* @param $values
|
|
*/
|
|
private function formatForImport(&$values) {
|
|
|
|
// Change timestamp into DateTime string
|
|
if (!empty($values['last_update'])) {
|
|
$date = DateTime::createFromFormat('U', $values['last_update']);
|
|
$values['last_update'] = $date->format('Y-m-d H:i:s');
|
|
}
|
|
|
|
// Change event type empty string into 'default'
|
|
if ($values['type'] == '') {
|
|
$values['type'] = 'default';
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Formats values to send them to Twingle API
|
|
*
|
|
* @param $values
|
|
*/
|
|
private function formatForExport(&$values) {
|
|
|
|
// Change DateTime string into timestamp
|
|
if (!empty($values['last_update'])) {
|
|
$date = DateTime::createFromFormat('Y-m-d H:i:s', $values['last_update']);
|
|
$values['last_update'] = $date->getTimestamp();
|
|
}
|
|
|
|
// Change event type 'default' into empty string
|
|
if ($values['type'] == 'default') {
|
|
$values['type'] = '';
|
|
}
|
|
}
|
|
|
|
public function syncSettings() {
|
|
|
|
}
|
|
|
|
/**
|
|
* @return mixed
|
|
*/
|
|
public function getId() {
|
|
return $this->id;
|
|
}
|
|
|
|
/**
|
|
* @param mixed $id
|
|
*/
|
|
public function setId($id): void {
|
|
$this->id = $id;
|
|
}
|
|
|
|
/**
|
|
* @return mixed
|
|
*/
|
|
public function getProjectId() {
|
|
return $this->project_id;
|
|
}
|
|
|
|
/**
|
|
* @param mixed $project_id
|
|
*/
|
|
public function setProjectId($project_id): void {
|
|
$this->project_id = $project_id;
|
|
}
|
|
|
|
/**
|
|
* @return mixed
|
|
*/
|
|
public function getTimestamp() {
|
|
return $this->timestamp;
|
|
}
|
|
|
|
/**
|
|
* @param mixed $timestamp
|
|
*/
|
|
public function setTimestamp($timestamp): void {
|
|
$this->timestamp = $timestamp;
|
|
}
|
|
|
|
|
|
|
|
|
|
} |