123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- <?php
- /**
- * @file
- * Install file for the link module.
- */
- /**
- * Upgrade notes:
- * Things we need to make sure work when upgrading from Drupal 6 to Drupal 7:
- */
- /**
- * Implements hook_field_schema().
- */
- function link_field_schema($field) {
- return array(
- 'columns' => array(
- 'url' => array(
- 'type' => 'varchar',
- // Maximum URLs length.
- 'length' => 2048,
- 'not null' => FALSE,
- 'sortable' => TRUE,
- ),
- 'title' => array(
- 'type' => 'varchar',
- 'length' => 255,
- 'not null' => FALSE,
- 'sortable' => TRUE,
- ),
- 'attributes' => array(
- 'type' => 'text',
- 'size' => 'medium',
- 'not null' => FALSE,
- ),
- ),
- );
- }
- /**
- * Implements hook_update_last_removed().
- */
- function link_update_last_removed() {
- return 6001;
- }
- /**
- * Handles moving settings data from field_config.data to field_config_instance.data.
- */
- function link_update_7000() {
-
- // For each field that is a link field, we need to copy the settings from the general field level down to the instance.
- //$field_data = array();
- $result = db_query("SELECT id, field_name, data FROM {field_config} WHERE module = 'link' AND type = 'link_field'");
- foreach ($result as $field) {
- $field_id = $field->id;
- $name = $field->field_name;
- $field_data = unserialize($field->data);
-
- $instances = db_query("SELECT id, data FROM {field_config_instance} WHERE field_id = :field_id", array(':field_id' => $field_id));
- foreach ($instances as $instance) {
- // If this field has been updated already, we want to skip it.
- $instance_data = unserialize($instance->data);
- $update_instance = FALSE;
- if (!isset($instance_data['settings']['title'])) {
- foreach ($field_data['settings'] as $key => $value) {
- if (!isset($instance_data['settings'][$key])) {
- $instance_data['settings'][$key] = $value;
- $update_instance = TRUE;
- }
- }
- if ($update_instance) {
- // update the database.
- $num_updated = db_update('field_config_instance')
- ->fields(array('data' => serialize($instance_data)))
- ->condition('id', $instance->id)
- ->execute();
- }
- }
- }
- }
-
- return t("Instance settings have been set with the data from the field settings.");
- }
- /**
- * Renames all displays from foobar to link_foobar
- */
- function link_update_7001() {
- // Update the display type for each link field type.
- $result = db_query("SELECT id, field_name, data FROM {field_config} WHERE module = 'link' AND type = 'link_field'");
- foreach ($result as $field) {
- $field_id = $field->id;
- $name = $field->field_name;
- $field_data = unserialize($field->data);
-
- $instances = db_query("SELECT id, data FROM {field_config_instance} WHERE field_id = :field_id", array(':field_id' => $field_id));
- foreach ($instances as $instance) {
- // If this field has been updated already, we want to skip it.
- $instance_data = unserialize($instance->data);
- $update_instance = FALSE;
- foreach ($instance_data['display'] as $display_name => $display_data) {
- if ($display_data['type'] && (0 !== strpos($display_data['type'], 'link_'))) {
- $instance_data['display'][$display_name]['type'] = 'link_' . $display_data['type'];
- $update_instance = TRUE;
- }
- }
- if ($update_instance) {
- db_update('field_config_instance')
- ->fields(array('data' => serialize($instance_data)))
- ->condition('id', $instance->id)
- ->execute();
- }
- }
- }
- }
|