You are here

class MigrateDestinationUserRelationships in Migrate Extras 6.2

Same name and namespace in other branches
  1. 7.2 user_relationships.inc \MigrateDestinationUserRelationships

Destination class implementing migration into user_relationships table.

Hierarchy

Expanded class hierarchy of MigrateDestinationUserRelationships

File

./user_relationships.inc, line 13
Import User Relationships.

View source
class MigrateDestinationUserRelationships extends MigrateDestination {
  public function __construct($rtid) {
    parent::__construct();
    $this->rtid = $rtid;
  }
  public function __toString() {
    $reltype = user_relationships_type_load($this->rtid);
    return t('User relationship type: !type', array(
      '!type' => $reltype->name,
    ));
  }
  public static function getKeySchema() {
    return array(
      'rid' => array(
        'type' => 'int',
        'not null' => TRUE,
        'description' => 'Relationship ID',
      ),
    );
  }

  /**
   * Delete a membership.
   *
   * @param $migration
   *  Controlling migration object. Unused here.
   * @param $id
   *  ID to be deleted.
   */
  public function rollback(array $id) {
    migrate_instrument_start(__METHOD__);
    if ($relationship = user_relationships_load(array(
      'rid' => $id['destid1'],
    ))) {
      $account = new stdClass();
      user_relationships_delete_relationship(current($relationship), $account);
    }
    migrate_instrument_stop(__METHOD__);
  }

  /**
   * Import a single membership.
   *
   * @param $entity
   *  Object object to build. Prefilled with any fields mapped in the Migration.
   * @param $row
   *  Raw source data object - passed through to prepare/complete handlers.
   * @return array
   *  Array of key fields of the object that was saved if
   *  successful. FALSE on failure.
   */
  public function import(stdClass $entity, stdClass $row) {

    // TODO: handle updates
    foreach (array(
      'created_at',
      'updated_at',
    ) as $property) {
      if (isset($entity->{$property})) {
        $entity->{$property} = Migration::timestamp($entity->{$property});
      }
    }
    $entity->rtid = $this->rtid;
    $op = isset($entity->op) ? $entity->op : 'approve';
    if (user_relationships_save_relationship($entity, $op)) {
      return array(
        $entity->rid,
      );
    }
  }
  public function fields() {
    return array(
      'rid' => 'Relationship ID',
      'requester_id' => '',
      'requestee_id' => '',
      'approved' => '',
      'created_at' => '',
      'updated_at' => '',
      'flags' => '',
      'op' => '',
    );
  }

}

Members

Namesort descending Modifiers Type Description Overrides
MigrateDestination::$numCreated protected property Maintain stats on the number of destination objects created or updated.
MigrateDestination::$numUpdated protected property
MigrateDestination::getCreated public function
MigrateDestination::getUpdated public function
MigrateDestination::resetStats public function Reset numCreated and numUpdated back to 0.
MigrateDestinationUserRelationships::fields public function Derived classes must implement fields(), returning a list of available destination fields. Overrides MigrateDestination::fields
MigrateDestinationUserRelationships::getKeySchema public static function
MigrateDestinationUserRelationships::import public function Import a single membership. Overrides MigrateDestination::import
MigrateDestinationUserRelationships::rollback public function Delete a membership.
MigrateDestinationUserRelationships::__construct public function Null constructor Overrides MigrateDestination::__construct
MigrateDestinationUserRelationships::__toString public function Derived classes must implement __toString(). Overrides MigrateDestination::__toString