class backup_migrate_item in Backup and Migrate 7.3
Same name and namespace in other branches
- 8.2 includes/crud.inc \backup_migrate_item
- 8.3 includes/crud.inc \backup_migrate_item
- 6.3 includes/crud.inc \backup_migrate_item
- 6.2 includes/crud.inc \backup_migrate_item
- 7.2 includes/crud.inc \backup_migrate_item
A base class for items which can be stored in the database.
Hierarchy
- class \backup_migrate_item
Expanded class hierarchy of backup_migrate_item
File
- includes/
crud.inc, line 398 - CRUD functions for backup and migrate types (schedules, profiles etc.).
View source
class backup_migrate_item {
public $show_in_list = TRUE;
public $settings_path = '/settings/';
public $db_table = '';
public $type_name = '';
public $storage = FALSE;
public $default_values = array();
public $singular = 'item';
public $plural = 'items';
public $title_plural = 'Items';
public $title_singular = 'Item';
/**
* This function is not supposed to be called.
*
* It is just here to help the po extractor out.
*/
public function strings() {
// Help the pot extractor find these strings.
t('item');
t('items');
t('Items');
t('Item');
// Help the pot extractor find these strings.
t('List !type');
t('Create !type');
t('Delete !type');
t('Edit !type');
t('Export !type');
}
/**
* Set the basic info pulled from the db or generated programatically.
*/
public function __construct($params = array()) {
$this
->from_array($this
->_merge_defaults((array) $params, (array) $this
->get_default_values()));
}
/**
* Merge parameters with the given defaults.
*
* Works like array_merge_recursive, but it doesn't turn scalar values into
* arrays.
*/
public function _merge_defaults($params, $defaults) {
foreach ($defaults as $key => $val) {
if (!isset($params[$key])) {
$params[$key] = $val;
}
elseif (is_array($params[$key])) {
$params[$key] = $this
->_merge_defaults($params[$key], $val);
}
}
return $params;
}
/**
* Get the default values for standard parameters.
*/
public function get_default_values() {
return $this->default_values;
}
/**
* Save the item to the database.
*/
public function save() {
if (!$this
->get_id()) {
$this
->unique_id();
}
$record = $this
->to_array();
drupal_write_record($this->db_table, $record, !empty($this->storage) ? $this
->get_primary_key() : array());
}
/**
* Delete the item from the database.
*/
public function delete() {
$keys = (array) $this
->get_machine_name_field();
db_query('DELETE FROM {' . $this->db_table . '} WHERE ' . $keys[0] . ' = :id', array(
':id' => $this
->get_id(),
));
}
/**
* Load an existing item from an array.
*/
public function from_array($params) {
foreach ($params as $key => $value) {
if (method_exists($this, 'set_' . $key)) {
$this
->{'set_' . $key}($value);
}
else {
$this->{$key} = $value;
}
}
}
/**
* Return as an array of values.
*/
public function to_array() {
$out = array();
// Return fields as specified in the schema.
$schema = $this
->get_schema();
if (!empty($schema['fields']) && is_array($schema['fields'])) {
foreach ($schema['fields'] as $field => $info) {
$out[$field] = $this
->get($field);
}
}
return $out;
}
/**
* Return as an exported array of values.
*/
public function export() {
$out = $this
->to_array();
$out['type_name'] = $this->type_name;
ob_start();
var_export($out);
$out = ob_get_contents();
ob_end_clean();
return $out;
}
/**
* Load an existing item from an database (serialized) array.
*/
public function load_row($data) {
$params = array();
$schema = $this
->get_schema();
// Load fields as specified in the schema.
foreach ($schema['fields'] as $field => $info) {
$params[$field] = empty($info['serialize']) ? $data[$field] : unserialize($data[$field]);
}
$this
->from_array($params);
}
/**
* Decode a loaded db row (unserialize necessary fields).
*/
public function decode_db_row($data) {
$params = array();
$schema = $this
->get_schema();
// Load fields as specified in the schema.
foreach ($schema['fields'] as $field => $info) {
$params[$field] = empty($info['serialize']) ? $data[$field] : unserialize($data[$field]);
}
return $params;
}
/**
* Return the fields which must be serialized before saving to the db.
*/
public function get_serialized_fields() {
$out = array();
$schema = $this
->get_schema();
foreach ($schema['fields'] as $field => $info) {
if (!empty($info['serialize'])) {
$out[] = $field;
}
}
return $out;
}
/**
* Get the primary key field title from the schema.
*/
public function get_primary_key() {
$schema = $this
->get_schema();
return @$schema['primary key'];
}
/**
* Get the machine name field name from the schema.
*/
public function get_machine_name_field() {
$schema = $this
->get_schema();
if (isset($schema['export']['key'])) {
return $schema['export']['key'];
}
return @$schema['primary key'];
}
/**
* Get the schema for the item type.
*/
public function get_schema() {
return drupal_get_schema($this->db_table);
}
/**
* Get the primary id for this item (if any is set).
*
* We only handle single field keys since that's all we need.
*/
public function get_id() {
$keys = (array) $this
->get_machine_name_field();
return !empty($keys[0]) && !empty($this->{$keys[0]}) ? (string) $this->{$keys[0]} : '';
}
/**
* Set the primary id for this item (if any is set).
*/
public function set_id($id) {
$keys = (array) $this
->get_machine_name_field();
if (!empty($keys[0])) {
return $this->{$keys[0]} = $id;
}
return NULL;
}
/**
* Return a random (very very likely unique) string id for a new item.
*/
public function generate_id() {
$id = md5(uniqid(mt_rand(), TRUE));
// Find the shortest possible unique id from (min 4 chars).
for ($i = 4; $i < 32; $i++) {
$new_id = substr($id, 0, $i);
if (!$this
->item($new_id)) {
return $new_id;
}
}
// If we get here, then all 28 increasingly complex ids were already taken
// so we'll try again; this could theoretially lead to an infinite loop,
// but the odds are incredibly low.
return $this
->generate_id();
}
/**
* Make sure this item has a unique id.
*
* Should only be called for new items or the item will collide with itself.
*/
public function unique_id() {
$id = $this
->get_id();
// Unset the autoincrement field so it can be regenerated.
foreach ((array) $this
->get_primary_key() as $key) {
$this->{$key} = NULL;
}
// If the item doesn't have an ID or if it's id is already taken, generate
// random one.
if (!$id || $this
->item($id)) {
$this
->set_id($this
->generate_id());
}
}
/**
* Get the name of the item.
*/
public function get_name() {
return @$this->name;
}
/**
* Get the member with the given key.
*/
public function get($key) {
if (method_exists($this, 'get_' . $key)) {
return $this
->{'get_' . $key}();
}
return @$this->{$key};
}
/**
* Get the action links for a destination.
*/
public function get_action_links() {
$out = array();
$item_id = $this
->get_id();
$path = $this
->get_settings_path();
if (@$this->storage == BACKUP_MIGRATE_STORAGE_DB || @$this->storage == BACKUP_MIGRATE_STORAGE_OVERRIDEN) {
$out['edit'] = l(t("edit"), $path . "/edit/{$item_id}");
}
elseif (@$this->storage == BACKUP_MIGRATE_STORAGE_NONE) {
$out['edit'] = l(t("override"), $path . "/edit/{$item_id}");
}
if (@$this->storage == BACKUP_MIGRATE_STORAGE_DB) {
$out['delete'] = l(t("delete"), $path . "/delete/{$item_id}");
}
elseif (@$this->storage == BACKUP_MIGRATE_STORAGE_OVERRIDEN) {
$out['delete'] = l(t("revert"), $path . "/delete/{$item_id}");
}
$out['export'] = l(t("export"), $path . "/export/{$item_id}");
return $out;
}
/**
* Get a table of all items of this type.
*/
public function get_list() {
$items = $this
->all_items();
$rows = array();
foreach ((array) $items as $item) {
if ($item
->show_in_list()) {
if ($row = $item
->get_list_row()) {
$rows[] = $row;
}
}
}
if (count($rows)) {
$out = theme('table', array(
'header' => $this
->get_list_header(),
'rows' => $rows,
));
}
else {
$out = t('There are no !items to display.', array(
'!items' => $this->plural,
));
}
if (user_access('administer backup and migrate')) {
$out .= ' ' . l(t('Create a new !item', array(
'!item' => $this->singular,
)), $this
->get_settings_path() . '/add');
}
return $out;
}
/**
* Get the columns needed to list the type.
*/
public function show_in_list() {
return $this->show_in_list;
}
/**
* Get the columns needed to list the type.
*/
public function get_settings_path() {
return BACKUP_MIGRATE_MENU_PATH . $this->settings_path . $this->type_name;
}
/**
* Get the columns needed to list the type.
*/
public function get_list_column_info() {
return array(
'actions' => array(
'title' => t('Operations'),
'html' => TRUE,
),
);
}
/**
* Get header for a lost of this type.
*/
public function get_list_header() {
$out = array();
foreach ($this
->get_list_column_info() as $key => $col) {
$out[] = $col['title'];
}
return $out;
}
/**
* Get a row of data to be used in a list of items of this type.
*/
public function get_list_row() {
$out = array();
foreach ($this
->get_list_column_info() as $key => $col) {
$out[$key] = empty($col['html']) ? check_plain($this
->get($key)) : $this
->get($key);
if (isset($col['class'])) {
$out[$key] = array(
'data' => $out[$key],
'class' => $col['class'],
);
}
}
return $out;
}
/**
* Get the rendered action links for a destination.
*/
public function get_actions() {
$links = $this
->get_action_links();
return implode(" ", $links);
}
/**
* Get the edit form for the item.
*/
public function edit_form() {
$form = array();
$form['item'] = array(
'#type' => 'value',
'#value' => $this,
);
$name = $this
->get('name');
$form['name'] = array(
"#type" => "textfield",
"#title" => t("!type name", array(
'!type' => $this->title_singular,
)),
"#default_value" => empty($name) ? t('Untitled !type', array(
'!type' => $this->title_singular,
)) : $name,
"#required" => TRUE,
);
$form['id'] = array(
'#type' => 'value',
'#value' => $this
->get_id(),
);
$form['machine_name'] = array(
'#type' => 'machine_name',
'#default_value' => $this
->get_id(),
'#maxlength' => 255,
'#machine_name' => array(
'source' => array(
'name',
),
'exists' => 'backup_migrate_crud_item_exists',
),
);
$form['actions'] = array(
'#prefix' => '<div class="container-inline">',
'#suffix' => '</div>',
'#weight' => 99,
);
$form['actions']['submit'] = array(
'#type' => 'submit',
'#value' => t('Save !type', array(
'!type' => t($this->singular),
)),
);
$form['actions']['cancel'] = array(
'#value' => l(t('Cancel'), $this
->get_settings_path()),
);
return $form;
}
/**
* Validate the edit form for the item.
*/
public function edit_form_validate($form, &$form_state) {
}
/**
* Submit the edit form for the item.
*/
public function edit_form_submit($form, &$form_state) {
$this
->from_array($form_state['values']);
$this
->save();
_backup_migrate_message('Your !type was saved', array(
'!type' => t($this->singular),
));
}
/**
* The message to send to the user when confirming the deletion of the item.
*/
public function delete_confirm_message() {
return t('Are you sure you want to delete the !type %name?', array(
'!type' => t($this->singular),
'%name' => $this
->get('name'),
));
}
/**
* The message to send to the user when confirming the deletion of the item.
*/
public function revert_confirm_message() {
return t('Are you sure you want to revert the !type %name back to the default settings?', array(
'!type' => t($this->singular),
'%name' => $this
->get('name'),
));
}
/**
* Get the menu items for manipulating this type.
*/
public function get_menu_items() {
$path = $this
->get_settings_path();
$type = $this->type_name;
$items[$path] = array(
'title' => $this->title_plural,
'page callback' => 'backup_migrate_menu_callback',
'page arguments' => array(
'crud',
'backup_migrate_crud_ui_list',
TRUE,
$this->type_name,
),
'access arguments' => array(
'administer backup and migrate',
),
'weight' => 2,
'type' => MENU_LOCAL_TASK,
);
$items[$path . '/list'] = array(
'title' => 'List !type',
'title arguments' => array(
'!type' => t($this->title_plural),
),
'weight' => 1,
'type' => MENU_DEFAULT_LOCAL_TASK,
);
$items[$path . '/add'] = array(
'title' => 'Add !type',
'title arguments' => array(
'!type' => t($this->title_singular),
),
'page callback' => 'backup_migrate_menu_callback',
'page arguments' => array(
'crud',
'backup_migrate_crud_ui_create',
TRUE,
$this->type_name,
),
'access arguments' => array(
'administer backup and migrate',
),
'weight' => 2,
'type' => MENU_LOCAL_ACTION,
);
$items[$path . '/delete'] = array(
'title' => 'Delete !type',
'title arguments' => array(
'!type' => t($this->title_singular),
),
'page callback' => 'backup_migrate_menu_callback',
'page arguments' => array(
'crud',
'backup_migrate_crud_ui_delete',
TRUE,
$this->type_name,
),
'access arguments' => array(
'administer backup and migrate',
),
'type' => MENU_CALLBACK,
);
$items[$path . '/edit'] = array(
'title' => 'Edit !type',
'title arguments' => array(
'!type' => t($this->title_singular),
),
'page callback' => 'backup_migrate_menu_callback',
'page arguments' => array(
'crud',
'backup_migrate_crud_ui_edit',
TRUE,
$this->type_name,
),
'access arguments' => array(
'administer backup and migrate',
),
'type' => MENU_CALLBACK,
);
$items[$path . '/export'] = array(
'title' => 'Export !type',
'title arguments' => array(
'!type' => t($this->title_singular),
),
'page callback' => 'backup_migrate_menu_callback',
'page arguments' => array(
'crud',
'backup_migrate_crud_ui_export',
TRUE,
$this->type_name,
),
'access arguments' => array(
'administer backup and migrate',
),
'type' => MENU_CALLBACK,
);
return $items;
}
/**
* Create a new items with the given input.
*
* Doesn't load the parameters, but could use them to determine what type to
* create.
*/
public function create($params = array()) {
$type = get_class($this);
return new $type($params);
}
/**
* Get all of the given items.
*/
public function all_items() {
$items = array();
// Get any items stored as a variable. This allows destinations to be
// defined in settings.php.
$defaults = (array) variable_get($this->db_table . '_defaults', array());
foreach ($defaults as $info) {
if (is_array($info) && ($item = $this
->create($info))) {
$items[$item
->get_id()] = $item;
}
}
// Get the items from the db.
$result = db_query("SELECT * FROM {{$this->db_table}}", array(), array(
'fetch' => PDO::FETCH_ASSOC,
));
foreach ($result as $info) {
$info = $this
->decode_db_row($info);
if ($item = $this
->create($info)) {
$item->storage = empty($items[$item
->get_id()]) ? BACKUP_MIGRATE_STORAGE_DB : BACKUP_MIGRATE_STORAGE_OVERRIDEN;
$items[$item
->get_id()] = $item;
}
}
// Allow other modules to declare destinations programatically.
$default_items = module_invoke_all($this->db_table);
// Get CTools exported versions.
if (function_exists('ctools_include')) {
ctools_include('export');
$defaults = ctools_export_load_object($this->db_table);
foreach ($defaults as $info) {
$info = (array) $info;
if (!empty($info) && ($item = $this
->create($info))) {
// If this item is not already in $default_items,
// set flag to indicate it's only there because of ctools export.
if (empty($default_items[$item
->get_id()])) {
$item->settings['ctools_export'] = TRUE;
}
$default_items[$item
->get_id()] = $item;
}
}
}
// Get any items stored as a variable again to correctly mark overrides.
$defaults = (array) variable_get($this->db_table . '_defaults', array());
foreach ($defaults as $info) {
if (is_array($info) && ($item = $this
->create($info))) {
$default_items[] = $item;
}
}
// Add the default items to the array or set the storage flag if they've
// already been overridden.
foreach ($default_items as $item) {
if (isset($items[$item
->get_id()])) {
// Items added by ctools export are not overrides.
if (empty($item->settings['ctools_export'])) {
$items[$item
->get_id()]->storage = BACKUP_MIGRATE_STORAGE_OVERRIDEN;
}
}
else {
$item->storage = BACKUP_MIGRATE_STORAGE_NONE;
$items[$item
->get_id()] = $item;
}
}
// Allow other modules to alter the items. This should maybe be before the
// db override code above but then the filters are not able to set defaults
// for missing values. Other modules should just be careful not to
// overwrite the user's UI changes in an unexpected way.
drupal_alter($this->db_table, $items);
return $items;
}
/**
* A particular item.
*/
public function item($item_id) {
$items = $this
->all_items();
return !empty($items[$item_id]) ? $items[$item_id] : NULL;
}
/**
* A particular item.
*/
public function item_exists($item_id) {
$items = $this
->all_items();
return !empty($items[$item_id]);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
backup_migrate_item:: |
public | property | 3 | |
backup_migrate_item:: |
public | property | 2 | |
backup_migrate_item:: |
public | property | 3 | |
backup_migrate_item:: |
public | property | ||
backup_migrate_item:: |
public | property | ||
backup_migrate_item:: |
public | property | 3 | |
backup_migrate_item:: |
public | property | ||
backup_migrate_item:: |
public | property | 3 | |
backup_migrate_item:: |
public | property | 3 | |
backup_migrate_item:: |
public | property | 3 | |
backup_migrate_item:: |
public | function | Get all of the given items. | |
backup_migrate_item:: |
public | function | Create a new items with the given input. | 1 |
backup_migrate_item:: |
public | function | Decode a loaded db row (unserialize necessary fields). | |
backup_migrate_item:: |
public | function | Delete the item from the database. | |
backup_migrate_item:: |
public | function | The message to send to the user when confirming the deletion of the item. | 3 |
backup_migrate_item:: |
public | function | Get the edit form for the item. | 3 |
backup_migrate_item:: |
public | function | Submit the edit form for the item. | 5 |
backup_migrate_item:: |
public | function | Validate the edit form for the item. | 4 |
backup_migrate_item:: |
public | function | Return as an exported array of values. | |
backup_migrate_item:: |
public | function | Load an existing item from an array. | |
backup_migrate_item:: |
public | function | Return a random (very very likely unique) string id for a new item. | |
backup_migrate_item:: |
public | function | Get the member with the given key. | |
backup_migrate_item:: |
public | function | Get the rendered action links for a destination. | |
backup_migrate_item:: |
public | function | Get the action links for a destination. | 1 |
backup_migrate_item:: |
public | function | Get the default values for standard parameters. | 2 |
backup_migrate_item:: |
public | function | Get the primary id for this item (if any is set). | |
backup_migrate_item:: |
public | function | Get a table of all items of this type. | 1 |
backup_migrate_item:: |
public | function | Get the columns needed to list the type. | 3 |
backup_migrate_item:: |
public | function | Get header for a lost of this type. | |
backup_migrate_item:: |
public | function | Get a row of data to be used in a list of items of this type. | 2 |
backup_migrate_item:: |
public | function | Get the machine name field name from the schema. | |
backup_migrate_item:: |
public | function | Get the menu items for manipulating this type. | 2 |
backup_migrate_item:: |
public | function | Get the name of the item. | 1 |
backup_migrate_item:: |
public | function | Get the primary key field title from the schema. | |
backup_migrate_item:: |
public | function | Get the schema for the item type. | |
backup_migrate_item:: |
public | function | Return the fields which must be serialized before saving to the db. | |
backup_migrate_item:: |
public | function | Get the columns needed to list the type. | 1 |
backup_migrate_item:: |
public | function | A particular item. | |
backup_migrate_item:: |
public | function | A particular item. | |
backup_migrate_item:: |
public | function | Load an existing item from an database (serialized) array. | |
backup_migrate_item:: |
public | function | The message to send to the user when confirming the deletion of the item. | |
backup_migrate_item:: |
public | function | Save the item to the database. | |
backup_migrate_item:: |
public | function | Set the primary id for this item (if any is set). | |
backup_migrate_item:: |
public | function | Get the columns needed to list the type. | |
backup_migrate_item:: |
public | function | This function is not supposed to be called. | 3 |
backup_migrate_item:: |
public | function | Return as an array of values. | 1 |
backup_migrate_item:: |
public | function | Make sure this item has a unique id. | |
backup_migrate_item:: |
public | function | Merge parameters with the given defaults. | |
backup_migrate_item:: |
public | function | Set the basic info pulled from the db or generated programatically. | 5 |