Skip to content

Commit 52e80af

Browse files
committed
Merge branch 'develop'
2 parents 566405a + 4906cae commit 52e80af

File tree

3 files changed

+70
-7
lines changed

3 files changed

+70
-7
lines changed

src/Controller/Component/CRUDComponent.php

+56-6
Original file line numberDiff line numberDiff line change
@@ -432,9 +432,9 @@ public function add(array $params = []): void
432432
if ($metaFieldsEnabled) {
433433
$metaTemplates = $this->getMetaTemplates();
434434
$data = $this->attachMetaTemplatesIfNeeded($data, $metaTemplates->toArray());
435-
if (isset($params['afterFind'])) {
436-
$data = $params['afterFind']($data, $params);
437-
}
435+
}
436+
if (isset($params['afterFind'])) {
437+
$data = $params['afterFind']($data, $params);
438438
}
439439
if ($this->request->is('post')) {
440440
$patchEntityParams = [
@@ -458,6 +458,9 @@ public function add(array $params = []): void
458458
$massagedData = $this->massageMetaFields($data, $input, $metaTemplates);
459459
unset($input['MetaTemplates']); // Avoid MetaTemplates to be overriden when patching entity
460460
$data = $massagedData['entity'];
461+
if (isset($input['meta_fields'])) {
462+
unset($input['meta_fields']);
463+
}
461464
}
462465
$data = $this->Table->patchEntity($data, $input, $patchEntityParams);
463466
if (isset($params['beforeSave'])) {
@@ -568,10 +571,35 @@ private function saveMetaFields($id, $input)
568571
$this->Table->saveMetaFields($id, $input, $this->Table);
569572
}
570573

574+
private function handleSimpleMetaFieldInput($allMetaTemplates, $input, &$cleanupMetaFields)
575+
{
576+
$input['MetaTemplates'] = [];
577+
foreach ($input['meta_fields'] as $metaField) {
578+
foreach ($allMetaTemplates as $metaTemplate) {
579+
if ($metaTemplate->uuid != $metaField['template_uuid'] || $metaTemplate->version != $metaField['template_version']) {
580+
continue;
581+
}
582+
foreach ($metaTemplate['meta_template_fields'] as $mtp) {
583+
if ($mtp->field == $metaField['field']) {
584+
// I feel dirty. I'm sorry.
585+
$input['MetaTemplates'][$metaTemplate->id]['meta_template_fields'][$mtp->id]['metaFields']['new'][] = $metaField['value'];
586+
$cleanupMetaFields[] = [
587+
'scope' => $this->Table->getBehavior('MetaFields')->getScope(),
588+
'field' => $mtp->field,
589+
'meta_template_field_id' => $mtp->id,
590+
'meta_template_id' => $metaTemplate->id
591+
];
592+
}
593+
}
594+
}
595+
}
596+
return $input;
597+
}
598+
571599
// prune empty values and marshall fields
572-
public function massageMetaFields($entity, $input, $allMetaTemplates = [])
600+
public function massageMetaFields($entity, $input, $allMetaTemplates = [], &$cleanupMetaFields = [])
573601
{
574-
if (empty($input['MetaTemplates']) || !$this->metaFieldsSupported()) {
602+
if ((empty($input['MetaTemplates']) && !isset($input['meta_fields'])) || !$this->metaFieldsSupported()) {
575603
return ['entity' => $entity, 'metafields_to_delete' => []];
576604
}
577605

@@ -580,6 +608,11 @@ public function massageMetaFields($entity, $input, $allMetaTemplates = [])
580608
if (empty($metaTemplates)) {
581609
$allMetaTemplates = $this->getMetaTemplates()->toArray();
582610
}
611+
// handle simpler format of meta_templates via the API
612+
// the idea is that integrators shouldn't have to mimic the complex format used by the UI.
613+
if (isset($input['meta_fields'])) {
614+
$input = $this->handleSimpleMetaFieldInput($allMetaTemplates, $input, $cleanupMetaFields);
615+
}
583616
if (!empty($entity->meta_fields)) {
584617
foreach ($entity->meta_fields as $i => $metaField) {
585618
$metaFieldsIndex[$metaField->id] = $i;
@@ -738,11 +771,28 @@ public function edit(int $id, array $params = []): void
738771
throw new NotFoundException(__('Could not save {0} due to the marshaling failing. Your input is bad and you should feel bad.', $this->ObjectAlias));
739772
}
740773
}
774+
$cleanupMetaFields = [];
741775
if ($metaFieldsEnabled) {
742-
$massagedData = $this->massageMetaFields($data, $input, $metaTemplates);
776+
$massagedData = $this->massageMetaFields($data, $input, $metaTemplates, $cleanupMetaFields);
777+
if (!empty($cleanupMetaFields)) {
778+
foreach ($cleanupMetaFields as $cleanupMetaField) {
779+
$this->Table->MetaFields->deleteAll([
780+
'AND' => [
781+
'scope' => $cleanupMetaField['scope'],
782+
'field' => $cleanupMetaField['field'],
783+
'meta_template_field_id' => $cleanupMetaField['meta_template_field_id'],
784+
'meta_template_id' => $cleanupMetaField['meta_template_id'],
785+
'parent_id' => $id
786+
]
787+
]);
788+
}
789+
}
743790
unset($input['MetaTemplates']); // Avoid MetaTemplates to be overriden when patching entity
744791
$data = $massagedData['entity'];
745792
$metaFieldsToDelete = $massagedData['metafields_to_delete'];
793+
if (isset($input['meta_fields'])) {
794+
unset($input['meta_fields']);
795+
}
746796
}
747797
$data = $this->Table->patchEntity($data, $input, $patchEntityParams);
748798
if (isset($params['beforeSave'])) {

src/Controller/IndividualsController.php

+10-1
Original file line numberDiff line numberDiff line change
@@ -62,7 +62,16 @@ public function filtering()
6262

6363
public function add()
6464
{
65-
$this->CRUD->add();
65+
$currentUser = $this->ACL->getUser();
66+
$params = [
67+
'afterSave' => function($data) use ($currentUser) {
68+
if (empty($currentUser['role']['perm_community_admin'])) {
69+
$this->Individuals->Alignments->setAlignment($currentUser['organisation_id'], $data->id, 'Member');
70+
}
71+
return $data;
72+
}
73+
];
74+
$this->CRUD->add($params);
6675
$responsePayload = $this->CRUD->getResponsePayload();
6776
if (!empty($responsePayload)) {
6877
return $responsePayload;

src/Controller/UsersController.php

+4
Original file line numberDiff line numberDiff line change
@@ -156,6 +156,10 @@ public function add()
156156
if (Configure::read('keycloak.enabled')) {
157157
$this->Users->enrollUserRouter($data);
158158
}
159+
if ($data['individual_id']) {
160+
$data['individual'] = $this->Users->Individuals->find('all')->where(['id' => $data['individual_id']])->contain(['Alignments' => 'Organisations'])->first();
161+
}
162+
return $data;
159163
},
160164
'afterFind' => function ($user, &$params) use ($currentUser) {
161165
if (!empty($user)) { // We don't have a 404

0 commit comments

Comments
 (0)