headers); if ($response->data && strpos($headers['content-type'], 'text/html') === FALSE && strpos($response->data, "Malformed DOI") === FALSE ) { $crossref_xml = new DOMDocument('1.0'); if (!$crossref_xml->loadXML($response->data)) { drupal_set_message(t('Error parseing DOI response, @msg')); $form['doi']['#value'] = ''; return $form; } else { return upei_roblib_ill_populate_form_doi($crossref_xml, $form); } } else { drupal_set_message(t('Error retrieve data using DOI of @doi', array('@doi' => $doi)), 'error'); $form['doi']['#value'] = ''; return $form; } } function upei_roblib_ill_populate_form_doi($crossref_xml, $form) { $full_title = $crossref_xml->getElementsbyTagName('full_title') ->item(0)->nodeValue; $form['Title']['#value'] = $full_title; $form['ISSN']['#value'] = $crossref_xml->getElementsbyTagName('issn') ->item(0)->nodeValue; $form['Date']['#value'] = $crossref_xml->getElementsbyTagName('year') ->item(0)->nodeValue; $form['ArticleTitle']['#value'] = $crossref_xml->getElementsbyTagName('title') ->item(0)->nodeValue; $form['ImageOrPageNumber']['#value'] = $crossref_xml->getElementsbyTagName('first_page') ->item(0)->nodeValue; $form['PagesRequested']['#value'] = $crossref_xml->getElementsbyTagName('last_page') ->item(0)->nodeValue; $form['Volume']['#value'] = $crossref_xml->getElementsbyTagName('volume') ->item(0)->nodeValue; $form['Issue']['#value'] = $crossref_xml->getElementsbyTagName('issue') ->item(0)->nodeValue; foreach ($crossref_xml->getElementsbyTagName('person_name') as $person) { $role = $person->getAttribute('contributor_role'); $sequence = $person->getAttribute('sequence'); if ($person->getAttribute('contributor_role') == 'author' && $person->getAttribute('sequence') == 'first' ) { $author = $person->getElementsbyTagName('surname') ->item(0)->nodeValue . ',' . $person->getElementsbyTagName('given_name') ->item(0)->nodeValue; } } $form['ArticleAuthor']['#value'] = $author; $form['doi']['#value'] = ''; return $form; } /** * Get the DOI name for the given url. * * @param string $doi_url * A DOI url, or a DOI name with or without the "doi:" prefix. If the $url * is a CrossRef ID passed in as doi:10.1016/j.tiv.2011.10.017 or * 10.1111/eve.12339 it will not get changed by running it through parse_url. * * @return string * A string containing the DOI name. */ function upei_roblib_ill_doi_name_from_url($doi_url) { // Allows for DOI to be entered in the following formats: 10.1111/eva.12339, // http://dx.doi.org/10.1111/eva.12339, http://doi.org/10.1111/eva.12339, // or doi:10.1111/eva.12339. Removing whitespace before parsing the url and // then removing any trailing "/" from the returned path. $doi_name = trim(parse_url(trim($doi_url), PHP_URL_PATH), '/'); return $doi_name; } /** * Perform a request to CrossRef for the given ID. * * @param string $doi * A DOI to lookop. May be provided with or without the "doi:" prefix. Can * also pass a full DOI url (i.e, http://doi.org/10.1111/eva.12339 ). * * @return object * An object as provided by drupal_http_request(). */ function upei_roblib_ill_doi_load($doi) { // Allows for $id to pass a DOI url string or the DOI name. $id = upei_roblib_ill_doi_name_from_url($doi); $openurl = variable_get('upei_roblib_ill_doi_openurl', 'http://www.crossref.org/openurl'); $openurl_pid = variable_get('upei_roblib_ill_doi_openurl_pid', 'user@example.com'); $url = url($openurl, array( 'query' => array( 'noredirect' => 'true', 'pid' => $openurl_pid, 'format' => 'unixref', 'id' => ((strpos($id, 'doi:') === 0) ? $id : 'doi:' . $id), ), )); return drupal_http_request($url); }