Merge pull request #15986 from civicrm/5.20
[civicrm-core.git] / Civi / Api4 / Service / Spec / Provider / MappingCreationSpecProvider.php
CommitLineData
19b53e5b
C
1<?php
2
380f3545
TO
3/*
4 +--------------------------------------------------------------------+
41498ac5 5 | Copyright CiviCRM LLC. All rights reserved. |
380f3545 6 | |
41498ac5
TO
7 | This work is published under the GNU AGPLv3 license with some |
8 | permitted exceptions and without any warranty. For full license |
9 | and copyright information, see https://civicrm.org/licensing |
380f3545
TO
10 +--------------------------------------------------------------------+
11 */
12
13/**
14 *
15 * @package CRM
ca5cec67 16 * @copyright CiviCRM LLC https://civicrm.org/licensing
380f3545
TO
17 * $Id$
18 *
19 */
20
21
19b53e5b
C
22namespace Civi\Api4\Service\Spec\Provider;
23
24use Civi\Api4\Service\Spec\RequestSpec;
25
26class MappingCreationSpecProvider implements Generic\SpecProviderInterface {
27
28 /**
29 * This function runs for both Mapping and MappingField entities
30 *
31 * @param \Civi\Api4\Service\Spec\RequestSpec $spec
32 */
33 public function modifySpec(RequestSpec $spec) {
34 $spec->getFieldByName('name')->setRequired(TRUE);
35 }
36
37 /**
38 * @param string $entity
39 * @param string $action
40 *
41 * @return bool
42 */
43 public function applies($entity, $action) {
44 return strpos($entity, 'Mapping') === 0 && $action === 'create';
45 }
46
47}