123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271 |
- <?php
- /**
- * @class
- * Purpose:
- *
- * Data:
- * Assumptions:
- */
- class remote__data extends WebServicesField {
- // --------------------------------------------------------------------------
- // EDITABLE STATIC CONSTANTS
- //
- // The following constants SHOULD be set for each descendant class. They are
- // used by the static functions to provide information to Drupal about
- // the field and it's default widget and formatter.
- // --------------------------------------------------------------------------
- // The default label for this field.
- public static $default_label = 'Remote Tripal Site';
- // The default description for this field.
- public static $default_description = 'Allows for inclusion of remote data from another Tripal site.';
- // The default widget for this field.
- public static $default_widget = 'remote__data_widget';
- // The default formatter for this field.
- public static $default_formatter = 'remote__data_formatter';
- // The module that manages this field.
- public static $module = 'tripal_ws';
- // A list of global settings. These can be accessed within the
- // globalSettingsForm. When the globalSettingsForm is submitted then
- // Drupal will automatically change these settings for all fields.
- // Once instances exist for a field type then these settings cannot be
- // changed.
- public static $default_settings = array(
- 'storage' => 'field_tripal_ws_storage',
- // It is expected that all fields set a 'value' in the load() function.
- // In many cases, the value may be an associative array of key/value pairs.
- // In order for Tripal to provide context for all data, the keys should
- // be a controlled vocabulary term (e.g. rdfs:type). Keys in the load()
- // function that are supported by the query() function should be
- // listed here.
- 'searchable_keys' => array(),
- );
- // Provide a list of instance specific settings. These can be access within
- // the instanceSettingsForm. When the instanceSettingsForm is submitted
- // then Drupal with automatically change these settings for the instance.
- // It is recommended to put settings at the instance level whenever possible.
- // If you override this variable in a child class be sure to replicate the
- // term_name, term_vocab, term_accession and term_fixed keys as these are
- // required for all TripalFields.
- public static $default_instance_settings = array(
- // The short name for the vocabulary (e.g. schema, SO, GO, PATO, etc.).
- 'term_vocabulary' => 'schema',
- // The name of the term.
- 'term_name' => 'Thing',
- // The unique ID (i.e. accession) of the term.
- 'term_accession' => 'property',
- // Set to TRUE if the site admin is not allowed to change the term
- // type, otherwise the admin can change the term mapped to a field.
- 'term_fixed' => FALSE,
- // Indicates if this field should be automatically attached to display
- // or web services or if this field should be loaded separately. This
- // is convenient for speed. Fields that are slow should for loading
- // should have auto_attach set to FALSE so tha their values can be
- // attached asynchronously.
- 'auto_attach' => FALSE,
- // Settings to allow the site admin to set the remote data source info.
- 'data_info' => array(
- 'query' => '',
- 'remote_site' => '',
- 'description' => '',
- 'rd_field_name' => '',
- ),
- );
- // A boolean specifying that users should not be allowed to create
- // fields and instances of this field type through the UI. Such
- // fields can only be created programmatically with field_create_field()
- // and field_create_instance().
- public static $no_ui = FALSE;
- // A boolean specifying that the field will not contain any data. This
- // should exclude the field from web services or downloads. An example
- // could be a quick search field that appears on the page that redirects
- // the user but otherwise provides no data.
- public static $no_data = FALSE;
- // Holds an object describing the remote site that tihs field connects to.
- private $remote_site = NULL;
- public function __construct($field, $instance) {
- parent::__construct($field, $instance);
- //Get the site url from the tripal_sites table.
- $site_id_ws = $this->instance['settings']['data_info']['remote_site'];
- $this->remote_site = db_select('tripal_sites', 'ts')
- ->fields('ts')
- ->condition('ts.id', $site_id_ws)
- ->execute()
- ->fetchObject();
- }
- /**
- * @see WebServicesField::load()
- */
- public function load($entity) {
- $field_name = $this->field['field_name'];
- $field_type = $this->field['type'];
- // Set some defaults for the empty record.
- $entity->{$field_name}['und'][0] = array(
- 'value' => array(),
- );
- // Get the query set by the admin for this field and replace any tokesn
- $query_str = $this->instance['settings']['data_info']['query'];
- $bundle = tripal_load_bundle_entity(array('name' => $entity->bundle));
- $query_str = tripal_replace_entity_tokens($query_str, $entity, $bundle);
- // Make the request.
- $data = $this->makeRemoteRequest($query_str);
- if(!$data){
- return;
- }
- $total_items = $data['totalItems'];
- // Iterate through the members returned and save those for the field.
- for ($i = 0; $i < count($data['members']); $i++) {
- $member = $data['members'][$i];
- // Get the cotent type and remote entity id
- $content_type = $member['@type'];
- $remote_entity_id = $member['@id'];
- $remote_entity_id = preg_replace('/^.*\/(\d+)/', '$1', $remote_entity_id);
- // Save the member information for use later.
- $entity->{$field_name}['und'][$i]['remote_entity'] = $member;
- // Next get the the details about this member.
- $query_field = 'relationship';
- $query_field_url = $content_type . '/' . $remote_entity_id . '/' . $query_field;
- $field_data = $this->makeRemoteRequest($query_field_url);
- if(!$field_data){
- // If we encounter any type of error, we'll reset the field and return.
- $entity->{$field_name}['und'] = array();
- $entity->{$field_name}['und'][0] = array(
- 'value' => array(),
- );
- return;
- }
- // Set the field data as the value.
- $field_data_type = $field_data['@type'];
- $entity->{$field_name}['und'][$i]['value'] = $field_data;
- }
- }
- /**
- *
- * @see TripalField::settingsForm()
- */
- public function instanceSettingsForm() {
- $element = parent::instanceSettingsForm();
- // Get the setting for the option for how this widget.
- $instance = $this->instance;
- $settings = '';
- $site_list = '';
- $tokens = array();
- // Get the form info from the bundle about to be saved.
- $bundle_info = tripal_load_bundle_entity(array($instance['bundle']));
- // Retrieve all available tokens.
- $tokens = tripal_get_entity_tokens($bundle_info);
- $element['data_info'] = array(
- '#type' => 'fieldset',
- '#title' => 'Remote Data Settings',
- '#description' => 'Provide the site name, query and description for the remote data source.',
- '#collapsible' => TRUE,
- '#collapsed' => FALSE,
- '#prefix' => "<div id='set_titles-fieldset'>",
- '#suffix' => '</div>',
- );
- // Get the site info from the tripal_sites table.
- $sites = db_select('tripal_sites', 's')
- ->fields('s')
- ->execute()->fetchAll();
- foreach ($sites as $site) {
- $rows[$site->id] =$site->name;
- }
- $element['data_info']['remote_site'] = array(
- '#type' => 'select',
- '#title' => t('Site'),
- '#options' => $rows,
- '#default_value' => $this->instance['settings']['data_info']['remote_site'],
- );
- $element['data_info']['query'] = array(
- '#type' => 'textarea',
- '#title' => 'Query',
- '#description' => 'Build the query string that should be appended after the url. The tokens
- listed below may be used in your query build.',
- '#default_value' => $this->instance['settings']['data_info']['query'],
- '#rows' => 5,
- '#required' => TRUE
- );
- $element['data_info']['rd_field_name'] = array(
- '#type' => 'textfield',
- '#title' => 'Field',
- '#description' => 'Name of the field you would like to display.',
- '#default_value' => $this->instance['settings']['data_info']['rd_field_name'],
- '#required' => TRUE
- );
- $element['data_info']['token_display']['tokens'] = array(
- '#type' => 'hidden',
- '#value' => serialize($tokens)
- );
- $element['data_info']['token_display'] = array(
- '#type' => 'fieldset',
- '#title' => 'Available Tokens',
- '#description' => 'Copy the token and paste it into the "Query" text field above.',
- '#collapsible' => TRUE,
- '#collapsed' => TRUE
- );
- $element['data_info']['token_display']['content'] = array(
- '#type' => 'item',
- '#markup' => theme_token_list($tokens),
- );
- $element['data_info']['description'] = array(
- '#type' => 'textarea',
- '#title' => 'Description',
- '#description' => 'Describe the data being pulled in.',
- '#default_value' => $this->instance['settings']['data_info']['description'],
- '#rows' => 1
- );
- /*$element['test_button']['data'] = array(
- '#prefix' => '<div class="returned-data">',
- '#suffix' => '</div>',
- '#type' => 'container',
- //…
- );
- $element['test_button'] = array(
- '#type' => 'button',
- '#value' => t('Test Query'),
- '#ajax' => array(
- 'wrapper' => 'data-id',
- 'callback' => 'tripal_ws_url_query_test',
- ),
- //…
- );*/
- return $element;
- }
- /**
- *
- * @param unknown $form
- * @param unknown $form_state
- */
- public function instanceSettingsFormValidate($form, &$form_state) {
- }
- }
|