name = $name;
   $record->modulename = $modulename;
   $record->mv_schema = 'DUMMY';
   $record->mv_table = $mv_table;
   $record->mv_specs = $mv_specs;
   $record->indexed = $indexed;
   $record->query = $query;
   $record->special_index = $special_index;
   // add the record to the tripal_mviews table and if successful
   // create the new materialized view in the chado schema
   if(drupal_write_record('tripal_mviews',$record)){
      // drop the table from chado if it exists
      $previous_db = tripal_db_set_active('chado');  // use chado database
      if (db_table_exists($mv_table)) {
         $sql = "DROP TABLE $mv_table";
         db_query($sql);
      }
      tripal_db_set_active($previous_db);  // now use drupal database
      
      // now add the table for this view
      $index = '';
      if($indexed){
         $index = ", CONSTRAINT ". $mv_table . "_index UNIQUE ($indexed) ";
      }
      $sql = "CREATE TABLE {$mv_table} ($mv_specs $index)"; 
      $previous_db = tripal_db_set_active('chado');  // use chado database
      $results = db_query($sql);
      tripal_db_set_active($previous_db);  // now use drupal database
      if($results){
         drupal_set_message(t("View '$name' created"));
      } else {
         // if we failed to create the view in chado then
         // remove the record from the tripal_jobs table
         $sql = "DELETE FROM {tripal_mviews} ".
                "WHERE mview_id = $record->mview_id";
         db_query($sql);
      }
   }
}
/**
 * Retrieve the materialized view_id given the name
 *
 * @param $view_name
 *   The name of the materialized view
 *
 * @return
 *   The unique identifier for the given view
 *
 * @ingroup tripal_mviews_api
 */
function tripal_mviews_get_mview_id ($view_name){
   $sql = "SELECT * FROM {tripal_mviews} ".
          "WHERE name = '%s'";
   if(db_table_exists('tripal_mviews')){
      $mview = db_fetch_object(db_query($sql,$view_name));
	   if($mview){
	      return $mview->mview_id;
	   }
   }
   return 0;
}
/**
*
*
* @ingroup tripal_core
*/
function tripal_mviews_action ($op,$mview_id){
   global $user;
   $args = array("$mview_id");
   
   if(!$mview_id){
      return '';
   }
   // get this mview details
   $sql = "SELECT * FROM {tripal_mviews} WHERE mview_id = $mview_id ";
   $mview = db_fetch_object(db_query($sql));
   
   // add a job or perform the action based on the given operation
   if($op == 'update'){
      tripal_add_job("Update materialized view '$mview->name'",'tripal_core',
         'tripal_update_mview',$args,$user->uid);
	}
   if($op == 'delete'){
	   // remove the mview from the tripal_mviews table
	   $sql = "DELETE FROM {tripal_mviews} ".
             "WHERE mview_id = $mview_id";
      db_query($sql);
		
	   // drop the table from chado if it exists
      $previous_db = tripal_db_set_active('chado');  // use chado database
      if (db_table_exists($mview->mv_table)) {
         $sql = "DROP TABLE $mview->mv_table";
         db_query($sql);
      }
      tripal_db_set_active($previous_db);  // now use drupal database
   }
   return '';
}
/**
* Update a Materialized View
*
* @param $mview_id
*   The unique identifier for the materialized view to be updated
*
* @return
*   True if successful, false otherwise
*
* @ingroup tripal_mviews_api
*/
function tripal_update_mview ($mview_id){
   $sql = "SELECT * FROM {tripal_mviews} WHERE mview_id = %d ";
   $mview = db_fetch_object(db_query($sql,$mview_id));
   if($mview){
      $previous_db = tripal_db_set_active('chado');  // use chado database
	   $results = db_query("DELETE FROM {$mview->mv_table}");
      $results = db_query("INSERT INTO $mview->mv_table ($mview->query)");
      tripal_db_set_active($previous_db);  // now use drupal database
      if($results){
	      $record = new stdClass();
         $record->mview_id = $mview_id;
         $record->last_update = time();
		   drupal_write_record('tripal_mviews',$record,'mview_id');
		   return 1;
      } else {
	     // TODO -- error handling
	     return 0;
	  }
   }
}
/**
*
*
* @ingroup tripal_mviews_api
*/
function tripal_mview_report ($mview_id) {
   // get this mview details
   $sql = "SELECT * FROM {tripal_mviews} WHERE mview_id = $mview_id ";
   $mview = db_fetch_object(db_query($sql));
   // create a table with each row containig stats for
   // an individual job in the results set.
   $return_url = url("admin/tripal/views/mviews/");
   $output .= "
Return to table of materialized views.
";
   $output .= "
";
   $output .= "Details for $mview->name:
";
   $output .= "
";
   $output .= "";
   if($mview->name){
      $output .= "  ".
      "    | View Name".
      " | $mview->name".
      " | 
";
   }   
   if($mview->modulename){
      $output .= "  ".
      "    | Module Name".
      " | $mview->modulename".
      " | 
";
   }
   if($mview->mv_table){
      $output .= "  ".
      "    | Table Name".
      " | $mview->mv_table".
      " | 
";
   }   
   if($mview->mv_specs){
      $output .= "  ".
      "    | Table Field Definitions".
      " | $mview->mv_specs".
      " | 
";
   }   
   if($mview->query){
      $output .= "  ".
      "    | Query".
      " | ".
      "$mview->query | 
";
   }   
   if($mview->indexed){
      $output .= "  ".
      "    | Indexed Fields".
      " | $mview->indexed".
      " | 
";
   }   
   if($mview->special_index){
      $output .= "  ".
      "    | Special Indexed Fields".
      " | $mview->speical_index".
      " | 
";
   }   
   if($mview->last_update > 0){
      $update = format_date($mview->last_update);
   } else {
      $update = 'Not yet populated';
   }
   $output .= "  ".
      "    | Last Update".
      " | $update".
      " | 
";
   // build the URLs using the url function so we can handle installations where
   // clean URLs are or are not used
   $update_url = url("admin/tripal/views/mviews/action/update/$mview->mview_id");
   $delete_url = url("admin/tripal/views/mviews/action/delete/$mview->mview_id");
   $edit_url = url("admin/tripal/views/mviews/edit/$mview->mview_id");
   $output .= "| Actions".
              " | Update, ".
              "     Edit, ".
              "     Delete | 
|---|
";
   $output .= "
";
   return $output;
}
/**
*
*
* @ingroup tripal_mviews_api
*/
function tripal_mviews_report () {
   $header = array('','MView Name','Last Update','');
   $rows = array();
   $mviews = db_query("SELECT * FROM {tripal_mviews} ORDER BY name");  
   while($mview = db_fetch_object($mviews)){
      if($mview->last_update > 0){
         $update = format_date($mview->last_update);
      } else {
         $update = 'Not yet populated';
      }
      $rows[] = array(
         l('View',"admin/tripal/views/mviews/report/$mview->mview_id") ." | ".
            l('Update',"admin/tripal/views/mviews/action/update/$mview->mview_id"),
         $mview->name,
         $update,
         l('Delete',"admin/tripal/views/mviews/action/delete/$mview->mview_id"),
      );
   }
   $rows[] = array(
      'data' => array( 
         array('data' => l('Create a new materialized view.',"admin/tripal/views/mviews/new"), 
               'colspan' => 4),
         )
   );
   return theme('table', $header, $rows);
}
/**
*
*
* @ingroup tripal_core
*/
function tripal_mviews_form(&$form_state = NULL,$mview_id = NULL){
   if(!$mview_id){
      $action = 'Add';
   } else {
      $action = 'Update';
   }
   // get this requested view
   if(strcmp($action,'Update')==0){
      $sql = "SELECT * FROM {tripal_mviews} WHERE mview_id = $mview_id ";
      $mview = db_fetch_object(db_query($sql));
      # set the default values.  If there is a value set in the 
      # form_state then let's use that, otherwise, we'll pull 
      # the values from the database 
      $default_name = $form_state['values']['name'];
      $default_mv_table = $form_state['values']['mv_table'];
      $default_mv_specs = $form_state['values']['mv_specs'];
      $default_indexed = $form_state['values']['indexed'];
      $default_mvquery = $form_state['values']['mvquery'];
      $default_special_index = $form_state['values']['special_index'];
      if(!$default_name){
         $default_name = $mview->name;
      }
      if(!$default_mv_table){
         $default_mv_table = $mview->mv_table;
      }
      if(!$default_mv_specs){
         $default_mv_specs = $mview->mv_specs;
      }
      if(!$default_indexed){
         $default_indexed = $mview->indexed;
      }
      if(!$default_mvquery){
         $default_mvquery = $mview->query;
      }
      if(!$default_special_index){
         $default_special_index = $mview->special_index;
      }
   }
   // Build the form
   $form['action'] = array(
      '#type' => 'value',
      '#value' => $action
   );
   $form['mview_id'] = array(
      '#type' => 'value',
      '#value' => $mview_id
   );
   $form['name']= array(
      '#type'          => 'textfield',
      '#title'         => t('View Name'),
      '#description'   => t('Please enter the name for this materialized view.'),
      '#required'      => TRUE,
      '#default_value' => $default_name,
      '#weight'        => 1
   );
   $form['mv_table']= array(
      '#type'          => 'textfield',
      '#title'         => t('Table Name'),
      '#description'   => t('Please enter the Postgres table name that this view will generate in the database.  You can use the schema and table name for querying the view'),
      '#required'      => TRUE,
      '#default_value' => $default_mv_table,
      '#weight'        => 3
   );
   $form['mv_specs']= array(
      '#type'          => 'textarea',
      '#title'         => t('Table Definition'),
      '#description'   => t('Please enter the field definitions for this view. Each field should be separated by a comma or enter each field definition on each line.'),
      '#required'      => TRUE,
      '#default_value' => $default_mv_specs,
      '#weight'        => 4
   );
   $form['indexed']= array(
      '#type'          => 'textarea',
      '#title'         => t('Indexed Fields'),
      '#description'   => t('Please enter the field names (as provided in the table definition above) that will be indexed for this view.  Separate by a comma or enter each field on a new line.'),
      '#required'      => FALSE,
      '#default_value' => $default_indexed,
      '#weight'        => 5
   );
   $form['mvquery']= array(
      '#type'          => 'textarea',
      '#title'         => t('Query'),
      '#description'   => t('Please enter the SQL statement used to populate the table.'),
      '#required'      => TRUE,
      '#default_value' => $default_mvquery,
      '#weight'        => 6
   );
/**
   $form['special_index']= array(
      '#type'          => 'textarea',
      '#title'         => t('View Name'),
      '#description'   => t('Please enter the name for this materialized view.'),
      '#required'      => TRUE,
      '#default_value' => $default_special_index,
      '#weight'        => 7
   );
*/
   $form['submit'] = array (
     '#type'         => 'submit',
     '#value'        => t($action),
     '#weight'       => 8,
     '#executes_submit_callback' => TRUE,
   );
   $form['#redirect'] = 'admin/tripal/views/mviews';
   return $form;
}
/**
*
*
* @ingroup tripal_core
*/
function tripal_mviews_form_submit($form, &$form_state){
   
   $action = $form_state['values']['action'];
   if(strcmp($action,'Update')==0){
      $record = new stdClass();
      $record->mview_id = $form_state['values']['mview_id'];
      $record->name = $form_state['values']['name'];
      $record->mv_table = $form_state['values']['mv_table'];
      $record->mv_specs = $form_state['values']['mv_specs'];
      $record->indexed = $form_state['values']['indexed'];
      $record->query = $form_state['values']['mvquery'];
      $record->special_index = $form_state['values']['special_index'];
      // add the record to the tripal_mviews table and if successful
      // create the new materialized view in the chado schema
      if(drupal_write_record('tripal_mviews',$record,'mview_id')){
         drupal_set_message('View updated successfullly');
      } else {
         drupal_set_message('View update failed');
      }
   }
   else if(strcmp($action,'Add')==0){
      tripal_add_mview ($form_state['values']['name'], 'tripal_core',
         $form_state['values']['mv_table'], $form_state['values']['mv_specs'],
         $form_state['values']['indexed'], $form_state['values']['mvquery'],
         $form_state['values']['special_index']);
   }
   else {
        drupal_set_message("No action performed.");
   }
   return '';
}