123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500 |
- <?php
- /**
- * @file
- * Installation functions for Entity Translation module.
- */
- /**
- * Implements hook_schema().
- */
- function entity_translation_schema() {
- $schema = array();
- $schema['entity_translation'] = array(
- 'description' => 'Table to track entity translations',
- 'fields' => array(
- 'entity_type' => array(
- 'type' => 'varchar',
- 'length' => 128,
- 'not null' => TRUE,
- 'default' => '',
- 'description' => 'The entity type this translation relates to',
- ),
- 'entity_id' => array(
- 'type' => 'int',
- 'unsigned' => TRUE,
- 'not null' => TRUE,
- 'description' => 'The entity id this translation relates to',
- ),
- 'revision_id' => array(
- 'type' => 'int',
- 'unsigned' => TRUE,
- 'not null' => TRUE,
- 'description' => 'The entity revision id this translation relates to',
- ),
- 'language' => array(
- 'type' => 'varchar',
- 'length' => 32,
- 'not null' => TRUE,
- 'default' => '',
- 'description' => 'The target language for this translation.',
- ),
- 'source' => array(
- 'type' => 'varchar',
- 'length' => 32,
- 'not null' => TRUE,
- 'default' => '',
- 'description' => 'The source language from which this translation was created.',
- ),
- 'uid' => array(
- 'description' => 'The author of this translation.',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 0,
- ),
- 'status' => array(
- 'description' => 'Boolean indicating whether the translation is published (visible to non-administrators).',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 1,
- ),
- 'translate' => array(
- 'description' => 'A boolean indicating whether this translation needs to be updated.',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 0,
- ),
- 'created' => array(
- 'description' => 'The Unix timestamp when the translation was created.',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 0,
- ),
- 'changed' => array(
- 'description' => 'The Unix timestamp when the translation was most recently saved.',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 0,
- ),
- ),
- 'primary key' => array('entity_type', 'entity_id', 'language'),
- );
- $schema['entity_translation_revision'] = array(
- 'description' => 'Table to track entity translation revisions',
- 'fields' => array(
- 'entity_type' => array(
- 'type' => 'varchar',
- 'length' => 128,
- 'not null' => TRUE,
- 'default' => '',
- 'description' => 'The entity type this translation revision relates to',
- ),
- 'entity_id' => array(
- 'type' => 'int',
- 'unsigned' => TRUE,
- 'not null' => TRUE,
- 'description' => 'The entity id this translation revision relates to',
- ),
- 'revision_id' => array(
- 'type' => 'int',
- 'unsigned' => TRUE,
- 'not null' => TRUE,
- 'description' => 'The entity revision id this translation relates to',
- ),
- 'language' => array(
- 'type' => 'varchar',
- 'length' => 32,
- 'not null' => TRUE,
- 'default' => '',
- 'description' => 'The target language for this translation revision.',
- ),
- 'source' => array(
- 'type' => 'varchar',
- 'length' => 32,
- 'not null' => TRUE,
- 'default' => '',
- 'description' => 'The source language from which this translation revision was created.',
- ),
- 'uid' => array(
- 'description' => 'The author of this translation revision.',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 0,
- ),
- 'status' => array(
- 'description' => 'Boolean indicating whether the translation revision is published (visible to non-administrators).',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 1,
- ),
- 'translate' => array(
- 'description' => 'A boolean indicating whether this translation revision needs to be updated.',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 0,
- ),
- 'created' => array(
- 'description' => 'The Unix timestamp when the translation revision was created.',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 0,
- ),
- 'changed' => array(
- 'description' => 'The Unix timestamp when the translation revision was most recently saved.',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 0,
- ),
- ),
- 'primary key' => array('entity_type', 'revision_id', 'language'),
- 'indexes'=> array('revision_id' => array('revision_id')),
- );
- return $schema;
- }
- /**
- * Implements hook_install().
- */
- function entity_translation_install() {
- // entity_translation_form_alter() needs to run after locale_form_alter() and
- // translation_menu(); entity_translation_menu_alter() needs to run after
- // i18n_node_menu_alter().
- db_update('system')
- ->fields(array('weight' => 11))
- ->condition('name', 'entity_translation')
- ->execute();
- // Enable translation for nodes.
- variable_set('entity_translation_entity_types', array('node' => 'node'));
- // Make translation use the content language type.
- variable_set('translation_language_type', LANGUAGE_TYPE_CONTENT);
- // Enable revision support for entity translation.
- variable_set('entity_translation_revision_enabled', TRUE);
- // Enable taxonomy autocomplete support.
- variable_set('entity_translation_taxonomy_autocomplete', TRUE);
- }
- /**
- * Grant 'edit $type original values' permission to existing roles.
- */
- function _entity_translation_grant_edit_permissions() {
- variable_set('entity_translation_workflow_enabled', TRUE);
- $permissions = array();
- // Nodes.
- $permissions['node'][] = 'bypass node access';
- foreach (node_permissions_get_configured_types() as $type) {
- $permissions['node'][] = "edit own $type content";
- $permissions['node'][] = "edit any $type content";
- }
- // Comments.
- if (module_exists('comment')) {
- $permissions['comment'][] = 'administer comments';
- $permissions['comment'][] = 'edit own comments';
- }
- // Taxonomy terms.
- if (module_exists('taxonomy')) {
- $permissions['taxonomy_term'][] = 'administer taxonomy';
- foreach (taxonomy_get_vocabularies() as $vocabulary) {
- $permissions['taxonomy_term'][] = "edit terms in {$vocabulary->vid}";
- }
- }
- $assignments = array();
- foreach ($permissions as $entity_type => $permissions_filter) {
- if (entity_translation_enabled($entity_type)) {
- $permission = "edit $entity_type original values";
- $assignments[] = _entity_translation_grant_permission($permission, $permissions_filter);
- $permission = "edit $entity_type translation shared fields";
- $assignments[] = _entity_translation_grant_permission($permission, $permissions_filter);
- }
- }
- $assignments = '<ul><li>' . implode('</li><li>', $assignments) . '</li></ul>';
- $t = get_t();
- return $t('The following permissions have been assigned to existing roles: !assignments', array('!assignments' => $assignments));
- }
- /**
- * Grant the given permission to all roles which already have any of the
- * permissions specified in the $permissions_filter parameter.
- *
- * @param $permission
- * The new permission which to grant.
- * @param $permissions_filter
- * List of permissions used for loading roles.
- *
- * @return
- * A message describing permission changes.
- */
- function _entity_translation_grant_permission($permission, $permissions_filter = NULL) {
- $roles = user_roles(FALSE, $permissions_filter);
- foreach ($roles as $rid => $role) {
- user_role_grant_permissions($rid, array($permission));
- }
- $t = get_t();
- return $t('%permission was assigned to %roles', array(
- '%permission' => $permission,
- '%roles' => implode(', ', $roles)
- ));
- }
- /**
- * Implements hook_enable().
- */
- function entity_translation_enable() {
- // Re-activate entity translation for content types which had used it when
- // the module was last disabled (if any), unless these have since been altered
- // by the user to use a different translation option.
- $entity_translation_types = variable_get('entity_translation_disabled_content_types', array());
- foreach ($entity_translation_types as $index => $type) {
- if (variable_get("language_content_type_$type", 0) == 0) {
- variable_set("language_content_type_$type", ENTITY_TRANSLATION_ENABLED);
- }
- // We should show the warning only if we actually restored at least one
- // content type.
- else {
- unset($entity_translation_types[$index]);
- }
- }
- if ($entity_translation_types) {
- drupal_set_message(t('All content types previously configured to use field translation are now using it again.'), 'warning');
- }
- variable_del('entity_translation_disabled_content_types');
- }
- /**
- * Implements hook_disable().
- */
- function entity_translation_disable() {
- // Store record of which types are using entity translation, and set those
- // types to not be translated. These content types will be reset to use entity
- // translation again if the module is later re-enabled, unless they have been
- // changed by the user in the meantime.
- $entity_translation_types = array();
- foreach (node_type_get_types() as $type => $object) {
- if (variable_get("language_content_type_$type", 0) == ENTITY_TRANSLATION_ENABLED) {
- $entity_translation_types[] = $type;
- variable_set("language_content_type_$type", 0);
- }
- }
- if ($entity_translation_types) {
- variable_set('entity_translation_disabled_content_types', $entity_translation_types);
- drupal_set_message(t('All content types configured to use field translation now have multilingual support disabled. This change will be reverted if the entity translation module is enabled again.'), 'warning');
- }
- }
- /**
- * Implements hook_uninstall().
- */
- function entity_translation_uninstall() {
- db_delete('variable')
- ->condition('name', db_like('entity_translation_') . '%', 'LIKE')
- ->execute();
- variable_del('translation_language_type');
- variable_del('locale_field_language_fallback');
- }
- /**
- * Implements hook_update_N().
- */
- function entity_translation_update_7001() {
- db_update('system')
- ->fields(array('weight' => 11))
- ->condition('name', 'entity_translation')
- ->execute();
- }
- /**
- * Grant 'edit original values' and 'edit shared field' permissions to roles which have entity editing permissions.
- */
- function entity_translation_update_7002() {
- // Grant the 'edit original values' permission, so we don't break editing on
- // existing sites.
- return _entity_translation_grant_edit_permissions();
- }
- /**
- * Configure node and comment language settings to the prior default behavior.
- */
- function entity_translation_update_7003() {
- module_load_include('inc', 'entity_translation', 'entity_translation.admin');
- foreach (array_keys(entity_get_info()) as $entity_type) {
- entity_translation_settings_init($entity_type);
- }
- }
- /**
- * Rebuild entity information to update the path scheme settings.
- */
- function entity_translation_update_7004() {
- entity_info_cache_clear();
- }
- /**
- * Rebuild the class registry to pick up the translation handler factory class.
- */
- function entity_translation_update_7005() {
- registry_rebuild();
- }
- /**
- * Add revision schema for entity translation metadata.
- */
- function entity_translation_update_7006() {
- // Create revision id column.
- $spec = array(
- 'type' => 'int',
- 'unsigned' => TRUE,
- // If we have existing data we cannot enforce this to be NOT NULL.
- 'not null' => FALSE,
- 'description' => 'The entity revision id this translation relates to',
- );
- // Create revision id column if it doesn't exist already.
- if (!db_field_exists('entity_translation', 'revision_id')) {
- db_add_field('entity_translation', 'revision_id', $spec);
- }
- // Create the entity translation revision schema.
- $table = array(
- 'description' => 'Table to track entity translation revisions',
- 'fields' => array(
- 'entity_type' => array(
- 'type' => 'varchar',
- 'length' => 128,
- 'not null' => TRUE,
- 'default' => '',
- 'description' => 'The entity type this translation revision relates to',
- ),
- 'entity_id' => array(
- 'type' => 'int',
- 'unsigned' => TRUE,
- 'not null' => TRUE,
- 'description' => 'The entity id this translation revision relates to',
- ),
- 'revision_id' => array(
- 'type' => 'int',
- 'unsigned' => TRUE,
- 'not null' => TRUE,
- 'description' => 'The entity revision id this translation relates to',
- ),
- 'language' => array(
- 'type' => 'varchar',
- 'length' => 32,
- 'not null' => TRUE,
- 'default' => '',
- 'description' => 'The target language for this translation revision.',
- ),
- 'source' => array(
- 'type' => 'varchar',
- 'length' => 32,
- 'not null' => TRUE,
- 'default' => '',
- 'description' => 'The source language from which this translation revision was created.',
- ),
- 'uid' => array(
- 'description' => 'The author of this translation revision.',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 0,
- ),
- 'status' => array(
- 'description' => 'Boolean indicating whether the translation revision is published (visible to non-administrators).',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 1,
- ),
- 'translate' => array(
- 'description' => 'A boolean indicating whether this translation revision needs to be updated.',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 0,
- ),
- 'created' => array(
- 'description' => 'The Unix timestamp when the translation revision was created.',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 0,
- ),
- 'changed' => array(
- 'description' => 'The Unix timestamp when the translation revision was most recently saved.',
- 'type' => 'int',
- 'not null' => TRUE,
- 'default' => 0,
- ),
- ),
- 'primary key' => array('entity_type', 'revision_id', 'language'),
- 'indexes'=> array('revision_id' => array('revision_id')),
- );
- // Create entity translation revision table if it doesn't exist already.
- if (!db_table_exists('entity_translation_revision')) {
- db_create_table('entity_translation_revision', $table);
- }
- }
- /**
- * Disable revision support on existing installations.
- */
- function entity_translation_update_7007() {
- // Revision support is not enabled by default on existing installations as
- // making it work implies copying translation metadata to the
- // {entity_translation_revision} table for all the existing translations.
- // Since this process cannot be reliably implemented in an update function,
- // we leave the choice of manually performing the upgrade to people with the
- // required skills to do so. Be aware that enabling revision support on sites
- // where data has not been manually migrated may cause translation metadata to
- // be permanently lost or corrupted. See https://www.drupal.org/node/2396103.
- variable_set('entity_translation_revision_enabled', FALSE);
- }
- /**
- * Enable Entity Translation for taxonomy vocabularies having terms translated
- * through it.
- */
- function entity_translation_update_7008() {
- if (!module_exists('taxonomy')) {
- return;
- }
- // According to EXPLAIN joining {taxonomy_vocabulary} here makes the query
- // perform way worse, so we just split into two quick ones.
- $query = "SELECT t.vid
- FROM {entity_translation} et
- JOIN {taxonomy_term_data} t ON et.entity_type = 'taxonomy_term' AND et.entity_id = t.tid AND et.source != ''
- GROUP BY t.vid";
- $vids = db_query($query)->fetchCol();
- if ($vids) {
- $query = "SELECT v.machine_name FROM {taxonomy_vocabulary} v WHERE v.vid IN (:vids)";
- $names = db_query($query, array(':vids' => $vids))->fetchCol();
- $info = variable_get('entity_translation_taxonomy', array());
- foreach ($names as $name) {
- $info[$name] = TRUE;
- }
- variable_set('entity_translation_taxonomy', $info);
- }
- }
- /**
- * Make sure "i18n_mode" is correctly set for vocabularies having entity
- * translation enabled.
- */
- function entity_translation_update_7009() {
- $info = array_filter(variable_get('entity_translation_taxonomy', array()));
- if ($info && module_exists('i18n_taxonomy')) {
- $query = "UPDATE {taxonomy_vocabulary} SET i18n_mode = :et_mode WHERE machine_name IN (:names)";
- $names = array_keys(array_filter($info));
- db_query($query, array(':et_mode' => 32768, ':names' => $names));
- }
- }
|