A search interface for data from the Politics of Patents case study (part of Copim WP6): this parses data from the archive of RTF files and provides additional data from the European Patent Office API. https://patents.copim.ac.uk
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

преди 3 години
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. <?php
  2. function random_record (){
  3. // Generate a random number for sorting by random
  4. $random = rand();
  5. // Assemble a query string to send to Solr. This uses the Solr hostname from config.env. Solr's query syntax can be found at many sites including https://lucene.apache.org/solr/guide/6_6/the-standard-query-parser.html
  6. // This query retrieves only the bib identifier field for records which satisfy the search query
  7. #$solrurl = 'http://host.docker.internal:8983/solr/epo_data/select?q.op=OR&q=*%3A*&wt=json&sort=random_' . $random . '%20asc';
  8. $solrurl = 'http://' . $_ENV["SOLR_HOSTNAME"] . ':' . $_ENV["SOLR_PORT"] . '/solr/' . $_ENV["SOLR_CORE"] . '/select?q.op=OR&q=*%3A*&wt=json&sort=random_' . $random . '%20asc';
  9. // Perform Curl request on the Solr API
  10. $ch = curl_init();
  11. curl_setopt($ch, CURLOPT_URL, $solrurl);
  12. curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
  13. curl_setopt($ch, CURLOPT_HEADER, FALSE);
  14. curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'GET');
  15. $response = curl_exec($ch);
  16. curl_close($ch);
  17. // Turn the API response into useful Json
  18. $json = json_decode($response);
  19. // Pick a random key out of the docs array
  20. $random = array_rand($json->response->docs);
  21. // Search for the application ID in the content element and display it
  22. $content = $json->response->docs[$random]->content;
  23. preg_match('/Application.*\n(.*)\n/', $content, $application_id);
  24. $application_id = json_encode($application_id[1]);
  25. $output['application_id'] = $application_id;
  26. // Search for the publication ID in the content element and display it
  27. $content = $json->response->docs[$random]->content;
  28. preg_match('/Publication.*\n(.*)\n/', $content, $publication);
  29. $publication_id = json_encode($publication[1]);
  30. $output['publication_id'] = $publication_id;
  31. // Search for the title in the content element and display it
  32. $content = $json->response->docs[$random]->content;
  33. preg_match('/Title.*\n(.*)\n/', $content, $title);
  34. $title = json_encode($title[1]);
  35. $output['title'] = $title;
  36. // Search for the abstract in the content element and display it
  37. $content = $json->response->docs[$random]->content;
  38. preg_match('/Abstract.*\n(.*)\n/', $content, $abstract);
  39. $abstract = json_encode($abstract[1]);
  40. $output['abstract'] = $abstract;
  41. return $output;
  42. }
  43. ?>