tripal_ws.admin.inc 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  1. <?php
  2. /**
  3. * Provide form to store information of other Tripal sites
  4. *
  5. * @param unknown $form
  6. * @param unknown $form_state
  7. */
  8. function tripal_ws_tripal_sites_form($form, &$form_state) {
  9. $form = array();
  10. $values = key_exists('values', $form_state) ? $form_state['values'] : NULL;
  11. $tripal_site = $values ? $values['tripal_site'] : 0;
  12. $results =
  13. db_select('tripal_sites', 'ts')
  14. ->fields('ts')
  15. ->execute();
  16. $headers = array('Name', 'URL', 'Version', 'Description', 'Action');
  17. $rows = array();
  18. while ($site = $results->fetchObject()) {
  19. $rows[] = array(
  20. $site->name,
  21. $site->url,
  22. $site->version,
  23. $site->description,
  24. array(
  25. 'data' => l('Edit', '/admin/tripal/storage/ws/tripal_sites/edit/' . $site->id) . ' | ' .
  26. l('Remove', '/admin/tripal/storage/ws/tripal_sites/remove/' . $site->id),
  27. 'nowrap' => TRUE,
  28. ),
  29. );
  30. }
  31. if (count($rows) == 0) {
  32. $rows[] = array('No configured Tripal site.', array('colspan' => 5));
  33. }
  34. $table = array(
  35. 'header' => $headers,
  36. 'rows' => $rows,
  37. 'attributes' => array(),
  38. 'sticky' => FALSE,
  39. 'caption' => '',
  40. 'colgroups' => array(),
  41. 'empty' => '',
  42. );
  43. $output = theme_table($table);
  44. $form['instructions'] = array(
  45. '#type' => 'item',
  46. '#markup' => t('The following is a list of remote Tripal sites with which
  47. this site can communicate. You may add and remove site as needed.')
  48. );
  49. $form['table'] = array(
  50. '#markup' => $output
  51. );
  52. return $form;
  53. }
  54. /**
  55. * Provide form to add/edit a Tripal site
  56. *
  57. * @param unknown $form
  58. * @param unknown $form_state
  59. */
  60. function tripal_ws_tripal_sites_edit_form($form, &$form_state, $tripal_site_id = NULL) {
  61. $id = NULL;
  62. $name = '';
  63. $url = '';
  64. $version = '';
  65. $description = '';
  66. if ($tripal_site_id) {
  67. $site = db_select('tripal_sites', 'ts')
  68. ->fields('ts')
  69. ->condition('id', $tripal_site_id)
  70. ->execute()
  71. ->fetchObject();
  72. if (is_object($site)) {
  73. $id = $site->id;
  74. $name = $site->name;
  75. $url = $site->url;
  76. $version = $site->version;
  77. $description = $site->description;
  78. }
  79. }
  80. $form = array();
  81. $form['tripal_site_info']['id'] = array(
  82. '#type' => 'hidden',
  83. '#value' => $id,
  84. );
  85. $form['tripal_site_info']['name'] = array(
  86. '#title' => t('Name'),
  87. '#type' => 'textfield',
  88. '#description' => t('Full name of the Tripal site.'),
  89. '#default_value' => $name,
  90. '#required' => TRUE
  91. );
  92. $form['tripal_site_info']['url'] = array(
  93. '#title' => t('URL'),
  94. '#type' => 'textfield',
  95. '#description' => t('The URL of the Tripal site.'),
  96. '#default_value' => $url,
  97. '#required' => TRUE
  98. );
  99. $form['tripal_site_info']['version'] = array(
  100. '#title' => t('Version'),
  101. '#type' => 'textfield',
  102. '#description' => t('Web services version used by the Tripal site.'),
  103. '#default_value' => $version,
  104. );
  105. $form['tripal_site_info']['description'] = array(
  106. '#title' => t('Description'),
  107. '#type' => 'textarea',
  108. '#default_value' => $description,
  109. );
  110. $form['submit_button'] = array(
  111. '#type' => 'submit',
  112. '#value' => t('Save'),
  113. '#name' => 'save'
  114. );
  115. $form['cancel_button'] = array(
  116. '#type' => 'button',
  117. '#value' => t('Cancel'),
  118. '#name' => 'cancel_button',
  119. '#limit_validation_errors' => array()
  120. );
  121. return $form;
  122. }
  123. /**
  124. * Implements hook_validate()
  125. *
  126. * @param unknown $form
  127. * @param unknown $form_state
  128. */
  129. function tripal_ws_tripal_sites_edit_form_validate($form, &$form_state) {
  130. if (array_key_exists('clicked_button', $form_state)) {
  131. if ($form_state['clicked_button']['#name'] =='cancel_button') {
  132. drupal_goto('/admin/tripal/storage/ws/tripal_sites');
  133. }
  134. // Make sure URL does not already exist
  135. else if ($form_state['clicked_button']['#name'] =='save') {
  136. $url = $form_state['values']['url'];
  137. $check = NULL;
  138. // When updating a record
  139. if ($form_state['values']['id']) {
  140. $check =
  141. db_select('tripal_sites', 'ts')
  142. ->fields('ts', array('id'))
  143. ->condition('url', $url)
  144. ->condition('id', $form_state['values']['id'], '<>')
  145. ->execute()
  146. ->fetchField();
  147. }
  148. // When inserting a record
  149. else {
  150. $check =
  151. db_select('tripal_sites', 'ts')
  152. ->fields('ts', array('id'))
  153. ->condition('url', $url)
  154. ->execute()
  155. ->fetchField();
  156. }
  157. if ($check) {
  158. form_set_error('url', t('The URL is used by another site.'));
  159. }
  160. }
  161. }
  162. }
  163. /**
  164. * Implements hook_submit()
  165. *
  166. * @param unknown $form
  167. * @param unknown $form_state
  168. */
  169. function tripal_ws_tripal_sites_edit_form_submit($form, &$form_state) {
  170. $id = $form_state['values']['id'];
  171. $name = $form_state['values']['name'];
  172. $url = $form_state['values']['url'];
  173. $version = $form_state['values']['version'];
  174. $description = $form_state['values']['description'];
  175. // If there is an 'id' do an update, otherwise do an insert
  176. if ($id) {
  177. db_update('tripal_sites')
  178. ->fields(array(
  179. 'name' => $name,
  180. 'url' => $url,
  181. 'version' => $version,
  182. 'description' => $description
  183. ))
  184. ->condition('id', $id)
  185. ->execute();
  186. drupal_set_message(t('Tripal site \'' . $name . '\' has been updated.'));
  187. }
  188. else {
  189. db_insert('tripal_sites')
  190. ->fields(array(
  191. 'name' => $name,
  192. 'url' => $url,
  193. 'version' => $version,
  194. 'description' => $description
  195. ))
  196. ->execute();
  197. drupal_set_message(t('Tripal site \'' . $name . '\' has been added.'));
  198. }
  199. drupal_goto('/admin/tripal/storage/ws/tripal_sites');
  200. }
  201. /**
  202. * Implements hook_form()
  203. * Reset term used by semantic web
  204. *
  205. * @param $form
  206. * @param $form_state
  207. * @param $table
  208. * @param $column
  209. * @return $form
  210. */
  211. function tripal_ws_tripal_sites_remove_form($form, &$form_state, $id = NULL) {
  212. $name = '';
  213. $record_id = '';
  214. if ($id) {
  215. $site = db_select('tripal_sites', 'ts')
  216. ->fields('ts')
  217. ->condition('id', $id)
  218. ->execute()
  219. ->fetchObject();
  220. if (is_object($site)) {
  221. $record_id = $site->id;
  222. $name = $site->name;
  223. }
  224. }
  225. $form['confirmation'] = array(
  226. '#markup' => 'Really remove the \'' . $name . '\' Tripal site? ',
  227. );
  228. $form['tripal_site_id'] = array(
  229. '#type' => 'value',
  230. '#value' => $record_id
  231. );
  232. $form['tripal_site_name'] = array(
  233. '#type' => 'value',
  234. '#value' => $name
  235. );
  236. $form['submit_button'] = array(
  237. '#type' => 'submit',
  238. '#value' => t('Remove'),
  239. '#name' => 'remove'
  240. );
  241. $form['cancel_button'] = array(
  242. '#type' => 'button',
  243. '#value' => t('Cancel'),
  244. '#name' => 'cancel_button',
  245. '#limit_validation_errors' => array()
  246. );
  247. return $form;
  248. }
  249. /**
  250. * Implements hook_form_validate()
  251. *
  252. * Validate function for resetting the semantic web term
  253. *
  254. * @param unknown $form
  255. * @param unknown $form_state
  256. */
  257. function tripal_ws_tripal_sites_remove_form_validate($form, &$form_state) {
  258. if (array_key_exists('clicked_button', $form_state)) {
  259. if ($form_state['clicked_button']['#name'] =='cancel_button') {
  260. drupal_goto('/admin/tripal/storage/ws/tripal_sites');
  261. }
  262. else if (!$form_state['values']['tripal_site_id']) {
  263. drupal_set_message(t('Invalid Tripal site id'), 'error');
  264. }
  265. }
  266. }
  267. /**
  268. * Implements hook_form_submit()
  269. *
  270. * Submit function for editing the semantic web term
  271. *
  272. * @param unknown $form
  273. * @param unknown $form_state
  274. */
  275. function tripal_ws_tripal_sites_remove_form_submit($form, &$form_state) {
  276. $id = $form_state['values']['tripal_site_id'];
  277. $name = $form_state['values']['tripal_site_name'];
  278. if ($id) {
  279. db_delete('tripal_sites')
  280. ->condition('id', $id)
  281. ->execute();
  282. drupal_set_message('The Tripal site \'' .$name . '\' has been removed.');
  283. }
  284. drupal_goto('/admin/tripal/storage/ws/tripal_sites');
  285. }