123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229 |
- <?php
- function tripal_add_chado_semweb_table($chado_table) {
-
- if (preg_match('/tripal_.+_temp/', $chado_table)) {
- return;
- }
-
-
- $schema = chado_get_schema($chado_table);
- foreach ($schema['fields'] as $chado_column => $details) {
-
- $record = db_select('chado_semweb', 'CS')
- ->fields('CS', array('chado_semweb_id'))
- ->condition('CS.chado_table', $chado_table)
- ->condition('CS.chado_column', $chado_column)
- ->execute()
- ->fetchField();
- if (!$record) {
- $record = array(
- 'chado_table' => $chado_table,
- 'chado_column' => $chado_column,
- );
- drupal_write_record('chado_semweb', $record);
- }
- }
- }
- function tripal_associate_chado_semweb_term($chado_table, $chado_column, $term,
- $update = FALSE) {
-
- if (!$chado_column) {
- tripal_set_message('Please provide the $chado_column argument.', TRIPAL_ERROR);
- return FALSE;
- }
- if (!$term) {
- tripal_set_message('Please provide the $term argument.', TRIPAL_ERROR);
- return FALSE;
- }
-
- if ($chado_table) {
- $schema = chado_get_schema($chado_table);
- if (!$schema) {
- tripal_set_message('The $chado_table is not a known table in Chado.', TRIPAL_ERROR);
- return FALSE;
- }
- if (!array_key_exists($chado_column, $schema['fields'])) {
- tripal_set_message('The $chado_column is not a known column in the $chado_table.', TRIPAL_ERROR);
- return FALSE;
- }
- }
-
-
- $query = db_select('chado_semweb', 'CS')
- ->fields('CS', array('chado_semweb_id'))
- ->condition('chado_column', $chado_column);
- if ($chado_table) {
- $query->condition('chado_table', $chado_table);
- }
- $query->range(0,1);
- $id = $query->execute()->fetchField();
- if (!$id) {
-
-
- if (!$chado_table) {
- tripal_set_message('The provided $chado_column has no match for any
- table currently known. This could be because the table has not yet
- been added to the semantic web management. Please provide the
- $chado_table.', TRIPAL_ERROR);
- return FALSE;
- }
-
- $id = db_insert('chado_semweb')
- ->fields(array(
- 'chado_table' => $chado_table,
- 'chado_column' => $chado_column,
- 'cvterm_id' => $term->cvterm_id,
- ));
- if ($id) {
- return TRUE;
- }
- else {
- tripal_set_message('Failure associating term.', TRIPAL_ERROR);
- return FALSE;
- }
- }
-
-
- $update = db_update('chado_semweb')
- ->fields(array(
- 'cvterm_id' => $term->cvterm_id
- ))
- ->condition('chado_column', $chado_column);
- if ($chado_table) {
- $update->condition('chado_table', $chado_table);
- }
- if (!$update) {
- $update->condition('cvterm_id', NULL);
- }
- $num_updated = $update->execute();
- if (!$num_updated) {
- tripal_set_message('Failure associating term.', TRIPAL_ERROR);
- return FALSE;
- }
- return TRUE;
- }
- function tripal_get_chado_semweb_term($chado_table, $chado_column, $options = array()) {
- $cvterm_id = db_select('chado_semweb', 'CS')
- ->fields('CS', array('cvterm_id'))
- ->condition('chado_column', $chado_column)
- ->condition('chado_table', $chado_table)
- ->execute()
- ->fetchField();
- if ($cvterm_id) {
- $cvterm = chado_generate_var('cvterm', array('cvterm_id' => $cvterm_id));
- if (array_key_exists('return_object', $options)) {
- return $cvterm;
- }
- return $cvterm->dbxref_id->db_id->name . ':' . $cvterm->dbxref_id->accession;
- }
- }
- function tripal_get_chado_semweb_column($chado_table, $term) {
- $columns = db_select('chado_semweb', 'CS')
- ->fields('CS')
- ->condition('chado_table', $chado_table)
- ->execute();
- while($column = $columns->fetchObject()) {
- $cvterm_id = $column->cvterm_id;
- if ($cvterm_id) {
- $cvterm = chado_generate_var('cvterm', array('cvterm_id' => $cvterm_id));
- if ($term == $cvterm->name) {
- return $column->chado_column;
- }
- else if ($term == preg_replace('/ /', '_', $cvterm->name)) {
- return $column->chado_column;
- }
- else if ($term == $cvterm->dbxref_id->db_id->name . ':' . $cvterm->dbxref_id->accession) {
- return $column->chado_column;
- }
- }
- }
- return FALSE;
- }
|