Comments (7)
Same here: Had to add "url" to my packages, and then in the code where i use it I had to import as well before calling the validation (import * as url from "url"). Otherwise the validation throws an error that urilib.resolve
is not a method
from jsonschema.
Same, it seems the lib was designed with only Node in mind. If you are in the browser, you will need to install "url" from npm to have the url.resolve function. I don't know why it broke recently, I guess "url" was installed by another dependency.
from jsonschema.
Yes, tdegrunt/jsonschema has an implicit dependency on the "url" library.
It would be nice to make this explicit or even better ditch it altogether to have a nice, lean, no external dependencies jsonschema validator
from jsonschema.
The above PR should address this issue.
from jsonschema.
The "url" package should be builtin. It is not supposed to refer to a third-party package. Can you tell me a little more about your environment?
from jsonschema.
Environment: Browser (vuejs, vite).
The uri library is only present in nodejs, the browser does not have it, the jsonschema package.json should explicitely specify this library
var urilib = require('url');
validator.js:118 Uncaught (in promise) TypeError: urilib.resolve is not a function
at Validator2.validate (validator.js:118:21)
at module.exports.validate (index.js:14:12)
at Proxy.validate (edit.vue:81:39)
...
var urilib = require('url');
/**
- Validates instance against the provided schema
- @param instance
- @param schema
- @param [options]
- @param [ctx]
- @return {Array}
*/
Validator.prototype.validate = function validate (instance, schema, options, ctx) {
if((typeof schema !== 'boolean' && typeof schema !== 'object') || schema === null){
throw new SchemaError('Expectedschema
to be an object or boolean');
}
if (!options) {
options = {};
}
// This section indexes subschemas in the provided schema, so they don't need to be added with Validator#addSchema
// This will work so long as the function at uri.resolve() will resolve a relative URI to a relative URI
var id = schema.$id || schema.id;
var base = urilib.resolve(options.base||anonymousBase, id||'');
from jsonschema.
Hi @awwright any updates on this issue?
from jsonschema.
Related Issues (20)
- v1.4.1 does not support chrome 49 HOT 4
- TypeScript readonly arrays?
- How to enforce `enum` validation on a specific property? HOT 1
- Date as custom type HOT 2
- Deeper arrays are not being validated HOT 1
- Validation errors in firefox not constructing properly HOT 1
- Nested Schema in the definitions object unsupported attribute when allowUnknownAttributes is set to false
- Support for unevaluatedProperties
- validation error reported onOf object incorrectly HOT 3
- v.validate() on a specific property of a schema? HOT 1
- OpenHarmony support
- pattern does not work when use a regexp with attributes HOT 1
- Validation error (Not supporting anyOf property)
- $id is incompatible with allowUnknownAttributes: false
- Unable to update the git submodules HOT 1
- [DEP0169] DeprecationWarning: `url.parse()` behavior is not standardized and prone to errors that have security implications. Use the WHATWG URL API instead. CVEs are not issued for `url.parse()` vulnerabilities. HOT 1
- bug?: Object literal may only specify known properties, and 'default' does not exist in type 'Schema' HOT 1
- Vite Module "url" has been externalized for browser compatibility HOT 1
- Validator does not honor "nullable" property for `type: "string", enum: [...]` HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from jsonschema.