Socket
Socket
Sign inDemoInstall

express-cassandra

Package Overview
Dependencies
Maintainers
1
Versions
98
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

express-cassandra - npm Package Compare versions

Comparing version 2.2.2 to 2.2.3

.nyc_output/692a279c3783f9cc332b7effe48f253b.json

7

CHANGELOG.md

@@ -9,2 +9,6 @@ # Changelog

## [2.2.3] - 2018-07-10
### Fixed
- Auto timestamp and version fields are not working properly if used in index and materialized views
## [2.2.2] - 2018-06-17

@@ -489,3 +493,4 @@ ### Fixed

[Unreleased]: https://github.com/masumsoft/express-cassandra/compare/v2.2.2...master
[Unreleased]: https://github.com/masumsoft/express-cassandra/compare/v2.2.3...master
[2.2.3]: https://github.com/masumsoft/express-cassandra/compare/v2.2.2...v2.2.3
[2.2.2]: https://github.com/masumsoft/express-cassandra/compare/v2.2.1...v2.2.2

@@ -492,0 +497,0 @@ [2.2.1]: https://github.com/masumsoft/express-cassandra/compare/v2.2.0...v2.2.1

79

lib/validators/schema.js

@@ -12,2 +12,23 @@ 'use strict';

},
has_field(modelSchema, fieldName) {
var optionFieldNames = [];
if (modelSchema.options) {
if (modelSchema.options.timestamps) {
var timestampOptions = {
createdAt: modelSchema.options.timestamps.createdAt || 'createdAt',
updatedAt: modelSchema.options.timestamps.updatedAt || 'updatedAt'
};
optionFieldNames.push(timestampOptions.createdAt);
optionFieldNames.push(timestampOptions.updatedAt);
}
if (modelSchema.options.versions) {
var versionOptions = {
key: modelSchema.options.versions.key || '__v'
};
optionFieldNames.push(versionOptions.key);
}
}
return _.has(modelSchema.fields, fieldName) || optionFieldNames.includes(fieldName);
},
validate_field(modelSchema, fieldObject, fieldName) {

@@ -35,7 +56,9 @@ if (!fieldObject) {

validate_primary_key(modelSchema) {
var _this = this;
if (typeof modelSchema.key[0] === 'string') {
if (!_.has(modelSchema.fields, modelSchema.key[0])) {
if (!this.has_field(modelSchema, modelSchema.key[0])) {
throw new Error('Partition Key must also be a valid field name');
}
if (modelSchema.fields[modelSchema.key[0]].virtual) {
if (modelSchema.fields[modelSchema.key[0]] && modelSchema.fields[modelSchema.key[0]].virtual) {
throw new Error("Partition Key must also be a db field name, can't be a virtual field name");

@@ -48,6 +71,6 @@ }

modelSchema.key[0].forEach(function (partitionKeyField) {
if (typeof partitionKeyField !== 'string' || !_.has(modelSchema.fields, partitionKeyField)) {
if (typeof partitionKeyField !== 'string' || !_this.has_field(modelSchema, partitionKeyField)) {
throw new Error('Partition Key array must contain only valid field names');
}
if (modelSchema.fields[partitionKeyField].virtual) {
if (modelSchema.fields[partitionKeyField] && modelSchema.fields[partitionKeyField].virtual) {
throw new Error("Partition Key array must contain only db field names, can't contain virtual field names");

@@ -62,6 +85,6 @@ }

if (primaryKeyIndex > 0) {
if (typeof primaryKeyField !== 'string' || !_.has(modelSchema.fields, primaryKeyField)) {
if (typeof primaryKeyField !== 'string' || !_this.has_field(modelSchema, primaryKeyField)) {
throw new Error('Clustering Keys must be valid field names');
}
if (modelSchema.fields[primaryKeyField].virtual) {
if (modelSchema.fields[primaryKeyField] && modelSchema.fields[primaryKeyField].virtual) {
throw new Error("Clustering Keys must be db field names, can't be virtual field names");

@@ -89,2 +112,4 @@ }

validate_materialized_view(modelSchema, materializedViewObject, materializedViewName) {
var _this2 = this;
if (!_.isPlainObject(materializedViewObject)) {

@@ -103,3 +128,3 @@ throw new Error(util.format('attribute "%s" under materialized_views must be an object', materializedViewName));

materializedViewObject.select.forEach(function (materializedViewSelectField) {
if (typeof materializedViewSelectField !== 'string' || !(_.has(modelSchema.fields, materializedViewSelectField) || materializedViewSelectField === '*')) {
if (typeof materializedViewSelectField !== 'string' || !(_this2.has_field(modelSchema, materializedViewSelectField) || materializedViewSelectField === '*')) {
throw new Error(util.format('the select attribute under materialized_view %s must be an array of field name strings or ["*"]', materializedViewName));

@@ -115,6 +140,6 @@ }

if (typeof materializedViewObject.key[0] === 'string') {
if (!_.has(modelSchema.fields, materializedViewObject.key[0])) {
if (!this.has_field(modelSchema, materializedViewObject.key[0])) {
throw new Error(util.format('materialized_view %s: partition key string must match a valid field name', materializedViewName));
}
if (modelSchema.fields[materializedViewObject.key[0]].virtual) {
if (modelSchema.fields[materializedViewObject.key[0]] && modelSchema.fields[materializedViewObject.key[0]].virtual) {
throw new Error(util.format('materialized_view %s: partition key must match a db field name, cannot be a virtual field name', materializedViewName));

@@ -127,6 +152,6 @@ }

materializedViewObject.key[0].forEach(function (materializedViewPartitionKeyField) {
if (typeof materializedViewPartitionKeyField !== 'string' || !_.has(modelSchema.fields, materializedViewPartitionKeyField)) {
if (typeof materializedViewPartitionKeyField !== 'string' || !_this2.has_field(modelSchema, materializedViewPartitionKeyField)) {
throw new Error(util.format('materialized_view %s: partition key array must contain only valid field names', materializedViewName));
}
if (modelSchema.fields[materializedViewPartitionKeyField].virtual) {
if (modelSchema.fields[materializedViewPartitionKeyField] && modelSchema.fields[materializedViewPartitionKeyField].virtual) {
throw new Error(util.format('materialized_view %s: partition key array must contain only db field names, ' + 'cannot contain virtual field names', materializedViewName));

@@ -141,6 +166,6 @@ }

if (materializedViewPrimaryKeyIndex > 0) {
if (typeof materializedViewPrimaryKeyField !== 'string' || !_.has(modelSchema.fields, materializedViewPrimaryKeyField)) {
if (typeof materializedViewPrimaryKeyField !== 'string' || !_this2.has_field(modelSchema, materializedViewPrimaryKeyField)) {
throw new Error(util.format('materialized_view %s: clustering keys must be valid field names', materializedViewName));
}
if (modelSchema.fields[materializedViewPrimaryKeyField].virtual) {
if (modelSchema.fields[materializedViewPrimaryKeyField] && modelSchema.fields[materializedViewPrimaryKeyField].virtual) {
throw new Error(util.format('materialized_view %s: clustering keys must be db field names, cannot contain virtual fields', materializedViewName));

@@ -178,13 +203,13 @@ }

}
if (!_.has(modelSchema.fields, indexNameList[1])) {
if (!this.has_field(modelSchema, indexNameList[1])) {
throw new Error(util.format('"%s" is not a valid field name, indexes must be defined on field names', indexNameList[1]));
}
if (modelSchema.fields[indexNameList[1]].virtual) {
if (modelSchema.fields[indexNameList[1]] && modelSchema.fields[indexNameList[1]].virtual) {
throw new Error("indexes must be an array of db field names, can't contain virtual fields");
}
} else {
if (!_.has(modelSchema.fields, indexNameList[0])) {
if (!this.has_field(modelSchema, indexNameList[0])) {
throw new Error(util.format('"%s" is not a valid field, indexes must be defined on field names', indexNameList[0]));
}
if (modelSchema.fields[indexNameList[0]].virtual) {
if (modelSchema.fields[indexNameList[0]] && modelSchema.fields[indexNameList[0]].virtual) {
throw new Error("indexes must be an array of db field names, can't contain virtual fields");

@@ -199,6 +224,6 @@ }

}
if (typeof customIndex.on !== 'string' || !_.has(modelSchema.fields, customIndex.on)) {
if (typeof customIndex.on !== 'string' || !this.has_field(modelSchema, customIndex.on)) {
throw new Error("custom_index must have an 'on' attribute with string value and value must be a valid field name");
}
if (modelSchema.fields[customIndex.on].virtual) {
if (modelSchema.fields[customIndex.on] && modelSchema.fields[customIndex.on].virtual) {
throw new Error("custom_index 'on' attribute must be a db field name, can't contain virtual fields");

@@ -215,3 +240,3 @@ }

validate_model_schema(modelSchema) {
var _this = this;
var _this3 = this;

@@ -231,3 +256,3 @@ if (!modelSchema) {

_.forEach(modelSchema.fields, function (fieldObject, fieldName) {
_this.validate_field(modelSchema, fieldObject, fieldName);
_this3.validate_field(modelSchema, fieldObject, fieldName);
});

@@ -242,3 +267,3 @@

_.forEach(modelSchema.materialized_views, function (materializedViewObject, materializedViewName) {
_this.validate_materialized_view(modelSchema, materializedViewObject, materializedViewName);
_this3.validate_materialized_view(modelSchema, materializedViewObject, materializedViewName);
});

@@ -253,3 +278,3 @@ }

modelSchema.indexes.forEach(function (indexDef) {
_this.validate_index(modelSchema, indexDef);
_this3.validate_index(modelSchema, indexDef);
});

@@ -271,3 +296,3 @@ }

modelSchema.custom_indexes.forEach(function (customIndex) {
_this.validate_custom_index(modelSchema, customIndex);
_this3.validate_custom_index(modelSchema, customIndex);
});

@@ -318,3 +343,3 @@ }

get_validators(modelSchema, fieldname) {
var _this2 = this;
var _this4 = this;

@@ -339,3 +364,3 @@ var validators = [];

field.rule.validators.forEach(function (fieldrule) {
validators.push(_this2.format_validation_rule(fieldrule, fieldname));
validators.push(_this4.format_validation_rule(fieldrule, fieldname));
});

@@ -389,2 +414,2 @@ } else if (field.rule.validator) {

module.exports = schemer;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/validators/schema.js"],"names":["_","require","util","datatypes","schemer","validate_table_name","tableName","test","validate_field","modelSchema","fieldObject","fieldName","Error","format","fieldtype","get_field_type","has","type","includes","typeDef","is_field_default_value_valid","validate_primary_key","key","fields","virtual","isArray","length","forEach","partitionKeyField","primaryKeyField","primaryKeyIndex","clustering_order","isPlainObject","clusteringOrder","clusteringFieldName","toLowerCase","indexOf","validate_materialized_view","materializedViewObject","materializedViewName","select","materializedViewSelectField","materializedViewPartitionKeyField","materializedViewPrimaryKeyField","materializedViewPrimaryKeyIndex","mvClusteringOrder","mvlusteringFieldName","validate_index","indexDef","indexNameList","replace","split","validate_custom_index","customIndex","on","using","options","validate_model_schema","Object","keys","materialized_views","indexes","custom_index","custom_indexes","format_validation_rule","rule","fieldname","validator","message","get_generic_validation_message","f1","bind","value","propName","get_validation_message","validators","$db_function","v","get_validators","typeFieldValidator","generic_type_validator","push","field","Array","fieldrule","is_required_field","required","is_primary_key_field","default","module","exports"],"mappings":";;AAAA,IAAMA,IAAIC,QAAQ,QAAR,CAAV;AACA,IAAMC,OAAOD,QAAQ,MAAR,CAAb;;AAEA,IAAME,YAAYF,QAAQ,aAAR,CAAlB;;AAEA,IAAMG,UAAU;AACdC,sBAAoBC,SAApB,EAA+B;AAC7B,WAAQ,OAAOA,SAAP,KAAqB,QAArB,IAAiC,0BAA0BC,IAA1B,CAA+BD,SAA/B,CAAzC;AACD,GAHa;AAIdE,iBAAeC,WAAf,EAA4BC,WAA5B,EAAyCC,SAAzC,EAAoD;AAClD,QAAI,CAACD,WAAL,EAAkB;AAChB,YAAO,IAAIE,KAAJ,CAAUV,KAAKW,MAAL,CAAY,2CAAZ,EAAyDF,SAAzD,CAAV,CAAP;AACD;AACD,QAAMG,YAAY,KAAKC,cAAL,CAAoBN,WAApB,EAAiCE,SAAjC,CAAlB;AACA,QAAI,CAACX,EAAEgB,GAAF,CAAMb,SAAN,EAAiBW,SAAjB,CAAL,EAAkC;AAChC,YAAO,IAAIF,KAAJ,CAAUV,KAAKW,MAAL,CAAY,uCAAZ,EAAqDH,YAAYO,IAAjE,EAAuEN,SAAvE,CAAV,CAAP;AACD;AACD,QAAI,CAAC,KAAD,EAAQ,MAAR,EAAgB,KAAhB,EAAuB,QAAvB,EAAiCO,QAAjC,CAA0CR,YAAYO,IAAtD,CAAJ,EAAiE;AAC/D,UAAI,CAACP,YAAYS,OAAjB,EAA0B;AACxB,cAAO,IAAIP,KAAJ,CAAUV,KAAKW,MAAL,CAAY,kDAAZ,EAAgEH,YAAYO,IAA5E,EAAkFN,SAAlF,CAAV,CAAP;AACD;AACD,UAAI,OAAOD,YAAYS,OAAnB,KAA+B,QAAnC,EAA6C;AAC3C,cAAO,IAAIP,KAAJ,CAAUV,KAAKW,MAAL,CAAY,kDAAZ,EAAgEH,YAAYO,IAA5E,EAAkFN,SAAlF,CAAV,CAAP;AACD;AACF;AACD,QAAI,CAAE,KAAKS,4BAAL,CAAkCX,WAAlC,EAA+CE,SAA/C,CAAN,EAAkE;AAChE,YAAO,IAAIC,KAAJ,CAAUV,KAAKW,MAAL,CAAY,wCAAZ,EAAsDF,SAAtD,EAAiED,YAAYO,IAA7E,CAAV,CAAP;AACD;AACF,GAvBa;;AAyBdI,uBAAqBZ,WAArB,EAAkC;AAChC,QAAI,OAAQA,YAAYa,GAAZ,CAAgB,CAAhB,CAAR,KAAgC,QAApC,EAA8C;AAC5C,UAAI,CAACtB,EAAEgB,GAAF,CAAMP,YAAYc,MAAlB,EAA0Bd,YAAYa,GAAZ,CAAgB,CAAhB,CAA1B,CAAL,EAAoD;AAClD,cAAO,IAAIV,KAAJ,CAAU,+CAAV,CAAP;AACD;AACD,UAAIH,YAAYc,MAAZ,CAAmBd,YAAYa,GAAZ,CAAgB,CAAhB,CAAnB,EAAuCE,OAA3C,EAAoD;AAClD,cAAO,IAAIZ,KAAJ,CAAU,2EAAV,CAAP;AACD;AACF,KAPD,MAOO,IAAIZ,EAAEyB,OAAF,CAAUhB,YAAYa,GAAZ,CAAgB,CAAhB,CAAV,CAAJ,EAAmC;AACxC,UAAIb,YAAYa,GAAZ,CAAgB,CAAhB,EAAmBI,MAAnB,KAA8B,CAAlC,EAAqC;AACnC,cAAO,IAAId,KAAJ,CAAU,oCAAV,CAAP;AACD;AACDH,kBAAYa,GAAZ,CAAgB,CAAhB,EAAmBK,OAAnB,CAA2B,UAACC,iBAAD,EAAuB;AAChD,YAAK,OAAQA,iBAAR,KAA+B,QAAhC,IAA6C,CAAC5B,EAAEgB,GAAF,CAAMP,YAAYc,MAAlB,EAA0BK,iBAA1B,CAAlD,EAAgG;AAC9F,gBAAO,IAAIhB,KAAJ,CAAU,yDAAV,CAAP;AACD;AACD,YAAIH,YAAYc,MAAZ,CAAmBK,iBAAnB,EAAsCJ,OAA1C,EAAmD;AACjD,gBAAO,IAAIZ,KAAJ,CAAU,yFAAV,CAAP;AACD;AACF,OAPD;AAQD,KAZM,MAYA;AACL,YAAO,IAAIA,KAAJ,CAAU,oEAAV,CAAP;AACD;;AAEDH,gBAAYa,GAAZ,CAAgBK,OAAhB,CAAwB,UAACE,eAAD,EAAkBC,eAAlB,EAAsC;AAC5D,UAAIA,kBAAkB,CAAtB,EAAyB;AACvB,YAAK,OAAQD,eAAR,KAA6B,QAA9B,IAA2C,CAAC7B,EAAEgB,GAAF,CAAMP,YAAYc,MAAlB,EAA0BM,eAA1B,CAAhD,EAA4F;AAC1F,gBAAO,IAAIjB,KAAJ,CAAU,2CAAV,CAAP;AACD;AACD,YAAIH,YAAYc,MAAZ,CAAmBM,eAAnB,EAAoCL,OAAxC,EAAiD;AAC/C,gBAAO,IAAIZ,KAAJ,CAAU,sEAAV,CAAP;AACD;AACF;AACF,KATD;;AAWA,QAAIH,YAAYsB,gBAAhB,EAAkC;AAChC,UAAI,CAAC/B,EAAEgC,aAAF,CAAgBvB,YAAYsB,gBAA5B,CAAL,EAAoD;AAClD,cAAO,IAAInB,KAAJ,CAAU,iEAAV,CAAP;AACD;;AAEDZ,QAAE2B,OAAF,CAAUlB,YAAYsB,gBAAtB,EAAwC,UAACE,eAAD,EAAkBC,mBAAlB,EAA0C;AAChF,YAAI,CAAC,CAAC,KAAD,EAAQ,MAAR,EAAgBhB,QAAhB,CAAyBe,gBAAgBE,WAAhB,EAAzB,CAAL,EAA8D;AAC5D,gBAAO,IAAIvB,KAAJ,CAAU,2DAAV,CAAP;AACD;AACD,YAAIH,YAAYa,GAAZ,CAAgBc,OAAhB,CAAwBF,mBAAxB,IAA+C,CAAnD,EAAsD;AACpD,gBAAO,IAAItB,KAAJ,CAAU,gEAAV,CAAP;AACD;AACF,OAPD;AAQD;AACF,GA1Ea;;AA4EdyB,6BAA2B5B,WAA3B,EAAwC6B,sBAAxC,EAAgEC,oBAAhE,EAAsF;AACpF,QAAI,CAACvC,EAAEgC,aAAF,CAAgBM,sBAAhB,CAAL,EAA8C;AAC5C,YAAO,IAAI1B,KAAJ,CAAUV,KAAKW,MAAL,CAAY,2DAAZ,EAAyE0B,oBAAzE,CAAV,CAAP;AACD;;AAED,QAAI,CAACD,uBAAuBE,MAAxB,IAAkC,CAACF,uBAAuBhB,GAA9D,EAAmE;AACjE,YAAO,IAAIV,KAAJ,CAAUV,KAAKW,MAAL,CAAY,gEAAZ,EAA8E0B,oBAA9E,CAAV,CAAP;AACD;;AAED,QAAI,CAACvC,EAAEyB,OAAF,CAAUa,uBAAuBE,MAAjC,CAAD,IAA6C,CAACxC,EAAEyB,OAAF,CAAUa,uBAAuBhB,GAAjC,CAAlD,EAAyF;AACvF,YAAO,IAAIV,KAAJ,CAAUV,KAAKW,MAAL,CAAY,yFAAZ,EAAuG0B,oBAAvG,CAAV,CAAP;AACD;;AAEDD,2BAAuBE,MAAvB,CAA8Bb,OAA9B,CAAsC,UAACc,2BAAD,EAAiC;AACrE,UAAK,OAAQA,2BAAR,KAAyC,QAA1C,IACK,EAAEzC,EAAEgB,GAAF,CAAMP,YAAYc,MAAlB,EAA0BkB,2BAA1B,KACFA,gCAAgC,GADhC,CADT,EAE+C;AAC7C,cAAO,IAAI7B,KAAJ,CAAUV,KAAKW,MAAL,CACf,iGADe,EAEf0B,oBAFe,CAAV,CAAP;AAID;;AAED,UAAI9B,YAAYc,MAAZ,CAAmBkB,2BAAnB,KACGhC,YAAYc,MAAZ,CAAmBkB,2BAAnB,EAAgDjB,OADvD,EACgE;AAC9D,cAAO,IAAIZ,KAAJ,CAAUV,KAAKW,MAAL,CACf,6FACA,uCAFe,EAGf0B,oBAHe,CAAV,CAAP;AAKD;AACF,KAlBD;;AAoBA;AACA,QAAI,OAAQD,uBAAuBhB,GAAvB,CAA2B,CAA3B,CAAR,KAA2C,QAA/C,EAAyD;AACvD,UAAI,CAACtB,EAAEgB,GAAF,CAAMP,YAAYc,MAAlB,EAA0Be,uBAAuBhB,GAAvB,CAA2B,CAA3B,CAA1B,CAAL,EAA+D;AAC7D,cAAO,IAAIV,KAAJ,CAAUV,KAAKW,MAAL,CAAY,0EAAZ,EAAwF0B,oBAAxF,CAAV,CAAP;AACD;AACD,UAAI9B,YAAYc,MAAZ,CAAmBe,uBAAuBhB,GAAvB,CAA2B,CAA3B,CAAnB,EAAkDE,OAAtD,EAA+D;AAC7D,cAAO,IAAIZ,KAAJ,CAAUV,KAAKW,MAAL,CACf,gGADe,EAEf0B,oBAFe,CAAV,CAAP;AAID;AACF,KAVD,MAUO,IAAIvC,EAAEyB,OAAF,CAAUa,uBAAuBhB,GAAvB,CAA2B,CAA3B,CAAV,CAAJ,EAA8C;AACnD,UAAIgB,uBAAuBhB,GAAvB,CAA2B,CAA3B,EAA8BI,MAA9B,KAAyC,CAA7C,EAAgD;AAC9C,cAAO,IAAId,KAAJ,CAAUV,KAAKW,MAAL,CAAY,2DAAZ,EAAyE0B,oBAAzE,CAAV,CAAP;AACD;AACDD,6BAAuBhB,GAAvB,CAA2B,CAA3B,EAA8BK,OAA9B,CAAsC,UAACe,iCAAD,EAAuC;AAC3E,YAAK,OAAQA,iCAAR,KAA+C,QAAhD,IACG,CAAC1C,EAAEgB,GAAF,CAAMP,YAAYc,MAAlB,EAA0BmB,iCAA1B,CADR,EACsE;AACpE,gBAAO,IAAI9B,KAAJ,CAAUV,KAAKW,MAAL,CACf,+EADe,EAEf0B,oBAFe,CAAV,CAAP;AAID;AACD,YAAI9B,YAAYc,MAAZ,CAAmBmB,iCAAnB,EAAsDlB,OAA1D,EAAmE;AACjE,gBAAO,IAAIZ,KAAJ,CAAUV,KAAKW,MAAL,CACf,iFACA,oCAFe,EAGf0B,oBAHe,CAAV,CAAP;AAKD;AACF,OAfD;AAgBD,KApBM,MAoBA;AACL,YAAO,IAAI3B,KAAJ,CAAUV,KAAKW,MAAL,CACf,0FADe,EAEf0B,oBAFe,CAAV,CAAP;AAID;;AAEDD,2BAAuBhB,GAAvB,CAA2BK,OAA3B,CAAmC,UAACgB,+BAAD,EAAkCC,+BAAlC,EAAsE;AACvG,UAAIA,kCAAkC,CAAtC,EAAyC;AACvC,YAAK,OAAQD,+BAAR,KAA6C,QAA9C,IACG,CAAC3C,EAAEgB,GAAF,CAAMP,YAAYc,MAAlB,EAA0BoB,+BAA1B,CADR,EACoE;AAClE,gBAAO,IAAI/B,KAAJ,CAAUV,KAAKW,MAAL,CAAY,iEAAZ,EAA+E0B,oBAA/E,CAAV,CAAP;AACD;AACD,YAAI9B,YAAYc,MAAZ,CAAmBoB,+BAAnB,EAAoDnB,OAAxD,EAAiE;AAC/D,gBAAO,IAAIZ,KAAJ,CAAUV,KAAKW,MAAL,CACf,6FADe,EAEf0B,oBAFe,CAAV,CAAP;AAID;AACF;AACF,KAbD;;AAeA,QAAID,uBAAuBP,gBAA3B,EAA6C;AAC3C,UAAI,CAAC/B,EAAEgC,aAAF,CAAgBM,uBAAuBP,gBAAvC,CAAL,EAA+D;AAC7D,cAAO,IAAInB,KAAJ,CAAUV,KAAKW,MAAL,CACf,uFADe,EAEf0B,oBAFe,CAAV,CAAP;AAID;;AAEDvC,QAAE2B,OAAF,CAAUW,uBAAuBP,gBAAjC,EAAmD,UAACc,iBAAD,EAAoBC,oBAApB,EAA6C;AAC9F,YAAI,CAAC,CAAC,KAAD,EAAQ,MAAR,EAAgB5B,QAAhB,CAAyB2B,kBAAkBV,WAAlB,EAAzB,CAAL,EAAgE;AAC9D,gBAAO,IAAIvB,KAAJ,CAAUV,KAAKW,MAAL,CAAY,iFAAZ,EAA+F0B,oBAA/F,CAAV,CAAP;AACD;AACD,YAAID,uBAAuBhB,GAAvB,CAA2Bc,OAA3B,CAAmCU,oBAAnC,IAA2D,CAA/D,EAAkE;AAChE,gBAAO,IAAIlC,KAAJ,CAAUV,KAAKW,MAAL,CACf,sFADe,EAEf0B,oBAFe,CAAV,CAAP;AAID;AACF,OAVD;AAWD;AACF,GAtLa;;AAwLdQ,iBAAetC,WAAf,EAA4BuC,QAA5B,EAAsC;AACpC,QAAI,OAAOA,QAAP,KAAoB,QAAxB,EAAkC;AAChC,YAAO,IAAIpC,KAAJ,CAAU,qCAAV,CAAP;AACD;;AAED,QAAMqC,gBAAgBD,SAASE,OAAT,CAAiB,QAAjB,EAA2B,EAA3B,EAA+BC,KAA/B,CAAqC,OAArC,CAAtB;AACA,QAAIF,cAAcvB,MAAd,GAAuB,CAA3B,EAA8B;AAC5BuB,oBAAc,CAAd,IAAmBA,cAAc,CAAd,EAAiBd,WAAjB,EAAnB;AACA,UAAI,CAAC,CAAC,SAAD,EAAY,MAAZ,EAAoB,QAApB,EAA8B,MAA9B,EAAsCjB,QAAtC,CAA+C+B,cAAc,CAAd,CAA/C,CAAL,EAAuE;AACrE,cAAO,IAAIrC,KAAJ,CAAUV,KAAKW,MAAL,CAAY,oCAAZ,EAAkDmC,QAAlD,CAAV,CAAP;AACD;AACD,UAAI,CAAChD,EAAEgB,GAAF,CAAMP,YAAYc,MAAlB,EAA0B0B,cAAc,CAAd,CAA1B,CAAL,EAAkD;AAChD,cAAO,IAAIrC,KAAJ,CAAUV,KAAKW,MAAL,CAAY,wEAAZ,EAAsFoC,cAAc,CAAd,CAAtF,CAAV,CAAP;AACD;AACD,UAAIxC,YAAYc,MAAZ,CAAmB0B,cAAc,CAAd,CAAnB,EAAqCzB,OAAzC,EAAkD;AAChD,cAAO,IAAIZ,KAAJ,CAAU,0EAAV,CAAP;AACD;AACF,KAXD,MAWO;AACL,UAAI,CAACZ,EAAEgB,GAAF,CAAMP,YAAYc,MAAlB,EAA0B0B,cAAc,CAAd,CAA1B,CAAL,EAAkD;AAChD,cAAO,IAAIrC,KAAJ,CAAUV,KAAKW,MAAL,CAAY,mEAAZ,EAAiFoC,cAAc,CAAd,CAAjF,CAAV,CAAP;AACD;AACD,UAAIxC,YAAYc,MAAZ,CAAmB0B,cAAc,CAAd,CAAnB,EAAqCzB,OAAzC,EAAkD;AAChD,cAAO,IAAIZ,KAAJ,CAAU,0EAAV,CAAP;AACD;AACF;AACF,GAjNa;;AAmNdwC,wBAAsB3C,WAAtB,EAAmC4C,WAAnC,EAAgD;AAC9C,QAAI,CAACrD,EAAEgC,aAAF,CAAgBqB,WAAhB,CAAL,EAAmC;AACjC,YAAO,IAAIzC,KAAJ,CAAU,gEAAV,CAAP;AACD;AACD,QAAK,OAAQyC,YAAYC,EAApB,KAA4B,QAA7B,IAA0C,CAACtD,EAAEgB,GAAF,CAAMP,YAAYc,MAAlB,EAA0B8B,YAAYC,EAAtC,CAA/C,EAA0F;AACxF,YAAO,IAAI1C,KAAJ,CAAU,iGAAV,CAAP;AACD;AACD,QAAIH,YAAYc,MAAZ,CAAmB8B,YAAYC,EAA/B,EAAmC9B,OAAvC,EAAgD;AAC9C,YAAO,IAAIZ,KAAJ,CAAU,mFAAV,CAAP;AACD;AACD,QAAI,OAAQyC,YAAYE,KAApB,KAA+B,QAAnC,EAA6C;AAC3C,YAAO,IAAI3C,KAAJ,CAAU,8DAAV,CAAP;AACD;AACD,QAAI,CAACZ,EAAEgC,aAAF,CAAgBqB,YAAYG,OAA5B,CAAL,EAA2C;AACzC,YAAO,IAAI5C,KAAJ,CAAU,6EACf,iDADK,CAAP;AAED;AACF,GApOa;;AAsOd6C,wBAAsBhD,WAAtB,EAAmC;AAAA;;AACjC,QAAI,CAACA,WAAL,EAAkB;AAChB,YAAO,IAAIG,KAAJ,CAAU,4BAAV,CAAP;AACD;;AAED,QAAI,CAACZ,EAAEgC,aAAF,CAAgBvB,YAAYc,MAA5B,CAAD,IAAwCmC,OAAOC,IAAP,CAAYlD,YAAYc,MAAxB,EAAgCG,MAAhC,KAA2C,CAAvF,EAA0F;AACxF,YAAO,IAAId,KAAJ,CAAU,qDAAV,CAAP;AACD;;AAED,QAAI,CAACH,YAAYa,GAAb,IAAoB,CAACtB,EAAEyB,OAAF,CAAUhB,YAAYa,GAAtB,CAAzB,EAAqD;AACnD,YAAO,IAAIV,KAAJ,CAAU,qFAAV,CAAP;AACD;;AAEDZ,MAAE2B,OAAF,CAAUlB,YAAYc,MAAtB,EAA8B,UAACb,WAAD,EAAcC,SAAd,EAA4B;AACxD,YAAKH,cAAL,CAAoBC,WAApB,EAAiCC,WAAjC,EAA8CC,SAA9C;AACD,KAFD;;AAIA,SAAKU,oBAAL,CAA0BZ,WAA1B;;AAEA,QAAIA,YAAYmD,kBAAhB,EAAoC;AAClC,UAAI,CAAC5D,EAAEgC,aAAF,CAAgBvB,YAAYmD,kBAA5B,CAAL,EAAsD;AACpD,cAAO,IAAIhD,KAAJ,CAAU,oEAAV,CAAP;AACD;AACDZ,QAAE2B,OAAF,CAAUlB,YAAYmD,kBAAtB,EAA0C,UAACtB,sBAAD,EAAyBC,oBAAzB,EAAkD;AAC1F,cAAKF,0BAAL,CAAgC5B,WAAhC,EAA6C6B,sBAA7C,EAAqEC,oBAArE;AACD,OAFD;AAGD;;AAED,QAAI9B,YAAYoD,OAAhB,EAAyB;AACvB,UAAI,CAAC7D,EAAEyB,OAAF,CAAUhB,YAAYoD,OAAtB,CAAL,EAAqC;AACnC,cAAO,IAAIjD,KAAJ,CAAU,gDAAV,CAAP;AACD;;AAEDH,kBAAYoD,OAAZ,CAAoBlC,OAApB,CAA4B,UAACqB,QAAD,EAAc;AACxC,cAAKD,cAAL,CAAoBtC,WAApB,EAAiCuC,QAAjC;AACD,OAFD;AAGD;;AAED,QAAIvC,YAAYqD,YAAZ,IAA4BrD,YAAYsD,cAA5C,EAA4D;AAC1D,YAAO,IAAInD,KAAJ,CAAU,gGAAV,CAAP;AACD;;AAED,QAAIH,YAAYqD,YAAhB,EAA8B;AAC5B,WAAKV,qBAAL,CAA2B3C,WAA3B,EAAwCA,YAAYqD,YAApD;AACD;;AAED,QAAIrD,YAAYsD,cAAhB,EAAgC;AAC9B,UAAI,CAAC/D,EAAEyB,OAAF,CAAUhB,YAAYsD,cAAtB,CAAL,EAA4C;AAC1C,cAAO,IAAInD,KAAJ,CAAU,8EAAV,CAAP;AACD;AACDH,kBAAYsD,cAAZ,CAA2BpC,OAA3B,CAAmC,UAAC0B,WAAD,EAAiB;AAClD,cAAKD,qBAAL,CAA2B3C,WAA3B,EAAwC4C,WAAxC;AACD,OAFD;AAGD;AACF,GA5Ra;;AA8RdW,yBAAuBC,IAAvB,EAA6BC,SAA7B,EAAwC;AACtC,QAAI,CAAClE,EAAEgC,aAAF,CAAgBiC,IAAhB,CAAL,EAA4B;AAC1B,YAAO,IAAIrD,KAAJ,CAAUV,KAAKW,MAAL,CAAY,0DAAZ,EAAwEqD,SAAxE,CAAV,CAAP;AACD;AACD,QAAI,OAAOD,KAAKE,SAAZ,KAA0B,UAA9B,EAA0C;AACxC,YAAO,IAAIvD,KAAJ,CAAUV,KAAKW,MAAL,CAAY,kDAAZ,EAAgEqD,SAAhE,CAAV,CAAP;AACD;AACD,QAAI,CAACD,KAAKG,OAAV,EAAmB;AACjBH,WAAKG,OAAL,GAAe,KAAKC,8BAApB;AACD;AACD,QAAI,OAAOJ,KAAKG,OAAZ,KAAwB,QAA5B,EAAsC;AACpCH,WAAKG,OAAL,GAAe,SAASE,EAAT,CAAYF,OAAZ,EAAqB;AAClC,eAAOlE,KAAKW,MAAL,CAAYuD,OAAZ,CAAP;AACD,OAFc,CAEbG,IAFa,CAER,IAFQ,EAEFN,KAAKG,OAFH,CAAf;AAGD;AACD,QAAI,OAAOH,KAAKG,OAAZ,KAAwB,UAA5B,EAAwC;AACtC,YAAO,IAAIxD,KAAJ,CAAUV,KAAKW,MAAL,CAAY,kEAAZ,EAAgFqD,SAAhF,CAAV,CAAP;AACD;AACD,WAAOD,IAAP;AACD,GAjTa;;AAmTdI,iCAA+BG,KAA/B,EAAsCC,QAAtC,EAAgD3D,SAAhD,EAA2D;AACzD,WAAOZ,KAAKW,MAAL,CAAY,8CAAZ,EAA4D2D,KAA5D,EAAmEC,QAAnE,EAA6E3D,SAA7E,CAAP;AACD,GArTa;;AAuTd4D,yBAAuBC,UAAvB,EAAmCH,KAAnC,EAA0C;AACxC,QAAIA,SAAS,IAAT,IAAkBxE,EAAEgC,aAAF,CAAgBwC,KAAhB,KAA0BA,MAAMI,YAAtD,EAAqE;AACnE,aAAO,IAAP;AACD;;AAED,SAAK,IAAIC,IAAI,CAAb,EAAgBA,IAAIF,WAAWjD,MAA/B,EAAuCmD,GAAvC,EAA4C;AAC1C,UAAI,OAAOF,WAAWE,CAAX,EAAcV,SAArB,KAAmC,UAAvC,EAAmD;AACjD,YAAI,CAACQ,WAAWE,CAAX,EAAcV,SAAd,CAAwBK,KAAxB,CAAL,EAAqC;AACnC,iBAAOG,WAAWE,CAAX,EAAcT,OAArB;AACD;AACF;AACF;AACD,WAAO,IAAP;AACD,GApUa;;AAsUdU,iBAAerE,WAAf,EAA4ByD,SAA5B,EAAuC;AAAA;;AACrC,QAAMS,aAAa,EAAnB;AACA,QAAM7D,YAAY,KAAKC,cAAL,CAAoBN,WAApB,EAAiCyD,SAAjC,CAAlB;AACA,QAAMa,qBAAqB5E,UAAU6E,sBAAV,CAAiClE,SAAjC,CAA3B;;AAEA,QAAIiE,kBAAJ,EAAwB;AACtBJ,iBAAWM,IAAX,CAAgBF,kBAAhB;AACD;;AAED,QAAMG,QAAQzE,YAAYc,MAAZ,CAAmB2C,SAAnB,CAAd;AACA,QAAI,OAAOgB,MAAMjB,IAAb,KAAsB,WAA1B,EAAuC;AACrC,UAAI,OAAOiB,MAAMjB,IAAb,KAAsB,UAA1B,EAAsC;AACpCiB,cAAMjB,IAAN,GAAa;AACXE,qBAAWe,MAAMjB,IADN;AAEXG,mBAAS,KAAKC;AAFH,SAAb;AAIAM,mBAAWM,IAAX,CAAgBC,MAAMjB,IAAtB;AACD,OAND,MAMO,IAAIkB,MAAM1D,OAAN,CAAcyD,MAAMjB,IAAN,CAAWU,UAAzB,CAAJ,EAA0C;AAC/CO,cAAMjB,IAAN,CAAWU,UAAX,CAAsBhD,OAAtB,CAA8B,UAACyD,SAAD,EAAe;AAC3CT,qBAAWM,IAAX,CAAgB,OAAKjB,sBAAL,CAA4BoB,SAA5B,EAAuClB,SAAvC,CAAhB;AACD,SAFD;AAGD,OAJM,MAIA,IAAIgB,MAAMjB,IAAN,CAAWE,SAAf,EAA0B;AAC/BQ,mBAAWM,IAAX,CAAgB,KAAKjB,sBAAL,CAA4BkB,MAAMjB,IAAlC,EAAwCC,SAAxC,CAAhB;AACD;AACF;;AAED,WAAOS,UAAP;AACD,GAjWa;;AAmWd5D,iBAAeN,WAAf,EAA4BE,SAA5B,EAAuC;AACrC,QAAMD,cAAcD,YAAYc,MAAZ,CAAmBZ,SAAnB,CAApB;;AAEA,QAAI,OAAOD,WAAP,KAAuB,QAA3B,EAAqC;AACnC,aAAOA,WAAP;AACD;AACD,QAAIV,EAAEgC,aAAF,CAAgBtB,WAAhB,CAAJ,EAAkC;AAChC,aAAOA,YAAYO,IAAnB;AACD;AACD,UAAO,IAAIL,KAAJ,CAAU,iCAAV,CAAP;AACD,GA7Wa;;AA+WdyE,oBAAkB5E,WAAlB,EAA+BE,SAA/B,EAA0C;AACxC,QAAIF,YAAYc,MAAZ,CAAmBZ,SAAnB,EAA8BsD,IAA9B,IAAsCxD,YAAYc,MAAZ,CAAmBZ,SAAnB,EAA8BsD,IAA9B,CAAmCqB,QAA7E,EAAuF;AACrF,aAAO,IAAP;AACD;AACD,WAAO,KAAP;AACD,GApXa;;AAsXdC,uBAAqB9E,WAArB,EAAkCE,SAAlC,EAA6C;AAC3C,QAAIF,YAAYa,GAAZ,CAAgBJ,QAAhB,CAAyBP,SAAzB,KAAuCF,YAAYa,GAAZ,CAAgB,CAAhB,EAAmBJ,QAAnB,CAA4BP,SAA5B,CAA3C,EAAmF;AACjF,aAAO,IAAP;AACD;AACD,WAAO,KAAP;AACD,GA3Xa;;AA6XdS,+BAA6BX,WAA7B,EAA0CE,SAA1C,EAAqD;AACnD,QAAIX,EAAEgC,aAAF,CAAgBvB,YAAYc,MAAZ,CAAmBZ,SAAnB,CAAhB,KAAkDF,YAAYc,MAAZ,CAAmBZ,SAAnB,EAA8B6E,OAApF,EAA6F;AAC3F,UAAIxF,EAAEgC,aAAF,CAAgBvB,YAAYc,MAAZ,CAAmBZ,SAAnB,EAA8B6E,OAA9C,KACG,CAAE/E,YAAYc,MAAZ,CAAmBZ,SAAnB,EAA8B6E,OAA9B,CAAsCZ,YAD/C,EAC8D;AAC5D,eAAO,CAAC,KAAD,EAAQ,MAAR,EAAgB,KAAhB,EAAuB,QAAvB,EAAiC1D,QAAjC,CAA0CT,YAAYc,MAAZ,CAAmBZ,SAAnB,EAA8BM,IAAxE,CAAP;AACD;AACD,aAAO,IAAP;AACD;AACD,WAAO,IAAP;AACD;;AAtYa,CAAhB;;AA0YAwE,OAAOC,OAAP,GAAiBtF,OAAjB","file":"schema.js","sourcesContent":["const _ = require('lodash');\nconst util = require('util');\n\nconst datatypes = require('./datatypes');\n\nconst schemer = {\n  validate_table_name(tableName) {\n    return (typeof tableName === 'string' && /^[a-zA-Z]+[a-zA-Z0-9_]*/.test(tableName));\n  },\n  validate_field(modelSchema, fieldObject, fieldName) {\n    if (!fieldObject) {\n      throw (new Error(util.format('Schema field \"%s\" is not properly defined', fieldName)));\n    }\n    const fieldtype = this.get_field_type(modelSchema, fieldName);\n    if (!_.has(datatypes, fieldtype)) {\n      throw (new Error(util.format('Invalid field type \"%s\" for field: %s', fieldObject.type, fieldName)));\n    }\n    if (['map', 'list', 'set', 'frozen'].includes(fieldObject.type)) {\n      if (!fieldObject.typeDef) {\n        throw (new Error(util.format('Missing typeDef for field type \"%s\" on field: %s', fieldObject.type, fieldName)));\n      }\n      if (typeof fieldObject.typeDef !== 'string') {\n        throw (new Error(util.format('Invalid typeDef for field type \"%s\" on field: %s', fieldObject.type, fieldName)));\n      }\n    }\n    if (!(this.is_field_default_value_valid(modelSchema, fieldName))) {\n      throw (new Error(util.format('Invalid defult value for field: %s(%s)', fieldName, fieldObject.type)));\n    }\n  },\n\n  validate_primary_key(modelSchema) {\n    if (typeof (modelSchema.key[0]) === 'string') {\n      if (!_.has(modelSchema.fields, modelSchema.key[0])) {\n        throw (new Error('Partition Key must also be a valid field name'));\n      }\n      if (modelSchema.fields[modelSchema.key[0]].virtual) {\n        throw (new Error(\"Partition Key must also be a db field name, can't be a virtual field name\"));\n      }\n    } else if (_.isArray(modelSchema.key[0])) {\n      if (modelSchema.key[0].length === 0) {\n        throw (new Error(\"Partition Key array can't be empty\"));\n      }\n      modelSchema.key[0].forEach((partitionKeyField) => {\n        if ((typeof (partitionKeyField) !== 'string') || !_.has(modelSchema.fields, partitionKeyField)) {\n          throw (new Error('Partition Key array must contain only valid field names'));\n        }\n        if (modelSchema.fields[partitionKeyField].virtual) {\n          throw (new Error(\"Partition Key array must contain only db field names, can't contain virtual field names\"));\n        }\n      });\n    } else {\n      throw (new Error('Partition Key must be a field name string, or array of field names'));\n    }\n\n    modelSchema.key.forEach((primaryKeyField, primaryKeyIndex) => {\n      if (primaryKeyIndex > 0) {\n        if ((typeof (primaryKeyField) !== 'string') || !_.has(modelSchema.fields, primaryKeyField)) {\n          throw (new Error('Clustering Keys must be valid field names'));\n        }\n        if (modelSchema.fields[primaryKeyField].virtual) {\n          throw (new Error(\"Clustering Keys must be db field names, can't be virtual field names\"));\n        }\n      }\n    });\n\n    if (modelSchema.clustering_order) {\n      if (!_.isPlainObject(modelSchema.clustering_order)) {\n        throw (new Error('clustering_order must be an object of clustering_key attributes'));\n      }\n\n      _.forEach(modelSchema.clustering_order, (clusteringOrder, clusteringFieldName) => {\n        if (!['asc', 'desc'].includes(clusteringOrder.toLowerCase())) {\n          throw (new Error('clustering_order attribute values can only be ASC or DESC'));\n        }\n        if (modelSchema.key.indexOf(clusteringFieldName) < 1) {\n          throw (new Error('clustering_order field attributes must be clustering keys only'));\n        }\n      });\n    }\n  },\n\n  validate_materialized_view(modelSchema, materializedViewObject, materializedViewName) {\n    if (!_.isPlainObject(materializedViewObject)) {\n      throw (new Error(util.format('attribute \"%s\" under materialized_views must be an object', materializedViewName)));\n    }\n\n    if (!materializedViewObject.select || !materializedViewObject.key) {\n      throw (new Error(util.format('materialized_view \"%s\" must have \"select\" and \"key\" attributes', materializedViewName)));\n    }\n\n    if (!_.isArray(materializedViewObject.select) || !_.isArray(materializedViewObject.key)) {\n      throw (new Error(util.format('\"select\" and \"key\" attributes must be an array under attribute %s of materialized_views', materializedViewName)));\n    }\n\n    materializedViewObject.select.forEach((materializedViewSelectField) => {\n      if ((typeof (materializedViewSelectField) !== 'string')\n            || !(_.has(modelSchema.fields, materializedViewSelectField)\n            || materializedViewSelectField === '*')) {\n        throw (new Error(util.format(\n          'the select attribute under materialized_view %s must be an array of field name strings or [\"*\"]',\n          materializedViewName,\n        )));\n      }\n\n      if (modelSchema.fields[materializedViewSelectField]\n          && modelSchema.fields[materializedViewSelectField].virtual) {\n        throw (new Error(util.format(\n          'the select attribute under %s of materialized_views must be an array of db field names, ' +\n          'cannot contain any virtual field name',\n          materializedViewName,\n        )));\n      }\n    });\n\n    // validate materialized_view primary key\n    if (typeof (materializedViewObject.key[0]) === 'string') {\n      if (!_.has(modelSchema.fields, materializedViewObject.key[0])) {\n        throw (new Error(util.format('materialized_view %s: partition key string must match a valid field name', materializedViewName)));\n      }\n      if (modelSchema.fields[materializedViewObject.key[0]].virtual) {\n        throw (new Error(util.format(\n          'materialized_view %s: partition key must match a db field name, cannot be a virtual field name',\n          materializedViewName,\n        )));\n      }\n    } else if (_.isArray(materializedViewObject.key[0])) {\n      if (materializedViewObject.key[0].length === 0) {\n        throw (new Error(util.format('materialized_view %s: partition key array cannot be empty', materializedViewName)));\n      }\n      materializedViewObject.key[0].forEach((materializedViewPartitionKeyField) => {\n        if ((typeof (materializedViewPartitionKeyField) !== 'string')\n            || !_.has(modelSchema.fields, materializedViewPartitionKeyField)) {\n          throw (new Error(util.format(\n            'materialized_view %s: partition key array must contain only valid field names',\n            materializedViewName,\n          )));\n        }\n        if (modelSchema.fields[materializedViewPartitionKeyField].virtual) {\n          throw (new Error(util.format(\n            'materialized_view %s: partition key array must contain only db field names, ' +\n            'cannot contain virtual field names',\n            materializedViewName,\n          )));\n        }\n      });\n    } else {\n      throw (new Error(util.format(\n        'materialized_view %s: partition key must be a field name string, or array of field names',\n        materializedViewName,\n      )));\n    }\n\n    materializedViewObject.key.forEach((materializedViewPrimaryKeyField, materializedViewPrimaryKeyIndex) => {\n      if (materializedViewPrimaryKeyIndex > 0) {\n        if ((typeof (materializedViewPrimaryKeyField) !== 'string')\n            || !_.has(modelSchema.fields, materializedViewPrimaryKeyField)) {\n          throw (new Error(util.format('materialized_view %s: clustering keys must be valid field names', materializedViewName)));\n        }\n        if (modelSchema.fields[materializedViewPrimaryKeyField].virtual) {\n          throw (new Error(util.format(\n            'materialized_view %s: clustering keys must be db field names, cannot contain virtual fields',\n            materializedViewName,\n          )));\n        }\n      }\n    });\n\n    if (materializedViewObject.clustering_order) {\n      if (!_.isPlainObject(materializedViewObject.clustering_order)) {\n        throw (new Error(util.format(\n          'materialized_view %s: clustering_order must be an object of clustering_key attributes',\n          materializedViewName,\n        )));\n      }\n\n      _.forEach(materializedViewObject.clustering_order, (mvClusteringOrder, mvlusteringFieldName) => {\n        if (!['asc', 'desc'].includes(mvClusteringOrder.toLowerCase())) {\n          throw (new Error(util.format('materialized_view %s: clustering_order attribute values can only be ASC or DESC', materializedViewName)));\n        }\n        if (materializedViewObject.key.indexOf(mvlusteringFieldName) < 1) {\n          throw (new Error(util.format(\n            'materialized_view %s: clustering_order field attributes must be clustering keys only',\n            materializedViewName,\n          )));\n        }\n      });\n    }\n  },\n\n  validate_index(modelSchema, indexDef) {\n    if (typeof indexDef !== 'string') {\n      throw (new Error('indexes must be an array of strings'));\n    }\n\n    const indexNameList = indexDef.replace(/[\"\\s]/g, '').split(/[()]/g);\n    if (indexNameList.length > 1) {\n      indexNameList[0] = indexNameList[0].toLowerCase();\n      if (!['entries', 'keys', 'values', 'full'].includes(indexNameList[0])) {\n        throw (new Error(util.format('index \"%s\" is not defined properly', indexDef)));\n      }\n      if (!_.has(modelSchema.fields, indexNameList[1])) {\n        throw (new Error(util.format('\"%s\" is not a valid field name, indexes must be defined on field names', indexNameList[1])));\n      }\n      if (modelSchema.fields[indexNameList[1]].virtual) {\n        throw (new Error(\"indexes must be an array of db field names, can't contain virtual fields\"));\n      }\n    } else {\n      if (!_.has(modelSchema.fields, indexNameList[0])) {\n        throw (new Error(util.format('\"%s\" is not a valid field, indexes must be defined on field names', indexNameList[0])));\n      }\n      if (modelSchema.fields[indexNameList[0]].virtual) {\n        throw (new Error(\"indexes must be an array of db field names, can't contain virtual fields\"));\n      }\n    }\n  },\n\n  validate_custom_index(modelSchema, customIndex) {\n    if (!_.isPlainObject(customIndex)) {\n      throw (new Error('custom_index must be an object with proper indexing attributes'));\n    }\n    if ((typeof (customIndex.on) !== 'string') || !_.has(modelSchema.fields, customIndex.on)) {\n      throw (new Error(\"custom_index must have an 'on' attribute with string value and value must be a valid field name\"));\n    }\n    if (modelSchema.fields[customIndex.on].virtual) {\n      throw (new Error(\"custom_index 'on' attribute must be a db field name, can't contain virtual fields\"));\n    }\n    if (typeof (customIndex.using) !== 'string') {\n      throw (new Error(\"custom_index must have a 'using' attribute with string value\"));\n    }\n    if (!_.isPlainObject(customIndex.options)) {\n      throw (new Error('custom_index must have an \"options\" attribute and it must be an object, ' +\n        'pass blank {} object if no options are required'));\n    }\n  },\n\n  validate_model_schema(modelSchema) {\n    if (!modelSchema) {\n      throw (new Error('A schema must be specified'));\n    }\n\n    if (!_.isPlainObject(modelSchema.fields) || Object.keys(modelSchema.fields).length === 0) {\n      throw (new Error('Schema must contain a non-empty \"fields\" map object'));\n    }\n\n    if (!modelSchema.key || !_.isArray(modelSchema.key)) {\n      throw (new Error('Schema must contain \"key\" in the form: [ [partitionkey1, ...], clusteringkey1, ...]'));\n    }\n\n    _.forEach(modelSchema.fields, (fieldObject, fieldName) => {\n      this.validate_field(modelSchema, fieldObject, fieldName);\n    });\n\n    this.validate_primary_key(modelSchema);\n\n    if (modelSchema.materialized_views) {\n      if (!_.isPlainObject(modelSchema.materialized_views)) {\n        throw (new Error('materialized_views must be an object with view names as attributes'));\n      }\n      _.forEach(modelSchema.materialized_views, (materializedViewObject, materializedViewName) => {\n        this.validate_materialized_view(modelSchema, materializedViewObject, materializedViewName);\n      });\n    }\n\n    if (modelSchema.indexes) {\n      if (!_.isArray(modelSchema.indexes)) {\n        throw (new Error('indexes must be an array of field name strings'));\n      }\n\n      modelSchema.indexes.forEach((indexDef) => {\n        this.validate_index(modelSchema, indexDef);\n      });\n    }\n\n    if (modelSchema.custom_index && modelSchema.custom_indexes) {\n      throw (new Error('both custom_index and custom_indexes are defined in schema, only one of them should be defined'));\n    }\n\n    if (modelSchema.custom_index) {\n      this.validate_custom_index(modelSchema, modelSchema.custom_index);\n    }\n\n    if (modelSchema.custom_indexes) {\n      if (!_.isArray(modelSchema.custom_indexes)) {\n        throw (new Error('custom_indexes must be an array with objects with proper indexing attributes'));\n      }\n      modelSchema.custom_indexes.forEach((customIndex) => {\n        this.validate_custom_index(modelSchema, customIndex);\n      });\n    }\n  },\n\n  format_validation_rule(rule, fieldname) {\n    if (!_.isPlainObject(rule)) {\n      throw (new Error(util.format('Validation rule for \"%s\" must be a function or an object', fieldname)));\n    }\n    if (typeof rule.validator !== 'function') {\n      throw (new Error(util.format('Rule validator for \"%s\" must be a valid function', fieldname)));\n    }\n    if (!rule.message) {\n      rule.message = this.get_generic_validation_message;\n    }\n    if (typeof rule.message === 'string') {\n      rule.message = function f1(message) {\n        return util.format(message);\n      }.bind(null, rule.message);\n    }\n    if (typeof rule.message !== 'function') {\n      throw (new Error(util.format('Invalid validator message for \"%s\", must be string or a function', fieldname)));\n    }\n    return rule;\n  },\n\n  get_generic_validation_message(value, propName, fieldtype) {\n    return util.format('Invalid Value: \"%s\" for Field: %s (Type: %s)', value, propName, fieldtype);\n  },\n\n  get_validation_message(validators, value) {\n    if (value == null || (_.isPlainObject(value) && value.$db_function)) {\n      return true;\n    }\n\n    for (let v = 0; v < validators.length; v++) {\n      if (typeof validators[v].validator === 'function') {\n        if (!validators[v].validator(value)) {\n          return validators[v].message;\n        }\n      }\n    }\n    return true;\n  },\n\n  get_validators(modelSchema, fieldname) {\n    const validators = [];\n    const fieldtype = this.get_field_type(modelSchema, fieldname);\n    const typeFieldValidator = datatypes.generic_type_validator(fieldtype);\n\n    if (typeFieldValidator) {\n      validators.push(typeFieldValidator);\n    }\n\n    const field = modelSchema.fields[fieldname];\n    if (typeof field.rule !== 'undefined') {\n      if (typeof field.rule === 'function') {\n        field.rule = {\n          validator: field.rule,\n          message: this.get_generic_validation_message,\n        };\n        validators.push(field.rule);\n      } else if (Array.isArray(field.rule.validators)) {\n        field.rule.validators.forEach((fieldrule) => {\n          validators.push(this.format_validation_rule(fieldrule, fieldname));\n        });\n      } else if (field.rule.validator) {\n        validators.push(this.format_validation_rule(field.rule, fieldname));\n      }\n    }\n\n    return validators;\n  },\n\n  get_field_type(modelSchema, fieldName) {\n    const fieldObject = modelSchema.fields[fieldName];\n\n    if (typeof fieldObject === 'string') {\n      return fieldObject;\n    }\n    if (_.isPlainObject(fieldObject)) {\n      return fieldObject.type;\n    }\n    throw (new Error('Field type not defined properly'));\n  },\n\n  is_required_field(modelSchema, fieldName) {\n    if (modelSchema.fields[fieldName].rule && modelSchema.fields[fieldName].rule.required) {\n      return true;\n    }\n    return false;\n  },\n\n  is_primary_key_field(modelSchema, fieldName) {\n    if (modelSchema.key.includes(fieldName) || modelSchema.key[0].includes(fieldName)) {\n      return true;\n    }\n    return false;\n  },\n\n  is_field_default_value_valid(modelSchema, fieldName) {\n    if (_.isPlainObject(modelSchema.fields[fieldName]) && modelSchema.fields[fieldName].default) {\n      if (_.isPlainObject(modelSchema.fields[fieldName].default)\n          && !(modelSchema.fields[fieldName].default.$db_function)) {\n        return ['map', 'list', 'set', 'frozen'].includes(modelSchema.fields[fieldName].type);\n      }\n      return true;\n    }\n    return true;\n  },\n\n};\n\nmodule.exports = schemer;\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/validators/schema.js"],"names":["_","require","util","datatypes","schemer","validate_table_name","tableName","test","has_field","modelSchema","fieldName","optionFieldNames","options","timestamps","timestampOptions","createdAt","updatedAt","push","versions","versionOptions","key","has","fields","includes","validate_field","fieldObject","Error","format","fieldtype","get_field_type","type","typeDef","is_field_default_value_valid","validate_primary_key","virtual","isArray","length","forEach","partitionKeyField","primaryKeyField","primaryKeyIndex","clustering_order","isPlainObject","clusteringOrder","clusteringFieldName","toLowerCase","indexOf","validate_materialized_view","materializedViewObject","materializedViewName","select","materializedViewSelectField","materializedViewPartitionKeyField","materializedViewPrimaryKeyField","materializedViewPrimaryKeyIndex","mvClusteringOrder","mvlusteringFieldName","validate_index","indexDef","indexNameList","replace","split","validate_custom_index","customIndex","on","using","validate_model_schema","Object","keys","materialized_views","indexes","custom_index","custom_indexes","format_validation_rule","rule","fieldname","validator","message","get_generic_validation_message","f1","bind","value","propName","get_validation_message","validators","$db_function","v","get_validators","typeFieldValidator","generic_type_validator","field","Array","fieldrule","is_required_field","required","is_primary_key_field","default","module","exports"],"mappings":"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","file":"schema.js","sourcesContent":["const _ = require('lodash');\nconst util = require('util');\n\nconst datatypes = require('./datatypes');\n\nconst schemer = {\n  validate_table_name(tableName) {\n    return (typeof tableName === 'string' && /^[a-zA-Z]+[a-zA-Z0-9_]*/.test(tableName));\n  },\n  has_field(modelSchema, fieldName) {\n    const optionFieldNames = [];\n    if (modelSchema.options) {\n      if (modelSchema.options.timestamps) {\n        const timestampOptions = {\n          createdAt: modelSchema.options.timestamps.createdAt || 'createdAt',\n          updatedAt: modelSchema.options.timestamps.updatedAt || 'updatedAt',\n        };\n        optionFieldNames.push(timestampOptions.createdAt);\n        optionFieldNames.push(timestampOptions.updatedAt);\n      }\n\n      if (modelSchema.options.versions) {\n        const versionOptions = {\n          key: modelSchema.options.versions.key || '__v',\n        };\n        optionFieldNames.push(versionOptions.key);\n      }\n    }\n    return _.has(modelSchema.fields, fieldName) || optionFieldNames.includes(fieldName);\n  },\n  validate_field(modelSchema, fieldObject, fieldName) {\n    if (!fieldObject) {\n      throw (new Error(util.format('Schema field \"%s\" is not properly defined', fieldName)));\n    }\n    const fieldtype = this.get_field_type(modelSchema, fieldName);\n    if (!_.has(datatypes, fieldtype)) {\n      throw (new Error(util.format('Invalid field type \"%s\" for field: %s', fieldObject.type, fieldName)));\n    }\n    if (['map', 'list', 'set', 'frozen'].includes(fieldObject.type)) {\n      if (!fieldObject.typeDef) {\n        throw (new Error(util.format('Missing typeDef for field type \"%s\" on field: %s', fieldObject.type, fieldName)));\n      }\n      if (typeof fieldObject.typeDef !== 'string') {\n        throw (new Error(util.format('Invalid typeDef for field type \"%s\" on field: %s', fieldObject.type, fieldName)));\n      }\n    }\n    if (!(this.is_field_default_value_valid(modelSchema, fieldName))) {\n      throw (new Error(util.format('Invalid defult value for field: %s(%s)', fieldName, fieldObject.type)));\n    }\n  },\n\n  validate_primary_key(modelSchema) {\n    if (typeof (modelSchema.key[0]) === 'string') {\n      if (!this.has_field(modelSchema, modelSchema.key[0])) {\n        throw (new Error('Partition Key must also be a valid field name'));\n      }\n      if (modelSchema.fields[modelSchema.key[0]] && modelSchema.fields[modelSchema.key[0]].virtual) {\n        throw (new Error(\"Partition Key must also be a db field name, can't be a virtual field name\"));\n      }\n    } else if (_.isArray(modelSchema.key[0])) {\n      if (modelSchema.key[0].length === 0) {\n        throw (new Error(\"Partition Key array can't be empty\"));\n      }\n      modelSchema.key[0].forEach((partitionKeyField) => {\n        if ((typeof (partitionKeyField) !== 'string') || !this.has_field(modelSchema, partitionKeyField)) {\n          throw (new Error('Partition Key array must contain only valid field names'));\n        }\n        if (modelSchema.fields[partitionKeyField] && modelSchema.fields[partitionKeyField].virtual) {\n          throw (new Error(\"Partition Key array must contain only db field names, can't contain virtual field names\"));\n        }\n      });\n    } else {\n      throw (new Error('Partition Key must be a field name string, or array of field names'));\n    }\n\n    modelSchema.key.forEach((primaryKeyField, primaryKeyIndex) => {\n      if (primaryKeyIndex > 0) {\n        if ((typeof (primaryKeyField) !== 'string') || !this.has_field(modelSchema, primaryKeyField)) {\n          throw (new Error('Clustering Keys must be valid field names'));\n        }\n        if (modelSchema.fields[primaryKeyField] && modelSchema.fields[primaryKeyField].virtual) {\n          throw (new Error(\"Clustering Keys must be db field names, can't be virtual field names\"));\n        }\n      }\n    });\n\n    if (modelSchema.clustering_order) {\n      if (!_.isPlainObject(modelSchema.clustering_order)) {\n        throw (new Error('clustering_order must be an object of clustering_key attributes'));\n      }\n\n      _.forEach(modelSchema.clustering_order, (clusteringOrder, clusteringFieldName) => {\n        if (!['asc', 'desc'].includes(clusteringOrder.toLowerCase())) {\n          throw (new Error('clustering_order attribute values can only be ASC or DESC'));\n        }\n        if (modelSchema.key.indexOf(clusteringFieldName) < 1) {\n          throw (new Error('clustering_order field attributes must be clustering keys only'));\n        }\n      });\n    }\n  },\n\n  validate_materialized_view(modelSchema, materializedViewObject, materializedViewName) {\n    if (!_.isPlainObject(materializedViewObject)) {\n      throw (new Error(util.format('attribute \"%s\" under materialized_views must be an object', materializedViewName)));\n    }\n\n    if (!materializedViewObject.select || !materializedViewObject.key) {\n      throw (new Error(util.format('materialized_view \"%s\" must have \"select\" and \"key\" attributes', materializedViewName)));\n    }\n\n    if (!_.isArray(materializedViewObject.select) || !_.isArray(materializedViewObject.key)) {\n      throw (new Error(util.format('\"select\" and \"key\" attributes must be an array under attribute %s of materialized_views', materializedViewName)));\n    }\n\n    materializedViewObject.select.forEach((materializedViewSelectField) => {\n      if ((typeof (materializedViewSelectField) !== 'string')\n            || !(this.has_field(modelSchema, materializedViewSelectField)\n            || materializedViewSelectField === '*')) {\n        throw (new Error(util.format(\n          'the select attribute under materialized_view %s must be an array of field name strings or [\"*\"]',\n          materializedViewName,\n        )));\n      }\n\n      if (modelSchema.fields[materializedViewSelectField]\n          && modelSchema.fields[materializedViewSelectField].virtual) {\n        throw (new Error(util.format(\n          'the select attribute under %s of materialized_views must be an array of db field names, ' +\n          'cannot contain any virtual field name',\n          materializedViewName,\n        )));\n      }\n    });\n\n    // validate materialized_view primary key\n    if (typeof (materializedViewObject.key[0]) === 'string') {\n      if (!this.has_field(modelSchema, materializedViewObject.key[0])) {\n        throw (new Error(util.format('materialized_view %s: partition key string must match a valid field name', materializedViewName)));\n      }\n      if (modelSchema.fields[materializedViewObject.key[0]]\n        && modelSchema.fields[materializedViewObject.key[0]].virtual) {\n        throw (new Error(util.format(\n          'materialized_view %s: partition key must match a db field name, cannot be a virtual field name',\n          materializedViewName,\n        )));\n      }\n    } else if (_.isArray(materializedViewObject.key[0])) {\n      if (materializedViewObject.key[0].length === 0) {\n        throw (new Error(util.format('materialized_view %s: partition key array cannot be empty', materializedViewName)));\n      }\n      materializedViewObject.key[0].forEach((materializedViewPartitionKeyField) => {\n        if ((typeof (materializedViewPartitionKeyField) !== 'string')\n            || !this.has_field(modelSchema, materializedViewPartitionKeyField)) {\n          throw (new Error(util.format(\n            'materialized_view %s: partition key array must contain only valid field names',\n            materializedViewName,\n          )));\n        }\n        if (modelSchema.fields[materializedViewPartitionKeyField]\n          && modelSchema.fields[materializedViewPartitionKeyField].virtual) {\n          throw (new Error(util.format(\n            'materialized_view %s: partition key array must contain only db field names, ' +\n            'cannot contain virtual field names',\n            materializedViewName,\n          )));\n        }\n      });\n    } else {\n      throw (new Error(util.format(\n        'materialized_view %s: partition key must be a field name string, or array of field names',\n        materializedViewName,\n      )));\n    }\n\n    materializedViewObject.key.forEach((materializedViewPrimaryKeyField, materializedViewPrimaryKeyIndex) => {\n      if (materializedViewPrimaryKeyIndex > 0) {\n        if ((typeof (materializedViewPrimaryKeyField) !== 'string')\n            || !this.has_field(modelSchema, materializedViewPrimaryKeyField)) {\n          throw (new Error(util.format('materialized_view %s: clustering keys must be valid field names', materializedViewName)));\n        }\n        if (modelSchema.fields[materializedViewPrimaryKeyField]\n          && modelSchema.fields[materializedViewPrimaryKeyField].virtual) {\n          throw (new Error(util.format(\n            'materialized_view %s: clustering keys must be db field names, cannot contain virtual fields',\n            materializedViewName,\n          )));\n        }\n      }\n    });\n\n    if (materializedViewObject.clustering_order) {\n      if (!_.isPlainObject(materializedViewObject.clustering_order)) {\n        throw (new Error(util.format(\n          'materialized_view %s: clustering_order must be an object of clustering_key attributes',\n          materializedViewName,\n        )));\n      }\n\n      _.forEach(materializedViewObject.clustering_order, (mvClusteringOrder, mvlusteringFieldName) => {\n        if (!['asc', 'desc'].includes(mvClusteringOrder.toLowerCase())) {\n          throw (new Error(util.format('materialized_view %s: clustering_order attribute values can only be ASC or DESC', materializedViewName)));\n        }\n        if (materializedViewObject.key.indexOf(mvlusteringFieldName) < 1) {\n          throw (new Error(util.format(\n            'materialized_view %s: clustering_order field attributes must be clustering keys only',\n            materializedViewName,\n          )));\n        }\n      });\n    }\n  },\n\n  validate_index(modelSchema, indexDef) {\n    if (typeof indexDef !== 'string') {\n      throw (new Error('indexes must be an array of strings'));\n    }\n\n    const indexNameList = indexDef.replace(/[\"\\s]/g, '').split(/[()]/g);\n    if (indexNameList.length > 1) {\n      indexNameList[0] = indexNameList[0].toLowerCase();\n      if (!['entries', 'keys', 'values', 'full'].includes(indexNameList[0])) {\n        throw (new Error(util.format('index \"%s\" is not defined properly', indexDef)));\n      }\n      if (!this.has_field(modelSchema, indexNameList[1])) {\n        throw (new Error(util.format('\"%s\" is not a valid field name, indexes must be defined on field names', indexNameList[1])));\n      }\n      if (modelSchema.fields[indexNameList[1]] && modelSchema.fields[indexNameList[1]].virtual) {\n        throw (new Error(\"indexes must be an array of db field names, can't contain virtual fields\"));\n      }\n    } else {\n      if (!this.has_field(modelSchema, indexNameList[0])) {\n        throw (new Error(util.format('\"%s\" is not a valid field, indexes must be defined on field names', indexNameList[0])));\n      }\n      if (modelSchema.fields[indexNameList[0]] && modelSchema.fields[indexNameList[0]].virtual) {\n        throw (new Error(\"indexes must be an array of db field names, can't contain virtual fields\"));\n      }\n    }\n  },\n\n  validate_custom_index(modelSchema, customIndex) {\n    if (!_.isPlainObject(customIndex)) {\n      throw (new Error('custom_index must be an object with proper indexing attributes'));\n    }\n    if ((typeof (customIndex.on) !== 'string') || !this.has_field(modelSchema, customIndex.on)) {\n      throw (new Error(\"custom_index must have an 'on' attribute with string value and value must be a valid field name\"));\n    }\n    if (modelSchema.fields[customIndex.on] && modelSchema.fields[customIndex.on].virtual) {\n      throw (new Error(\"custom_index 'on' attribute must be a db field name, can't contain virtual fields\"));\n    }\n    if (typeof (customIndex.using) !== 'string') {\n      throw (new Error(\"custom_index must have a 'using' attribute with string value\"));\n    }\n    if (!_.isPlainObject(customIndex.options)) {\n      throw (new Error('custom_index must have an \"options\" attribute and it must be an object, ' +\n        'pass blank {} object if no options are required'));\n    }\n  },\n\n  validate_model_schema(modelSchema) {\n    if (!modelSchema) {\n      throw (new Error('A schema must be specified'));\n    }\n\n    if (!_.isPlainObject(modelSchema.fields) || Object.keys(modelSchema.fields).length === 0) {\n      throw (new Error('Schema must contain a non-empty \"fields\" map object'));\n    }\n\n    if (!modelSchema.key || !_.isArray(modelSchema.key)) {\n      throw (new Error('Schema must contain \"key\" in the form: [ [partitionkey1, ...], clusteringkey1, ...]'));\n    }\n\n    _.forEach(modelSchema.fields, (fieldObject, fieldName) => {\n      this.validate_field(modelSchema, fieldObject, fieldName);\n    });\n\n    this.validate_primary_key(modelSchema);\n\n    if (modelSchema.materialized_views) {\n      if (!_.isPlainObject(modelSchema.materialized_views)) {\n        throw (new Error('materialized_views must be an object with view names as attributes'));\n      }\n      _.forEach(modelSchema.materialized_views, (materializedViewObject, materializedViewName) => {\n        this.validate_materialized_view(modelSchema, materializedViewObject, materializedViewName);\n      });\n    }\n\n    if (modelSchema.indexes) {\n      if (!_.isArray(modelSchema.indexes)) {\n        throw (new Error('indexes must be an array of field name strings'));\n      }\n\n      modelSchema.indexes.forEach((indexDef) => {\n        this.validate_index(modelSchema, indexDef);\n      });\n    }\n\n    if (modelSchema.custom_index && modelSchema.custom_indexes) {\n      throw (new Error('both custom_index and custom_indexes are defined in schema, only one of them should be defined'));\n    }\n\n    if (modelSchema.custom_index) {\n      this.validate_custom_index(modelSchema, modelSchema.custom_index);\n    }\n\n    if (modelSchema.custom_indexes) {\n      if (!_.isArray(modelSchema.custom_indexes)) {\n        throw (new Error('custom_indexes must be an array with objects with proper indexing attributes'));\n      }\n      modelSchema.custom_indexes.forEach((customIndex) => {\n        this.validate_custom_index(modelSchema, customIndex);\n      });\n    }\n  },\n\n  format_validation_rule(rule, fieldname) {\n    if (!_.isPlainObject(rule)) {\n      throw (new Error(util.format('Validation rule for \"%s\" must be a function or an object', fieldname)));\n    }\n    if (typeof rule.validator !== 'function') {\n      throw (new Error(util.format('Rule validator for \"%s\" must be a valid function', fieldname)));\n    }\n    if (!rule.message) {\n      rule.message = this.get_generic_validation_message;\n    }\n    if (typeof rule.message === 'string') {\n      rule.message = function f1(message) {\n        return util.format(message);\n      }.bind(null, rule.message);\n    }\n    if (typeof rule.message !== 'function') {\n      throw (new Error(util.format('Invalid validator message for \"%s\", must be string or a function', fieldname)));\n    }\n    return rule;\n  },\n\n  get_generic_validation_message(value, propName, fieldtype) {\n    return util.format('Invalid Value: \"%s\" for Field: %s (Type: %s)', value, propName, fieldtype);\n  },\n\n  get_validation_message(validators, value) {\n    if (value == null || (_.isPlainObject(value) && value.$db_function)) {\n      return true;\n    }\n\n    for (let v = 0; v < validators.length; v++) {\n      if (typeof validators[v].validator === 'function') {\n        if (!validators[v].validator(value)) {\n          return validators[v].message;\n        }\n      }\n    }\n    return true;\n  },\n\n  get_validators(modelSchema, fieldname) {\n    const validators = [];\n    const fieldtype = this.get_field_type(modelSchema, fieldname);\n    const typeFieldValidator = datatypes.generic_type_validator(fieldtype);\n\n    if (typeFieldValidator) {\n      validators.push(typeFieldValidator);\n    }\n\n    const field = modelSchema.fields[fieldname];\n    if (typeof field.rule !== 'undefined') {\n      if (typeof field.rule === 'function') {\n        field.rule = {\n          validator: field.rule,\n          message: this.get_generic_validation_message,\n        };\n        validators.push(field.rule);\n      } else if (Array.isArray(field.rule.validators)) {\n        field.rule.validators.forEach((fieldrule) => {\n          validators.push(this.format_validation_rule(fieldrule, fieldname));\n        });\n      } else if (field.rule.validator) {\n        validators.push(this.format_validation_rule(field.rule, fieldname));\n      }\n    }\n\n    return validators;\n  },\n\n  get_field_type(modelSchema, fieldName) {\n    const fieldObject = modelSchema.fields[fieldName];\n\n    if (typeof fieldObject === 'string') {\n      return fieldObject;\n    }\n    if (_.isPlainObject(fieldObject)) {\n      return fieldObject.type;\n    }\n    throw (new Error('Field type not defined properly'));\n  },\n\n  is_required_field(modelSchema, fieldName) {\n    if (modelSchema.fields[fieldName].rule && modelSchema.fields[fieldName].rule.required) {\n      return true;\n    }\n    return false;\n  },\n\n  is_primary_key_field(modelSchema, fieldName) {\n    if (modelSchema.key.includes(fieldName) || modelSchema.key[0].includes(fieldName)) {\n      return true;\n    }\n    return false;\n  },\n\n  is_field_default_value_valid(modelSchema, fieldName) {\n    if (_.isPlainObject(modelSchema.fields[fieldName]) && modelSchema.fields[fieldName].default) {\n      if (_.isPlainObject(modelSchema.fields[fieldName].default)\n          && !(modelSchema.fields[fieldName].default.$db_function)) {\n        return ['map', 'list', 'set', 'frozen'].includes(modelSchema.fields[fieldName].type);\n      }\n      return true;\n    }\n    return true;\n  },\n\n};\n\nmodule.exports = schemer;\n"]}
{
"name": "express-cassandra",
"version": "2.2.2",
"version": "2.2.3",
"dependencies": {

@@ -5,0 +5,0 @@ "JSONStream": "^1.3.1",

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

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

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

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

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

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

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

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

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