webmaster@1: 'Stores site access rules.', webmaster@1: 'fields' => array( webmaster@1: 'aid' => array( webmaster@1: 'type' => 'serial', webmaster@1: 'not null' => TRUE, franck@19: 'description' => 'Primary Key: Unique access ID.', webmaster@1: ), webmaster@1: 'mask' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 255, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => '', franck@19: 'description' => 'Text mask used for filtering access.', webmaster@1: ), webmaster@1: 'type' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 255, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => '', franck@19: 'description' => 'Type of access rule: name, mail or host.', webmaster@1: ), webmaster@1: 'status' => array( webmaster@1: 'type' => 'int', webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => 0, webmaster@1: 'size' => 'tiny', franck@19: 'description' => 'Whether rule is to allow(1) or deny(0) access.', webmaster@1: ), webmaster@1: ), webmaster@1: 'primary key' => array('aid'), webmaster@1: ); webmaster@1: webmaster@1: $schema['authmap'] = array( franck@19: 'description' => 'Stores distributed authentication mapping.', webmaster@1: 'fields' => array( webmaster@1: 'aid' => array( franck@19: 'description' => 'Primary Key: Unique authmap ID.', webmaster@1: 'type' => 'serial', webmaster@1: 'unsigned' => TRUE, webmaster@1: 'not null' => TRUE, webmaster@1: ), webmaster@1: 'uid' => array( webmaster@1: 'type' => 'int', webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => 0, franck@19: 'description' => "User's {users}.uid.", webmaster@1: ), webmaster@1: 'authname' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 128, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => '', franck@19: 'description' => 'Unique authentication name.', webmaster@1: ), webmaster@1: 'module' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 128, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => '', franck@19: 'description' => 'Module which is controlling the authentication.', webmaster@1: ), webmaster@1: ), webmaster@1: 'unique keys' => array('authname' => array('authname')), webmaster@1: 'primary key' => array('aid'), webmaster@1: ); webmaster@1: webmaster@1: $schema['permission'] = array( franck@19: 'description' => 'Stores permissions for users.', webmaster@1: 'fields' => array( webmaster@1: 'pid' => array( webmaster@1: 'type' => 'serial', webmaster@1: 'not null' => TRUE, franck@19: 'description' => 'Primary Key: Unique permission ID.', webmaster@1: ), webmaster@1: 'rid' => array( webmaster@1: 'type' => 'int', webmaster@1: 'unsigned' => TRUE, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => 0, franck@19: 'description' => 'The {role}.rid to which the permissions are assigned.', webmaster@1: ), webmaster@1: 'perm' => array( webmaster@1: 'type' => 'text', webmaster@1: 'not null' => FALSE, webmaster@1: 'size' => 'big', franck@19: 'description' => 'List of permissions being assigned.', webmaster@1: ), webmaster@1: 'tid' => array( webmaster@1: 'type' => 'int', webmaster@1: 'unsigned' => TRUE, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => 0, franck@19: 'description' => 'Originally intended for taxonomy-based permissions, but never used.', webmaster@1: ), webmaster@1: ), webmaster@1: 'primary key' => array('pid'), webmaster@1: 'indexes' => array('rid' => array('rid')), webmaster@1: ); webmaster@1: webmaster@1: $schema['role'] = array( franck@19: 'description' => 'Stores user roles.', webmaster@1: 'fields' => array( webmaster@1: 'rid' => array( webmaster@1: 'type' => 'serial', webmaster@1: 'unsigned' => TRUE, webmaster@1: 'not null' => TRUE, franck@19: 'description' => 'Primary Key: Unique role id.', webmaster@1: ), webmaster@1: 'name' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 64, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => '', franck@19: 'description' => 'Unique role name.', webmaster@1: ), webmaster@1: ), webmaster@1: 'unique keys' => array('name' => array('name')), webmaster@1: 'primary key' => array('rid'), webmaster@1: ); webmaster@1: webmaster@1: $schema['users'] = array( franck@19: 'description' => 'Stores user data.', webmaster@1: 'fields' => array( webmaster@1: 'uid' => array( webmaster@1: 'type' => 'serial', webmaster@1: 'unsigned' => TRUE, webmaster@1: 'not null' => TRUE, franck@19: 'description' => 'Primary Key: Unique user ID.', webmaster@1: ), webmaster@1: 'name' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 60, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => '', franck@19: 'description' => 'Unique user name.', webmaster@1: ), webmaster@1: 'pass' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 32, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => '', franck@19: 'description' => "User's password (md5 hash).", webmaster@1: ), webmaster@1: 'mail' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 64, webmaster@1: 'not null' => FALSE, webmaster@1: 'default' => '', franck@19: 'description' => "User's email address.", webmaster@1: ), webmaster@1: 'mode' => array( webmaster@1: 'type' => 'int', webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => 0, webmaster@1: 'size' => 'tiny', franck@19: 'description' => 'Per-user comment display mode (threaded vs. flat), used by the {comment} module.', webmaster@1: ), webmaster@1: 'sort' => array( webmaster@1: 'type' => 'int', webmaster@1: 'not null' => FALSE, webmaster@1: 'default' => 0, webmaster@1: 'size' => 'tiny', franck@19: 'description' => 'Per-user comment sort order (newest vs. oldest first), used by the {comment} module.', webmaster@1: ), webmaster@1: 'threshold' => array( webmaster@1: 'type' => 'int', webmaster@1: 'not null' => FALSE, webmaster@1: 'default' => 0, webmaster@1: 'size' => 'tiny', franck@19: 'description' => 'Previously used by the {comment} module for per-user preferences; no longer used.', webmaster@1: ), webmaster@1: 'theme' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 255, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => '', franck@19: 'description' => "User's default theme.", webmaster@1: ), webmaster@1: 'signature' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 255, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => '', franck@19: 'description' => "User's signature.", webmaster@1: ), webmaster@1: 'created' => array( webmaster@1: 'type' => 'int', webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => 0, franck@19: 'description' => 'Timestamp for when user was created.', webmaster@1: ), webmaster@1: 'access' => array( webmaster@1: 'type' => 'int', webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => 0, franck@19: 'description' => 'Timestamp for previous time user accessed the site.', webmaster@1: ), webmaster@1: 'login' => array( webmaster@1: 'type' => 'int', webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => 0, franck@19: 'description' => "Timestamp for user's last login.", webmaster@1: ), webmaster@1: 'status' => array( webmaster@1: 'type' => 'int', webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => 0, webmaster@1: 'size' => 'tiny', franck@19: 'description' => 'Whether the user is active(1) or blocked(0).', webmaster@1: ), webmaster@1: 'timezone' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 8, webmaster@1: 'not null' => FALSE, franck@19: 'description' => "User's timezone.", webmaster@1: ), webmaster@1: 'language' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 12, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => '', franck@19: 'description' => "User's default language.", webmaster@1: ), webmaster@1: 'picture' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 255, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => '', franck@19: 'description' => "Path to the user's uploaded picture.", webmaster@1: ), webmaster@1: 'init' => array( webmaster@1: 'type' => 'varchar', webmaster@1: 'length' => 64, webmaster@1: 'not null' => FALSE, webmaster@1: 'default' => '', franck@19: 'description' => 'Email address used for initial account creation.', webmaster@1: ), webmaster@1: 'data' => array( webmaster@1: 'type' => 'text', webmaster@1: 'not null' => FALSE, webmaster@1: 'size' => 'big', franck@19: 'description' => 'A serialized array of name value pairs that are related to the user. Any form values posted during user edit are stored and are loaded into the $user object during user_load(). Use of this field is discouraged and it will likely disappear in a future version of Drupal.', webmaster@1: ), webmaster@1: ), webmaster@1: 'indexes' => array( webmaster@1: 'access' => array('access'), webmaster@1: 'created' => array('created'), webmaster@1: 'mail' => array('mail'), webmaster@1: ), webmaster@1: 'unique keys' => array( webmaster@1: 'name' => array('name'), webmaster@1: ), webmaster@1: 'primary key' => array('uid'), webmaster@1: ); webmaster@1: webmaster@1: $schema['users_roles'] = array( franck@19: 'description' => 'Maps users to roles.', webmaster@1: 'fields' => array( webmaster@1: 'uid' => array( webmaster@1: 'type' => 'int', webmaster@1: 'unsigned' => TRUE, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => 0, franck@19: 'description' => 'Primary Key: {users}.uid for user.', webmaster@1: ), webmaster@1: 'rid' => array( webmaster@1: 'type' => 'int', webmaster@1: 'unsigned' => TRUE, webmaster@1: 'not null' => TRUE, webmaster@1: 'default' => 0, franck@19: 'description' => 'Primary Key: {role}.rid for role.', webmaster@1: ), webmaster@1: ), webmaster@1: 'primary key' => array('uid', 'rid'), webmaster@1: 'indexes' => array( webmaster@1: 'rid' => array('rid'), webmaster@1: ), webmaster@1: ); webmaster@1: webmaster@1: return $schema; webmaster@1: } webmaster@1: