1 | ;
|
2 | /// <reference path="../typings/index.d.ts" />
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | // TODO use a cache, such as
|
5 | // https://github.com/levelgraph/levelgraph
|
6 | require("source-map-support/register");
|
7 | if (!global.hasOwnProperty("XMLHttpRequest")) {
|
8 | global.XMLHttpRequest = require("xhr2");
|
9 | }
|
10 | var fp_1 = require("lodash/fp");
|
11 | var lodash_1 = require("lodash");
|
12 | var Observable_1 = require("rxjs/Observable");
|
13 | require("rxjs/add/observable/dom/ajax");
|
14 | require("rxjs/add/observable/empty");
|
15 | require("rxjs/add/observable/forkJoin");
|
16 | require("rxjs/add/observable/from");
|
17 | require("rxjs/add/observable/throw");
|
18 | require("rxjs/add/observable/zip");
|
19 | require("rxjs/add/operator/buffer");
|
20 | require("rxjs/add/operator/bufferWhen");
|
21 | require("rxjs/add/operator/catch");
|
22 | require("rxjs/add/operator/concatAll");
|
23 | require("rxjs/add/operator/debounceTime");
|
24 | require("rxjs/add/operator/delay");
|
25 | require("rxjs/add/operator/distinctUntilChanged");
|
26 | require("rxjs/add/operator/do");
|
27 | require("rxjs/add/operator/filter");
|
28 | require("rxjs/add/operator/find");
|
29 | require("rxjs/add/operator/mergeMap");
|
30 | require("rxjs/add/operator/map");
|
31 | require("rxjs/add/operator/multicast");
|
32 | require("rxjs/add/operator/publishReplay");
|
33 | require("rxjs/add/operator/race");
|
34 | require("rxjs/add/operator/reduce");
|
35 | require("rxjs/add/operator/skip");
|
36 | require("rxjs/add/operator/toArray");
|
37 | require("rx-extra/add/operator/throughNodeStream");
|
38 | var Subject_1 = require("rxjs/Subject");
|
39 | var TSVGetter_1 = require("./spinoffs/TSVGetter");
|
40 | var dataTypeParsers_1 = require("./spinoffs/dataTypeParsers");
|
41 | var jsonld_utils_1 = require("./spinoffs/jsonld-utils");
|
42 | var VError = require("verror");
|
43 | var BDB = "http://vocabularies.bridgedb.org/ops#";
|
44 | var BIOPAX = "http://www.biopax.org/release/biopax-level3.owl#";
|
45 | var IDENTIFIERS = "http://identifiers.org/";
|
46 | var OWL = "http://www.w3.org/2002/07/owl#";
|
47 | var RDF = "http://www.w3.org/1999/02/22-rdf-syntax-ns#";
|
48 | var CSV_OPTIONS = { objectMode: true, delimiter: "\t" };
|
49 | // time to wait for no new calls to xrefs() before we
|
50 | // batch up all calls in the queue and send to xrefsBatch()
|
51 | var XREF_REQUEST_DEBOUNCE_TIME = 10; // ms
|
52 | var XREF_REQUEST_CHUNK_SIZE = 100;
|
53 | var BRIDGE_DB_REPO_CDN = "https://raw.githubusercontent.com/bridgedb/BridgeDb/";
|
54 | var BRIDGE_DB_COMMIT_HASH = "465f9f944d09cefbb167eceb9c69499a764100a2";
|
55 | exports.CONFIG_DEFAULT = {
|
56 | baseIri: "https://webservice.bridgedb.org/",
|
57 | context: [
|
58 | BRIDGE_DB_REPO_CDN,
|
59 | BRIDGE_DB_COMMIT_HASH,
|
60 | "/org.bridgedb.bio/resources/org/bridgedb/bio/jsonld-context.jsonld"
|
61 | ].join(""),
|
62 | dataSourcesMetadataHeadersIri: [
|
63 | BRIDGE_DB_REPO_CDN,
|
64 | BRIDGE_DB_COMMIT_HASH,
|
65 | "/org.bridgedb.bio/resources/org/bridgedb/bio/datasources_headers.txt"
|
66 | ].join(""),
|
67 | dataSourcesMetadataIri: [
|
68 | BRIDGE_DB_REPO_CDN,
|
69 | BRIDGE_DB_COMMIT_HASH,
|
70 | "/org.bridgedb.bio/resources/org/bridgedb/bio/datasources.txt"
|
71 | ].join(""),
|
72 | http: {
|
73 | timeout: 4 * 1000,
|
74 | retryLimit: 2,
|
75 | retryDelay: 3 * 1000
|
76 | }
|
77 | };
|
78 | // these properties can be trusted to
|
79 | // uniquely identify a data source.
|
80 | var DATASOURCE_ID_PROPERTIES = [
|
81 | "id",
|
82 | "miriamUrn",
|
83 | "conventionalName",
|
84 | "preferredPrefix",
|
85 | "systemCode"
|
86 | ];
|
87 | var IRI_TO_NAME = {
|
88 | "http://www.w3.org/1999/02/22-rdf-syntax-ns#about": "id",
|
89 | "http://identifiers.org/idot/preferredPrefix": "preferredPrefix",
|
90 | "http://identifiers.org/miriam.collection/": "miriamUrn"
|
91 | };
|
92 | var NAME_TO_IRI = lodash_1.invert(IRI_TO_NAME);
|
93 | /**
|
94 | * miriamUrnToIdentifiersIri
|
95 | *
|
96 | * @param {string} miriamUrn
|
97 | * @return {string} e.g., "http://identifiers.org/ncbigene/"
|
98 | */
|
99 | function miriamUrnToIdentifiersIri(miriamUrn) {
|
100 | var preferredPrefix = miriamUrnToPreferredPrefix(miriamUrn);
|
101 | if (preferredPrefix) {
|
102 | return IDENTIFIERS + preferredPrefix + "/";
|
103 | }
|
104 | }
|
105 | /**
|
106 | * miriamUrnToPreferredPrefix
|
107 | *
|
108 | * @param {string} uri, e.g., "urn:miriam:ncbigene"
|
109 | * @return {string} preferredPrefix from identifiers.org/Miriam, e.g., "ncbigene"
|
110 | */
|
111 | function miriamUrnToPreferredPrefix(miriamUrn) {
|
112 | // Make sure it's actually an identifiers.org namespace,
|
113 | // not a BridgeDb system code:
|
114 | if (miriamUrn.indexOf("urn:miriam:") > -1) {
|
115 | return miriamUrn.substring(11, miriamUrn.length);
|
116 | }
|
117 | }
|
118 | var BridgeDb = /** @class */ (function () {
|
119 | function BridgeDb(config) {
|
120 | var _this = this;
|
121 | if (config === void 0) { config = exports.CONFIG_DEFAULT; }
|
122 | this.convertXrefDataSourceTo = fp_1.curry(function (targetType, input) {
|
123 | var bridgeDb = _this;
|
124 | return bridgeDb.dataSourceMappings$
|
125 | .map(function (mapping) {
|
126 | return !!mapping[input] && mapping[input][targetType];
|
127 | })
|
128 | .catch(function (err) {
|
129 | throw new VError(err, "calling bridgedb.convertXrefDataSourceTo");
|
130 | });
|
131 | });
|
132 | this.identifyHeaderNameForXrefDataSource = function (input) {
|
133 | var bridgeDb = _this;
|
134 | return bridgeDb.dataSourceMappings$
|
135 | .map(function (mapping) { return mapping[input]; })
|
136 | .filter(fp_1.negate(lodash_1.isEmpty))
|
137 | .map(function (dataSource) {
|
138 | return lodash_1.toPairs(dataSource)
|
139 | .filter(function (_a) {
|
140 | var key = _a[0], value = _a[1];
|
141 | return value === input;
|
142 | })
|
143 | .map(function (_a) {
|
144 | var key = _a[0], value = _a[1];
|
145 | return key;
|
146 | })
|
147 | .reduce(function (acc, key) {
|
148 | // we want to return the IRI, if it's available.
|
149 | return acc.length > key.length ? acc : key;
|
150 | });
|
151 | })
|
152 | .catch(function (err) {
|
153 | throw new VError(err, "calling bridgedb.identifyHeaderNameForXrefDataSource");
|
154 | });
|
155 | };
|
156 | this.dataSourceProperties = function (input) {
|
157 | var bridgeDb = _this;
|
158 | return bridgeDb.dataSourceMappings$
|
159 | .map(function (mapping) { return mapping[input]; })
|
160 | .catch(function (err) {
|
161 | throw new VError(err, "calling bridgedb.dataSourceProperties");
|
162 | });
|
163 | };
|
164 | this.parseXrefRow = function (_a) {
|
165 | var xrefIdentifier = _a[0], dataSourceConventionalName = _a[1], symbol = _a[2];
|
166 | var bridgeDb = _this;
|
167 | if (!xrefIdentifier || !dataSourceConventionalName) {
|
168 | return Observable_1.Observable.empty();
|
169 | }
|
170 | return bridgeDb.dataSourceMappings$
|
171 | .map(function (mapping) { return mapping[dataSourceConventionalName]; })
|
172 | .map(function (dataSource) {
|
173 | var xref = {
|
174 | xrefIdentifier: xrefIdentifier,
|
175 | isDataItemIn: dataSource
|
176 | };
|
177 | if (symbol) {
|
178 | xref.symbol = symbol;
|
179 | }
|
180 | if (dataSource.hasOwnProperty("id")) {
|
181 | xref.id = encodeURI(dataSource.id + xref.xrefIdentifier);
|
182 | }
|
183 | return xref;
|
184 | });
|
185 | };
|
186 | this.xrefsBatch = function (organism, oneOrMoreXrefDataSources, xrefIdentifiers, desiredXrefDataSourceOrSources) {
|
187 | var bridgeDb = _this;
|
188 | var desiredXrefDataSources = jsonld_utils_1.arrayify(desiredXrefDataSourceOrSources);
|
189 | var dataSourceFilterParamSection = desiredXrefDataSources.length === 1
|
190 | ? "?dataSource=" + desiredXrefDataSources[0]
|
191 | : "";
|
192 | var xrefDataSources = lodash_1.isArray(oneOrMoreXrefDataSources)
|
193 | ? oneOrMoreXrefDataSources
|
194 | : lodash_1.fill(new Array(xrefIdentifiers.length), oneOrMoreXrefDataSources);
|
195 | var convertXrefDataSourceToConventionalName = bridgeDb.convertXrefDataSourceTo("conventionalName");
|
196 | var callString = "Called xrefsBatch(\n\t" + organism + ",\n\t" + oneOrMoreXrefDataSources + ",\n\t" + xrefIdentifiers + ",\n\t" + desiredXrefDataSourceOrSources + "\n)";
|
197 | var postURL = bridgeDb.config.baseIri +
|
198 | organism +
|
199 | "/xrefsBatch" +
|
200 | dataSourceFilterParamSection;
|
201 | var inputXrefDataSourceHeaderName$ = Observable_1.Observable.from(xrefDataSources)
|
202 | .mergeMap(function (xrefDataSource) {
|
203 | return bridgeDb.identifyHeaderNameForXrefDataSource(xrefDataSource);
|
204 | })
|
205 | .find(lodash_1.isString);
|
206 | var desiredXrefDataSourceHeaderName$ = lodash_1.isEmpty(desiredXrefDataSources)
|
207 | ? inputXrefDataSourceHeaderName$
|
208 | : Observable_1.Observable.from(desiredXrefDataSources)
|
209 | .mergeMap(function (xrefDataSource) {
|
210 | return bridgeDb.identifyHeaderNameForXrefDataSource(xrefDataSource);
|
211 | })
|
212 | .find(lodash_1.isString);
|
213 | var dataSourceConventionalNames$ = Observable_1.Observable.from(xrefDataSources)
|
214 | .mergeMap(function (xrefDataSource) {
|
215 | return convertXrefDataSourceToConventionalName(xrefDataSource);
|
216 | })
|
217 | .toArray();
|
218 | return Observable_1.Observable.forkJoin(inputXrefDataSourceHeaderName$, desiredXrefDataSourceHeaderName$, dataSourceConventionalNames$).mergeMap(function (_a) {
|
219 | var inputXrefDataSourceHeaderName = _a[0], desiredXrefDataSourceHeaderName = _a[1], dataSourceConventionalNames = _a[2];
|
220 | // TODO: find out how we're getting duplicate rows in the body.
|
221 | // For at least one example, see RefSeqSample.tsv in test dir.
|
222 | // It has duplicates.
|
223 | var body = fp_1.uniq(lodash_1.zip(xrefIdentifiers, dataSourceConventionalNames)
|
224 | .filter(function (pair) { return !!pair[1]; })
|
225 | .map(function (x) { return x.join("\t"); })).join("\n");
|
226 | if (lodash_1.isEmpty(body.replace(/[\ \n\t]/g, ""))) {
|
227 | return Observable_1.Observable.throw(new Error("Error: body is empty. " + callString));
|
228 | }
|
229 | var convertXrefDataSourceToInputFormat = bridgeDb.convertXrefDataSourceTo(inputXrefDataSourceHeaderName);
|
230 | var convertXrefDataSourceToDesiredInputFormat = bridgeDb.convertXrefDataSourceTo(desiredXrefDataSourceHeaderName);
|
231 | return bridgeDb
|
232 | .getTSV(postURL, "POST", body)
|
233 | .mergeMap(function (xrefStringsByInput) {
|
234 | var inputXrefIdentifier = xrefStringsByInput[0];
|
235 | var inputXrefDataSource = xrefStringsByInput[1];
|
236 | var xrefsString = xrefStringsByInput[2];
|
237 | // NOTE: splitting by comma, e.g.:
|
238 | // 'T:GO:0031966,Il:ILMN_1240829' -> ['T:GO:0031966', 'Il:ILMN_1240829']
|
239 | return Observable_1.Observable.from(xrefsString.split(","))
|
240 | .mergeMap(function (xrefString) {
|
241 | if (xrefString === "N/A") {
|
242 | return Observable_1.Observable.empty();
|
243 | }
|
244 | // NOTE: splitting by FIRST colon only, e.g.:
|
245 | // 'T:GO:0031966' -> ['T', 'GO:0031966']
|
246 | var _a = xrefString.split(/:(.+)/), returnedXrefDataSource = _a[0], returnedXrefIdentifier = _a[1];
|
247 | return convertXrefDataSourceToDesiredInputFormat(returnedXrefDataSource).map(function (desiredXrefDataSource) {
|
248 | return {
|
249 | xrefDataSource: desiredXrefDataSource,
|
250 | xrefIdentifier: returnedXrefIdentifier
|
251 | };
|
252 | });
|
253 | })
|
254 | .filter(function (_a) {
|
255 | var xrefDataSource = _a.xrefDataSource;
|
256 | return (!lodash_1.isEmpty(xrefDataSource) &&
|
257 | (desiredXrefDataSources.length === 0 ||
|
258 | desiredXrefDataSources.indexOf(xrefDataSource) > -1));
|
259 | })
|
260 | .toArray()
|
261 | .mergeMap(function (xrefs) {
|
262 | if (desiredXrefDataSources.length > 0) {
|
263 | // Sort xrefs in the order matching the order that the user specified
|
264 | // in desiredXrefDataSource1, desiredXrefDataSource2, ...
|
265 | xrefs.sort(function (a, b) {
|
266 | var aIndex = desiredXrefDataSources.indexOf(a.xrefDataSource);
|
267 | var bIndex = desiredXrefDataSources.indexOf(b.xrefDataSource);
|
268 | if (aIndex < bIndex) {
|
269 | return -1;
|
270 | }
|
271 | else if (aIndex > bIndex) {
|
272 | return 1;
|
273 | }
|
274 | else {
|
275 | return 0;
|
276 | }
|
277 | });
|
278 | }
|
279 | return convertXrefDataSourceToInputFormat(inputXrefDataSource).map(function (inputXrefDataSource) {
|
280 | return {
|
281 | organism: organism,
|
282 | inputXrefDataSource: inputXrefDataSource,
|
283 | inputXrefIdentifier: inputXrefIdentifier,
|
284 | xrefs: xrefs,
|
285 | // NOTE: return desiredXrefDataSources for use in xrefsResponseQueue
|
286 | desiredXrefDataSources: desiredXrefDataSources
|
287 | };
|
288 | });
|
289 | });
|
290 | })
|
291 | .catch(null, function (err) {
|
292 | throw new VError(err, "Error: " + callString);
|
293 | });
|
294 | });
|
295 | };
|
296 | var bridgeDb = this;
|
297 | lodash_1.defaultsDeep(config, exports.CONFIG_DEFAULT);
|
298 | bridgeDb.config = config;
|
299 | var xrefsRequestQueue = (bridgeDb.xrefsRequestQueue = new Subject_1.Subject());
|
300 | var debounceSignel = xrefsRequestQueue.debounceTime(XREF_REQUEST_DEBOUNCE_TIME);
|
301 | bridgeDb.xrefsResponseQueue = xrefsRequestQueue
|
302 | .filter(function (_a) {
|
303 | var organism = _a.organism, xrefDataSource = _a.xrefDataSource, xrefIdentifier = _a.xrefIdentifier;
|
304 | return !lodash_1.isEmpty(organism) &&
|
305 | !lodash_1.isEmpty(xrefDataSource) &&
|
306 | !lodash_1.isEmpty(xrefIdentifier);
|
307 | })
|
308 | /* TODO should we use this? It doesn't seem to work, and we could just use caching.
|
309 | .distinctUntilChanged(function(
|
310 | a: { xrefDataSource; xrefIdentifier },
|
311 | b: { xrefDataSource; xrefIdentifier }
|
312 | ) {
|
313 | return JSON.stringify(a) === JSON.stringify(b);
|
314 | })
|
315 | //*/
|
316 | //.buffer(Observable.race(debounceSignel, xrefsRequestQueue.skip(2000)))
|
317 | .bufferWhen(function () {
|
318 | return Observable_1.Observable.race(debounceSignel, xrefsRequestQueue.skip(2000));
|
319 | })
|
320 | .filter(function (x) { return !lodash_1.isEmpty(x); })
|
321 | .mergeMap(function (inputs) {
|
322 | var firstInput = inputs[0];
|
323 | var organism = firstInput.organism;
|
324 | var xrefDataSources = inputs.map(function (input) { return input.xrefDataSource; });
|
325 | var xrefIdentifiers = inputs.map(function (input) { return input.xrefIdentifier; });
|
326 | var desiredXrefDataSources = firstInput.desiredXrefDataSources;
|
327 | return bridgeDb.xrefsBatch(organism, xrefDataSources, xrefIdentifiers, desiredXrefDataSources);
|
328 | })
|
329 | .multicast(new Subject_1.Subject());
|
330 | // toggle from cold to hot
|
331 | bridgeDb.xrefsResponseQueue.connect();
|
332 | var getTSV = (bridgeDb.getTSV = new TSVGetter_1.TSVGetter(config.http).get);
|
333 | var dataSourcesMetadataHeaders$ = getTSV(config.dataSourcesMetadataHeadersIri).map(function (fields) {
|
334 | var id = fields[4];
|
335 | return {
|
336 | // NOTE: the column number could be confusing, because it's one-based,
|
337 | // so I'll just use the index instead and ignore the column number.
|
338 | //column: parseFloat(fields[0]),
|
339 | header: fields[1],
|
340 | description: fields[2],
|
341 | example_entry: fields[3],
|
342 | id: id,
|
343 | name: IRI_TO_NAME.hasOwnProperty(id)
|
344 | ? IRI_TO_NAME[id]
|
345 | : id.split(/[\/|#]/).pop(),
|
346 | "http://www.w3.org/1999/02/22-rdf-syntax-ns#datatype": fields[5]
|
347 | };
|
348 | });
|
349 | bridgeDb.dataSourceMappings$ = Observable_1.Observable.forkJoin(dataSourcesMetadataHeaders$.toArray(), getTSV(config.dataSourcesMetadataIri).toArray())
|
350 | .mergeMap(function (results) {
|
351 | var metadataByColumnIndex = results[0];
|
352 | var rows = results[1];
|
353 | return Observable_1.Observable.from(rows).map(function (fields) {
|
354 | return fields.reduce(function (acc, field, i) {
|
355 | var metadata = metadataByColumnIndex[i];
|
356 | var id = metadata.id, name = metadata.name;
|
357 | // NOTE: side effects
|
358 | if (!!id && !(id in IRI_TO_NAME)) {
|
359 | IRI_TO_NAME[id] = name;
|
360 | NAME_TO_IRI[name] = id;
|
361 | }
|
362 | acc[name] = dataTypeParsers_1.dataTypeParsers[metadata[RDF + "datatype"]](field);
|
363 | return acc;
|
364 | }, {});
|
365 | });
|
366 | })
|
367 | .map(function (dataSource) {
|
368 | // remove empty properties, ie., properties with these values:
|
369 | // ''
|
370 | // NaN
|
371 | // null
|
372 | // undefined
|
373 | // TODO what about empty plain object {} or array []
|
374 | return lodash_1.omitBy(dataSource, function (value) {
|
375 | return (value === "" || lodash_1.isNaN(value) || lodash_1.isNull(value) || lodash_1.isUndefined(value));
|
376 | });
|
377 | })
|
378 | .map(function (dataSource) {
|
379 | // Kludge to temporarily handle this issue:
|
380 | // https://github.com/bridgedb/BridgeDb/issues/58
|
381 | if (dataSource.id === "Sp") {
|
382 | dataSource.id = "urn:miriam:uniprot";
|
383 | }
|
384 | // If the Miriam URN is unknown or unspecified, datasources.txt uses
|
385 | // the BridgeDb system code as a placeholder value.
|
386 | // So here we make sure "id" is actually a Miriam URN.
|
387 | if (dataSource.hasOwnProperty("id") &&
|
388 | dataSource.id.indexOf("urn:miriam:") > -1) {
|
389 | // switch "id" property from Miriam URN to identifiers.org IRI
|
390 | var miriamUrn = dataSource.id;
|
391 | dataSource.miriamUrn = miriamUrn;
|
392 | var preferredPrefix = miriamUrnToPreferredPrefix(miriamUrn);
|
393 | if (preferredPrefix) {
|
394 | dataSource.preferredPrefix = preferredPrefix;
|
395 | dataSource.sameAs = dataSource.sameAs || [];
|
396 | dataSource.sameAs.push(miriamUrn);
|
397 | var identifiersIri = miriamUrnToIdentifiersIri(miriamUrn);
|
398 | if (identifiersIri) {
|
399 | dataSource.id = dataSource.hasIdentifiersOrgPattern = identifiersIri;
|
400 | }
|
401 | }
|
402 | }
|
403 | else {
|
404 | delete dataSource.id;
|
405 | }
|
406 | return dataSource;
|
407 | })
|
408 | .map(function (dataSource) {
|
409 | var primaryUriPattern = dataSource.hasPrimaryUriPattern;
|
410 | if (!!primaryUriPattern) {
|
411 | var regexXrefIdentifierPattern = dataSource.hasRegexPattern || ".*";
|
412 | dataSource.hasRegexUriPattern = primaryUriPattern.replace("$id",
|
413 | // removing ^ (start) and $ (end) from regexXrefIdentifierPattern
|
414 | "(" + regexXrefIdentifierPattern.replace(/(^\^|\$$)/g, "") + ")");
|
415 | // if '$id' is at the end of the primaryUriPattern
|
416 | var indexOfDollaridWhenAtEnd = primaryUriPattern.length - 3;
|
417 | if (primaryUriPattern.indexOf("$id") === indexOfDollaridWhenAtEnd) {
|
418 | dataSource.sameAs = dataSource.sameAs || [];
|
419 | dataSource.sameAs.push(primaryUriPattern.substr(0, indexOfDollaridWhenAtEnd));
|
420 | }
|
421 | }
|
422 | if (dataSource.type) {
|
423 | dataSource[BDB + "type"] = dataSource.type;
|
424 | }
|
425 | dataSource.type = "Dataset";
|
426 | return dataSource;
|
427 | })
|
428 | .map(function (dataSource) {
|
429 | var bdbType = dataSource[BDB + "type"];
|
430 | if (!!bdbType) {
|
431 | dataSource.subject = [];
|
432 | /* Example of using 'subject' (from the VOID docs <http://www.w3.org/TR/void/#subject>):
|
433 | :Bio2RDF a void:Dataset;
|
434 | dcterms:subject <http://purl.uniprot.org/core/Gene>;
|
435 | .
|
436 |
|
437 | The closest concepts from the WP, BioPAX and MESH vocabularies are included below,
|
438 | with the default vocabulary being WP.
|
439 |
|
440 | Note that in BioPAX, 'ProteinReference' is to 'Protein' as
|
441 | 'Class' is to 'Instance' or
|
442 | 'platonic ideal of http://identifiers.org/uniprot/P78527' is to
|
443 | 'one specific example of http://identifiers.org/uniprot/P78527'
|
444 | with the same logic applying for Dna, Rna and SmallMolecule. As such, it appears the
|
445 | subject of Uniprot is best described in BioPAX terms as biopax:ProteinReference instead
|
446 | of biopax:Protein.
|
447 |
|
448 | It is unclear whether the subject of Entrez Gene is biopax:DnaReference or biopax:Gene,
|
449 | but I'm going with biopax:DnaReference for now because it appears to be analogous to
|
450 | ProteinReference and SmallMoleculeReference.
|
451 | //*/
|
452 | if (bdbType === "gene" ||
|
453 | // TODO should the following two conditions be removed?
|
454 | bdbType === "probe" ||
|
455 | dataSource.preferredPrefix === "go") {
|
456 | dataSource.subject.push("GeneProduct");
|
457 | dataSource.subject.push(BIOPAX + "DnaReference");
|
458 | }
|
459 | else if (bdbType === "rna") {
|
460 | dataSource.subject.push("Rna");
|
461 | dataSource.subject.push(BIOPAX + "RnaReference");
|
462 | }
|
463 | else if (bdbType === "protein") {
|
464 | dataSource.subject.push("Protein");
|
465 | dataSource.subject.push(BIOPAX + "ProteinReference");
|
466 | }
|
467 | else if (bdbType === "metabolite") {
|
468 | dataSource.subject.push("Metabolite");
|
469 | dataSource.subject.push(BIOPAX + "SmallMoleculeReference");
|
470 | }
|
471 | else if (bdbType === "pathway") {
|
472 | // BioPAX does not have a term for pathways that is analogous to
|
473 | // biopax:ProteinReference for proteins.
|
474 | dataSource.subject.push("Pathway");
|
475 | dataSource.subject.push(BIOPAX + "Pathway");
|
476 | }
|
477 | else if (bdbType === "ontology") {
|
478 | dataSource.subject.push(OWL + "Ontology");
|
479 | }
|
480 | else if (bdbType === "interaction") {
|
481 | dataSource.subject.push("Interaction");
|
482 | dataSource.subject.push(BIOPAX + "Interaction");
|
483 | }
|
484 | }
|
485 | dataSource.alternatePrefix = [dataSource.systemCode];
|
486 | return dataSource;
|
487 | })
|
488 | .reduce(function (acc, dataSource) {
|
489 | DATASOURCE_ID_PROPERTIES.forEach(function (propertyName) {
|
490 | var propertyValue = dataSource[propertyName];
|
491 | var propertyId = NAME_TO_IRI[propertyName];
|
492 | dataSource[propertyId] = propertyValue;
|
493 | acc[propertyValue] = dataSource;
|
494 | });
|
495 | return acc;
|
496 | }, {})
|
497 | .catch(function (err) {
|
498 | throw new VError(err, "Setting up dataSourceMappings$ in constructor");
|
499 | })
|
500 | .publishReplay();
|
501 | // toggle from cold to hot
|
502 | bridgeDb.dataSourceMappings$.connect();
|
503 | } // end constructor
|
504 | BridgeDb.prototype.attributes = function (organism, xrefDataSource, xrefIdentifier) {
|
505 | var bridgeDb = this;
|
506 | return bridgeDb
|
507 | .getTSV(bridgeDb.config.baseIri +
|
508 | organism +
|
509 | "/attributes/" +
|
510 | xrefDataSource +
|
511 | "/" +
|
512 | xrefIdentifier)
|
513 | .reduce(function (acc, fields) {
|
514 | var key = lodash_1.camelCase(fields[0]);
|
515 | var value = fields[1];
|
516 | acc[key] = value;
|
517 | return acc;
|
518 | }, {})
|
519 | .catch(function (err) {
|
520 | throw new VError(err, "calling bridgedb.attributes");
|
521 | });
|
522 | };
|
523 | BridgeDb.prototype.attributeSearch = function (organism, query, attrName) {
|
524 | var bridgeDb = this;
|
525 | var attrNameParamSection = attrName ? "?attrName=" + attrName : "";
|
526 | return bridgeDb
|
527 | .getTSV(bridgeDb.config.baseIri +
|
528 | organism +
|
529 | "/attributeSearch/" +
|
530 | query +
|
531 | attrNameParamSection)
|
532 | .mergeMap(bridgeDb.parseXrefRow)
|
533 | .catch(function (err) {
|
534 | throw new VError(err, "calling bridgedb.attributeSearch");
|
535 | });
|
536 | };
|
537 | BridgeDb.prototype.attributeSet = function (organism) {
|
538 | var bridgeDb = this;
|
539 | return bridgeDb
|
540 | .getTSV(bridgeDb.config.baseIri + organism + "/attributeSet")
|
541 | .reduce(function (acc, row) {
|
542 | acc.push(row[0]);
|
543 | return acc;
|
544 | }, [])
|
545 | .catch(function (err) {
|
546 | throw new VError(err, "calling bridgedb.attributeSet");
|
547 | });
|
548 | };
|
549 | BridgeDb.prototype.isFreeSearchSupported = function (organism) {
|
550 | var bridgeDb = this;
|
551 | var ajaxRequest = {
|
552 | url: bridgeDb.config.baseIri + organism + "/isFreeSearchSupported",
|
553 | method: "GET",
|
554 | responseType: "text",
|
555 | timeout: bridgeDb.config.http.timeout,
|
556 | crossDomain: true
|
557 | };
|
558 | return (Observable_1.Observable.ajax(ajaxRequest)
|
559 | .map(function (ajaxResponse) { return ajaxResponse.xhr.response; })
|
560 | // NOTE: must compare with 'true' as a string, because the response is just a string, not a parsed JS boolean.
|
561 | .map(function (res) { return res === "true"; })
|
562 | // TODO is this TS correct?
|
563 | .catch(function (err) {
|
564 | throw new VError(err, "calling bridgedb.isFreeSearchSupported");
|
565 | }));
|
566 | };
|
567 | BridgeDb.prototype.isMappingSupported = function (organism, sourceXrefDataSource, targetXrefDataSource) {
|
568 | var bridgeDb = this;
|
569 | var ajaxRequest = {
|
570 | url: bridgeDb.config.baseIri +
|
571 | organism + "/isMappingSupported/" + sourceXrefDataSource + "/" + targetXrefDataSource,
|
572 | method: "GET",
|
573 | responseType: "text",
|
574 | timeout: bridgeDb.config.http.timeout,
|
575 | crossDomain: true
|
576 | };
|
577 | return (Observable_1.Observable.ajax(ajaxRequest)
|
578 | .map(function (ajaxResponse) { return ajaxResponse.xhr.response; })
|
579 | // NOTE: must compare with 'true' as a string, because the response is just a string, not a parsed JS boolean.
|
580 | .map(function (res) { return res === "true"; })
|
581 | // TODO is this TS correct?
|
582 | .catch(function (err) {
|
583 | throw new VError(err, "calling bridgedb.isMappingSupported");
|
584 | }));
|
585 | };
|
586 | BridgeDb.prototype.organismProperties = function (organism) {
|
587 | var bridgeDb = this;
|
588 | return bridgeDb
|
589 | .getTSV(bridgeDb.config.baseIri + organism + "/properties")
|
590 | .reduce(function (acc, fields) {
|
591 | var key = lodash_1.camelCase(fields[0]);
|
592 | var value = fields[1];
|
593 | acc[key] = value;
|
594 | return acc;
|
595 | }, {})
|
596 | .catch(function (err) {
|
597 | throw new VError(err, "calling bridgedb.organismProperties");
|
598 | });
|
599 | };
|
600 | BridgeDb.prototype.organisms = function () {
|
601 | var bridgeDb = this;
|
602 | return bridgeDb
|
603 | .getTSV(bridgeDb.config.baseIri + "contents")
|
604 | .map(function (fields) {
|
605 | return {
|
606 | en: fields[0],
|
607 | la: fields[1]
|
608 | };
|
609 | })
|
610 | .catch(function (err) {
|
611 | throw new VError(err, "calling bridgedb.organisms");
|
612 | });
|
613 | };
|
614 | BridgeDb.prototype.search = function (organism, query) {
|
615 | var bridgeDb = this;
|
616 | return bridgeDb
|
617 | .getTSV(bridgeDb.config.baseIri + organism + "/search/" + query)
|
618 | .mergeMap(bridgeDb.parseXrefRow)
|
619 | .catch(function (err) {
|
620 | throw new VError(err, "calling bridgedb.search");
|
621 | });
|
622 | };
|
623 | BridgeDb.prototype.sourceDataSources = function (organism) {
|
624 | var bridgeDb = this;
|
625 | return bridgeDb
|
626 | .getTSV(bridgeDb.config.baseIri + organism + "/sourceDataSources")
|
627 | .map(function (fields) {
|
628 | return fields[0];
|
629 | })
|
630 | .mergeMap(bridgeDb.dataSourceProperties)
|
631 | .catch(function (err) {
|
632 | throw new VError(err, "calling bridgedb.sourceDataSources");
|
633 | });
|
634 | };
|
635 | BridgeDb.prototype.targetDataSources = function (organism) {
|
636 | var bridgeDb = this;
|
637 | return bridgeDb
|
638 | .getTSV(bridgeDb.config.baseIri + organism + "/targetDataSources")
|
639 | .map(function (fields) {
|
640 | return fields[0];
|
641 | })
|
642 | .mergeMap(bridgeDb.dataSourceProperties)
|
643 | .catch(function (err) {
|
644 | throw new VError(err, "calling bridgedb.targetDataSources");
|
645 | });
|
646 | };
|
647 | // TODO check whether dataSource exists before calling webservice re:
|
648 | // dataSource AND identifier
|
649 | BridgeDb.prototype.xrefExists = function (organism, xrefDataSource, xrefIdentifier) {
|
650 | var bridgeDb = this;
|
651 | var ajaxRequest = {
|
652 | url: bridgeDb.config.baseIri +
|
653 | organism + "/xrefExists/" + xrefDataSource + "/" + xrefIdentifier,
|
654 | method: "GET",
|
655 | responseType: "text",
|
656 | timeout: bridgeDb.config.http.timeout,
|
657 | crossDomain: true
|
658 | };
|
659 | return (Observable_1.Observable.ajax(ajaxRequest)
|
660 | .map(function (ajaxResponse) { return ajaxResponse.xhr.response; })
|
661 | // NOTE: must compare with 'true' as a string, because the response is just a string, not a parsed JS boolean.
|
662 | .map(function (res) { return res === "true"; })
|
663 | // TODO is this TS correct?
|
664 | .catch(function (err) {
|
665 | throw new VError(err, "calling bridgedb.xrefExists");
|
666 | }));
|
667 | };
|
668 | BridgeDb.prototype.xrefs = function (organism, xrefDataSource, xrefIdentifier, desiredXrefDataSourceOrSources) {
|
669 | var bridgeDb = this;
|
670 | var xrefsRequestQueue = bridgeDb.xrefsRequestQueue;
|
671 | var xrefsResponseQueue = bridgeDb.xrefsResponseQueue;
|
672 | var desiredXrefDataSources = jsonld_utils_1.arrayify(desiredXrefDataSourceOrSources);
|
673 | xrefsRequestQueue.next({
|
674 | organism: organism,
|
675 | xrefDataSource: xrefDataSource,
|
676 | xrefIdentifier: xrefIdentifier,
|
677 | desiredXrefDataSources: desiredXrefDataSources
|
678 | });
|
679 | return (xrefsResponseQueue
|
680 | .find(function (xrefBatchEnvelope) {
|
681 | return (xrefBatchEnvelope.organism === organism &&
|
682 | // NOTE: we are not using the dataSource test in the line below.
|
683 | // Instead, we are matching dataSources in the mergeMap further below.
|
684 | // The reason is that the inputXrefDataSource and the returned dataSource
|
685 | // may not match, e.g., 'L' vs. 'Entrez Gene'.
|
686 | xrefBatchEnvelope.inputXrefDataSource === xrefDataSource &&
|
687 | xrefBatchEnvelope.inputXrefIdentifier === xrefIdentifier &&
|
688 | xrefBatchEnvelope.desiredXrefDataSources.join() ===
|
689 | desiredXrefDataSources.join());
|
690 | })
|
691 | .map(function (x) { return x.xrefs; })
|
692 | //.do(null, xrefsRequestQueue.complete)
|
693 | .catch(function (err) {
|
694 | throw new VError(err, "calling bridgedb.xrefs");
|
695 | }));
|
696 | };
|
697 | return BridgeDb;
|
698 | }());
|
699 | exports.BridgeDb = BridgeDb;
|
700 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"BridgeDb.js","sourceRoot":"","sources":["../src/BridgeDb.ts"],"names":[],"mappings":"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"} |
\ | No newline at end of file |