2020-05-29 13:41:58 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Model\Table;
|
|
|
|
|
|
|
|
use Cake\ORM\Table;
|
|
|
|
use Cake\Validation\Validator;
|
2020-06-21 23:53:38 +02:00
|
|
|
use Cake\Core\Configure;
|
|
|
|
use Cake\Core\Configure\Engine\PhpConfig;
|
2021-01-13 14:20:29 +01:00
|
|
|
use Cake\ORM\TableRegistry;
|
2020-05-29 13:41:58 +02:00
|
|
|
|
|
|
|
class AppTable extends Table
|
|
|
|
{
|
|
|
|
public function initialize(array $config): void
|
|
|
|
{
|
|
|
|
}
|
2021-01-13 14:20:29 +01:00
|
|
|
|
2021-11-15 11:48:23 +01:00
|
|
|
// Move this into a tool
|
|
|
|
public function getStatisticsForModel(Object $table, int $days = 30): array
|
|
|
|
{
|
|
|
|
$statistics = [];
|
|
|
|
if ($table->hasBehavior('Timestamp')) {
|
|
|
|
$statistics['created'] = $this->getActivityStatistic($table, $days, 'created');
|
|
|
|
$statistics['modified'] = $this->getActivityStatistic($table, $days, 'modified');
|
|
|
|
}
|
|
|
|
return $statistics;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getActivityStatistic(Object $table, int $days = 30, string $field = 'modified', bool $includeTimeline = true): array
|
|
|
|
{
|
|
|
|
$statistics = [];
|
|
|
|
$statistics['days'] = $days;
|
|
|
|
$statistics['amount'] = $table->find()->all()->count();
|
|
|
|
if ($table->behaviors()->has('Timestamp') && $includeTimeline) {
|
|
|
|
$statistics['timeline'] = $this->buildTimeline($table, $days, $field);
|
|
|
|
$statistics['variation'] = $table->find()->where(["{$field} >" => new \DateTime("-{$days} days")])->all()->count();
|
|
|
|
-$statistics['amount'];
|
|
|
|
} else {
|
|
|
|
$statistics['timeline'] = [];
|
|
|
|
$statistics['variation'] = 0;
|
|
|
|
}
|
|
|
|
return $statistics;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function buildTimeline(Object $table, int $days = 30, string $field = 'modified'): array
|
|
|
|
{
|
|
|
|
$timeline = [];
|
|
|
|
$authorizedFields = ['modified', 'created'];
|
|
|
|
if ($table->behaviors()->has('Timestamp')) {
|
|
|
|
if (!in_array($field, $authorizedFields)) {
|
|
|
|
throw new MethodNotAllowedException(__('Cannot construct timeline for field `{0}`', $field));
|
|
|
|
}
|
|
|
|
$days = $days - 1;
|
|
|
|
$query = $table->find();
|
|
|
|
$query->select([
|
|
|
|
'count' => $query->func()->count('id'),
|
|
|
|
'date' => "DATE({$field})",
|
|
|
|
])
|
|
|
|
->where(["{$field} >" => new \DateTime("-{$days} days")])
|
|
|
|
->group(['date'])
|
|
|
|
->order(['date']);
|
|
|
|
$data = $query->toArray();
|
|
|
|
$interval = new \DateInterval('P1D');
|
|
|
|
$period = new \DatePeriod(new \DateTime("-{$days} days"), $interval, (new \DateTime())->modify( '+1 day' ));
|
|
|
|
foreach ($period as $date) {
|
|
|
|
$timeline[$date->format("Y-m-d")] = [
|
|
|
|
'time' => $date->format("Y-m-d"),
|
|
|
|
'count' => 0
|
|
|
|
];
|
|
|
|
}
|
|
|
|
foreach ($data as $entry) {
|
|
|
|
$timeline[$entry->date]['count'] = $entry->count;
|
|
|
|
}
|
|
|
|
$timeline = array_values($timeline);
|
|
|
|
}
|
|
|
|
return $timeline;
|
|
|
|
}
|
|
|
|
|
2021-01-13 14:20:29 +01:00
|
|
|
public function saveMetaFields($id, $input)
|
|
|
|
{
|
|
|
|
$this->MetaFields = TableRegistry::getTableLocator()->get('MetaFields');
|
2021-01-14 09:15:37 +01:00
|
|
|
$this->MetaTemplates = TableRegistry::getTableLocator()->get('MetaTemplates');
|
|
|
|
foreach ($input['metaFields'] as $templateID => $metaFields) {
|
|
|
|
$metaTemplates = $this->MetaTemplates->find()->where([
|
|
|
|
'id' => $templateID,
|
|
|
|
'enabled' => 1
|
|
|
|
])->contain(['MetaTemplateFields'])->first();
|
|
|
|
$fieldNameToId = [];
|
|
|
|
foreach ($metaTemplates->meta_template_fields as $i => $metaTemplateField) {
|
|
|
|
$fieldNameToId[$metaTemplateField->field] = $metaTemplateField->id;
|
2021-01-13 14:20:29 +01:00
|
|
|
}
|
2021-01-14 09:15:37 +01:00
|
|
|
foreach ($metaFields as $metaField => $values) {
|
|
|
|
if (!is_array($values)) {
|
|
|
|
$values = [$values];
|
|
|
|
}
|
|
|
|
foreach ($values as $value) {
|
|
|
|
if ($value !== '') {
|
|
|
|
$temp = $this->MetaFields->newEmptyEntity();
|
|
|
|
$temp->field = $metaField;
|
|
|
|
$temp->value = $value;
|
2021-01-15 14:40:03 +01:00
|
|
|
$temp->scope = $this->metaFields;
|
2021-01-14 09:15:37 +01:00
|
|
|
$temp->parent_id = $id;
|
|
|
|
$temp->meta_template_id = $templateID;
|
|
|
|
$temp->meta_template_field_id = $fieldNameToId[$metaField];
|
2021-01-15 14:40:03 +01:00
|
|
|
$res = $this->MetaFields->save($temp);
|
2021-01-14 09:15:37 +01:00
|
|
|
}
|
2021-01-13 14:20:29 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-05-29 13:41:58 +02:00
|
|
|
}
|