annotate sites/all/modules/imce/imce.install @ 13:134d4b2e75f6

updated quicktabs and google analytics modules
author danieleb <danielebarchiesi@me.com>
date Tue, 29 Oct 2013 13:48:59 +0000
parents ff03f76ab3fe
children
rev   line source
danielebarchiesi@0 1 <?php
danielebarchiesi@0 2
danielebarchiesi@0 3 /**
danielebarchiesi@0 4 * @file
danielebarchiesi@0 5 * Installs, updates, and uninstalls IMCE.
danielebarchiesi@0 6 */
danielebarchiesi@0 7
danielebarchiesi@0 8 /**
danielebarchiesi@0 9 * Implements hook_install().
danielebarchiesi@0 10 */
danielebarchiesi@0 11 function imce_install() {
danielebarchiesi@0 12 module_load_include('inc', 'imce', 'inc/imce.core.profiles');
danielebarchiesi@0 13 imce_install_profiles();
danielebarchiesi@0 14 }
danielebarchiesi@0 15
danielebarchiesi@0 16 /**
danielebarchiesi@0 17 * Implements hook_uninstall().
danielebarchiesi@0 18 */
danielebarchiesi@0 19 function imce_uninstall() {
danielebarchiesi@0 20 db_delete('file_usage')->condition('module', 'imce')->execute();
danielebarchiesi@0 21 variable_del('imce_profiles');
danielebarchiesi@0 22 variable_del('imce_roles_profiles');
danielebarchiesi@0 23 variable_del('imce_settings_textarea');
danielebarchiesi@0 24 variable_del('imce_settings_absurls');
danielebarchiesi@0 25 variable_del('imce_settings_replace');
danielebarchiesi@0 26 variable_del('imce_settings_thumb_method');
danielebarchiesi@0 27 variable_del('imce_settings_disable_private');
danielebarchiesi@0 28 variable_del('imce_custom_content');
danielebarchiesi@0 29 variable_del('imce_custom_process');
danielebarchiesi@0 30 variable_del('imce_custom_init');
danielebarchiesi@0 31 variable_del('imce_custom_scan');
danielebarchiesi@0 32 variable_del('imce_custom_response');
danielebarchiesi@0 33 }
danielebarchiesi@0 34
danielebarchiesi@0 35 /**
danielebarchiesi@0 36 * Updates from 6.x to 7.x.
danielebarchiesi@0 37 */
danielebarchiesi@0 38 function imce_update_7000() {
danielebarchiesi@0 39 // Update role-profile assignments
danielebarchiesi@0 40 $roles_profiles = variable_get('imce_roles_profiles', array());
danielebarchiesi@0 41 if (!empty($roles_profiles)) {
danielebarchiesi@0 42 $scheme = variable_get('file_default_scheme', 'public');
danielebarchiesi@0 43 foreach ($roles_profiles as $rid => &$role) {
danielebarchiesi@0 44 $role[$scheme . '_pid'] = $role['pid'];
danielebarchiesi@0 45 unset($role['pid']);
danielebarchiesi@0 46 }
danielebarchiesi@0 47 variable_set('imce_roles_profiles', $roles_profiles);
danielebarchiesi@0 48 }
danielebarchiesi@0 49 // Update textarea ids
danielebarchiesi@0 50 $ids = str_replace(' ', '', variable_get('imce_settings_textarea', ''));
danielebarchiesi@0 51 if ($ids != '') {
danielebarchiesi@0 52 $ids = explode(',', $ids);
danielebarchiesi@0 53 foreach ($ids as &$id) {
danielebarchiesi@0 54 $id .= '*';
danielebarchiesi@0 55 }
danielebarchiesi@0 56 variable_set('imce_settings_textarea', implode(', ', $ids));
danielebarchiesi@0 57 }
danielebarchiesi@0 58 }
danielebarchiesi@0 59
danielebarchiesi@0 60 /**
danielebarchiesi@0 61 * Migrates imce files from {files} to {file_managed}.
danielebarchiesi@0 62 * Removes {imce_files} in favor of {file_usage}.
danielebarchiesi@0 63 */
danielebarchiesi@0 64 function imce_update_7001(&$sandbox) {
danielebarchiesi@0 65 if (!db_table_exists('imce_files') || !db_table_exists('files')) {
danielebarchiesi@0 66 return;
danielebarchiesi@0 67 }
danielebarchiesi@0 68 // Initiate progress
danielebarchiesi@0 69 if (!isset($sandbox['progress'])) {
danielebarchiesi@0 70 $sandbox['progress'] = 0;
danielebarchiesi@0 71 $sandbox['last_fid_processed'] = 0;
danielebarchiesi@0 72 $sandbox['max'] = db_query("SELECT COUNT(*) FROM {imce_files} i INNER JOIN {files} f ON i.fid = f.fid")->fetchField();
danielebarchiesi@0 73 }
danielebarchiesi@0 74 // Prepare variables
danielebarchiesi@0 75 $limit = 250;
danielebarchiesi@0 76 $basedir = variable_get('file_directory_path', conf_path() . '/files') . '/';
danielebarchiesi@0 77 $baselen = strlen($basedir);
danielebarchiesi@0 78 $scheme = file_default_scheme() . '://';
danielebarchiesi@0 79 $result = db_query_range('SELECT f.* FROM {imce_files} i INNER JOIN {files} f ON i.fid = f.fid WHERE i.fid > :fid ORDER BY i.fid', 0, $limit, array(':fid' => $sandbox['last_fid_processed']))->fetchAll();
danielebarchiesi@0 80 // Migrate imce files from {files} to {file_managed}
danielebarchiesi@0 81 foreach ($result as $file) {
danielebarchiesi@0 82 $relpath = substr($file->filepath, 0, $baselen) == $basedir ? substr($file->filepath, $baselen) : $file->filepath;
danielebarchiesi@0 83 $file->uri = file_stream_wrapper_uri_normalize($scheme . $relpath);
danielebarchiesi@0 84 unset($file->filepath);
danielebarchiesi@0 85 if (!db_query("SELECT 1 FROM {file_managed} WHERE fid = :fid", array(':fid' => $file->fid))->fetchField()) {
danielebarchiesi@0 86 // Check duplicate uri
danielebarchiesi@0 87 if ($fid = db_query("SELECT fid FROM {file_managed} WHERE uri = :uri", array(':uri' => $file->uri))->fetchField()) {
danielebarchiesi@0 88 $file->fid = $fid;
danielebarchiesi@0 89 }
danielebarchiesi@0 90 else {
danielebarchiesi@0 91 drupal_write_record('file_managed', $file);
danielebarchiesi@0 92 }
danielebarchiesi@0 93 }
danielebarchiesi@0 94 file_usage_add($file, 'imce', 'file', $file->fid);
danielebarchiesi@0 95 $sandbox['progress']++;
danielebarchiesi@0 96 $sandbox['last_fid_processed'] = $file->fid;
danielebarchiesi@0 97 }
danielebarchiesi@0 98 // Drop {imce_files} if the progress is complete.
danielebarchiesi@0 99 $sandbox['#finished'] = empty($sandbox['max']) ? 1 : $sandbox['progress'] / $sandbox['max'];
danielebarchiesi@0 100 if ($sandbox['#finished'] >= 1) {
danielebarchiesi@0 101 db_drop_table('imce_files');
danielebarchiesi@0 102 return t('Migrated IMCE files.');
danielebarchiesi@0 103 }
danielebarchiesi@0 104 }