@graphcms/validation
Advanced tools
Comparing version 1.2.7 to 1.2.8
@@ -15,2 +15,14 @@ import * as yup from 'yup'; | ||
/** | ||
* Matcher for field api IDs for the reverse relation side: | ||
* | ||
* .string() -> Ensures that only strings can be validated with success | ||
* .typeError(:string)-> Ensures that types other than string return false | ||
* .strict(:boolean) -> Prevents manipulation of the string during validation | ||
* .min() -> Sets minimum required length of string to 1 character | ||
* .max() -> Sets maximum required length of string to 64 characters | ||
* .test() -> Executes an arbitrary test on the input value | ||
* .matches(:RegExpr) -> Matches the input value against a regular expression | ||
*/ | ||
export declare const reverseRelationFieldApiId: yup.StringSchema; | ||
/** | ||
* Matcher for field display names: | ||
@@ -17,0 +29,0 @@ * |
@@ -69,18 +69,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, 'The API ID of a field must be at least one character long.').test({ | ||
name: 'max-length', | ||
test: function (value) { | ||
if (!value) | ||
return true; | ||
var options = this.options; | ||
var max = 32; | ||
if (options.context && options.context.allowLongApiIds) { | ||
max = 64; | ||
} | ||
if (value.length >= max) { | ||
return yup.ValidationError("The API ID of a field may not exceed " + max + " characters.", value, ''); | ||
} | ||
return true; | ||
} | ||
}).test({ | ||
var apiId$1 = yup.string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'The API ID of a field must be at least one character long.').max(32, 'The API ID of a field may not exceed 32 characters.').test({ | ||
name: 'no-graphql-type', | ||
@@ -108,2 +93,3 @@ test: function (value) { | ||
}).matches(/^[a-z][a-zA-Z0-9]*$/, 'The API ID of a field may only start with a lowercase letter and contain alphanumeric characters.'); | ||
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, 'The display name of a field must be at least one character long.').test('no-letter', 'The display name of a field should contain at least one non-whitespace character', function (value) { | ||
@@ -127,2 +113,3 @@ if (!value) { | ||
apiId: apiId$1, | ||
reverseRelationFieldApiId: reverseRelationFieldApiId, | ||
displayName: displayName$1, | ||
@@ -129,0 +116,0 @@ description: description$2, |
@@ -1,2 +0,2 @@ | ||
import { string, ValidationError, boolean } from 'yup'; | ||
import { string, boolean } from 'yup'; | ||
@@ -72,18 +72,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, 'The API ID of a field must be at least one character long.').test({ | ||
name: 'max-length', | ||
test: function (value) { | ||
if (!value) | ||
return true; | ||
var options = this.options; | ||
var max = 32; | ||
if (options.context && options.context.allowLongApiIds) { | ||
max = 64; | ||
} | ||
if (value.length >= max) { | ||
return ValidationError("The API ID of a field may not exceed " + max + " characters.", value, ''); | ||
} | ||
return true; | ||
} | ||
}).test({ | ||
var apiId$1 = string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'The API ID of a field must be at least one character long.').max(32, 'The API ID of a field may not exceed 32 characters.').test({ | ||
name: 'no-graphql-type', | ||
@@ -111,2 +96,3 @@ test: function (value) { | ||
}).matches(/^[a-z][a-zA-Z0-9]*$/, 'The API ID of a field may only start with a lowercase letter and contain alphanumeric characters.'); | ||
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, 'The display name of a field must be at least one character long.').test('no-letter', 'The display name of a field should contain at least one non-whitespace character', function (value) { | ||
@@ -125,3 +111,3 @@ if (!value) { | ||
//# 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,6DAJO,CAKd,IALc,CAKT;IACN,MAAM,YADA,CAAA;IAEN,MAAM,UAAU,OAAO;QACnB,IAAI,CAAC;YACD,OAAO;QACX,GAAA,CAAI,UAAU,IAAA,CAAK;QACnB,GAAA,CAAI,MAAM;QACV,IAAI,OAAA,CAAQ,OAAR,CAAA,EAAA,CAAmB,OAAA,CAAQ,OAAR,CAAgB,iBAAiB;YACpD,GAAA,CAAA,CAAA,CAAM;QAClB;QACQ,IAAI,KAAA,CAAM,MAAN,CAAA,EAAA,CAAgB,KAAK;YACrB,OAAO,GAAA,CAAI,eAAJ,CAAoB,uCAAA,CAAA,CAAA,CAA0C,GAA1C,CAAA,CAAA,CAAgD,gBAAgB,OAAO;QAC9G;QACQ,OAAO;IACf;EAnBmB,CAqBd,IArBc,CAqBT;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,sDALH,CAAA;IAMN,WAAW;EA3BI,CA6Bd,IA7Bc,CA6BT;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,8EATH,CAAA;IAUN,WAAW;EAvCI,CAyCd,OAzCc,CAyCN,uBAAuB;AAWpC,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,SAFoB,CAEV,wFAFU,CAGpB,MAHoB,CAGb,KAHa,CAIpB,GAJoB,CAIhB,GAAG,mEAJa,CAKpB,IALoB,CAKf,aAAa,oFAAoF,UAAU,OAAO;IACxH,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,KAAK,GAAnB,CAAuB,MAAvB,CAAA,CAAA,CAAgC;IAC/C;IACI,OAAO;AACX;AAQA,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,SAFoB,CAEV,wFAFU,CAGpB,MAHoB;AAIzB,OAAO,GAAA,CAAI,SAAS,GAAA,CACf,OADe,EAAA,CAEf,MAFe,CAER,KAFQ,CAGf,SAHe,CAGL;AA7Ff","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, 'The API ID of a field must be at least one character long.')\r\n    .test({\r\n    name: 'max-length',\r\n    test: function (value) {\r\n        if (!value)\r\n            return true;\r\n        var options = this.options;\r\n        var max = 32;\r\n        if (options.context && options.context.allowLongApiIds) {\r\n            max = 64;\r\n        }\r\n        if (value.length >= max) {\r\n            return yup.ValidationError(\"The API ID of a field may not exceed \" + max + \" characters.\", value, '');\r\n        }\r\n        return true;\r\n    },\r\n})\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 by the graphql spec.',\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, which can cause issues in stage deployment.',\r\n    exclusive: false,\r\n})\r\n    .matches(/^[a-z][a-zA-Z0-9]*$/, 'The API ID of a field may only start with a lowercase letter and contain alphanumeric characters.'); // <-- 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 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, 'The display name of a field must be at least one character long.')\r\n    .test('no-letter', 'The display name of a field should contain at least one non-whitespace character', function (value) {\r\n    if (!value) {\r\n        return true;\r\n    }\r\n    if (value && typeof value === 'string') {\r\n        return value.replace(' ', '').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    .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\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,6DAJO,CAKd,GALc,CAKV,IAAI,sDALM,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,sDALH,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,8EATH,CAAA;IAUN,WAAW;EAxBI,CA0Bd,OA1Bc,CA0BN,uBAAuB;AAYpC,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,mEAJa,CAKpB,IALoB,CAKf,aAAa,oFAAoF,UAAU,OAAO;IACxH,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,KAAK,GAAnB,CAAuB,MAAvB,CAAA,CAAA,CAAgC;IAC/C;IACI,OAAO;AACX;AAQA,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,SAFoB,CAEV,wFAFU,CAGpB,MAHoB;AAIzB,OAAO,GAAA,CAAI,SAAS,GAAA,CACf,OADe,EAAA,CAEf,MAFe,CAER,KAFQ,CAGf,SAHe,CAGL;AA1Ff","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, 'The API ID of a field must be at least one character long.')\r\n    .max(32, 'The API ID of a field may not exceed 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 by the graphql spec.',\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, which can cause issues in stage deployment.',\r\n    exclusive: false,\r\n})\r\n    .matches(/^[a-z][a-zA-Z0-9]*$/, 'The API ID of a field may only start with a lowercase letter and contain alphanumeric characters.'); // <-- 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, 'The display name of a field must be at least one character long.')\r\n    .test('no-letter', 'The display name of a field should contain at least one non-whitespace character', function (value) {\r\n    if (!value) {\r\n        return true;\r\n    }\r\n    if (value && typeof value === 'string') {\r\n        return value.replace(' ', '').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    .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\n"]} | ||
@@ -131,2 +117,3 @@ | ||
apiId: apiId$1, | ||
reverseRelationFieldApiId: reverseRelationFieldApiId, | ||
displayName: displayName$1, | ||
@@ -133,0 +120,0 @@ description: description$2, |
@@ -76,18 +76,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, 'The API ID of a field must be at least one character long.').test({ | ||
name: 'max-length', | ||
test: function (value) { | ||
if (!value) | ||
return true; | ||
var options = this.options; | ||
var max = 32; | ||
if (options.context && options.context.allowLongApiIds) { | ||
max = 64; | ||
} | ||
if (value.length >= max) { | ||
return yup.ValidationError("The API ID of a field may not exceed " + max + " characters.", value, ''); | ||
} | ||
return true; | ||
} | ||
}).test({ | ||
var apiId$1 = yup.string().typeError('The supplied value "${value}" of type "${type}" is not compatible with type "string"!').strict(true).min(1, 'The API ID of a field must be at least one character long.').max(32, 'The API ID of a field may not exceed 32 characters.').test({ | ||
name: 'no-graphql-type', | ||
@@ -115,2 +100,3 @@ test: function (value) { | ||
}).matches(/^[a-z][a-zA-Z0-9]*$/, 'The API ID of a field may only start with a lowercase letter and contain alphanumeric characters.'); | ||
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, 'The display name of a field must be at least one character long.').test('no-letter', 'The display name of a field should contain at least one non-whitespace character', function (value) { | ||
@@ -129,3 +115,3 @@ if (!value) { | ||
//# 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,6DAJO,CAKd,IALc,CAKT;IACN,MAAM,YADA,CAAA;IAEN,MAAM,UAAU,OAAO;QACnB,IAAI,CAAC;YACD,OAAO;QACX,GAAA,CAAI,UAAU,IAAA,CAAK;QACnB,GAAA,CAAI,MAAM;QACV,IAAI,OAAA,CAAQ,OAAR,CAAA,EAAA,CAAmB,OAAA,CAAQ,OAAR,CAAgB,iBAAiB;YACpD,GAAA,CAAA,CAAA,CAAM;QAClB;QACQ,IAAI,KAAA,CAAM,MAAN,CAAA,EAAA,CAAgB,KAAK;YACrB,OAAO,GAAA,CAAI,eAAJ,CAAoB,uCAAA,CAAA,CAAA,CAA0C,GAA1C,CAAA,CAAA,CAAgD,gBAAgB,OAAO;QAC9G;QACQ,OAAO;IACf;EAnBmB,CAqBd,IArBc,CAqBT;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,sDALH,CAAA;IAMN,WAAW;EA3BI,CA6Bd,IA7Bc,CA6BT;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,8EATH,CAAA;IAUN,WAAW;EAvCI,CAyCd,OAzCc,CAyCN,uBAAuB;AAWpC,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,SAFoB,CAEV,wFAFU,CAGpB,MAHoB,CAGb,KAHa,CAIpB,GAJoB,CAIhB,GAAG,mEAJa,CAKpB,IALoB,CAKf,aAAa,oFAAoF,UAAU,OAAO;IACxH,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,KAAK,GAAnB,CAAuB,MAAvB,CAAA,CAAA,CAAgC;IAC/C;IACI,OAAO;AACX;AAQA,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,SAFoB,CAEV,wFAFU,CAGpB,MAHoB;AAIzB,OAAO,GAAA,CAAI,SAAS,GAAA,CACf,OADe,EAAA,CAEf,MAFe,CAER,KAFQ,CAGf,SAHe,CAGL;AA7Ff","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, 'The API ID of a field must be at least one character long.')\r\n    .test({\r\n    name: 'max-length',\r\n    test: function (value) {\r\n        if (!value)\r\n            return true;\r\n        var options = this.options;\r\n        var max = 32;\r\n        if (options.context && options.context.allowLongApiIds) {\r\n            max = 64;\r\n        }\r\n        if (value.length >= max) {\r\n            return yup.ValidationError(\"The API ID of a field may not exceed \" + max + \" characters.\", value, '');\r\n        }\r\n        return true;\r\n    },\r\n})\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 by the graphql spec.',\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, which can cause issues in stage deployment.',\r\n    exclusive: false,\r\n})\r\n    .matches(/^[a-z][a-zA-Z0-9]*$/, 'The API ID of a field may only start with a lowercase letter and contain alphanumeric characters.'); // <-- 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 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, 'The display name of a field must be at least one character long.')\r\n    .test('no-letter', 'The display name of a field should contain at least one non-whitespace character', function (value) {\r\n    if (!value) {\r\n        return true;\r\n    }\r\n    if (value && typeof value === 'string') {\r\n        return value.replace(' ', '').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    .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\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,6DAJO,CAKd,GALc,CAKV,IAAI,sDALM,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,sDALH,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,8EATH,CAAA;IAUN,WAAW;EAxBI,CA0Bd,OA1Bc,CA0BN,uBAAuB;AAYpC,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,mEAJa,CAKpB,IALoB,CAKf,aAAa,oFAAoF,UAAU,OAAO;IACxH,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,KAAK,GAAnB,CAAuB,MAAvB,CAAA,CAAA,CAAgC;IAC/C;IACI,OAAO;AACX;AAQA,OAAO,GAAA,CAAI,cAAc,GAAA,CACpB,MADoB,EAAA,CAEpB,SAFoB,CAEV,wFAFU,CAGpB,MAHoB;AAIzB,OAAO,GAAA,CAAI,SAAS,GAAA,CACf,OADe,EAAA,CAEf,MAFe,CAER,KAFQ,CAGf,SAHe,CAGL;AA1Ff","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, 'The API ID of a field must be at least one character long.')\r\n    .max(32, 'The API ID of a field may not exceed 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 by the graphql spec.',\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, which can cause issues in stage deployment.',\r\n    exclusive: false,\r\n})\r\n    .matches(/^[a-z][a-zA-Z0-9]*$/, 'The API ID of a field may only start with a lowercase letter and contain alphanumeric characters.'); // <-- 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, 'The display name of a field must be at least one character long.')\r\n    .test('no-letter', 'The display name of a field should contain at least one non-whitespace character', function (value) {\r\n    if (!value) {\r\n        return true;\r\n    }\r\n    if (value && typeof value === 'string') {\r\n        return value.replace(' ', '').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    .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\n"]} | ||
@@ -135,2 +121,3 @@ | ||
apiId: apiId$1, | ||
reverseRelationFieldApiId: reverseRelationFieldApiId, | ||
displayName: displayName$1, | ||
@@ -137,0 +124,0 @@ description: description$2, |
{ | ||
"name": "@graphcms/validation", | ||
"version": "1.2.7", | ||
"version": "1.2.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
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
587412
1104