From 4f1529dbacbfae9b515c8c36504114390c003acd Mon Sep 17 00:00:00 2001 From: Scott Christley Date: Wed, 12 Jun 2024 19:24:16 -0500 Subject: [PATCH] curie resolve, handle undefined, fix deprecate bug, additional vocabulary for validate --- lang/js/schema.js | 45 +++++++++++++++++++++++++++++++++++++++------ 1 file changed, 39 insertions(+), 6 deletions(-) diff --git a/lang/js/schema.js b/lang/js/schema.js index 7058c00c..66326d5a 100644 --- a/lang/js/schema.js +++ b/lang/js/schema.js @@ -108,15 +108,13 @@ module.exports = function(airr, schema) { for (let prop in this.definition['properties']) { let spec = this.definition['properties'][prop]; if ((spec['x-airr']) && (spec['x-airr']['deprecated'])) - this.properties[prop] = spec; + this.deprecated[prop] = spec; else this.properties[prop] = spec; } this.required = this.definition['required'] if (! this.required) this.required = []; - //this.optional = [f for f in self.properties if f not in self.required] - return this; } @@ -143,6 +141,7 @@ module.exports = function(airr, schema) { airr.SchemaDefinition.prototype.to_bool = function(value, validate) { if (value == null) return null; + if (value == undefined) return null; var bool_value = _to_bool_map(value); if (validate && (bool_value == null)) @@ -161,6 +160,7 @@ module.exports = function(airr, schema) { airr.SchemaDefinition.prototype.to_int = function(value, validate) { if (value == null) return null; + if (value == undefined) return null; if (value == '') return null; var int_value = parseInt(value); @@ -175,6 +175,7 @@ module.exports = function(airr, schema) { airr.SchemaDefinition.prototype.to_float = function(value, validate) { if (value == null) return null; + if (value == undefined) return null; if (value == '') return null; var float_value = parseFloat(value); @@ -202,10 +203,41 @@ module.exports = function(airr, schema) { case 'number': field_value = this.to_float(field_value); break; + case 'string': + if (field_value == '') field_value = null; + if (field_value == undefined) field_value = null; + break; } return field_value; }; + airr.SchemaDefinition.prototype.resolve_curie = function(field, curie_value) { + if (!field) return null + if (curie_value == null) return null; + if (curie_value == '') return null; + var spec = this.spec(field); + if (!spec) return null; + if (!spec['x-airr']) return null; + if (!spec['x-airr']['ontology']) return null; + + var cmap = airr.get_curie_map(); + var iprov = airr.get_iri_providers(); + var f = curie_value.split(':'); + if (cmap[f[0]]) { + var p = cmap[f[0]]['default']['provider']; + var m = cmap[f[0]]['default']['map']; + if (p && m) { + var ontology = iprov['parameter'][f[0]][p]['ontology_id']; + var iri = cmap[f[0]]['map'][m]['iri_prefix'] + f[1]; + var ols_api = iprov['provider']['OLS']['request']['url']; + ols_api = ols_api.replace('{ontology_id}', ontology); + ols_api = ols_api.replace('{iri}', iri); + return ols_api; + } + } + return null; + }; + // // Validation functions // @@ -218,13 +250,14 @@ module.exports = function(airr, schema) { return false; } - airr.SchemaDefinition.prototype.validate_object = function(object) { + airr.SchemaDefinition.prototype.validate_object = function(object, vocabulary) { const ajv = new AJV({allErrors: true}); addFormats(ajv); ajv.addVocabulary(['x-airr', 'example', 'discriminator']); + if (vocabulary) ajv.addVocabulary(vocabulary); - const validate = ajv.compile(this.definition) - const valid = validate(object) + const validate = ajv.compile(this.definition); + const valid = validate(object); if (!valid) return validate.errors; else return null; }