Source of file PxdInfo.php
Size: 2,962 Bytes - Last Modified: 2019-05-10T12:24:09+01:00
src/Reader/PxdInfo.php
12345678910111213141516171819202122232425262728293031323334353637383940
Covered by 3 test(s):
41
Covered by 1 test(s):
42
Covered by 3 test(s):
43
Covered by 2 test(s):
44
Covered by 2 test(s):
45464748
Covered by 3 test(s):
49
Covered by 3 test(s):
50515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
| <?php /** * Copyright 2016 University of Liverpool * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ namespace pgb_liv\php_ms\Reader; /** * * @author Andrew Collins */ class PxdInfo { const INFO_PATH = 'http://proteomecentral.proteomexchange.org/cgi/GetDataset?ID=%s&outputMode=XML&test=no'; private $identifier; private $fileList = array(); /** * Proteome Exchange identifer to search for. * * @param string $id * Identifier must be specified as either "PXD###" or as an integer */ public function __construct($identifier) { if (stripos($identifier, 'PXD') === 0) { $this->identifier = (int) substr($identifier, 3); } elseif (is_numeric($identifier) && (int) $identifier == $identifier) { $this->identifier = (int) $identifier; } else { throw new \InvalidArgumentException('Identifier must be either an integer or PXD#### string'); } $this->parseInfo(); } private function parseInfo() { $url = sprintf(PxdInfo::INFO_PATH, $this->identifier); $data = get_headers($url, 1); $status = explode(' ', $data[0], 3); if ($status[1] != 200) { throw new \InvalidArgumentException($status[2]); } $schema = new \SimpleXMLElement($url, null, true); foreach ($schema->FullDatasetLinkList->FullDatasetLink as $datasetLink) { if ((string) $datasetLink->cvParam->attributes()->accession == 'PRIDE:0000411') { $this->datasetBaseUrl = (string) $datasetLink->cvParam->attributes()->accession->value; } } $this->idString = $schema->attributes()->id; $file = array(); if (isset($schema->DatasetFileList)) { foreach ($schema->DatasetFileList->DatasetFile as $datasetFile) { $file['id'] = (string) $datasetFile->attributes()->id; $file['name'] = (string) $datasetFile->attributes()->name; $file['location'] = (string) $datasetFile->cvParam->attributes()->value; $this->fileList[] = $file; } } $this->isInitialised = true; } public function getDatasetFileList() { return $this->fileList; } public function getIdString() { return $this->idString; } } |