Socket
Socket
Sign inDemoInstall

@graphcms/validation

Package Overview
Dependencies
Maintainers
4
Versions
65
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@graphcms/validation - npm Package Compare versions

Comparing version 1.3.7 to 1.3.8

.rpt2_cache/1a3e9eaa4dd2142e502e9aaca51ff27b60073785/code/cache/1cc6d96a6785349adbed1fa0a5655833c720e422

4

dist/field.d.ts

@@ -9,3 +9,3 @@ import * as yup from 'yup';

* .min() -> Sets minimum required length of string to 1 character
* .max() -> Sets maximum required length of string to 32 characters
* .max() -> Sets maximum required length of string to 64 characters
* .test() -> Executes an arbitrary test on the input value

@@ -34,3 +34,3 @@ * .matches(:RegExpr) -> Matches the input value against a regular expression

* .min() -> Sets minimum required length of string to 1 character
* .max() -> Sets maximum required length of string to 32 characters
* .max() -> Sets maximum required length of string to 64 characters
* .test() -> Executes an arbitrary test on the input value

@@ -37,0 +37,0 @@ */

@@ -33,1 +33,2 @@ import * as yup from 'yup';

export declare const modelId: yup.StringSchema;
export declare const previewURLs: yup.ArraySchema<{}>;

@@ -78,3 +78,3 @@ var yup = require('yup');

var apiId$1 = yup.string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'Enter an Api Id.').max(32, 'Use an Api Id that is shorter than 32 characters.').test({
var apiId$1 = yup.string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'Enter an Api Id.').max(64, 'Use an Api Id that is shorter than 64 characters.').test({
name: 'no-graphql-type',

@@ -103,3 +103,3 @@ test: function (value) {

var reverseRelationFieldApiId = apiId$1.concat(yup.string().max(64, 'The API ID of a field may not exceed 64 characters.'));
var displayName$1 = yup.string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'Enter a Display Name.').test('no-letter', 'Enter a Display Name.', function (value) {
var displayName$1 = yup.string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'Enter a Display Name.').max(64, 'The Display Name of a field may not exceed 64characters.').test('no-letter', 'Enter a Display Name.', function (value) {
if (!value) {

@@ -166,2 +166,6 @@ return true;

var modelId = yup.string().strict(true);
var previewURLs = yup.array().of(yup.object().shape({
name: yup.string().required(),
template: yup.string().required()
}).required());

@@ -176,3 +180,4 @@

description: description$3,
modelId: modelId
modelId: modelId,
previewURLs: previewURLs
});

@@ -179,0 +184,0 @@

@@ -1,2 +0,2 @@

import { string, boolean } from 'yup';
import { string, boolean, array, object } from 'yup';

@@ -81,3 +81,3 @@ var name = string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1).ensure().trim('The name of an authentication token may not start or end with white space characters.');

var apiId$1 = string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'Enter an Api Id.').max(32, 'Use an Api Id that is shorter than 32 characters.').test({
var apiId$1 = string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'Enter an Api Id.').max(64, 'Use an Api Id that is shorter than 64 characters.').test({
name: 'no-graphql-type',

@@ -106,3 +106,3 @@ test: function (value) {

var reverseRelationFieldApiId = apiId$1.concat(string().max(64, 'The API ID of a field may not exceed 64 characters.'));
var displayName$1 = string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'Enter a Display Name.').test('no-letter', 'Enter a Display Name.', function (value) {
var displayName$1 = string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'Enter a Display Name.').max(64, 'The Display Name of a field may not exceed 64characters.').test('no-letter', 'Enter a Display Name.', function (value) {
if (!value) {

@@ -121,3 +121,3 @@ return true;

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["field.ts(original)"],"names":[],"mappings":"AAAA,YAAY,SAAS;AACrB,QAAS,kBAAkB,0BAA2B;AAYtD,OAAO,GAAA,CAAI,QAAQ,GAAA,CACd,MADc,EAAA,CAEd,SAFc,CAEJ,wFAFI,CAGd,MAHc,CAGP,KAHO,CAId,GAJc,CAIV,GAAG,mBAJO,CAKd,GALc,CAKV,IAAI,oDALM,CAMd,IANc,CAMT;IACN,MAAM,iBADA,CAAA;IAEN,MAAM,UAAU,OAAO;QACnB,OAAO,CAAC,gBAAA,CAAiB,IAAjB,CAAsB,UAAU,cAAc;YAAE,OAAQ,KAAA,GAAQ,YAAA,CAAA,GAAA,CAAiB,KAAA,CAAM,WAAN,KAAsB;QAAvH;IACA,CAJU,CAAA;IAKN,SAAS,0DALH,CAAA;IAMN,WAAW;EAZI,CAcd,IAdc,CAcT;IACN,MAAM,kBADA,CAAA;IAEN,MAAM,UAAU,OAAO;QACnB,GAAA,CAAI,UAAU,IAAA,CAAK;QACnB,IAAI,OAAA,CAAQ,OAAR,CAAA,EAAA,CAAmB,OAAA,CAAQ,OAAR,CAAgB,UAAU;YAC7C,OAAO;QACnB;QACQ,OAAO,CAAC,mBAAA,CAAoB,IAApB,CAAyB,UAAU,cAAc;YAAE,OAAQ,KAAA,GAAQ,YAAA,CAAA,GAAA,CAAiB,KAAA,CAAM,WAAN,KAAsB;QAA1H;IACA,CARU,CAAA;IASN,SAAS,0DATH,CAAA;IAUN,WAAW;EAxBI,CA0Bd,OA1Bc,CA0BN,wBAAwB;AAYrC,OAAO,GAAA,CAAI,4BAA4B,KAAA,CAAM,MAAN,CAAa,GAAA,CAAI,MAAJ,EAAA,CAAa,GAAb,CAAiB,IAAI;AAWzE,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,SAFoB,CAEV,wFAFU,CAGpB,MAHoB,CAGb,KAHa,CAIpB,GAJoB,CAIhB,GAAG,wBAJa,CAKpB,IALoB,CAKf,aAAa,yBAAyB,UAAU,OAAO;IAC7D,IAAI,CAAC,OAAO;QACR,OAAO;IACf;IACI,IAAI,KAAA,CAAA,EAAA,CAAS,MAAA,CAAO,KAAP,CAAA,GAAA,CAAiB,UAAU;QACpC,OAAO,KAAA,CAAM,OAAN,CAAc,OAAO,GAArB,CAAyB,MAAzB,CAAA,CAAA,CAAkC;IACjD;IACI,OAAO;AACX;AAQA,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,QAFoB,CAEX,KAFW,CAGpB,SAHoB,CAGV,wFAHU,CAIpB,MAJoB;AAKzB,OAAO,GAAA,CAAI,SAAS,GAAA,CACf,OADe,EAAA,CAEf,MAFe,CAER,KAFQ,CAGf,SAHe,CAGL;AACf,OAAO,GAAA,CAAI,WAAW,GAAA,CACjB,OADiB,EAAA,CAEjB,MAFiB,CAEV,KAFU,CAGjB,SAHiB,CAGP;AA/Ff","file":"field.ts(original)","sourcesContent":["import * as yup from 'yup';\r\nimport { graphQlTypeNames, reservedFieldApiIds } from './reservedWords';\r\n/**\r\n * Matcher for field api IDs:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .strict(:boolean)  -> Prevents manipulation of the string during validation\r\n * .min()             -> Sets minimum required length of string to 1 character\r\n * .max()             -> Sets maximum required length of string to 32 characters\r\n * .test()            -> Executes an arbitrary test on the input value\r\n * .matches(:RegExpr) -> Matches the input value against a regular expression\r\n */\r\nexport var apiId = yup\r\n    .string()\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"string\"!')\r\n    .strict(true)\r\n    .min(1, 'Enter an Api Id.')\r\n    .max(32, 'Use an Api Id that is shorter than 32 characters.')\r\n    .test({\r\n    name: 'no-graphql-type',\r\n    test: function (value) {\r\n        return !graphQlTypeNames.some(function (reservedWord) { return (value ? reservedWord === value.toLowerCase() : false); });\r\n    },\r\n    message: '\"${value}\" is a restricted word and cannot be used here.',\r\n    exclusive: false,\r\n})\r\n    .test({\r\n    name: 'no-reserved-word',\r\n    test: function (value) {\r\n        var options = this.options;\r\n        if (options.context && options.context.isSystem) {\r\n            return true;\r\n        }\r\n        return !reservedFieldApiIds.some(function (reservedWord) { return (value ? reservedWord === value.toLowerCase() : false); });\r\n    },\r\n    message: '\"${value}\" is a restricted word and cannot be used here.',\r\n    exclusive: false,\r\n})\r\n    .matches(/^[a-z][a-zA-Z0-9_]*$/, 'Start with a lowercase letter and use only alphanumeric characters and underscores.'); // <-- Those are validations enforced by prisma: https://github.com/graphcool/prisma/blob/master/server/servers/deploy/src/main/scala/com/prisma/deploy/validation/NameConstraints.scala\r\n/**\r\n * Matcher for field api IDs for the reverse relation side:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .strict(:boolean)  -> Prevents manipulation of the string during validation\r\n * .min()             -> Sets minimum required length of string to 1 character\r\n * .max()             -> Sets maximum required length of string to 64 characters\r\n * .test()            -> Executes an arbitrary test on the input value\r\n * .matches(:RegExpr) -> Matches the input value against a regular expression\r\n */\r\nexport var reverseRelationFieldApiId = apiId.concat(yup.string().max(64, 'The API ID of a field may not exceed 64 characters.'));\r\n/**\r\n * Matcher for field display names:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .strict(:boolean)  -> Prevents manipulation of the string during validation\r\n * .min()             -> Sets minimum required length of string to 1 character\r\n * .max()             -> Sets maximum required length of string to 32 characters\r\n * .test()            -> Executes an arbitrary test on the input value\r\n */\r\nexport var displayName = yup\r\n    .string()\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"string\"!')\r\n    .strict(true)\r\n    .min(1, 'Enter a Display Name.')\r\n    .test('no-letter', 'Enter a Display Name.', function (value) {\r\n    if (!value) {\r\n        return true;\r\n    }\r\n    if (value && typeof value === 'string') {\r\n        return value.replace(/\\s/g, '').length > 0;\r\n    }\r\n    return false;\r\n});\r\n/**\r\n * Matcher for field descriptions:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .ensure()          -> Transforms the values \"undefined\" and \"null\" into empty strings\r\n */\r\nexport var description = yup\r\n    .string()\r\n    .nullable(true)\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"string\"!')\r\n    .ensure();\r\nexport var isList = yup\r\n    .boolean()\r\n    .strict(true)\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"boolean\"!');\r\nexport var isHidden = yup\r\n    .boolean()\r\n    .strict(true)\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"boolean\"!');\r\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["field.ts(original)"],"names":[],"mappings":"AAAA,YAAY,SAAS;AACrB,QAAS,kBAAkB,0BAA2B;AAYtD,OAAO,GAAA,CAAI,QAAQ,GAAA,CACd,MADc,EAAA,CAEd,SAFc,CAEJ,wFAFI,CAGd,MAHc,CAGP,KAHO,CAId,GAJc,CAIV,GAAG,mBAJO,CAKd,GALc,CAKV,IAAI,oDALM,CAMd,IANc,CAMT;IACN,MAAM,iBADA,CAAA;IAEN,MAAM,UAAU,OAAO;QACnB,OAAO,CAAC,gBAAA,CAAiB,IAAjB,CAAsB,UAAU,cAAc;YAAE,OAAQ,KAAA,GAAQ,YAAA,CAAA,GAAA,CAAiB,KAAA,CAAM,WAAN,KAAsB;QAAvH;IACA,CAJU,CAAA;IAKN,SAAS,0DALH,CAAA;IAMN,WAAW;EAZI,CAcd,IAdc,CAcT;IACN,MAAM,kBADA,CAAA;IAEN,MAAM,UAAU,OAAO;QACnB,GAAA,CAAI,UAAU,IAAA,CAAK;QACnB,IAAI,OAAA,CAAQ,OAAR,CAAA,EAAA,CAAmB,OAAA,CAAQ,OAAR,CAAgB,UAAU;YAC7C,OAAO;QACnB;QACQ,OAAO,CAAC,mBAAA,CAAoB,IAApB,CAAyB,UAAU,cAAc;YAAE,OAAQ,KAAA,GAAQ,YAAA,CAAA,GAAA,CAAiB,KAAA,CAAM,WAAN,KAAsB;QAA1H;IACA,CARU,CAAA;IASN,SAAS,0DATH,CAAA;IAUN,WAAW;EAxBI,CA0Bd,OA1Bc,CA0BN,wBAAwB;AAYrC,OAAO,GAAA,CAAI,4BAA4B,KAAA,CAAM,MAAN,CAAa,GAAA,CAAI,MAAJ,EAAA,CAAa,GAAb,CAAiB,IAAI;AAWzE,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,SAFoB,CAEV,wFAFU,CAGpB,MAHoB,CAGb,KAHa,CAIpB,GAJoB,CAIhB,GAAG,wBAJa,CAKpB,GALoB,CAKhB,IAAI,2DALY,CAMpB,IANoB,CAMf,aAAa,yBAAyB,UAAU,OAAO;IAC7D,IAAI,CAAC,OAAO;QACR,OAAO;IACf;IACI,IAAI,KAAA,CAAA,EAAA,CAAS,MAAA,CAAO,KAAP,CAAA,GAAA,CAAiB,UAAU;QACpC,OAAO,KAAA,CAAM,OAAN,CAAc,OAAO,GAArB,CAAyB,MAAzB,CAAA,CAAA,CAAkC;IACjD;IACI,OAAO;AACX;AAQA,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,QAFoB,CAEX,KAFW,CAGpB,SAHoB,CAGV,wFAHU,CAIpB,MAJoB;AAKzB,OAAO,GAAA,CAAI,SAAS,GAAA,CACf,OADe,EAAA,CAEf,MAFe,CAER,KAFQ,CAGf,SAHe,CAGL;AACf,OAAO,GAAA,CAAI,WAAW,GAAA,CACjB,OADiB,EAAA,CAEjB,MAFiB,CAEV,KAFU,CAGjB,SAHiB,CAGP;AAhGf","file":"field.ts(original)","sourcesContent":["import * as yup from 'yup';\r\nimport { graphQlTypeNames, reservedFieldApiIds } from './reservedWords';\r\n/**\r\n * Matcher for field api IDs:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .strict(:boolean)  -> Prevents manipulation of the string during validation\r\n * .min()             -> Sets minimum required length of string to 1 character\r\n * .max()             -> Sets maximum required length of string to 64 characters\r\n * .test()            -> Executes an arbitrary test on the input value\r\n * .matches(:RegExpr) -> Matches the input value against a regular expression\r\n */\r\nexport var apiId = yup\r\n    .string()\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"string\"!')\r\n    .strict(true)\r\n    .min(1, 'Enter an Api Id.')\r\n    .max(64, 'Use an Api Id that is shorter than 64 characters.')\r\n    .test({\r\n    name: 'no-graphql-type',\r\n    test: function (value) {\r\n        return !graphQlTypeNames.some(function (reservedWord) { return (value ? reservedWord === value.toLowerCase() : false); });\r\n    },\r\n    message: '\"${value}\" is a restricted word and cannot be used here.',\r\n    exclusive: false,\r\n})\r\n    .test({\r\n    name: 'no-reserved-word',\r\n    test: function (value) {\r\n        var options = this.options;\r\n        if (options.context && options.context.isSystem) {\r\n            return true;\r\n        }\r\n        return !reservedFieldApiIds.some(function (reservedWord) { return (value ? reservedWord === value.toLowerCase() : false); });\r\n    },\r\n    message: '\"${value}\" is a restricted word and cannot be used here.',\r\n    exclusive: false,\r\n})\r\n    .matches(/^[a-z][a-zA-Z0-9_]*$/, 'Start with a lowercase letter and use only alphanumeric characters and underscores.'); // <-- Those are validations enforced by prisma: https://github.com/graphcool/prisma/blob/master/server/servers/deploy/src/main/scala/com/prisma/deploy/validation/NameConstraints.scala\r\n/**\r\n * Matcher for field api IDs for the reverse relation side:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .strict(:boolean)  -> Prevents manipulation of the string during validation\r\n * .min()             -> Sets minimum required length of string to 1 character\r\n * .max()             -> Sets maximum required length of string to 64 characters\r\n * .test()            -> Executes an arbitrary test on the input value\r\n * .matches(:RegExpr) -> Matches the input value against a regular expression\r\n */\r\nexport var reverseRelationFieldApiId = apiId.concat(yup.string().max(64, 'The API ID of a field may not exceed 64 characters.'));\r\n/**\r\n * Matcher for field display names:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .strict(:boolean)  -> Prevents manipulation of the string during validation\r\n * .min()             -> Sets minimum required length of string to 1 character\r\n * .max()             -> Sets maximum required length of string to 64 characters\r\n * .test()            -> Executes an arbitrary test on the input value\r\n */\r\nexport var displayName = yup\r\n    .string()\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"string\"!')\r\n    .strict(true)\r\n    .min(1, 'Enter a Display Name.')\r\n    .max(64, 'The Display Name of a field may not exceed 64characters.')\r\n    .test('no-letter', 'Enter a Display Name.', function (value) {\r\n    if (!value) {\r\n        return true;\r\n    }\r\n    if (value && typeof value === 'string') {\r\n        return value.replace(/\\s/g, '').length > 0;\r\n    }\r\n    return false;\r\n});\r\n/**\r\n * Matcher for field descriptions:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .ensure()          -> Transforms the values \"undefined\" and \"null\" into empty strings\r\n */\r\nexport var description = yup\r\n    .string()\r\n    .nullable(true)\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"string\"!')\r\n    .ensure();\r\nexport var isList = yup\r\n    .boolean()\r\n    .strict(true)\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"boolean\"!');\r\nexport var isHidden = yup\r\n    .boolean()\r\n    .strict(true)\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"boolean\"!');\r\n"]}

@@ -170,5 +170,9 @@

var modelId = string().strict(true);
var previewURLs = array().of(object().shape({
name: string().required(),
template: string().required()
}).required());
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm1vZGVsLnRzKG9yaWdpbmFsKSJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxZQUFZLFNBQVM7QUFDckIsUUFBUyxrQkFBa0IsMEJBQTJCO0FBYXRELE9BQU8sR0FBQSxDQUFJLFFBQVEsR0FBQSxDQUNkLE1BRGMsRUFBQSxDQUVkLFNBRmMsQ0FFSix3RkFGSSxDQUdkLE1BSGMsQ0FHUCxLQUhPLENBSWQsR0FKYyxDQUlWLEdBQUcsbUJBSk8sQ0FLZCxHQUxjLENBS1YsSUFBSSxvREFMTSxDQU1kLElBTmMsQ0FNVDtJQUNOLE1BQU0saUJBREEsQ0FBQTtJQUVOLE1BQU0sVUFBVSxPQUFPO1FBQ25CLE9BQU8sQ0FBQyxnQkFBQSxDQUFpQixJQUFqQixDQUFzQixVQUFVLGNBQWM7WUFBRSxPQUFRLEtBQUEsR0FBUSxZQUFBLENBQUEsR0FBQSxDQUFpQixLQUFBLENBQU0sV0FBTixLQUFzQjtRQUF2SDtJQUNBLENBSlUsQ0FBQTtJQUtOLFNBQVMsMERBTEgsQ0FBQTtJQU1OLFdBQVc7RUFaSSxDQWNkLElBZGMsQ0FjVDtJQUNOLE1BQU0sa0JBREEsQ0FBQTtJQUVOLE1BQU0sVUFBVSxPQUFPO1FBQ25CLEdBQUEsQ0FBSSxVQUFVLElBQUEsQ0FBSztRQUNuQixJQUFJLE9BQUEsQ0FBUSxPQUFSLENBQUEsRUFBQSxDQUFtQixPQUFBLENBQVEsT0FBUixDQUFnQixVQUFVO1lBQzdDLE9BQU87UUFDbkI7UUFDUSxPQUFPLENBQUMsbUJBQUEsQ0FBb0IsSUFBcEIsQ0FBeUIsVUFBVSxjQUFjO1lBQ3JELE9BQU8sS0FBQSxHQUFRLFlBQUEsQ0FBYSxXQUFiLEVBQUEsQ0FBQSxHQUFBLENBQStCLEtBQUEsQ0FBTSxXQUFOLEtBQXNCO1FBQ2hGO0lBQ0EsQ0FWVSxDQUFBO0lBV04sU0FBUywwREFYSCxDQUFBO0lBWU4sV0FBVztFQTFCSSxDQTRCZCxPQTVCYyxDQTRCTix3QkFBd0I7QUFTckMsT0FBTyxHQUFBLENBQUksY0FBYyxHQUFBLENBQ3BCLE1BRG9CLEVBQUEsQ0FFcEIsU0FGb0IsQ0FFVix3RkFGVSxDQUdwQixNQUhvQixDQUdiLEtBSGEsQ0FJcEIsR0FKb0IsQ0FJaEIsR0FBRyx1QkFKYSxDQUtwQixJQUxvQixDQUtmO0FBUVYsT0FBTyxHQUFBLENBQUksY0FBYyxHQUFBLENBQ3BCLE1BRG9CLEVBQUEsQ0FFcEIsU0FGb0IsQ0FFVix3RkFGVSxDQUdwQixNQUhvQjtBQUl6QixPQUFPLEdBQUEsQ0FBSSxVQUFVLEdBQUEsQ0FBSSxNQUFKLEVBQUEsQ0FBYSxNQUFiLENBQW9CO0FBcEV6QyIsImZpbGUiOiJtb2RlbC50cyhvcmlnaW5hbCkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyB5dXAgZnJvbSAneXVwJztcclxuaW1wb3J0IHsgZ3JhcGhRbFR5cGVOYW1lcywgcmVzZXJ2ZWRNb2RlbEFwaUlkcyB9IGZyb20gJy4vcmVzZXJ2ZWRXb3Jkcyc7XHJcbi8qKlxyXG4gKiBNYXRjaGVyIGZvciBtb2RlbCBhcGkgSURzOlxyXG4gKlxyXG4gKiAuc3RyaW5nKCkgICAgICAgICAgLT4gRW5zdXJlcyB0aGF0IG9ubHkgc3RyaW5ncyBjYW4gYmUgdmFsaWRhdGVkIHdpdGggc3VjY2Vzc1xyXG4gKiAudHlwZUVycm9yKDpzdHJpbmcpLT4gRW5zdXJlcyB0aGF0IHR5cGVzIG90aGVyIHRoYW4gc3RyaW5nIHJldHVybiBmYWxzZVxyXG4gKiAuc3RyaWN0KDpib29sZWFuKSAgLT4gUHJldmVudHMgbWFuaXB1bGF0aW9uIG9mIHRoZSBzdHJpbmcgZHVyaW5nIHZhbGlkYXRpb25cclxuICogLm1pbigpICAgICAgICAgICAgIC0+IFNldHMgbWluaW11bSByZXF1aXJlZCBsZW5ndGggb2Ygc3RyaW5nIHRvIDEgY2hhcmFjdGVyXHJcbiAqIC5tYXgoKSAgICAgICAgICAgICAtPiBTZXRzIG1heGltdW0gcmVxdWlyZWQgbGVuZ3RoIG9mIHN0cmluZyB0byA2NCBjaGFyYWN0ZXJzXHJcbiAqIC5yZXF1aXJlZCgpICAgICAgICAtPiBFbnN1cmVzIHRoYXQgZW1wdHkgc3RyaW5ncyBhcmUgdHJlYXRlZCBhcyBpbnZhbGlkIHZhbHVlXHJcbiAqIC50ZXN0KCkgICAgICAgICAgICAtPiBFeGVjdXRlcyBhbiBhcmJpdHJhcnkgdGVzdCBvbiB0aGUgaW5wdXQgdmFsdWVcclxuICogLm1hdGNoZXMoOlJlZ0V4cHIpIC0+IE1hdGNoZXMgdGhlIGlucHV0IHZhbHVlIGFnYWluc3QgYSByZWd1bGFyIGV4cHJlc3Npb25cclxuICovXHJcbmV4cG9ydCB2YXIgYXBpSWQgPSB5dXBcclxuICAgIC5zdHJpbmcoKVxyXG4gICAgLnR5cGVFcnJvcignVGhlIHN1cHBsaWVkIHZhbHVlIFwiJHt2YWx1ZX1cIiBvZiB0eXBlIFwiJHt0eXBlfVwiIGlzIG5vdCBjb21wYXRpYmxlIHdpdGggdHlwZSBcInN0cmluZ1wiIScpXHJcbiAgICAuc3RyaWN0KHRydWUpXHJcbiAgICAubWluKDEsICdFbnRlciBhbiBBcGkgSUQuJylcclxuICAgIC5tYXgoNjQsICdVc2UgYW4gQXBpIElkIHRoYXQgaXMgc2hvcnRlciB0aGFuIDY0IGNoYXJhY3RlcnMuJylcclxuICAgIC50ZXN0KHtcclxuICAgIG5hbWU6ICduby1ncmFwaHFsLXR5cGUnLFxyXG4gICAgdGVzdDogZnVuY3Rpb24gKHZhbHVlKSB7XHJcbiAgICAgICAgcmV0dXJuICFncmFwaFFsVHlwZU5hbWVzLnNvbWUoZnVuY3Rpb24gKHJlc2VydmVkV29yZCkgeyByZXR1cm4gKHZhbHVlID8gcmVzZXJ2ZWRXb3JkID09PSB2YWx1ZS50b0xvd2VyQ2FzZSgpIDogZmFsc2UpOyB9KTtcclxuICAgIH0sXHJcbiAgICBtZXNzYWdlOiAnXCIke3ZhbHVlfVwiIGlzIGEgcmVzdHJpY3RlZCB3b3JkIGFuZCBjYW5ub3QgYmUgdXNlZCBoZXJlLicsXHJcbiAgICBleGNsdXNpdmU6IGZhbHNlLFxyXG59KVxyXG4gICAgLnRlc3Qoe1xyXG4gICAgbmFtZTogJ25vLXJlc2VydmVkLXdvcmQnLFxyXG4gICAgdGVzdDogZnVuY3Rpb24gKHZhbHVlKSB7XHJcbiAgICAgICAgdmFyIG9wdGlvbnMgPSB0aGlzLm9wdGlvbnM7XHJcbiAgICAgICAgaWYgKG9wdGlvbnMuY29udGV4dCAmJiBvcHRpb25zLmNvbnRleHQuaXNTeXN0ZW0pIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiAhcmVzZXJ2ZWRNb2RlbEFwaUlkcy5zb21lKGZ1bmN0aW9uIChyZXNlcnZlZFdvcmQpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHZhbHVlID8gcmVzZXJ2ZWRXb3JkLnRvTG93ZXJDYXNlKCkgPT09IHZhbHVlLnRvTG93ZXJDYXNlKCkgOiBmYWxzZTtcclxuICAgICAgICB9KTtcclxuICAgIH0sXHJcbiAgICBtZXNzYWdlOiAnXCIke3ZhbHVlfVwiIGlzIGEgcmVzdHJpY3RlZCB3b3JkIGFuZCBjYW5ub3QgYmUgdXNlZCBoZXJlLicsXHJcbiAgICBleGNsdXNpdmU6IGZhbHNlLFxyXG59KVxyXG4gICAgLm1hdGNoZXMoL15bQS1aXVthLXpBLVowLTlfXSokLywgJ1N0YXJ0IHdpdGggYSBjYXBpdGFsIGxldHRlciBhbmQgdXNlIG9ubHkgYWxwaGFudW1lcmljIGNoYXJhY3RlcnMgYW5kIHVuZGVyc2NvcmVzLicpOyAvLyA8LS0gVGhvc2UgYXJlIHZhbGlkYXRpb25zIGVuZm9yY2VkIGJ5IHByaXNtYTogaHR0cHM6Ly9naXRodWIuY29tL2dyYXBoY29vbC9wcmlzbWEvYmxvYi9tYXN0ZXIvc2VydmVyL3NlcnZlcnMvZGVwbG95L3NyYy9tYWluL3NjYWxhL2NvbS9wcmlzbWEvZGVwbG95L3ZhbGlkYXRpb24vTmFtZUNvbnN0cmFpbnRzLnNjYWxhXHJcbi8qKlxyXG4gKiBNYXRjaGVyIGZvciBtb2RlbCBkaXNwbGF5IG5hbWVzOlxyXG4gKlxyXG4gKiAuc3RyaW5nKCkgICAgICAgICAgLT4gRW5zdXJlcyB0aGF0IG9ubHkgc3RyaW5ncyBjYW4gYmUgdmFsaWRhdGVkIHdpdGggc3VjY2Vzc1xyXG4gKiAudHlwZUVycm9yKDpzdHJpbmcpLT4gRW5zdXJlcyB0aGF0IHR5cGVzIG90aGVyIHRoYW4gc3RyaW5nIHJldHVybiBmYWxzZVxyXG4gKiAuc3RyaWN0KDpib29sZWFuKSAgLT4gUHJldmVudHMgbWFuaXB1bGF0aW9uIG9mIHRoZSBzdHJpbmcgZHVyaW5nIHZhbGlkYXRpb25cclxuICogLnJlcXVpcmVkKCkgICAgICAgIC0+IEVuc3VyZXMgdGhhdCBlbXB0eSBzdHJpbmdzIGFyZSB0cmVhdGVkIGFzIGludmFsaWQgdmFsdWVcclxuICovXHJcbmV4cG9ydCB2YXIgZGlzcGxheU5hbWUgPSB5dXBcclxuICAgIC5zdHJpbmcoKVxyXG4gICAgLnR5cGVFcnJvcignVGhlIHN1cHBsaWVkIHZhbHVlIFwiJHt2YWx1ZX1cIiBvZiB0eXBlIFwiJHt0eXBlfVwiIGlzIG5vdCBjb21wYXRpYmxlIHdpdGggdHlwZSBcInN0cmluZ1wiIScpXHJcbiAgICAuc3RyaWN0KHRydWUpXHJcbiAgICAubWluKDEsICdFbnRlciBhIERpc3BsYXkgTmFtZScpXHJcbiAgICAudHJpbSgnRGlzcGxheSBuYW1lcyBtYXkgbm90IGhhdmUgbGVhZGluZyBvciB0cmFpbGluZyB3aGl0ZXNwYWNlcy4nKTtcclxuLyoqXHJcbiAqIE1hdGNoZXIgZm9yIG1vZGVsIGRlc2NyaXB0aW9uczpcclxuICpcclxuICogLnN0cmluZygpICAgICAgICAgIC0+IEVuc3VyZXMgdGhhdCBvbmx5IHN0cmluZ3MgY2FuIGJlIHZhbGlkYXRlZCB3aXRoIHN1Y2Nlc3NcclxuICogLnR5cGVFcnJvcig6c3RyaW5nKS0+IEVuc3VyZXMgdGhhdCB0eXBlcyBvdGhlciB0aGFuIHN0cmluZyByZXR1cm4gZmFsc2VcclxuICogLmVuc3VyZSgpICAgICAgICAgIC0+IFRyYW5zZm9ybXMgdGhlIHZhbHVlcyBcInVuZGVmaW5lZFwiIGFuZCBcIm51bGxcIiBpbnRvIGVtcHR5IHN0cmluZ3NcclxuICovXHJcbmV4cG9ydCB2YXIgZGVzY3JpcHRpb24gPSB5dXBcclxuICAgIC5zdHJpbmcoKVxyXG4gICAgLnR5cGVFcnJvcignVGhlIHN1cHBsaWVkIHZhbHVlIFwiJHt2YWx1ZX1cIiBvZiB0eXBlIFwiJHt0eXBlfVwiIGlzIG5vdCBjb21wYXRpYmxlIHdpdGggdHlwZSBcInN0cmluZ1wiIScpXHJcbiAgICAuZW5zdXJlKCk7XHJcbmV4cG9ydCB2YXIgbW9kZWxJZCA9IHl1cC5zdHJpbmcoKS5zdHJpY3QodHJ1ZSk7XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm1vZGVsLnRzKG9yaWdpbmFsKSJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxZQUFZLFNBQVM7QUFDckIsUUFBUyxrQkFBa0IsMEJBQTJCO0FBYXRELE9BQU8sR0FBQSxDQUFJLFFBQVEsR0FBQSxDQUNkLE1BRGMsRUFBQSxDQUVkLFNBRmMsQ0FFSix3RkFGSSxDQUdkLE1BSGMsQ0FHUCxLQUhPLENBSWQsR0FKYyxDQUlWLEdBQUcsbUJBSk8sQ0FLZCxHQUxjLENBS1YsSUFBSSxvREFMTSxDQU1kLElBTmMsQ0FNVDtJQUNOLE1BQU0saUJBREEsQ0FBQTtJQUVOLE1BQU0sVUFBVSxPQUFPO1FBQ25CLE9BQU8sQ0FBQyxnQkFBQSxDQUFpQixJQUFqQixDQUFzQixVQUFVLGNBQWM7WUFBRSxPQUFRLEtBQUEsR0FBUSxZQUFBLENBQUEsR0FBQSxDQUFpQixLQUFBLENBQU0sV0FBTixLQUFzQjtRQUF2SDtJQUNBLENBSlUsQ0FBQTtJQUtOLFNBQVMsMERBTEgsQ0FBQTtJQU1OLFdBQVc7RUFaSSxDQWNkLElBZGMsQ0FjVDtJQUNOLE1BQU0sa0JBREEsQ0FBQTtJQUVOLE1BQU0sVUFBVSxPQUFPO1FBQ25CLEdBQUEsQ0FBSSxVQUFVLElBQUEsQ0FBSztRQUNuQixJQUFJLE9BQUEsQ0FBUSxPQUFSLENBQUEsRUFBQSxDQUFtQixPQUFBLENBQVEsT0FBUixDQUFnQixVQUFVO1lBQzdDLE9BQU87UUFDbkI7UUFDUSxPQUFPLENBQUMsbUJBQUEsQ0FBb0IsSUFBcEIsQ0FBeUIsVUFBVSxjQUFjO1lBQ3JELE9BQU8sS0FBQSxHQUFRLFlBQUEsQ0FBYSxXQUFiLEVBQUEsQ0FBQSxHQUFBLENBQStCLEtBQUEsQ0FBTSxXQUFOLEtBQXNCO1FBQ2hGO0lBQ0EsQ0FWVSxDQUFBO0lBV04sU0FBUywwREFYSCxDQUFBO0lBWU4sV0FBVztFQTFCSSxDQTRCZCxPQTVCYyxDQTRCTix3QkFBd0I7QUFTckMsT0FBTyxHQUFBLENBQUksY0FBYyxHQUFBLENBQ3BCLE1BRG9CLEVBQUEsQ0FFcEIsU0FGb0IsQ0FFVix3RkFGVSxDQUdwQixNQUhvQixDQUdiLEtBSGEsQ0FJcEIsR0FKb0IsQ0FJaEIsR0FBRyx1QkFKYSxDQUtwQixJQUxvQixDQUtmO0FBUVYsT0FBTyxHQUFBLENBQUksY0FBYyxHQUFBLENBQ3BCLE1BRG9CLEVBQUEsQ0FFcEIsU0FGb0IsQ0FFVix3RkFGVSxDQUdwQixNQUhvQjtBQUl6QixPQUFPLEdBQUEsQ0FBSSxVQUFVLEdBQUEsQ0FBSSxNQUFKLEVBQUEsQ0FBYSxNQUFiLENBQW9CO0FBQ3pDLE9BQU8sR0FBQSxDQUFJLGNBQWMsR0FBQSxDQUFJLEtBQUosRUFBQSxDQUFZLEVBQVosQ0FBZSxHQUFBLENBQ25DLE1BRG1DLEVBQUEsQ0FFbkMsS0FGbUMsQ0FFN0I7SUFDUCxNQUFNLEdBQUEsQ0FBSSxNQUFKLEVBQUEsQ0FBYSxRQUFiLEVBREMsQ0FBQTtJQUVQLFVBQVUsR0FBQSxDQUFJLE1BQUosRUFBQSxDQUFhLFFBQWI7RUFKMEIsQ0FNbkMsUUFObUM7QUFyRXhDIiwiZmlsZSI6Im1vZGVsLnRzKG9yaWdpbmFsKSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHl1cCBmcm9tICd5dXAnO1xyXG5pbXBvcnQgeyBncmFwaFFsVHlwZU5hbWVzLCByZXNlcnZlZE1vZGVsQXBpSWRzIH0gZnJvbSAnLi9yZXNlcnZlZFdvcmRzJztcclxuLyoqXHJcbiAqIE1hdGNoZXIgZm9yIG1vZGVsIGFwaSBJRHM6XHJcbiAqXHJcbiAqIC5zdHJpbmcoKSAgICAgICAgICAtPiBFbnN1cmVzIHRoYXQgb25seSBzdHJpbmdzIGNhbiBiZSB2YWxpZGF0ZWQgd2l0aCBzdWNjZXNzXHJcbiAqIC50eXBlRXJyb3IoOnN0cmluZyktPiBFbnN1cmVzIHRoYXQgdHlwZXMgb3RoZXIgdGhhbiBzdHJpbmcgcmV0dXJuIGZhbHNlXHJcbiAqIC5zdHJpY3QoOmJvb2xlYW4pICAtPiBQcmV2ZW50cyBtYW5pcHVsYXRpb24gb2YgdGhlIHN0cmluZyBkdXJpbmcgdmFsaWRhdGlvblxyXG4gKiAubWluKCkgICAgICAgICAgICAgLT4gU2V0cyBtaW5pbXVtIHJlcXVpcmVkIGxlbmd0aCBvZiBzdHJpbmcgdG8gMSBjaGFyYWN0ZXJcclxuICogLm1heCgpICAgICAgICAgICAgIC0+IFNldHMgbWF4aW11bSByZXF1aXJlZCBsZW5ndGggb2Ygc3RyaW5nIHRvIDY0IGNoYXJhY3RlcnNcclxuICogLnJlcXVpcmVkKCkgICAgICAgIC0+IEVuc3VyZXMgdGhhdCBlbXB0eSBzdHJpbmdzIGFyZSB0cmVhdGVkIGFzIGludmFsaWQgdmFsdWVcclxuICogLnRlc3QoKSAgICAgICAgICAgIC0+IEV4ZWN1dGVzIGFuIGFyYml0cmFyeSB0ZXN0IG9uIHRoZSBpbnB1dCB2YWx1ZVxyXG4gKiAubWF0Y2hlcyg6UmVnRXhwcikgLT4gTWF0Y2hlcyB0aGUgaW5wdXQgdmFsdWUgYWdhaW5zdCBhIHJlZ3VsYXIgZXhwcmVzc2lvblxyXG4gKi9cclxuZXhwb3J0IHZhciBhcGlJZCA9IHl1cFxyXG4gICAgLnN0cmluZygpXHJcbiAgICAudHlwZUVycm9yKCdUaGUgc3VwcGxpZWQgdmFsdWUgXCIke3ZhbHVlfVwiIG9mIHR5cGUgXCIke3R5cGV9XCIgaXMgbm90IGNvbXBhdGlibGUgd2l0aCB0eXBlIFwic3RyaW5nXCIhJylcclxuICAgIC5zdHJpY3QodHJ1ZSlcclxuICAgIC5taW4oMSwgJ0VudGVyIGFuIEFwaSBJRC4nKVxyXG4gICAgLm1heCg2NCwgJ1VzZSBhbiBBcGkgSWQgdGhhdCBpcyBzaG9ydGVyIHRoYW4gNjQgY2hhcmFjdGVycy4nKVxyXG4gICAgLnRlc3Qoe1xyXG4gICAgbmFtZTogJ25vLWdyYXBocWwtdHlwZScsXHJcbiAgICB0ZXN0OiBmdW5jdGlvbiAodmFsdWUpIHtcclxuICAgICAgICByZXR1cm4gIWdyYXBoUWxUeXBlTmFtZXMuc29tZShmdW5jdGlvbiAocmVzZXJ2ZWRXb3JkKSB7IHJldHVybiAodmFsdWUgPyByZXNlcnZlZFdvcmQgPT09IHZhbHVlLnRvTG93ZXJDYXNlKCkgOiBmYWxzZSk7IH0pO1xyXG4gICAgfSxcclxuICAgIG1lc3NhZ2U6ICdcIiR7dmFsdWV9XCIgaXMgYSByZXN0cmljdGVkIHdvcmQgYW5kIGNhbm5vdCBiZSB1c2VkIGhlcmUuJyxcclxuICAgIGV4Y2x1c2l2ZTogZmFsc2UsXHJcbn0pXHJcbiAgICAudGVzdCh7XHJcbiAgICBuYW1lOiAnbm8tcmVzZXJ2ZWQtd29yZCcsXHJcbiAgICB0ZXN0OiBmdW5jdGlvbiAodmFsdWUpIHtcclxuICAgICAgICB2YXIgb3B0aW9ucyA9IHRoaXMub3B0aW9ucztcclxuICAgICAgICBpZiAob3B0aW9ucy5jb250ZXh0ICYmIG9wdGlvbnMuY29udGV4dC5pc1N5c3RlbSkge1xyXG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuICFyZXNlcnZlZE1vZGVsQXBpSWRzLnNvbWUoZnVuY3Rpb24gKHJlc2VydmVkV29yZCkge1xyXG4gICAgICAgICAgICByZXR1cm4gdmFsdWUgPyByZXNlcnZlZFdvcmQudG9Mb3dlckNhc2UoKSA9PT0gdmFsdWUudG9Mb3dlckNhc2UoKSA6IGZhbHNlO1xyXG4gICAgICAgIH0pO1xyXG4gICAgfSxcclxuICAgIG1lc3NhZ2U6ICdcIiR7dmFsdWV9XCIgaXMgYSByZXN0cmljdGVkIHdvcmQgYW5kIGNhbm5vdCBiZSB1c2VkIGhlcmUuJyxcclxuICAgIGV4Y2x1c2l2ZTogZmFsc2UsXHJcbn0pXHJcbiAgICAubWF0Y2hlcygvXltBLVpdW2EtekEtWjAtOV9dKiQvLCAnU3RhcnQgd2l0aCBhIGNhcGl0YWwgbGV0dGVyIGFuZCB1c2Ugb25seSBhbHBoYW51bWVyaWMgY2hhcmFjdGVycyBhbmQgdW5kZXJzY29yZXMuJyk7IC8vIDwtLSBUaG9zZSBhcmUgdmFsaWRhdGlvbnMgZW5mb3JjZWQgYnkgcHJpc21hOiBodHRwczovL2dpdGh1Yi5jb20vZ3JhcGhjb29sL3ByaXNtYS9ibG9iL21hc3Rlci9zZXJ2ZXIvc2VydmVycy9kZXBsb3kvc3JjL21haW4vc2NhbGEvY29tL3ByaXNtYS9kZXBsb3kvdmFsaWRhdGlvbi9OYW1lQ29uc3RyYWludHMuc2NhbGFcclxuLyoqXHJcbiAqIE1hdGNoZXIgZm9yIG1vZGVsIGRpc3BsYXkgbmFtZXM6XHJcbiAqXHJcbiAqIC5zdHJpbmcoKSAgICAgICAgICAtPiBFbnN1cmVzIHRoYXQgb25seSBzdHJpbmdzIGNhbiBiZSB2YWxpZGF0ZWQgd2l0aCBzdWNjZXNzXHJcbiAqIC50eXBlRXJyb3IoOnN0cmluZyktPiBFbnN1cmVzIHRoYXQgdHlwZXMgb3RoZXIgdGhhbiBzdHJpbmcgcmV0dXJuIGZhbHNlXHJcbiAqIC5zdHJpY3QoOmJvb2xlYW4pICAtPiBQcmV2ZW50cyBtYW5pcHVsYXRpb24gb2YgdGhlIHN0cmluZyBkdXJpbmcgdmFsaWRhdGlvblxyXG4gKiAucmVxdWlyZWQoKSAgICAgICAgLT4gRW5zdXJlcyB0aGF0IGVtcHR5IHN0cmluZ3MgYXJlIHRyZWF0ZWQgYXMgaW52YWxpZCB2YWx1ZVxyXG4gKi9cclxuZXhwb3J0IHZhciBkaXNwbGF5TmFtZSA9IHl1cFxyXG4gICAgLnN0cmluZygpXHJcbiAgICAudHlwZUVycm9yKCdUaGUgc3VwcGxpZWQgdmFsdWUgXCIke3ZhbHVlfVwiIG9mIHR5cGUgXCIke3R5cGV9XCIgaXMgbm90IGNvbXBhdGlibGUgd2l0aCB0eXBlIFwic3RyaW5nXCIhJylcclxuICAgIC5zdHJpY3QodHJ1ZSlcclxuICAgIC5taW4oMSwgJ0VudGVyIGEgRGlzcGxheSBOYW1lJylcclxuICAgIC50cmltKCdEaXNwbGF5IG5hbWVzIG1heSBub3QgaGF2ZSBsZWFkaW5nIG9yIHRyYWlsaW5nIHdoaXRlc3BhY2VzLicpO1xyXG4vKipcclxuICogTWF0Y2hlciBmb3IgbW9kZWwgZGVzY3JpcHRpb25zOlxyXG4gKlxyXG4gKiAuc3RyaW5nKCkgICAgICAgICAgLT4gRW5zdXJlcyB0aGF0IG9ubHkgc3RyaW5ncyBjYW4gYmUgdmFsaWRhdGVkIHdpdGggc3VjY2Vzc1xyXG4gKiAudHlwZUVycm9yKDpzdHJpbmcpLT4gRW5zdXJlcyB0aGF0IHR5cGVzIG90aGVyIHRoYW4gc3RyaW5nIHJldHVybiBmYWxzZVxyXG4gKiAuZW5zdXJlKCkgICAgICAgICAgLT4gVHJhbnNmb3JtcyB0aGUgdmFsdWVzIFwidW5kZWZpbmVkXCIgYW5kIFwibnVsbFwiIGludG8gZW1wdHkgc3RyaW5nc1xyXG4gKi9cclxuZXhwb3J0IHZhciBkZXNjcmlwdGlvbiA9IHl1cFxyXG4gICAgLnN0cmluZygpXHJcbiAgICAudHlwZUVycm9yKCdUaGUgc3VwcGxpZWQgdmFsdWUgXCIke3ZhbHVlfVwiIG9mIHR5cGUgXCIke3R5cGV9XCIgaXMgbm90IGNvbXBhdGlibGUgd2l0aCB0eXBlIFwic3RyaW5nXCIhJylcclxuICAgIC5lbnN1cmUoKTtcclxuZXhwb3J0IHZhciBtb2RlbElkID0geXVwLnN0cmluZygpLnN0cmljdCh0cnVlKTtcclxuZXhwb3J0IHZhciBwcmV2aWV3VVJMcyA9IHl1cC5hcnJheSgpLm9mKHl1cFxyXG4gICAgLm9iamVjdCgpXHJcbiAgICAuc2hhcGUoe1xyXG4gICAgbmFtZTogeXVwLnN0cmluZygpLnJlcXVpcmVkKCksXHJcbiAgICB0ZW1wbGF0ZTogeXVwLnN0cmluZygpLnJlcXVpcmVkKCksXHJcbn0pXHJcbiAgICAucmVxdWlyZWQoKSk7XHJcbiJdfQ==

@@ -180,3 +184,4 @@

description: description$3,
modelId: modelId
modelId: modelId,
previewURLs: previewURLs
});

@@ -183,0 +188,0 @@

@@ -85,3 +85,3 @@ (function (global, factory) {

var apiId$1 = yup.string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'Enter an Api Id.').max(32, 'Use an Api Id that is shorter than 32 characters.').test({
var apiId$1 = yup.string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'Enter an Api Id.').max(64, 'Use an Api Id that is shorter than 64 characters.').test({
name: 'no-graphql-type',

@@ -110,3 +110,3 @@ test: function (value) {

var reverseRelationFieldApiId = apiId$1.concat(yup.string().max(64, 'The API ID of a field may not exceed 64 characters.'));
var displayName$1 = yup.string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'Enter a Display Name.').test('no-letter', 'Enter a Display Name.', function (value) {
var displayName$1 = yup.string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'Enter a Display Name.').max(64, 'The Display Name of a field may not exceed 64characters.').test('no-letter', 'Enter a Display Name.', function (value) {
if (!value) {

@@ -125,3 +125,3 @@ return true;

//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["field.ts(original)"],"names":[],"mappings":"AAAA,YAAY,SAAS;AACrB,QAAS,kBAAkB,0BAA2B;AAYtD,OAAO,GAAA,CAAI,QAAQ,GAAA,CACd,MADc,EAAA,CAEd,SAFc,CAEJ,wFAFI,CAGd,MAHc,CAGP,KAHO,CAId,GAJc,CAIV,GAAG,mBAJO,CAKd,GALc,CAKV,IAAI,oDALM,CAMd,IANc,CAMT;IACN,MAAM,iBADA,CAAA;IAEN,MAAM,UAAU,OAAO;QACnB,OAAO,CAAC,gBAAA,CAAiB,IAAjB,CAAsB,UAAU,cAAc;YAAE,OAAQ,KAAA,GAAQ,YAAA,CAAA,GAAA,CAAiB,KAAA,CAAM,WAAN,KAAsB;QAAvH;IACA,CAJU,CAAA;IAKN,SAAS,0DALH,CAAA;IAMN,WAAW;EAZI,CAcd,IAdc,CAcT;IACN,MAAM,kBADA,CAAA;IAEN,MAAM,UAAU,OAAO;QACnB,GAAA,CAAI,UAAU,IAAA,CAAK;QACnB,IAAI,OAAA,CAAQ,OAAR,CAAA,EAAA,CAAmB,OAAA,CAAQ,OAAR,CAAgB,UAAU;YAC7C,OAAO;QACnB;QACQ,OAAO,CAAC,mBAAA,CAAoB,IAApB,CAAyB,UAAU,cAAc;YAAE,OAAQ,KAAA,GAAQ,YAAA,CAAA,GAAA,CAAiB,KAAA,CAAM,WAAN,KAAsB;QAA1H;IACA,CARU,CAAA;IASN,SAAS,0DATH,CAAA;IAUN,WAAW;EAxBI,CA0Bd,OA1Bc,CA0BN,wBAAwB;AAYrC,OAAO,GAAA,CAAI,4BAA4B,KAAA,CAAM,MAAN,CAAa,GAAA,CAAI,MAAJ,EAAA,CAAa,GAAb,CAAiB,IAAI;AAWzE,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,SAFoB,CAEV,wFAFU,CAGpB,MAHoB,CAGb,KAHa,CAIpB,GAJoB,CAIhB,GAAG,wBAJa,CAKpB,IALoB,CAKf,aAAa,yBAAyB,UAAU,OAAO;IAC7D,IAAI,CAAC,OAAO;QACR,OAAO;IACf;IACI,IAAI,KAAA,CAAA,EAAA,CAAS,MAAA,CAAO,KAAP,CAAA,GAAA,CAAiB,UAAU;QACpC,OAAO,KAAA,CAAM,OAAN,CAAc,OAAO,GAArB,CAAyB,MAAzB,CAAA,CAAA,CAAkC;IACjD;IACI,OAAO;AACX;AAQA,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,QAFoB,CAEX,KAFW,CAGpB,SAHoB,CAGV,wFAHU,CAIpB,MAJoB;AAKzB,OAAO,GAAA,CAAI,SAAS,GAAA,CACf,OADe,EAAA,CAEf,MAFe,CAER,KAFQ,CAGf,SAHe,CAGL;AACf,OAAO,GAAA,CAAI,WAAW,GAAA,CACjB,OADiB,EAAA,CAEjB,MAFiB,CAEV,KAFU,CAGjB,SAHiB,CAGP;AA/Ff","file":"field.ts(original)","sourcesContent":["import * as yup from 'yup';\r\nimport { graphQlTypeNames, reservedFieldApiIds } from './reservedWords';\r\n/**\r\n * Matcher for field api IDs:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .strict(:boolean)  -> Prevents manipulation of the string during validation\r\n * .min()             -> Sets minimum required length of string to 1 character\r\n * .max()             -> Sets maximum required length of string to 32 characters\r\n * .test()            -> Executes an arbitrary test on the input value\r\n * .matches(:RegExpr) -> Matches the input value against a regular expression\r\n */\r\nexport var apiId = yup\r\n    .string()\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"string\"!')\r\n    .strict(true)\r\n    .min(1, 'Enter an Api Id.')\r\n    .max(32, 'Use an Api Id that is shorter than 32 characters.')\r\n    .test({\r\n    name: 'no-graphql-type',\r\n    test: function (value) {\r\n        return !graphQlTypeNames.some(function (reservedWord) { return (value ? reservedWord === value.toLowerCase() : false); });\r\n    },\r\n    message: '\"${value}\" is a restricted word and cannot be used here.',\r\n    exclusive: false,\r\n})\r\n    .test({\r\n    name: 'no-reserved-word',\r\n    test: function (value) {\r\n        var options = this.options;\r\n        if (options.context && options.context.isSystem) {\r\n            return true;\r\n        }\r\n        return !reservedFieldApiIds.some(function (reservedWord) { return (value ? reservedWord === value.toLowerCase() : false); });\r\n    },\r\n    message: '\"${value}\" is a restricted word and cannot be used here.',\r\n    exclusive: false,\r\n})\r\n    .matches(/^[a-z][a-zA-Z0-9_]*$/, 'Start with a lowercase letter and use only alphanumeric characters and underscores.'); // <-- Those are validations enforced by prisma: https://github.com/graphcool/prisma/blob/master/server/servers/deploy/src/main/scala/com/prisma/deploy/validation/NameConstraints.scala\r\n/**\r\n * Matcher for field api IDs for the reverse relation side:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .strict(:boolean)  -> Prevents manipulation of the string during validation\r\n * .min()             -> Sets minimum required length of string to 1 character\r\n * .max()             -> Sets maximum required length of string to 64 characters\r\n * .test()            -> Executes an arbitrary test on the input value\r\n * .matches(:RegExpr) -> Matches the input value against a regular expression\r\n */\r\nexport var reverseRelationFieldApiId = apiId.concat(yup.string().max(64, 'The API ID of a field may not exceed 64 characters.'));\r\n/**\r\n * Matcher for field display names:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .strict(:boolean)  -> Prevents manipulation of the string during validation\r\n * .min()             -> Sets minimum required length of string to 1 character\r\n * .max()             -> Sets maximum required length of string to 32 characters\r\n * .test()            -> Executes an arbitrary test on the input value\r\n */\r\nexport var displayName = yup\r\n    .string()\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"string\"!')\r\n    .strict(true)\r\n    .min(1, 'Enter a Display Name.')\r\n    .test('no-letter', 'Enter a Display Name.', function (value) {\r\n    if (!value) {\r\n        return true;\r\n    }\r\n    if (value && typeof value === 'string') {\r\n        return value.replace(/\\s/g, '').length > 0;\r\n    }\r\n    return false;\r\n});\r\n/**\r\n * Matcher for field descriptions:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .ensure()          -> Transforms the values \"undefined\" and \"null\" into empty strings\r\n */\r\nexport var description = yup\r\n    .string()\r\n    .nullable(true)\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"string\"!')\r\n    .ensure();\r\nexport var isList = yup\r\n    .boolean()\r\n    .strict(true)\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"boolean\"!');\r\nexport var isHidden = yup\r\n    .boolean()\r\n    .strict(true)\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"boolean\"!');\r\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["field.ts(original)"],"names":[],"mappings":"AAAA,YAAY,SAAS;AACrB,QAAS,kBAAkB,0BAA2B;AAYtD,OAAO,GAAA,CAAI,QAAQ,GAAA,CACd,MADc,EAAA,CAEd,SAFc,CAEJ,wFAFI,CAGd,MAHc,CAGP,KAHO,CAId,GAJc,CAIV,GAAG,mBAJO,CAKd,GALc,CAKV,IAAI,oDALM,CAMd,IANc,CAMT;IACN,MAAM,iBADA,CAAA;IAEN,MAAM,UAAU,OAAO;QACnB,OAAO,CAAC,gBAAA,CAAiB,IAAjB,CAAsB,UAAU,cAAc;YAAE,OAAQ,KAAA,GAAQ,YAAA,CAAA,GAAA,CAAiB,KAAA,CAAM,WAAN,KAAsB;QAAvH;IACA,CAJU,CAAA;IAKN,SAAS,0DALH,CAAA;IAMN,WAAW;EAZI,CAcd,IAdc,CAcT;IACN,MAAM,kBADA,CAAA;IAEN,MAAM,UAAU,OAAO;QACnB,GAAA,CAAI,UAAU,IAAA,CAAK;QACnB,IAAI,OAAA,CAAQ,OAAR,CAAA,EAAA,CAAmB,OAAA,CAAQ,OAAR,CAAgB,UAAU;YAC7C,OAAO;QACnB;QACQ,OAAO,CAAC,mBAAA,CAAoB,IAApB,CAAyB,UAAU,cAAc;YAAE,OAAQ,KAAA,GAAQ,YAAA,CAAA,GAAA,CAAiB,KAAA,CAAM,WAAN,KAAsB;QAA1H;IACA,CARU,CAAA;IASN,SAAS,0DATH,CAAA;IAUN,WAAW;EAxBI,CA0Bd,OA1Bc,CA0BN,wBAAwB;AAYrC,OAAO,GAAA,CAAI,4BAA4B,KAAA,CAAM,MAAN,CAAa,GAAA,CAAI,MAAJ,EAAA,CAAa,GAAb,CAAiB,IAAI;AAWzE,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,SAFoB,CAEV,wFAFU,CAGpB,MAHoB,CAGb,KAHa,CAIpB,GAJoB,CAIhB,GAAG,wBAJa,CAKpB,GALoB,CAKhB,IAAI,2DALY,CAMpB,IANoB,CAMf,aAAa,yBAAyB,UAAU,OAAO;IAC7D,IAAI,CAAC,OAAO;QACR,OAAO;IACf;IACI,IAAI,KAAA,CAAA,EAAA,CAAS,MAAA,CAAO,KAAP,CAAA,GAAA,CAAiB,UAAU;QACpC,OAAO,KAAA,CAAM,OAAN,CAAc,OAAO,GAArB,CAAyB,MAAzB,CAAA,CAAA,CAAkC;IACjD;IACI,OAAO;AACX;AAQA,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,QAFoB,CAEX,KAFW,CAGpB,SAHoB,CAGV,wFAHU,CAIpB,MAJoB;AAKzB,OAAO,GAAA,CAAI,SAAS,GAAA,CACf,OADe,EAAA,CAEf,MAFe,CAER,KAFQ,CAGf,SAHe,CAGL;AACf,OAAO,GAAA,CAAI,WAAW,GAAA,CACjB,OADiB,EAAA,CAEjB,MAFiB,CAEV,KAFU,CAGjB,SAHiB,CAGP;AAhGf","file":"field.ts(original)","sourcesContent":["import * as yup from 'yup';\r\nimport { graphQlTypeNames, reservedFieldApiIds } from './reservedWords';\r\n/**\r\n * Matcher for field api IDs:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .strict(:boolean)  -> Prevents manipulation of the string during validation\r\n * .min()             -> Sets minimum required length of string to 1 character\r\n * .max()             -> Sets maximum required length of string to 64 characters\r\n * .test()            -> Executes an arbitrary test on the input value\r\n * .matches(:RegExpr) -> Matches the input value against a regular expression\r\n */\r\nexport var apiId = yup\r\n    .string()\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"string\"!')\r\n    .strict(true)\r\n    .min(1, 'Enter an Api Id.')\r\n    .max(64, 'Use an Api Id that is shorter than 64 characters.')\r\n    .test({\r\n    name: 'no-graphql-type',\r\n    test: function (value) {\r\n        return !graphQlTypeNames.some(function (reservedWord) { return (value ? reservedWord === value.toLowerCase() : false); });\r\n    },\r\n    message: '\"${value}\" is a restricted word and cannot be used here.',\r\n    exclusive: false,\r\n})\r\n    .test({\r\n    name: 'no-reserved-word',\r\n    test: function (value) {\r\n        var options = this.options;\r\n        if (options.context && options.context.isSystem) {\r\n            return true;\r\n        }\r\n        return !reservedFieldApiIds.some(function (reservedWord) { return (value ? reservedWord === value.toLowerCase() : false); });\r\n    },\r\n    message: '\"${value}\" is a restricted word and cannot be used here.',\r\n    exclusive: false,\r\n})\r\n    .matches(/^[a-z][a-zA-Z0-9_]*$/, 'Start with a lowercase letter and use only alphanumeric characters and underscores.'); // <-- Those are validations enforced by prisma: https://github.com/graphcool/prisma/blob/master/server/servers/deploy/src/main/scala/com/prisma/deploy/validation/NameConstraints.scala\r\n/**\r\n * Matcher for field api IDs for the reverse relation side:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .strict(:boolean)  -> Prevents manipulation of the string during validation\r\n * .min()             -> Sets minimum required length of string to 1 character\r\n * .max()             -> Sets maximum required length of string to 64 characters\r\n * .test()            -> Executes an arbitrary test on the input value\r\n * .matches(:RegExpr) -> Matches the input value against a regular expression\r\n */\r\nexport var reverseRelationFieldApiId = apiId.concat(yup.string().max(64, 'The API ID of a field may not exceed 64 characters.'));\r\n/**\r\n * Matcher for field display names:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .strict(:boolean)  -> Prevents manipulation of the string during validation\r\n * .min()             -> Sets minimum required length of string to 1 character\r\n * .max()             -> Sets maximum required length of string to 64 characters\r\n * .test()            -> Executes an arbitrary test on the input value\r\n */\r\nexport var displayName = yup\r\n    .string()\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"string\"!')\r\n    .strict(true)\r\n    .min(1, 'Enter a Display Name.')\r\n    .max(64, 'The Display Name of a field may not exceed 64characters.')\r\n    .test('no-letter', 'Enter a Display Name.', function (value) {\r\n    if (!value) {\r\n        return true;\r\n    }\r\n    if (value && typeof value === 'string') {\r\n        return value.replace(/\\s/g, '').length > 0;\r\n    }\r\n    return false;\r\n});\r\n/**\r\n * Matcher for field descriptions:\r\n *\r\n * .string()          -> Ensures that only strings can be validated with success\r\n * .typeError(:string)-> Ensures that types other than string return false\r\n * .ensure()          -> Transforms the values \"undefined\" and \"null\" into empty strings\r\n */\r\nexport var description = yup\r\n    .string()\r\n    .nullable(true)\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"string\"!')\r\n    .ensure();\r\nexport var isList = yup\r\n    .boolean()\r\n    .strict(true)\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"boolean\"!');\r\nexport var isHidden = yup\r\n    .boolean()\r\n    .strict(true)\r\n    .typeError('The supplied value \"${value}\" of type \"${type}\" is not compatible with type \"boolean\"!');\r\n"]}

@@ -174,5 +174,9 @@

var modelId = yup.string().strict(true);
var previewURLs = yup.array().of(yup.object().shape({
name: yup.string().required(),
template: yup.string().required()
}).required());
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm1vZGVsLnRzKG9yaWdpbmFsKSJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxZQUFZLFNBQVM7QUFDckIsUUFBUyxrQkFBa0IsMEJBQTJCO0FBYXRELE9BQU8sR0FBQSxDQUFJLFFBQVEsR0FBQSxDQUNkLE1BRGMsRUFBQSxDQUVkLFNBRmMsQ0FFSix3RkFGSSxDQUdkLE1BSGMsQ0FHUCxLQUhPLENBSWQsR0FKYyxDQUlWLEdBQUcsbUJBSk8sQ0FLZCxHQUxjLENBS1YsSUFBSSxvREFMTSxDQU1kLElBTmMsQ0FNVDtJQUNOLE1BQU0saUJBREEsQ0FBQTtJQUVOLE1BQU0sVUFBVSxPQUFPO1FBQ25CLE9BQU8sQ0FBQyxnQkFBQSxDQUFpQixJQUFqQixDQUFzQixVQUFVLGNBQWM7WUFBRSxPQUFRLEtBQUEsR0FBUSxZQUFBLENBQUEsR0FBQSxDQUFpQixLQUFBLENBQU0sV0FBTixLQUFzQjtRQUF2SDtJQUNBLENBSlUsQ0FBQTtJQUtOLFNBQVMsMERBTEgsQ0FBQTtJQU1OLFdBQVc7RUFaSSxDQWNkLElBZGMsQ0FjVDtJQUNOLE1BQU0sa0JBREEsQ0FBQTtJQUVOLE1BQU0sVUFBVSxPQUFPO1FBQ25CLEdBQUEsQ0FBSSxVQUFVLElBQUEsQ0FBSztRQUNuQixJQUFJLE9BQUEsQ0FBUSxPQUFSLENBQUEsRUFBQSxDQUFtQixPQUFBLENBQVEsT0FBUixDQUFnQixVQUFVO1lBQzdDLE9BQU87UUFDbkI7UUFDUSxPQUFPLENBQUMsbUJBQUEsQ0FBb0IsSUFBcEIsQ0FBeUIsVUFBVSxjQUFjO1lBQ3JELE9BQU8sS0FBQSxHQUFRLFlBQUEsQ0FBYSxXQUFiLEVBQUEsQ0FBQSxHQUFBLENBQStCLEtBQUEsQ0FBTSxXQUFOLEtBQXNCO1FBQ2hGO0lBQ0EsQ0FWVSxDQUFBO0lBV04sU0FBUywwREFYSCxDQUFBO0lBWU4sV0FBVztFQTFCSSxDQTRCZCxPQTVCYyxDQTRCTix3QkFBd0I7QUFTckMsT0FBTyxHQUFBLENBQUksY0FBYyxHQUFBLENBQ3BCLE1BRG9CLEVBQUEsQ0FFcEIsU0FGb0IsQ0FFVix3RkFGVSxDQUdwQixNQUhvQixDQUdiLEtBSGEsQ0FJcEIsR0FKb0IsQ0FJaEIsR0FBRyx1QkFKYSxDQUtwQixJQUxvQixDQUtmO0FBUVYsT0FBTyxHQUFBLENBQUksY0FBYyxHQUFBLENBQ3BCLE1BRG9CLEVBQUEsQ0FFcEIsU0FGb0IsQ0FFVix3RkFGVSxDQUdwQixNQUhvQjtBQUl6QixPQUFPLEdBQUEsQ0FBSSxVQUFVLEdBQUEsQ0FBSSxNQUFKLEVBQUEsQ0FBYSxNQUFiLENBQW9CO0FBcEV6QyIsImZpbGUiOiJtb2RlbC50cyhvcmlnaW5hbCkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyB5dXAgZnJvbSAneXVwJztcclxuaW1wb3J0IHsgZ3JhcGhRbFR5cGVOYW1lcywgcmVzZXJ2ZWRNb2RlbEFwaUlkcyB9IGZyb20gJy4vcmVzZXJ2ZWRXb3Jkcyc7XHJcbi8qKlxyXG4gKiBNYXRjaGVyIGZvciBtb2RlbCBhcGkgSURzOlxyXG4gKlxyXG4gKiAuc3RyaW5nKCkgICAgICAgICAgLT4gRW5zdXJlcyB0aGF0IG9ubHkgc3RyaW5ncyBjYW4gYmUgdmFsaWRhdGVkIHdpdGggc3VjY2Vzc1xyXG4gKiAudHlwZUVycm9yKDpzdHJpbmcpLT4gRW5zdXJlcyB0aGF0IHR5cGVzIG90aGVyIHRoYW4gc3RyaW5nIHJldHVybiBmYWxzZVxyXG4gKiAuc3RyaWN0KDpib29sZWFuKSAgLT4gUHJldmVudHMgbWFuaXB1bGF0aW9uIG9mIHRoZSBzdHJpbmcgZHVyaW5nIHZhbGlkYXRpb25cclxuICogLm1pbigpICAgICAgICAgICAgIC0+IFNldHMgbWluaW11bSByZXF1aXJlZCBsZW5ndGggb2Ygc3RyaW5nIHRvIDEgY2hhcmFjdGVyXHJcbiAqIC5tYXgoKSAgICAgICAgICAgICAtPiBTZXRzIG1heGltdW0gcmVxdWlyZWQgbGVuZ3RoIG9mIHN0cmluZyB0byA2NCBjaGFyYWN0ZXJzXHJcbiAqIC5yZXF1aXJlZCgpICAgICAgICAtPiBFbnN1cmVzIHRoYXQgZW1wdHkgc3RyaW5ncyBhcmUgdHJlYXRlZCBhcyBpbnZhbGlkIHZhbHVlXHJcbiAqIC50ZXN0KCkgICAgICAgICAgICAtPiBFeGVjdXRlcyBhbiBhcmJpdHJhcnkgdGVzdCBvbiB0aGUgaW5wdXQgdmFsdWVcclxuICogLm1hdGNoZXMoOlJlZ0V4cHIpIC0+IE1hdGNoZXMgdGhlIGlucHV0IHZhbHVlIGFnYWluc3QgYSByZWd1bGFyIGV4cHJlc3Npb25cclxuICovXHJcbmV4cG9ydCB2YXIgYXBpSWQgPSB5dXBcclxuICAgIC5zdHJpbmcoKVxyXG4gICAgLnR5cGVFcnJvcignVGhlIHN1cHBsaWVkIHZhbHVlIFwiJHt2YWx1ZX1cIiBvZiB0eXBlIFwiJHt0eXBlfVwiIGlzIG5vdCBjb21wYXRpYmxlIHdpdGggdHlwZSBcInN0cmluZ1wiIScpXHJcbiAgICAuc3RyaWN0KHRydWUpXHJcbiAgICAubWluKDEsICdFbnRlciBhbiBBcGkgSUQuJylcclxuICAgIC5tYXgoNjQsICdVc2UgYW4gQXBpIElkIHRoYXQgaXMgc2hvcnRlciB0aGFuIDY0IGNoYXJhY3RlcnMuJylcclxuICAgIC50ZXN0KHtcclxuICAgIG5hbWU6ICduby1ncmFwaHFsLXR5cGUnLFxyXG4gICAgdGVzdDogZnVuY3Rpb24gKHZhbHVlKSB7XHJcbiAgICAgICAgcmV0dXJuICFncmFwaFFsVHlwZU5hbWVzLnNvbWUoZnVuY3Rpb24gKHJlc2VydmVkV29yZCkgeyByZXR1cm4gKHZhbHVlID8gcmVzZXJ2ZWRXb3JkID09PSB2YWx1ZS50b0xvd2VyQ2FzZSgpIDogZmFsc2UpOyB9KTtcclxuICAgIH0sXHJcbiAgICBtZXNzYWdlOiAnXCIke3ZhbHVlfVwiIGlzIGEgcmVzdHJpY3RlZCB3b3JkIGFuZCBjYW5ub3QgYmUgdXNlZCBoZXJlLicsXHJcbiAgICBleGNsdXNpdmU6IGZhbHNlLFxyXG59KVxyXG4gICAgLnRlc3Qoe1xyXG4gICAgbmFtZTogJ25vLXJlc2VydmVkLXdvcmQnLFxyXG4gICAgdGVzdDogZnVuY3Rpb24gKHZhbHVlKSB7XHJcbiAgICAgICAgdmFyIG9wdGlvbnMgPSB0aGlzLm9wdGlvbnM7XHJcbiAgICAgICAgaWYgKG9wdGlvbnMuY29udGV4dCAmJiBvcHRpb25zLmNvbnRleHQuaXNTeXN0ZW0pIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiAhcmVzZXJ2ZWRNb2RlbEFwaUlkcy5zb21lKGZ1bmN0aW9uIChyZXNlcnZlZFdvcmQpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHZhbHVlID8gcmVzZXJ2ZWRXb3JkLnRvTG93ZXJDYXNlKCkgPT09IHZhbHVlLnRvTG93ZXJDYXNlKCkgOiBmYWxzZTtcclxuICAgICAgICB9KTtcclxuICAgIH0sXHJcbiAgICBtZXNzYWdlOiAnXCIke3ZhbHVlfVwiIGlzIGEgcmVzdHJpY3RlZCB3b3JkIGFuZCBjYW5ub3QgYmUgdXNlZCBoZXJlLicsXHJcbiAgICBleGNsdXNpdmU6IGZhbHNlLFxyXG59KVxyXG4gICAgLm1hdGNoZXMoL15bQS1aXVthLXpBLVowLTlfXSokLywgJ1N0YXJ0IHdpdGggYSBjYXBpdGFsIGxldHRlciBhbmQgdXNlIG9ubHkgYWxwaGFudW1lcmljIGNoYXJhY3RlcnMgYW5kIHVuZGVyc2NvcmVzLicpOyAvLyA8LS0gVGhvc2UgYXJlIHZhbGlkYXRpb25zIGVuZm9yY2VkIGJ5IHByaXNtYTogaHR0cHM6Ly9naXRodWIuY29tL2dyYXBoY29vbC9wcmlzbWEvYmxvYi9tYXN0ZXIvc2VydmVyL3NlcnZlcnMvZGVwbG95L3NyYy9tYWluL3NjYWxhL2NvbS9wcmlzbWEvZGVwbG95L3ZhbGlkYXRpb24vTmFtZUNvbnN0cmFpbnRzLnNjYWxhXHJcbi8qKlxyXG4gKiBNYXRjaGVyIGZvciBtb2RlbCBkaXNwbGF5IG5hbWVzOlxyXG4gKlxyXG4gKiAuc3RyaW5nKCkgICAgICAgICAgLT4gRW5zdXJlcyB0aGF0IG9ubHkgc3RyaW5ncyBjYW4gYmUgdmFsaWRhdGVkIHdpdGggc3VjY2Vzc1xyXG4gKiAudHlwZUVycm9yKDpzdHJpbmcpLT4gRW5zdXJlcyB0aGF0IHR5cGVzIG90aGVyIHRoYW4gc3RyaW5nIHJldHVybiBmYWxzZVxyXG4gKiAuc3RyaWN0KDpib29sZWFuKSAgLT4gUHJldmVudHMgbWFuaXB1bGF0aW9uIG9mIHRoZSBzdHJpbmcgZHVyaW5nIHZhbGlkYXRpb25cclxuICogLnJlcXVpcmVkKCkgICAgICAgIC0+IEVuc3VyZXMgdGhhdCBlbXB0eSBzdHJpbmdzIGFyZSB0cmVhdGVkIGFzIGludmFsaWQgdmFsdWVcclxuICovXHJcbmV4cG9ydCB2YXIgZGlzcGxheU5hbWUgPSB5dXBcclxuICAgIC5zdHJpbmcoKVxyXG4gICAgLnR5cGVFcnJvcignVGhlIHN1cHBsaWVkIHZhbHVlIFwiJHt2YWx1ZX1cIiBvZiB0eXBlIFwiJHt0eXBlfVwiIGlzIG5vdCBjb21wYXRpYmxlIHdpdGggdHlwZSBcInN0cmluZ1wiIScpXHJcbiAgICAuc3RyaWN0KHRydWUpXHJcbiAgICAubWluKDEsICdFbnRlciBhIERpc3BsYXkgTmFtZScpXHJcbiAgICAudHJpbSgnRGlzcGxheSBuYW1lcyBtYXkgbm90IGhhdmUgbGVhZGluZyBvciB0cmFpbGluZyB3aGl0ZXNwYWNlcy4nKTtcclxuLyoqXHJcbiAqIE1hdGNoZXIgZm9yIG1vZGVsIGRlc2NyaXB0aW9uczpcclxuICpcclxuICogLnN0cmluZygpICAgICAgICAgIC0+IEVuc3VyZXMgdGhhdCBvbmx5IHN0cmluZ3MgY2FuIGJlIHZhbGlkYXRlZCB3aXRoIHN1Y2Nlc3NcclxuICogLnR5cGVFcnJvcig6c3RyaW5nKS0+IEVuc3VyZXMgdGhhdCB0eXBlcyBvdGhlciB0aGFuIHN0cmluZyByZXR1cm4gZmFsc2VcclxuICogLmVuc3VyZSgpICAgICAgICAgIC0+IFRyYW5zZm9ybXMgdGhlIHZhbHVlcyBcInVuZGVmaW5lZFwiIGFuZCBcIm51bGxcIiBpbnRvIGVtcHR5IHN0cmluZ3NcclxuICovXHJcbmV4cG9ydCB2YXIgZGVzY3JpcHRpb24gPSB5dXBcclxuICAgIC5zdHJpbmcoKVxyXG4gICAgLnR5cGVFcnJvcignVGhlIHN1cHBsaWVkIHZhbHVlIFwiJHt2YWx1ZX1cIiBvZiB0eXBlIFwiJHt0eXBlfVwiIGlzIG5vdCBjb21wYXRpYmxlIHdpdGggdHlwZSBcInN0cmluZ1wiIScpXHJcbiAgICAuZW5zdXJlKCk7XHJcbmV4cG9ydCB2YXIgbW9kZWxJZCA9IHl1cC5zdHJpbmcoKS5zdHJpY3QodHJ1ZSk7XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm1vZGVsLnRzKG9yaWdpbmFsKSJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxZQUFZLFNBQVM7QUFDckIsUUFBUyxrQkFBa0IsMEJBQTJCO0FBYXRELE9BQU8sR0FBQSxDQUFJLFFBQVEsR0FBQSxDQUNkLE1BRGMsRUFBQSxDQUVkLFNBRmMsQ0FFSix3RkFGSSxDQUdkLE1BSGMsQ0FHUCxLQUhPLENBSWQsR0FKYyxDQUlWLEdBQUcsbUJBSk8sQ0FLZCxHQUxjLENBS1YsSUFBSSxvREFMTSxDQU1kLElBTmMsQ0FNVDtJQUNOLE1BQU0saUJBREEsQ0FBQTtJQUVOLE1BQU0sVUFBVSxPQUFPO1FBQ25CLE9BQU8sQ0FBQyxnQkFBQSxDQUFpQixJQUFqQixDQUFzQixVQUFVLGNBQWM7WUFBRSxPQUFRLEtBQUEsR0FBUSxZQUFBLENBQUEsR0FBQSxDQUFpQixLQUFBLENBQU0sV0FBTixLQUFzQjtRQUF2SDtJQUNBLENBSlUsQ0FBQTtJQUtOLFNBQVMsMERBTEgsQ0FBQTtJQU1OLFdBQVc7RUFaSSxDQWNkLElBZGMsQ0FjVDtJQUNOLE1BQU0sa0JBREEsQ0FBQTtJQUVOLE1BQU0sVUFBVSxPQUFPO1FBQ25CLEdBQUEsQ0FBSSxVQUFVLElBQUEsQ0FBSztRQUNuQixJQUFJLE9BQUEsQ0FBUSxPQUFSLENBQUEsRUFBQSxDQUFtQixPQUFBLENBQVEsT0FBUixDQUFnQixVQUFVO1lBQzdDLE9BQU87UUFDbkI7UUFDUSxPQUFPLENBQUMsbUJBQUEsQ0FBb0IsSUFBcEIsQ0FBeUIsVUFBVSxjQUFjO1lBQ3JELE9BQU8sS0FBQSxHQUFRLFlBQUEsQ0FBYSxXQUFiLEVBQUEsQ0FBQSxHQUFBLENBQStCLEtBQUEsQ0FBTSxXQUFOLEtBQXNCO1FBQ2hGO0lBQ0EsQ0FWVSxDQUFBO0lBV04sU0FBUywwREFYSCxDQUFBO0lBWU4sV0FBVztFQTFCSSxDQTRCZCxPQTVCYyxDQTRCTix3QkFBd0I7QUFTckMsT0FBTyxHQUFBLENBQUksY0FBYyxHQUFBLENBQ3BCLE1BRG9CLEVBQUEsQ0FFcEIsU0FGb0IsQ0FFVix3RkFGVSxDQUdwQixNQUhvQixDQUdiLEtBSGEsQ0FJcEIsR0FKb0IsQ0FJaEIsR0FBRyx1QkFKYSxDQUtwQixJQUxvQixDQUtmO0FBUVYsT0FBTyxHQUFBLENBQUksY0FBYyxHQUFBLENBQ3BCLE1BRG9CLEVBQUEsQ0FFcEIsU0FGb0IsQ0FFVix3RkFGVSxDQUdwQixNQUhvQjtBQUl6QixPQUFPLEdBQUEsQ0FBSSxVQUFVLEdBQUEsQ0FBSSxNQUFKLEVBQUEsQ0FBYSxNQUFiLENBQW9CO0FBQ3pDLE9BQU8sR0FBQSxDQUFJLGNBQWMsR0FBQSxDQUFJLEtBQUosRUFBQSxDQUFZLEVBQVosQ0FBZSxHQUFBLENBQ25DLE1BRG1DLEVBQUEsQ0FFbkMsS0FGbUMsQ0FFN0I7SUFDUCxNQUFNLEdBQUEsQ0FBSSxNQUFKLEVBQUEsQ0FBYSxRQUFiLEVBREMsQ0FBQTtJQUVQLFVBQVUsR0FBQSxDQUFJLE1BQUosRUFBQSxDQUFhLFFBQWI7RUFKMEIsQ0FNbkMsUUFObUM7QUFyRXhDIiwiZmlsZSI6Im1vZGVsLnRzKG9yaWdpbmFsKSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHl1cCBmcm9tICd5dXAnO1xyXG5pbXBvcnQgeyBncmFwaFFsVHlwZU5hbWVzLCByZXNlcnZlZE1vZGVsQXBpSWRzIH0gZnJvbSAnLi9yZXNlcnZlZFdvcmRzJztcclxuLyoqXHJcbiAqIE1hdGNoZXIgZm9yIG1vZGVsIGFwaSBJRHM6XHJcbiAqXHJcbiAqIC5zdHJpbmcoKSAgICAgICAgICAtPiBFbnN1cmVzIHRoYXQgb25seSBzdHJpbmdzIGNhbiBiZSB2YWxpZGF0ZWQgd2l0aCBzdWNjZXNzXHJcbiAqIC50eXBlRXJyb3IoOnN0cmluZyktPiBFbnN1cmVzIHRoYXQgdHlwZXMgb3RoZXIgdGhhbiBzdHJpbmcgcmV0dXJuIGZhbHNlXHJcbiAqIC5zdHJpY3QoOmJvb2xlYW4pICAtPiBQcmV2ZW50cyBtYW5pcHVsYXRpb24gb2YgdGhlIHN0cmluZyBkdXJpbmcgdmFsaWRhdGlvblxyXG4gKiAubWluKCkgICAgICAgICAgICAgLT4gU2V0cyBtaW5pbXVtIHJlcXVpcmVkIGxlbmd0aCBvZiBzdHJpbmcgdG8gMSBjaGFyYWN0ZXJcclxuICogLm1heCgpICAgICAgICAgICAgIC0+IFNldHMgbWF4aW11bSByZXF1aXJlZCBsZW5ndGggb2Ygc3RyaW5nIHRvIDY0IGNoYXJhY3RlcnNcclxuICogLnJlcXVpcmVkKCkgICAgICAgIC0+IEVuc3VyZXMgdGhhdCBlbXB0eSBzdHJpbmdzIGFyZSB0cmVhdGVkIGFzIGludmFsaWQgdmFsdWVcclxuICogLnRlc3QoKSAgICAgICAgICAgIC0+IEV4ZWN1dGVzIGFuIGFyYml0cmFyeSB0ZXN0IG9uIHRoZSBpbnB1dCB2YWx1ZVxyXG4gKiAubWF0Y2hlcyg6UmVnRXhwcikgLT4gTWF0Y2hlcyB0aGUgaW5wdXQgdmFsdWUgYWdhaW5zdCBhIHJlZ3VsYXIgZXhwcmVzc2lvblxyXG4gKi9cclxuZXhwb3J0IHZhciBhcGlJZCA9IHl1cFxyXG4gICAgLnN0cmluZygpXHJcbiAgICAudHlwZUVycm9yKCdUaGUgc3VwcGxpZWQgdmFsdWUgXCIke3ZhbHVlfVwiIG9mIHR5cGUgXCIke3R5cGV9XCIgaXMgbm90IGNvbXBhdGlibGUgd2l0aCB0eXBlIFwic3RyaW5nXCIhJylcclxuICAgIC5zdHJpY3QodHJ1ZSlcclxuICAgIC5taW4oMSwgJ0VudGVyIGFuIEFwaSBJRC4nKVxyXG4gICAgLm1heCg2NCwgJ1VzZSBhbiBBcGkgSWQgdGhhdCBpcyBzaG9ydGVyIHRoYW4gNjQgY2hhcmFjdGVycy4nKVxyXG4gICAgLnRlc3Qoe1xyXG4gICAgbmFtZTogJ25vLWdyYXBocWwtdHlwZScsXHJcbiAgICB0ZXN0OiBmdW5jdGlvbiAodmFsdWUpIHtcclxuICAgICAgICByZXR1cm4gIWdyYXBoUWxUeXBlTmFtZXMuc29tZShmdW5jdGlvbiAocmVzZXJ2ZWRXb3JkKSB7IHJldHVybiAodmFsdWUgPyByZXNlcnZlZFdvcmQgPT09IHZhbHVlLnRvTG93ZXJDYXNlKCkgOiBmYWxzZSk7IH0pO1xyXG4gICAgfSxcclxuICAgIG1lc3NhZ2U6ICdcIiR7dmFsdWV9XCIgaXMgYSByZXN0cmljdGVkIHdvcmQgYW5kIGNhbm5vdCBiZSB1c2VkIGhlcmUuJyxcclxuICAgIGV4Y2x1c2l2ZTogZmFsc2UsXHJcbn0pXHJcbiAgICAudGVzdCh7XHJcbiAgICBuYW1lOiAnbm8tcmVzZXJ2ZWQtd29yZCcsXHJcbiAgICB0ZXN0OiBmdW5jdGlvbiAodmFsdWUpIHtcclxuICAgICAgICB2YXIgb3B0aW9ucyA9IHRoaXMub3B0aW9ucztcclxuICAgICAgICBpZiAob3B0aW9ucy5jb250ZXh0ICYmIG9wdGlvbnMuY29udGV4dC5pc1N5c3RlbSkge1xyXG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuICFyZXNlcnZlZE1vZGVsQXBpSWRzLnNvbWUoZnVuY3Rpb24gKHJlc2VydmVkV29yZCkge1xyXG4gICAgICAgICAgICByZXR1cm4gdmFsdWUgPyByZXNlcnZlZFdvcmQudG9Mb3dlckNhc2UoKSA9PT0gdmFsdWUudG9Mb3dlckNhc2UoKSA6IGZhbHNlO1xyXG4gICAgICAgIH0pO1xyXG4gICAgfSxcclxuICAgIG1lc3NhZ2U6ICdcIiR7dmFsdWV9XCIgaXMgYSByZXN0cmljdGVkIHdvcmQgYW5kIGNhbm5vdCBiZSB1c2VkIGhlcmUuJyxcclxuICAgIGV4Y2x1c2l2ZTogZmFsc2UsXHJcbn0pXHJcbiAgICAubWF0Y2hlcygvXltBLVpdW2EtekEtWjAtOV9dKiQvLCAnU3RhcnQgd2l0aCBhIGNhcGl0YWwgbGV0dGVyIGFuZCB1c2Ugb25seSBhbHBoYW51bWVyaWMgY2hhcmFjdGVycyBhbmQgdW5kZXJzY29yZXMuJyk7IC8vIDwtLSBUaG9zZSBhcmUgdmFsaWRhdGlvbnMgZW5mb3JjZWQgYnkgcHJpc21hOiBodHRwczovL2dpdGh1Yi5jb20vZ3JhcGhjb29sL3ByaXNtYS9ibG9iL21hc3Rlci9zZXJ2ZXIvc2VydmVycy9kZXBsb3kvc3JjL21haW4vc2NhbGEvY29tL3ByaXNtYS9kZXBsb3kvdmFsaWRhdGlvbi9OYW1lQ29uc3RyYWludHMuc2NhbGFcclxuLyoqXHJcbiAqIE1hdGNoZXIgZm9yIG1vZGVsIGRpc3BsYXkgbmFtZXM6XHJcbiAqXHJcbiAqIC5zdHJpbmcoKSAgICAgICAgICAtPiBFbnN1cmVzIHRoYXQgb25seSBzdHJpbmdzIGNhbiBiZSB2YWxpZGF0ZWQgd2l0aCBzdWNjZXNzXHJcbiAqIC50eXBlRXJyb3IoOnN0cmluZyktPiBFbnN1cmVzIHRoYXQgdHlwZXMgb3RoZXIgdGhhbiBzdHJpbmcgcmV0dXJuIGZhbHNlXHJcbiAqIC5zdHJpY3QoOmJvb2xlYW4pICAtPiBQcmV2ZW50cyBtYW5pcHVsYXRpb24gb2YgdGhlIHN0cmluZyBkdXJpbmcgdmFsaWRhdGlvblxyXG4gKiAucmVxdWlyZWQoKSAgICAgICAgLT4gRW5zdXJlcyB0aGF0IGVtcHR5IHN0cmluZ3MgYXJlIHRyZWF0ZWQgYXMgaW52YWxpZCB2YWx1ZVxyXG4gKi9cclxuZXhwb3J0IHZhciBkaXNwbGF5TmFtZSA9IHl1cFxyXG4gICAgLnN0cmluZygpXHJcbiAgICAudHlwZUVycm9yKCdUaGUgc3VwcGxpZWQgdmFsdWUgXCIke3ZhbHVlfVwiIG9mIHR5cGUgXCIke3R5cGV9XCIgaXMgbm90IGNvbXBhdGlibGUgd2l0aCB0eXBlIFwic3RyaW5nXCIhJylcclxuICAgIC5zdHJpY3QodHJ1ZSlcclxuICAgIC5taW4oMSwgJ0VudGVyIGEgRGlzcGxheSBOYW1lJylcclxuICAgIC50cmltKCdEaXNwbGF5IG5hbWVzIG1heSBub3QgaGF2ZSBsZWFkaW5nIG9yIHRyYWlsaW5nIHdoaXRlc3BhY2VzLicpO1xyXG4vKipcclxuICogTWF0Y2hlciBmb3IgbW9kZWwgZGVzY3JpcHRpb25zOlxyXG4gKlxyXG4gKiAuc3RyaW5nKCkgICAgICAgICAgLT4gRW5zdXJlcyB0aGF0IG9ubHkgc3RyaW5ncyBjYW4gYmUgdmFsaWRhdGVkIHdpdGggc3VjY2Vzc1xyXG4gKiAudHlwZUVycm9yKDpzdHJpbmcpLT4gRW5zdXJlcyB0aGF0IHR5cGVzIG90aGVyIHRoYW4gc3RyaW5nIHJldHVybiBmYWxzZVxyXG4gKiAuZW5zdXJlKCkgICAgICAgICAgLT4gVHJhbnNmb3JtcyB0aGUgdmFsdWVzIFwidW5kZWZpbmVkXCIgYW5kIFwibnVsbFwiIGludG8gZW1wdHkgc3RyaW5nc1xyXG4gKi9cclxuZXhwb3J0IHZhciBkZXNjcmlwdGlvbiA9IHl1cFxyXG4gICAgLnN0cmluZygpXHJcbiAgICAudHlwZUVycm9yKCdUaGUgc3VwcGxpZWQgdmFsdWUgXCIke3ZhbHVlfVwiIG9mIHR5cGUgXCIke3R5cGV9XCIgaXMgbm90IGNvbXBhdGlibGUgd2l0aCB0eXBlIFwic3RyaW5nXCIhJylcclxuICAgIC5lbnN1cmUoKTtcclxuZXhwb3J0IHZhciBtb2RlbElkID0geXVwLnN0cmluZygpLnN0cmljdCh0cnVlKTtcclxuZXhwb3J0IHZhciBwcmV2aWV3VVJMcyA9IHl1cC5hcnJheSgpLm9mKHl1cFxyXG4gICAgLm9iamVjdCgpXHJcbiAgICAuc2hhcGUoe1xyXG4gICAgbmFtZTogeXVwLnN0cmluZygpLnJlcXVpcmVkKCksXHJcbiAgICB0ZW1wbGF0ZTogeXVwLnN0cmluZygpLnJlcXVpcmVkKCksXHJcbn0pXHJcbiAgICAucmVxdWlyZWQoKSk7XHJcbiJdfQ==

@@ -184,3 +188,4 @@

description: description$3,
modelId: modelId
modelId: modelId,
previewURLs: previewURLs
});

@@ -187,0 +192,0 @@

{
"name": "@graphcms/validation",
"version": "1.3.7",
"version": "1.3.8",
"main": "dist/validation.js",

@@ -5,0 +5,0 @@ "types": "dist/index.d.ts",

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc