api4 - Apply standard headers
[civicrm-core.git] / Civi / Api4 / Action / Contact / GetChecksum.php
CommitLineData
19b53e5b
C
1<?php
2
380f3545
TO
3/*
4 +--------------------------------------------------------------------+
5 | CiviCRM version 5 |
6 +--------------------------------------------------------------------+
7 | Copyright CiviCRM LLC (c) 2004-2019 |
8 +--------------------------------------------------------------------+
9 | This file is a part of CiviCRM. |
10 | |
11 | CiviCRM is free software; you can copy, modify, and distribute it |
12 | under the terms of the GNU Affero General Public License |
13 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
14 | |
15 | CiviCRM is distributed in the hope that it will be useful, but |
16 | WITHOUT ANY WARRANTY; without even the implied warranty of |
17 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
18 | See the GNU Affero General Public License for more details. |
19 | |
20 | You should have received a copy of the GNU Affero General Public |
21 | License and the CiviCRM Licensing Exception along |
22 | with this program; if not, contact CiviCRM LLC |
23 | at info[AT]civicrm[DOT]org. If you have questions about the |
24 | GNU Affero General Public License or the licensing of CiviCRM, |
25 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
26 +--------------------------------------------------------------------+
27 */
28
29/**
30 *
31 * @package CRM
32 * @copyright CiviCRM LLC (c) 2004-2019
33 * $Id$
34 *
35 */
36
37
19b53e5b
C
38namespace Civi\Api4\Action\Contact;
39
40use Civi\Api4\Generic\Result;
41
42/**
43 * Generate a security checksum for anonymous access to CiviCRM.
44 *
45 * @method $this setContactId(int $cid) Set contact ID (required)
46 * @method int getContactId() Get contact ID param
47 * @method $this setTtl(int $ttl) Set TTL param
48 * @method int getTtl() Get TTL param
49 */
50class GetChecksum extends \Civi\Api4\Generic\AbstractAction {
51
52 /**
53 * ID of contact
54 *
55 * @var int
56 * @required
57 */
58 protected $contactId;
59
60 /**
61 * Expiration time (hours). Defaults to 168 (24 * [7 or value of checksum_timeout system setting]).
62 *
63 * Set to 0 for infinite.
64 *
65 * @var int
66 */
67 protected $ttl = NULL;
68
69 /**
70 * @param \Civi\Api4\Generic\Result $result
71 */
72 public function _run(Result $result) {
73 $ttl = ($this->ttl === 0 || $this->ttl === '0') ? 'inf' : $this->ttl;
74 $result[] = [
75 'id' => $this->contactId,
76 'checksum' => \CRM_Contact_BAO_Contact_Utils::generateChecksum($this->contactId, NULL, $ttl),
77 ];
78 }
79
80}