class MigrateDestinationFlagSimple in Migrate Extras 7.2
Same name and namespace in other branches
- 6.2 flag.inc \MigrateDestinationFlagSimple
Destination class implementing when you want just an insert into flag_content table.
Hierarchy
- class \MigrateDestination
- class \MigrateDestinationFlagSimple
Expanded class hierarchy of MigrateDestinationFlagSimple
File
- ./
flag.inc, line 11 - Flag module integration
View source
class MigrateDestinationFlagSimple extends MigrateDestination {
public function __construct($fid) {
parent::__construct();
$this->fid = $fid;
}
public function __toString() {
$flag = flag_get_flag(NULL, $this->fid);
return t('flag (!flag)', array(
'!flag' => $flag->name,
));
}
public static function getKeySchema() {
return array(
'fcid' => array(
'type' => 'int',
'not null' => TRUE,
),
);
}
/**
* Delete a membership.
*
* @param $id
* IDs to be deleted.
*/
public function bulkRollback(array $ids) {
migrate_instrument_start(__METHOD__);
db_delete('flag_content')
->condition('fcid', $ids, 'IN')
->execute();
migrate_instrument_stop(__METHOD__);
}
/**
* Import a single flag_content.
*
* @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) {
if (isset($entity->timestamp)) {
$entity->timestamp = Migration::timestamp($entity->timestamp);
}
$entity->fid = $this->fid;
if (!empty($entity->fcid)) {
$return = drupal_write_record('flag_content', $entity, 'fcid');
}
else {
$return = drupal_write_record('flag_content', $entity);
}
if ($return) {
// Update the flag_counts table.
$count = db_select('flag_content')
->fields('flag_content')
->condition('fid', $this->fid)
->condition('content_type', $entity->content_type)
->condition('content_id', $entity->content_id)
->countQuery()
->execute()
->fetchField();
db_merge('flag_counts')
->key(array(
'fid' => $this->fid,
'content_id' => $entity->content_id,
))
->fields(array(
'content_type' => $entity->content_type,
'count' => $count,
'last_updated' => REQUEST_TIME,
))
->execute();
return array(
$entity->fcid,
);
}
}
public function fields() {
return array(
'fcid' => 'Flag content ID',
'fid' => 'Flag ID',
'content_type' => '',
'content_id' => '',
'uid' => 'User ID',
'timestamp' => '',
);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
MigrateDestination:: |
protected | property | Maintain stats on the number of destination objects created or updated. | |
MigrateDestination:: |
protected | property | ||
MigrateDestination:: |
public | function | ||
MigrateDestination:: |
public | function | ||
MigrateDestination:: |
public | function | Reset numCreated and numUpdated back to 0. | |
MigrateDestinationFlagSimple:: |
public | function | Delete a membership. | |
MigrateDestinationFlagSimple:: |
public | function |
Derived classes must implement fields(), returning a list of available
destination fields. Overrides MigrateDestination:: |
|
MigrateDestinationFlagSimple:: |
public static | function | ||
MigrateDestinationFlagSimple:: |
public | function |
Import a single flag_content. Overrides MigrateDestination:: |
|
MigrateDestinationFlagSimple:: |
public | function |
Null constructor Overrides MigrateDestination:: |
|
MigrateDestinationFlagSimple:: |
public | function |
Derived classes must implement __toString(). Overrides MigrateDestination:: |