 c259bc4543
			
		
	
	c259bc4543
	
	
	
		
			
			- table flags becomes flag
- replace all content_type and content_id by entity_type and entity_id
- changed flag_lists.install (new rows name entity_type & entity_id) and flags table name become flag
- factory_by_content_type('node') became factory_by_entity_type('node')
- flag_lists.views_default.inc (entity_id & entity_type)
Signed-off-by: bachy <git@g-u-i.net>
		
	
		
			
				
	
	
		
			208 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			208 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| /**
 | |
|  * @file
 | |
|  * The Flag lists module install file.
 | |
|  */
 | |
| 
 | |
|  /**
 | |
|  * Implementation of hook_install().
 | |
|  */
 | |
| function flag_lists_schema() {
 | |
|   $schema = array();
 | |
|   $schema['flag_lists_flags'] = array(
 | |
|     'fields' => array(
 | |
|       'fid' => array(
 | |
|         'type' => 'serial',
 | |
|         'size' => 'small',
 | |
|         'unsigned' => TRUE,
 | |
|         'not null' => TRUE,
 | |
|       ),
 | |
|       'pfid' => array(
 | |
|         'type' => 'int',
 | |
|         'size' => 'small',
 | |
|         'unsigned' => TRUE,
 | |
|         'not null' => TRUE,
 | |
|       ),
 | |
|       'uid' => array(
 | |
|         'type' => 'int',
 | |
|         'size' => 'small',
 | |
|         'unsigned' => TRUE,
 | |
|         'not null' => TRUE,
 | |
|       ),
 | |
|       'entity_type' => array(
 | |
|         'type' => 'varchar',
 | |
|         'length' => '32',
 | |
|         'not null' => TRUE,
 | |
|         'default' => '',
 | |
|       ),
 | |
|       'name' => array(
 | |
|         'type' => 'varchar',
 | |
|         'length' => '32',
 | |
|         'not null' => FALSE,
 | |
|         'default' => '',
 | |
|       ),
 | |
|       'title' => array(
 | |
|         'type' => 'varchar',
 | |
|         'length' => '255',
 | |
|         'not null' => FALSE,
 | |
|         'default' => '',
 | |
|       ),
 | |
|       'options' => array(
 | |
|         'type' => 'text',
 | |
|         'not null' => FALSE,
 | |
|       ),
 | |
|     ),
 | |
|     'primary key' => array('fid'),
 | |
|     'unique keys' => array(
 | |
|       'name' => array('name'),
 | |
|     ),
 | |
|   );
 | |
|   $schema['flag_lists_content'] = array(
 | |
|     'fields' => array(
 | |
|       'fcid' => array(
 | |
|         'type' => 'serial',
 | |
|         'unsigned' => TRUE,
 | |
|         'not null' => TRUE,
 | |
|       ),
 | |
|       'fid' => array(
 | |
|         'type' => 'int',
 | |
|         'size' => 'small',
 | |
|         'unsigned' => TRUE,
 | |
|         'not null' => TRUE,
 | |
|         'default' => 0,
 | |
|       ),
 | |
|       'entity_type' => array(
 | |
|         'type' => 'varchar',
 | |
|         'length' => '32',
 | |
|         'not null' => TRUE,
 | |
|         'default' => '',
 | |
|       ),
 | |
|       'entity_id' => array(
 | |
|         'type' => 'int',
 | |
|         'unsigned' => TRUE,
 | |
|         'not null' => TRUE,
 | |
|         'default' => 0,
 | |
|       ),
 | |
|       'uid' => array(
 | |
|         'type' => 'int',
 | |
|         'unsigned' => TRUE,
 | |
|         'not null' => TRUE,
 | |
|         'default' => 0,
 | |
|       ),
 | |
|       'sid' => array(
 | |
|         'type' => 'int',
 | |
|         'unsigned' => TRUE,
 | |
|         'not null' => TRUE,
 | |
|         'default' => 0,
 | |
|       ),
 | |
|       'timestamp' => array(
 | |
|         'type' => 'int',
 | |
|         'unsigned' => TRUE,
 | |
|         'not null' => TRUE,
 | |
|         'default' => 0,
 | |
|         'disp-size' => 11,
 | |
|       )
 | |
|     ),
 | |
|     'primary key' => array('fcid'),
 | |
|     'unique keys' => array(
 | |
|       'fid_entity_id_uid_sid' => array('fid', 'entity_id', 'uid', 'sid'),
 | |
|     ),
 | |
|     'indexes' => array(
 | |
|       'entity_type_entity_id' => array('entity_type', 'entity_id'),
 | |
|       'entity_type_uid_sid' => array('entity_type', 'uid', 'sid'),
 | |
|     ),
 | |
|   );
 | |
|   $schema['flag_lists_counts'] = array(
 | |
|     'fields' => array(
 | |
|       'fid' => array(
 | |
|         'type' => 'int',
 | |
|         'size' => 'small',
 | |
|         'unsigned' => TRUE,
 | |
|         'not null' => TRUE,
 | |
|         'default' => 0,
 | |
|       ),
 | |
|       'entity_type' => array(
 | |
|         'type' => 'varchar',
 | |
|         'length' => '32',
 | |
|         'not null' => TRUE,
 | |
|         'default' => '',
 | |
|       ),
 | |
|       'entity_id' => array(
 | |
|         'type' => 'int',
 | |
|         'unsigned' => TRUE,
 | |
|         'not null' => TRUE,
 | |
|         'default' => 0,
 | |
|         'disp-width' => '10',
 | |
|       ),
 | |
|       'count' => array(
 | |
|         'type' => 'int',
 | |
|         'unsigned' => TRUE,
 | |
|         'not null' => TRUE,
 | |
|         'default' => 0,
 | |
|         'disp-width' => '10',
 | |
|       )
 | |
|     ),
 | |
|     'primary key' => array('fid', 'entity_id'),
 | |
|     'indexes' => array(
 | |
|       'fid_entity_type' => array('fid', 'entity_type'),
 | |
|       'entity_type_entity_id' => array('entity_type', 'entity_id'),
 | |
|       'count' => array('count'),
 | |
|     ),
 | |
|   );
 | |
|   $schema['flag_lists_types'] = array(
 | |
|     'fields' => array(
 | |
|       'name' => array(
 | |
|         'type' => 'varchar',
 | |
|         'length' => '32',
 | |
|         'not null' => TRUE,
 | |
|         'default' => '',
 | |
|       ),
 | |
|       'type' => array(
 | |
|         'type' => 'varchar',
 | |
|         'length' => '32',
 | |
|         'not null' => FALSE,
 | |
|         'default' => '')
 | |
|     ),
 | |
|     'primary key' => array('name', 'type'),
 | |
|     'indexes' => array(
 | |
|       'name' => array('name'),
 | |
|     ),
 | |
|   );
 | |
|   return $schema;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Implements hook_install().
 | |
|  */
 | |
| function flag_lists_install() {
 | |
|   // Set up our default template.
 | |
|   db_insert('flag_lists_types')
 | |
|     ->fields(array(
 | |
|       'name' => 'fl_template',
 | |
|     ))
 | |
|     ->execute();
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Implements hook_uninstall().
 | |
|  */
 | |
| function flag_lists_uninstall() {
 | |
|   // Remove our template flags.
 | |
|   $query = db_select('flag_lists_types', 'fl');
 | |
|   $query->leftJoin('flag', 'f', 'fl.name = f.name');
 | |
|   $query->addField('fl', 'fid', 'fid');
 | |
|   $query->distinct();
 | |
|   $fids = $query->execute();
 | |
| 
 | |
|   foreach ($fids as $fid) {
 | |
|     db_delete('flag')->condition('fid', $fid->fid);
 | |
|     db_delete('flag_content')->condition('fid', $fid->fid);
 | |
|     db_delete('flag_types')->condition('fid', $fid->fid);
 | |
|     db_delete('flag_counts')->condition('fid', $fid->fid);
 | |
|   }
 | |
| 
 | |
|   db_delete('variable')->condition('name', 'flag_lists%', 'LIKE');
 | |
|   drupal_set_message(t('Flag lists has been uninstalled.'));
 | |
| }
 |