annotate modules/profile/profile.install @ 0:ff03f76ab3fe

initial version
author danieleb <danielebarchiesi@me.com>
date Wed, 21 Aug 2013 18:51:11 +0100
parents
children
rev   line source
danielebarchiesi@0 1 <?php
danielebarchiesi@0 2
danielebarchiesi@0 3 /**
danielebarchiesi@0 4 * @file
danielebarchiesi@0 5 * Install, update and uninstall functions for the profile module.
danielebarchiesi@0 6 */
danielebarchiesi@0 7
danielebarchiesi@0 8 /**
danielebarchiesi@0 9 * Implements hook_uninstall().
danielebarchiesi@0 10 */
danielebarchiesi@0 11 function profile_uninstall() {
danielebarchiesi@0 12 variable_del('profile_block_author_fields');
danielebarchiesi@0 13 }
danielebarchiesi@0 14
danielebarchiesi@0 15 /**
danielebarchiesi@0 16 * Implements hook_schema().
danielebarchiesi@0 17 */
danielebarchiesi@0 18 function profile_schema() {
danielebarchiesi@0 19 $schema['profile_field'] = array(
danielebarchiesi@0 20 'description' => 'Stores profile field information.',
danielebarchiesi@0 21 'fields' => array(
danielebarchiesi@0 22 'fid' => array(
danielebarchiesi@0 23 'type' => 'serial',
danielebarchiesi@0 24 'not null' => TRUE,
danielebarchiesi@0 25 'description' => 'Primary Key: Unique profile field ID.',
danielebarchiesi@0 26 ),
danielebarchiesi@0 27 'title' => array(
danielebarchiesi@0 28 'type' => 'varchar',
danielebarchiesi@0 29 'length' => 255,
danielebarchiesi@0 30 'not null' => FALSE,
danielebarchiesi@0 31 'description' => 'Title of the field shown to the end user.',
danielebarchiesi@0 32 ),
danielebarchiesi@0 33 'name' => array(
danielebarchiesi@0 34 'type' => 'varchar',
danielebarchiesi@0 35 'length' => 128,
danielebarchiesi@0 36 'not null' => TRUE,
danielebarchiesi@0 37 'default' => '',
danielebarchiesi@0 38 'description' => 'Internal name of the field used in the form HTML and URLs.',
danielebarchiesi@0 39 ),
danielebarchiesi@0 40 'explanation' => array(
danielebarchiesi@0 41 'type' => 'text',
danielebarchiesi@0 42 'not null' => FALSE,
danielebarchiesi@0 43 'description' => 'Explanation of the field to end users.',
danielebarchiesi@0 44 ),
danielebarchiesi@0 45 'category' => array(
danielebarchiesi@0 46 'type' => 'varchar',
danielebarchiesi@0 47 'length' => 255,
danielebarchiesi@0 48 'not null' => FALSE,
danielebarchiesi@0 49 'description' => 'Profile category that the field will be grouped under.',
danielebarchiesi@0 50 ),
danielebarchiesi@0 51 'page' => array(
danielebarchiesi@0 52 'type' => 'varchar',
danielebarchiesi@0 53 'length' => 255,
danielebarchiesi@0 54 'not null' => FALSE,
danielebarchiesi@0 55 'description' => "Title of page used for browsing by the field's value",
danielebarchiesi@0 56 ),
danielebarchiesi@0 57 'type' => array(
danielebarchiesi@0 58 'type' => 'varchar',
danielebarchiesi@0 59 'length' => 128,
danielebarchiesi@0 60 'not null' => FALSE,
danielebarchiesi@0 61 'description' => 'Type of form field.',
danielebarchiesi@0 62 ),
danielebarchiesi@0 63 'weight' => array(
danielebarchiesi@0 64 'type' => 'int',
danielebarchiesi@0 65 'not null' => TRUE,
danielebarchiesi@0 66 'default' => 0,
danielebarchiesi@0 67 'description' => 'Weight of field in relation to other profile fields.',
danielebarchiesi@0 68 ),
danielebarchiesi@0 69 'required' => array(
danielebarchiesi@0 70 'type' => 'int',
danielebarchiesi@0 71 'not null' => TRUE,
danielebarchiesi@0 72 'default' => 0,
danielebarchiesi@0 73 'size' => 'tiny',
danielebarchiesi@0 74 'description' => 'Whether the user is required to enter a value. (0 = no, 1 = yes)',
danielebarchiesi@0 75 ),
danielebarchiesi@0 76 'register' => array(
danielebarchiesi@0 77 'type' => 'int',
danielebarchiesi@0 78 'not null' => TRUE,
danielebarchiesi@0 79 'default' => 0,
danielebarchiesi@0 80 'size' => 'tiny',
danielebarchiesi@0 81 'description' => 'Whether the field is visible in the user registration form. (1 = yes, 0 = no)',
danielebarchiesi@0 82 ),
danielebarchiesi@0 83 'visibility' => array(
danielebarchiesi@0 84 'type' => 'int',
danielebarchiesi@0 85 'not null' => TRUE,
danielebarchiesi@0 86 'default' => 0,
danielebarchiesi@0 87 'size' => 'tiny',
danielebarchiesi@0 88 'description' => 'The level of visibility for the field. (0 = hidden, 1 = private, 2 = public on profile but not member list pages, 3 = public on profile and list pages)',
danielebarchiesi@0 89 ),
danielebarchiesi@0 90 'autocomplete' => array(
danielebarchiesi@0 91 'type' => 'int',
danielebarchiesi@0 92 'not null' => TRUE,
danielebarchiesi@0 93 'default' => 0,
danielebarchiesi@0 94 'size' => 'tiny',
danielebarchiesi@0 95 'description' => 'Whether form auto-completion is enabled. (0 = disabled, 1 = enabled)',
danielebarchiesi@0 96 ),
danielebarchiesi@0 97 'options' => array(
danielebarchiesi@0 98 'type' => 'text',
danielebarchiesi@0 99 'not null' => FALSE,
danielebarchiesi@0 100 'description' => 'List of options to be used in a list selection field.',
danielebarchiesi@0 101 ),
danielebarchiesi@0 102 ),
danielebarchiesi@0 103 'indexes' => array(
danielebarchiesi@0 104 'category' => array('category'),
danielebarchiesi@0 105 ),
danielebarchiesi@0 106 'unique keys' => array(
danielebarchiesi@0 107 'name' => array('name'),
danielebarchiesi@0 108 ),
danielebarchiesi@0 109 'primary key' => array('fid'),
danielebarchiesi@0 110 );
danielebarchiesi@0 111
danielebarchiesi@0 112 $schema['profile_value'] = array(
danielebarchiesi@0 113 'description' => 'Stores values for profile fields.',
danielebarchiesi@0 114 'fields' => array(
danielebarchiesi@0 115 'fid' => array(
danielebarchiesi@0 116 'type' => 'int',
danielebarchiesi@0 117 'unsigned' => TRUE,
danielebarchiesi@0 118 'not null' => TRUE,
danielebarchiesi@0 119 'default' => 0,
danielebarchiesi@0 120 'description' => 'The {profile_field}.fid of the field.',
danielebarchiesi@0 121 ),
danielebarchiesi@0 122 'uid' => array(
danielebarchiesi@0 123 'type' => 'int',
danielebarchiesi@0 124 'unsigned' => TRUE,
danielebarchiesi@0 125 'not null' => TRUE,
danielebarchiesi@0 126 'default' => 0,
danielebarchiesi@0 127 'description' => 'The {users}.uid of the profile user.',
danielebarchiesi@0 128 ),
danielebarchiesi@0 129 'value' => array(
danielebarchiesi@0 130 'type' => 'text',
danielebarchiesi@0 131 'not null' => FALSE,
danielebarchiesi@0 132 'description' => 'The value for the field.',
danielebarchiesi@0 133 ),
danielebarchiesi@0 134 ),
danielebarchiesi@0 135 'primary key' => array('uid', 'fid'),
danielebarchiesi@0 136 'indexes' => array(
danielebarchiesi@0 137 'fid' => array('fid'),
danielebarchiesi@0 138 ),
danielebarchiesi@0 139 'foreign keys' => array(
danielebarchiesi@0 140 'profile_field' => array(
danielebarchiesi@0 141 'table' => 'profile_field',
danielebarchiesi@0 142 'columns' => array('fid' => 'fid'),
danielebarchiesi@0 143 ),
danielebarchiesi@0 144 'profile_user' => array(
danielebarchiesi@0 145 'table' => 'users',
danielebarchiesi@0 146 'columns' => array('uid' => 'uid'),
danielebarchiesi@0 147 ),
danielebarchiesi@0 148 ),
danielebarchiesi@0 149 );
danielebarchiesi@0 150
danielebarchiesi@0 151 return $schema;
danielebarchiesi@0 152 }
danielebarchiesi@0 153
danielebarchiesi@0 154 /**
danielebarchiesi@0 155 * Rename {profile_fields} table to {profile_field} and {profile_values} to {profile_value}.
danielebarchiesi@0 156 */
danielebarchiesi@0 157 function profile_update_7001() {
danielebarchiesi@0 158 db_rename_table('profile_fields', 'profile_field');
danielebarchiesi@0 159 db_rename_table('profile_values', 'profile_value');
danielebarchiesi@0 160 }
danielebarchiesi@0 161
danielebarchiesi@0 162 /**
danielebarchiesi@0 163 * Change the weight column to normal int.
danielebarchiesi@0 164 */
danielebarchiesi@0 165 function profile_update_7002() {
danielebarchiesi@0 166 db_change_field('profile_field', 'weight', 'weight', array(
danielebarchiesi@0 167 'type' => 'int',
danielebarchiesi@0 168 'not null' => TRUE,
danielebarchiesi@0 169 'default' => 0,
danielebarchiesi@0 170 'description' => 'Weight of field in relation to other profile fields.',
danielebarchiesi@0 171 ));
danielebarchiesi@0 172 }