123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168 |
- <?php
- /**
- * @file
- * API functions relating to Analysis'
- *
- * @defgroup tripal_analysis_api Analysis Module API
- * @ingroup tripal_analysis
- * @ingroup tripal_api
- */
- /**
- * Retrieve properties of a given type for a given analysis
- *
- * @param $analysis_id
- * The analysis_id of the properties you would like to retrieve
- * @param $property
- * The cvterm name of the properties to retrieve
- *
- * @return
- * An analysis chado variable with the specified properties expanded
- *
- * @ingroup tripal_analysis_api
- */
- function tripal_analysis_get_property($analysis_id, $property) {
- return tripal_core_get_property('analysis', $analysis_id, $property, 'tripal');
- }
- /**
- * Insert a given property
- *
- * @param $analysis_id
- * The analysis_id of the property to insert
- * @param $property
- * The cvterm name of the property to insert
- * @param $value
- * The value of the property to insert
- * @param $update_if_present
- * A boolean indicated whether to update the record if it's already present
- *
- * @return
- * True of success, False otherwise
- *
- * @ingroup tripal_analysis_api
- */
- function tripal_analysis_insert_property($analysis_id, $property, $value, $update_if_present = 0) {
- return tripal_core_insert_property('analysis', $analysis_id, $property, 'tripal', $value, $update_if_present);
- }
- /**
- * Update a given property
- *
- * @param $analysis_id
- * The analysis_id of the property to update
- * @param $property
- * The cvterm name of the property to update
- * @param $value
- * The value of the property to update
- * @param $insert_if_missing
- * A boolean indicated whether to insert the record if it's absent
- *
- * Note: The property will be identified using the unique combination of the $analysis_id and $property
- * and then it will be updated with the supplied value
- *
- * @return
- * True of success, False otherwise
- *
- * @ingroup tripal_analysis_api
- */
- function tripal_analysis_update_property($analysis_id, $property, $value, $insert_if_missing = 0) {
- return tripal_core_update_property('analysis', $analysis_id, $property, 'tripal', $value, $insert_if_missing);
- }
- /**
- * Delete a given property
- *
- * @param $analysis_id
- * The analysis_id of the property to delete
- * @param $property
- * The cvterm name of the property to delete
- *
- * Note: The property will be identified using the unique combination of the $analysis_id and $property
- * and then it will be deleted
- *
- * @return
- * True of success, False otherwise
- *
- * @ingroup tripal_analysis_api
- */
- function tripal_analysis_delete_property($analysis_id, $property) {
- return tripal_core_delete_property('analysis', $analysis_id, $property, 'tripal');
- }
- /**
- * Retreives the node of a sync'ed analysis
- *
- * @param $analysis_id
- * The analysis_id of the property to delete
- *
- * @return
- * node of analysis on success, null otherwise
- *
- * @ingroup tripal_analysis_api
- */
- function tripal_analysis_get_node($analysis_id) {
- $sql = "SELECT *
- FROM chado_analysis CA
- INNER JOIN node N on CA.nid = N.nid
- WHERE analysis_id = %d";
- $node = db_fetch_object(db_query($sql, $analysis_id));
- return $node;
- }
- /**
- * @section Chado Table Descriptions
- */
- /**
- * Implements hook_chado_schema_v1_11_table()
- * Purpose: To add descriptions and foreign keys to default table description
- * Note: This array will be merged with the array from all other implementations
- *
- * @return
- * Array describing the analysis table
- *
- * @ingroup tripal_schema_api
- */
- function tripal_analysis_chado_schema_v1_11_analysis() {
- $description = array();
- // Default table description in tripal_core.schema.api.inc: tripal_core_chado_schema_v1_11_analysis()
- $referring_tables = array(
- 'analysisfeature',
- 'analysisprop',
- 'phylotree',
- 'quantification'
- );
- $description['referring_tables'] = $referring_tables;
- return $description;
- }
- /**
- * Implements hook_chado_schema_v1_2_table()
- * Purpose: To add descriptions and foreign keys to default table description
- * Note: This array will be merged with the array from all other implementations
- *
- * @return
- * Array describing the analysis table
- *
- * @ingroup tripal_schema_api
- */
- function tripal_analysis_chado_schema_v1_2_analysis() {
- $description = array();
- // Default table description in tripal_core.schema.api.inc: tripal_core_chado_schema_v1_2_analysis()
- $referring_tables = array(
- 'analysisfeature',
- 'analysisprop',
- 'phylotree',
- 'quantification'
- );
- $description['referring_tables'] = $referring_tables;
- return $description;
- }
|