Add initial version of dijkstra backend cloudron image
This commit is contained in:
commit
4f5db9ab26
5
.dockerignore
Normal file
5
.dockerignore
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
test/*
|
||||||
|
.git/*
|
||||||
|
Dockerfile
|
||||||
|
CloudronManifest.json
|
||||||
|
README.MD
|
16
CloudronManifest.json
Normal file
16
CloudronManifest.json
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
{
|
||||||
|
"id": "xyz.ruihildt.cloudronapp",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"healthCheckPath": "/",
|
||||||
|
"httpPort": 4000,
|
||||||
|
"website": "https://git.ruihildt.xyz",
|
||||||
|
"title": "Wiki.js",
|
||||||
|
"author": "Rui Hildt",
|
||||||
|
"contactEmail": "support@cloudron.io",
|
||||||
|
"tagline": "Find the shortest path between different cities.",
|
||||||
|
"documentationUrl": "https://git.ruihildt.xyz/ruihildt/dijkstra-backend",
|
||||||
|
"addons": {
|
||||||
|
"localstorage": {}
|
||||||
|
},
|
||||||
|
"manifestVersion": 2
|
||||||
|
}
|
13
Dockerfile
Normal file
13
Dockerfile
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
FROM cloudron/base:2.0.0@sha256:f9fea80513aa7c92fe2e7bf3978b54c8ac5222f47a9a32a7f8833edf0eb5a4f4
|
||||||
|
|
||||||
|
RUN mkdir -p /app/code
|
||||||
|
RUN mkdir -p /app/data
|
||||||
|
WORKDIR /app/code
|
||||||
|
|
||||||
|
# copy code
|
||||||
|
ADD / /app/code/
|
||||||
|
|
||||||
|
# install packages
|
||||||
|
RUN npm install
|
||||||
|
|
||||||
|
CMD [ "/app/code/start.sh" ]
|
10
README.md
Normal file
10
README.md
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
# dijkstra-backend
|
||||||
|
Find the the shortest path between different cities in Belgium with Dijkstra algorithm.
|
||||||
|
|
||||||
|
This is the cloudron app version.
|
||||||
|
|
||||||
|
- Deployed Frontend: https://dijkstra.ruihildt.xyz/
|
||||||
|
- Deployed Backend: https://dijkstra-backend.ruihildt.xyz
|
||||||
|
|
||||||
|
- Frontend Source: https://git.ruihildt.xyz/ruihildt/dijkstra-frontend
|
||||||
|
- Backend Source: https://git.ruihildt.xyz/ruihildt/dijkstra-backend
|
22
api/models/citiesModel.js
Normal file
22
api/models/citiesModel.js
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
const db = require('../../data/dbConfig');
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
getCities,
|
||||||
|
getCitiesByCountry
|
||||||
|
// getCity,
|
||||||
|
};
|
||||||
|
|
||||||
|
function getCities() {
|
||||||
|
return db('cities')
|
||||||
|
}
|
||||||
|
|
||||||
|
function getCitiesByCountry(country_id) {
|
||||||
|
return db('cities')
|
||||||
|
.where({ country_id })
|
||||||
|
}
|
||||||
|
|
||||||
|
// function getCity(name) {
|
||||||
|
// return db('cities')
|
||||||
|
// .where({ name })
|
||||||
|
// .first()
|
||||||
|
// }
|
16
api/models/countriesModel.js
Normal file
16
api/models/countriesModel.js
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
const db = require('../../data/dbConfig');
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
getCountries,
|
||||||
|
getCountryByName,
|
||||||
|
};
|
||||||
|
|
||||||
|
function getCountries() {
|
||||||
|
return db('countries')
|
||||||
|
}
|
||||||
|
|
||||||
|
function getCountryByName(name) {
|
||||||
|
return db('countries')
|
||||||
|
.where({ name })
|
||||||
|
.first()
|
||||||
|
}
|
9
api/models/roadsModel.js
Normal file
9
api/models/roadsModel.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
const db = require('../../data/dbConfig');
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
getRoads
|
||||||
|
};
|
||||||
|
|
||||||
|
function getRoads() {
|
||||||
|
return db('roads')
|
||||||
|
}
|
14
api/routes/citiesRouter.js
Normal file
14
api/routes/citiesRouter.js
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
const router = require('express').Router();
|
||||||
|
|
||||||
|
const Cities = require('../models/citiesModel');
|
||||||
|
|
||||||
|
router.get('', async (req, res) => {
|
||||||
|
try {
|
||||||
|
const cities = await Cities.getCities();
|
||||||
|
res.status(200).json(cities);
|
||||||
|
} catch (e) {
|
||||||
|
res.status(500).json(e);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
module.exports = router;
|
14
api/routes/countriesRouter.js
Normal file
14
api/routes/countriesRouter.js
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
const router = require('express').Router();
|
||||||
|
const Cities = require('../models/citiesModel');
|
||||||
|
|
||||||
|
router.get('/:country_id', async (req, res) => {
|
||||||
|
const { country_id } = req.params;
|
||||||
|
try {
|
||||||
|
const cities = await Cities.getCitiesByCountry(country_id);
|
||||||
|
res.status(200).json(cities);
|
||||||
|
} catch (e) {
|
||||||
|
res.status(500).json(e);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
module.exports = router;
|
43
api/routes/pathRouter.js
Normal file
43
api/routes/pathRouter.js
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
const router = require('express').Router();
|
||||||
|
|
||||||
|
const Roads = require('../models/roadsModel');
|
||||||
|
const Cities = require('../models/citiesModel');
|
||||||
|
|
||||||
|
const findShortestPath = require('../../helpers/dijkstra_algo');
|
||||||
|
|
||||||
|
router.get('', async (req, res) => {
|
||||||
|
const { start_city_id, end_city_id } = req.query;
|
||||||
|
|
||||||
|
start = Math.floor(start_city_id);
|
||||||
|
end = Math.floor(end_city_id);
|
||||||
|
|
||||||
|
try {
|
||||||
|
const cities = await Cities.getCities();
|
||||||
|
const roads = await Roads.getRoads();
|
||||||
|
|
||||||
|
let { path, distance } = findShortestPath(cities, roads, start, end);
|
||||||
|
const shortestPath = formatPath(path, cities)
|
||||||
|
|
||||||
|
let response = { path: shortestPath, distance }
|
||||||
|
|
||||||
|
res.status(200).json(response);
|
||||||
|
} catch (e) {
|
||||||
|
res.status(500).json(e);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
function formatPath(path, cities) {
|
||||||
|
const complete_path = []
|
||||||
|
|
||||||
|
for (let path_city of path) {
|
||||||
|
for (let city of cities) {
|
||||||
|
if (city.id == path_city) {
|
||||||
|
complete_path.push({ id: city.id, name: city.name });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return complete_path
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = router;
|
13
api/routes/roadsRouter.js
Normal file
13
api/routes/roadsRouter.js
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
const router = require('express').Router();
|
||||||
|
const Roads = require('../models/roadsModel');
|
||||||
|
|
||||||
|
router.get('', async (req, res) => {
|
||||||
|
try {
|
||||||
|
const roads = await Roads.getRoads();
|
||||||
|
res.status(200).json(roads);
|
||||||
|
} catch (e) {
|
||||||
|
res.status(500).json(e);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
module.exports = router;
|
21
api/server.js
Normal file
21
api/server.js
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
const express = require("express");
|
||||||
|
const helmet = require('helmet');
|
||||||
|
const cors = require('cors');
|
||||||
|
|
||||||
|
const citiesRouter = require('./routes/citiesRouter');
|
||||||
|
const roadsRouter = require('./routes/roadsRouter');
|
||||||
|
const countriesRouter = require('./routes/countriesRouter');
|
||||||
|
const pathRouter = require('./routes/pathRouter')
|
||||||
|
|
||||||
|
const server = express();
|
||||||
|
|
||||||
|
server.use(helmet());
|
||||||
|
server.use(express.json());
|
||||||
|
server.use(cors());
|
||||||
|
|
||||||
|
server.use('/api/cities', citiesRouter);
|
||||||
|
server.use('/api/roads', roadsRouter);
|
||||||
|
server.use('/api/countries', countriesRouter);
|
||||||
|
server.use('/api/path', pathRouter);
|
||||||
|
|
||||||
|
module.exports = server;
|
7
data/dbConfig.js
Normal file
7
data/dbConfig.js
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
|
||||||
|
const knex = require('knex');
|
||||||
|
const config = require('../knexfile');
|
||||||
|
|
||||||
|
const environment = 'development';
|
||||||
|
|
||||||
|
module.exports = knex(config[environment]);
|
13
data/migrations/20200207155645_countries.js
Normal file
13
data/migrations/20200207155645_countries.js
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
exports.up = function(knex, Promise) {
|
||||||
|
return knex.schema.createTable('countries', function(countries) {
|
||||||
|
countries.increments();
|
||||||
|
countries
|
||||||
|
.string('name', 128)
|
||||||
|
.notNullable()
|
||||||
|
.unique();
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
exports.down = function(knex, Promise) {
|
||||||
|
return knex.schema.dropTableIfExists('countries');
|
||||||
|
};
|
20
data/migrations/20200207160031_cities.js
Normal file
20
data/migrations/20200207160031_cities.js
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
exports.up = function(knex) {
|
||||||
|
return knex.schema.createTable('cities', function(cities) {
|
||||||
|
cities.increments();
|
||||||
|
|
||||||
|
cities.string('name', 128).notNullable();
|
||||||
|
cities
|
||||||
|
.integer('country_id')
|
||||||
|
.unsigned()
|
||||||
|
.notNullable()
|
||||||
|
.references('id')
|
||||||
|
.inTable('countries')
|
||||||
|
.onDelete('CASCADE')
|
||||||
|
.onUpdate('CASCADE');
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
exports.down = function(knex) {
|
||||||
|
return knex.schema.dropTableIfExists('cities');
|
||||||
|
};
|
||||||
|
|
32
data/migrations/20200207160304_roads.js
Normal file
32
data/migrations/20200207160304_roads.js
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
exports.up = function(knex) {
|
||||||
|
return knex.schema.createTable('roads', function(roads) {
|
||||||
|
roads.increments();
|
||||||
|
|
||||||
|
roads
|
||||||
|
.integer('start_city_id')
|
||||||
|
.unsigned()
|
||||||
|
.notNullable()
|
||||||
|
.references('id')
|
||||||
|
.inTable('cities')
|
||||||
|
.onDelete('CASCADE')
|
||||||
|
.onUpdate('CASCADE');
|
||||||
|
|
||||||
|
roads
|
||||||
|
.integer('end_city_id')
|
||||||
|
.unsigned()
|
||||||
|
.notNullable()
|
||||||
|
.references('id')
|
||||||
|
.inTable('cities')
|
||||||
|
.onDelete('CASCADE')
|
||||||
|
.onUpdate('CASCADE');
|
||||||
|
|
||||||
|
roads
|
||||||
|
.integer('distance')
|
||||||
|
.unsigned()
|
||||||
|
.notNullable()
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
exports.down = function(knex) {
|
||||||
|
return knex.schema.dropTableIfExists('roads');
|
||||||
|
};
|
12
data/seeds/01-countries.js
Normal file
12
data/seeds/01-countries.js
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
|
||||||
|
exports.seed = function(knex) {
|
||||||
|
return knex('countries').truncate()
|
||||||
|
.then(function () {
|
||||||
|
return knex('countries').insert([
|
||||||
|
{
|
||||||
|
id: 1,
|
||||||
|
name: 'Belgium',
|
||||||
|
}
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
};
|
58
data/seeds/02-cities.js
Normal file
58
data/seeds/02-cities.js
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
exports.seed = function (knex) {
|
||||||
|
return knex('cities')
|
||||||
|
.truncate()
|
||||||
|
.then(function () {
|
||||||
|
return knex('cities').insert([
|
||||||
|
{
|
||||||
|
id: 1,
|
||||||
|
name: 'bruges',
|
||||||
|
country_id: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 2,
|
||||||
|
name: 'antwerp',
|
||||||
|
country_id: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 3,
|
||||||
|
name: 'ghent',
|
||||||
|
country_id: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 4,
|
||||||
|
name: 'mechelen',
|
||||||
|
country_id: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 5,
|
||||||
|
name: 'brussels',
|
||||||
|
country_id: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 6,
|
||||||
|
name: 'mons',
|
||||||
|
country_id: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 7,
|
||||||
|
name: 'namur',
|
||||||
|
country_id: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 8,
|
||||||
|
name: 'liege',
|
||||||
|
country_id: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 9,
|
||||||
|
name: 'arlon',
|
||||||
|
country_id: 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 10,
|
||||||
|
name: 'tournai',
|
||||||
|
country_id: 1,
|
||||||
|
},
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
};
|
92
data/seeds/03-roads.js
Normal file
92
data/seeds/03-roads.js
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
exports.seed = function (knex) {
|
||||||
|
return knex('roads')
|
||||||
|
.truncate()
|
||||||
|
.then(function () {
|
||||||
|
return knex('roads').insert([
|
||||||
|
{
|
||||||
|
id: 1,
|
||||||
|
start_city_id: 1,
|
||||||
|
end_city_id: 3,
|
||||||
|
distance: 40,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 2,
|
||||||
|
start_city_id: 3,
|
||||||
|
end_city_id: 10,
|
||||||
|
distance: 60,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 3,
|
||||||
|
start_city_id: 10,
|
||||||
|
end_city_id: 5,
|
||||||
|
distance: 70,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 4,
|
||||||
|
start_city_id: 3,
|
||||||
|
end_city_id: 5,
|
||||||
|
distance: 50,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 5,
|
||||||
|
start_city_id: 3,
|
||||||
|
end_city_id: 2,
|
||||||
|
distance: 50,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 6,
|
||||||
|
start_city_id: 2,
|
||||||
|
end_city_id: 4,
|
||||||
|
distance: 20,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 7,
|
||||||
|
start_city_id: 4,
|
||||||
|
end_city_id: 5,
|
||||||
|
distance: 20,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 8,
|
||||||
|
start_city_id: 5,
|
||||||
|
end_city_id: 6,
|
||||||
|
distance: 50,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 9,
|
||||||
|
start_city_id: 6,
|
||||||
|
end_city_id: 7,
|
||||||
|
distance: 60,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 10,
|
||||||
|
start_city_id: 6,
|
||||||
|
end_city_id: 10,
|
||||||
|
distance: 40,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 11,
|
||||||
|
start_city_id: 7,
|
||||||
|
end_city_id: 9,
|
||||||
|
distance: 110,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 12,
|
||||||
|
start_city_id: 9,
|
||||||
|
end_city_id: 7,
|
||||||
|
distance: 110,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 13,
|
||||||
|
start_city_id: 8,
|
||||||
|
end_city_id: 7,
|
||||||
|
distance: 50,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 14,
|
||||||
|
start_city_id: 8,
|
||||||
|
end_city_id: 5,
|
||||||
|
distance: 90,
|
||||||
|
},
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
};
|
55
helpers/dijkstra_algo.js
Normal file
55
helpers/dijkstra_algo.js
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
const Queue = require('./queue');
|
||||||
|
const Graph = require('./graph');
|
||||||
|
|
||||||
|
function findPathWithDijkstra(cities, roads, startNode, endNode) {
|
||||||
|
const graph = new Graph();
|
||||||
|
|
||||||
|
// Add cities and roads to graph
|
||||||
|
for (let city of cities) {
|
||||||
|
graph.addNode(city.id)
|
||||||
|
}
|
||||||
|
|
||||||
|
for (let { start_city_id, end_city_id, distance } of roads) {
|
||||||
|
graph.addEdge(start_city_id, end_city_id, distance)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Dijkstra path search algo
|
||||||
|
let times = {};
|
||||||
|
let backtrace = {};
|
||||||
|
let queue = new Queue();
|
||||||
|
|
||||||
|
times[startNode] = 0;
|
||||||
|
|
||||||
|
graph.nodes.forEach(node => {
|
||||||
|
if (node !== startNode) {
|
||||||
|
times[node] = Infinity
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
queue.enqueue([startNode, 0]);
|
||||||
|
|
||||||
|
while (queue.size()) {
|
||||||
|
let shortestStep = queue.dequeue();
|
||||||
|
let currentNode = shortestStep[0];
|
||||||
|
graph.adjacencyList[currentNode].forEach(neighbor => {
|
||||||
|
let time = times[currentNode] + neighbor.distance;
|
||||||
|
|
||||||
|
if (time < times[neighbor.node]) {
|
||||||
|
times[neighbor.node] = time;
|
||||||
|
backtrace[neighbor.node] = currentNode;
|
||||||
|
queue.enqueue([neighbor.node, time]);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
let path = [endNode];
|
||||||
|
let lastStep = endNode; while(lastStep !== startNode) {
|
||||||
|
path.unshift(backtrace[lastStep])
|
||||||
|
lastStep = backtrace[lastStep]
|
||||||
|
}
|
||||||
|
|
||||||
|
// return `Path is ${path} and time is ${times[endNode]}`
|
||||||
|
return {path, distance: times[endNode]}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = findPathWithDijkstra;
|
18
helpers/graph.js
Normal file
18
helpers/graph.js
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
class Graph {
|
||||||
|
constructor() {
|
||||||
|
this.nodes = [];
|
||||||
|
this.adjacencyList = {};
|
||||||
|
}
|
||||||
|
|
||||||
|
addNode(node) {
|
||||||
|
this.nodes.push(node);
|
||||||
|
this.adjacencyList[node] = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
addEdge(node1, node2, distance) {
|
||||||
|
this.adjacencyList[node1].push({node:node2, distance});
|
||||||
|
this.adjacencyList[node2].push({node:node1, distance});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Graph;
|
21
helpers/queue.js
Normal file
21
helpers/queue.js
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
class Queue {
|
||||||
|
constructor() {
|
||||||
|
this.store = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
size() {
|
||||||
|
return this.store.length
|
||||||
|
}
|
||||||
|
|
||||||
|
enqueue(node) {
|
||||||
|
this.store.push(node);
|
||||||
|
}
|
||||||
|
|
||||||
|
dequeue() {
|
||||||
|
if (this.size() > 0) {
|
||||||
|
return this.store.shift();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Queue;
|
12
index.js
Normal file
12
index.js
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
const server = require("./api/server");
|
||||||
|
|
||||||
|
server.get("/", (req, res) => {
|
||||||
|
res.json({
|
||||||
|
message: `API server for Dijkstra. :)`,
|
||||||
|
documentation: `Check out: https://git.ruihildt.xyz/ruihildt/dijkstra-backend`
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
server.listen(4000, () => {
|
||||||
|
console.log(`Listening on port 4000...`);
|
||||||
|
});
|
23
knexfile.js
Normal file
23
knexfile.js
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
module.exports = {
|
||||||
|
|
||||||
|
development: {
|
||||||
|
client: 'sqlite3',
|
||||||
|
connection: {
|
||||||
|
filename: '/app/data/database_file.db3',
|
||||||
|
},
|
||||||
|
useNullAsDefault: true,
|
||||||
|
migrations: {
|
||||||
|
directory: './data/migrations'
|
||||||
|
},
|
||||||
|
seeds: {
|
||||||
|
directory: './data/seeds'
|
||||||
|
},
|
||||||
|
pool: {
|
||||||
|
afterCreate: (conn, done) => {
|
||||||
|
// runs after a connection is made to the sqlite engine
|
||||||
|
conn.run('PRAGMA foreign_keys = ON', done); // turn on FK enforcement
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
1
node_modules/.bin/atob
generated
vendored
Symbolic link
1
node_modules/.bin/atob
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../atob/bin/atob.js
|
1
node_modules/.bin/detect-libc
generated
vendored
Symbolic link
1
node_modules/.bin/detect-libc
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../detect-libc/bin/detect-libc.js
|
1
node_modules/.bin/is-ci
generated
vendored
Symbolic link
1
node_modules/.bin/is-ci
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../is-ci/bin.js
|
1
node_modules/.bin/knex
generated
vendored
Symbolic link
1
node_modules/.bin/knex
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../knex/bin/cli.js
|
1
node_modules/.bin/mime
generated
vendored
Symbolic link
1
node_modules/.bin/mime
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../mime/cli.js
|
1
node_modules/.bin/mkdirp
generated
vendored
Symbolic link
1
node_modules/.bin/mkdirp
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../mkdirp/bin/cmd.js
|
1
node_modules/.bin/needle
generated
vendored
Symbolic link
1
node_modules/.bin/needle
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../needle/bin/needle
|
1
node_modules/.bin/node-pre-gyp
generated
vendored
Symbolic link
1
node_modules/.bin/node-pre-gyp
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../node-pre-gyp/bin/node-pre-gyp
|
1
node_modules/.bin/nodemon
generated
vendored
Symbolic link
1
node_modules/.bin/nodemon
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../nodemon/bin/nodemon.js
|
1
node_modules/.bin/nodetouch
generated
vendored
Symbolic link
1
node_modules/.bin/nodetouch
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../touch/bin/nodetouch.js
|
1
node_modules/.bin/nopt
generated
vendored
Symbolic link
1
node_modules/.bin/nopt
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../nopt/bin/nopt.js
|
1
node_modules/.bin/rc
generated
vendored
Symbolic link
1
node_modules/.bin/rc
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../rc/cli.js
|
1
node_modules/.bin/rimraf
generated
vendored
Symbolic link
1
node_modules/.bin/rimraf
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../rimraf/bin.js
|
1
node_modules/.bin/semver
generated
vendored
Symbolic link
1
node_modules/.bin/semver
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../semver/bin/semver
|
1
node_modules/.bin/sshpk-conv
generated
vendored
Symbolic link
1
node_modules/.bin/sshpk-conv
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../sshpk/bin/sshpk-conv
|
1
node_modules/.bin/sshpk-sign
generated
vendored
Symbolic link
1
node_modules/.bin/sshpk-sign
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../sshpk/bin/sshpk-sign
|
1
node_modules/.bin/sshpk-verify
generated
vendored
Symbolic link
1
node_modules/.bin/sshpk-verify
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../sshpk/bin/sshpk-verify
|
1
node_modules/.bin/uuid
generated
vendored
Symbolic link
1
node_modules/.bin/uuid
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../uuid/bin/uuid
|
1
node_modules/.bin/which
generated
vendored
Symbolic link
1
node_modules/.bin/which
generated
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../which/bin/which
|
File diff suppressed because one or more lines are too long
2
node_modules/.cache/terser-webpack-plugin/index-v5/4c/05/7eea19d89972a5155d16260e736a4bb680508347463b756b6f36981e164c
generated
vendored
Normal file
2
node_modules/.cache/terser-webpack-plugin/index-v5/4c/05/7eea19d89972a5155d16260e736a4bb680508347463b756b6f36981e164c
generated
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
|
||||||
|
9a33838bc351e55ffa949dcbecd94ad22cd5a3da {"key":"{\"terser\":\"3.10.12\",\"terser-webpack-plugin\":\"1.1.0\",\"terser-webpack-plugin-options\":{\"test\":/\\.js(\\?.*)?$/i,\"warningsFilter\":() => true,\"extractComments\":false,\"sourceMap\":false,\"cache\":true,\"cacheKeys\":defaultCacheKeys => defaultCacheKeys,\"parallel\":true,\"terserOptions\":{\"output\":{\"comments\":/^\\**!|@preserve|@license|@cc_on/i}}},\"path\":\"\\u002Fhome\\u002Frui\\u002Fcode\\u002Fpersonal\\u002Fdijkstra-app\\u002Fbackend-dijkstra\\u002Fdist\\u002Fbundle.js\",\"hash\":\"76e9314883582c8fc84477275058c8b9\"}","integrity":"sha512-dDrZgY6riWmSXdgjzX6vs8KOVr9ojlYaMKthhmtcE/ngUJcigFF2SBxqsSIxe9YEf6dPrgey0iW40S0T9Zov2Q==","time":1602263429292,"size":603960}
|
46
node_modules/abbrev/LICENSE
generated
vendored
Normal file
46
node_modules/abbrev/LICENSE
generated
vendored
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
This software is dual-licensed under the ISC and MIT licenses.
|
||||||
|
You may use this software under EITHER of the following licenses.
|
||||||
|
|
||||||
|
----------
|
||||||
|
|
||||||
|
The ISC License
|
||||||
|
|
||||||
|
Copyright (c) Isaac Z. Schlueter and Contributors
|
||||||
|
|
||||||
|
Permission to use, copy, modify, and/or distribute this software for any
|
||||||
|
purpose with or without fee is hereby granted, provided that the above
|
||||||
|
copyright notice and this permission notice appear in all copies.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||||||
|
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||||||
|
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||||||
|
ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||||
|
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||||||
|
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
|
||||||
|
IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
|
||||||
|
----------
|
||||||
|
|
||||||
|
Copyright Isaac Z. Schlueter and Contributors
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person
|
||||||
|
obtaining a copy of this software and associated documentation
|
||||||
|
files (the "Software"), to deal in the Software without
|
||||||
|
restriction, including without limitation the rights to use,
|
||||||
|
copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the
|
||||||
|
Software is furnished to do so, subject to the following
|
||||||
|
conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
||||||
|
OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
||||||
|
HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||||
|
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||||
|
OTHER DEALINGS IN THE SOFTWARE.
|
23
node_modules/abbrev/README.md
generated
vendored
Normal file
23
node_modules/abbrev/README.md
generated
vendored
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
# abbrev-js
|
||||||
|
|
||||||
|
Just like [ruby's Abbrev](http://apidock.com/ruby/Abbrev).
|
||||||
|
|
||||||
|
Usage:
|
||||||
|
|
||||||
|
var abbrev = require("abbrev");
|
||||||
|
abbrev("foo", "fool", "folding", "flop");
|
||||||
|
|
||||||
|
// returns:
|
||||||
|
{ fl: 'flop'
|
||||||
|
, flo: 'flop'
|
||||||
|
, flop: 'flop'
|
||||||
|
, fol: 'folding'
|
||||||
|
, fold: 'folding'
|
||||||
|
, foldi: 'folding'
|
||||||
|
, foldin: 'folding'
|
||||||
|
, folding: 'folding'
|
||||||
|
, foo: 'foo'
|
||||||
|
, fool: 'fool'
|
||||||
|
}
|
||||||
|
|
||||||
|
This is handy for command-line scripts, or other cases where you want to be able to accept shorthands.
|
61
node_modules/abbrev/abbrev.js
generated
vendored
Normal file
61
node_modules/abbrev/abbrev.js
generated
vendored
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
module.exports = exports = abbrev.abbrev = abbrev
|
||||||
|
|
||||||
|
abbrev.monkeyPatch = monkeyPatch
|
||||||
|
|
||||||
|
function monkeyPatch () {
|
||||||
|
Object.defineProperty(Array.prototype, 'abbrev', {
|
||||||
|
value: function () { return abbrev(this) },
|
||||||
|
enumerable: false, configurable: true, writable: true
|
||||||
|
})
|
||||||
|
|
||||||
|
Object.defineProperty(Object.prototype, 'abbrev', {
|
||||||
|
value: function () { return abbrev(Object.keys(this)) },
|
||||||
|
enumerable: false, configurable: true, writable: true
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
function abbrev (list) {
|
||||||
|
if (arguments.length !== 1 || !Array.isArray(list)) {
|
||||||
|
list = Array.prototype.slice.call(arguments, 0)
|
||||||
|
}
|
||||||
|
for (var i = 0, l = list.length, args = [] ; i < l ; i ++) {
|
||||||
|
args[i] = typeof list[i] === "string" ? list[i] : String(list[i])
|
||||||
|
}
|
||||||
|
|
||||||
|
// sort them lexicographically, so that they're next to their nearest kin
|
||||||
|
args = args.sort(lexSort)
|
||||||
|
|
||||||
|
// walk through each, seeing how much it has in common with the next and previous
|
||||||
|
var abbrevs = {}
|
||||||
|
, prev = ""
|
||||||
|
for (var i = 0, l = args.length ; i < l ; i ++) {
|
||||||
|
var current = args[i]
|
||||||
|
, next = args[i + 1] || ""
|
||||||
|
, nextMatches = true
|
||||||
|
, prevMatches = true
|
||||||
|
if (current === next) continue
|
||||||
|
for (var j = 0, cl = current.length ; j < cl ; j ++) {
|
||||||
|
var curChar = current.charAt(j)
|
||||||
|
nextMatches = nextMatches && curChar === next.charAt(j)
|
||||||
|
prevMatches = prevMatches && curChar === prev.charAt(j)
|
||||||
|
if (!nextMatches && !prevMatches) {
|
||||||
|
j ++
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
prev = current
|
||||||
|
if (j === cl) {
|
||||||
|
abbrevs[current] = current
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
for (var a = current.substr(0, j) ; j <= cl ; j ++) {
|
||||||
|
abbrevs[a] = current
|
||||||
|
a += current.charAt(j)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return abbrevs
|
||||||
|
}
|
||||||
|
|
||||||
|
function lexSort (a, b) {
|
||||||
|
return a === b ? 0 : a > b ? 1 : -1
|
||||||
|
}
|
60
node_modules/abbrev/package.json
generated
vendored
Normal file
60
node_modules/abbrev/package.json
generated
vendored
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
{
|
||||||
|
"_args": [
|
||||||
|
[
|
||||||
|
"abbrev@1.1.1",
|
||||||
|
"/home/rui/code/personal/dijkstra-app/backend-dijkstra"
|
||||||
|
]
|
||||||
|
],
|
||||||
|
"_from": "abbrev@1.1.1",
|
||||||
|
"_id": "abbrev@1.1.1",
|
||||||
|
"_inBundle": false,
|
||||||
|
"_integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==",
|
||||||
|
"_location": "/abbrev",
|
||||||
|
"_phantomChildren": {},
|
||||||
|
"_requested": {
|
||||||
|
"type": "version",
|
||||||
|
"registry": true,
|
||||||
|
"raw": "abbrev@1.1.1",
|
||||||
|
"name": "abbrev",
|
||||||
|
"escapedName": "abbrev",
|
||||||
|
"rawSpec": "1.1.1",
|
||||||
|
"saveSpec": null,
|
||||||
|
"fetchSpec": "1.1.1"
|
||||||
|
},
|
||||||
|
"_requiredBy": [
|
||||||
|
"/nopt",
|
||||||
|
"/touch/nopt"
|
||||||
|
],
|
||||||
|
"_resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz",
|
||||||
|
"_spec": "1.1.1",
|
||||||
|
"_where": "/home/rui/code/personal/dijkstra-app/backend-dijkstra",
|
||||||
|
"author": {
|
||||||
|
"name": "Isaac Z. Schlueter",
|
||||||
|
"email": "i@izs.me"
|
||||||
|
},
|
||||||
|
"bugs": {
|
||||||
|
"url": "https://github.com/isaacs/abbrev-js/issues"
|
||||||
|
},
|
||||||
|
"description": "Like ruby's abbrev module, but in js",
|
||||||
|
"devDependencies": {
|
||||||
|
"tap": "^10.1"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"abbrev.js"
|
||||||
|
],
|
||||||
|
"homepage": "https://github.com/isaacs/abbrev-js#readme",
|
||||||
|
"license": "ISC",
|
||||||
|
"main": "abbrev.js",
|
||||||
|
"name": "abbrev",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git+ssh://git@github.com/isaacs/abbrev-js.git"
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"postpublish": "git push origin --all; git push origin --tags",
|
||||||
|
"postversion": "npm publish",
|
||||||
|
"preversion": "npm test",
|
||||||
|
"test": "tap test.js --100"
|
||||||
|
},
|
||||||
|
"version": "1.1.1"
|
||||||
|
}
|
236
node_modules/accepts/HISTORY.md
generated
vendored
Normal file
236
node_modules/accepts/HISTORY.md
generated
vendored
Normal file
@ -0,0 +1,236 @@
|
|||||||
|
1.3.7 / 2019-04-29
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: negotiator@0.6.2
|
||||||
|
- Fix sorting charset, encoding, and language with extra parameters
|
||||||
|
|
||||||
|
1.3.6 / 2019-04-28
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.1.24
|
||||||
|
- deps: mime-db@~1.40.0
|
||||||
|
|
||||||
|
1.3.5 / 2018-02-28
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.1.18
|
||||||
|
- deps: mime-db@~1.33.0
|
||||||
|
|
||||||
|
1.3.4 / 2017-08-22
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.1.16
|
||||||
|
- deps: mime-db@~1.29.0
|
||||||
|
|
||||||
|
1.3.3 / 2016-05-02
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.1.11
|
||||||
|
- deps: mime-db@~1.23.0
|
||||||
|
* deps: negotiator@0.6.1
|
||||||
|
- perf: improve `Accept` parsing speed
|
||||||
|
- perf: improve `Accept-Charset` parsing speed
|
||||||
|
- perf: improve `Accept-Encoding` parsing speed
|
||||||
|
- perf: improve `Accept-Language` parsing speed
|
||||||
|
|
||||||
|
1.3.2 / 2016-03-08
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.1.10
|
||||||
|
- Fix extension of `application/dash+xml`
|
||||||
|
- Update primary extension for `audio/mp4`
|
||||||
|
- deps: mime-db@~1.22.0
|
||||||
|
|
||||||
|
1.3.1 / 2016-01-19
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.1.9
|
||||||
|
- deps: mime-db@~1.21.0
|
||||||
|
|
||||||
|
1.3.0 / 2015-09-29
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.1.7
|
||||||
|
- deps: mime-db@~1.19.0
|
||||||
|
* deps: negotiator@0.6.0
|
||||||
|
- Fix including type extensions in parameters in `Accept` parsing
|
||||||
|
- Fix parsing `Accept` parameters with quoted equals
|
||||||
|
- Fix parsing `Accept` parameters with quoted semicolons
|
||||||
|
- Lazy-load modules from main entry point
|
||||||
|
- perf: delay type concatenation until needed
|
||||||
|
- perf: enable strict mode
|
||||||
|
- perf: hoist regular expressions
|
||||||
|
- perf: remove closures getting spec properties
|
||||||
|
- perf: remove a closure from media type parsing
|
||||||
|
- perf: remove property delete from media type parsing
|
||||||
|
|
||||||
|
1.2.13 / 2015-09-06
|
||||||
|
===================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.1.6
|
||||||
|
- deps: mime-db@~1.18.0
|
||||||
|
|
||||||
|
1.2.12 / 2015-07-30
|
||||||
|
===================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.1.4
|
||||||
|
- deps: mime-db@~1.16.0
|
||||||
|
|
||||||
|
1.2.11 / 2015-07-16
|
||||||
|
===================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.1.3
|
||||||
|
- deps: mime-db@~1.15.0
|
||||||
|
|
||||||
|
1.2.10 / 2015-07-01
|
||||||
|
===================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.1.2
|
||||||
|
- deps: mime-db@~1.14.0
|
||||||
|
|
||||||
|
1.2.9 / 2015-06-08
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.1.1
|
||||||
|
- perf: fix deopt during mapping
|
||||||
|
|
||||||
|
1.2.8 / 2015-06-07
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.1.0
|
||||||
|
- deps: mime-db@~1.13.0
|
||||||
|
* perf: avoid argument reassignment & argument slice
|
||||||
|
* perf: avoid negotiator recursive construction
|
||||||
|
* perf: enable strict mode
|
||||||
|
* perf: remove unnecessary bitwise operator
|
||||||
|
|
||||||
|
1.2.7 / 2015-05-10
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: negotiator@0.5.3
|
||||||
|
- Fix media type parameter matching to be case-insensitive
|
||||||
|
|
||||||
|
1.2.6 / 2015-05-07
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.0.11
|
||||||
|
- deps: mime-db@~1.9.1
|
||||||
|
* deps: negotiator@0.5.2
|
||||||
|
- Fix comparing media types with quoted values
|
||||||
|
- Fix splitting media types with quoted commas
|
||||||
|
|
||||||
|
1.2.5 / 2015-03-13
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.0.10
|
||||||
|
- deps: mime-db@~1.8.0
|
||||||
|
|
||||||
|
1.2.4 / 2015-02-14
|
||||||
|
==================
|
||||||
|
|
||||||
|
* Support Node.js 0.6
|
||||||
|
* deps: mime-types@~2.0.9
|
||||||
|
- deps: mime-db@~1.7.0
|
||||||
|
* deps: negotiator@0.5.1
|
||||||
|
- Fix preference sorting to be stable for long acceptable lists
|
||||||
|
|
||||||
|
1.2.3 / 2015-01-31
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.0.8
|
||||||
|
- deps: mime-db@~1.6.0
|
||||||
|
|
||||||
|
1.2.2 / 2014-12-30
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.0.7
|
||||||
|
- deps: mime-db@~1.5.0
|
||||||
|
|
||||||
|
1.2.1 / 2014-12-30
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.0.5
|
||||||
|
- deps: mime-db@~1.3.1
|
||||||
|
|
||||||
|
1.2.0 / 2014-12-19
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: negotiator@0.5.0
|
||||||
|
- Fix list return order when large accepted list
|
||||||
|
- Fix missing identity encoding when q=0 exists
|
||||||
|
- Remove dynamic building of Negotiator class
|
||||||
|
|
||||||
|
1.1.4 / 2014-12-10
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.0.4
|
||||||
|
- deps: mime-db@~1.3.0
|
||||||
|
|
||||||
|
1.1.3 / 2014-11-09
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.0.3
|
||||||
|
- deps: mime-db@~1.2.0
|
||||||
|
|
||||||
|
1.1.2 / 2014-10-14
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: negotiator@0.4.9
|
||||||
|
- Fix error when media type has invalid parameter
|
||||||
|
|
||||||
|
1.1.1 / 2014-09-28
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: mime-types@~2.0.2
|
||||||
|
- deps: mime-db@~1.1.0
|
||||||
|
* deps: negotiator@0.4.8
|
||||||
|
- Fix all negotiations to be case-insensitive
|
||||||
|
- Stable sort preferences of same quality according to client order
|
||||||
|
|
||||||
|
1.1.0 / 2014-09-02
|
||||||
|
==================
|
||||||
|
|
||||||
|
* update `mime-types`
|
||||||
|
|
||||||
|
1.0.7 / 2014-07-04
|
||||||
|
==================
|
||||||
|
|
||||||
|
* Fix wrong type returned from `type` when match after unknown extension
|
||||||
|
|
||||||
|
1.0.6 / 2014-06-24
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: negotiator@0.4.7
|
||||||
|
|
||||||
|
1.0.5 / 2014-06-20
|
||||||
|
==================
|
||||||
|
|
||||||
|
* fix crash when unknown extension given
|
||||||
|
|
||||||
|
1.0.4 / 2014-06-19
|
||||||
|
==================
|
||||||
|
|
||||||
|
* use `mime-types`
|
||||||
|
|
||||||
|
1.0.3 / 2014-06-11
|
||||||
|
==================
|
||||||
|
|
||||||
|
* deps: negotiator@0.4.6
|
||||||
|
- Order by specificity when quality is the same
|
||||||
|
|
||||||
|
1.0.2 / 2014-05-29
|
||||||
|
==================
|
||||||
|
|
||||||
|
* Fix interpretation when header not in request
|
||||||
|
* deps: pin negotiator@0.4.5
|
||||||
|
|
||||||
|
1.0.1 / 2014-01-18
|
||||||
|
==================
|
||||||
|
|
||||||
|
* Identity encoding isn't always acceptable
|
||||||
|
* deps: negotiator@~0.4.0
|
||||||
|
|
||||||
|
1.0.0 / 2013-12-27
|
||||||
|
==================
|
||||||
|
|
||||||
|
* Genesis
|
23
node_modules/accepts/LICENSE
generated
vendored
Normal file
23
node_modules/accepts/LICENSE
generated
vendored
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
(The MIT License)
|
||||||
|
|
||||||
|
Copyright (c) 2014 Jonathan Ong <me@jongleberry.com>
|
||||||
|
Copyright (c) 2015 Douglas Christopher Wilson <doug@somethingdoug.com>
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
a copy of this software and associated documentation files (the
|
||||||
|
'Software'), to deal in the Software without restriction, including
|
||||||
|
without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||||
|
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
||||||
|
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
||||||
|
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
142
node_modules/accepts/README.md
generated
vendored
Normal file
142
node_modules/accepts/README.md
generated
vendored
Normal file
@ -0,0 +1,142 @@
|
|||||||
|
# accepts
|
||||||
|
|
||||||
|
[![NPM Version][npm-version-image]][npm-url]
|
||||||
|
[![NPM Downloads][npm-downloads-image]][npm-url]
|
||||||
|
[![Node.js Version][node-version-image]][node-version-url]
|
||||||
|
[![Build Status][travis-image]][travis-url]
|
||||||
|
[![Test Coverage][coveralls-image]][coveralls-url]
|
||||||
|
|
||||||
|
Higher level content negotiation based on [negotiator](https://www.npmjs.com/package/negotiator).
|
||||||
|
Extracted from [koa](https://www.npmjs.com/package/koa) for general use.
|
||||||
|
|
||||||
|
In addition to negotiator, it allows:
|
||||||
|
|
||||||
|
- Allows types as an array or arguments list, ie `(['text/html', 'application/json'])`
|
||||||
|
as well as `('text/html', 'application/json')`.
|
||||||
|
- Allows type shorthands such as `json`.
|
||||||
|
- Returns `false` when no types match
|
||||||
|
- Treats non-existent headers as `*`
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
This is a [Node.js](https://nodejs.org/en/) module available through the
|
||||||
|
[npm registry](https://www.npmjs.com/). Installation is done using the
|
||||||
|
[`npm install` command](https://docs.npmjs.com/getting-started/installing-npm-packages-locally):
|
||||||
|
|
||||||
|
```sh
|
||||||
|
$ npm install accepts
|
||||||
|
```
|
||||||
|
|
||||||
|
## API
|
||||||
|
|
||||||
|
<!-- eslint-disable no-unused-vars -->
|
||||||
|
|
||||||
|
```js
|
||||||
|
var accepts = require('accepts')
|
||||||
|
```
|
||||||
|
|
||||||
|
### accepts(req)
|
||||||
|
|
||||||
|
Create a new `Accepts` object for the given `req`.
|
||||||
|
|
||||||
|
#### .charset(charsets)
|
||||||
|
|
||||||
|
Return the first accepted charset. If nothing in `charsets` is accepted,
|
||||||
|
then `false` is returned.
|
||||||
|
|
||||||
|
#### .charsets()
|
||||||
|
|
||||||
|
Return the charsets that the request accepts, in the order of the client's
|
||||||
|
preference (most preferred first).
|
||||||
|
|
||||||
|
#### .encoding(encodings)
|
||||||
|
|
||||||
|
Return the first accepted encoding. If nothing in `encodings` is accepted,
|
||||||
|
then `false` is returned.
|
||||||
|
|
||||||
|
#### .encodings()
|
||||||
|
|
||||||
|
Return the encodings that the request accepts, in the order of the client's
|
||||||
|
preference (most preferred first).
|
||||||
|
|
||||||
|
#### .language(languages)
|
||||||
|
|
||||||
|
Return the first accepted language. If nothing in `languages` is accepted,
|
||||||
|
then `false` is returned.
|
||||||
|
|
||||||
|
#### .languages()
|
||||||
|
|
||||||
|
Return the languages that the request accepts, in the order of the client's
|
||||||
|
preference (most preferred first).
|
||||||
|
|
||||||
|
#### .type(types)
|
||||||
|
|
||||||
|
Return the first accepted type (and it is returned as the same text as what
|
||||||
|
appears in the `types` array). If nothing in `types` is accepted, then `false`
|
||||||
|
is returned.
|
||||||
|
|
||||||
|
The `types` array can contain full MIME types or file extensions. Any value
|
||||||
|
that is not a full MIME types is passed to `require('mime-types').lookup`.
|
||||||
|
|
||||||
|
#### .types()
|
||||||
|
|
||||||
|
Return the types that the request accepts, in the order of the client's
|
||||||
|
preference (most preferred first).
|
||||||
|
|
||||||
|
## Examples
|
||||||
|
|
||||||
|
### Simple type negotiation
|
||||||
|
|
||||||
|
This simple example shows how to use `accepts` to return a different typed
|
||||||
|
respond body based on what the client wants to accept. The server lists it's
|
||||||
|
preferences in order and will get back the best match between the client and
|
||||||
|
server.
|
||||||
|
|
||||||
|
```js
|
||||||
|
var accepts = require('accepts')
|
||||||
|
var http = require('http')
|
||||||
|
|
||||||
|
function app (req, res) {
|
||||||
|
var accept = accepts(req)
|
||||||
|
|
||||||
|
// the order of this list is significant; should be server preferred order
|
||||||
|
switch (accept.type(['json', 'html'])) {
|
||||||
|
case 'json':
|
||||||
|
res.setHeader('Content-Type', 'application/json')
|
||||||
|
res.write('{"hello":"world!"}')
|
||||||
|
break
|
||||||
|
case 'html':
|
||||||
|
res.setHeader('Content-Type', 'text/html')
|
||||||
|
res.write('<b>hello, world!</b>')
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
// the fallback is text/plain, so no need to specify it above
|
||||||
|
res.setHeader('Content-Type', 'text/plain')
|
||||||
|
res.write('hello, world!')
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
res.end()
|
||||||
|
}
|
||||||
|
|
||||||
|
http.createServer(app).listen(3000)
|
||||||
|
```
|
||||||
|
|
||||||
|
You can test this out with the cURL program:
|
||||||
|
```sh
|
||||||
|
curl -I -H'Accept: text/html' http://localhost:3000/
|
||||||
|
```
|
||||||
|
|
||||||
|
## License
|
||||||
|
|
||||||
|
[MIT](LICENSE)
|
||||||
|
|
||||||
|
[coveralls-image]: https://badgen.net/coveralls/c/github/jshttp/accepts/master
|
||||||
|
[coveralls-url]: https://coveralls.io/r/jshttp/accepts?branch=master
|
||||||
|
[node-version-image]: https://badgen.net/npm/node/accepts
|
||||||
|
[node-version-url]: https://nodejs.org/en/download
|
||||||
|
[npm-downloads-image]: https://badgen.net/npm/dm/accepts
|
||||||
|
[npm-url]: https://npmjs.org/package/accepts
|
||||||
|
[npm-version-image]: https://badgen.net/npm/v/accepts
|
||||||
|
[travis-image]: https://badgen.net/travis/jshttp/accepts/master
|
||||||
|
[travis-url]: https://travis-ci.org/jshttp/accepts
|
238
node_modules/accepts/index.js
generated
vendored
Normal file
238
node_modules/accepts/index.js
generated
vendored
Normal file
@ -0,0 +1,238 @@
|
|||||||
|
/*!
|
||||||
|
* accepts
|
||||||
|
* Copyright(c) 2014 Jonathan Ong
|
||||||
|
* Copyright(c) 2015 Douglas Christopher Wilson
|
||||||
|
* MIT Licensed
|
||||||
|
*/
|
||||||
|
|
||||||
|
'use strict'
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Module dependencies.
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
|
||||||
|
var Negotiator = require('negotiator')
|
||||||
|
var mime = require('mime-types')
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Module exports.
|
||||||
|
* @public
|
||||||
|
*/
|
||||||
|
|
||||||
|
module.exports = Accepts
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new Accepts object for the given req.
|
||||||
|
*
|
||||||
|
* @param {object} req
|
||||||
|
* @public
|
||||||
|
*/
|
||||||
|
|
||||||
|
function Accepts (req) {
|
||||||
|
if (!(this instanceof Accepts)) {
|
||||||
|
return new Accepts(req)
|
||||||
|
}
|
||||||
|
|
||||||
|
this.headers = req.headers
|
||||||
|
this.negotiator = new Negotiator(req)
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if the given `type(s)` is acceptable, returning
|
||||||
|
* the best match when true, otherwise `undefined`, in which
|
||||||
|
* case you should respond with 406 "Not Acceptable".
|
||||||
|
*
|
||||||
|
* The `type` value may be a single mime type string
|
||||||
|
* such as "application/json", the extension name
|
||||||
|
* such as "json" or an array `["json", "html", "text/plain"]`. When a list
|
||||||
|
* or array is given the _best_ match, if any is returned.
|
||||||
|
*
|
||||||
|
* Examples:
|
||||||
|
*
|
||||||
|
* // Accept: text/html
|
||||||
|
* this.types('html');
|
||||||
|
* // => "html"
|
||||||
|
*
|
||||||
|
* // Accept: text/*, application/json
|
||||||
|
* this.types('html');
|
||||||
|
* // => "html"
|
||||||
|
* this.types('text/html');
|
||||||
|
* // => "text/html"
|
||||||
|
* this.types('json', 'text');
|
||||||
|
* // => "json"
|
||||||
|
* this.types('application/json');
|
||||||
|
* // => "application/json"
|
||||||
|
*
|
||||||
|
* // Accept: text/*, application/json
|
||||||
|
* this.types('image/png');
|
||||||
|
* this.types('png');
|
||||||
|
* // => undefined
|
||||||
|
*
|
||||||
|
* // Accept: text/*;q=.5, application/json
|
||||||
|
* this.types(['html', 'json']);
|
||||||
|
* this.types('html', 'json');
|
||||||
|
* // => "json"
|
||||||
|
*
|
||||||
|
* @param {String|Array} types...
|
||||||
|
* @return {String|Array|Boolean}
|
||||||
|
* @public
|
||||||
|
*/
|
||||||
|
|
||||||
|
Accepts.prototype.type =
|
||||||
|
Accepts.prototype.types = function (types_) {
|
||||||
|
var types = types_
|
||||||
|
|
||||||
|
// support flattened arguments
|
||||||
|
if (types && !Array.isArray(types)) {
|
||||||
|
types = new Array(arguments.length)
|
||||||
|
for (var i = 0; i < types.length; i++) {
|
||||||
|
types[i] = arguments[i]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// no types, return all requested types
|
||||||
|
if (!types || types.length === 0) {
|
||||||
|
return this.negotiator.mediaTypes()
|
||||||
|
}
|
||||||
|
|
||||||
|
// no accept header, return first given type
|
||||||
|
if (!this.headers.accept) {
|
||||||
|
return types[0]
|
||||||
|
}
|
||||||
|
|
||||||
|
var mimes = types.map(extToMime)
|
||||||
|
var accepts = this.negotiator.mediaTypes(mimes.filter(validMime))
|
||||||
|
var first = accepts[0]
|
||||||
|
|
||||||
|
return first
|
||||||
|
? types[mimes.indexOf(first)]
|
||||||
|
: false
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return accepted encodings or best fit based on `encodings`.
|
||||||
|
*
|
||||||
|
* Given `Accept-Encoding: gzip, deflate`
|
||||||
|
* an array sorted by quality is returned:
|
||||||
|
*
|
||||||
|
* ['gzip', 'deflate']
|
||||||
|
*
|
||||||
|
* @param {String|Array} encodings...
|
||||||
|
* @return {String|Array}
|
||||||
|
* @public
|
||||||
|
*/
|
||||||
|
|
||||||
|
Accepts.prototype.encoding =
|
||||||
|
Accepts.prototype.encodings = function (encodings_) {
|
||||||
|
var encodings = encodings_
|
||||||
|
|
||||||
|
// support flattened arguments
|
||||||
|
if (encodings && !Array.isArray(encodings)) {
|
||||||
|
encodings = new Array(arguments.length)
|
||||||
|
for (var i = 0; i < encodings.length; i++) {
|
||||||
|
encodings[i] = arguments[i]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// no encodings, return all requested encodings
|
||||||
|
if (!encodings || encodings.length === 0) {
|
||||||
|
return this.negotiator.encodings()
|
||||||
|
}
|
||||||
|
|
||||||
|
return this.negotiator.encodings(encodings)[0] || false
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return accepted charsets or best fit based on `charsets`.
|
||||||
|
*
|
||||||
|
* Given `Accept-Charset: utf-8, iso-8859-1;q=0.2, utf-7;q=0.5`
|
||||||
|
* an array sorted by quality is returned:
|
||||||
|
*
|
||||||
|
* ['utf-8', 'utf-7', 'iso-8859-1']
|
||||||
|
*
|
||||||
|
* @param {String|Array} charsets...
|
||||||
|
* @return {String|Array}
|
||||||
|
* @public
|
||||||
|
*/
|
||||||
|
|
||||||
|
Accepts.prototype.charset =
|
||||||
|
Accepts.prototype.charsets = function (charsets_) {
|
||||||
|
var charsets = charsets_
|
||||||
|
|
||||||
|
// support flattened arguments
|
||||||
|
if (charsets && !Array.isArray(charsets)) {
|
||||||
|
charsets = new Array(arguments.length)
|
||||||
|
for (var i = 0; i < charsets.length; i++) {
|
||||||
|
charsets[i] = arguments[i]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// no charsets, return all requested charsets
|
||||||
|
if (!charsets || charsets.length === 0) {
|
||||||
|
return this.negotiator.charsets()
|
||||||
|
}
|
||||||
|
|
||||||
|
return this.negotiator.charsets(charsets)[0] || false
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return accepted languages or best fit based on `langs`.
|
||||||
|
*
|
||||||
|
* Given `Accept-Language: en;q=0.8, es, pt`
|
||||||
|
* an array sorted by quality is returned:
|
||||||
|
*
|
||||||
|
* ['es', 'pt', 'en']
|
||||||
|
*
|
||||||
|
* @param {String|Array} langs...
|
||||||
|
* @return {Array|String}
|
||||||
|
* @public
|
||||||
|
*/
|
||||||
|
|
||||||
|
Accepts.prototype.lang =
|
||||||
|
Accepts.prototype.langs =
|
||||||
|
Accepts.prototype.language =
|
||||||
|
Accepts.prototype.languages = function (languages_) {
|
||||||
|
var languages = languages_
|
||||||
|
|
||||||
|
// support flattened arguments
|
||||||
|
if (languages && !Array.isArray(languages)) {
|
||||||
|
languages = new Array(arguments.length)
|
||||||
|
for (var i = 0; i < languages.length; i++) {
|
||||||
|
languages[i] = arguments[i]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// no languages, return all requested languages
|
||||||
|
if (!languages || languages.length === 0) {
|
||||||
|
return this.negotiator.languages()
|
||||||
|
}
|
||||||
|
|
||||||
|
return this.negotiator.languages(languages)[0] || false
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert extnames to mime.
|
||||||
|
*
|
||||||
|
* @param {String} type
|
||||||
|
* @return {String}
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
|
||||||
|
function extToMime (type) {
|
||||||
|
return type.indexOf('/') === -1
|
||||||
|
? mime.lookup(type)
|
||||||
|
: type
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if mime is valid.
|
||||||
|
*
|
||||||
|
* @param {String} type
|
||||||
|
* @return {String}
|
||||||
|
* @private
|
||||||
|
*/
|
||||||
|
|
||||||
|
function validMime (type) {
|
||||||
|
return typeof type === 'string'
|
||||||
|
}
|
89
node_modules/accepts/package.json
generated
vendored
Normal file
89
node_modules/accepts/package.json
generated
vendored
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
{
|
||||||
|
"_args": [
|
||||||
|
[
|
||||||
|
"accepts@1.3.7",
|
||||||
|
"/home/rui/code/personal/dijkstra-app/backend-dijkstra"
|
||||||
|
]
|
||||||
|
],
|
||||||
|
"_from": "accepts@1.3.7",
|
||||||
|
"_id": "accepts@1.3.7",
|
||||||
|
"_inBundle": false,
|
||||||
|
"_integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==",
|
||||||
|
"_location": "/accepts",
|
||||||
|
"_phantomChildren": {},
|
||||||
|
"_requested": {
|
||||||
|
"type": "version",
|
||||||
|
"registry": true,
|
||||||
|
"raw": "accepts@1.3.7",
|
||||||
|
"name": "accepts",
|
||||||
|
"escapedName": "accepts",
|
||||||
|
"rawSpec": "1.3.7",
|
||||||
|
"saveSpec": null,
|
||||||
|
"fetchSpec": "1.3.7"
|
||||||
|
},
|
||||||
|
"_requiredBy": [
|
||||||
|
"/express"
|
||||||
|
],
|
||||||
|
"_resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz",
|
||||||
|
"_spec": "1.3.7",
|
||||||
|
"_where": "/home/rui/code/personal/dijkstra-app/backend-dijkstra",
|
||||||
|
"bugs": {
|
||||||
|
"url": "https://github.com/jshttp/accepts/issues"
|
||||||
|
},
|
||||||
|
"contributors": [
|
||||||
|
{
|
||||||
|
"name": "Douglas Christopher Wilson",
|
||||||
|
"email": "doug@somethingdoug.com"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Jonathan Ong",
|
||||||
|
"email": "me@jongleberry.com",
|
||||||
|
"url": "http://jongleberry.com"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"dependencies": {
|
||||||
|
"mime-types": "~2.1.24",
|
||||||
|
"negotiator": "0.6.2"
|
||||||
|
},
|
||||||
|
"description": "Higher-level content negotiation",
|
||||||
|
"devDependencies": {
|
||||||
|
"deep-equal": "1.0.1",
|
||||||
|
"eslint": "5.16.0",
|
||||||
|
"eslint-config-standard": "12.0.0",
|
||||||
|
"eslint-plugin-import": "2.17.2",
|
||||||
|
"eslint-plugin-markdown": "1.0.0",
|
||||||
|
"eslint-plugin-node": "8.0.1",
|
||||||
|
"eslint-plugin-promise": "4.1.1",
|
||||||
|
"eslint-plugin-standard": "4.0.0",
|
||||||
|
"mocha": "6.1.4",
|
||||||
|
"nyc": "14.0.0"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": ">= 0.6"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"LICENSE",
|
||||||
|
"HISTORY.md",
|
||||||
|
"index.js"
|
||||||
|
],
|
||||||
|
"homepage": "https://github.com/jshttp/accepts#readme",
|
||||||
|
"keywords": [
|
||||||
|
"content",
|
||||||
|
"negotiation",
|
||||||
|
"accept",
|
||||||
|
"accepts"
|
||||||
|
],
|
||||||
|
"license": "MIT",
|
||||||
|
"name": "accepts",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git+https://github.com/jshttp/accepts.git"
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"lint": "eslint --plugin markdown --ext js,md .",
|
||||||
|
"test": "mocha --reporter spec --check-leaks --bail test/",
|
||||||
|
"test-cov": "nyc --reporter=html --reporter=text npm test",
|
||||||
|
"test-travis": "nyc --reporter=text npm test"
|
||||||
|
},
|
||||||
|
"version": "1.3.7"
|
||||||
|
}
|
20
node_modules/ajv/.tonic_example.js
generated
vendored
Normal file
20
node_modules/ajv/.tonic_example.js
generated
vendored
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
var Ajv = require('ajv');
|
||||||
|
var ajv = new Ajv({allErrors: true});
|
||||||
|
|
||||||
|
var schema = {
|
||||||
|
"properties": {
|
||||||
|
"foo": { "type": "string" },
|
||||||
|
"bar": { "type": "number", "maximum": 3 }
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var validate = ajv.compile(schema);
|
||||||
|
|
||||||
|
test({"foo": "abc", "bar": 2});
|
||||||
|
test({"foo": 2, "bar": 4});
|
||||||
|
|
||||||
|
function test(data) {
|
||||||
|
var valid = validate(data);
|
||||||
|
if (valid) console.log('Valid!');
|
||||||
|
else console.log('Invalid: ' + ajv.errorsText(validate.errors));
|
||||||
|
}
|
22
node_modules/ajv/LICENSE
generated
vendored
Normal file
22
node_modules/ajv/LICENSE
generated
vendored
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
The MIT License (MIT)
|
||||||
|
|
||||||
|
Copyright (c) 2015-2017 Evgeny Poberezkin
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
||||||
|
|
1380
node_modules/ajv/README.md
generated
vendored
Normal file
1380
node_modules/ajv/README.md
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
7163
node_modules/ajv/dist/ajv.bundle.js
generated
vendored
Normal file
7163
node_modules/ajv/dist/ajv.bundle.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
3
node_modules/ajv/dist/ajv.min.js
generated
vendored
Normal file
3
node_modules/ajv/dist/ajv.min.js
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
1
node_modules/ajv/dist/ajv.min.js.map
generated
vendored
Normal file
1
node_modules/ajv/dist/ajv.min.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
391
node_modules/ajv/lib/ajv.d.ts
generated
vendored
Normal file
391
node_modules/ajv/lib/ajv.d.ts
generated
vendored
Normal file
@ -0,0 +1,391 @@
|
|||||||
|
declare var ajv: {
|
||||||
|
(options?: ajv.Options): ajv.Ajv;
|
||||||
|
new(options?: ajv.Options): ajv.Ajv;
|
||||||
|
ValidationError: typeof AjvErrors.ValidationError;
|
||||||
|
MissingRefError: typeof AjvErrors.MissingRefError;
|
||||||
|
$dataMetaSchema: object;
|
||||||
|
}
|
||||||
|
|
||||||
|
declare namespace AjvErrors {
|
||||||
|
class ValidationError extends Error {
|
||||||
|
constructor(errors: Array<ajv.ErrorObject>);
|
||||||
|
|
||||||
|
message: string;
|
||||||
|
errors: Array<ajv.ErrorObject>;
|
||||||
|
ajv: true;
|
||||||
|
validation: true;
|
||||||
|
}
|
||||||
|
|
||||||
|
class MissingRefError extends Error {
|
||||||
|
constructor(baseId: string, ref: string, message?: string);
|
||||||
|
static message: (baseId: string, ref: string) => string;
|
||||||
|
|
||||||
|
message: string;
|
||||||
|
missingRef: string;
|
||||||
|
missingSchema: string;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
declare namespace ajv {
|
||||||
|
type ValidationError = AjvErrors.ValidationError;
|
||||||
|
|
||||||
|
type MissingRefError = AjvErrors.MissingRefError;
|
||||||
|
|
||||||
|
interface Ajv {
|
||||||
|
/**
|
||||||
|
* Validate data using schema
|
||||||
|
* Schema will be compiled and cached (using serialized JSON as key, [fast-json-stable-stringify](https://github.com/epoberezkin/fast-json-stable-stringify) is used to serialize by default).
|
||||||
|
* @param {string|object|Boolean} schemaKeyRef key, ref or schema object
|
||||||
|
* @param {Any} data to be validated
|
||||||
|
* @return {Boolean} validation result. Errors from the last validation will be available in `ajv.errors` (and also in compiled schema: `schema.errors`).
|
||||||
|
*/
|
||||||
|
validate(schemaKeyRef: object | string | boolean, data: any): boolean | PromiseLike<any>;
|
||||||
|
/**
|
||||||
|
* Create validating function for passed schema.
|
||||||
|
* @param {object|Boolean} schema schema object
|
||||||
|
* @return {Function} validating function
|
||||||
|
*/
|
||||||
|
compile(schema: object | boolean): ValidateFunction;
|
||||||
|
/**
|
||||||
|
* Creates validating function for passed schema with asynchronous loading of missing schemas.
|
||||||
|
* `loadSchema` option should be a function that accepts schema uri and node-style callback.
|
||||||
|
* @this Ajv
|
||||||
|
* @param {object|Boolean} schema schema object
|
||||||
|
* @param {Boolean} meta optional true to compile meta-schema; this parameter can be skipped
|
||||||
|
* @param {Function} callback optional node-style callback, it is always called with 2 parameters: error (or null) and validating function.
|
||||||
|
* @return {PromiseLike<ValidateFunction>} validating function
|
||||||
|
*/
|
||||||
|
compileAsync(schema: object | boolean, meta?: Boolean, callback?: (err: Error, validate: ValidateFunction) => any): PromiseLike<ValidateFunction>;
|
||||||
|
/**
|
||||||
|
* Adds schema to the instance.
|
||||||
|
* @param {object|Array} schema schema or array of schemas. If array is passed, `key` and other parameters will be ignored.
|
||||||
|
* @param {string} key Optional schema key. Can be passed to `validate` method instead of schema object or id/ref. One schema per instance can have empty `id` and `key`.
|
||||||
|
* @return {Ajv} this for method chaining
|
||||||
|
*/
|
||||||
|
addSchema(schema: Array<object> | object, key?: string): Ajv;
|
||||||
|
/**
|
||||||
|
* Add schema that will be used to validate other schemas
|
||||||
|
* options in META_IGNORE_OPTIONS are alway set to false
|
||||||
|
* @param {object} schema schema object
|
||||||
|
* @param {string} key optional schema key
|
||||||
|
* @return {Ajv} this for method chaining
|
||||||
|
*/
|
||||||
|
addMetaSchema(schema: object, key?: string): Ajv;
|
||||||
|
/**
|
||||||
|
* Validate schema
|
||||||
|
* @param {object|Boolean} schema schema to validate
|
||||||
|
* @return {Boolean} true if schema is valid
|
||||||
|
*/
|
||||||
|
validateSchema(schema: object | boolean): boolean;
|
||||||
|
/**
|
||||||
|
* Get compiled schema from the instance by `key` or `ref`.
|
||||||
|
* @param {string} keyRef `key` that was passed to `addSchema` or full schema reference (`schema.id` or resolved id).
|
||||||
|
* @return {Function} schema validating function (with property `schema`).
|
||||||
|
*/
|
||||||
|
getSchema(keyRef: string): ValidateFunction;
|
||||||
|
/**
|
||||||
|
* Remove cached schema(s).
|
||||||
|
* If no parameter is passed all schemas but meta-schemas are removed.
|
||||||
|
* If RegExp is passed all schemas with key/id matching pattern but meta-schemas are removed.
|
||||||
|
* Even if schema is referenced by other schemas it still can be removed as other schemas have local references.
|
||||||
|
* @param {string|object|RegExp|Boolean} schemaKeyRef key, ref, pattern to match key/ref or schema object
|
||||||
|
* @return {Ajv} this for method chaining
|
||||||
|
*/
|
||||||
|
removeSchema(schemaKeyRef?: object | string | RegExp | boolean): Ajv;
|
||||||
|
/**
|
||||||
|
* Add custom format
|
||||||
|
* @param {string} name format name
|
||||||
|
* @param {string|RegExp|Function} format string is converted to RegExp; function should return boolean (true when valid)
|
||||||
|
* @return {Ajv} this for method chaining
|
||||||
|
*/
|
||||||
|
addFormat(name: string, format: FormatValidator | FormatDefinition): Ajv;
|
||||||
|
/**
|
||||||
|
* Define custom keyword
|
||||||
|
* @this Ajv
|
||||||
|
* @param {string} keyword custom keyword, should be a valid identifier, should be different from all standard, custom and macro keywords.
|
||||||
|
* @param {object} definition keyword definition object with properties `type` (type(s) which the keyword applies to), `validate` or `compile`.
|
||||||
|
* @return {Ajv} this for method chaining
|
||||||
|
*/
|
||||||
|
addKeyword(keyword: string, definition: KeywordDefinition): Ajv;
|
||||||
|
/**
|
||||||
|
* Get keyword definition
|
||||||
|
* @this Ajv
|
||||||
|
* @param {string} keyword pre-defined or custom keyword.
|
||||||
|
* @return {object|Boolean} custom keyword definition, `true` if it is a predefined keyword, `false` otherwise.
|
||||||
|
*/
|
||||||
|
getKeyword(keyword: string): object | boolean;
|
||||||
|
/**
|
||||||
|
* Remove keyword
|
||||||
|
* @this Ajv
|
||||||
|
* @param {string} keyword pre-defined or custom keyword.
|
||||||
|
* @return {Ajv} this for method chaining
|
||||||
|
*/
|
||||||
|
removeKeyword(keyword: string): Ajv;
|
||||||
|
/**
|
||||||
|
* Validate keyword
|
||||||
|
* @this Ajv
|
||||||
|
* @param {object} definition keyword definition object
|
||||||
|
* @param {boolean} throwError true to throw exception if definition is invalid
|
||||||
|
* @return {boolean} validation result
|
||||||
|
*/
|
||||||
|
validateKeyword(definition: KeywordDefinition, throwError: boolean): boolean;
|
||||||
|
/**
|
||||||
|
* Convert array of error message objects to string
|
||||||
|
* @param {Array<object>} errors optional array of validation errors, if not passed errors from the instance are used.
|
||||||
|
* @param {object} options optional options with properties `separator` and `dataVar`.
|
||||||
|
* @return {string} human readable string with all errors descriptions
|
||||||
|
*/
|
||||||
|
errorsText(errors?: Array<ErrorObject> | null, options?: ErrorsTextOptions): string;
|
||||||
|
errors?: Array<ErrorObject> | null;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface CustomLogger {
|
||||||
|
log(...args: any[]): any;
|
||||||
|
warn(...args: any[]): any;
|
||||||
|
error(...args: any[]): any;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface ValidateFunction {
|
||||||
|
(
|
||||||
|
data: any,
|
||||||
|
dataPath?: string,
|
||||||
|
parentData?: object | Array<any>,
|
||||||
|
parentDataProperty?: string | number,
|
||||||
|
rootData?: object | Array<any>
|
||||||
|
): boolean | PromiseLike<any>;
|
||||||
|
schema?: object | boolean;
|
||||||
|
errors?: null | Array<ErrorObject>;
|
||||||
|
refs?: object;
|
||||||
|
refVal?: Array<any>;
|
||||||
|
root?: ValidateFunction | object;
|
||||||
|
$async?: true;
|
||||||
|
source?: object;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface Options {
|
||||||
|
$data?: boolean;
|
||||||
|
allErrors?: boolean;
|
||||||
|
verbose?: boolean;
|
||||||
|
jsonPointers?: boolean;
|
||||||
|
uniqueItems?: boolean;
|
||||||
|
unicode?: boolean;
|
||||||
|
format?: string;
|
||||||
|
formats?: object;
|
||||||
|
unknownFormats?: true | string[] | 'ignore';
|
||||||
|
schemas?: Array<object> | object;
|
||||||
|
schemaId?: '$id' | 'id' | 'auto';
|
||||||
|
missingRefs?: true | 'ignore' | 'fail';
|
||||||
|
extendRefs?: true | 'ignore' | 'fail';
|
||||||
|
loadSchema?: (uri: string, cb?: (err: Error, schema: object) => void) => PromiseLike<object | boolean>;
|
||||||
|
removeAdditional?: boolean | 'all' | 'failing';
|
||||||
|
useDefaults?: boolean | 'empty' | 'shared';
|
||||||
|
coerceTypes?: boolean | 'array';
|
||||||
|
strictDefaults?: boolean | 'log';
|
||||||
|
strictKeywords?: boolean | 'log';
|
||||||
|
async?: boolean | string;
|
||||||
|
transpile?: string | ((code: string) => string);
|
||||||
|
meta?: boolean | object;
|
||||||
|
validateSchema?: boolean | 'log';
|
||||||
|
addUsedSchema?: boolean;
|
||||||
|
inlineRefs?: boolean | number;
|
||||||
|
passContext?: boolean;
|
||||||
|
loopRequired?: number;
|
||||||
|
ownProperties?: boolean;
|
||||||
|
multipleOfPrecision?: boolean | number;
|
||||||
|
errorDataPath?: string,
|
||||||
|
messages?: boolean;
|
||||||
|
sourceCode?: boolean;
|
||||||
|
processCode?: (code: string) => string;
|
||||||
|
cache?: object;
|
||||||
|
logger?: CustomLogger | false;
|
||||||
|
nullable?: boolean;
|
||||||
|
serialize?: ((schema: object | boolean) => any) | false;
|
||||||
|
}
|
||||||
|
|
||||||
|
type FormatValidator = string | RegExp | ((data: string) => boolean | PromiseLike<any>);
|
||||||
|
type NumberFormatValidator = ((data: number) => boolean | PromiseLike<any>);
|
||||||
|
|
||||||
|
interface NumberFormatDefinition {
|
||||||
|
type: "number",
|
||||||
|
validate: NumberFormatValidator;
|
||||||
|
compare?: (data1: number, data2: number) => number;
|
||||||
|
async?: boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface StringFormatDefinition {
|
||||||
|
type?: "string",
|
||||||
|
validate: FormatValidator;
|
||||||
|
compare?: (data1: string, data2: string) => number;
|
||||||
|
async?: boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
type FormatDefinition = NumberFormatDefinition | StringFormatDefinition;
|
||||||
|
|
||||||
|
interface KeywordDefinition {
|
||||||
|
type?: string | Array<string>;
|
||||||
|
async?: boolean;
|
||||||
|
$data?: boolean;
|
||||||
|
errors?: boolean | string;
|
||||||
|
metaSchema?: object;
|
||||||
|
// schema: false makes validate not to expect schema (ValidateFunction)
|
||||||
|
schema?: boolean;
|
||||||
|
statements?: boolean;
|
||||||
|
dependencies?: Array<string>;
|
||||||
|
modifying?: boolean;
|
||||||
|
valid?: boolean;
|
||||||
|
// one and only one of the following properties should be present
|
||||||
|
validate?: SchemaValidateFunction | ValidateFunction;
|
||||||
|
compile?: (schema: any, parentSchema: object, it: CompilationContext) => ValidateFunction;
|
||||||
|
macro?: (schema: any, parentSchema: object, it: CompilationContext) => object | boolean;
|
||||||
|
inline?: (it: CompilationContext, keyword: string, schema: any, parentSchema: object) => string;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface CompilationContext {
|
||||||
|
level: number;
|
||||||
|
dataLevel: number;
|
||||||
|
dataPathArr: string[];
|
||||||
|
schema: any;
|
||||||
|
schemaPath: string;
|
||||||
|
baseId: string;
|
||||||
|
async: boolean;
|
||||||
|
opts: Options;
|
||||||
|
formats: {
|
||||||
|
[index: string]: FormatDefinition | undefined;
|
||||||
|
};
|
||||||
|
compositeRule: boolean;
|
||||||
|
validate: (schema: object) => boolean;
|
||||||
|
util: {
|
||||||
|
copy(obj: any, target?: any): any;
|
||||||
|
toHash(source: string[]): { [index: string]: true | undefined };
|
||||||
|
equal(obj: any, target: any): boolean;
|
||||||
|
getProperty(str: string): string;
|
||||||
|
schemaHasRules(schema: object, rules: any): string;
|
||||||
|
escapeQuotes(str: string): string;
|
||||||
|
toQuotedString(str: string): string;
|
||||||
|
getData(jsonPointer: string, dataLevel: number, paths: string[]): string;
|
||||||
|
escapeJsonPointer(str: string): string;
|
||||||
|
unescapeJsonPointer(str: string): string;
|
||||||
|
escapeFragment(str: string): string;
|
||||||
|
unescapeFragment(str: string): string;
|
||||||
|
};
|
||||||
|
self: Ajv;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface SchemaValidateFunction {
|
||||||
|
(
|
||||||
|
schema: any,
|
||||||
|
data: any,
|
||||||
|
parentSchema?: object,
|
||||||
|
dataPath?: string,
|
||||||
|
parentData?: object | Array<any>,
|
||||||
|
parentDataProperty?: string | number,
|
||||||
|
rootData?: object | Array<any>
|
||||||
|
): boolean | PromiseLike<any>;
|
||||||
|
errors?: Array<ErrorObject>;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface ErrorsTextOptions {
|
||||||
|
separator?: string;
|
||||||
|
dataVar?: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface ErrorObject {
|
||||||
|
keyword: string;
|
||||||
|
dataPath: string;
|
||||||
|
schemaPath: string;
|
||||||
|
params: ErrorParameters;
|
||||||
|
// Added to validation errors of propertyNames keyword schema
|
||||||
|
propertyName?: string;
|
||||||
|
// Excluded if messages set to false.
|
||||||
|
message?: string;
|
||||||
|
// These are added with the `verbose` option.
|
||||||
|
schema?: any;
|
||||||
|
parentSchema?: object;
|
||||||
|
data?: any;
|
||||||
|
}
|
||||||
|
|
||||||
|
type ErrorParameters = RefParams | LimitParams | AdditionalPropertiesParams |
|
||||||
|
DependenciesParams | FormatParams | ComparisonParams |
|
||||||
|
MultipleOfParams | PatternParams | RequiredParams |
|
||||||
|
TypeParams | UniqueItemsParams | CustomParams |
|
||||||
|
PatternRequiredParams | PropertyNamesParams |
|
||||||
|
IfParams | SwitchParams | NoParams | EnumParams;
|
||||||
|
|
||||||
|
interface RefParams {
|
||||||
|
ref: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface LimitParams {
|
||||||
|
limit: number;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface AdditionalPropertiesParams {
|
||||||
|
additionalProperty: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface DependenciesParams {
|
||||||
|
property: string;
|
||||||
|
missingProperty: string;
|
||||||
|
depsCount: number;
|
||||||
|
deps: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface FormatParams {
|
||||||
|
format: string
|
||||||
|
}
|
||||||
|
|
||||||
|
interface ComparisonParams {
|
||||||
|
comparison: string;
|
||||||
|
limit: number | string;
|
||||||
|
exclusive: boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface MultipleOfParams {
|
||||||
|
multipleOf: number;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface PatternParams {
|
||||||
|
pattern: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface RequiredParams {
|
||||||
|
missingProperty: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface TypeParams {
|
||||||
|
type: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface UniqueItemsParams {
|
||||||
|
i: number;
|
||||||
|
j: number;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface CustomParams {
|
||||||
|
keyword: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface PatternRequiredParams {
|
||||||
|
missingPattern: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface PropertyNamesParams {
|
||||||
|
propertyName: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface IfParams {
|
||||||
|
failingKeyword: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface SwitchParams {
|
||||||
|
caseIndex: number;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface NoParams { }
|
||||||
|
|
||||||
|
interface EnumParams {
|
||||||
|
allowedValues: Array<any>;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export = ajv;
|
497
node_modules/ajv/lib/ajv.js
generated
vendored
Normal file
497
node_modules/ajv/lib/ajv.js
generated
vendored
Normal file
@ -0,0 +1,497 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var compileSchema = require('./compile')
|
||||||
|
, resolve = require('./compile/resolve')
|
||||||
|
, Cache = require('./cache')
|
||||||
|
, SchemaObject = require('./compile/schema_obj')
|
||||||
|
, stableStringify = require('fast-json-stable-stringify')
|
||||||
|
, formats = require('./compile/formats')
|
||||||
|
, rules = require('./compile/rules')
|
||||||
|
, $dataMetaSchema = require('./data')
|
||||||
|
, util = require('./compile/util');
|
||||||
|
|
||||||
|
module.exports = Ajv;
|
||||||
|
|
||||||
|
Ajv.prototype.validate = validate;
|
||||||
|
Ajv.prototype.compile = compile;
|
||||||
|
Ajv.prototype.addSchema = addSchema;
|
||||||
|
Ajv.prototype.addMetaSchema = addMetaSchema;
|
||||||
|
Ajv.prototype.validateSchema = validateSchema;
|
||||||
|
Ajv.prototype.getSchema = getSchema;
|
||||||
|
Ajv.prototype.removeSchema = removeSchema;
|
||||||
|
Ajv.prototype.addFormat = addFormat;
|
||||||
|
Ajv.prototype.errorsText = errorsText;
|
||||||
|
|
||||||
|
Ajv.prototype._addSchema = _addSchema;
|
||||||
|
Ajv.prototype._compile = _compile;
|
||||||
|
|
||||||
|
Ajv.prototype.compileAsync = require('./compile/async');
|
||||||
|
var customKeyword = require('./keyword');
|
||||||
|
Ajv.prototype.addKeyword = customKeyword.add;
|
||||||
|
Ajv.prototype.getKeyword = customKeyword.get;
|
||||||
|
Ajv.prototype.removeKeyword = customKeyword.remove;
|
||||||
|
Ajv.prototype.validateKeyword = customKeyword.validate;
|
||||||
|
|
||||||
|
var errorClasses = require('./compile/error_classes');
|
||||||
|
Ajv.ValidationError = errorClasses.Validation;
|
||||||
|
Ajv.MissingRefError = errorClasses.MissingRef;
|
||||||
|
Ajv.$dataMetaSchema = $dataMetaSchema;
|
||||||
|
|
||||||
|
var META_SCHEMA_ID = 'http://json-schema.org/draft-07/schema';
|
||||||
|
|
||||||
|
var META_IGNORE_OPTIONS = [ 'removeAdditional', 'useDefaults', 'coerceTypes', 'strictDefaults' ];
|
||||||
|
var META_SUPPORT_DATA = ['/properties'];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates validator instance.
|
||||||
|
* Usage: `Ajv(opts)`
|
||||||
|
* @param {Object} opts optional options
|
||||||
|
* @return {Object} ajv instance
|
||||||
|
*/
|
||||||
|
function Ajv(opts) {
|
||||||
|
if (!(this instanceof Ajv)) return new Ajv(opts);
|
||||||
|
opts = this._opts = util.copy(opts) || {};
|
||||||
|
setLogger(this);
|
||||||
|
this._schemas = {};
|
||||||
|
this._refs = {};
|
||||||
|
this._fragments = {};
|
||||||
|
this._formats = formats(opts.format);
|
||||||
|
|
||||||
|
this._cache = opts.cache || new Cache;
|
||||||
|
this._loadingSchemas = {};
|
||||||
|
this._compilations = [];
|
||||||
|
this.RULES = rules();
|
||||||
|
this._getId = chooseGetId(opts);
|
||||||
|
|
||||||
|
opts.loopRequired = opts.loopRequired || Infinity;
|
||||||
|
if (opts.errorDataPath == 'property') opts._errorDataPathProperty = true;
|
||||||
|
if (opts.serialize === undefined) opts.serialize = stableStringify;
|
||||||
|
this._metaOpts = getMetaSchemaOptions(this);
|
||||||
|
|
||||||
|
if (opts.formats) addInitialFormats(this);
|
||||||
|
addDefaultMetaSchema(this);
|
||||||
|
if (typeof opts.meta == 'object') this.addMetaSchema(opts.meta);
|
||||||
|
if (opts.nullable) this.addKeyword('nullable', {metaSchema: {type: 'boolean'}});
|
||||||
|
addInitialSchemas(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate data using schema
|
||||||
|
* Schema will be compiled and cached (using serialized JSON as key. [fast-json-stable-stringify](https://github.com/epoberezkin/fast-json-stable-stringify) is used to serialize.
|
||||||
|
* @this Ajv
|
||||||
|
* @param {String|Object} schemaKeyRef key, ref or schema object
|
||||||
|
* @param {Any} data to be validated
|
||||||
|
* @return {Boolean} validation result. Errors from the last validation will be available in `ajv.errors` (and also in compiled schema: `schema.errors`).
|
||||||
|
*/
|
||||||
|
function validate(schemaKeyRef, data) {
|
||||||
|
var v;
|
||||||
|
if (typeof schemaKeyRef == 'string') {
|
||||||
|
v = this.getSchema(schemaKeyRef);
|
||||||
|
if (!v) throw new Error('no schema with key or ref "' + schemaKeyRef + '"');
|
||||||
|
} else {
|
||||||
|
var schemaObj = this._addSchema(schemaKeyRef);
|
||||||
|
v = schemaObj.validate || this._compile(schemaObj);
|
||||||
|
}
|
||||||
|
|
||||||
|
var valid = v(data);
|
||||||
|
if (v.$async !== true) this.errors = v.errors;
|
||||||
|
return valid;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create validating function for passed schema.
|
||||||
|
* @this Ajv
|
||||||
|
* @param {Object} schema schema object
|
||||||
|
* @param {Boolean} _meta true if schema is a meta-schema. Used internally to compile meta schemas of custom keywords.
|
||||||
|
* @return {Function} validating function
|
||||||
|
*/
|
||||||
|
function compile(schema, _meta) {
|
||||||
|
var schemaObj = this._addSchema(schema, undefined, _meta);
|
||||||
|
return schemaObj.validate || this._compile(schemaObj);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds schema to the instance.
|
||||||
|
* @this Ajv
|
||||||
|
* @param {Object|Array} schema schema or array of schemas. If array is passed, `key` and other parameters will be ignored.
|
||||||
|
* @param {String} key Optional schema key. Can be passed to `validate` method instead of schema object or id/ref. One schema per instance can have empty `id` and `key`.
|
||||||
|
* @param {Boolean} _skipValidation true to skip schema validation. Used internally, option validateSchema should be used instead.
|
||||||
|
* @param {Boolean} _meta true if schema is a meta-schema. Used internally, addMetaSchema should be used instead.
|
||||||
|
* @return {Ajv} this for method chaining
|
||||||
|
*/
|
||||||
|
function addSchema(schema, key, _skipValidation, _meta) {
|
||||||
|
if (Array.isArray(schema)){
|
||||||
|
for (var i=0; i<schema.length; i++) this.addSchema(schema[i], undefined, _skipValidation, _meta);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
var id = this._getId(schema);
|
||||||
|
if (id !== undefined && typeof id != 'string')
|
||||||
|
throw new Error('schema id must be string');
|
||||||
|
key = resolve.normalizeId(key || id);
|
||||||
|
checkUnique(this, key);
|
||||||
|
this._schemas[key] = this._addSchema(schema, _skipValidation, _meta, true);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add schema that will be used to validate other schemas
|
||||||
|
* options in META_IGNORE_OPTIONS are alway set to false
|
||||||
|
* @this Ajv
|
||||||
|
* @param {Object} schema schema object
|
||||||
|
* @param {String} key optional schema key
|
||||||
|
* @param {Boolean} skipValidation true to skip schema validation, can be used to override validateSchema option for meta-schema
|
||||||
|
* @return {Ajv} this for method chaining
|
||||||
|
*/
|
||||||
|
function addMetaSchema(schema, key, skipValidation) {
|
||||||
|
this.addSchema(schema, key, skipValidation, true);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate schema
|
||||||
|
* @this Ajv
|
||||||
|
* @param {Object} schema schema to validate
|
||||||
|
* @param {Boolean} throwOrLogError pass true to throw (or log) an error if invalid
|
||||||
|
* @return {Boolean} true if schema is valid
|
||||||
|
*/
|
||||||
|
function validateSchema(schema, throwOrLogError) {
|
||||||
|
var $schema = schema.$schema;
|
||||||
|
if ($schema !== undefined && typeof $schema != 'string')
|
||||||
|
throw new Error('$schema must be a string');
|
||||||
|
$schema = $schema || this._opts.defaultMeta || defaultMeta(this);
|
||||||
|
if (!$schema) {
|
||||||
|
this.logger.warn('meta-schema not available');
|
||||||
|
this.errors = null;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
var valid = this.validate($schema, schema);
|
||||||
|
if (!valid && throwOrLogError) {
|
||||||
|
var message = 'schema is invalid: ' + this.errorsText();
|
||||||
|
if (this._opts.validateSchema == 'log') this.logger.error(message);
|
||||||
|
else throw new Error(message);
|
||||||
|
}
|
||||||
|
return valid;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function defaultMeta(self) {
|
||||||
|
var meta = self._opts.meta;
|
||||||
|
self._opts.defaultMeta = typeof meta == 'object'
|
||||||
|
? self._getId(meta) || meta
|
||||||
|
: self.getSchema(META_SCHEMA_ID)
|
||||||
|
? META_SCHEMA_ID
|
||||||
|
: undefined;
|
||||||
|
return self._opts.defaultMeta;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get compiled schema from the instance by `key` or `ref`.
|
||||||
|
* @this Ajv
|
||||||
|
* @param {String} keyRef `key` that was passed to `addSchema` or full schema reference (`schema.id` or resolved id).
|
||||||
|
* @return {Function} schema validating function (with property `schema`).
|
||||||
|
*/
|
||||||
|
function getSchema(keyRef) {
|
||||||
|
var schemaObj = _getSchemaObj(this, keyRef);
|
||||||
|
switch (typeof schemaObj) {
|
||||||
|
case 'object': return schemaObj.validate || this._compile(schemaObj);
|
||||||
|
case 'string': return this.getSchema(schemaObj);
|
||||||
|
case 'undefined': return _getSchemaFragment(this, keyRef);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function _getSchemaFragment(self, ref) {
|
||||||
|
var res = resolve.schema.call(self, { schema: {} }, ref);
|
||||||
|
if (res) {
|
||||||
|
var schema = res.schema
|
||||||
|
, root = res.root
|
||||||
|
, baseId = res.baseId;
|
||||||
|
var v = compileSchema.call(self, schema, root, undefined, baseId);
|
||||||
|
self._fragments[ref] = new SchemaObject({
|
||||||
|
ref: ref,
|
||||||
|
fragment: true,
|
||||||
|
schema: schema,
|
||||||
|
root: root,
|
||||||
|
baseId: baseId,
|
||||||
|
validate: v
|
||||||
|
});
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function _getSchemaObj(self, keyRef) {
|
||||||
|
keyRef = resolve.normalizeId(keyRef);
|
||||||
|
return self._schemas[keyRef] || self._refs[keyRef] || self._fragments[keyRef];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove cached schema(s).
|
||||||
|
* If no parameter is passed all schemas but meta-schemas are removed.
|
||||||
|
* If RegExp is passed all schemas with key/id matching pattern but meta-schemas are removed.
|
||||||
|
* Even if schema is referenced by other schemas it still can be removed as other schemas have local references.
|
||||||
|
* @this Ajv
|
||||||
|
* @param {String|Object|RegExp} schemaKeyRef key, ref, pattern to match key/ref or schema object
|
||||||
|
* @return {Ajv} this for method chaining
|
||||||
|
*/
|
||||||
|
function removeSchema(schemaKeyRef) {
|
||||||
|
if (schemaKeyRef instanceof RegExp) {
|
||||||
|
_removeAllSchemas(this, this._schemas, schemaKeyRef);
|
||||||
|
_removeAllSchemas(this, this._refs, schemaKeyRef);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
switch (typeof schemaKeyRef) {
|
||||||
|
case 'undefined':
|
||||||
|
_removeAllSchemas(this, this._schemas);
|
||||||
|
_removeAllSchemas(this, this._refs);
|
||||||
|
this._cache.clear();
|
||||||
|
return this;
|
||||||
|
case 'string':
|
||||||
|
var schemaObj = _getSchemaObj(this, schemaKeyRef);
|
||||||
|
if (schemaObj) this._cache.del(schemaObj.cacheKey);
|
||||||
|
delete this._schemas[schemaKeyRef];
|
||||||
|
delete this._refs[schemaKeyRef];
|
||||||
|
return this;
|
||||||
|
case 'object':
|
||||||
|
var serialize = this._opts.serialize;
|
||||||
|
var cacheKey = serialize ? serialize(schemaKeyRef) : schemaKeyRef;
|
||||||
|
this._cache.del(cacheKey);
|
||||||
|
var id = this._getId(schemaKeyRef);
|
||||||
|
if (id) {
|
||||||
|
id = resolve.normalizeId(id);
|
||||||
|
delete this._schemas[id];
|
||||||
|
delete this._refs[id];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function _removeAllSchemas(self, schemas, regex) {
|
||||||
|
for (var keyRef in schemas) {
|
||||||
|
var schemaObj = schemas[keyRef];
|
||||||
|
if (!schemaObj.meta && (!regex || regex.test(keyRef))) {
|
||||||
|
self._cache.del(schemaObj.cacheKey);
|
||||||
|
delete schemas[keyRef];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* @this Ajv */
|
||||||
|
function _addSchema(schema, skipValidation, meta, shouldAddSchema) {
|
||||||
|
if (typeof schema != 'object' && typeof schema != 'boolean')
|
||||||
|
throw new Error('schema should be object or boolean');
|
||||||
|
var serialize = this._opts.serialize;
|
||||||
|
var cacheKey = serialize ? serialize(schema) : schema;
|
||||||
|
var cached = this._cache.get(cacheKey);
|
||||||
|
if (cached) return cached;
|
||||||
|
|
||||||
|
shouldAddSchema = shouldAddSchema || this._opts.addUsedSchema !== false;
|
||||||
|
|
||||||
|
var id = resolve.normalizeId(this._getId(schema));
|
||||||
|
if (id && shouldAddSchema) checkUnique(this, id);
|
||||||
|
|
||||||
|
var willValidate = this._opts.validateSchema !== false && !skipValidation;
|
||||||
|
var recursiveMeta;
|
||||||
|
if (willValidate && !(recursiveMeta = id && id == resolve.normalizeId(schema.$schema)))
|
||||||
|
this.validateSchema(schema, true);
|
||||||
|
|
||||||
|
var localRefs = resolve.ids.call(this, schema);
|
||||||
|
|
||||||
|
var schemaObj = new SchemaObject({
|
||||||
|
id: id,
|
||||||
|
schema: schema,
|
||||||
|
localRefs: localRefs,
|
||||||
|
cacheKey: cacheKey,
|
||||||
|
meta: meta
|
||||||
|
});
|
||||||
|
|
||||||
|
if (id[0] != '#' && shouldAddSchema) this._refs[id] = schemaObj;
|
||||||
|
this._cache.put(cacheKey, schemaObj);
|
||||||
|
|
||||||
|
if (willValidate && recursiveMeta) this.validateSchema(schema, true);
|
||||||
|
|
||||||
|
return schemaObj;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* @this Ajv */
|
||||||
|
function _compile(schemaObj, root) {
|
||||||
|
if (schemaObj.compiling) {
|
||||||
|
schemaObj.validate = callValidate;
|
||||||
|
callValidate.schema = schemaObj.schema;
|
||||||
|
callValidate.errors = null;
|
||||||
|
callValidate.root = root ? root : callValidate;
|
||||||
|
if (schemaObj.schema.$async === true)
|
||||||
|
callValidate.$async = true;
|
||||||
|
return callValidate;
|
||||||
|
}
|
||||||
|
schemaObj.compiling = true;
|
||||||
|
|
||||||
|
var currentOpts;
|
||||||
|
if (schemaObj.meta) {
|
||||||
|
currentOpts = this._opts;
|
||||||
|
this._opts = this._metaOpts;
|
||||||
|
}
|
||||||
|
|
||||||
|
var v;
|
||||||
|
try { v = compileSchema.call(this, schemaObj.schema, root, schemaObj.localRefs); }
|
||||||
|
catch(e) {
|
||||||
|
delete schemaObj.validate;
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
finally {
|
||||||
|
schemaObj.compiling = false;
|
||||||
|
if (schemaObj.meta) this._opts = currentOpts;
|
||||||
|
}
|
||||||
|
|
||||||
|
schemaObj.validate = v;
|
||||||
|
schemaObj.refs = v.refs;
|
||||||
|
schemaObj.refVal = v.refVal;
|
||||||
|
schemaObj.root = v.root;
|
||||||
|
return v;
|
||||||
|
|
||||||
|
|
||||||
|
/* @this {*} - custom context, see passContext option */
|
||||||
|
function callValidate() {
|
||||||
|
/* jshint validthis: true */
|
||||||
|
var _validate = schemaObj.validate;
|
||||||
|
var result = _validate.apply(this, arguments);
|
||||||
|
callValidate.errors = _validate.errors;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function chooseGetId(opts) {
|
||||||
|
switch (opts.schemaId) {
|
||||||
|
case 'auto': return _get$IdOrId;
|
||||||
|
case 'id': return _getId;
|
||||||
|
default: return _get$Id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* @this Ajv */
|
||||||
|
function _getId(schema) {
|
||||||
|
if (schema.$id) this.logger.warn('schema $id ignored', schema.$id);
|
||||||
|
return schema.id;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* @this Ajv */
|
||||||
|
function _get$Id(schema) {
|
||||||
|
if (schema.id) this.logger.warn('schema id ignored', schema.id);
|
||||||
|
return schema.$id;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function _get$IdOrId(schema) {
|
||||||
|
if (schema.$id && schema.id && schema.$id != schema.id)
|
||||||
|
throw new Error('schema $id is different from id');
|
||||||
|
return schema.$id || schema.id;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert array of error message objects to string
|
||||||
|
* @this Ajv
|
||||||
|
* @param {Array<Object>} errors optional array of validation errors, if not passed errors from the instance are used.
|
||||||
|
* @param {Object} options optional options with properties `separator` and `dataVar`.
|
||||||
|
* @return {String} human readable string with all errors descriptions
|
||||||
|
*/
|
||||||
|
function errorsText(errors, options) {
|
||||||
|
errors = errors || this.errors;
|
||||||
|
if (!errors) return 'No errors';
|
||||||
|
options = options || {};
|
||||||
|
var separator = options.separator === undefined ? ', ' : options.separator;
|
||||||
|
var dataVar = options.dataVar === undefined ? 'data' : options.dataVar;
|
||||||
|
|
||||||
|
var text = '';
|
||||||
|
for (var i=0; i<errors.length; i++) {
|
||||||
|
var e = errors[i];
|
||||||
|
if (e) text += dataVar + e.dataPath + ' ' + e.message + separator;
|
||||||
|
}
|
||||||
|
return text.slice(0, -separator.length);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add custom format
|
||||||
|
* @this Ajv
|
||||||
|
* @param {String} name format name
|
||||||
|
* @param {String|RegExp|Function} format string is converted to RegExp; function should return boolean (true when valid)
|
||||||
|
* @return {Ajv} this for method chaining
|
||||||
|
*/
|
||||||
|
function addFormat(name, format) {
|
||||||
|
if (typeof format == 'string') format = new RegExp(format);
|
||||||
|
this._formats[name] = format;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function addDefaultMetaSchema(self) {
|
||||||
|
var $dataSchema;
|
||||||
|
if (self._opts.$data) {
|
||||||
|
$dataSchema = require('./refs/data.json');
|
||||||
|
self.addMetaSchema($dataSchema, $dataSchema.$id, true);
|
||||||
|
}
|
||||||
|
if (self._opts.meta === false) return;
|
||||||
|
var metaSchema = require('./refs/json-schema-draft-07.json');
|
||||||
|
if (self._opts.$data) metaSchema = $dataMetaSchema(metaSchema, META_SUPPORT_DATA);
|
||||||
|
self.addMetaSchema(metaSchema, META_SCHEMA_ID, true);
|
||||||
|
self._refs['http://json-schema.org/schema'] = META_SCHEMA_ID;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function addInitialSchemas(self) {
|
||||||
|
var optsSchemas = self._opts.schemas;
|
||||||
|
if (!optsSchemas) return;
|
||||||
|
if (Array.isArray(optsSchemas)) self.addSchema(optsSchemas);
|
||||||
|
else for (var key in optsSchemas) self.addSchema(optsSchemas[key], key);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function addInitialFormats(self) {
|
||||||
|
for (var name in self._opts.formats) {
|
||||||
|
var format = self._opts.formats[name];
|
||||||
|
self.addFormat(name, format);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function checkUnique(self, id) {
|
||||||
|
if (self._schemas[id] || self._refs[id])
|
||||||
|
throw new Error('schema with key or id "' + id + '" already exists');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function getMetaSchemaOptions(self) {
|
||||||
|
var metaOpts = util.copy(self._opts);
|
||||||
|
for (var i=0; i<META_IGNORE_OPTIONS.length; i++)
|
||||||
|
delete metaOpts[META_IGNORE_OPTIONS[i]];
|
||||||
|
return metaOpts;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function setLogger(self) {
|
||||||
|
var logger = self._opts.logger;
|
||||||
|
if (logger === false) {
|
||||||
|
self.logger = {log: noop, warn: noop, error: noop};
|
||||||
|
} else {
|
||||||
|
if (logger === undefined) logger = console;
|
||||||
|
if (!(typeof logger == 'object' && logger.log && logger.warn && logger.error))
|
||||||
|
throw new Error('logger must implement log, warn and error methods');
|
||||||
|
self.logger = logger;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function noop() {}
|
26
node_modules/ajv/lib/cache.js
generated
vendored
Normal file
26
node_modules/ajv/lib/cache.js
generated
vendored
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
|
||||||
|
var Cache = module.exports = function Cache() {
|
||||||
|
this._cache = {};
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
Cache.prototype.put = function Cache_put(key, value) {
|
||||||
|
this._cache[key] = value;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
Cache.prototype.get = function Cache_get(key) {
|
||||||
|
return this._cache[key];
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
Cache.prototype.del = function Cache_del(key) {
|
||||||
|
delete this._cache[key];
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
Cache.prototype.clear = function Cache_clear() {
|
||||||
|
this._cache = {};
|
||||||
|
};
|
90
node_modules/ajv/lib/compile/async.js
generated
vendored
Normal file
90
node_modules/ajv/lib/compile/async.js
generated
vendored
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var MissingRefError = require('./error_classes').MissingRef;
|
||||||
|
|
||||||
|
module.exports = compileAsync;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates validating function for passed schema with asynchronous loading of missing schemas.
|
||||||
|
* `loadSchema` option should be a function that accepts schema uri and returns promise that resolves with the schema.
|
||||||
|
* @this Ajv
|
||||||
|
* @param {Object} schema schema object
|
||||||
|
* @param {Boolean} meta optional true to compile meta-schema; this parameter can be skipped
|
||||||
|
* @param {Function} callback an optional node-style callback, it is called with 2 parameters: error (or null) and validating function.
|
||||||
|
* @return {Promise} promise that resolves with a validating function.
|
||||||
|
*/
|
||||||
|
function compileAsync(schema, meta, callback) {
|
||||||
|
/* eslint no-shadow: 0 */
|
||||||
|
/* global Promise */
|
||||||
|
/* jshint validthis: true */
|
||||||
|
var self = this;
|
||||||
|
if (typeof this._opts.loadSchema != 'function')
|
||||||
|
throw new Error('options.loadSchema should be a function');
|
||||||
|
|
||||||
|
if (typeof meta == 'function') {
|
||||||
|
callback = meta;
|
||||||
|
meta = undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
var p = loadMetaSchemaOf(schema).then(function () {
|
||||||
|
var schemaObj = self._addSchema(schema, undefined, meta);
|
||||||
|
return schemaObj.validate || _compileAsync(schemaObj);
|
||||||
|
});
|
||||||
|
|
||||||
|
if (callback) {
|
||||||
|
p.then(
|
||||||
|
function(v) { callback(null, v); },
|
||||||
|
callback
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return p;
|
||||||
|
|
||||||
|
|
||||||
|
function loadMetaSchemaOf(sch) {
|
||||||
|
var $schema = sch.$schema;
|
||||||
|
return $schema && !self.getSchema($schema)
|
||||||
|
? compileAsync.call(self, { $ref: $schema }, true)
|
||||||
|
: Promise.resolve();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function _compileAsync(schemaObj) {
|
||||||
|
try { return self._compile(schemaObj); }
|
||||||
|
catch(e) {
|
||||||
|
if (e instanceof MissingRefError) return loadMissingSchema(e);
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function loadMissingSchema(e) {
|
||||||
|
var ref = e.missingSchema;
|
||||||
|
if (added(ref)) throw new Error('Schema ' + ref + ' is loaded but ' + e.missingRef + ' cannot be resolved');
|
||||||
|
|
||||||
|
var schemaPromise = self._loadingSchemas[ref];
|
||||||
|
if (!schemaPromise) {
|
||||||
|
schemaPromise = self._loadingSchemas[ref] = self._opts.loadSchema(ref);
|
||||||
|
schemaPromise.then(removePromise, removePromise);
|
||||||
|
}
|
||||||
|
|
||||||
|
return schemaPromise.then(function (sch) {
|
||||||
|
if (!added(ref)) {
|
||||||
|
return loadMetaSchemaOf(sch).then(function () {
|
||||||
|
if (!added(ref)) self.addSchema(sch, ref, undefined, meta);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}).then(function() {
|
||||||
|
return _compileAsync(schemaObj);
|
||||||
|
});
|
||||||
|
|
||||||
|
function removePromise() {
|
||||||
|
delete self._loadingSchemas[ref];
|
||||||
|
}
|
||||||
|
|
||||||
|
function added(ref) {
|
||||||
|
return self._refs[ref] || self._schemas[ref];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
5
node_modules/ajv/lib/compile/equal.js
generated
vendored
Normal file
5
node_modules/ajv/lib/compile/equal.js
generated
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
// do NOT remove this file - it would break pre-compiled schemas
|
||||||
|
// https://github.com/epoberezkin/ajv/issues/889
|
||||||
|
module.exports = require('fast-deep-equal');
|
34
node_modules/ajv/lib/compile/error_classes.js
generated
vendored
Normal file
34
node_modules/ajv/lib/compile/error_classes.js
generated
vendored
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var resolve = require('./resolve');
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
Validation: errorSubclass(ValidationError),
|
||||||
|
MissingRef: errorSubclass(MissingRefError)
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
function ValidationError(errors) {
|
||||||
|
this.message = 'validation failed';
|
||||||
|
this.errors = errors;
|
||||||
|
this.ajv = this.validation = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
MissingRefError.message = function (baseId, ref) {
|
||||||
|
return 'can\'t resolve reference ' + ref + ' from id ' + baseId;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
function MissingRefError(baseId, ref, message) {
|
||||||
|
this.message = message || MissingRefError.message(baseId, ref);
|
||||||
|
this.missingRef = resolve.url(baseId, ref);
|
||||||
|
this.missingSchema = resolve.normalizeId(resolve.fullPath(this.missingRef));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function errorSubclass(Subclass) {
|
||||||
|
Subclass.prototype = Object.create(Error.prototype);
|
||||||
|
Subclass.prototype.constructor = Subclass;
|
||||||
|
return Subclass;
|
||||||
|
}
|
149
node_modules/ajv/lib/compile/formats.js
generated
vendored
Normal file
149
node_modules/ajv/lib/compile/formats.js
generated
vendored
Normal file
@ -0,0 +1,149 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var util = require('./util');
|
||||||
|
|
||||||
|
var DATE = /^(\d\d\d\d)-(\d\d)-(\d\d)$/;
|
||||||
|
var DAYS = [0,31,28,31,30,31,30,31,31,30,31,30,31];
|
||||||
|
var TIME = /^(\d\d):(\d\d):(\d\d)(\.\d+)?(z|[+-]\d\d(?::?\d\d)?)?$/i;
|
||||||
|
var HOSTNAME = /^[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[-0-9a-z]{0,61}[0-9a-z])?)*$/i;
|
||||||
|
var URI = /^(?:[a-z][a-z0-9+\-.]*:)(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|[Vv][0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)|(?:[a-z0-9\-._~!$&'()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*|\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)?|(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)(?:\?(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i;
|
||||||
|
var URIREF = /^(?:[a-z][a-z0-9+\-.]*:)?(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|[Vv][0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)|(?:[a-z0-9\-._~!$&'"()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*|\/(?:(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*)?|(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*)?(?:\?(?:[a-z0-9\-._~!$&'"()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'"()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i;
|
||||||
|
// uri-template: https://tools.ietf.org/html/rfc6570
|
||||||
|
var URITEMPLATE = /^(?:(?:[^\x00-\x20"'<>%\\^`{|}]|%[0-9a-f]{2})|\{[+#./;?&=,!@|]?(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?(?:,(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?)*\})*$/i;
|
||||||
|
// For the source: https://gist.github.com/dperini/729294
|
||||||
|
// For test cases: https://mathiasbynens.be/demo/url-regex
|
||||||
|
// @todo Delete current URL in favour of the commented out URL rule when this issue is fixed https://github.com/eslint/eslint/issues/7983.
|
||||||
|
// var URL = /^(?:(?:https?|ftp):\/\/)(?:\S+(?::\S*)?@)?(?:(?!10(?:\.\d{1,3}){3})(?!127(?:\.\d{1,3}){3})(?!169\.254(?:\.\d{1,3}){2})(?!192\.168(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u{00a1}-\u{ffff}0-9]+-?)*[a-z\u{00a1}-\u{ffff}0-9]+)(?:\.(?:[a-z\u{00a1}-\u{ffff}0-9]+-?)*[a-z\u{00a1}-\u{ffff}0-9]+)*(?:\.(?:[a-z\u{00a1}-\u{ffff}]{2,})))(?::\d{2,5})?(?:\/[^\s]*)?$/iu;
|
||||||
|
var URL = /^(?:(?:http[s\u017F]?|ftp):\/\/)(?:(?:[\0-\x08\x0E-\x1F!-\x9F\xA1-\u167F\u1681-\u1FFF\u200B-\u2027\u202A-\u202E\u2030-\u205E\u2060-\u2FFF\u3001-\uD7FF\uE000-\uFEFE\uFF00-\uFFFF]|[\uD800-\uDBFF][\uDC00-\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+(?::(?:[\0-\x08\x0E-\x1F!-\x9F\xA1-\u167F\u1681-\u1FFF\u200B-\u2027\u202A-\u202E\u2030-\u205E\u2060-\u2FFF\u3001-\uD7FF\uE000-\uFEFE\uFF00-\uFFFF]|[\uD800-\uDBFF][\uDC00-\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])*)?@)?(?:(?!10(?:\.[0-9]{1,3}){3})(?!127(?:\.[0-9]{1,3}){3})(?!169\.254(?:\.[0-9]{1,3}){2})(?!192\.168(?:\.[0-9]{1,3}){2})(?!172\.(?:1[6-9]|2[0-9]|3[01])(?:\.[0-9]{1,3}){2})(?:[1-9][0-9]?|1[0-9][0-9]|2[01][0-9]|22[0-3])(?:\.(?:1?[0-9]{1,2}|2[0-4][0-9]|25[0-5])){2}(?:\.(?:[1-9][0-9]?|1[0-9][0-9]|2[0-4][0-9]|25[0-4]))|(?:(?:(?:[0-9KSa-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+-?)*(?:[0-9KSa-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+)(?:\.(?:(?:[0-9KSa-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+-?)*(?:[0-9KSa-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+)*(?:\.(?:(?:[KSa-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF]){2,})))(?::[0-9]{2,5})?(?:\/(?:[\0-\x08\x0E-\x1F!-\x9F\xA1-\u167F\u1681-\u1FFF\u200B-\u2027\u202A-\u202E\u2030-\u205E\u2060-\u2FFF\u3001-\uD7FF\uE000-\uFEFE\uFF00-\uFFFF]|[\uD800-\uDBFF][\uDC00-\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])*)?$/i;
|
||||||
|
var UUID = /^(?:urn:uuid:)?[0-9a-f]{8}-(?:[0-9a-f]{4}-){3}[0-9a-f]{12}$/i;
|
||||||
|
var JSON_POINTER = /^(?:\/(?:[^~/]|~0|~1)*)*$/;
|
||||||
|
var JSON_POINTER_URI_FRAGMENT = /^#(?:\/(?:[a-z0-9_\-.!$&'()*+,;:=@]|%[0-9a-f]{2}|~0|~1)*)*$/i;
|
||||||
|
var RELATIVE_JSON_POINTER = /^(?:0|[1-9][0-9]*)(?:#|(?:\/(?:[^~/]|~0|~1)*)*)$/;
|
||||||
|
|
||||||
|
|
||||||
|
module.exports = formats;
|
||||||
|
|
||||||
|
function formats(mode) {
|
||||||
|
mode = mode == 'full' ? 'full' : 'fast';
|
||||||
|
return util.copy(formats[mode]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
formats.fast = {
|
||||||
|
// date: http://tools.ietf.org/html/rfc3339#section-5.6
|
||||||
|
date: /^\d\d\d\d-[0-1]\d-[0-3]\d$/,
|
||||||
|
// date-time: http://tools.ietf.org/html/rfc3339#section-5.6
|
||||||
|
time: /^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)?$/i,
|
||||||
|
'date-time': /^\d\d\d\d-[0-1]\d-[0-3]\d[t\s](?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)$/i,
|
||||||
|
// uri: https://github.com/mafintosh/is-my-json-valid/blob/master/formats.js
|
||||||
|
uri: /^(?:[a-z][a-z0-9+-.]*:)(?:\/?\/)?[^\s]*$/i,
|
||||||
|
'uri-reference': /^(?:(?:[a-z][a-z0-9+-.]*:)?\/?\/)?(?:[^\\\s#][^\s#]*)?(?:#[^\\\s]*)?$/i,
|
||||||
|
'uri-template': URITEMPLATE,
|
||||||
|
url: URL,
|
||||||
|
// email (sources from jsen validator):
|
||||||
|
// http://stackoverflow.com/questions/201323/using-a-regular-expression-to-validate-an-email-address#answer-8829363
|
||||||
|
// http://www.w3.org/TR/html5/forms.html#valid-e-mail-address (search for 'willful violation')
|
||||||
|
email: /^[a-z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?)*$/i,
|
||||||
|
hostname: HOSTNAME,
|
||||||
|
// optimized https://www.safaribooksonline.com/library/view/regular-expressions-cookbook/9780596802837/ch07s16.html
|
||||||
|
ipv4: /^(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)$/,
|
||||||
|
// optimized http://stackoverflow.com/questions/53497/regular-expression-that-matches-valid-ipv6-addresses
|
||||||
|
ipv6: /^\s*(?:(?:(?:[0-9a-f]{1,4}:){7}(?:[0-9a-f]{1,4}|:))|(?:(?:[0-9a-f]{1,4}:){6}(?::[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){5}(?:(?:(?::[0-9a-f]{1,4}){1,2})|:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){4}(?:(?:(?::[0-9a-f]{1,4}){1,3})|(?:(?::[0-9a-f]{1,4})?:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){3}(?:(?:(?::[0-9a-f]{1,4}){1,4})|(?:(?::[0-9a-f]{1,4}){0,2}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){2}(?:(?:(?::[0-9a-f]{1,4}){1,5})|(?:(?::[0-9a-f]{1,4}){0,3}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){1}(?:(?:(?::[0-9a-f]{1,4}){1,6})|(?:(?::[0-9a-f]{1,4}){0,4}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?::(?:(?:(?::[0-9a-f]{1,4}){1,7})|(?:(?::[0-9a-f]{1,4}){0,5}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(?:%.+)?\s*$/i,
|
||||||
|
regex: regex,
|
||||||
|
// uuid: http://tools.ietf.org/html/rfc4122
|
||||||
|
uuid: UUID,
|
||||||
|
// JSON-pointer: https://tools.ietf.org/html/rfc6901
|
||||||
|
// uri fragment: https://tools.ietf.org/html/rfc3986#appendix-A
|
||||||
|
'json-pointer': JSON_POINTER,
|
||||||
|
'json-pointer-uri-fragment': JSON_POINTER_URI_FRAGMENT,
|
||||||
|
// relative JSON-pointer: http://tools.ietf.org/html/draft-luff-relative-json-pointer-00
|
||||||
|
'relative-json-pointer': RELATIVE_JSON_POINTER
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
formats.full = {
|
||||||
|
date: date,
|
||||||
|
time: time,
|
||||||
|
'date-time': date_time,
|
||||||
|
uri: uri,
|
||||||
|
'uri-reference': URIREF,
|
||||||
|
'uri-template': URITEMPLATE,
|
||||||
|
url: URL,
|
||||||
|
email: /^[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?$/i,
|
||||||
|
hostname: hostname,
|
||||||
|
ipv4: /^(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)$/,
|
||||||
|
ipv6: /^\s*(?:(?:(?:[0-9a-f]{1,4}:){7}(?:[0-9a-f]{1,4}|:))|(?:(?:[0-9a-f]{1,4}:){6}(?::[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){5}(?:(?:(?::[0-9a-f]{1,4}){1,2})|:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){4}(?:(?:(?::[0-9a-f]{1,4}){1,3})|(?:(?::[0-9a-f]{1,4})?:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){3}(?:(?:(?::[0-9a-f]{1,4}){1,4})|(?:(?::[0-9a-f]{1,4}){0,2}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){2}(?:(?:(?::[0-9a-f]{1,4}){1,5})|(?:(?::[0-9a-f]{1,4}){0,3}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){1}(?:(?:(?::[0-9a-f]{1,4}){1,6})|(?:(?::[0-9a-f]{1,4}){0,4}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?::(?:(?:(?::[0-9a-f]{1,4}){1,7})|(?:(?::[0-9a-f]{1,4}){0,5}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(?:%.+)?\s*$/i,
|
||||||
|
regex: regex,
|
||||||
|
uuid: UUID,
|
||||||
|
'json-pointer': JSON_POINTER,
|
||||||
|
'json-pointer-uri-fragment': JSON_POINTER_URI_FRAGMENT,
|
||||||
|
'relative-json-pointer': RELATIVE_JSON_POINTER
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
function isLeapYear(year) {
|
||||||
|
// https://tools.ietf.org/html/rfc3339#appendix-C
|
||||||
|
return year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function date(str) {
|
||||||
|
// full-date from http://tools.ietf.org/html/rfc3339#section-5.6
|
||||||
|
var matches = str.match(DATE);
|
||||||
|
if (!matches) return false;
|
||||||
|
|
||||||
|
var year = +matches[1];
|
||||||
|
var month = +matches[2];
|
||||||
|
var day = +matches[3];
|
||||||
|
|
||||||
|
return month >= 1 && month <= 12 && day >= 1 &&
|
||||||
|
day <= (month == 2 && isLeapYear(year) ? 29 : DAYS[month]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function time(str, full) {
|
||||||
|
var matches = str.match(TIME);
|
||||||
|
if (!matches) return false;
|
||||||
|
|
||||||
|
var hour = matches[1];
|
||||||
|
var minute = matches[2];
|
||||||
|
var second = matches[3];
|
||||||
|
var timeZone = matches[5];
|
||||||
|
return ((hour <= 23 && minute <= 59 && second <= 59) ||
|
||||||
|
(hour == 23 && minute == 59 && second == 60)) &&
|
||||||
|
(!full || timeZone);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var DATE_TIME_SEPARATOR = /t|\s/i;
|
||||||
|
function date_time(str) {
|
||||||
|
// http://tools.ietf.org/html/rfc3339#section-5.6
|
||||||
|
var dateTime = str.split(DATE_TIME_SEPARATOR);
|
||||||
|
return dateTime.length == 2 && date(dateTime[0]) && time(dateTime[1], true);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function hostname(str) {
|
||||||
|
// https://tools.ietf.org/html/rfc1034#section-3.5
|
||||||
|
// https://tools.ietf.org/html/rfc1123#section-2
|
||||||
|
return str.length <= 255 && HOSTNAME.test(str);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var NOT_URI_FRAGMENT = /\/|:/;
|
||||||
|
function uri(str) {
|
||||||
|
// http://jmrware.com/articles/2009/uri_regexp/URI_regex.html + optional protocol + required "."
|
||||||
|
return NOT_URI_FRAGMENT.test(str) && URI.test(str);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var Z_ANCHOR = /[^\\]\\Z/;
|
||||||
|
function regex(str) {
|
||||||
|
if (Z_ANCHOR.test(str)) return false;
|
||||||
|
try {
|
||||||
|
new RegExp(str);
|
||||||
|
return true;
|
||||||
|
} catch(e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
387
node_modules/ajv/lib/compile/index.js
generated
vendored
Normal file
387
node_modules/ajv/lib/compile/index.js
generated
vendored
Normal file
@ -0,0 +1,387 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var resolve = require('./resolve')
|
||||||
|
, util = require('./util')
|
||||||
|
, errorClasses = require('./error_classes')
|
||||||
|
, stableStringify = require('fast-json-stable-stringify');
|
||||||
|
|
||||||
|
var validateGenerator = require('../dotjs/validate');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Functions below are used inside compiled validations function
|
||||||
|
*/
|
||||||
|
|
||||||
|
var ucs2length = util.ucs2length;
|
||||||
|
var equal = require('fast-deep-equal');
|
||||||
|
|
||||||
|
// this error is thrown by async schemas to return validation errors via exception
|
||||||
|
var ValidationError = errorClasses.Validation;
|
||||||
|
|
||||||
|
module.exports = compile;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Compiles schema to validation function
|
||||||
|
* @this Ajv
|
||||||
|
* @param {Object} schema schema object
|
||||||
|
* @param {Object} root object with information about the root schema for this schema
|
||||||
|
* @param {Object} localRefs the hash of local references inside the schema (created by resolve.id), used for inline resolution
|
||||||
|
* @param {String} baseId base ID for IDs in the schema
|
||||||
|
* @return {Function} validation function
|
||||||
|
*/
|
||||||
|
function compile(schema, root, localRefs, baseId) {
|
||||||
|
/* jshint validthis: true, evil: true */
|
||||||
|
/* eslint no-shadow: 0 */
|
||||||
|
var self = this
|
||||||
|
, opts = this._opts
|
||||||
|
, refVal = [ undefined ]
|
||||||
|
, refs = {}
|
||||||
|
, patterns = []
|
||||||
|
, patternsHash = {}
|
||||||
|
, defaults = []
|
||||||
|
, defaultsHash = {}
|
||||||
|
, customRules = [];
|
||||||
|
|
||||||
|
root = root || { schema: schema, refVal: refVal, refs: refs };
|
||||||
|
|
||||||
|
var c = checkCompiling.call(this, schema, root, baseId);
|
||||||
|
var compilation = this._compilations[c.index];
|
||||||
|
if (c.compiling) return (compilation.callValidate = callValidate);
|
||||||
|
|
||||||
|
var formats = this._formats;
|
||||||
|
var RULES = this.RULES;
|
||||||
|
|
||||||
|
try {
|
||||||
|
var v = localCompile(schema, root, localRefs, baseId);
|
||||||
|
compilation.validate = v;
|
||||||
|
var cv = compilation.callValidate;
|
||||||
|
if (cv) {
|
||||||
|
cv.schema = v.schema;
|
||||||
|
cv.errors = null;
|
||||||
|
cv.refs = v.refs;
|
||||||
|
cv.refVal = v.refVal;
|
||||||
|
cv.root = v.root;
|
||||||
|
cv.$async = v.$async;
|
||||||
|
if (opts.sourceCode) cv.source = v.source;
|
||||||
|
}
|
||||||
|
return v;
|
||||||
|
} finally {
|
||||||
|
endCompiling.call(this, schema, root, baseId);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* @this {*} - custom context, see passContext option */
|
||||||
|
function callValidate() {
|
||||||
|
/* jshint validthis: true */
|
||||||
|
var validate = compilation.validate;
|
||||||
|
var result = validate.apply(this, arguments);
|
||||||
|
callValidate.errors = validate.errors;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
function localCompile(_schema, _root, localRefs, baseId) {
|
||||||
|
var isRoot = !_root || (_root && _root.schema == _schema);
|
||||||
|
if (_root.schema != root.schema)
|
||||||
|
return compile.call(self, _schema, _root, localRefs, baseId);
|
||||||
|
|
||||||
|
var $async = _schema.$async === true;
|
||||||
|
|
||||||
|
var sourceCode = validateGenerator({
|
||||||
|
isTop: true,
|
||||||
|
schema: _schema,
|
||||||
|
isRoot: isRoot,
|
||||||
|
baseId: baseId,
|
||||||
|
root: _root,
|
||||||
|
schemaPath: '',
|
||||||
|
errSchemaPath: '#',
|
||||||
|
errorPath: '""',
|
||||||
|
MissingRefError: errorClasses.MissingRef,
|
||||||
|
RULES: RULES,
|
||||||
|
validate: validateGenerator,
|
||||||
|
util: util,
|
||||||
|
resolve: resolve,
|
||||||
|
resolveRef: resolveRef,
|
||||||
|
usePattern: usePattern,
|
||||||
|
useDefault: useDefault,
|
||||||
|
useCustomRule: useCustomRule,
|
||||||
|
opts: opts,
|
||||||
|
formats: formats,
|
||||||
|
logger: self.logger,
|
||||||
|
self: self
|
||||||
|
});
|
||||||
|
|
||||||
|
sourceCode = vars(refVal, refValCode) + vars(patterns, patternCode)
|
||||||
|
+ vars(defaults, defaultCode) + vars(customRules, customRuleCode)
|
||||||
|
+ sourceCode;
|
||||||
|
|
||||||
|
if (opts.processCode) sourceCode = opts.processCode(sourceCode);
|
||||||
|
// console.log('\n\n\n *** \n', JSON.stringify(sourceCode));
|
||||||
|
var validate;
|
||||||
|
try {
|
||||||
|
var makeValidate = new Function(
|
||||||
|
'self',
|
||||||
|
'RULES',
|
||||||
|
'formats',
|
||||||
|
'root',
|
||||||
|
'refVal',
|
||||||
|
'defaults',
|
||||||
|
'customRules',
|
||||||
|
'equal',
|
||||||
|
'ucs2length',
|
||||||
|
'ValidationError',
|
||||||
|
sourceCode
|
||||||
|
);
|
||||||
|
|
||||||
|
validate = makeValidate(
|
||||||
|
self,
|
||||||
|
RULES,
|
||||||
|
formats,
|
||||||
|
root,
|
||||||
|
refVal,
|
||||||
|
defaults,
|
||||||
|
customRules,
|
||||||
|
equal,
|
||||||
|
ucs2length,
|
||||||
|
ValidationError
|
||||||
|
);
|
||||||
|
|
||||||
|
refVal[0] = validate;
|
||||||
|
} catch(e) {
|
||||||
|
self.logger.error('Error compiling schema, function code:', sourceCode);
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
|
||||||
|
validate.schema = _schema;
|
||||||
|
validate.errors = null;
|
||||||
|
validate.refs = refs;
|
||||||
|
validate.refVal = refVal;
|
||||||
|
validate.root = isRoot ? validate : _root;
|
||||||
|
if ($async) validate.$async = true;
|
||||||
|
if (opts.sourceCode === true) {
|
||||||
|
validate.source = {
|
||||||
|
code: sourceCode,
|
||||||
|
patterns: patterns,
|
||||||
|
defaults: defaults
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
return validate;
|
||||||
|
}
|
||||||
|
|
||||||
|
function resolveRef(baseId, ref, isRoot) {
|
||||||
|
ref = resolve.url(baseId, ref);
|
||||||
|
var refIndex = refs[ref];
|
||||||
|
var _refVal, refCode;
|
||||||
|
if (refIndex !== undefined) {
|
||||||
|
_refVal = refVal[refIndex];
|
||||||
|
refCode = 'refVal[' + refIndex + ']';
|
||||||
|
return resolvedRef(_refVal, refCode);
|
||||||
|
}
|
||||||
|
if (!isRoot && root.refs) {
|
||||||
|
var rootRefId = root.refs[ref];
|
||||||
|
if (rootRefId !== undefined) {
|
||||||
|
_refVal = root.refVal[rootRefId];
|
||||||
|
refCode = addLocalRef(ref, _refVal);
|
||||||
|
return resolvedRef(_refVal, refCode);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
refCode = addLocalRef(ref);
|
||||||
|
var v = resolve.call(self, localCompile, root, ref);
|
||||||
|
if (v === undefined) {
|
||||||
|
var localSchema = localRefs && localRefs[ref];
|
||||||
|
if (localSchema) {
|
||||||
|
v = resolve.inlineRef(localSchema, opts.inlineRefs)
|
||||||
|
? localSchema
|
||||||
|
: compile.call(self, localSchema, root, localRefs, baseId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (v === undefined) {
|
||||||
|
removeLocalRef(ref);
|
||||||
|
} else {
|
||||||
|
replaceLocalRef(ref, v);
|
||||||
|
return resolvedRef(v, refCode);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function addLocalRef(ref, v) {
|
||||||
|
var refId = refVal.length;
|
||||||
|
refVal[refId] = v;
|
||||||
|
refs[ref] = refId;
|
||||||
|
return 'refVal' + refId;
|
||||||
|
}
|
||||||
|
|
||||||
|
function removeLocalRef(ref) {
|
||||||
|
delete refs[ref];
|
||||||
|
}
|
||||||
|
|
||||||
|
function replaceLocalRef(ref, v) {
|
||||||
|
var refId = refs[ref];
|
||||||
|
refVal[refId] = v;
|
||||||
|
}
|
||||||
|
|
||||||
|
function resolvedRef(refVal, code) {
|
||||||
|
return typeof refVal == 'object' || typeof refVal == 'boolean'
|
||||||
|
? { code: code, schema: refVal, inline: true }
|
||||||
|
: { code: code, $async: refVal && !!refVal.$async };
|
||||||
|
}
|
||||||
|
|
||||||
|
function usePattern(regexStr) {
|
||||||
|
var index = patternsHash[regexStr];
|
||||||
|
if (index === undefined) {
|
||||||
|
index = patternsHash[regexStr] = patterns.length;
|
||||||
|
patterns[index] = regexStr;
|
||||||
|
}
|
||||||
|
return 'pattern' + index;
|
||||||
|
}
|
||||||
|
|
||||||
|
function useDefault(value) {
|
||||||
|
switch (typeof value) {
|
||||||
|
case 'boolean':
|
||||||
|
case 'number':
|
||||||
|
return '' + value;
|
||||||
|
case 'string':
|
||||||
|
return util.toQuotedString(value);
|
||||||
|
case 'object':
|
||||||
|
if (value === null) return 'null';
|
||||||
|
var valueStr = stableStringify(value);
|
||||||
|
var index = defaultsHash[valueStr];
|
||||||
|
if (index === undefined) {
|
||||||
|
index = defaultsHash[valueStr] = defaults.length;
|
||||||
|
defaults[index] = value;
|
||||||
|
}
|
||||||
|
return 'default' + index;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function useCustomRule(rule, schema, parentSchema, it) {
|
||||||
|
if (self._opts.validateSchema !== false) {
|
||||||
|
var deps = rule.definition.dependencies;
|
||||||
|
if (deps && !deps.every(function(keyword) {
|
||||||
|
return Object.prototype.hasOwnProperty.call(parentSchema, keyword);
|
||||||
|
}))
|
||||||
|
throw new Error('parent schema must have all required keywords: ' + deps.join(','));
|
||||||
|
|
||||||
|
var validateSchema = rule.definition.validateSchema;
|
||||||
|
if (validateSchema) {
|
||||||
|
var valid = validateSchema(schema);
|
||||||
|
if (!valid) {
|
||||||
|
var message = 'keyword schema is invalid: ' + self.errorsText(validateSchema.errors);
|
||||||
|
if (self._opts.validateSchema == 'log') self.logger.error(message);
|
||||||
|
else throw new Error(message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var compile = rule.definition.compile
|
||||||
|
, inline = rule.definition.inline
|
||||||
|
, macro = rule.definition.macro;
|
||||||
|
|
||||||
|
var validate;
|
||||||
|
if (compile) {
|
||||||
|
validate = compile.call(self, schema, parentSchema, it);
|
||||||
|
} else if (macro) {
|
||||||
|
validate = macro.call(self, schema, parentSchema, it);
|
||||||
|
if (opts.validateSchema !== false) self.validateSchema(validate, true);
|
||||||
|
} else if (inline) {
|
||||||
|
validate = inline.call(self, it, rule.keyword, schema, parentSchema);
|
||||||
|
} else {
|
||||||
|
validate = rule.definition.validate;
|
||||||
|
if (!validate) return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (validate === undefined)
|
||||||
|
throw new Error('custom keyword "' + rule.keyword + '"failed to compile');
|
||||||
|
|
||||||
|
var index = customRules.length;
|
||||||
|
customRules[index] = validate;
|
||||||
|
|
||||||
|
return {
|
||||||
|
code: 'customRule' + index,
|
||||||
|
validate: validate
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks if the schema is currently compiled
|
||||||
|
* @this Ajv
|
||||||
|
* @param {Object} schema schema to compile
|
||||||
|
* @param {Object} root root object
|
||||||
|
* @param {String} baseId base schema ID
|
||||||
|
* @return {Object} object with properties "index" (compilation index) and "compiling" (boolean)
|
||||||
|
*/
|
||||||
|
function checkCompiling(schema, root, baseId) {
|
||||||
|
/* jshint validthis: true */
|
||||||
|
var index = compIndex.call(this, schema, root, baseId);
|
||||||
|
if (index >= 0) return { index: index, compiling: true };
|
||||||
|
index = this._compilations.length;
|
||||||
|
this._compilations[index] = {
|
||||||
|
schema: schema,
|
||||||
|
root: root,
|
||||||
|
baseId: baseId
|
||||||
|
};
|
||||||
|
return { index: index, compiling: false };
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes the schema from the currently compiled list
|
||||||
|
* @this Ajv
|
||||||
|
* @param {Object} schema schema to compile
|
||||||
|
* @param {Object} root root object
|
||||||
|
* @param {String} baseId base schema ID
|
||||||
|
*/
|
||||||
|
function endCompiling(schema, root, baseId) {
|
||||||
|
/* jshint validthis: true */
|
||||||
|
var i = compIndex.call(this, schema, root, baseId);
|
||||||
|
if (i >= 0) this._compilations.splice(i, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Index of schema compilation in the currently compiled list
|
||||||
|
* @this Ajv
|
||||||
|
* @param {Object} schema schema to compile
|
||||||
|
* @param {Object} root root object
|
||||||
|
* @param {String} baseId base schema ID
|
||||||
|
* @return {Integer} compilation index
|
||||||
|
*/
|
||||||
|
function compIndex(schema, root, baseId) {
|
||||||
|
/* jshint validthis: true */
|
||||||
|
for (var i=0; i<this._compilations.length; i++) {
|
||||||
|
var c = this._compilations[i];
|
||||||
|
if (c.schema == schema && c.root == root && c.baseId == baseId) return i;
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function patternCode(i, patterns) {
|
||||||
|
return 'var pattern' + i + ' = new RegExp(' + util.toQuotedString(patterns[i]) + ');';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function defaultCode(i) {
|
||||||
|
return 'var default' + i + ' = defaults[' + i + '];';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function refValCode(i, refVal) {
|
||||||
|
return refVal[i] === undefined ? '' : 'var refVal' + i + ' = refVal[' + i + '];';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function customRuleCode(i) {
|
||||||
|
return 'var customRule' + i + ' = customRules[' + i + '];';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function vars(arr, statement) {
|
||||||
|
if (!arr.length) return '';
|
||||||
|
var code = '';
|
||||||
|
for (var i=0; i<arr.length; i++)
|
||||||
|
code += statement(i, arr);
|
||||||
|
return code;
|
||||||
|
}
|
270
node_modules/ajv/lib/compile/resolve.js
generated
vendored
Normal file
270
node_modules/ajv/lib/compile/resolve.js
generated
vendored
Normal file
@ -0,0 +1,270 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var URI = require('uri-js')
|
||||||
|
, equal = require('fast-deep-equal')
|
||||||
|
, util = require('./util')
|
||||||
|
, SchemaObject = require('./schema_obj')
|
||||||
|
, traverse = require('json-schema-traverse');
|
||||||
|
|
||||||
|
module.exports = resolve;
|
||||||
|
|
||||||
|
resolve.normalizeId = normalizeId;
|
||||||
|
resolve.fullPath = getFullPath;
|
||||||
|
resolve.url = resolveUrl;
|
||||||
|
resolve.ids = resolveIds;
|
||||||
|
resolve.inlineRef = inlineRef;
|
||||||
|
resolve.schema = resolveSchema;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* [resolve and compile the references ($ref)]
|
||||||
|
* @this Ajv
|
||||||
|
* @param {Function} compile reference to schema compilation funciton (localCompile)
|
||||||
|
* @param {Object} root object with information about the root schema for the current schema
|
||||||
|
* @param {String} ref reference to resolve
|
||||||
|
* @return {Object|Function} schema object (if the schema can be inlined) or validation function
|
||||||
|
*/
|
||||||
|
function resolve(compile, root, ref) {
|
||||||
|
/* jshint validthis: true */
|
||||||
|
var refVal = this._refs[ref];
|
||||||
|
if (typeof refVal == 'string') {
|
||||||
|
if (this._refs[refVal]) refVal = this._refs[refVal];
|
||||||
|
else return resolve.call(this, compile, root, refVal);
|
||||||
|
}
|
||||||
|
|
||||||
|
refVal = refVal || this._schemas[ref];
|
||||||
|
if (refVal instanceof SchemaObject) {
|
||||||
|
return inlineRef(refVal.schema, this._opts.inlineRefs)
|
||||||
|
? refVal.schema
|
||||||
|
: refVal.validate || this._compile(refVal);
|
||||||
|
}
|
||||||
|
|
||||||
|
var res = resolveSchema.call(this, root, ref);
|
||||||
|
var schema, v, baseId;
|
||||||
|
if (res) {
|
||||||
|
schema = res.schema;
|
||||||
|
root = res.root;
|
||||||
|
baseId = res.baseId;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (schema instanceof SchemaObject) {
|
||||||
|
v = schema.validate || compile.call(this, schema.schema, root, undefined, baseId);
|
||||||
|
} else if (schema !== undefined) {
|
||||||
|
v = inlineRef(schema, this._opts.inlineRefs)
|
||||||
|
? schema
|
||||||
|
: compile.call(this, schema, root, undefined, baseId);
|
||||||
|
}
|
||||||
|
|
||||||
|
return v;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resolve schema, its root and baseId
|
||||||
|
* @this Ajv
|
||||||
|
* @param {Object} root root object with properties schema, refVal, refs
|
||||||
|
* @param {String} ref reference to resolve
|
||||||
|
* @return {Object} object with properties schema, root, baseId
|
||||||
|
*/
|
||||||
|
function resolveSchema(root, ref) {
|
||||||
|
/* jshint validthis: true */
|
||||||
|
var p = URI.parse(ref)
|
||||||
|
, refPath = _getFullPath(p)
|
||||||
|
, baseId = getFullPath(this._getId(root.schema));
|
||||||
|
if (Object.keys(root.schema).length === 0 || refPath !== baseId) {
|
||||||
|
var id = normalizeId(refPath);
|
||||||
|
var refVal = this._refs[id];
|
||||||
|
if (typeof refVal == 'string') {
|
||||||
|
return resolveRecursive.call(this, root, refVal, p);
|
||||||
|
} else if (refVal instanceof SchemaObject) {
|
||||||
|
if (!refVal.validate) this._compile(refVal);
|
||||||
|
root = refVal;
|
||||||
|
} else {
|
||||||
|
refVal = this._schemas[id];
|
||||||
|
if (refVal instanceof SchemaObject) {
|
||||||
|
if (!refVal.validate) this._compile(refVal);
|
||||||
|
if (id == normalizeId(ref))
|
||||||
|
return { schema: refVal, root: root, baseId: baseId };
|
||||||
|
root = refVal;
|
||||||
|
} else {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!root.schema) return;
|
||||||
|
baseId = getFullPath(this._getId(root.schema));
|
||||||
|
}
|
||||||
|
return getJsonPointer.call(this, p, baseId, root.schema, root);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* @this Ajv */
|
||||||
|
function resolveRecursive(root, ref, parsedRef) {
|
||||||
|
/* jshint validthis: true */
|
||||||
|
var res = resolveSchema.call(this, root, ref);
|
||||||
|
if (res) {
|
||||||
|
var schema = res.schema;
|
||||||
|
var baseId = res.baseId;
|
||||||
|
root = res.root;
|
||||||
|
var id = this._getId(schema);
|
||||||
|
if (id) baseId = resolveUrl(baseId, id);
|
||||||
|
return getJsonPointer.call(this, parsedRef, baseId, schema, root);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var PREVENT_SCOPE_CHANGE = util.toHash(['properties', 'patternProperties', 'enum', 'dependencies', 'definitions']);
|
||||||
|
/* @this Ajv */
|
||||||
|
function getJsonPointer(parsedRef, baseId, schema, root) {
|
||||||
|
/* jshint validthis: true */
|
||||||
|
parsedRef.fragment = parsedRef.fragment || '';
|
||||||
|
if (parsedRef.fragment.slice(0,1) != '/') return;
|
||||||
|
var parts = parsedRef.fragment.split('/');
|
||||||
|
|
||||||
|
for (var i = 1; i < parts.length; i++) {
|
||||||
|
var part = parts[i];
|
||||||
|
if (part) {
|
||||||
|
part = util.unescapeFragment(part);
|
||||||
|
schema = schema[part];
|
||||||
|
if (schema === undefined) break;
|
||||||
|
var id;
|
||||||
|
if (!PREVENT_SCOPE_CHANGE[part]) {
|
||||||
|
id = this._getId(schema);
|
||||||
|
if (id) baseId = resolveUrl(baseId, id);
|
||||||
|
if (schema.$ref) {
|
||||||
|
var $ref = resolveUrl(baseId, schema.$ref);
|
||||||
|
var res = resolveSchema.call(this, root, $ref);
|
||||||
|
if (res) {
|
||||||
|
schema = res.schema;
|
||||||
|
root = res.root;
|
||||||
|
baseId = res.baseId;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (schema !== undefined && schema !== root.schema)
|
||||||
|
return { schema: schema, root: root, baseId: baseId };
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var SIMPLE_INLINED = util.toHash([
|
||||||
|
'type', 'format', 'pattern',
|
||||||
|
'maxLength', 'minLength',
|
||||||
|
'maxProperties', 'minProperties',
|
||||||
|
'maxItems', 'minItems',
|
||||||
|
'maximum', 'minimum',
|
||||||
|
'uniqueItems', 'multipleOf',
|
||||||
|
'required', 'enum'
|
||||||
|
]);
|
||||||
|
function inlineRef(schema, limit) {
|
||||||
|
if (limit === false) return false;
|
||||||
|
if (limit === undefined || limit === true) return checkNoRef(schema);
|
||||||
|
else if (limit) return countKeys(schema) <= limit;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function checkNoRef(schema) {
|
||||||
|
var item;
|
||||||
|
if (Array.isArray(schema)) {
|
||||||
|
for (var i=0; i<schema.length; i++) {
|
||||||
|
item = schema[i];
|
||||||
|
if (typeof item == 'object' && !checkNoRef(item)) return false;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (var key in schema) {
|
||||||
|
if (key == '$ref') return false;
|
||||||
|
item = schema[key];
|
||||||
|
if (typeof item == 'object' && !checkNoRef(item)) return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function countKeys(schema) {
|
||||||
|
var count = 0, item;
|
||||||
|
if (Array.isArray(schema)) {
|
||||||
|
for (var i=0; i<schema.length; i++) {
|
||||||
|
item = schema[i];
|
||||||
|
if (typeof item == 'object') count += countKeys(item);
|
||||||
|
if (count == Infinity) return Infinity;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (var key in schema) {
|
||||||
|
if (key == '$ref') return Infinity;
|
||||||
|
if (SIMPLE_INLINED[key]) {
|
||||||
|
count++;
|
||||||
|
} else {
|
||||||
|
item = schema[key];
|
||||||
|
if (typeof item == 'object') count += countKeys(item) + 1;
|
||||||
|
if (count == Infinity) return Infinity;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function getFullPath(id, normalize) {
|
||||||
|
if (normalize !== false) id = normalizeId(id);
|
||||||
|
var p = URI.parse(id);
|
||||||
|
return _getFullPath(p);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function _getFullPath(p) {
|
||||||
|
return URI.serialize(p).split('#')[0] + '#';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var TRAILING_SLASH_HASH = /#\/?$/;
|
||||||
|
function normalizeId(id) {
|
||||||
|
return id ? id.replace(TRAILING_SLASH_HASH, '') : '';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function resolveUrl(baseId, id) {
|
||||||
|
id = normalizeId(id);
|
||||||
|
return URI.resolve(baseId, id);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* @this Ajv */
|
||||||
|
function resolveIds(schema) {
|
||||||
|
var schemaId = normalizeId(this._getId(schema));
|
||||||
|
var baseIds = {'': schemaId};
|
||||||
|
var fullPaths = {'': getFullPath(schemaId, false)};
|
||||||
|
var localRefs = {};
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
traverse(schema, {allKeys: true}, function(sch, jsonPtr, rootSchema, parentJsonPtr, parentKeyword, parentSchema, keyIndex) {
|
||||||
|
if (jsonPtr === '') return;
|
||||||
|
var id = self._getId(sch);
|
||||||
|
var baseId = baseIds[parentJsonPtr];
|
||||||
|
var fullPath = fullPaths[parentJsonPtr] + '/' + parentKeyword;
|
||||||
|
if (keyIndex !== undefined)
|
||||||
|
fullPath += '/' + (typeof keyIndex == 'number' ? keyIndex : util.escapeFragment(keyIndex));
|
||||||
|
|
||||||
|
if (typeof id == 'string') {
|
||||||
|
id = baseId = normalizeId(baseId ? URI.resolve(baseId, id) : id);
|
||||||
|
|
||||||
|
var refVal = self._refs[id];
|
||||||
|
if (typeof refVal == 'string') refVal = self._refs[refVal];
|
||||||
|
if (refVal && refVal.schema) {
|
||||||
|
if (!equal(sch, refVal.schema))
|
||||||
|
throw new Error('id "' + id + '" resolves to more than one schema');
|
||||||
|
} else if (id != normalizeId(fullPath)) {
|
||||||
|
if (id[0] == '#') {
|
||||||
|
if (localRefs[id] && !equal(sch, localRefs[id]))
|
||||||
|
throw new Error('id "' + id + '" resolves to more than one schema');
|
||||||
|
localRefs[id] = sch;
|
||||||
|
} else {
|
||||||
|
self._refs[id] = fullPath;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
baseIds[jsonPtr] = baseId;
|
||||||
|
fullPaths[jsonPtr] = fullPath;
|
||||||
|
});
|
||||||
|
|
||||||
|
return localRefs;
|
||||||
|
}
|
66
node_modules/ajv/lib/compile/rules.js
generated
vendored
Normal file
66
node_modules/ajv/lib/compile/rules.js
generated
vendored
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var ruleModules = require('../dotjs')
|
||||||
|
, toHash = require('./util').toHash;
|
||||||
|
|
||||||
|
module.exports = function rules() {
|
||||||
|
var RULES = [
|
||||||
|
{ type: 'number',
|
||||||
|
rules: [ { 'maximum': ['exclusiveMaximum'] },
|
||||||
|
{ 'minimum': ['exclusiveMinimum'] }, 'multipleOf', 'format'] },
|
||||||
|
{ type: 'string',
|
||||||
|
rules: [ 'maxLength', 'minLength', 'pattern', 'format' ] },
|
||||||
|
{ type: 'array',
|
||||||
|
rules: [ 'maxItems', 'minItems', 'items', 'contains', 'uniqueItems' ] },
|
||||||
|
{ type: 'object',
|
||||||
|
rules: [ 'maxProperties', 'minProperties', 'required', 'dependencies', 'propertyNames',
|
||||||
|
{ 'properties': ['additionalProperties', 'patternProperties'] } ] },
|
||||||
|
{ rules: [ '$ref', 'const', 'enum', 'not', 'anyOf', 'oneOf', 'allOf', 'if' ] }
|
||||||
|
];
|
||||||
|
|
||||||
|
var ALL = [ 'type', '$comment' ];
|
||||||
|
var KEYWORDS = [
|
||||||
|
'$schema', '$id', 'id', '$data', '$async', 'title',
|
||||||
|
'description', 'default', 'definitions',
|
||||||
|
'examples', 'readOnly', 'writeOnly',
|
||||||
|
'contentMediaType', 'contentEncoding',
|
||||||
|
'additionalItems', 'then', 'else'
|
||||||
|
];
|
||||||
|
var TYPES = [ 'number', 'integer', 'string', 'array', 'object', 'boolean', 'null' ];
|
||||||
|
RULES.all = toHash(ALL);
|
||||||
|
RULES.types = toHash(TYPES);
|
||||||
|
|
||||||
|
RULES.forEach(function (group) {
|
||||||
|
group.rules = group.rules.map(function (keyword) {
|
||||||
|
var implKeywords;
|
||||||
|
if (typeof keyword == 'object') {
|
||||||
|
var key = Object.keys(keyword)[0];
|
||||||
|
implKeywords = keyword[key];
|
||||||
|
keyword = key;
|
||||||
|
implKeywords.forEach(function (k) {
|
||||||
|
ALL.push(k);
|
||||||
|
RULES.all[k] = true;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
ALL.push(keyword);
|
||||||
|
var rule = RULES.all[keyword] = {
|
||||||
|
keyword: keyword,
|
||||||
|
code: ruleModules[keyword],
|
||||||
|
implements: implKeywords
|
||||||
|
};
|
||||||
|
return rule;
|
||||||
|
});
|
||||||
|
|
||||||
|
RULES.all.$comment = {
|
||||||
|
keyword: '$comment',
|
||||||
|
code: ruleModules.$comment
|
||||||
|
};
|
||||||
|
|
||||||
|
if (group.type) RULES.types[group.type] = group;
|
||||||
|
});
|
||||||
|
|
||||||
|
RULES.keywords = toHash(ALL.concat(KEYWORDS));
|
||||||
|
RULES.custom = {};
|
||||||
|
|
||||||
|
return RULES;
|
||||||
|
};
|
9
node_modules/ajv/lib/compile/schema_obj.js
generated
vendored
Normal file
9
node_modules/ajv/lib/compile/schema_obj.js
generated
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var util = require('./util');
|
||||||
|
|
||||||
|
module.exports = SchemaObject;
|
||||||
|
|
||||||
|
function SchemaObject(obj) {
|
||||||
|
util.copy(obj, this);
|
||||||
|
}
|
20
node_modules/ajv/lib/compile/ucs2length.js
generated
vendored
Normal file
20
node_modules/ajv/lib/compile/ucs2length.js
generated
vendored
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
// https://mathiasbynens.be/notes/javascript-encoding
|
||||||
|
// https://github.com/bestiejs/punycode.js - punycode.ucs2.decode
|
||||||
|
module.exports = function ucs2length(str) {
|
||||||
|
var length = 0
|
||||||
|
, len = str.length
|
||||||
|
, pos = 0
|
||||||
|
, value;
|
||||||
|
while (pos < len) {
|
||||||
|
length++;
|
||||||
|
value = str.charCodeAt(pos++);
|
||||||
|
if (value >= 0xD800 && value <= 0xDBFF && pos < len) {
|
||||||
|
// high surrogate, and there is a next character
|
||||||
|
value = str.charCodeAt(pos);
|
||||||
|
if ((value & 0xFC00) == 0xDC00) pos++; // low surrogate
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return length;
|
||||||
|
};
|
274
node_modules/ajv/lib/compile/util.js
generated
vendored
Normal file
274
node_modules/ajv/lib/compile/util.js
generated
vendored
Normal file
@ -0,0 +1,274 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
copy: copy,
|
||||||
|
checkDataType: checkDataType,
|
||||||
|
checkDataTypes: checkDataTypes,
|
||||||
|
coerceToTypes: coerceToTypes,
|
||||||
|
toHash: toHash,
|
||||||
|
getProperty: getProperty,
|
||||||
|
escapeQuotes: escapeQuotes,
|
||||||
|
equal: require('fast-deep-equal'),
|
||||||
|
ucs2length: require('./ucs2length'),
|
||||||
|
varOccurences: varOccurences,
|
||||||
|
varReplace: varReplace,
|
||||||
|
cleanUpCode: cleanUpCode,
|
||||||
|
finalCleanUpCode: finalCleanUpCode,
|
||||||
|
schemaHasRules: schemaHasRules,
|
||||||
|
schemaHasRulesExcept: schemaHasRulesExcept,
|
||||||
|
schemaUnknownRules: schemaUnknownRules,
|
||||||
|
toQuotedString: toQuotedString,
|
||||||
|
getPathExpr: getPathExpr,
|
||||||
|
getPath: getPath,
|
||||||
|
getData: getData,
|
||||||
|
unescapeFragment: unescapeFragment,
|
||||||
|
unescapeJsonPointer: unescapeJsonPointer,
|
||||||
|
escapeFragment: escapeFragment,
|
||||||
|
escapeJsonPointer: escapeJsonPointer
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
function copy(o, to) {
|
||||||
|
to = to || {};
|
||||||
|
for (var key in o) to[key] = o[key];
|
||||||
|
return to;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function checkDataType(dataType, data, negate) {
|
||||||
|
var EQUAL = negate ? ' !== ' : ' === '
|
||||||
|
, AND = negate ? ' || ' : ' && '
|
||||||
|
, OK = negate ? '!' : ''
|
||||||
|
, NOT = negate ? '' : '!';
|
||||||
|
switch (dataType) {
|
||||||
|
case 'null': return data + EQUAL + 'null';
|
||||||
|
case 'array': return OK + 'Array.isArray(' + data + ')';
|
||||||
|
case 'object': return '(' + OK + data + AND +
|
||||||
|
'typeof ' + data + EQUAL + '"object"' + AND +
|
||||||
|
NOT + 'Array.isArray(' + data + '))';
|
||||||
|
case 'integer': return '(typeof ' + data + EQUAL + '"number"' + AND +
|
||||||
|
NOT + '(' + data + ' % 1)' +
|
||||||
|
AND + data + EQUAL + data + ')';
|
||||||
|
default: return 'typeof ' + data + EQUAL + '"' + dataType + '"';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function checkDataTypes(dataTypes, data) {
|
||||||
|
switch (dataTypes.length) {
|
||||||
|
case 1: return checkDataType(dataTypes[0], data, true);
|
||||||
|
default:
|
||||||
|
var code = '';
|
||||||
|
var types = toHash(dataTypes);
|
||||||
|
if (types.array && types.object) {
|
||||||
|
code = types.null ? '(': '(!' + data + ' || ';
|
||||||
|
code += 'typeof ' + data + ' !== "object")';
|
||||||
|
delete types.null;
|
||||||
|
delete types.array;
|
||||||
|
delete types.object;
|
||||||
|
}
|
||||||
|
if (types.number) delete types.integer;
|
||||||
|
for (var t in types)
|
||||||
|
code += (code ? ' && ' : '' ) + checkDataType(t, data, true);
|
||||||
|
|
||||||
|
return code;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var COERCE_TO_TYPES = toHash([ 'string', 'number', 'integer', 'boolean', 'null' ]);
|
||||||
|
function coerceToTypes(optionCoerceTypes, dataTypes) {
|
||||||
|
if (Array.isArray(dataTypes)) {
|
||||||
|
var types = [];
|
||||||
|
for (var i=0; i<dataTypes.length; i++) {
|
||||||
|
var t = dataTypes[i];
|
||||||
|
if (COERCE_TO_TYPES[t]) types[types.length] = t;
|
||||||
|
else if (optionCoerceTypes === 'array' && t === 'array') types[types.length] = t;
|
||||||
|
}
|
||||||
|
if (types.length) return types;
|
||||||
|
} else if (COERCE_TO_TYPES[dataTypes]) {
|
||||||
|
return [dataTypes];
|
||||||
|
} else if (optionCoerceTypes === 'array' && dataTypes === 'array') {
|
||||||
|
return ['array'];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function toHash(arr) {
|
||||||
|
var hash = {};
|
||||||
|
for (var i=0; i<arr.length; i++) hash[arr[i]] = true;
|
||||||
|
return hash;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var IDENTIFIER = /^[a-z$_][a-z$_0-9]*$/i;
|
||||||
|
var SINGLE_QUOTE = /'|\\/g;
|
||||||
|
function getProperty(key) {
|
||||||
|
return typeof key == 'number'
|
||||||
|
? '[' + key + ']'
|
||||||
|
: IDENTIFIER.test(key)
|
||||||
|
? '.' + key
|
||||||
|
: "['" + escapeQuotes(key) + "']";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function escapeQuotes(str) {
|
||||||
|
return str.replace(SINGLE_QUOTE, '\\$&')
|
||||||
|
.replace(/\n/g, '\\n')
|
||||||
|
.replace(/\r/g, '\\r')
|
||||||
|
.replace(/\f/g, '\\f')
|
||||||
|
.replace(/\t/g, '\\t');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function varOccurences(str, dataVar) {
|
||||||
|
dataVar += '[^0-9]';
|
||||||
|
var matches = str.match(new RegExp(dataVar, 'g'));
|
||||||
|
return matches ? matches.length : 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function varReplace(str, dataVar, expr) {
|
||||||
|
dataVar += '([^0-9])';
|
||||||
|
expr = expr.replace(/\$/g, '$$$$');
|
||||||
|
return str.replace(new RegExp(dataVar, 'g'), expr + '$1');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var EMPTY_ELSE = /else\s*{\s*}/g
|
||||||
|
, EMPTY_IF_NO_ELSE = /if\s*\([^)]+\)\s*\{\s*\}(?!\s*else)/g
|
||||||
|
, EMPTY_IF_WITH_ELSE = /if\s*\(([^)]+)\)\s*\{\s*\}\s*else(?!\s*if)/g;
|
||||||
|
function cleanUpCode(out) {
|
||||||
|
return out.replace(EMPTY_ELSE, '')
|
||||||
|
.replace(EMPTY_IF_NO_ELSE, '')
|
||||||
|
.replace(EMPTY_IF_WITH_ELSE, 'if (!($1))');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var ERRORS_REGEXP = /[^v.]errors/g
|
||||||
|
, REMOVE_ERRORS = /var errors = 0;|var vErrors = null;|validate.errors = vErrors;/g
|
||||||
|
, REMOVE_ERRORS_ASYNC = /var errors = 0;|var vErrors = null;/g
|
||||||
|
, RETURN_VALID = 'return errors === 0;'
|
||||||
|
, RETURN_TRUE = 'validate.errors = null; return true;'
|
||||||
|
, RETURN_ASYNC = /if \(errors === 0\) return data;\s*else throw new ValidationError\(vErrors\);/
|
||||||
|
, RETURN_DATA_ASYNC = 'return data;'
|
||||||
|
, ROOTDATA_REGEXP = /[^A-Za-z_$]rootData[^A-Za-z0-9_$]/g
|
||||||
|
, REMOVE_ROOTDATA = /if \(rootData === undefined\) rootData = data;/;
|
||||||
|
|
||||||
|
function finalCleanUpCode(out, async) {
|
||||||
|
var matches = out.match(ERRORS_REGEXP);
|
||||||
|
if (matches && matches.length == 2) {
|
||||||
|
out = async
|
||||||
|
? out.replace(REMOVE_ERRORS_ASYNC, '')
|
||||||
|
.replace(RETURN_ASYNC, RETURN_DATA_ASYNC)
|
||||||
|
: out.replace(REMOVE_ERRORS, '')
|
||||||
|
.replace(RETURN_VALID, RETURN_TRUE);
|
||||||
|
}
|
||||||
|
|
||||||
|
matches = out.match(ROOTDATA_REGEXP);
|
||||||
|
if (!matches || matches.length !== 3) return out;
|
||||||
|
return out.replace(REMOVE_ROOTDATA, '');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function schemaHasRules(schema, rules) {
|
||||||
|
if (typeof schema == 'boolean') return !schema;
|
||||||
|
for (var key in schema) if (rules[key]) return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function schemaHasRulesExcept(schema, rules, exceptKeyword) {
|
||||||
|
if (typeof schema == 'boolean') return !schema && exceptKeyword != 'not';
|
||||||
|
for (var key in schema) if (key != exceptKeyword && rules[key]) return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function schemaUnknownRules(schema, rules) {
|
||||||
|
if (typeof schema == 'boolean') return;
|
||||||
|
for (var key in schema) if (!rules[key]) return key;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function toQuotedString(str) {
|
||||||
|
return '\'' + escapeQuotes(str) + '\'';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function getPathExpr(currentPath, expr, jsonPointers, isNumber) {
|
||||||
|
var path = jsonPointers // false by default
|
||||||
|
? '\'/\' + ' + expr + (isNumber ? '' : '.replace(/~/g, \'~0\').replace(/\\//g, \'~1\')')
|
||||||
|
: (isNumber ? '\'[\' + ' + expr + ' + \']\'' : '\'[\\\'\' + ' + expr + ' + \'\\\']\'');
|
||||||
|
return joinPaths(currentPath, path);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function getPath(currentPath, prop, jsonPointers) {
|
||||||
|
var path = jsonPointers // false by default
|
||||||
|
? toQuotedString('/' + escapeJsonPointer(prop))
|
||||||
|
: toQuotedString(getProperty(prop));
|
||||||
|
return joinPaths(currentPath, path);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var JSON_POINTER = /^\/(?:[^~]|~0|~1)*$/;
|
||||||
|
var RELATIVE_JSON_POINTER = /^([0-9]+)(#|\/(?:[^~]|~0|~1)*)?$/;
|
||||||
|
function getData($data, lvl, paths) {
|
||||||
|
var up, jsonPointer, data, matches;
|
||||||
|
if ($data === '') return 'rootData';
|
||||||
|
if ($data[0] == '/') {
|
||||||
|
if (!JSON_POINTER.test($data)) throw new Error('Invalid JSON-pointer: ' + $data);
|
||||||
|
jsonPointer = $data;
|
||||||
|
data = 'rootData';
|
||||||
|
} else {
|
||||||
|
matches = $data.match(RELATIVE_JSON_POINTER);
|
||||||
|
if (!matches) throw new Error('Invalid JSON-pointer: ' + $data);
|
||||||
|
up = +matches[1];
|
||||||
|
jsonPointer = matches[2];
|
||||||
|
if (jsonPointer == '#') {
|
||||||
|
if (up >= lvl) throw new Error('Cannot access property/index ' + up + ' levels up, current level is ' + lvl);
|
||||||
|
return paths[lvl - up];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (up > lvl) throw new Error('Cannot access data ' + up + ' levels up, current level is ' + lvl);
|
||||||
|
data = 'data' + ((lvl - up) || '');
|
||||||
|
if (!jsonPointer) return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
var expr = data;
|
||||||
|
var segments = jsonPointer.split('/');
|
||||||
|
for (var i=0; i<segments.length; i++) {
|
||||||
|
var segment = segments[i];
|
||||||
|
if (segment) {
|
||||||
|
data += getProperty(unescapeJsonPointer(segment));
|
||||||
|
expr += ' && ' + data;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return expr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function joinPaths (a, b) {
|
||||||
|
if (a == '""') return b;
|
||||||
|
return (a + ' + ' + b).replace(/' \+ '/g, '');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function unescapeFragment(str) {
|
||||||
|
return unescapeJsonPointer(decodeURIComponent(str));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function escapeFragment(str) {
|
||||||
|
return encodeURIComponent(escapeJsonPointer(str));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function escapeJsonPointer(str) {
|
||||||
|
return str.replace(/~/g, '~0').replace(/\//g, '~1');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function unescapeJsonPointer(str) {
|
||||||
|
return str.replace(/~1/g, '/').replace(/~0/g, '~');
|
||||||
|
}
|
49
node_modules/ajv/lib/data.js
generated
vendored
Normal file
49
node_modules/ajv/lib/data.js
generated
vendored
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var KEYWORDS = [
|
||||||
|
'multipleOf',
|
||||||
|
'maximum',
|
||||||
|
'exclusiveMaximum',
|
||||||
|
'minimum',
|
||||||
|
'exclusiveMinimum',
|
||||||
|
'maxLength',
|
||||||
|
'minLength',
|
||||||
|
'pattern',
|
||||||
|
'additionalItems',
|
||||||
|
'maxItems',
|
||||||
|
'minItems',
|
||||||
|
'uniqueItems',
|
||||||
|
'maxProperties',
|
||||||
|
'minProperties',
|
||||||
|
'required',
|
||||||
|
'additionalProperties',
|
||||||
|
'enum',
|
||||||
|
'format',
|
||||||
|
'const'
|
||||||
|
];
|
||||||
|
|
||||||
|
module.exports = function (metaSchema, keywordsJsonPointers) {
|
||||||
|
for (var i=0; i<keywordsJsonPointers.length; i++) {
|
||||||
|
metaSchema = JSON.parse(JSON.stringify(metaSchema));
|
||||||
|
var segments = keywordsJsonPointers[i].split('/');
|
||||||
|
var keywords = metaSchema;
|
||||||
|
var j;
|
||||||
|
for (j=1; j<segments.length; j++)
|
||||||
|
keywords = keywords[segments[j]];
|
||||||
|
|
||||||
|
for (j=0; j<KEYWORDS.length; j++) {
|
||||||
|
var key = KEYWORDS[j];
|
||||||
|
var schema = keywords[key];
|
||||||
|
if (schema) {
|
||||||
|
keywords[key] = {
|
||||||
|
anyOf: [
|
||||||
|
schema,
|
||||||
|
{ $ref: 'https://raw.githubusercontent.com/epoberezkin/ajv/master/lib/refs/data.json#' }
|
||||||
|
]
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return metaSchema;
|
||||||
|
};
|
37
node_modules/ajv/lib/definition_schema.js
generated
vendored
Normal file
37
node_modules/ajv/lib/definition_schema.js
generated
vendored
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var metaSchema = require('./refs/json-schema-draft-07.json');
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
$id: 'https://github.com/epoberezkin/ajv/blob/master/lib/definition_schema.js',
|
||||||
|
definitions: {
|
||||||
|
simpleTypes: metaSchema.definitions.simpleTypes
|
||||||
|
},
|
||||||
|
type: 'object',
|
||||||
|
dependencies: {
|
||||||
|
schema: ['validate'],
|
||||||
|
$data: ['validate'],
|
||||||
|
statements: ['inline'],
|
||||||
|
valid: {not: {required: ['macro']}}
|
||||||
|
},
|
||||||
|
properties: {
|
||||||
|
type: metaSchema.properties.type,
|
||||||
|
schema: {type: 'boolean'},
|
||||||
|
statements: {type: 'boolean'},
|
||||||
|
dependencies: {
|
||||||
|
type: 'array',
|
||||||
|
items: {type: 'string'}
|
||||||
|
},
|
||||||
|
metaSchema: {type: 'object'},
|
||||||
|
modifying: {type: 'boolean'},
|
||||||
|
valid: {type: 'boolean'},
|
||||||
|
$data: {type: 'boolean'},
|
||||||
|
async: {type: 'boolean'},
|
||||||
|
errors: {
|
||||||
|
anyOf: [
|
||||||
|
{type: 'boolean'},
|
||||||
|
{const: 'full'}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
104
node_modules/ajv/lib/dot/_limit.jst
generated
vendored
Normal file
104
node_modules/ajv/lib/dot/_limit.jst
generated
vendored
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.$data }}
|
||||||
|
|
||||||
|
{{## def.setExclusiveLimit:
|
||||||
|
$exclusive = true;
|
||||||
|
$errorKeyword = $exclusiveKeyword;
|
||||||
|
$errSchemaPath = it.errSchemaPath + '/' + $exclusiveKeyword;
|
||||||
|
#}}
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $isMax = $keyword == 'maximum'
|
||||||
|
, $exclusiveKeyword = $isMax ? 'exclusiveMaximum' : 'exclusiveMinimum'
|
||||||
|
, $schemaExcl = it.schema[$exclusiveKeyword]
|
||||||
|
, $isDataExcl = it.opts.$data && $schemaExcl && $schemaExcl.$data
|
||||||
|
, $op = $isMax ? '<' : '>'
|
||||||
|
, $notOp = $isMax ? '>' : '<'
|
||||||
|
, $errorKeyword = undefined;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{? $isDataExcl }}
|
||||||
|
{{
|
||||||
|
var $schemaValueExcl = it.util.getData($schemaExcl.$data, $dataLvl, it.dataPathArr)
|
||||||
|
, $exclusive = 'exclusive' + $lvl
|
||||||
|
, $exclType = 'exclType' + $lvl
|
||||||
|
, $exclIsNumber = 'exclIsNumber' + $lvl
|
||||||
|
, $opExpr = 'op' + $lvl
|
||||||
|
, $opStr = '\' + ' + $opExpr + ' + \'';
|
||||||
|
}}
|
||||||
|
var schemaExcl{{=$lvl}} = {{=$schemaValueExcl}};
|
||||||
|
{{ $schemaValueExcl = 'schemaExcl' + $lvl; }}
|
||||||
|
|
||||||
|
var {{=$exclusive}};
|
||||||
|
var {{=$exclType}} = typeof {{=$schemaValueExcl}};
|
||||||
|
if ({{=$exclType}} != 'boolean' && {{=$exclType}} != 'undefined' && {{=$exclType}} != 'number') {
|
||||||
|
{{ var $errorKeyword = $exclusiveKeyword; }}
|
||||||
|
{{# def.error:'_exclusiveLimit' }}
|
||||||
|
} else if ({{# def.$dataNotType:'number' }}
|
||||||
|
{{=$exclType}} == 'number'
|
||||||
|
? (
|
||||||
|
({{=$exclusive}} = {{=$schemaValue}} === undefined || {{=$schemaValueExcl}} {{=$op}}= {{=$schemaValue}})
|
||||||
|
? {{=$data}} {{=$notOp}}= {{=$schemaValueExcl}}
|
||||||
|
: {{=$data}} {{=$notOp}} {{=$schemaValue}}
|
||||||
|
)
|
||||||
|
: (
|
||||||
|
({{=$exclusive}} = {{=$schemaValueExcl}} === true)
|
||||||
|
? {{=$data}} {{=$notOp}}= {{=$schemaValue}}
|
||||||
|
: {{=$data}} {{=$notOp}} {{=$schemaValue}}
|
||||||
|
)
|
||||||
|
|| {{=$data}} !== {{=$data}}) {
|
||||||
|
var op{{=$lvl}} = {{=$exclusive}} ? '{{=$op}}' : '{{=$op}}=';
|
||||||
|
{{
|
||||||
|
if ($schema === undefined) {
|
||||||
|
$errorKeyword = $exclusiveKeyword;
|
||||||
|
$errSchemaPath = it.errSchemaPath + '/' + $exclusiveKeyword;
|
||||||
|
$schemaValue = $schemaValueExcl;
|
||||||
|
$isData = $isDataExcl;
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
{{??}}
|
||||||
|
{{
|
||||||
|
var $exclIsNumber = typeof $schemaExcl == 'number'
|
||||||
|
, $opStr = $op; /*used in error*/
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{? $exclIsNumber && $isData }}
|
||||||
|
{{ var $opExpr = '\'' + $opStr + '\''; /*used in error*/ }}
|
||||||
|
if ({{# def.$dataNotType:'number' }}
|
||||||
|
( {{=$schemaValue}} === undefined
|
||||||
|
|| {{=$schemaExcl}} {{=$op}}= {{=$schemaValue}}
|
||||||
|
? {{=$data}} {{=$notOp}}= {{=$schemaExcl}}
|
||||||
|
: {{=$data}} {{=$notOp}} {{=$schemaValue}} )
|
||||||
|
|| {{=$data}} !== {{=$data}}) {
|
||||||
|
{{??}}
|
||||||
|
{{
|
||||||
|
if ($exclIsNumber && $schema === undefined) {
|
||||||
|
{{# def.setExclusiveLimit }}
|
||||||
|
$schemaValue = $schemaExcl;
|
||||||
|
$notOp += '=';
|
||||||
|
} else {
|
||||||
|
if ($exclIsNumber)
|
||||||
|
$schemaValue = Math[$isMax ? 'min' : 'max']($schemaExcl, $schema);
|
||||||
|
|
||||||
|
if ($schemaExcl === ($exclIsNumber ? $schemaValue : true)) {
|
||||||
|
{{# def.setExclusiveLimit }}
|
||||||
|
$notOp += '=';
|
||||||
|
} else {
|
||||||
|
$exclusive = false;
|
||||||
|
$opStr += '=';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var $opExpr = '\'' + $opStr + '\''; /*used in error*/
|
||||||
|
}}
|
||||||
|
|
||||||
|
if ({{# def.$dataNotType:'number' }}
|
||||||
|
{{=$data}} {{=$notOp}} {{=$schemaValue}}
|
||||||
|
|| {{=$data}} !== {{=$data}}) {
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
{{ $errorKeyword = $errorKeyword || $keyword; }}
|
||||||
|
{{# def.error:'_limit' }}
|
||||||
|
} {{? $breakOnError }} else { {{?}}
|
10
node_modules/ajv/lib/dot/_limitItems.jst
generated
vendored
Normal file
10
node_modules/ajv/lib/dot/_limitItems.jst
generated
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.$data }}
|
||||||
|
|
||||||
|
{{ var $op = $keyword == 'maxItems' ? '>' : '<'; }}
|
||||||
|
if ({{# def.$dataNotType:'number' }} {{=$data}}.length {{=$op}} {{=$schemaValue}}) {
|
||||||
|
{{ var $errorKeyword = $keyword; }}
|
||||||
|
{{# def.error:'_limitItems' }}
|
||||||
|
} {{? $breakOnError }} else { {{?}}
|
10
node_modules/ajv/lib/dot/_limitLength.jst
generated
vendored
Normal file
10
node_modules/ajv/lib/dot/_limitLength.jst
generated
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.$data }}
|
||||||
|
|
||||||
|
{{ var $op = $keyword == 'maxLength' ? '>' : '<'; }}
|
||||||
|
if ({{# def.$dataNotType:'number' }} {{# def.strLength }} {{=$op}} {{=$schemaValue}}) {
|
||||||
|
{{ var $errorKeyword = $keyword; }}
|
||||||
|
{{# def.error:'_limitLength' }}
|
||||||
|
} {{? $breakOnError }} else { {{?}}
|
10
node_modules/ajv/lib/dot/_limitProperties.jst
generated
vendored
Normal file
10
node_modules/ajv/lib/dot/_limitProperties.jst
generated
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.$data }}
|
||||||
|
|
||||||
|
{{ var $op = $keyword == 'maxProperties' ? '>' : '<'; }}
|
||||||
|
if ({{# def.$dataNotType:'number' }} Object.keys({{=$data}}).length {{=$op}} {{=$schemaValue}}) {
|
||||||
|
{{ var $errorKeyword = $keyword; }}
|
||||||
|
{{# def.error:'_limitProperties' }}
|
||||||
|
} {{? $breakOnError }} else { {{?}}
|
34
node_modules/ajv/lib/dot/allOf.jst
generated
vendored
Normal file
34
node_modules/ajv/lib/dot/allOf.jst
generated
vendored
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.setupNextLevel }}
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $currentBaseId = $it.baseId
|
||||||
|
, $allSchemasEmpty = true;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{~ $schema:$sch:$i }}
|
||||||
|
{{? {{# def.nonEmptySchema:$sch }} }}
|
||||||
|
{{
|
||||||
|
$allSchemasEmpty = false;
|
||||||
|
$it.schema = $sch;
|
||||||
|
$it.schemaPath = $schemaPath + '[' + $i + ']';
|
||||||
|
$it.errSchemaPath = $errSchemaPath + '/' + $i;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{# def.insertSubschemaCode }}
|
||||||
|
|
||||||
|
{{# def.ifResultValid }}
|
||||||
|
{{?}}
|
||||||
|
{{~}}
|
||||||
|
|
||||||
|
{{? $breakOnError }}
|
||||||
|
{{? $allSchemasEmpty }}
|
||||||
|
if (true) {
|
||||||
|
{{??}}
|
||||||
|
{{= $closingBraces.slice(0,-1) }}
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{# def.cleanUp }}
|
48
node_modules/ajv/lib/dot/anyOf.jst
generated
vendored
Normal file
48
node_modules/ajv/lib/dot/anyOf.jst
generated
vendored
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.setupNextLevel }}
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $noEmptySchema = $schema.every(function($sch) {
|
||||||
|
return {{# def.nonEmptySchema:$sch }};
|
||||||
|
});
|
||||||
|
}}
|
||||||
|
{{? $noEmptySchema }}
|
||||||
|
{{ var $currentBaseId = $it.baseId; }}
|
||||||
|
var {{=$errs}} = errors;
|
||||||
|
var {{=$valid}} = false;
|
||||||
|
|
||||||
|
{{# def.setCompositeRule }}
|
||||||
|
|
||||||
|
{{~ $schema:$sch:$i }}
|
||||||
|
{{
|
||||||
|
$it.schema = $sch;
|
||||||
|
$it.schemaPath = $schemaPath + '[' + $i + ']';
|
||||||
|
$it.errSchemaPath = $errSchemaPath + '/' + $i;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{# def.insertSubschemaCode }}
|
||||||
|
|
||||||
|
{{=$valid}} = {{=$valid}} || {{=$nextValid}};
|
||||||
|
|
||||||
|
if (!{{=$valid}}) {
|
||||||
|
{{ $closingBraces += '}'; }}
|
||||||
|
{{~}}
|
||||||
|
|
||||||
|
{{# def.resetCompositeRule }}
|
||||||
|
|
||||||
|
{{= $closingBraces }}
|
||||||
|
|
||||||
|
if (!{{=$valid}}) {
|
||||||
|
{{# def.extraError:'anyOf' }}
|
||||||
|
} else {
|
||||||
|
{{# def.resetErrors }}
|
||||||
|
{{? it.opts.allErrors }} } {{?}}
|
||||||
|
|
||||||
|
{{# def.cleanUp }}
|
||||||
|
{{??}}
|
||||||
|
{{? $breakOnError }}
|
||||||
|
if (true) {
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
61
node_modules/ajv/lib/dot/coerce.def
generated
vendored
Normal file
61
node_modules/ajv/lib/dot/coerce.def
generated
vendored
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
{{## def.coerceType:
|
||||||
|
{{
|
||||||
|
var $dataType = 'dataType' + $lvl
|
||||||
|
, $coerced = 'coerced' + $lvl;
|
||||||
|
}}
|
||||||
|
var {{=$dataType}} = typeof {{=$data}};
|
||||||
|
{{? it.opts.coerceTypes == 'array'}}
|
||||||
|
if ({{=$dataType}} == 'object' && Array.isArray({{=$data}})) {{=$dataType}} = 'array';
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
var {{=$coerced}} = undefined;
|
||||||
|
|
||||||
|
{{ var $bracesCoercion = ''; }}
|
||||||
|
{{~ $coerceToTypes:$type:$i }}
|
||||||
|
{{? $i }}
|
||||||
|
if ({{=$coerced}} === undefined) {
|
||||||
|
{{ $bracesCoercion += '}'; }}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{? it.opts.coerceTypes == 'array' && $type != 'array' }}
|
||||||
|
if ({{=$dataType}} == 'array' && {{=$data}}.length == 1) {
|
||||||
|
{{=$coerced}} = {{=$data}} = {{=$data}}[0];
|
||||||
|
{{=$dataType}} = typeof {{=$data}};
|
||||||
|
/*if ({{=$dataType}} == 'object' && Array.isArray({{=$data}})) {{=$dataType}} = 'array';*/
|
||||||
|
}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{? $type == 'string' }}
|
||||||
|
if ({{=$dataType}} == 'number' || {{=$dataType}} == 'boolean')
|
||||||
|
{{=$coerced}} = '' + {{=$data}};
|
||||||
|
else if ({{=$data}} === null) {{=$coerced}} = '';
|
||||||
|
{{?? $type == 'number' || $type == 'integer' }}
|
||||||
|
if ({{=$dataType}} == 'boolean' || {{=$data}} === null
|
||||||
|
|| ({{=$dataType}} == 'string' && {{=$data}} && {{=$data}} == +{{=$data}}
|
||||||
|
{{? $type == 'integer' }} && !({{=$data}} % 1){{?}}))
|
||||||
|
{{=$coerced}} = +{{=$data}};
|
||||||
|
{{?? $type == 'boolean' }}
|
||||||
|
if ({{=$data}} === 'false' || {{=$data}} === 0 || {{=$data}} === null)
|
||||||
|
{{=$coerced}} = false;
|
||||||
|
else if ({{=$data}} === 'true' || {{=$data}} === 1)
|
||||||
|
{{=$coerced}} = true;
|
||||||
|
{{?? $type == 'null' }}
|
||||||
|
if ({{=$data}} === '' || {{=$data}} === 0 || {{=$data}} === false)
|
||||||
|
{{=$coerced}} = null;
|
||||||
|
{{?? it.opts.coerceTypes == 'array' && $type == 'array' }}
|
||||||
|
if ({{=$dataType}} == 'string' || {{=$dataType}} == 'number' || {{=$dataType}} == 'boolean' || {{=$data}} == null)
|
||||||
|
{{=$coerced}} = [{{=$data}}];
|
||||||
|
{{?}}
|
||||||
|
{{~}}
|
||||||
|
|
||||||
|
{{= $bracesCoercion }}
|
||||||
|
|
||||||
|
if ({{=$coerced}} === undefined) {
|
||||||
|
{{# def.error:'type' }}
|
||||||
|
} else {
|
||||||
|
{{# def.setParentData }}
|
||||||
|
{{=$data}} = {{=$coerced}};
|
||||||
|
{{? !$dataLvl }}if ({{=$parentData}} !== undefined){{?}}
|
||||||
|
{{=$parentData}}[{{=$parentDataProperty}}] = {{=$coerced}};
|
||||||
|
}
|
||||||
|
#}}
|
9
node_modules/ajv/lib/dot/comment.jst
generated
vendored
Normal file
9
node_modules/ajv/lib/dot/comment.jst
generated
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
|
||||||
|
{{ var $comment = it.util.toQuotedString($schema); }}
|
||||||
|
{{? it.opts.$comment === true }}
|
||||||
|
console.log({{=$comment}});
|
||||||
|
{{?? typeof it.opts.$comment == 'function' }}
|
||||||
|
self._opts.$comment({{=$comment}}, {{=it.util.toQuotedString($errSchemaPath)}}, validate.root.schema);
|
||||||
|
{{?}}
|
11
node_modules/ajv/lib/dot/const.jst
generated
vendored
Normal file
11
node_modules/ajv/lib/dot/const.jst
generated
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.$data }}
|
||||||
|
|
||||||
|
{{? !$isData }}
|
||||||
|
var schema{{=$lvl}} = validate.schema{{=$schemaPath}};
|
||||||
|
{{?}}
|
||||||
|
var {{=$valid}} = equal({{=$data}}, schema{{=$lvl}});
|
||||||
|
{{# def.checkError:'const' }}
|
||||||
|
{{? $breakOnError }} else { {{?}}
|
57
node_modules/ajv/lib/dot/contains.jst
generated
vendored
Normal file
57
node_modules/ajv/lib/dot/contains.jst
generated
vendored
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.setupNextLevel }}
|
||||||
|
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $idx = 'i' + $lvl
|
||||||
|
, $dataNxt = $it.dataLevel = it.dataLevel + 1
|
||||||
|
, $nextData = 'data' + $dataNxt
|
||||||
|
, $currentBaseId = it.baseId
|
||||||
|
, $nonEmptySchema = {{# def.nonEmptySchema:$schema }};
|
||||||
|
}}
|
||||||
|
|
||||||
|
var {{=$errs}} = errors;
|
||||||
|
var {{=$valid}};
|
||||||
|
|
||||||
|
{{? $nonEmptySchema }}
|
||||||
|
{{# def.setCompositeRule }}
|
||||||
|
|
||||||
|
{{
|
||||||
|
$it.schema = $schema;
|
||||||
|
$it.schemaPath = $schemaPath;
|
||||||
|
$it.errSchemaPath = $errSchemaPath;
|
||||||
|
}}
|
||||||
|
|
||||||
|
var {{=$nextValid}} = false;
|
||||||
|
|
||||||
|
for (var {{=$idx}} = 0; {{=$idx}} < {{=$data}}.length; {{=$idx}}++) {
|
||||||
|
{{
|
||||||
|
$it.errorPath = it.util.getPathExpr(it.errorPath, $idx, it.opts.jsonPointers, true);
|
||||||
|
var $passData = $data + '[' + $idx + ']';
|
||||||
|
$it.dataPathArr[$dataNxt] = $idx;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{# def.generateSubschemaCode }}
|
||||||
|
{{# def.optimizeValidate }}
|
||||||
|
|
||||||
|
if ({{=$nextValid}}) break;
|
||||||
|
}
|
||||||
|
|
||||||
|
{{# def.resetCompositeRule }}
|
||||||
|
{{= $closingBraces }}
|
||||||
|
|
||||||
|
if (!{{=$nextValid}}) {
|
||||||
|
{{??}}
|
||||||
|
if ({{=$data}}.length == 0) {
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{# def.error:'contains' }}
|
||||||
|
} else {
|
||||||
|
{{? $nonEmptySchema }}
|
||||||
|
{{# def.resetErrors }}
|
||||||
|
{{?}}
|
||||||
|
{{? it.opts.allErrors }} } {{?}}
|
||||||
|
|
||||||
|
{{# def.cleanUp }}
|
191
node_modules/ajv/lib/dot/custom.jst
generated
vendored
Normal file
191
node_modules/ajv/lib/dot/custom.jst
generated
vendored
Normal file
@ -0,0 +1,191 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.$data }}
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $rule = this
|
||||||
|
, $definition = 'definition' + $lvl
|
||||||
|
, $rDef = $rule.definition
|
||||||
|
, $closingBraces = '';
|
||||||
|
var $validate = $rDef.validate;
|
||||||
|
var $compile, $inline, $macro, $ruleValidate, $validateCode;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{? $isData && $rDef.$data }}
|
||||||
|
{{
|
||||||
|
$validateCode = 'keywordValidate' + $lvl;
|
||||||
|
var $validateSchema = $rDef.validateSchema;
|
||||||
|
}}
|
||||||
|
var {{=$definition}} = RULES.custom['{{=$keyword}}'].definition;
|
||||||
|
var {{=$validateCode}} = {{=$definition}}.validate;
|
||||||
|
{{??}}
|
||||||
|
{{
|
||||||
|
$ruleValidate = it.useCustomRule($rule, $schema, it.schema, it);
|
||||||
|
if (!$ruleValidate) return;
|
||||||
|
$schemaValue = 'validate.schema' + $schemaPath;
|
||||||
|
$validateCode = $ruleValidate.code;
|
||||||
|
$compile = $rDef.compile;
|
||||||
|
$inline = $rDef.inline;
|
||||||
|
$macro = $rDef.macro;
|
||||||
|
}}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $ruleErrs = $validateCode + '.errors'
|
||||||
|
, $i = 'i' + $lvl
|
||||||
|
, $ruleErr = 'ruleErr' + $lvl
|
||||||
|
, $asyncKeyword = $rDef.async;
|
||||||
|
|
||||||
|
if ($asyncKeyword && !it.async)
|
||||||
|
throw new Error('async keyword in sync schema');
|
||||||
|
}}
|
||||||
|
|
||||||
|
|
||||||
|
{{? !($inline || $macro) }}{{=$ruleErrs}} = null;{{?}}
|
||||||
|
var {{=$errs}} = errors;
|
||||||
|
var {{=$valid}};
|
||||||
|
|
||||||
|
{{## def.callRuleValidate:
|
||||||
|
{{=$validateCode}}.call(
|
||||||
|
{{? it.opts.passContext }}this{{??}}self{{?}}
|
||||||
|
{{? $compile || $rDef.schema === false }}
|
||||||
|
, {{=$data}}
|
||||||
|
{{??}}
|
||||||
|
, {{=$schemaValue}}
|
||||||
|
, {{=$data}}
|
||||||
|
, validate.schema{{=it.schemaPath}}
|
||||||
|
{{?}}
|
||||||
|
, {{# def.dataPath }}
|
||||||
|
{{# def.passParentData }}
|
||||||
|
, rootData
|
||||||
|
)
|
||||||
|
#}}
|
||||||
|
|
||||||
|
{{## def.extendErrors:_inline:
|
||||||
|
for (var {{=$i}}={{=$errs}}; {{=$i}}<errors; {{=$i}}++) {
|
||||||
|
var {{=$ruleErr}} = vErrors[{{=$i}}];
|
||||||
|
if ({{=$ruleErr}}.dataPath === undefined)
|
||||||
|
{{=$ruleErr}}.dataPath = (dataPath || '') + {{= it.errorPath }};
|
||||||
|
{{# _inline ? 'if (\{\{=$ruleErr\}\}.schemaPath === undefined) {' : '' }}
|
||||||
|
{{=$ruleErr}}.schemaPath = "{{=$errSchemaPath}}";
|
||||||
|
{{# _inline ? '}' : '' }}
|
||||||
|
{{? it.opts.verbose }}
|
||||||
|
{{=$ruleErr}}.schema = {{=$schemaValue}};
|
||||||
|
{{=$ruleErr}}.data = {{=$data}};
|
||||||
|
{{?}}
|
||||||
|
}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{? $isData && $rDef.$data }}
|
||||||
|
{{ $closingBraces += '}'; }}
|
||||||
|
if ({{=$schemaValue}} === undefined) {
|
||||||
|
{{=$valid}} = true;
|
||||||
|
} else {
|
||||||
|
{{? $validateSchema }}
|
||||||
|
{{ $closingBraces += '}'; }}
|
||||||
|
{{=$valid}} = {{=$definition}}.validateSchema({{=$schemaValue}});
|
||||||
|
if ({{=$valid}}) {
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{? $inline }}
|
||||||
|
{{? $rDef.statements }}
|
||||||
|
{{= $ruleValidate.validate }}
|
||||||
|
{{??}}
|
||||||
|
{{=$valid}} = {{= $ruleValidate.validate }};
|
||||||
|
{{?}}
|
||||||
|
{{?? $macro }}
|
||||||
|
{{# def.setupNextLevel }}
|
||||||
|
{{
|
||||||
|
$it.schema = $ruleValidate.validate;
|
||||||
|
$it.schemaPath = '';
|
||||||
|
}}
|
||||||
|
{{# def.setCompositeRule }}
|
||||||
|
{{ var $code = it.validate($it).replace(/validate\.schema/g, $validateCode); }}
|
||||||
|
{{# def.resetCompositeRule }}
|
||||||
|
{{= $code }}
|
||||||
|
{{??}}
|
||||||
|
{{# def.beginDefOut}}
|
||||||
|
{{# def.callRuleValidate }}
|
||||||
|
{{# def.storeDefOut:def_callRuleValidate }}
|
||||||
|
|
||||||
|
{{? $rDef.errors === false }}
|
||||||
|
{{=$valid}} = {{? $asyncKeyword }}await {{?}}{{= def_callRuleValidate }};
|
||||||
|
{{??}}
|
||||||
|
{{? $asyncKeyword }}
|
||||||
|
{{ $ruleErrs = 'customErrors' + $lvl; }}
|
||||||
|
var {{=$ruleErrs}} = null;
|
||||||
|
try {
|
||||||
|
{{=$valid}} = await {{= def_callRuleValidate }};
|
||||||
|
} catch (e) {
|
||||||
|
{{=$valid}} = false;
|
||||||
|
if (e instanceof ValidationError) {{=$ruleErrs}} = e.errors;
|
||||||
|
else throw e;
|
||||||
|
}
|
||||||
|
{{??}}
|
||||||
|
{{=$ruleErrs}} = null;
|
||||||
|
{{=$valid}} = {{= def_callRuleValidate }};
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{? $rDef.modifying }}
|
||||||
|
if ({{=$parentData}}) {{=$data}} = {{=$parentData}}[{{=$parentDataProperty}}];
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{= $closingBraces }}
|
||||||
|
|
||||||
|
{{## def.notValidationResult:
|
||||||
|
{{? $rDef.valid === undefined }}
|
||||||
|
!{{? $macro }}{{=$nextValid}}{{??}}{{=$valid}}{{?}}
|
||||||
|
{{??}}
|
||||||
|
{{= !$rDef.valid }}
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
{{? $rDef.valid }}
|
||||||
|
{{? $breakOnError }} if (true) { {{?}}
|
||||||
|
{{??}}
|
||||||
|
if ({{# def.notValidationResult }}) {
|
||||||
|
{{ $errorKeyword = $rule.keyword; }}
|
||||||
|
{{# def.beginDefOut}}
|
||||||
|
{{# def.error:'custom' }}
|
||||||
|
{{# def.storeDefOut:def_customError }}
|
||||||
|
|
||||||
|
{{? $inline }}
|
||||||
|
{{? $rDef.errors }}
|
||||||
|
{{? $rDef.errors != 'full' }}
|
||||||
|
{{# def.extendErrors:true }}
|
||||||
|
{{?}}
|
||||||
|
{{??}}
|
||||||
|
{{? $rDef.errors === false}}
|
||||||
|
{{= def_customError }}
|
||||||
|
{{??}}
|
||||||
|
if ({{=$errs}} == errors) {
|
||||||
|
{{= def_customError }}
|
||||||
|
} else {
|
||||||
|
{{# def.extendErrors:true }}
|
||||||
|
}
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
{{?? $macro }}
|
||||||
|
{{# def.extraError:'custom' }}
|
||||||
|
{{??}}
|
||||||
|
{{? $rDef.errors === false}}
|
||||||
|
{{= def_customError }}
|
||||||
|
{{??}}
|
||||||
|
if (Array.isArray({{=$ruleErrs}})) {
|
||||||
|
if (vErrors === null) vErrors = {{=$ruleErrs}};
|
||||||
|
else vErrors = vErrors.concat({{=$ruleErrs}});
|
||||||
|
errors = vErrors.length;
|
||||||
|
{{# def.extendErrors:false }}
|
||||||
|
} else {
|
||||||
|
{{= def_customError }}
|
||||||
|
}
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
} {{? $breakOnError }} else { {{?}}
|
||||||
|
{{?}}
|
47
node_modules/ajv/lib/dot/defaults.def
generated
vendored
Normal file
47
node_modules/ajv/lib/dot/defaults.def
generated
vendored
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
{{## def.assignDefault:
|
||||||
|
{{? it.compositeRule }}
|
||||||
|
{{
|
||||||
|
if (it.opts.strictDefaults) {
|
||||||
|
var $defaultMsg = 'default is ignored for: ' + $passData;
|
||||||
|
if (it.opts.strictDefaults === 'log') it.logger.warn($defaultMsg);
|
||||||
|
else throw new Error($defaultMsg);
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
{{??}}
|
||||||
|
if ({{=$passData}} === undefined
|
||||||
|
{{? it.opts.useDefaults == 'empty' }}
|
||||||
|
|| {{=$passData}} === null
|
||||||
|
|| {{=$passData}} === ''
|
||||||
|
{{?}}
|
||||||
|
)
|
||||||
|
{{=$passData}} = {{? it.opts.useDefaults == 'shared' }}
|
||||||
|
{{= it.useDefault($sch.default) }}
|
||||||
|
{{??}}
|
||||||
|
{{= JSON.stringify($sch.default) }}
|
||||||
|
{{?}};
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.defaultProperties:
|
||||||
|
{{
|
||||||
|
var $schema = it.schema.properties
|
||||||
|
, $schemaKeys = Object.keys($schema); }}
|
||||||
|
{{~ $schemaKeys:$propertyKey }}
|
||||||
|
{{ var $sch = $schema[$propertyKey]; }}
|
||||||
|
{{? $sch.default !== undefined }}
|
||||||
|
{{ var $passData = $data + it.util.getProperty($propertyKey); }}
|
||||||
|
{{# def.assignDefault }}
|
||||||
|
{{?}}
|
||||||
|
{{~}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.defaultItems:
|
||||||
|
{{~ it.schema.items:$sch:$i }}
|
||||||
|
{{? $sch.default !== undefined }}
|
||||||
|
{{ var $passData = $data + '[' + $i + ']'; }}
|
||||||
|
{{# def.assignDefault }}
|
||||||
|
{{?}}
|
||||||
|
{{~}}
|
||||||
|
#}}
|
201
node_modules/ajv/lib/dot/definitions.def
generated
vendored
Normal file
201
node_modules/ajv/lib/dot/definitions.def
generated
vendored
Normal file
@ -0,0 +1,201 @@
|
|||||||
|
{{## def.setupKeyword:
|
||||||
|
{{
|
||||||
|
var $lvl = it.level;
|
||||||
|
var $dataLvl = it.dataLevel;
|
||||||
|
var $schema = it.schema[$keyword];
|
||||||
|
var $schemaPath = it.schemaPath + it.util.getProperty($keyword);
|
||||||
|
var $errSchemaPath = it.errSchemaPath + '/' + $keyword;
|
||||||
|
var $breakOnError = !it.opts.allErrors;
|
||||||
|
var $errorKeyword;
|
||||||
|
|
||||||
|
var $data = 'data' + ($dataLvl || '');
|
||||||
|
var $valid = 'valid' + $lvl;
|
||||||
|
var $errs = 'errs__' + $lvl;
|
||||||
|
}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.setCompositeRule:
|
||||||
|
{{
|
||||||
|
var $wasComposite = it.compositeRule;
|
||||||
|
it.compositeRule = $it.compositeRule = true;
|
||||||
|
}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.resetCompositeRule:
|
||||||
|
{{ it.compositeRule = $it.compositeRule = $wasComposite; }}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.setupNextLevel:
|
||||||
|
{{
|
||||||
|
var $it = it.util.copy(it);
|
||||||
|
var $closingBraces = '';
|
||||||
|
$it.level++;
|
||||||
|
var $nextValid = 'valid' + $it.level;
|
||||||
|
}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.ifValid:
|
||||||
|
{{? $breakOnError }}
|
||||||
|
if ({{=$valid}}) {
|
||||||
|
{{ $closingBraces += '}'; }}
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.ifResultValid:
|
||||||
|
{{? $breakOnError }}
|
||||||
|
if ({{=$nextValid}}) {
|
||||||
|
{{ $closingBraces += '}'; }}
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.elseIfValid:
|
||||||
|
{{? $breakOnError }}
|
||||||
|
{{ $closingBraces += '}'; }}
|
||||||
|
else {
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.nonEmptySchema:_schema:
|
||||||
|
(it.opts.strictKeywords
|
||||||
|
? typeof _schema == 'object' && Object.keys(_schema).length > 0
|
||||||
|
: it.util.schemaHasRules(_schema, it.RULES.all))
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.strLength:
|
||||||
|
{{? it.opts.unicode === false }}
|
||||||
|
{{=$data}}.length
|
||||||
|
{{??}}
|
||||||
|
ucs2length({{=$data}})
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.willOptimize:
|
||||||
|
it.util.varOccurences($code, $nextData) < 2
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.generateSubschemaCode:
|
||||||
|
{{
|
||||||
|
var $code = it.validate($it);
|
||||||
|
$it.baseId = $currentBaseId;
|
||||||
|
}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.insertSubschemaCode:
|
||||||
|
{{= it.validate($it) }}
|
||||||
|
{{ $it.baseId = $currentBaseId; }}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def._optimizeValidate:
|
||||||
|
it.util.varReplace($code, $nextData, $passData)
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.optimizeValidate:
|
||||||
|
{{? {{# def.willOptimize}} }}
|
||||||
|
{{= {{# def._optimizeValidate }} }}
|
||||||
|
{{??}}
|
||||||
|
var {{=$nextData}} = {{=$passData}};
|
||||||
|
{{= $code }}
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.cleanUp: {{ out = it.util.cleanUpCode(out); }} #}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.finalCleanUp: {{ out = it.util.finalCleanUpCode(out, $async); }} #}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.$data:
|
||||||
|
{{
|
||||||
|
var $isData = it.opts.$data && $schema && $schema.$data
|
||||||
|
, $schemaValue;
|
||||||
|
}}
|
||||||
|
{{? $isData }}
|
||||||
|
var schema{{=$lvl}} = {{= it.util.getData($schema.$data, $dataLvl, it.dataPathArr) }};
|
||||||
|
{{ $schemaValue = 'schema' + $lvl; }}
|
||||||
|
{{??}}
|
||||||
|
{{ $schemaValue = $schema; }}
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.$dataNotType:_type:
|
||||||
|
{{?$isData}} ({{=$schemaValue}} !== undefined && typeof {{=$schemaValue}} != _type) || {{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.check$dataIsArray:
|
||||||
|
if (schema{{=$lvl}} === undefined) {{=$valid}} = true;
|
||||||
|
else if (!Array.isArray(schema{{=$lvl}})) {{=$valid}} = false;
|
||||||
|
else {
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.beginDefOut:
|
||||||
|
{{
|
||||||
|
var $$outStack = $$outStack || [];
|
||||||
|
$$outStack.push(out);
|
||||||
|
out = '';
|
||||||
|
}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.storeDefOut:_variable:
|
||||||
|
{{
|
||||||
|
var _variable = out;
|
||||||
|
out = $$outStack.pop();
|
||||||
|
}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.dataPath:(dataPath || ''){{? it.errorPath != '""'}} + {{= it.errorPath }}{{?}}#}}
|
||||||
|
|
||||||
|
{{## def.setParentData:
|
||||||
|
{{
|
||||||
|
var $parentData = $dataLvl ? 'data' + (($dataLvl-1)||'') : 'parentData'
|
||||||
|
, $parentDataProperty = $dataLvl ? it.dataPathArr[$dataLvl] : 'parentDataProperty';
|
||||||
|
}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
{{## def.passParentData:
|
||||||
|
{{# def.setParentData }}
|
||||||
|
, {{= $parentData }}
|
||||||
|
, {{= $parentDataProperty }}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.iterateProperties:
|
||||||
|
{{? $ownProperties }}
|
||||||
|
{{=$dataProperties}} = {{=$dataProperties}} || Object.keys({{=$data}});
|
||||||
|
for (var {{=$idx}}=0; {{=$idx}}<{{=$dataProperties}}.length; {{=$idx}}++) {
|
||||||
|
var {{=$key}} = {{=$dataProperties}}[{{=$idx}}];
|
||||||
|
{{??}}
|
||||||
|
for (var {{=$key}} in {{=$data}}) {
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.noPropertyInData:
|
||||||
|
{{=$useData}} === undefined
|
||||||
|
{{? $ownProperties }}
|
||||||
|
|| !{{# def.isOwnProperty }}
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.isOwnProperty:
|
||||||
|
Object.prototype.hasOwnProperty.call({{=$data}}, '{{=it.util.escapeQuotes($propertyKey)}}')
|
||||||
|
#}}
|
80
node_modules/ajv/lib/dot/dependencies.jst
generated
vendored
Normal file
80
node_modules/ajv/lib/dot/dependencies.jst
generated
vendored
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.missing }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.setupNextLevel }}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.propertyInData:
|
||||||
|
{{=$data}}{{= it.util.getProperty($property) }} !== undefined
|
||||||
|
{{? $ownProperties }}
|
||||||
|
&& Object.prototype.hasOwnProperty.call({{=$data}}, '{{=it.util.escapeQuotes($property)}}')
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $schemaDeps = {}
|
||||||
|
, $propertyDeps = {}
|
||||||
|
, $ownProperties = it.opts.ownProperties;
|
||||||
|
|
||||||
|
for ($property in $schema) {
|
||||||
|
var $sch = $schema[$property];
|
||||||
|
var $deps = Array.isArray($sch) ? $propertyDeps : $schemaDeps;
|
||||||
|
$deps[$property] = $sch;
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
|
||||||
|
var {{=$errs}} = errors;
|
||||||
|
|
||||||
|
{{ var $currentErrorPath = it.errorPath; }}
|
||||||
|
|
||||||
|
var missing{{=$lvl}};
|
||||||
|
{{ for (var $property in $propertyDeps) { }}
|
||||||
|
{{ $deps = $propertyDeps[$property]; }}
|
||||||
|
{{? $deps.length }}
|
||||||
|
if ({{# def.propertyInData }}
|
||||||
|
{{? $breakOnError }}
|
||||||
|
&& ({{# def.checkMissingProperty:$deps }})) {
|
||||||
|
{{# def.errorMissingProperty:'dependencies' }}
|
||||||
|
{{??}}
|
||||||
|
) {
|
||||||
|
{{~ $deps:$propertyKey }}
|
||||||
|
{{# def.allErrorsMissingProperty:'dependencies' }}
|
||||||
|
{{~}}
|
||||||
|
{{?}}
|
||||||
|
} {{# def.elseIfValid }}
|
||||||
|
{{?}}
|
||||||
|
{{ } }}
|
||||||
|
|
||||||
|
{{
|
||||||
|
it.errorPath = $currentErrorPath;
|
||||||
|
var $currentBaseId = $it.baseId;
|
||||||
|
}}
|
||||||
|
|
||||||
|
|
||||||
|
{{ for (var $property in $schemaDeps) { }}
|
||||||
|
{{ var $sch = $schemaDeps[$property]; }}
|
||||||
|
{{? {{# def.nonEmptySchema:$sch }} }}
|
||||||
|
{{=$nextValid}} = true;
|
||||||
|
|
||||||
|
if ({{# def.propertyInData }}) {
|
||||||
|
{{
|
||||||
|
$it.schema = $sch;
|
||||||
|
$it.schemaPath = $schemaPath + it.util.getProperty($property);
|
||||||
|
$it.errSchemaPath = $errSchemaPath + '/' + it.util.escapeFragment($property);
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{# def.insertSubschemaCode }}
|
||||||
|
}
|
||||||
|
|
||||||
|
{{# def.ifResultValid }}
|
||||||
|
{{?}}
|
||||||
|
{{ } }}
|
||||||
|
|
||||||
|
{{? $breakOnError }}
|
||||||
|
{{= $closingBraces }}
|
||||||
|
if ({{=$errs}} == errors) {
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{# def.cleanUp }}
|
30
node_modules/ajv/lib/dot/enum.jst
generated
vendored
Normal file
30
node_modules/ajv/lib/dot/enum.jst
generated
vendored
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.$data }}
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $i = 'i' + $lvl
|
||||||
|
, $vSchema = 'schema' + $lvl;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{? !$isData }}
|
||||||
|
var {{=$vSchema}} = validate.schema{{=$schemaPath}};
|
||||||
|
{{?}}
|
||||||
|
var {{=$valid}};
|
||||||
|
|
||||||
|
{{?$isData}}{{# def.check$dataIsArray }}{{?}}
|
||||||
|
|
||||||
|
{{=$valid}} = false;
|
||||||
|
|
||||||
|
for (var {{=$i}}=0; {{=$i}}<{{=$vSchema}}.length; {{=$i}}++)
|
||||||
|
if (equal({{=$data}}, {{=$vSchema}}[{{=$i}}])) {
|
||||||
|
{{=$valid}} = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
{{? $isData }} } {{?}}
|
||||||
|
|
||||||
|
{{# def.checkError:'enum' }}
|
||||||
|
|
||||||
|
{{? $breakOnError }} else { {{?}}
|
194
node_modules/ajv/lib/dot/errors.def
generated
vendored
Normal file
194
node_modules/ajv/lib/dot/errors.def
generated
vendored
Normal file
@ -0,0 +1,194 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
|
||||||
|
{{## def._error:_rule:
|
||||||
|
{{ 'istanbul ignore else'; }}
|
||||||
|
{{? it.createErrors !== false }}
|
||||||
|
{
|
||||||
|
keyword: '{{= $errorKeyword || _rule }}'
|
||||||
|
, dataPath: (dataPath || '') + {{= it.errorPath }}
|
||||||
|
, schemaPath: {{=it.util.toQuotedString($errSchemaPath)}}
|
||||||
|
, params: {{# def._errorParams[_rule] }}
|
||||||
|
{{? it.opts.messages !== false }}
|
||||||
|
, message: {{# def._errorMessages[_rule] }}
|
||||||
|
{{?}}
|
||||||
|
{{? it.opts.verbose }}
|
||||||
|
, schema: {{# def._errorSchemas[_rule] }}
|
||||||
|
, parentSchema: validate.schema{{=it.schemaPath}}
|
||||||
|
, data: {{=$data}}
|
||||||
|
{{?}}
|
||||||
|
}
|
||||||
|
{{??}}
|
||||||
|
{}
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def._addError:_rule:
|
||||||
|
if (vErrors === null) vErrors = [err];
|
||||||
|
else vErrors.push(err);
|
||||||
|
errors++;
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.addError:_rule:
|
||||||
|
var err = {{# def._error:_rule }};
|
||||||
|
{{# def._addError:_rule }}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.error:_rule:
|
||||||
|
{{# def.beginDefOut}}
|
||||||
|
{{# def._error:_rule }}
|
||||||
|
{{# def.storeDefOut:__err }}
|
||||||
|
|
||||||
|
{{? !it.compositeRule && $breakOnError }}
|
||||||
|
{{ 'istanbul ignore if'; }}
|
||||||
|
{{? it.async }}
|
||||||
|
throw new ValidationError([{{=__err}}]);
|
||||||
|
{{??}}
|
||||||
|
validate.errors = [{{=__err}}];
|
||||||
|
return false;
|
||||||
|
{{?}}
|
||||||
|
{{??}}
|
||||||
|
var err = {{=__err}};
|
||||||
|
{{# def._addError:_rule }}
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.extraError:_rule:
|
||||||
|
{{# def.addError:_rule}}
|
||||||
|
{{? !it.compositeRule && $breakOnError }}
|
||||||
|
{{ 'istanbul ignore if'; }}
|
||||||
|
{{? it.async }}
|
||||||
|
throw new ValidationError(vErrors);
|
||||||
|
{{??}}
|
||||||
|
validate.errors = vErrors;
|
||||||
|
return false;
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.checkError:_rule:
|
||||||
|
if (!{{=$valid}}) {
|
||||||
|
{{# def.error:_rule }}
|
||||||
|
}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.resetErrors:
|
||||||
|
errors = {{=$errs}};
|
||||||
|
if (vErrors !== null) {
|
||||||
|
if ({{=$errs}}) vErrors.length = {{=$errs}};
|
||||||
|
else vErrors = null;
|
||||||
|
}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.concatSchema:{{?$isData}}' + {{=$schemaValue}} + '{{??}}{{=$schema}}{{?}}#}}
|
||||||
|
{{## def.appendSchema:{{?$isData}}' + {{=$schemaValue}}{{??}}{{=$schemaValue}}'{{?}}#}}
|
||||||
|
{{## def.concatSchemaEQ:{{?$isData}}' + {{=$schemaValue}} + '{{??}}{{=it.util.escapeQuotes($schema)}}{{?}}#}}
|
||||||
|
|
||||||
|
{{## def._errorMessages = {
|
||||||
|
'false schema': "'boolean schema is false'",
|
||||||
|
$ref: "'can\\\'t resolve reference {{=it.util.escapeQuotes($schema)}}'",
|
||||||
|
additionalItems: "'should NOT have more than {{=$schema.length}} items'",
|
||||||
|
additionalProperties: "'{{? it.opts._errorDataPathProperty }}is an invalid additional property{{??}}should NOT have additional properties{{?}}'",
|
||||||
|
anyOf: "'should match some schema in anyOf'",
|
||||||
|
const: "'should be equal to constant'",
|
||||||
|
contains: "'should contain a valid item'",
|
||||||
|
dependencies: "'should have {{? $deps.length == 1 }}property {{= it.util.escapeQuotes($deps[0]) }}{{??}}properties {{= it.util.escapeQuotes($deps.join(\", \")) }}{{?}} when property {{= it.util.escapeQuotes($property) }} is present'",
|
||||||
|
'enum': "'should be equal to one of the allowed values'",
|
||||||
|
format: "'should match format \"{{#def.concatSchemaEQ}}\"'",
|
||||||
|
'if': "'should match \"' + {{=$ifClause}} + '\" schema'",
|
||||||
|
_limit: "'should be {{=$opStr}} {{#def.appendSchema}}",
|
||||||
|
_exclusiveLimit: "'{{=$exclusiveKeyword}} should be boolean'",
|
||||||
|
_limitItems: "'should NOT have {{?$keyword=='maxItems'}}more{{??}}fewer{{?}} than {{#def.concatSchema}} items'",
|
||||||
|
_limitLength: "'should NOT be {{?$keyword=='maxLength'}}longer{{??}}shorter{{?}} than {{#def.concatSchema}} characters'",
|
||||||
|
_limitProperties:"'should NOT have {{?$keyword=='maxProperties'}}more{{??}}fewer{{?}} than {{#def.concatSchema}} properties'",
|
||||||
|
multipleOf: "'should be multiple of {{#def.appendSchema}}",
|
||||||
|
not: "'should NOT be valid'",
|
||||||
|
oneOf: "'should match exactly one schema in oneOf'",
|
||||||
|
pattern: "'should match pattern \"{{#def.concatSchemaEQ}}\"'",
|
||||||
|
propertyNames: "'property name \\'{{=$invalidName}}\\' is invalid'",
|
||||||
|
required: "'{{? it.opts._errorDataPathProperty }}is a required property{{??}}should have required property \\'{{=$missingProperty}}\\'{{?}}'",
|
||||||
|
type: "'should be {{? $typeIsArray }}{{= $typeSchema.join(\",\") }}{{??}}{{=$typeSchema}}{{?}}'",
|
||||||
|
uniqueItems: "'should NOT have duplicate items (items ## ' + j + ' and ' + i + ' are identical)'",
|
||||||
|
custom: "'should pass \"{{=$rule.keyword}}\" keyword validation'",
|
||||||
|
patternRequired: "'should have property matching pattern \\'{{=$missingPattern}}\\''",
|
||||||
|
switch: "'should pass \"switch\" keyword validation'",
|
||||||
|
_formatLimit: "'should be {{=$opStr}} \"{{#def.concatSchemaEQ}}\"'",
|
||||||
|
_formatExclusiveLimit: "'{{=$exclusiveKeyword}} should be boolean'"
|
||||||
|
} #}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.schemaRefOrVal: {{?$isData}}validate.schema{{=$schemaPath}}{{??}}{{=$schema}}{{?}} #}}
|
||||||
|
{{## def.schemaRefOrQS: {{?$isData}}validate.schema{{=$schemaPath}}{{??}}{{=it.util.toQuotedString($schema)}}{{?}} #}}
|
||||||
|
|
||||||
|
{{## def._errorSchemas = {
|
||||||
|
'false schema': "false",
|
||||||
|
$ref: "{{=it.util.toQuotedString($schema)}}",
|
||||||
|
additionalItems: "false",
|
||||||
|
additionalProperties: "false",
|
||||||
|
anyOf: "validate.schema{{=$schemaPath}}",
|
||||||
|
const: "validate.schema{{=$schemaPath}}",
|
||||||
|
contains: "validate.schema{{=$schemaPath}}",
|
||||||
|
dependencies: "validate.schema{{=$schemaPath}}",
|
||||||
|
'enum': "validate.schema{{=$schemaPath}}",
|
||||||
|
format: "{{#def.schemaRefOrQS}}",
|
||||||
|
'if': "validate.schema{{=$schemaPath}}",
|
||||||
|
_limit: "{{#def.schemaRefOrVal}}",
|
||||||
|
_exclusiveLimit: "validate.schema{{=$schemaPath}}",
|
||||||
|
_limitItems: "{{#def.schemaRefOrVal}}",
|
||||||
|
_limitLength: "{{#def.schemaRefOrVal}}",
|
||||||
|
_limitProperties:"{{#def.schemaRefOrVal}}",
|
||||||
|
multipleOf: "{{#def.schemaRefOrVal}}",
|
||||||
|
not: "validate.schema{{=$schemaPath}}",
|
||||||
|
oneOf: "validate.schema{{=$schemaPath}}",
|
||||||
|
pattern: "{{#def.schemaRefOrQS}}",
|
||||||
|
propertyNames: "validate.schema{{=$schemaPath}}",
|
||||||
|
required: "validate.schema{{=$schemaPath}}",
|
||||||
|
type: "validate.schema{{=$schemaPath}}",
|
||||||
|
uniqueItems: "{{#def.schemaRefOrVal}}",
|
||||||
|
custom: "validate.schema{{=$schemaPath}}",
|
||||||
|
patternRequired: "validate.schema{{=$schemaPath}}",
|
||||||
|
switch: "validate.schema{{=$schemaPath}}",
|
||||||
|
_formatLimit: "{{#def.schemaRefOrQS}}",
|
||||||
|
_formatExclusiveLimit: "validate.schema{{=$schemaPath}}"
|
||||||
|
} #}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.schemaValueQS: {{?$isData}}{{=$schemaValue}}{{??}}{{=it.util.toQuotedString($schema)}}{{?}} #}}
|
||||||
|
|
||||||
|
{{## def._errorParams = {
|
||||||
|
'false schema': "{}",
|
||||||
|
$ref: "{ ref: '{{=it.util.escapeQuotes($schema)}}' }",
|
||||||
|
additionalItems: "{ limit: {{=$schema.length}} }",
|
||||||
|
additionalProperties: "{ additionalProperty: '{{=$additionalProperty}}' }",
|
||||||
|
anyOf: "{}",
|
||||||
|
const: "{ allowedValue: schema{{=$lvl}} }",
|
||||||
|
contains: "{}",
|
||||||
|
dependencies: "{ property: '{{= it.util.escapeQuotes($property) }}', missingProperty: '{{=$missingProperty}}', depsCount: {{=$deps.length}}, deps: '{{= it.util.escapeQuotes($deps.length==1 ? $deps[0] : $deps.join(\", \")) }}' }",
|
||||||
|
'enum': "{ allowedValues: schema{{=$lvl}} }",
|
||||||
|
format: "{ format: {{#def.schemaValueQS}} }",
|
||||||
|
'if': "{ failingKeyword: {{=$ifClause}} }",
|
||||||
|
_limit: "{ comparison: {{=$opExpr}}, limit: {{=$schemaValue}}, exclusive: {{=$exclusive}} }",
|
||||||
|
_exclusiveLimit: "{}",
|
||||||
|
_limitItems: "{ limit: {{=$schemaValue}} }",
|
||||||
|
_limitLength: "{ limit: {{=$schemaValue}} }",
|
||||||
|
_limitProperties:"{ limit: {{=$schemaValue}} }",
|
||||||
|
multipleOf: "{ multipleOf: {{=$schemaValue}} }",
|
||||||
|
not: "{}",
|
||||||
|
oneOf: "{ passingSchemas: {{=$passingSchemas}} }",
|
||||||
|
pattern: "{ pattern: {{#def.schemaValueQS}} }",
|
||||||
|
propertyNames: "{ propertyName: '{{=$invalidName}}' }",
|
||||||
|
required: "{ missingProperty: '{{=$missingProperty}}' }",
|
||||||
|
type: "{ type: '{{? $typeIsArray }}{{= $typeSchema.join(\",\") }}{{??}}{{=$typeSchema}}{{?}}' }",
|
||||||
|
uniqueItems: "{ i: i, j: j }",
|
||||||
|
custom: "{ keyword: '{{=$rule.keyword}}' }",
|
||||||
|
patternRequired: "{ missingPattern: '{{=$missingPattern}}' }",
|
||||||
|
switch: "{ caseIndex: {{=$caseIndex}} }",
|
||||||
|
_formatLimit: "{ comparison: {{=$opExpr}}, limit: {{#def.schemaValueQS}}, exclusive: {{=$exclusive}} }",
|
||||||
|
_formatExclusiveLimit: "{}"
|
||||||
|
} #}}
|
106
node_modules/ajv/lib/dot/format.jst
generated
vendored
Normal file
106
node_modules/ajv/lib/dot/format.jst
generated
vendored
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
|
||||||
|
{{## def.skipFormat:
|
||||||
|
{{? $breakOnError }} if (true) { {{?}}
|
||||||
|
{{ return out; }}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
{{? it.opts.format === false }}{{# def.skipFormat }}{{?}}
|
||||||
|
|
||||||
|
|
||||||
|
{{# def.$data }}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.$dataCheckFormat:
|
||||||
|
{{# def.$dataNotType:'string' }}
|
||||||
|
({{? $unknownFormats != 'ignore' }}
|
||||||
|
({{=$schemaValue}} && !{{=$format}}
|
||||||
|
{{? $allowUnknown }}
|
||||||
|
&& self._opts.unknownFormats.indexOf({{=$schemaValue}}) == -1
|
||||||
|
{{?}}) ||
|
||||||
|
{{?}}
|
||||||
|
({{=$format}} && {{=$formatType}} == '{{=$ruleType}}'
|
||||||
|
&& !(typeof {{=$format}} == 'function'
|
||||||
|
? {{? it.async}}
|
||||||
|
(async{{=$lvl}} ? await {{=$format}}({{=$data}}) : {{=$format}}({{=$data}}))
|
||||||
|
{{??}}
|
||||||
|
{{=$format}}({{=$data}})
|
||||||
|
{{?}}
|
||||||
|
: {{=$format}}.test({{=$data}}))))
|
||||||
|
#}}
|
||||||
|
|
||||||
|
{{## def.checkFormat:
|
||||||
|
{{
|
||||||
|
var $formatRef = 'formats' + it.util.getProperty($schema);
|
||||||
|
if ($isObject) $formatRef += '.validate';
|
||||||
|
}}
|
||||||
|
{{? typeof $format == 'function' }}
|
||||||
|
{{=$formatRef}}({{=$data}})
|
||||||
|
{{??}}
|
||||||
|
{{=$formatRef}}.test({{=$data}})
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $unknownFormats = it.opts.unknownFormats
|
||||||
|
, $allowUnknown = Array.isArray($unknownFormats);
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{? $isData }}
|
||||||
|
{{
|
||||||
|
var $format = 'format' + $lvl
|
||||||
|
, $isObject = 'isObject' + $lvl
|
||||||
|
, $formatType = 'formatType' + $lvl;
|
||||||
|
}}
|
||||||
|
var {{=$format}} = formats[{{=$schemaValue}}];
|
||||||
|
var {{=$isObject}} = typeof {{=$format}} == 'object'
|
||||||
|
&& !({{=$format}} instanceof RegExp)
|
||||||
|
&& {{=$format}}.validate;
|
||||||
|
var {{=$formatType}} = {{=$isObject}} && {{=$format}}.type || 'string';
|
||||||
|
if ({{=$isObject}}) {
|
||||||
|
{{? it.async}}
|
||||||
|
var async{{=$lvl}} = {{=$format}}.async;
|
||||||
|
{{?}}
|
||||||
|
{{=$format}} = {{=$format}}.validate;
|
||||||
|
}
|
||||||
|
if ({{# def.$dataCheckFormat }}) {
|
||||||
|
{{??}}
|
||||||
|
{{ var $format = it.formats[$schema]; }}
|
||||||
|
{{? !$format }}
|
||||||
|
{{? $unknownFormats == 'ignore' }}
|
||||||
|
{{ it.logger.warn('unknown format "' + $schema + '" ignored in schema at path "' + it.errSchemaPath + '"'); }}
|
||||||
|
{{# def.skipFormat }}
|
||||||
|
{{?? $allowUnknown && $unknownFormats.indexOf($schema) >= 0 }}
|
||||||
|
{{# def.skipFormat }}
|
||||||
|
{{??}}
|
||||||
|
{{ throw new Error('unknown format "' + $schema + '" is used in schema at path "' + it.errSchemaPath + '"'); }}
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
{{
|
||||||
|
var $isObject = typeof $format == 'object'
|
||||||
|
&& !($format instanceof RegExp)
|
||||||
|
&& $format.validate;
|
||||||
|
var $formatType = $isObject && $format.type || 'string';
|
||||||
|
if ($isObject) {
|
||||||
|
var $async = $format.async === true;
|
||||||
|
$format = $format.validate;
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
{{? $formatType != $ruleType }}
|
||||||
|
{{# def.skipFormat }}
|
||||||
|
{{?}}
|
||||||
|
{{? $async }}
|
||||||
|
{{
|
||||||
|
if (!it.async) throw new Error('async format in sync schema');
|
||||||
|
var $formatRef = 'formats' + it.util.getProperty($schema) + '.validate';
|
||||||
|
}}
|
||||||
|
if (!(await {{=$formatRef}}({{=$data}}))) {
|
||||||
|
{{??}}
|
||||||
|
if (!{{# def.checkFormat }}) {
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
{{# def.error:'format' }}
|
||||||
|
} {{? $breakOnError }} else { {{?}}
|
75
node_modules/ajv/lib/dot/if.jst
generated
vendored
Normal file
75
node_modules/ajv/lib/dot/if.jst
generated
vendored
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.setupNextLevel }}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.validateIfClause:_clause:
|
||||||
|
{{
|
||||||
|
$it.schema = it.schema['_clause'];
|
||||||
|
$it.schemaPath = it.schemaPath + '._clause';
|
||||||
|
$it.errSchemaPath = it.errSchemaPath + '/_clause';
|
||||||
|
}}
|
||||||
|
{{# def.insertSubschemaCode }}
|
||||||
|
{{=$valid}} = {{=$nextValid}};
|
||||||
|
{{? $thenPresent && $elsePresent }}
|
||||||
|
{{ $ifClause = 'ifClause' + $lvl; }}
|
||||||
|
var {{=$ifClause}} = '_clause';
|
||||||
|
{{??}}
|
||||||
|
{{ $ifClause = '\'_clause\''; }}
|
||||||
|
{{?}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $thenSch = it.schema['then']
|
||||||
|
, $elseSch = it.schema['else']
|
||||||
|
, $thenPresent = $thenSch !== undefined && {{# def.nonEmptySchema:$thenSch }}
|
||||||
|
, $elsePresent = $elseSch !== undefined && {{# def.nonEmptySchema:$elseSch }}
|
||||||
|
, $currentBaseId = $it.baseId;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{? $thenPresent || $elsePresent }}
|
||||||
|
{{
|
||||||
|
var $ifClause;
|
||||||
|
$it.createErrors = false;
|
||||||
|
$it.schema = $schema;
|
||||||
|
$it.schemaPath = $schemaPath;
|
||||||
|
$it.errSchemaPath = $errSchemaPath;
|
||||||
|
}}
|
||||||
|
var {{=$errs}} = errors;
|
||||||
|
var {{=$valid}} = true;
|
||||||
|
|
||||||
|
{{# def.setCompositeRule }}
|
||||||
|
{{# def.insertSubschemaCode }}
|
||||||
|
{{ $it.createErrors = true; }}
|
||||||
|
{{# def.resetErrors }}
|
||||||
|
{{# def.resetCompositeRule }}
|
||||||
|
|
||||||
|
{{? $thenPresent }}
|
||||||
|
if ({{=$nextValid}}) {
|
||||||
|
{{# def.validateIfClause:then }}
|
||||||
|
}
|
||||||
|
{{? $elsePresent }}
|
||||||
|
else {
|
||||||
|
{{?}}
|
||||||
|
{{??}}
|
||||||
|
if (!{{=$nextValid}}) {
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{? $elsePresent }}
|
||||||
|
{{# def.validateIfClause:else }}
|
||||||
|
}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
if (!{{=$valid}}) {
|
||||||
|
{{# def.extraError:'if' }}
|
||||||
|
}
|
||||||
|
{{? $breakOnError }} else { {{?}}
|
||||||
|
|
||||||
|
{{# def.cleanUp }}
|
||||||
|
{{??}}
|
||||||
|
{{? $breakOnError }}
|
||||||
|
if (true) {
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
|
100
node_modules/ajv/lib/dot/items.jst
generated
vendored
Normal file
100
node_modules/ajv/lib/dot/items.jst
generated
vendored
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.setupNextLevel }}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.validateItems:startFrom:
|
||||||
|
for (var {{=$idx}} = {{=startFrom}}; {{=$idx}} < {{=$data}}.length; {{=$idx}}++) {
|
||||||
|
{{
|
||||||
|
$it.errorPath = it.util.getPathExpr(it.errorPath, $idx, it.opts.jsonPointers, true);
|
||||||
|
var $passData = $data + '[' + $idx + ']';
|
||||||
|
$it.dataPathArr[$dataNxt] = $idx;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{# def.generateSubschemaCode }}
|
||||||
|
{{# def.optimizeValidate }}
|
||||||
|
|
||||||
|
{{? $breakOnError }}
|
||||||
|
if (!{{=$nextValid}}) break;
|
||||||
|
{{?}}
|
||||||
|
}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $idx = 'i' + $lvl
|
||||||
|
, $dataNxt = $it.dataLevel = it.dataLevel + 1
|
||||||
|
, $nextData = 'data' + $dataNxt
|
||||||
|
, $currentBaseId = it.baseId;
|
||||||
|
}}
|
||||||
|
|
||||||
|
var {{=$errs}} = errors;
|
||||||
|
var {{=$valid}};
|
||||||
|
|
||||||
|
{{? Array.isArray($schema) }}
|
||||||
|
{{ /* 'items' is an array of schemas */}}
|
||||||
|
{{ var $additionalItems = it.schema.additionalItems; }}
|
||||||
|
{{? $additionalItems === false }}
|
||||||
|
{{=$valid}} = {{=$data}}.length <= {{= $schema.length }};
|
||||||
|
{{
|
||||||
|
var $currErrSchemaPath = $errSchemaPath;
|
||||||
|
$errSchemaPath = it.errSchemaPath + '/additionalItems';
|
||||||
|
}}
|
||||||
|
{{# def.checkError:'additionalItems' }}
|
||||||
|
{{ $errSchemaPath = $currErrSchemaPath; }}
|
||||||
|
{{# def.elseIfValid}}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{~ $schema:$sch:$i }}
|
||||||
|
{{? {{# def.nonEmptySchema:$sch }} }}
|
||||||
|
{{=$nextValid}} = true;
|
||||||
|
|
||||||
|
if ({{=$data}}.length > {{=$i}}) {
|
||||||
|
{{
|
||||||
|
var $passData = $data + '[' + $i + ']';
|
||||||
|
$it.schema = $sch;
|
||||||
|
$it.schemaPath = $schemaPath + '[' + $i + ']';
|
||||||
|
$it.errSchemaPath = $errSchemaPath + '/' + $i;
|
||||||
|
$it.errorPath = it.util.getPathExpr(it.errorPath, $i, it.opts.jsonPointers, true);
|
||||||
|
$it.dataPathArr[$dataNxt] = $i;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{# def.generateSubschemaCode }}
|
||||||
|
{{# def.optimizeValidate }}
|
||||||
|
}
|
||||||
|
|
||||||
|
{{# def.ifResultValid }}
|
||||||
|
{{?}}
|
||||||
|
{{~}}
|
||||||
|
|
||||||
|
{{? typeof $additionalItems == 'object' && {{# def.nonEmptySchema:$additionalItems }} }}
|
||||||
|
{{
|
||||||
|
$it.schema = $additionalItems;
|
||||||
|
$it.schemaPath = it.schemaPath + '.additionalItems';
|
||||||
|
$it.errSchemaPath = it.errSchemaPath + '/additionalItems';
|
||||||
|
}}
|
||||||
|
{{=$nextValid}} = true;
|
||||||
|
|
||||||
|
if ({{=$data}}.length > {{= $schema.length }}) {
|
||||||
|
{{# def.validateItems: $schema.length }}
|
||||||
|
}
|
||||||
|
|
||||||
|
{{# def.ifResultValid }}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{?? {{# def.nonEmptySchema:$schema }} }}
|
||||||
|
{{ /* 'items' is a single schema */}}
|
||||||
|
{{
|
||||||
|
$it.schema = $schema;
|
||||||
|
$it.schemaPath = $schemaPath;
|
||||||
|
$it.errSchemaPath = $errSchemaPath;
|
||||||
|
}}
|
||||||
|
{{# def.validateItems: 0 }}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{? $breakOnError }}
|
||||||
|
{{= $closingBraces }}
|
||||||
|
if ({{=$errs}} == errors) {
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{# def.cleanUp }}
|
39
node_modules/ajv/lib/dot/missing.def
generated
vendored
Normal file
39
node_modules/ajv/lib/dot/missing.def
generated
vendored
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
{{## def.checkMissingProperty:_properties:
|
||||||
|
{{~ _properties:$propertyKey:$i }}
|
||||||
|
{{?$i}} || {{?}}
|
||||||
|
{{
|
||||||
|
var $prop = it.util.getProperty($propertyKey)
|
||||||
|
, $useData = $data + $prop;
|
||||||
|
}}
|
||||||
|
( ({{# def.noPropertyInData }}) && (missing{{=$lvl}} = {{= it.util.toQuotedString(it.opts.jsonPointers ? $propertyKey : $prop) }}) )
|
||||||
|
{{~}}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.errorMissingProperty:_error:
|
||||||
|
{{
|
||||||
|
var $propertyPath = 'missing' + $lvl
|
||||||
|
, $missingProperty = '\' + ' + $propertyPath + ' + \'';
|
||||||
|
if (it.opts._errorDataPathProperty) {
|
||||||
|
it.errorPath = it.opts.jsonPointers
|
||||||
|
? it.util.getPathExpr($currentErrorPath, $propertyPath, true)
|
||||||
|
: $currentErrorPath + ' + ' + $propertyPath;
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
{{# def.error:_error }}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.allErrorsMissingProperty:_error:
|
||||||
|
{{
|
||||||
|
var $prop = it.util.getProperty($propertyKey)
|
||||||
|
, $missingProperty = it.util.escapeQuotes($propertyKey)
|
||||||
|
, $useData = $data + $prop;
|
||||||
|
if (it.opts._errorDataPathProperty) {
|
||||||
|
it.errorPath = it.util.getPath($currentErrorPath, $propertyKey, it.opts.jsonPointers);
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
if ({{# def.noPropertyInData }}) {
|
||||||
|
{{# def.addError:_error }}
|
||||||
|
}
|
||||||
|
#}}
|
20
node_modules/ajv/lib/dot/multipleOf.jst
generated
vendored
Normal file
20
node_modules/ajv/lib/dot/multipleOf.jst
generated
vendored
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.$data }}
|
||||||
|
|
||||||
|
var division{{=$lvl}};
|
||||||
|
if ({{?$isData}}
|
||||||
|
{{=$schemaValue}} !== undefined && (
|
||||||
|
typeof {{=$schemaValue}} != 'number' ||
|
||||||
|
{{?}}
|
||||||
|
(division{{=$lvl}} = {{=$data}} / {{=$schemaValue}},
|
||||||
|
{{? it.opts.multipleOfPrecision }}
|
||||||
|
Math.abs(Math.round(division{{=$lvl}}) - division{{=$lvl}}) > 1e-{{=it.opts.multipleOfPrecision}}
|
||||||
|
{{??}}
|
||||||
|
division{{=$lvl}} !== parseInt(division{{=$lvl}})
|
||||||
|
{{?}}
|
||||||
|
)
|
||||||
|
{{?$isData}} ) {{?}} ) {
|
||||||
|
{{# def.error:'multipleOf' }}
|
||||||
|
} {{? $breakOnError }} else { {{?}}
|
43
node_modules/ajv/lib/dot/not.jst
generated
vendored
Normal file
43
node_modules/ajv/lib/dot/not.jst
generated
vendored
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.setupNextLevel }}
|
||||||
|
|
||||||
|
{{? {{# def.nonEmptySchema:$schema }} }}
|
||||||
|
{{
|
||||||
|
$it.schema = $schema;
|
||||||
|
$it.schemaPath = $schemaPath;
|
||||||
|
$it.errSchemaPath = $errSchemaPath;
|
||||||
|
}}
|
||||||
|
|
||||||
|
var {{=$errs}} = errors;
|
||||||
|
|
||||||
|
{{# def.setCompositeRule }}
|
||||||
|
|
||||||
|
{{
|
||||||
|
$it.createErrors = false;
|
||||||
|
var $allErrorsOption;
|
||||||
|
if ($it.opts.allErrors) {
|
||||||
|
$allErrorsOption = $it.opts.allErrors;
|
||||||
|
$it.opts.allErrors = false;
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
{{= it.validate($it) }}
|
||||||
|
{{
|
||||||
|
$it.createErrors = true;
|
||||||
|
if ($allErrorsOption) $it.opts.allErrors = $allErrorsOption;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{# def.resetCompositeRule }}
|
||||||
|
|
||||||
|
if ({{=$nextValid}}) {
|
||||||
|
{{# def.error:'not' }}
|
||||||
|
} else {
|
||||||
|
{{# def.resetErrors }}
|
||||||
|
{{? it.opts.allErrors }} } {{?}}
|
||||||
|
{{??}}
|
||||||
|
{{# def.addError:'not' }}
|
||||||
|
{{? $breakOnError}}
|
||||||
|
if (false) {
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
54
node_modules/ajv/lib/dot/oneOf.jst
generated
vendored
Normal file
54
node_modules/ajv/lib/dot/oneOf.jst
generated
vendored
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.setupNextLevel }}
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $currentBaseId = $it.baseId
|
||||||
|
, $prevValid = 'prevValid' + $lvl
|
||||||
|
, $passingSchemas = 'passingSchemas' + $lvl;
|
||||||
|
}}
|
||||||
|
|
||||||
|
var {{=$errs}} = errors
|
||||||
|
, {{=$prevValid}} = false
|
||||||
|
, {{=$valid}} = false
|
||||||
|
, {{=$passingSchemas}} = null;
|
||||||
|
|
||||||
|
{{# def.setCompositeRule }}
|
||||||
|
|
||||||
|
{{~ $schema:$sch:$i }}
|
||||||
|
{{? {{# def.nonEmptySchema:$sch }} }}
|
||||||
|
{{
|
||||||
|
$it.schema = $sch;
|
||||||
|
$it.schemaPath = $schemaPath + '[' + $i + ']';
|
||||||
|
$it.errSchemaPath = $errSchemaPath + '/' + $i;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{# def.insertSubschemaCode }}
|
||||||
|
{{??}}
|
||||||
|
var {{=$nextValid}} = true;
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{? $i }}
|
||||||
|
if ({{=$nextValid}} && {{=$prevValid}}) {
|
||||||
|
{{=$valid}} = false;
|
||||||
|
{{=$passingSchemas}} = [{{=$passingSchemas}}, {{=$i}}];
|
||||||
|
} else {
|
||||||
|
{{ $closingBraces += '}'; }}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
if ({{=$nextValid}}) {
|
||||||
|
{{=$valid}} = {{=$prevValid}} = true;
|
||||||
|
{{=$passingSchemas}} = {{=$i}};
|
||||||
|
}
|
||||||
|
{{~}}
|
||||||
|
|
||||||
|
{{# def.resetCompositeRule }}
|
||||||
|
|
||||||
|
{{= $closingBraces }}
|
||||||
|
|
||||||
|
if (!{{=$valid}}) {
|
||||||
|
{{# def.extraError:'oneOf' }}
|
||||||
|
} else {
|
||||||
|
{{# def.resetErrors }}
|
||||||
|
{{? it.opts.allErrors }} } {{?}}
|
14
node_modules/ajv/lib/dot/pattern.jst
generated
vendored
Normal file
14
node_modules/ajv/lib/dot/pattern.jst
generated
vendored
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.$data }}
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $regexp = $isData
|
||||||
|
? '(new RegExp(' + $schemaValue + '))'
|
||||||
|
: it.usePattern($schema);
|
||||||
|
}}
|
||||||
|
|
||||||
|
if ({{# def.$dataNotType:'string' }} !{{=$regexp}}.test({{=$data}}) ) {
|
||||||
|
{{# def.error:'pattern' }}
|
||||||
|
} {{? $breakOnError }} else { {{?}}
|
244
node_modules/ajv/lib/dot/properties.jst
generated
vendored
Normal file
244
node_modules/ajv/lib/dot/properties.jst
generated
vendored
Normal file
@ -0,0 +1,244 @@
|
|||||||
|
{{# def.definitions }}
|
||||||
|
{{# def.errors }}
|
||||||
|
{{# def.setupKeyword }}
|
||||||
|
{{# def.setupNextLevel }}
|
||||||
|
|
||||||
|
|
||||||
|
{{## def.validateAdditional:
|
||||||
|
{{ /* additionalProperties is schema */
|
||||||
|
$it.schema = $aProperties;
|
||||||
|
$it.schemaPath = it.schemaPath + '.additionalProperties';
|
||||||
|
$it.errSchemaPath = it.errSchemaPath + '/additionalProperties';
|
||||||
|
$it.errorPath = it.opts._errorDataPathProperty
|
||||||
|
? it.errorPath
|
||||||
|
: it.util.getPathExpr(it.errorPath, $key, it.opts.jsonPointers);
|
||||||
|
var $passData = $data + '[' + $key + ']';
|
||||||
|
$it.dataPathArr[$dataNxt] = $key;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{# def.generateSubschemaCode }}
|
||||||
|
{{# def.optimizeValidate }}
|
||||||
|
#}}
|
||||||
|
|
||||||
|
|
||||||
|
{{
|
||||||
|
var $key = 'key' + $lvl
|
||||||
|
, $idx = 'idx' + $lvl
|
||||||
|
, $dataNxt = $it.dataLevel = it.dataLevel + 1
|
||||||
|
, $nextData = 'data' + $dataNxt
|
||||||
|
, $dataProperties = 'dataProperties' + $lvl;
|
||||||
|
|
||||||
|
var $schemaKeys = Object.keys($schema || {})
|
||||||
|
, $pProperties = it.schema.patternProperties || {}
|
||||||
|
, $pPropertyKeys = Object.keys($pProperties)
|
||||||
|
, $aProperties = it.schema.additionalProperties
|
||||||
|
, $someProperties = $schemaKeys.length || $pPropertyKeys.length
|
||||||
|
, $noAdditional = $aProperties === false
|
||||||
|
, $additionalIsSchema = typeof $aProperties == 'object'
|
||||||
|
&& Object.keys($aProperties).length
|
||||||
|
, $removeAdditional = it.opts.removeAdditional
|
||||||
|
, $checkAdditional = $noAdditional || $additionalIsSchema || $removeAdditional
|
||||||
|
, $ownProperties = it.opts.ownProperties
|
||||||
|
, $currentBaseId = it.baseId;
|
||||||
|
|
||||||
|
var $required = it.schema.required;
|
||||||
|
if ($required && !(it.opts.$data && $required.$data) && $required.length < it.opts.loopRequired)
|
||||||
|
var $requiredHash = it.util.toHash($required);
|
||||||
|
}}
|
||||||
|
|
||||||
|
|
||||||
|
var {{=$errs}} = errors;
|
||||||
|
var {{=$nextValid}} = true;
|
||||||
|
{{? $ownProperties }}
|
||||||
|
var {{=$dataProperties}} = undefined;
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{? $checkAdditional }}
|
||||||
|
{{# def.iterateProperties }}
|
||||||
|
{{? $someProperties }}
|
||||||
|
var isAdditional{{=$lvl}} = !(false
|
||||||
|
{{? $schemaKeys.length }}
|
||||||
|
{{? $schemaKeys.length > 8 }}
|
||||||
|
|| validate.schema{{=$schemaPath}}.hasOwnProperty({{=$key}})
|
||||||
|
{{??}}
|
||||||
|
{{~ $schemaKeys:$propertyKey }}
|
||||||
|
|| {{=$key}} == {{= it.util.toQuotedString($propertyKey) }}
|
||||||
|
{{~}}
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
{{? $pPropertyKeys.length }}
|
||||||
|
{{~ $pPropertyKeys:$pProperty:$i }}
|
||||||
|
|| {{= it.usePattern($pProperty) }}.test({{=$key}})
|
||||||
|
{{~}}
|
||||||
|
{{?}}
|
||||||
|
);
|
||||||
|
|
||||||
|
if (isAdditional{{=$lvl}}) {
|
||||||
|
{{?}}
|
||||||
|
{{? $removeAdditional == 'all' }}
|
||||||
|
delete {{=$data}}[{{=$key}}];
|
||||||
|
{{??}}
|
||||||
|
{{
|
||||||
|
var $currentErrorPath = it.errorPath;
|
||||||
|
var $additionalProperty = '\' + ' + $key + ' + \'';
|
||||||
|
if (it.opts._errorDataPathProperty) {
|
||||||
|
it.errorPath = it.util.getPathExpr(it.errorPath, $key, it.opts.jsonPointers);
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
{{? $noAdditional }}
|
||||||
|
{{? $removeAdditional }}
|
||||||
|
delete {{=$data}}[{{=$key}}];
|
||||||
|
{{??}}
|
||||||
|
{{=$nextValid}} = false;
|
||||||
|
{{
|
||||||
|
var $currErrSchemaPath = $errSchemaPath;
|
||||||
|
$errSchemaPath = it.errSchemaPath + '/additionalProperties';
|
||||||
|
}}
|
||||||
|
{{# def.error:'additionalProperties' }}
|
||||||
|
{{ $errSchemaPath = $currErrSchemaPath; }}
|
||||||
|
{{? $breakOnError }} break; {{?}}
|
||||||
|
{{?}}
|
||||||
|
{{?? $additionalIsSchema }}
|
||||||
|
{{? $removeAdditional == 'failing' }}
|
||||||
|
var {{=$errs}} = errors;
|
||||||
|
{{# def.setCompositeRule }}
|
||||||
|
|
||||||
|
{{# def.validateAdditional }}
|
||||||
|
|
||||||
|
if (!{{=$nextValid}}) {
|
||||||
|
errors = {{=$errs}};
|
||||||
|
if (validate.errors !== null) {
|
||||||
|
if (errors) validate.errors.length = errors;
|
||||||
|
else validate.errors = null;
|
||||||
|
}
|
||||||
|
delete {{=$data}}[{{=$key}}];
|
||||||
|
}
|
||||||
|
|
||||||
|
{{# def.resetCompositeRule }}
|
||||||
|
{{??}}
|
||||||
|
{{# def.validateAdditional }}
|
||||||
|
{{? $breakOnError }} if (!{{=$nextValid}}) break; {{?}}
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
{{ it.errorPath = $currentErrorPath; }}
|
||||||
|
{{?}}
|
||||||
|
{{? $someProperties }}
|
||||||
|
}
|
||||||
|
{{?}}
|
||||||
|
}
|
||||||
|
|
||||||
|
{{# def.ifResultValid }}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{ var $useDefaults = it.opts.useDefaults && !it.compositeRule; }}
|
||||||
|
|
||||||
|
{{? $schemaKeys.length }}
|
||||||
|
{{~ $schemaKeys:$propertyKey }}
|
||||||
|
{{ var $sch = $schema[$propertyKey]; }}
|
||||||
|
|
||||||
|
{{? {{# def.nonEmptySchema:$sch}} }}
|
||||||
|
{{
|
||||||
|
var $prop = it.util.getProperty($propertyKey)
|
||||||
|
, $passData = $data + $prop
|
||||||
|
, $hasDefault = $useDefaults && $sch.default !== undefined;
|
||||||
|
$it.schema = $sch;
|
||||||
|
$it.schemaPath = $schemaPath + $prop;
|
||||||
|
$it.errSchemaPath = $errSchemaPath + '/' + it.util.escapeFragment($propertyKey);
|
||||||
|
$it.errorPath = it.util.getPath(it.errorPath, $propertyKey, it.opts.jsonPointers);
|
||||||
|
$it.dataPathArr[$dataNxt] = it.util.toQuotedString($propertyKey);
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{# def.generateSubschemaCode }}
|
||||||
|
|
||||||
|
{{? {{# def.willOptimize }} }}
|
||||||
|
{{
|
||||||
|
$code = {{# def._optimizeValidate }};
|
||||||
|
var $useData = $passData;
|
||||||
|
}}
|
||||||
|
{{??}}
|
||||||
|
{{ var $useData = $nextData; }}
|
||||||
|
var {{=$nextData}} = {{=$passData}};
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{? $hasDefault }}
|
||||||
|
{{= $code }}
|
||||||
|
{{??}}
|
||||||
|
{{? $requiredHash && $requiredHash[$propertyKey] }}
|
||||||
|
if ({{# def.noPropertyInData }}) {
|
||||||
|
{{=$nextValid}} = false;
|
||||||
|
{{
|
||||||
|
var $currentErrorPath = it.errorPath
|
||||||
|
, $currErrSchemaPath = $errSchemaPath
|
||||||
|
, $missingProperty = it.util.escapeQuotes($propertyKey);
|
||||||
|
if (it.opts._errorDataPathProperty) {
|
||||||
|
it.errorPath = it.util.getPath($currentErrorPath, $propertyKey, it.opts.jsonPointers);
|
||||||
|
}
|
||||||
|
$errSchemaPath = it.errSchemaPath + '/required';
|
||||||
|
}}
|
||||||
|
{{# def.error:'required' }}
|
||||||
|
{{ $errSchemaPath = $currErrSchemaPath; }}
|
||||||
|
{{ it.errorPath = $currentErrorPath; }}
|
||||||
|
} else {
|
||||||
|
{{??}}
|
||||||
|
{{? $breakOnError }}
|
||||||
|
if ({{# def.noPropertyInData }}) {
|
||||||
|
{{=$nextValid}} = true;
|
||||||
|
} else {
|
||||||
|
{{??}}
|
||||||
|
if ({{=$useData}} !== undefined
|
||||||
|
{{? $ownProperties }}
|
||||||
|
&& {{# def.isOwnProperty }}
|
||||||
|
{{?}}
|
||||||
|
) {
|
||||||
|
{{?}}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{= $code }}
|
||||||
|
}
|
||||||
|
{{?}} {{ /* $hasDefault */ }}
|
||||||
|
{{?}} {{ /* def.nonEmptySchema */ }}
|
||||||
|
|
||||||
|
{{# def.ifResultValid }}
|
||||||
|
{{~}}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{? $pPropertyKeys.length }}
|
||||||
|
{{~ $pPropertyKeys:$pProperty }}
|
||||||
|
{{ var $sch = $pProperties[$pProperty]; }}
|
||||||
|
|
||||||
|
{{? {{# def.nonEmptySchema:$sch}} }}
|
||||||
|
{{
|
||||||
|
$it.schema = $sch;
|
||||||
|
$it.schemaPath = it.schemaPath + '.patternProperties' + it.util.getProperty($pProperty);
|
||||||
|
$it.errSchemaPath = it.errSchemaPath + '/patternProperties/'
|
||||||
|
+ it.util.escapeFragment($pProperty);
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{# def.iterateProperties }}
|
||||||
|
if ({{= it.usePattern($pProperty) }}.test({{=$key}})) {
|
||||||
|
{{
|
||||||
|
$it.errorPath = it.util.getPathExpr(it.errorPath, $key, it.opts.jsonPointers);
|
||||||
|
var $passData = $data + '[' + $key + ']';
|
||||||
|
$it.dataPathArr[$dataNxt] = $key;
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{# def.generateSubschemaCode }}
|
||||||
|
{{# def.optimizeValidate }}
|
||||||
|
|
||||||
|
{{? $breakOnError }} if (!{{=$nextValid}}) break; {{?}}
|
||||||
|
}
|
||||||
|
{{? $breakOnError }} else {{=$nextValid}} = true; {{?}}
|
||||||
|
}
|
||||||
|
|
||||||
|
{{# def.ifResultValid }}
|
||||||
|
{{?}} {{ /* def.nonEmptySchema */ }}
|
||||||
|
{{~}}
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
|
||||||
|
{{? $breakOnError }}
|
||||||
|
{{= $closingBraces }}
|
||||||
|
if ({{=$errs}} == errors) {
|
||||||
|
{{?}}
|
||||||
|
|
||||||
|
{{# def.cleanUp }}
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user