You are here

class RedhenOrgEntityController in RedHen CRM 7

The controller class for orgs contains methods for the org CRUD operations. The load method is inherited from the default controller.

Hierarchy

Expanded class hierarchy of RedhenOrgEntityController

1 string reference to 'RedhenOrgEntityController'
redhen_org_entity_info in modules/redhen_org/redhen_org.module
Implements hook_entity_info().

File

modules/redhen_org/lib/redhen_org.controller.inc, line 11
The controller for the org entity containing the CRUD operations.

View source
class RedhenOrgEntityController extends EntityAPIController {

  /**
   * Saves an org.
   *
   * @param RedhenOrg $org
   *   The full org object to save.
   *
   * @return RedhenOrg
   *   The saved org object.
   */
  public function save($org, DatabaseTransaction $transaction = NULL) {
    $org->updated = REQUEST_TIME;

    // New org, set created prop.
    if (isset($org->is_new) && $org->is_new) {
      $org->created = REQUEST_TIME;
    }
    else {
      if (!isset($org->is_new_revision)) {
        $org->is_new_revision = TRUE;
      }
      if (!isset($org->default_revision)) {
        $org->default_revision = TRUE;
      }
    }
    parent::save($org);
    return $org;
  }

  /**
   * Deletes multiple orgs by id.
   *
   * @param array $org_ids
   *   An array of org IDs to delete.
   * @param DatabaseTransaction $transaction
   *   DB transaction object.
   *
   * @return bool
   *   TRUE on success, FALSE otherwise.
   *
   * @throws Exception
   */
  public function delete($org_ids, DatabaseTransaction $transaction = NULL) {
    if (!empty($org_ids)) {
      $orgs = $this
        ->load($org_ids, array());

      // Ensure the orgs can actually be deleted.
      foreach ((array) $orgs as $org_id => $org) {
        if (in_array(FALSE, module_invoke_all('redhen_org_can_delete', $org))) {
          unset($orgs[$org_id]);
        }
        else {
          module_invoke_all('redhen_entity_predelete', $org, 'redhen_org');
        }
      }
      $transaction = db_transaction();
      try {
        parent::delete($org_ids, $transaction);
      } catch (Exception $e) {
        if (isset($transaction)) {
          $transaction
            ->rollback();
        }
        watchdog_exception($this->entityType, $e);
        throw $e;
      }
    }
    return TRUE;
  }

}

Members

Namesort descending Modifiers Type Description Overrides
DrupalDefaultEntityController::$cache protected property Whether this entity type should use the static cache.
DrupalDefaultEntityController::$entityCache protected property Static cache of entities, keyed by entity ID.
DrupalDefaultEntityController::$entityInfo protected property Array of information about the entity.
DrupalDefaultEntityController::$entityType protected property Entity type for this controller instance.
DrupalDefaultEntityController::$hookLoadArguments protected property Additional arguments to pass to hook_TYPE_load().
DrupalDefaultEntityController::$idKey protected property Name of the entity's ID field in the entity database table.
DrupalDefaultEntityController::$revisionKey protected property Name of entity's revision database table field, if it supports revisions.
DrupalDefaultEntityController::$revisionTable protected property The table that stores revisions, if the entity supports revisions.
DrupalDefaultEntityController::attachLoad protected function Attaches data to entities upon loading. 4
DrupalDefaultEntityController::cacheGet protected function Gets entities from the static cache. 1
DrupalDefaultEntityController::cacheSet protected function Stores entities in the static entity cache.
DrupalDefaultEntityController::cleanIds protected function Ensures integer entity IDs are valid.
DrupalDefaultEntityController::filterId protected function Callback for array_filter that removes non-integer IDs.
EntityAPIController::$bundleKey protected property
EntityAPIController::$cacheComplete protected property
EntityAPIController::$defaultRevisionKey protected property
EntityAPIController::buildContent public function Implements EntityAPIControllerInterface. Overrides EntityAPIControllerInterface::buildContent
EntityAPIController::buildQuery protected function Overrides DrupalDefaultEntityController::buildQuery(). Overrides DrupalDefaultEntityController::buildQuery 1
EntityAPIController::create public function Implements EntityAPIControllerInterface. Overrides EntityAPIControllerInterface::create
EntityAPIController::deleteRevision public function Implements EntityAPIControllerRevisionableInterface::deleteRevision(). Overrides EntityAPIControllerRevisionableInterface::deleteRevision
EntityAPIController::export public function Implements EntityAPIControllerInterface. Overrides EntityAPIControllerInterface::export 1
EntityAPIController::import public function Implements EntityAPIControllerInterface. Overrides EntityAPIControllerInterface::import
EntityAPIController::invoke public function Implements EntityAPIControllerInterface. Overrides EntityAPIControllerInterface::invoke 1
EntityAPIController::load public function Overridden. Overrides DrupalDefaultEntityController::load 1
EntityAPIController::query public function Builds and executes the query for loading.
EntityAPIController::renderEntityProperty protected function Renders a single entity property.
EntityAPIController::resetCache public function Overrides DrupalDefaultEntityController::resetCache(). Overrides DrupalDefaultEntityController::resetCache 1
EntityAPIController::saveRevision protected function Saves an entity revision.
EntityAPIController::view public function Implements EntityAPIControllerInterface. Overrides EntityAPIControllerInterface::view 1
EntityAPIController::__construct public function Overridden. Overrides DrupalDefaultEntityController::__construct 1
RedhenOrgEntityController::delete public function Deletes multiple orgs by id. Overrides EntityAPIController::delete
RedhenOrgEntityController::save public function Saves an org. Overrides EntityAPIController::save