CRM-19925 Add Entity data and date format data to fields array on DAO.
[civicrm-core.git] / CRM / Core / DAO / Managed.php
CommitLineData
e501603b
TO
1<?php
2/*
3+--------------------------------------------------------------------+
4| CiviCRM version 4.7 |
5+--------------------------------------------------------------------+
0f03f337 6| Copyright CiviCRM LLC (c) 2004-2017 |
e501603b
TO
7+--------------------------------------------------------------------+
8| This file is a part of CiviCRM. |
9| |
10| CiviCRM is free software; you can copy, modify, and distribute it |
11| under the terms of the GNU Affero General Public License |
12| Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
13| |
14| CiviCRM is distributed in the hope that it will be useful, but |
15| WITHOUT ANY WARRANTY; without even the implied warranty of |
16| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
17| See the GNU Affero General Public License for more details. |
18| |
19| You should have received a copy of the GNU Affero General Public |
20| License and the CiviCRM Licensing Exception along |
21| with this program; if not, contact CiviCRM LLC |
22| at info[AT]civicrm[DOT]org. If you have questions about the |
23| GNU Affero General Public License or the licensing of CiviCRM, |
24| see the CiviCRM license FAQ at http://civicrm.org/licensing |
25+--------------------------------------------------------------------+
26*/
27/**
28 * @package CRM
0f03f337 29 * @copyright CiviCRM LLC (c) 2004-2017
e501603b
TO
30 *
31 * Generated from xml/schema/CRM/Core/Managed.xml
32 * DO NOT EDIT. Generated by CRM_Core_CodeGen
437fafcf 33 * (GenCodeChecksum:c6ff05c82573ab973ddae2bd839a5a6d)
e501603b
TO
34 */
35require_once 'CRM/Core/DAO.php';
36require_once 'CRM/Utils/Type.php';
f41f0342 37/**
38 * CRM_Core_DAO_Managed constructor.
39 */
e501603b
TO
40class CRM_Core_DAO_Managed extends CRM_Core_DAO {
41 /**
f41f0342 42 * Static instance to hold the table name.
e501603b
TO
43 *
44 * @var string
45 */
46 static $_tableName = 'civicrm_managed';
e501603b 47 /**
f41f0342 48 * Should CiviCRM log any modifications to this table in the civicrm_log table.
e501603b
TO
49 *
50 * @var boolean
51 */
52 static $_log = false;
53 /**
54 * Surrogate Key
55 *
56 * @var int unsigned
57 */
58 public $id;
59 /**
60 * Name of the module which declared this object
61 *
62 * @var string
63 */
64 public $module;
65 /**
66 * Symbolic name used by the module to identify the object
67 *
68 * @var string
69 */
70 public $name;
71 /**
72 * API entity type
73 *
74 * @var string
75 */
76 public $entity_type;
77 /**
78 * Foreign key to the referenced item.
79 *
80 * @var int unsigned
81 */
82 public $entity_id;
83 /**
84 * Policy on when to cleanup entity (always, never, unused)
85 *
86 * @var string
87 */
88 public $cleanup;
89 /**
f41f0342 90 * Class constructor.
e501603b
TO
91 */
92 function __construct() {
93 $this->__table = 'civicrm_managed';
94 parent::__construct();
95 }
96 /**
97 * Returns all the column names of this table
98 *
99 * @return array
100 */
101 static function &fields() {
346aaaba
TO
102 if (!isset(Civi::$statics[__CLASS__]['fields'])) {
103 Civi::$statics[__CLASS__]['fields'] = array(
e501603b
TO
104 'id' => array(
105 'name' => 'id',
106 'type' => CRM_Utils_Type::T_INT,
107 'title' => ts('Managed ID') ,
108 'description' => 'Surrogate Key',
109 'required' => true,
110 ) ,
111 'module' => array(
112 'name' => 'module',
113 'type' => CRM_Utils_Type::T_STRING,
114 'title' => ts('Module') ,
115 'description' => 'Name of the module which declared this object',
116 'required' => true,
117 'maxlength' => 127,
118 'size' => CRM_Utils_Type::HUGE,
119 ) ,
120 'name' => array(
121 'name' => 'name',
122 'type' => CRM_Utils_Type::T_STRING,
123 'title' => ts('Name') ,
124 'description' => 'Symbolic name used by the module to identify the object',
125 'maxlength' => 127,
126 'size' => CRM_Utils_Type::HUGE,
127 ) ,
128 'entity_type' => array(
129 'name' => 'entity_type',
130 'type' => CRM_Utils_Type::T_STRING,
131 'title' => ts('Entity Type') ,
132 'description' => 'API entity type',
133 'required' => true,
134 'maxlength' => 64,
135 'size' => CRM_Utils_Type::BIG,
136 ) ,
137 'entity_id' => array(
138 'name' => 'entity_id',
139 'type' => CRM_Utils_Type::T_INT,
140 'title' => ts('Entity ID') ,
141 'description' => 'Foreign key to the referenced item.',
142 'required' => true,
143 ) ,
144 'cleanup' => array(
145 'name' => 'cleanup',
146 'type' => CRM_Utils_Type::T_STRING,
147 'title' => ts('Cleanup Setting') ,
148 'description' => 'Policy on when to cleanup entity (always, never, unused)',
149 'maxlength' => 32,
150 'size' => CRM_Utils_Type::MEDIUM,
151 'html' => array(
152 'type' => 'Select',
153 ) ,
154 'pseudoconstant' => array(
155 'callback' => 'CRM_Core_ManagedEntities::getCleanupOptions',
156 )
157 ) ,
158 );
346aaaba 159 CRM_Core_DAO_AllCoreTables::invoke(__CLASS__, 'fields_callback', Civi::$statics[__CLASS__]['fields']);
e501603b 160 }
346aaaba 161 return Civi::$statics[__CLASS__]['fields'];
e501603b
TO
162 }
163 /**
bd8e0b14 164 * Return a mapping from field-name to the corresponding key (as used in fields()).
e501603b
TO
165 *
166 * @return array
bd8e0b14 167 * Array(string $name => string $uniqueName).
e501603b
TO
168 */
169 static function &fieldKeys() {
bd8e0b14
TO
170 if (!isset(Civi::$statics[__CLASS__]['fieldKeys'])) {
171 Civi::$statics[__CLASS__]['fieldKeys'] = array_flip(CRM_Utils_Array::collect('name', self::fields()));
e501603b 172 }
bd8e0b14 173 return Civi::$statics[__CLASS__]['fieldKeys'];
e501603b
TO
174 }
175 /**
176 * Returns the names of this table
177 *
178 * @return string
179 */
180 static function getTableName() {
181 return self::$_tableName;
182 }
183 /**
184 * Returns if this table needs to be logged
185 *
186 * @return boolean
187 */
188 function getLog() {
189 return self::$_log;
190 }
191 /**
192 * Returns the list of fields that can be imported
193 *
194 * @param bool $prefix
195 *
196 * @return array
197 */
198 static function &import($prefix = false) {
60808919
TO
199 $r = CRM_Core_DAO_AllCoreTables::getImports(__CLASS__, 'managed', $prefix, array());
200 return $r;
e501603b
TO
201 }
202 /**
203 * Returns the list of fields that can be exported
204 *
205 * @param bool $prefix
206 *
207 * @return array
208 */
209 static function &export($prefix = false) {
60808919
TO
210 $r = CRM_Core_DAO_AllCoreTables::getExports(__CLASS__, 'managed', $prefix, array());
211 return $r;
e501603b
TO
212 }
213}