entity.api.php 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466
  1. <?php
  2. /**
  3. * @file
  4. * Hooks provided by the entity API.
  5. */
  6. /**
  7. * @addtogroup hooks
  8. * @{
  9. */
  10. /**
  11. * Provide an entity type via the entity CRUD API.
  12. *
  13. * This is a placeholder for describing further keys for hook_entity_info(),
  14. * which are introduced the entity API for providing a new entity type with the
  15. * entity CRUD API. For that the entity API provides two controllers:
  16. * - EntityAPIController: A regular CRUD controller.
  17. * - EntityAPIControllerExportable: Extends the regular controller to
  18. * additionally support exportable entities and/or entities making use of a
  19. * name key.
  20. * See entity_metadata_hook_entity_info() for the documentation of additional
  21. * keys for hook_entity_info() as introduced by the entity API and supported for
  22. * any entity type.
  23. *
  24. * The entity CRUD API supports the following keys:
  25. * - entity class: (optional) A class the controller will use for instantiating
  26. * entities. It is suggested to make use of the provided "Entity" class or to
  27. * extend it.
  28. * - bundle of: (optional) Entity types can be used as bundles for
  29. * other entity types. To enable this functionality, use the 'bundle of' key
  30. * to indicate which entity type this entity serves as a bundle for. But note
  31. * that the other entity type will still need to declare entities of this
  32. * type as bundles, as described by the documentation of hook_entity_info().
  33. * If the other entity type is fieldable, the entity API controller takes
  34. * care of invoking the field API bundle attachers. Note that
  35. * field_attach_delete_bundle() has to be invoked manually upon module
  36. * uninstallation. See entity_test_entity_info() and entity_test_uninstall()
  37. * for examples.
  38. * - module: (optional) The module providing the entity type. This is optional,
  39. * but strongly suggested.
  40. * - exportable: (optional) Whether the entity is exportable. Defaults to FALSE.
  41. * If enabled, a name key should be specified and db columns for the module
  42. * and status key as defined by entity_exportable_schema_fields() have to
  43. * exist in the entity's base table. Also see 'entity keys' below.
  44. * This option requires the EntityAPIControllerExportable to work.
  45. * - entity keys: An array of keys as defined by Drupal core. The following
  46. * additional keys are used by the entity CRUD API:
  47. * - name: (optional) The key of the entity property containing the unique,
  48. * machine readable name of the entity. If specified, this is used as
  49. * identifier of the entity, while the usual 'id' key is still required and
  50. * may be used when modules deal with entities generically, or to refer to
  51. * the entity internally, i.e. in the database.
  52. * If a name key is given, the name is used as entity identifier by the
  53. * entity API module, metadata wrappers and entity-type specific hooks.
  54. * However note that for consistency all generic entity hooks like
  55. * hook_entity_load() are invoked with the entities keyed by numeric id,
  56. * while entity-type specific hooks like hook_{entity_type}_load() are
  57. * invoked with the entities keyed by name.
  58. * Also, just as entity_load_single() entity_load() may be called
  59. * with names passed as the $ids parameter, while the results of
  60. * entity_load() are always keyed by numeric id. Thus, it is suggested to
  61. * make use of entity_load_multiple_by_name() to implement entity-type
  62. * specific loading functions like {entity_type}_load_multiple(), as this
  63. * function returns the entities keyed by name. See entity_test_get_types()
  64. * for an example.
  65. * For exportable entities, it is strongly recommended to make use of a
  66. * machine name as names are portable across systems.
  67. * This option requires the EntityAPIControllerExportable to work.
  68. * - module: (optional) A key for the module property used by the entity CRUD
  69. * API to save the source module name for exportable entities that have been
  70. * provided in code. Defaults to 'module'.
  71. * - status: (optional) The name of the entity property used by the entity
  72. * CRUD API to save the exportable entity status using defined bit flags.
  73. * Defaults to 'status'. See entity_has_status().
  74. * - default revision: (optional) The name of the entity property used by
  75. * the entity CRUD API to determine if a newly-created revision should be
  76. * set as the default revision. Defaults to 'default_revision'.
  77. * Note that on entity insert the created revision will be always default
  78. * regardless of the value of this entity property.
  79. * - export: (optional) An array of information used for exporting. For ctools
  80. * exportables compatibility any export-keys supported by ctools may be added
  81. * to this array too.
  82. * - default hook: What hook to invoke to find exportable entities that are
  83. * currently defined. This hook is automatically called by the CRUD
  84. * controller during entity_load(). Defaults to 'default_' . $entity_type.
  85. * - admin ui: (optional) An array of optional information used for providing an
  86. * administrative user interface. To enable the UI at least the path must be
  87. * given. Apart from that, the 'access callback' (see below) is required for
  88. * the entity, as well as the 'ENTITY_TYPE_form' for editing, adding and
  89. * cloning. The form gets the entity and the operation ('edit', 'add' or
  90. * 'clone') passed. See entity_ui_get_form() for more details.
  91. * Known keys are:
  92. * - path: A path where the UI should show up as expected by hook_menu().
  93. * - controller class: (optional) A controller class name for providing the
  94. * UI. Defaults to EntityDefaultUIController, which implements an admin UI
  95. * suiting for managing configuration entities. Other provided controllers
  96. * suiting for content entities are EntityContentUIController or
  97. * EntityBundleableUIController (which work fine despite the poorly named
  98. * 'admin ui' key).
  99. * For customizing the UI inherit from the default class and override
  100. * methods as suiting and specify your class as controller class.
  101. * - file: (optional) The name of the file in which the entity form resides
  102. * as it is required by hook_menu().
  103. * - file path: (optional) The path to the file as required by hook_menu. If
  104. * not set, it defaults to entity type's module's path, thus the entity
  105. * types 'module' key is required.
  106. * - menu wildcard: The wildcard to use in paths of the hook_menu() items.
  107. * Defaults to %entity_object which is the loader provided by Entity API.
  108. * - rules controller class: (optional) A controller class for providing Rules
  109. * integration, or FALSE to disable this feature. The given class has to
  110. * inherit from the class EntityDefaultRulesController, which serves as
  111. * default in case the entity type is not marked as configuration. For
  112. * configuration entities it defaults to FALSE.
  113. * - metadata controller class: (optional) A controller class for providing
  114. * entity property info. By default some info is generated out of the
  115. * information provided in your hook_schema() implementation, while only read
  116. * access is granted to that properties by default. Based upon that the
  117. * Entity tokens module also generates token replacements for your entity
  118. * type, once activated.
  119. * Override the controller class to adapt the defaults and to improve and
  120. * complete the generated metadata. Set it to FALSE to disable this feature.
  121. * Defaults to the EntityDefaultMetadataController class.
  122. * - extra fields controller class: (optional) A controller class for providing
  123. * field API extra fields. Defaults to none.
  124. * The class must implement the EntityExtraFieldsControllerInterface. Display
  125. * extra fields that are exposed that way are rendered by default by the
  126. * EntityAPIController. The EntityDefaultExtraFieldsController class may be
  127. * used to generate extra fields based upon property metadata, which in turn
  128. * get rendered by default by the EntityAPIController.
  129. * - features controller class: (optional) A controller class for providing
  130. * Features module integration for exportable entities. The given class has to
  131. * inherit from the default class being EntityDefaultFeaturesController. Set
  132. * it to FALSE to disable this feature.
  133. * - i18n controller class: (optional) A controller class for providing
  134. * i18n module integration for (exportable) entities. The given class has to
  135. * inherit from the class EntityDefaultI18nStringController. Defaults to
  136. * FALSE (disabled). See EntityDefaultI18nStringController for more
  137. * information.
  138. * - views controller class: (optional) A controller class for providing views
  139. * integration. The given class has to inherit from the class
  140. * EntityDefaultViewsController, which is set as default in case the providing
  141. * module has been specified (see 'module') and the module does not provide
  142. * any views integration. Else it defaults to FALSE, which disables this
  143. * feature. See EntityDefaultViewsController.
  144. * - access callback: (optional) Specify a callback that returns access
  145. * permissions for the operations 'create', 'update', 'delete' and 'view'.
  146. * The callback gets optionally the entity and the user account to check for
  147. * passed. See entity_access() for more details on the arguments and
  148. * entity_metadata_no_hook_node_access() for an example.
  149. * This is optional, but suggested for the Rules integration, and required for
  150. * the admin ui (see above).
  151. * - form callback: (optional) Specfiy a callback that returns a fully built
  152. * edit form for your entity type. See entity_form().
  153. * In case the 'admin ui' is used, no callback needs to be specified.
  154. * - entity cache: (optional) Whether entities should be cached using the cache
  155. * system. Requires the entitycache module to be installed and enabled. As
  156. * cached entities are only retrieved by id key, the cache would not apply to
  157. * exportable entities retrieved by name key. If enabled, 'field cache' is
  158. * obsolete and should be disabled. Defaults to FALSE.
  159. *
  160. * @see hook_entity_info()
  161. * @see entity_metadata_hook_entity_info()
  162. */
  163. function entity_crud_hook_entity_info() {
  164. $return = array(
  165. 'entity_test' => array(
  166. 'label' => t('Test Entity'),
  167. 'entity class' => 'Entity',
  168. 'controller class' => 'EntityAPIController',
  169. 'base table' => 'entity_test',
  170. 'module' => 'entity_test',
  171. 'fieldable' => TRUE,
  172. 'entity keys' => array(
  173. 'id' => 'pid',
  174. 'name' => 'name',
  175. 'bundle' => 'type',
  176. ),
  177. 'bundles' => array(),
  178. ),
  179. );
  180. foreach (entity_test_get_types() as $name => $info) {
  181. $return['entity_test']['bundles'][$name] = array(
  182. 'label' => $info['label'],
  183. );
  184. }
  185. return $return;
  186. }
  187. /**
  188. * Provide additional metadata for entities.
  189. *
  190. * This is a placeholder for describing further keys for hook_entity_info(),
  191. * which are introduced the entity API in order to support any entity type; e.g.
  192. * to make entity_save(), entity_create(), entity_view() and others work.
  193. * See entity_crud_hook_entity_info() for the documentation of additional keys
  194. * for hook_entity_info() as introduced by the entity API for providing new
  195. * entity types with the entity CRUD API.
  196. *
  197. * Additional keys are:
  198. * - plural label: (optional) The human-readable, plural name of the entity
  199. * type. As 'label' it should start capitalized.
  200. * - description: (optional) A human-readable description of the entity type.
  201. * - access callback: (optional) Specify a callback that returns access
  202. * permissions for the operations 'create', 'update', 'delete' and 'view'.
  203. * The callback gets optionally the entity and the user account to check for
  204. * passed. See entity_access() for more details on the arguments and
  205. * entity_metadata_no_hook_node_access() for an example.
  206. * - creation callback: (optional) A callback that creates a new instance of
  207. * this entity type. See entity_metadata_create_node() for an example.
  208. * - save callback: (optional) A callback that permanently saves an entity of
  209. * this type.
  210. * - deletion callback: (optional) A callback that permanently deletes an
  211. * entity of this type.
  212. * - revision deletion callback: (optional) A callback that deletes a revision
  213. * of the entity.
  214. * - view callback: (optional) A callback to render a list of entities.
  215. * See entity_metadata_view_node() as example.
  216. * - form callback: (optional) A callback that returns a fully built edit form
  217. * for the entity type.
  218. * - token type: (optional) A type name to use for token replacements. Set it
  219. * to FALSE if there aren't any token replacements for this entity type.
  220. * - configuration: (optional) A boolean value that specifies whether the entity
  221. * type should be considered as configuration. Modules working with entities
  222. * may use this value to decide whether they should deal with a certain entity
  223. * type. Defaults to TRUE to for entity types that are exportable, else to
  224. * FALSE.
  225. *
  226. * @see hook_entity_info()
  227. * @see entity_crud_hook_entity_info()
  228. * @see entity_access()
  229. * @see entity_create()
  230. * @see entity_save()
  231. * @see entity_delete()
  232. * @see entity_view()
  233. * @see entity_form()
  234. */
  235. function entity_metadata_hook_entity_info() {
  236. return array(
  237. 'node' => array(
  238. 'label' => t('Node'),
  239. 'access callback' => 'entity_metadata_no_hook_node_access',
  240. // ...
  241. ),
  242. );
  243. }
  244. /**
  245. * Allow modules to define metadata about entity properties.
  246. *
  247. * Modules providing properties for any entities defined in hook_entity_info()
  248. * can implement this hook to provide metadata about this properties.
  249. * For making use of the metadata have a look at the provided wrappers returned
  250. * by entity_metadata_wrapper().
  251. * For providing property information for fields see entity_hook_field_info().
  252. *
  253. * @return
  254. * An array whose keys are entity type names and whose values are arrays
  255. * containing the keys:
  256. * - properties: The array describing all properties for this entity. Entries
  257. * are keyed by the property name and contain an array of metadata for each
  258. * property. The name may only contain alphanumeric lowercase characters
  259. * and underscores. Known keys are:
  260. * - label: A human readable, translated label for the property.
  261. * - description: (optional) A human readable, translated description for
  262. * the property.
  263. * - type: The data type of the property. To make the property actually
  264. * useful it is important to map your properties to one of the known data
  265. * types, which currently are:
  266. * - text: Any text.
  267. * - token: A string containing only lowercase letters, numbers, and
  268. * underscores starting with a letter; e.g. this type is useful for
  269. * machine readable names.
  270. * - integer: A usual PHP integer value.
  271. * - decimal: A PHP float or integer.
  272. * - date: A full date and time, as timestamp.
  273. * - duration: A duration as number of seconds.
  274. * - boolean: A usual PHP boolean value.
  275. * - uri: An absolute URI or URL.
  276. * - entities - You may use the type of each entity known by
  277. * hook_entity_info(), e.g. 'node' or 'user'. Internally entities are
  278. * represented by their identifieres. In case of single-valued
  279. * properties getter callbacks may return full entity objects as well,
  280. * while a value of FALSE is interpreted like a NULL value as "property
  281. * is not set".
  282. * - entity: A special type to be used generically for entities where the
  283. * entity type is not known beforehand. The entity has to be
  284. * represented using an EntityMetadataWrapper.
  285. * - struct: This as well as any else not known type may be used for
  286. * supporting arbitrary data structures. For that additional metadata
  287. * has to be specified with the 'property info' key. New type names
  288. * have to be properly prefixed with the module name.
  289. * - list: A list of values, represented as numerically indexed array.
  290. * The list<TYPE> notation may be used to specify the type of the
  291. * contained items, where TYPE may be any valid type expression.
  292. * - bundle: (optional) If the property is an entity, you may specify the
  293. * bundle of the referenced entity.
  294. * - options list: (optional) A callback that returns a list of possible
  295. * values for the property. The callback has to return an array as
  296. * used by hook_options_list().
  297. * Note that it is possible to return a different set of options depending
  298. * whether they are used in read or in write context. See
  299. * EntityMetadataWrapper::optionsList() for more details on that.
  300. * - getter callback: (optional) A callback used to retrieve the value of
  301. * the property. Defaults to entity_property_verbatim_get().
  302. * It is important that your data is represented, as documented for your
  303. * data type, e.g. a date has to be a timestamp. Thus if necessary, the
  304. * getter callback has to do the necessary conversion. In case of an empty
  305. * or not set value, the callback has to return NULL.
  306. * - setter callback: (optional) A callback used to set the value of the
  307. * property. In many cases entity_property_verbatim_set() can be used.
  308. * - validation callback: (optional) A callback that returns whether the
  309. * passed data value is valid for the property. May be used to implement
  310. * additional validation checks, such as to ensure the value is a valid
  311. * mail address.
  312. * - access callback: (optional) An access callback to allow for checking
  313. * 'view' and 'edit' access for the described property. If no callback
  314. * is specified, a 'setter permission' may be specified instead.
  315. * - setter permission: (optional) A permission that describes whether
  316. * a user has permission to set ('edit') this property. This permission
  317. * is only be taken into account, if no 'access callback' is given.
  318. * - schema field: (optional) In case the property is directly based upon
  319. * a field specified in the entity's hook_schema(), the name of the field.
  320. * - queryable: (optional) Whether a property is queryable with
  321. * EntityFieldQuery. Defaults to TRUE if a 'schema field' is specified, or
  322. * if the deprecated 'query callback' is set to
  323. * 'entity_metadata_field_query'. Otherwise it defaults to FALSE.
  324. * - query callback: (deprecated) A callback for querying for entities
  325. * having the given property value. See entity_property_query().
  326. * Generally, properties should be queryable via EntityFieldQuery. If
  327. * that is the case, just set 'queryable' to TRUE.
  328. * - required: (optional) Whether this property is required for the creation
  329. * of a new instance of its entity. See
  330. * entity_property_values_create_entity().
  331. * - field: (optional) A boolean indicating whether a property is stemming
  332. * from a field.
  333. * - computed: (optional) A boolean indicating whether a property is
  334. * computed, i.e. the property value is not stored or loaded by the
  335. * entity's controller but determined on the fly by the getter callback.
  336. * Defaults to FALSE.
  337. * - entity views field: (optional) If enabled, the property is
  338. * automatically exposed as views field available to all views query
  339. * backends listing this entity-type. As the property value will always be
  340. * generated from a loaded entity object, this is particularly useful for
  341. * 'computed' properties. Defaults to FALSE.
  342. * - sanitized: (optional) For textual properties only, whether the text is
  343. * already sanitized. In this case you might want to also specify a raw
  344. * getter callback. Defaults to FALSE.
  345. * - sanitize: (optional) For textual properties, that are not sanitized
  346. * yet, specify a function for sanitizing the value. Defaults to
  347. * check_plain().
  348. * - raw getter callback: (optional) For sanitized textual properties, a
  349. * separate callback which can be used to retrieve the raw, unprocessed
  350. * value.
  351. * - clear: (optional) An array of property names, of which the cache should
  352. * be cleared too once this property is updated. As a rule of thumb any
  353. * duplicated properties should be avoided though.
  354. * - property info: (optional) An array of info for an arbitrary data
  355. * structure together with any else not defined type, see data type
  356. * 'struct'. Specify metadata in the same way as defined for this hook.
  357. * - property info alter: (optional) A callback for altering the property
  358. * info before it is used by the metadata wrappers.
  359. * - property defaults: (optional) An array of property info defaults for
  360. * each property derived of the wrapped data item (e.g. an entity).
  361. * Applied by the metadata wrappers.
  362. * - auto creation: (optional) Properties of type 'struct' may specify
  363. * this callback which is used to automatically create the data structure
  364. * (e.g. an array) if necessary. This is necessary in order to support
  365. * setting a property of a not yet initialized data structure.
  366. * See entity_metadata_field_file_callback() for an example.
  367. * - translatable: (optional) Whether the property is translatable, defaults
  368. * to FALSE.
  369. * - entity token: (optional) If Entity tokens module is enabled, the
  370. * module provides a token for the property if one does not exist yet.
  371. * Specify FALSE to disable this functionality for the property.
  372. * - bundles: An array keyed by bundle name containing further metadata
  373. * related to the bundles only. This array may contain the key 'properties'
  374. * with an array of info about the bundle specific properties, structured in
  375. * the same way as the entity properties array.
  376. *
  377. * @see hook_entity_property_info_alter()
  378. * @see entity_get_property_info()
  379. * @see entity_metadata_wrapper()
  380. */
  381. function hook_entity_property_info() {
  382. $info = array();
  383. $properties = &$info['node']['properties'];
  384. $properties['nid'] = array(
  385. 'label' => t("Content ID"),
  386. 'type' => 'integer',
  387. 'description' => t("The unique content ID."),
  388. );
  389. return $info;
  390. }
  391. /**
  392. * Allow modules to alter metadata about entity properties.
  393. *
  394. * @see hook_entity_property_info()
  395. */
  396. function hook_entity_property_info_alter(&$info) {
  397. $properties = &$info['node']['bundles']['poll']['properties'];
  398. $properties['poll-votes'] = array(
  399. 'label' => t("Poll votes"),
  400. 'description' => t("The number of votes that have been cast on a poll node."),
  401. 'type' => 'integer',
  402. 'getter callback' => 'entity_property_poll_node_get_properties',
  403. );
  404. }
  405. /**
  406. * Provide entity property information for fields.
  407. *
  408. * This is a placeholder for describing further keys for hook_field_info(),
  409. * which are introduced by the entity API.
  410. *
  411. * For providing entity property info for fields each field type may specify a
  412. * property type to map to using the key 'property_type'. With that info in
  413. * place useful defaults are generated, which suffice for a lot of field
  414. * types.
  415. * However it is possible to specify further callbacks that may alter the
  416. * generated property info. To do so use the key 'property_callbacks' and set
  417. * it to an array of function names. Apart from that any property info provided
  418. * for a field instance using the key 'property info' is added in too.
  419. *
  420. * @see entity_field_info_alter()
  421. * @see entity_metadata_field_text_property_callback()
  422. */
  423. function entity_hook_field_info() {
  424. return array(
  425. 'text' => array(
  426. 'label' => t('Text'),
  427. 'property_type' => 'text',
  428. // ...
  429. ),
  430. );
  431. }
  432. /**
  433. * Alter the handlers used by the data selection tables provided by this module.
  434. *
  435. * @param array $field_handlers
  436. * An array of the field handler classes to use for specific types. The keys
  437. * are the types, mapped to their respective classes. Contained types are:
  438. * - All primitive types known by the entity API (see
  439. * hook_entity_property_info()).
  440. * - options: Special type for fields having an options list.
  441. * - field: Special type for Field API fields.
  442. * - entity: Special type for entity-valued fields.
  443. * - relationship: Views relationship handler to use for relationships.
  444. * Values for all specific entity types can be additionally added.
  445. *
  446. * @see entity_views_field_definition()
  447. * @see entity_views_get_field_handlers()
  448. */
  449. function hook_entity_views_field_handlers_alter(array &$field_handlers) {
  450. $field_handlers['duration'] = 'example_duration_handler';
  451. $field_handlers['node'] = 'example_node_handler';
  452. }
  453. /**
  454. * @} End of "addtogroup hooks".
  455. */