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.8.0 to 2.9.0

.nyc_output/ef6768ea-c6fb-4462-96b9-4c5175e21794.json

19

CHANGELOG.md

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

## [2.9.0] - 2023-04-01
### Added
- Scylladb 5.x is now officially supported
- All LTS versions >= NodeJS 12 are now officially supported
### Changed
- Removed official support for Node version < 12, may still work in older versions
### Fixed
- Scylladb index conflict with materialized views
- Incorrect where clause comparison in schema matching logic for scylladb
### Security
- Upgraded package dependencies to resolve vulnerability in dependent packages
## [2.8.0] - 2022-03-12

@@ -573,3 +589,4 @@

[Unreleased]: https://github.com/masumsoft/express-cassandra/compare/v2.8.0...master
[Unreleased]: https://github.com/masumsoft/express-cassandra/compare/v2.9.0...master
[2.9.0]: https://github.com/masumsoft/express-cassandra/compare/v2.8.0...v2.9.0
[2.8.0]: https://github.com/masumsoft/express-cassandra/compare/v2.7.0...v2.8.0

@@ -576,0 +593,0 @@ [2.7.0]: https://github.com/masumsoft/express-cassandra/compare/v2.6.0...v2.7.0

6

CONTRIBUTING.md

@@ -38,9 +38,9 @@ ## Contributing to Express Cassandra

- Execute `npm install` to install the necessary dependencies
- Download the preconfigured [elassandra+janusgraph](https://www.dropbox.com/s/vebuzbdql0w6eap/elassandra_janusgraph_distribution.zip?dl=1) for running tests. Some of the test cases require configuration changes in cassandra, elassandra and janusgraph. [Elassandra](http://www.elassandra.io/) and [JanusGraph](http://janusgraph.org/) is required for test cases that are related to supporting them.
- Start the elassandra instance
- Start the janusgraph instance
- Run an instance of cassandra or scylladb with `materialized_views_enabled`, `sasi_indexes_enabled` and `user_defined_functions_enabled` configurations set to `true`
- Now execute `npm test` to run the tests (we're using [mocha](http://mochajs.org/))
> To test elassandra and janusgraph related functionalities, download the preconfigured [elassandra+janusgraph](https://www.dropbox.com/s/vebuzbdql0w6eap/elassandra_janusgraph_distribution.zip?dl=1) for running tests. Some of the test cases require configuration changes in cassandra, elassandra and janusgraph. [Elassandra](http://www.elassandra.io/) and [JanusGraph](http://janusgraph.org/) is required for test cases that are related to supporting them.
### Writing Documentation
To contribute to the [documentation](http://express-cassandra.readthedocs.io/) just make your changes to the relevant `*.md` file in the [docs](https://github.com/masumsoft/express-cassandra/tree/master/docs) directory in the master branch and submit a [pull request](https://help.github.com/articles/using-pull-requests/). You might also use the github [Edit](https://github.com/blog/844-forking-with-the-edit-button) button.

@@ -1,63 +0,87 @@

var jumpToCode = (function init () {
// Classes of code we would like to highlight
var missingCoverageClasses = [ '.cbranch-no', '.cstat-no', '.fstat-no' ];
/* eslint-disable */
var jumpToCode = (function init() {
// Classes of code we would like to highlight in the file view
var missingCoverageClasses = ['.cbranch-no', '.cstat-no', '.fstat-no'];
// We don't want to select elements that are direct descendants of another match
var notSelector = ':not(' + missingCoverageClasses.join('):not(') + ') > '; // becomes `:not(a):not(b) > `
// Elements to highlight in the file listing view
var fileListingElements = ['td.pct.low'];
// Selecter that finds elements on the page to which we can jump
var selector = notSelector + missingCoverageClasses.join(', ' + notSelector); // becomes `:not(a):not(b) > a, :not(a):not(b) > b`
// We don't want to select elements that are direct descendants of another match
var notSelector = ':not(' + missingCoverageClasses.join('):not(') + ') > '; // becomes `:not(a):not(b) > `
// The NodeList of matching elements
var missingCoverageElements = document.querySelectorAll(selector);
// Selecter that finds elements on the page to which we can jump
var selector =
fileListingElements.join(', ') +
', ' +
notSelector +
missingCoverageClasses.join(', ' + notSelector); // becomes `:not(a):not(b) > a, :not(a):not(b) > b`
var currentIndex;
// The NodeList of matching elements
var missingCoverageElements = document.querySelectorAll(selector);
function toggleClass(index) {
missingCoverageElements.item(currentIndex).classList.remove('highlighted');
missingCoverageElements.item(index).classList.add('highlighted');
}
var currentIndex;
function makeCurrent(index) {
toggleClass(index);
currentIndex = index;
missingCoverageElements.item(index)
.scrollIntoView({ behavior: 'smooth', block: 'center', inline: 'center' });
}
function toggleClass(index) {
missingCoverageElements
.item(currentIndex)
.classList.remove('highlighted');
missingCoverageElements.item(index).classList.add('highlighted');
}
function goToPrevious() {
var nextIndex = 0;
if (typeof currentIndex !== 'number' || currentIndex === 0) {
nextIndex = missingCoverageElements.length - 1;
} else if (missingCoverageElements.length > 1) {
nextIndex = currentIndex - 1;
function makeCurrent(index) {
toggleClass(index);
currentIndex = index;
missingCoverageElements.item(index).scrollIntoView({
behavior: 'smooth',
block: 'center',
inline: 'center'
});
}
makeCurrent(nextIndex);
}
function goToPrevious() {
var nextIndex = 0;
if (typeof currentIndex !== 'number' || currentIndex === 0) {
nextIndex = missingCoverageElements.length - 1;
} else if (missingCoverageElements.length > 1) {
nextIndex = currentIndex - 1;
}
function goToNext() {
var nextIndex = 0;
makeCurrent(nextIndex);
}
if (typeof currentIndex === 'number' && currentIndex < (missingCoverageElements.length - 1)) {
nextIndex = currentIndex + 1;
function goToNext() {
var nextIndex = 0;
if (
typeof currentIndex === 'number' &&
currentIndex < missingCoverageElements.length - 1
) {
nextIndex = currentIndex + 1;
}
makeCurrent(nextIndex);
}
makeCurrent(nextIndex);
}
return function jump(event) {
if (
document.getElementById('fileSearch') === document.activeElement &&
document.activeElement != null
) {
// if we're currently focused on the search input, we don't want to navigate
return;
}
return function jump(event) {
switch (event.which) {
case 78: // n
case 74: // j
goToNext();
break;
case 66: // b
case 75: // k
case 80: // p
goToPrevious();
break;
}
};
}());
switch (event.which) {
case 78: // n
case 74: // j
goToNext();
break;
case 66: // b
case 75: // k
case 80: // p
goToPrevious();
break;
}
};
})();
window.addEventListener('keydown', jumpToCode);

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

/* eslint-disable */
window.PR_SHOULD_USE_CONTINUATION=true;(function(){var h=["break,continue,do,else,for,if,return,while"];var u=[h,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"];var p=[u,"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"];var l=[p,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"];var x=[p,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"];var R=[x,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"];var r="all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes";var w=[p,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"];var s="caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END";var I=[h,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"];var f=[h,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"];var H=[h,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"];var A=[l,R,w,s+I,f,H];var e=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/;var C="str";var z="kwd";var j="com";var O="typ";var G="lit";var L="pun";var F="pln";var m="tag";var E="dec";var J="src";var P="atn";var n="atv";var N="nocode";var M="(?:^^\\.?|[+-]|\\!|\\!=|\\!==|\\#|\\%|\\%=|&|&&|&&=|&=|\\(|\\*|\\*=|\\+=|\\,|\\-=|\\->|\\/|\\/=|:|::|\\;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|\\?|\\@|\\[|\\^|\\^=|\\^\\^|\\^\\^=|\\{|\\||\\|=|\\|\\||\\|\\|=|\\~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\s*";function k(Z){var ad=0;var S=false;var ac=false;for(var V=0,U=Z.length;V<U;++V){var ae=Z[V];if(ae.ignoreCase){ac=true}else{if(/[a-z]/i.test(ae.source.replace(/\\u[0-9a-f]{4}|\\x[0-9a-f]{2}|\\[^ux]/gi,""))){S=true;ac=false;break}}}var Y={b:8,t:9,n:10,v:11,f:12,r:13};function ab(ah){var ag=ah.charCodeAt(0);if(ag!==92){return ag}var af=ah.charAt(1);ag=Y[af];if(ag){return ag}else{if("0"<=af&&af<="7"){return parseInt(ah.substring(1),8)}else{if(af==="u"||af==="x"){return parseInt(ah.substring(2),16)}else{return ah.charCodeAt(1)}}}}function T(af){if(af<32){return(af<16?"\\x0":"\\x")+af.toString(16)}var ag=String.fromCharCode(af);if(ag==="\\"||ag==="-"||ag==="["||ag==="]"){ag="\\"+ag}return ag}function X(am){var aq=am.substring(1,am.length-1).match(new RegExp("\\\\u[0-9A-Fa-f]{4}|\\\\x[0-9A-Fa-f]{2}|\\\\[0-3][0-7]{0,2}|\\\\[0-7]{1,2}|\\\\[\\s\\S]|-|[^-\\\\]","g"));var ak=[];var af=[];var ao=aq[0]==="^";for(var ar=ao?1:0,aj=aq.length;ar<aj;++ar){var ah=aq[ar];if(/\\[bdsw]/i.test(ah)){ak.push(ah)}else{var ag=ab(ah);var al;if(ar+2<aj&&"-"===aq[ar+1]){al=ab(aq[ar+2]);ar+=2}else{al=ag}af.push([ag,al]);if(!(al<65||ag>122)){if(!(al<65||ag>90)){af.push([Math.max(65,ag)|32,Math.min(al,90)|32])}if(!(al<97||ag>122)){af.push([Math.max(97,ag)&~32,Math.min(al,122)&~32])}}}}af.sort(function(av,au){return(av[0]-au[0])||(au[1]-av[1])});var ai=[];var ap=[NaN,NaN];for(var ar=0;ar<af.length;++ar){var at=af[ar];if(at[0]<=ap[1]+1){ap[1]=Math.max(ap[1],at[1])}else{ai.push(ap=at)}}var an=["["];if(ao){an.push("^")}an.push.apply(an,ak);for(var ar=0;ar<ai.length;++ar){var at=ai[ar];an.push(T(at[0]));if(at[1]>at[0]){if(at[1]+1>at[0]){an.push("-")}an.push(T(at[1]))}}an.push("]");return an.join("")}function W(al){var aj=al.source.match(new RegExp("(?:\\[(?:[^\\x5C\\x5D]|\\\\[\\s\\S])*\\]|\\\\u[A-Fa-f0-9]{4}|\\\\x[A-Fa-f0-9]{2}|\\\\[0-9]+|\\\\[^ux0-9]|\\(\\?[:!=]|[\\(\\)\\^]|[^\\x5B\\x5C\\(\\)\\^]+)","g"));var ah=aj.length;var an=[];for(var ak=0,am=0;ak<ah;++ak){var ag=aj[ak];if(ag==="("){++am}else{if("\\"===ag.charAt(0)){var af=+ag.substring(1);if(af&&af<=am){an[af]=-1}}}}for(var ak=1;ak<an.length;++ak){if(-1===an[ak]){an[ak]=++ad}}for(var ak=0,am=0;ak<ah;++ak){var ag=aj[ak];if(ag==="("){++am;if(an[am]===undefined){aj[ak]="(?:"}}else{if("\\"===ag.charAt(0)){var af=+ag.substring(1);if(af&&af<=am){aj[ak]="\\"+an[am]}}}}for(var ak=0,am=0;ak<ah;++ak){if("^"===aj[ak]&&"^"!==aj[ak+1]){aj[ak]=""}}if(al.ignoreCase&&S){for(var ak=0;ak<ah;++ak){var ag=aj[ak];var ai=ag.charAt(0);if(ag.length>=2&&ai==="["){aj[ak]=X(ag)}else{if(ai!=="\\"){aj[ak]=ag.replace(/[a-zA-Z]/g,function(ao){var ap=ao.charCodeAt(0);return"["+String.fromCharCode(ap&~32,ap|32)+"]"})}}}}return aj.join("")}var aa=[];for(var V=0,U=Z.length;V<U;++V){var ae=Z[V];if(ae.global||ae.multiline){throw new Error(""+ae)}aa.push("(?:"+W(ae)+")")}return new RegExp(aa.join("|"),ac?"gi":"g")}function a(V){var U=/(?:^|\s)nocode(?:\s|$)/;var X=[];var T=0;var Z=[];var W=0;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=document.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Y=S&&"pre"===S.substring(0,3);function aa(ab){switch(ab.nodeType){case 1:if(U.test(ab.className)){return}for(var ae=ab.firstChild;ae;ae=ae.nextSibling){aa(ae)}var ad=ab.nodeName;if("BR"===ad||"LI"===ad){X[W]="\n";Z[W<<1]=T++;Z[(W++<<1)|1]=ab}break;case 3:case 4:var ac=ab.nodeValue;if(ac.length){if(!Y){ac=ac.replace(/[ \t\r\n]+/g," ")}else{ac=ac.replace(/\r\n?/g,"\n")}X[W]=ac;Z[W<<1]=T;T+=ac.length;Z[(W++<<1)|1]=ab}break}}aa(V);return{sourceCode:X.join("").replace(/\n$/,""),spans:Z}}function B(S,U,W,T){if(!U){return}var V={sourceCode:U,basePos:S};W(V);T.push.apply(T,V.decorations)}var v=/\S/;function o(S){var V=undefined;for(var U=S.firstChild;U;U=U.nextSibling){var T=U.nodeType;V=(T===1)?(V?S:U):(T===3)?(v.test(U.nodeValue)?S:V):V}return V===S?undefined:V}function g(U,T){var S={};var V;(function(){var ad=U.concat(T);var ah=[];var ag={};for(var ab=0,Z=ad.length;ab<Z;++ab){var Y=ad[ab];var ac=Y[3];if(ac){for(var ae=ac.length;--ae>=0;){S[ac.charAt(ae)]=Y}}var af=Y[1];var aa=""+af;if(!ag.hasOwnProperty(aa)){ah.push(af);ag[aa]=null}}ah.push(/[\0-\uffff]/);V=k(ah)})();var X=T.length;var W=function(ah){var Z=ah.sourceCode,Y=ah.basePos;var ad=[Y,F];var af=0;var an=Z.match(V)||[];var aj={};for(var ae=0,aq=an.length;ae<aq;++ae){var ag=an[ae];var ap=aj[ag];var ai=void 0;var am;if(typeof ap==="string"){am=false}else{var aa=S[ag.charAt(0)];if(aa){ai=ag.match(aa[1]);ap=aa[0]}else{for(var ao=0;ao<X;++ao){aa=T[ao];ai=ag.match(aa[1]);if(ai){ap=aa[0];break}}if(!ai){ap=F}}am=ap.length>=5&&"lang-"===ap.substring(0,5);if(am&&!(ai&&typeof ai[1]==="string")){am=false;ap=J}if(!am){aj[ag]=ap}}var ab=af;af+=ag.length;if(!am){ad.push(Y+ab,ap)}else{var al=ai[1];var ak=ag.indexOf(al);var ac=ak+al.length;if(ai[2]){ac=ag.length-ai[2].length;ak=ac-al.length}var ar=ap.substring(5);B(Y+ab,ag.substring(0,ak),W,ad);B(Y+ab+ak,al,q(ar,al),ad);B(Y+ab+ac,ag.substring(ac),W,ad)}}ah.decorations=ad};return W}function i(T){var W=[],S=[];if(T.tripleQuotedStrings){W.push([C,/^(?:\'\'\'(?:[^\'\\]|\\[\s\S]|\'{1,2}(?=[^\']))*(?:\'\'\'|$)|\"\"\"(?:[^\"\\]|\\[\s\S]|\"{1,2}(?=[^\"]))*(?:\"\"\"|$)|\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$))/,null,"'\""])}else{if(T.multiLineStrings){W.push([C,/^(?:\'(?:[^\\\']|\\[\s\S])*(?:\'|$)|\"(?:[^\\\"]|\\[\s\S])*(?:\"|$)|\`(?:[^\\\`]|\\[\s\S])*(?:\`|$))/,null,"'\"`"])}else{W.push([C,/^(?:\'(?:[^\\\'\r\n]|\\.)*(?:\'|$)|\"(?:[^\\\"\r\n]|\\.)*(?:\"|$))/,null,"\"'"])}}if(T.verbatimStrings){S.push([C,/^@\"(?:[^\"]|\"\")*(?:\"|$)/,null])}var Y=T.hashComments;if(Y){if(T.cStyleComments){if(Y>1){W.push([j,/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,null,"#"])}else{W.push([j,/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\r\n]*)/,null,"#"])}S.push([C,/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,null])}else{W.push([j,/^#[^\r\n]*/,null,"#"])}}if(T.cStyleComments){S.push([j,/^\/\/[^\r\n]*/,null]);S.push([j,/^\/\*[\s\S]*?(?:\*\/|$)/,null])}if(T.regexLiterals){var X=("/(?=[^/*])(?:[^/\\x5B\\x5C]|\\x5C[\\s\\S]|\\x5B(?:[^\\x5C\\x5D]|\\x5C[\\s\\S])*(?:\\x5D|$))+/");S.push(["lang-regex",new RegExp("^"+M+"("+X+")")])}var V=T.types;if(V){S.push([O,V])}var U=(""+T.keywords).replace(/^ | $/g,"");if(U.length){S.push([z,new RegExp("^(?:"+U.replace(/[\s,]+/g,"|")+")\\b"),null])}W.push([F,/^\s+/,null," \r\n\t\xA0"]);S.push([G,/^@[a-z_$][a-z_$@0-9]*/i,null],[O,/^(?:[@_]?[A-Z]+[a-z][A-Za-z_$@0-9]*|\w+_t\b)/,null],[F,/^[a-z_$][a-z_$@0-9]*/i,null],[G,new RegExp("^(?:0x[a-f0-9]+|(?:\\d(?:_\\d+)*\\d*(?:\\.\\d*)?|\\.\\d\\+)(?:e[+\\-]?\\d+)?)[a-z]*","i"),null,"0123456789"],[F,/^\\[\s\S]?/,null],[L,/^.[^\s\w\.$@\'\"\`\/\#\\]*/,null]);return g(W,S)}var K=i({keywords:A,hashComments:true,cStyleComments:true,multiLineStrings:true,regexLiterals:true});function Q(V,ag){var U=/(?:^|\s)nocode(?:\s|$)/;var ab=/\r\n?|\n/;var ac=V.ownerDocument;var S;if(V.currentStyle){S=V.currentStyle.whiteSpace}else{if(window.getComputedStyle){S=ac.defaultView.getComputedStyle(V,null).getPropertyValue("white-space")}}var Z=S&&"pre"===S.substring(0,3);var af=ac.createElement("LI");while(V.firstChild){af.appendChild(V.firstChild)}var W=[af];function ae(al){switch(al.nodeType){case 1:if(U.test(al.className)){break}if("BR"===al.nodeName){ad(al);if(al.parentNode){al.parentNode.removeChild(al)}}else{for(var an=al.firstChild;an;an=an.nextSibling){ae(an)}}break;case 3:case 4:if(Z){var am=al.nodeValue;var aj=am.match(ab);if(aj){var ai=am.substring(0,aj.index);al.nodeValue=ai;var ah=am.substring(aj.index+aj[0].length);if(ah){var ak=al.parentNode;ak.insertBefore(ac.createTextNode(ah),al.nextSibling)}ad(al);if(!ai){al.parentNode.removeChild(al)}}}break}}function ad(ak){while(!ak.nextSibling){ak=ak.parentNode;if(!ak){return}}function ai(al,ar){var aq=ar?al.cloneNode(false):al;var ao=al.parentNode;if(ao){var ap=ai(ao,1);var an=al.nextSibling;ap.appendChild(aq);for(var am=an;am;am=an){an=am.nextSibling;ap.appendChild(am)}}return aq}var ah=ai(ak.nextSibling,0);for(var aj;(aj=ah.parentNode)&&aj.nodeType===1;){ah=aj}W.push(ah)}for(var Y=0;Y<W.length;++Y){ae(W[Y])}if(ag===(ag|0)){W[0].setAttribute("value",ag)}var aa=ac.createElement("OL");aa.className="linenums";var X=Math.max(0,((ag-1))|0)||0;for(var Y=0,T=W.length;Y<T;++Y){af=W[Y];af.className="L"+((Y+X)%10);if(!af.firstChild){af.appendChild(ac.createTextNode("\xA0"))}aa.appendChild(af)}V.appendChild(aa)}function D(ac){var aj=/\bMSIE\b/.test(navigator.userAgent);var am=/\n/g;var al=ac.sourceCode;var an=al.length;var V=0;var aa=ac.spans;var T=aa.length;var ah=0;var X=ac.decorations;var Y=X.length;var Z=0;X[Y]=an;var ar,aq;for(aq=ar=0;aq<Y;){if(X[aq]!==X[aq+2]){X[ar++]=X[aq++];X[ar++]=X[aq++]}else{aq+=2}}Y=ar;for(aq=ar=0;aq<Y;){var at=X[aq];var ab=X[aq+1];var W=aq+2;while(W+2<=Y&&X[W+1]===ab){W+=2}X[ar++]=at;X[ar++]=ab;aq=W}Y=X.length=ar;var ae=null;while(ah<T){var af=aa[ah];var S=aa[ah+2]||an;var ag=X[Z];var ap=X[Z+2]||an;var W=Math.min(S,ap);var ak=aa[ah+1];var U;if(ak.nodeType!==1&&(U=al.substring(V,W))){if(aj){U=U.replace(am,"\r")}ak.nodeValue=U;var ai=ak.ownerDocument;var ao=ai.createElement("SPAN");ao.className=X[Z+1];var ad=ak.parentNode;ad.replaceChild(ao,ak);ao.appendChild(ak);if(V<S){aa[ah+1]=ak=ai.createTextNode(al.substring(W,S));ad.insertBefore(ak,ao.nextSibling)}}V=W;if(V>=S){ah+=2}if(V>=ap){Z+=2}}}var t={};function c(U,V){for(var S=V.length;--S>=0;){var T=V[S];if(!t.hasOwnProperty(T)){t[T]=U}else{if(window.console){console.warn("cannot override language handler %s",T)}}}}function q(T,S){if(!(T&&t.hasOwnProperty(T))){T=/^\s*</.test(S)?"default-markup":"default-code"}return t[T]}c(K,["default-code"]);c(g([],[[F,/^[^<?]+/],[E,/^<!\w[^>]*(?:>|$)/],[j,/^<\!--[\s\S]*?(?:-\->|$)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],[L,/^(?:<[%?]|[%?]>)/],["lang-",/^<xmp\b[^>]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-js",/^<script\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-css",/^<style\b[^>]*>([\s\S]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i]]),["default-markup","htm","html","mxml","xhtml","xml","xsl"]);c(g([[F,/^[\s]+/,null," \t\r\n"],[n,/^(?:\"[^\"]*\"?|\'[^\']*\'?)/,null,"\"'"]],[[m,/^^<\/?[a-z](?:[\w.:-]*\w)?|\/?>$/i],[P,/^(?!style[\s=]|on)[a-z](?:[\w:-]*\w)?/i],["lang-uq.val",/^=\s*([^>\'\"\s]*(?:[^>\'\"\s\/]|\/(?=\s)))/],[L,/^[=<>\/]+/],["lang-js",/^on\w+\s*=\s*\"([^\"]+)\"/i],["lang-js",/^on\w+\s*=\s*\'([^\']+)\'/i],["lang-js",/^on\w+\s*=\s*([^\"\'>\s]+)/i],["lang-css",/^style\s*=\s*\"([^\"]+)\"/i],["lang-css",/^style\s*=\s*\'([^\']+)\'/i],["lang-css",/^style\s*=\s*([^\"\'>\s]+)/i]]),["in.tag"]);c(g([],[[n,/^[\s\S]+/]]),["uq.val"]);c(i({keywords:l,hashComments:true,cStyleComments:true,types:e}),["c","cc","cpp","cxx","cyc","m"]);c(i({keywords:"null,true,false"}),["json"]);c(i({keywords:R,hashComments:true,cStyleComments:true,verbatimStrings:true,types:e}),["cs"]);c(i({keywords:x,cStyleComments:true}),["java"]);c(i({keywords:H,hashComments:true,multiLineStrings:true}),["bsh","csh","sh"]);c(i({keywords:I,hashComments:true,multiLineStrings:true,tripleQuotedStrings:true}),["cv","py"]);c(i({keywords:s,hashComments:true,multiLineStrings:true,regexLiterals:true}),["perl","pl","pm"]);c(i({keywords:f,hashComments:true,multiLineStrings:true,regexLiterals:true}),["rb"]);c(i({keywords:w,cStyleComments:true,regexLiterals:true}),["js"]);c(i({keywords:r,hashComments:3,cStyleComments:true,multilineStrings:true,tripleQuotedStrings:true,regexLiterals:true}),["coffee"]);c(g([],[[C,/^[\s\S]+/]]),["regex"]);function d(V){var U=V.langExtension;try{var S=a(V.sourceNode);var T=S.sourceCode;V.sourceCode=T;V.spans=S.spans;V.basePos=0;q(U,T)(V);D(V)}catch(W){if("console" in window){console.log(W&&W.stack?W.stack:W)}}}function y(W,V,U){var S=document.createElement("PRE");S.innerHTML=W;if(U){Q(S,U)}var T={langExtension:V,numberLines:U,sourceNode:S};d(T);return S.innerHTML}function b(ad){function Y(af){return document.getElementsByTagName(af)}var ac=[Y("pre"),Y("code"),Y("xmp")];var T=[];for(var aa=0;aa<ac.length;++aa){for(var Z=0,V=ac[aa].length;Z<V;++Z){T.push(ac[aa][Z])}}ac=null;var W=Date;if(!W.now){W={now:function(){return +(new Date)}}}var X=0;var S;var ab=/\blang(?:uage)?-([\w.]+)(?!\S)/;var ae=/\bprettyprint\b/;function U(){var ag=(window.PR_SHOULD_USE_CONTINUATION?W.now()+250:Infinity);for(;X<T.length&&W.now()<ag;X++){var aj=T[X];var ai=aj.className;if(ai.indexOf("prettyprint")>=0){var ah=ai.match(ab);var am;if(!ah&&(am=o(aj))&&"CODE"===am.tagName){ah=am.className.match(ab)}if(ah){ah=ah[1]}var al=false;for(var ak=aj.parentNode;ak;ak=ak.parentNode){if((ak.tagName==="pre"||ak.tagName==="code"||ak.tagName==="xmp")&&ak.className&&ak.className.indexOf("prettyprint")>=0){al=true;break}}if(!al){var af=aj.className.match(/\blinenums\b(?::(\d+))?/);af=af?af[1]&&af[1].length?+af[1]:true:false;if(af){Q(aj,af)}S={langExtension:ah,sourceNode:aj,numberLines:af};d(S)}}}if(X<T.length){setTimeout(U,250)}else{if(ad){ad()}}}U()}window.prettyPrintOne=y;window.prettyPrint=b;window.PR={createSimpleLexer:g,registerLangHandler:c,sourceDecorator:i,PR_ATTRIB_NAME:P,PR_ATTRIB_VALUE:n,PR_COMMENT:j,PR_DECLARATION:E,PR_KEYWORD:z,PR_LITERAL:G,PR_NOCODE:N,PR_PLAIN:F,PR_PUNCTUATION:L,PR_SOURCE:J,PR_STRING:C,PR_TAG:m,PR_TYPE:O}})();PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_DECLARATION,/^<!\w[^>]*(?:>|$)/],[PR.PR_COMMENT,/^<\!--[\s\S]*?(?:-\->|$)/],[PR.PR_PUNCTUATION,/^(?:<[%?]|[%?]>)/],["lang-",/^<\?([\s\S]+?)(?:\?>|$)/],["lang-",/^<%([\s\S]+?)(?:%>|$)/],["lang-",/^<xmp\b[^>]*>([\s\S]+?)<\/xmp\b[^>]*>/i],["lang-handlebars",/^<script\b[^>]*type\s*=\s*['"]?text\/x-handlebars-template['"]?\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-js",/^<script\b[^>]*>([\s\S]*?)(<\/script\b[^>]*>)/i],["lang-css",/^<style\b[^>]*>([\s\S]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i],[PR.PR_DECLARATION,/^{{[#^>/]?\s*[\w.][^}]*}}/],[PR.PR_DECLARATION,/^{{&?\s*[\w.][^}]*}}/],[PR.PR_DECLARATION,/^{{{>?\s*[\w.][^}]*}}}/],[PR.PR_COMMENT,/^{{![^}]*}}/]]),["handlebars","hbs"]);PR.registerLangHandler(PR.createSimpleLexer([[PR.PR_PLAIN,/^[ \t\r\n\f]+/,null," \t\r\n\f"]],[[PR.PR_STRING,/^\"(?:[^\n\r\f\\\"]|\\(?:\r\n?|\n|\f)|\\[\s\S])*\"/,null],[PR.PR_STRING,/^\'(?:[^\n\r\f\\\']|\\(?:\r\n?|\n|\f)|\\[\s\S])*\'/,null],["lang-css-str",/^url\(([^\)\"\']*)\)/i],[PR.PR_KEYWORD,/^(?:url|rgb|\!important|@import|@page|@media|@charset|inherit)(?=[^\-\w]|$)/i,null],["lang-css-kw",/^(-?(?:[_a-z]|(?:\\[0-9a-f]+ ?))(?:[_a-z0-9\-]|\\(?:\\[0-9a-f]+ ?))*)\s*:/i],[PR.PR_COMMENT,/^\/\*[^*]*\*+(?:[^\/*][^*]*\*+)*\//],[PR.PR_COMMENT,/^(?:<!--|-->)/],[PR.PR_LITERAL,/^(?:\d+|\d*\.\d+)(?:%|[a-z]+)?/i],[PR.PR_LITERAL,/^#(?:[0-9a-f]{3}){1,2}/i],[PR.PR_PLAIN,/^-?(?:[_a-z]|(?:\\[\da-f]+ ?))(?:[_a-z\d\-]|\\(?:\\[\da-f]+ ?))*/i],[PR.PR_PUNCTUATION,/^[^\s\w\'\"]+/]]),["css"]);PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_KEYWORD,/^-?(?:[_a-z]|(?:\\[\da-f]+ ?))(?:[_a-z\d\-]|\\(?:\\[\da-f]+ ?))*/i]]),["css-kw"]);PR.registerLangHandler(PR.createSimpleLexer([],[[PR.PR_STRING,/^[^\)\"\']+/]]),["css-str"]);

@@ -1,3 +0,4 @@

var addSorting = (function () {
"use strict";
/* eslint-disable */
var addSorting = (function() {
'use strict';
var cols,

@@ -10,10 +11,43 @@ currentSort = {

// returns the summary table element
function getTable() { return document.querySelector('.coverage-summary'); }
function getTable() {
return document.querySelector('.coverage-summary');
}
// returns the thead element of the summary table
function getTableHeader() { return getTable().querySelector('thead tr'); }
function getTableHeader() {
return getTable().querySelector('thead tr');
}
// returns the tbody element of the summary table
function getTableBody() { return getTable().querySelector('tbody'); }
function getTableBody() {
return getTable().querySelector('tbody');
}
// returns the th element for nth column
function getNthColumn(n) { return getTableHeader().querySelectorAll('th')[n]; }
function getNthColumn(n) {
return getTableHeader().querySelectorAll('th')[n];
}
function onFilterInput() {
const searchValue = document.getElementById('fileSearch').value;
const rows = document.getElementsByTagName('tbody')[0].children;
for (let i = 0; i < rows.length; i++) {
const row = rows[i];
if (
row.textContent
.toLowerCase()
.includes(searchValue.toLowerCase())
) {
row.style.display = '';
} else {
row.style.display = 'none';
}
}
}
// loads the search box
function addSearchBox() {
var template = document.getElementById('filterTemplate');
var templateClone = template.content.cloneNode(true);
templateClone.getElementById('fileSearch').oninput = onFilterInput;
template.parentElement.appendChild(templateClone);
}
// loads all columns

@@ -37,3 +71,4 @@ function loadColumns() {

col.defaultDescSort = col.type === 'number';
colNode.innerHTML = colNode.innerHTML + '<span class="sorter"></span>';
colNode.innerHTML =
colNode.innerHTML + '<span class="sorter"></span>';
}

@@ -75,3 +110,3 @@ }

var key = cols[index].key,
sorter = function (a, b) {
sorter = function(a, b) {
a = a.data[key];

@@ -88,3 +123,3 @@ b = b.data[key];

if (desc) {
finalSorter = function (a, b) {
finalSorter = function(a, b) {
return -1 * sorter(a, b);

@@ -115,3 +150,5 @@ };

function addSortIndicators() {
getNthColumn(currentSort.index).className += currentSort.desc ? ' sorted-desc' : ' sorted';
getNthColumn(currentSort.index).className += currentSort.desc
? ' sorted-desc'
: ' sorted';
}

@@ -125,3 +162,3 @@ // adds event listeners for all sorter widgets

return function () {
return function() {
var desc = col.defaultDescSort;

@@ -139,3 +176,3 @@

};
for (i =0 ; i < cols.length; i += 1) {
for (i = 0; i < cols.length; i += 1) {
if (cols[i].sortable) {

@@ -154,3 +191,3 @@ // add the click event handler on the th so users

// adds sorting functionality to the UI
return function () {
return function() {
if (!getTable()) {

@@ -160,3 +197,4 @@ return;

cols = loadColumns();
loadData(cols);
loadData();
addSearchBox();
addSortIndicators();

@@ -163,0 +201,0 @@ enableUI();

# Overview
Express-Cassandra is a Cassandra ORM/ODM/OGM for NodeJS with Elassandra & JanusGraph Support.
Express-Cassandra is a Cassandra ORM/ODM/OGM for NodeJS with support for ScyllaDB, Datastax Enterprise, Elassandra & JanusGraph.
No more hassling with raw cql queries from your nodejs web frameworks. Express-Cassandra automatically loads your models and provides you with object oriented mapping to your cassandra tables like a standard ORM/ODM. Built in support for [Elassandra](http://www.elassandra.io/) and [JanusGraph](http://janusgraph.org/) allows you to automatically manage synced elasticsearch and janusgraph indexes stored in cassandra.
No more hassling with raw cql queries from your nodejs web frameworks. Express-Cassandra automatically loads your models and provides you with object oriented mapping to your cassandra/scylladb tables like a standard ORM/ODM. Built in support for [Cassandra](https://cassandra.apache.org/), [ScyllaDB](https://www.scylladb.com/), [Elassandra](http://www.elassandra.io/) and [JanusGraph](http://janusgraph.org/) allows you to automatically manage schema, graph and data models from your javascript codebase. Models are written as javascript modules and they automatically create the underlying db tables, indexes, materialized views, graphs etc. Afterwards you can save, update, delete and query your data using supported model methods. It's decoupled nature allows you to use it with many popular node frameworks without much hassle.
Express-cassandra enables your nodejs app to manage a highly available distributed data store capable of handling large dataset with powerful query features powered by cassandra, elasticsearch and janusgraph combined. Express-cassandra empowers you to manage and query this truely distributed datastore with search, analytics and graph computing functionality from nodejs like you are just dealing with javascript objects and methods. Models are written as javascript modules and they automatically create the underlying db tables, indexes, materialized views, graphs etc. Afterwards you can save, update, delete and query your data using supported model methods. It's decoupled nature allows you to use it with many popular node frameworks without much hassle.
If you are using elassandra, then saved data in cassandra automatically syncs with elasticsearch indexes defined in your schema. You can then do any query [elasticsearch](https://www.elastic.co/products/elasticsearch) indexes support.

@@ -15,6 +13,6 @@

* supports the latest cassandra 4.x and older stable 3.x releases
* supports the latest cassandra 4.x, 3.x and scylladb 5.x versions
* compatible with datastax enterprise solr search and dse graph
* support for elassandra index management and search queries
* support for janusgraph graph management and tinkerpop3 gremlin queries
* compatible with datastax enterprise solr search and dse graph
* full featured CRUD operations and data type validations

@@ -31,8 +29,4 @@ * full support for collections and other advanced data types

* optional support for query debug and progress logs
* most of the bleeding edge cassandra features are supported
* most of the bleeding edge cassandra and scylladb features are supported
This module internally uses [cassandra-driver](https://github.com/datastax/nodejs-driver).
## Optional Preconfigured Elassandra+JanusGraph
Download the preconfigured [elassandra+janusgraph](https://www.dropbox.com/s/vebuzbdql0w6eap/elassandra_janusgraph_distribution.zip?dl=1) distribution for development convenience. This distribution contains the elassandra and janusgraph versions express-cassandra was tested in and contains mostly configuration changes. This distribution can also be used as a reference configuration for your own environment.
# Installation
For apache cassandra version 4.x, 3.x or datastax enterprise
For apache cassandra 4.x, 3.x, scylladb 5.x or datastax enterprise 6.x, 5.x

@@ -19,2 +19,2 @@ npm install express-cassandra

Please note that if you use the legacy cassandra 2.x compliant version then please use the corresponding README.md file for that version. The following documentation is for version 4.x/3.x and datastax enterprise 6.x/5.x only. The materialized view support and several other part of the documentation is strictly applicable for cassandra 4.x/3.x or dse 6.x/5.x and will not work in earlier versions of cassandra.
Please note that if you use the legacy cassandra 2.x compliant version then please use the corresponding README.md file for that version. The following documentation is for version 4.x, 3.x and datastax enterprise 6.x/5.x only. The materialized view support and several other part of the documentation is strictly applicable for cassandra 4.x/3.x or scylladb 5.x or dse 6.x/5.x and will not work in earlier versions of cassandra.

@@ -74,3 +74,3 @@ 'use strict';

root: CassandraClient.directory,
fileFilter: ['*.js', '*.javascript', '*.jsx', '*.coffee', '*.coffeescript', '*.iced', '*.script', '*.ts', '*.tsx', '*.typescript', '*.cjsx', '*.co', '*.json', '*.json5', '*.litcoffee', '*.liticed', '*.ls', '*.node', '*.toml', '*.wisp']
fileFilter: ['*.js', '*.javascript', '*.jsx', '*.coffee', '*.coffeescript', '*.iced', '*.script', '*.ts', '*.tsx', '*.typescript', '*.cjsx', '*.co', '*.json', '*.json5', '*.litcoffee', '*.liticed', '*.ls', '*.node', '*.toml', '*.wisp', '*.cjs']
});

@@ -372,2 +372,2 @@ }).then(function (fileList) {

module.exports = CassandraClient;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/expressCassandra.js"],"names":["semver","require","satisfies","process","version","Promise","_","path","dseDriver","e","cql","promisifyAll","ORM","readdirpAsync","promisify","debug","exporter","importer","CassandraClient","f","options","modelInstance","orm","clientOptions","ormOptions","createClient","setDirectory","directory","syncModelFileToDB","file","callback","name","includes","modelName","_translateFileNameToModelName","fileLocation","join","defaultModelSchema","modelSchema","default","addModel","toLowerCase","syncDB","bind","cb","initAsync","then","root","fileFilter","fileList","syncModelTasks","syncModelFileToDBAsync","files","forEach","push","all","catch","err","isArray","length","bindAsync","prototype","init","getTableList","systemClient","get_system_client","keyspace","get_keyspace_name","tables","connect","systemQuery","execute","result","i","rows","table_name","shutdown","getTableListAsync","export","fixtureDirectory","each","table","processTableExport","exportAsync","import","arguments","defaults","batchSize","defaultsDeep","processTableImport","importAsync","loadSchema","uuid","types","Uuid","random","uuidFromString","str","fromString","uuidFromBuffer","buf","timeuuid","TimeUuid","now","timeuuidFromDate","date","fromDate","timeuuidFromString","timeuuidFromBuffer","maxTimeuuid","max","minTimeuuid","min","doBatch","queries","prepare","randomModel","Object","keys","beforeHooks","batchResult","execute_batchAsync","execute_queryAsync","query","params","response","afterHookResponse","after_hook","doBatchAsync","call","fileName","slice","lastIndexOf","replace","defineProperties","consistencies","get","datatypes","driver","instance","close","closeAsync","module","exports"],"mappings":"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","file":"expressCassandra.js","sourcesContent":["const semver = require('semver');\n\nif (!semver.satisfies(process.version, '>=6.0.0')) {\n  require('babel-polyfill');\n}\n\nconst Promise = require('bluebird');\nconst _ = require('lodash');\nconst path = require('path');\n\nlet dseDriver;\ntry {\n  // eslint-disable-next-line import/no-extraneous-dependencies, import/no-unresolved\n  dseDriver = require('dse-driver');\n} catch (e) {\n  dseDriver = null;\n}\n\nconst cql = Promise.promisifyAll(dseDriver || require('cassandra-driver'));\n\nconst ORM = Promise.promisifyAll(require('./orm/apollo'));\nconst readdirpAsync = Promise.promisify(require('readdirp'));\nconst debug = require('debug')('express-cassandra');\n\nconst exporter = require('./utils/exporter');\nconst importer = require('./utils/importer');\n\nconst CassandraClient = function f(options) {\n  this.modelInstance = {};\n  this.orm = new ORM(options.clientOptions, options.ormOptions);\n  this.orm = Promise.promisifyAll(this.orm);\n};\n\nCassandraClient.createClient = (options) => (new CassandraClient(options));\n\nCassandraClient.setDirectory = (directory) => {\n  CassandraClient.directory = directory;\n  return CassandraClient;\n};\n\nCassandraClient.syncModelFileToDB = (file, callback) => {\n  if (!file.name.includes('Model')) {\n    callback();\n    return;\n  }\n\n  const modelName = CassandraClient._translateFileNameToModelName(file.name);\n\n  if (modelName) {\n    const fileLocation = path.join(CassandraClient.directory, file.path);\n    // eslint-disable-next-line import/no-dynamic-require\n    const defaultModelSchema = require(fileLocation);\n    const modelSchema = defaultModelSchema.default ? defaultModelSchema.default : defaultModelSchema;\n    CassandraClient.modelInstance[modelName] = CassandraClient.orm.addModel(modelName.toLowerCase(), modelSchema);\n    CassandraClient.modelInstance[modelName].syncDB(callback);\n    CassandraClient.modelInstance[modelName] = Promise.promisifyAll(CassandraClient.modelInstance[modelName]);\n    return;\n  }\n\n  callback();\n};\n\nCassandraClient.bind = (options, cb) => {\n  CassandraClient.modelInstance = {};\n  CassandraClient.orm = new ORM(options.clientOptions, options.ormOptions);\n  CassandraClient.orm = Promise.promisifyAll(CassandraClient.orm);\n  CassandraClient.orm.initAsync()\n    .then(() => readdirpAsync({\n      root: CassandraClient.directory,\n      fileFilter: [\n        '*.js', '*.javascript', '*.jsx', '*.coffee', '*.coffeescript', '*.iced',\n        '*.script', '*.ts', '*.tsx', '*.typescript', '*.cjsx', '*.co', '*.json',\n        '*.json5', '*.litcoffee', '*.liticed', '*.ls', '*.node', '*.toml', '*.wisp',\n      ],\n    }))\n    .then((fileList) => {\n      const syncModelTasks = [];\n      const syncModelFileToDBAsync = Promise.promisify(CassandraClient.syncModelFileToDB);\n      fileList = fileList.files;\n      fileList.forEach((file) => {\n        syncModelTasks.push(syncModelFileToDBAsync(file));\n      });\n      return Promise.all(syncModelTasks);\n    })\n    .then(() => {\n      if (cb) cb();\n    })\n    .catch((err) => {\n      if (cb && _.isArray(err) && err.length > 0) cb(err[0]);\n      else if (cb) cb(err);\n    });\n};\n\nCassandraClient.bindAsync = Promise.promisify(CassandraClient.bind);\n\nCassandraClient.prototype.init = function f(callback) {\n  this.orm.init(callback);\n};\n\nCassandraClient.prototype.initAsync = Promise.promisify(CassandraClient.prototype.init);\n\nCassandraClient.getTableList = function f(callback) {\n  const systemClient = this.orm.get_system_client();\n  const keyspace = this.orm.get_keyspace_name();\n  const tables = [];\n\n  systemClient.connect()\n    .then(() => {\n      const systemQuery = 'SELECT table_name FROM system_schema.tables WHERE keyspace_name = ?';\n      debug(`Finding tables in keyspace: ${keyspace}`);\n      return systemClient.execute(systemQuery, [keyspace]);\n    })\n    .then((result) => {\n      for (let i = 0; i < result.rows.length; i++) {\n        tables.push(result.rows[i].table_name);\n      }\n    })\n    .then(() => systemClient.shutdown())\n    .then(() => {\n      callback(null, tables);\n    })\n    .catch((err) => {\n      callback(err);\n    });\n};\n\nCassandraClient.getTableListAsync = Promise.promisify(CassandraClient.getTableList);\n\nCassandraClient.export = function f(fixtureDirectory, callback) {\n  const systemClient = this.orm.get_system_client();\n  const keyspace = this.orm.get_keyspace_name();\n\n  systemClient.connect()\n    .then(() => this.getTableListAsync())\n    .then((tables) =>\n      Promise.each(tables, (table) =>\n        exporter.processTableExport(systemClient, fixtureDirectory, keyspace, table)))\n    .then(() => systemClient.shutdown())\n    .then(() => {\n      debug('==================================================');\n      debug(`Completed exporting all tables from keyspace: ${keyspace}`);\n      callback();\n    })\n    .catch((err) => {\n      debug(err);\n      callback(err);\n    });\n};\n\nCassandraClient.exportAsync = Promise.promisify(CassandraClient.export);\n\nCassandraClient.import = function f(fixtureDirectory, options, callback) {\n  if (arguments.length === 2) {\n    callback = options;\n    options = {};\n  }\n\n  const defaults = {\n    batchSize: 1,\n  };\n\n  options = _.defaultsDeep({}, options, defaults);\n\n  const systemClient = this.orm.get_system_client();\n  const keyspace = this.orm.get_keyspace_name();\n\n  systemClient.connect()\n    .then(() => this.getTableListAsync())\n    .then((tables) =>\n      Promise.each(tables, (table) =>\n        importer.processTableImport(systemClient, fixtureDirectory, keyspace, table, options.batchSize)))\n    .then(() => systemClient.shutdown())\n    .then(() => {\n      debug('==================================================');\n      debug(`Completed importing to keyspace: ${keyspace}`);\n      callback();\n    })\n    .catch((err) => {\n      debug(err);\n      callback(err);\n    });\n};\n\nCassandraClient.importAsync = Promise.promisify(CassandraClient.import);\n\nCassandraClient.prototype.loadSchema = function f(modelName, modelSchema) {\n  this.modelInstance[modelName] = this.orm.addModel(modelName, modelSchema);\n  this.modelInstance[modelName] = Promise.promisifyAll(this.modelInstance[modelName]);\n  return this.modelInstance[modelName];\n};\n\nCassandraClient.uuid = () => (cql.types.Uuid.random());\n\nCassandraClient.uuidFromString = (str) => (cql.types.Uuid.fromString(str));\n\nCassandraClient.uuidFromBuffer = (buf) => (new cql.types.Uuid(buf));\n\nCassandraClient.timeuuid = () => (cql.types.TimeUuid.now());\n\nCassandraClient.timeuuidFromDate = (date) => (cql.types.TimeUuid.fromDate(date));\n\nCassandraClient.timeuuidFromString = (str) => (cql.types.TimeUuid.fromString(str));\n\nCassandraClient.timeuuidFromBuffer = (buf) => (new cql.types.TimeUuid(buf));\n\nCassandraClient.maxTimeuuid = (date) => (cql.types.TimeUuid.max(date));\n\nCassandraClient.minTimeuuid = (date) => (cql.types.TimeUuid.min(date));\n\nCassandraClient.prototype.doBatch = function f(queries, options, callback) {\n  if (arguments.length === 2) {\n    callback = options;\n    options = {};\n  }\n\n  const defaults = {\n    prepare: true,\n  };\n\n  options = _.defaultsDeep({}, options, defaults);\n\n  const randomModel = this.modelInstance[Object.keys(this.modelInstance)[0]];\n  const beforeHooks = [];\n\n  let batchResult;\n  Promise.all(beforeHooks)\n    .then(() => {\n      if (queries.length > 1) {\n        return randomModel.execute_batchAsync(queries, options);\n      }\n      if (queries.length > 0) {\n        debug('single query provided for batch request, applying as non batch query');\n        return randomModel.execute_queryAsync(queries[0].query, queries[0].params, options);\n      }\n      debug('no queries provided for batch request, empty array found, doing nothing');\n      return {};\n    })\n    .then((response) => {\n      batchResult = response;\n      for (let i = 0; i < queries.length; i++) {\n        const afterHookResponse = queries[i].after_hook();\n        if (afterHookResponse !== true) {\n          callback(afterHookResponse);\n          return;\n        }\n      }\n      callback(null, batchResult);\n    })\n    .catch((err) => {\n      callback(err);\n    });\n};\n\nCassandraClient.prototype.doBatchAsync = Promise.promisify(CassandraClient.prototype.doBatch);\n\nCassandraClient.doBatch = function f(queries, options, callback) {\n  if (arguments.length === 2) {\n    callback = options;\n    options = {};\n  }\n\n  const defaults = {\n    prepare: true,\n  };\n\n  options = _.defaultsDeep({}, options, defaults);\n\n  CassandraClient.prototype.doBatch.call(CassandraClient, queries, options, callback);\n};\n\nCassandraClient.doBatchAsync = Promise.promisify(CassandraClient.doBatch);\n\nCassandraClient._translateFileNameToModelName = (fileName) => (\n  fileName.slice(0, fileName.lastIndexOf('.')).replace('Model', '')\n);\n\nObject.defineProperties(CassandraClient, {\n  consistencies: {\n    get() {\n      return cql.types.consistencies;\n    },\n  },\n  datatypes: {\n    get() {\n      return cql.types;\n    },\n  },\n  driver: {\n    get() {\n      return cql;\n    },\n  },\n  instance: {\n    get() {\n      return CassandraClient.modelInstance;\n    },\n  },\n  close: {\n    get() {\n      return CassandraClient.orm.close;\n    },\n  },\n  closeAsync: {\n    get() {\n      return Promise.promisify(CassandraClient.orm.close);\n    },\n  },\n});\n\n\nObject.defineProperties(CassandraClient.prototype, {\n  consistencies: {\n    get() {\n      return cql.types.consistencies;\n    },\n  },\n  datatypes: {\n    get() {\n      return cql.types;\n    },\n  },\n  driver: {\n    get() {\n      return cql;\n    },\n  },\n  instance: {\n    get() {\n      return this.modelInstance;\n    },\n  },\n  close: {\n    get() {\n      return this.orm.close;\n    },\n  },\n  closeAsync: {\n    get() {\n      return Promise.promisify(this.orm.close);\n    },\n  },\n});\n\nCassandraClient.prototype.uuid = CassandraClient.uuid;\nCassandraClient.prototype.uuidFromString = CassandraClient.uuidFromString;\nCassandraClient.prototype.uuidFromBuffer = CassandraClient.uuidFromBuffer;\nCassandraClient.prototype.timeuuid = CassandraClient.timeuuid;\nCassandraClient.prototype.timeuuidFromDate = CassandraClient.timeuuidFromDate;\nCassandraClient.prototype.timeuuidFromString = CassandraClient.timeuuidFromString;\nCassandraClient.prototype.timeuuidFromBuffer = CassandraClient.timeuuidFromBuffer;\nCassandraClient.prototype.maxTimeuuid = CassandraClient.maxTimeuuid;\nCassandraClient.prototype.minTimeuuid = CassandraClient.minTimeuuid;\n\nCassandraClient.prototype._translateFileNameToModelName = CassandraClient._translateFileNameToModelName;\n\nmodule.exports = CassandraClient;\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/expressCassandra.js"],"names":["semver","require","satisfies","process","version","Promise","_","path","dseDriver","e","cql","promisifyAll","ORM","readdirpAsync","promisify","debug","exporter","importer","CassandraClient","f","options","modelInstance","orm","clientOptions","ormOptions","createClient","setDirectory","directory","syncModelFileToDB","file","callback","name","includes","modelName","_translateFileNameToModelName","fileLocation","join","defaultModelSchema","modelSchema","default","addModel","toLowerCase","syncDB","bind","cb","initAsync","then","root","fileFilter","fileList","syncModelTasks","syncModelFileToDBAsync","files","forEach","push","all","catch","err","isArray","length","bindAsync","prototype","init","getTableList","systemClient","get_system_client","keyspace","get_keyspace_name","tables","connect","systemQuery","execute","result","i","rows","table_name","shutdown","getTableListAsync","export","fixtureDirectory","each","table","processTableExport","exportAsync","import","arguments","defaults","batchSize","defaultsDeep","processTableImport","importAsync","loadSchema","uuid","types","Uuid","random","uuidFromString","str","fromString","uuidFromBuffer","buf","timeuuid","TimeUuid","now","timeuuidFromDate","date","fromDate","timeuuidFromString","timeuuidFromBuffer","maxTimeuuid","max","minTimeuuid","min","doBatch","queries","prepare","randomModel","Object","keys","beforeHooks","batchResult","execute_batchAsync","execute_queryAsync","query","params","response","afterHookResponse","after_hook","doBatchAsync","call","fileName","slice","lastIndexOf","replace","defineProperties","consistencies","get","datatypes","driver","instance","close","closeAsync","module","exports"],"mappings":"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","file":"expressCassandra.js","sourcesContent":["const semver = require('semver');\n\nif (!semver.satisfies(process.version, '>=6.0.0')) {\n  require('babel-polyfill');\n}\n\nconst Promise = require('bluebird');\nconst _ = require('lodash');\nconst path = require('path');\n\nlet dseDriver;\ntry {\n  // eslint-disable-next-line import/no-extraneous-dependencies, import/no-unresolved\n  dseDriver = require('dse-driver');\n} catch (e) {\n  dseDriver = null;\n}\n\nconst cql = Promise.promisifyAll(dseDriver || require('cassandra-driver'));\n\nconst ORM = Promise.promisifyAll(require('./orm/apollo'));\nconst readdirpAsync = Promise.promisify(require('readdirp'));\nconst debug = require('debug')('express-cassandra');\n\nconst exporter = require('./utils/exporter');\nconst importer = require('./utils/importer');\n\nconst CassandraClient = function f(options) {\n  this.modelInstance = {};\n  this.orm = new ORM(options.clientOptions, options.ormOptions);\n  this.orm = Promise.promisifyAll(this.orm);\n};\n\nCassandraClient.createClient = (options) => (new CassandraClient(options));\n\nCassandraClient.setDirectory = (directory) => {\n  CassandraClient.directory = directory;\n  return CassandraClient;\n};\n\nCassandraClient.syncModelFileToDB = (file, callback) => {\n  if (!file.name.includes('Model')) {\n    callback();\n    return;\n  }\n\n  const modelName = CassandraClient._translateFileNameToModelName(file.name);\n\n  if (modelName) {\n    const fileLocation = path.join(CassandraClient.directory, file.path);\n    // eslint-disable-next-line import/no-dynamic-require\n    const defaultModelSchema = require(fileLocation);\n    const modelSchema = defaultModelSchema.default ? defaultModelSchema.default : defaultModelSchema;\n    CassandraClient.modelInstance[modelName] = CassandraClient.orm.addModel(modelName.toLowerCase(), modelSchema);\n    CassandraClient.modelInstance[modelName].syncDB(callback);\n    CassandraClient.modelInstance[modelName] = Promise.promisifyAll(CassandraClient.modelInstance[modelName]);\n    return;\n  }\n\n  callback();\n};\n\nCassandraClient.bind = (options, cb) => {\n  CassandraClient.modelInstance = {};\n  CassandraClient.orm = new ORM(options.clientOptions, options.ormOptions);\n  CassandraClient.orm = Promise.promisifyAll(CassandraClient.orm);\n  CassandraClient.orm.initAsync()\n    .then(() => readdirpAsync({\n      root: CassandraClient.directory,\n      fileFilter: [\n        '*.js', '*.javascript', '*.jsx', '*.coffee', '*.coffeescript', '*.iced',\n        '*.script', '*.ts', '*.tsx', '*.typescript', '*.cjsx', '*.co', '*.json',\n        '*.json5', '*.litcoffee', '*.liticed', '*.ls', '*.node', '*.toml',\n        '*.wisp', '*.cjs',\n      ],\n    }))\n    .then((fileList) => {\n      const syncModelTasks = [];\n      const syncModelFileToDBAsync = Promise.promisify(CassandraClient.syncModelFileToDB);\n      fileList = fileList.files;\n      fileList.forEach((file) => {\n        syncModelTasks.push(syncModelFileToDBAsync(file));\n      });\n      return Promise.all(syncModelTasks);\n    })\n    .then(() => {\n      if (cb) cb();\n    })\n    .catch((err) => {\n      if (cb && _.isArray(err) && err.length > 0) cb(err[0]);\n      else if (cb) cb(err);\n    });\n};\n\nCassandraClient.bindAsync = Promise.promisify(CassandraClient.bind);\n\nCassandraClient.prototype.init = function f(callback) {\n  this.orm.init(callback);\n};\n\nCassandraClient.prototype.initAsync = Promise.promisify(CassandraClient.prototype.init);\n\nCassandraClient.getTableList = function f(callback) {\n  const systemClient = this.orm.get_system_client();\n  const keyspace = this.orm.get_keyspace_name();\n  const tables = [];\n\n  systemClient.connect()\n    .then(() => {\n      const systemQuery = 'SELECT table_name FROM system_schema.tables WHERE keyspace_name = ?';\n      debug(`Finding tables in keyspace: ${keyspace}`);\n      return systemClient.execute(systemQuery, [keyspace]);\n    })\n    .then((result) => {\n      for (let i = 0; i < result.rows.length; i++) {\n        tables.push(result.rows[i].table_name);\n      }\n    })\n    .then(() => systemClient.shutdown())\n    .then(() => {\n      callback(null, tables);\n    })\n    .catch((err) => {\n      callback(err);\n    });\n};\n\nCassandraClient.getTableListAsync = Promise.promisify(CassandraClient.getTableList);\n\nCassandraClient.export = function f(fixtureDirectory, callback) {\n  const systemClient = this.orm.get_system_client();\n  const keyspace = this.orm.get_keyspace_name();\n\n  systemClient.connect()\n    .then(() => this.getTableListAsync())\n    .then((tables) => Promise.each(tables, (table) => exporter.processTableExport(\n      systemClient,\n      fixtureDirectory,\n      keyspace,\n      table,\n    )))\n    .then(() => systemClient.shutdown())\n    .then(() => {\n      debug('==================================================');\n      debug(`Completed exporting all tables from keyspace: ${keyspace}`);\n      callback();\n    })\n    .catch((err) => {\n      debug(err);\n      callback(err);\n    });\n};\n\nCassandraClient.exportAsync = Promise.promisify(CassandraClient.export);\n\nCassandraClient.import = function f(fixtureDirectory, options, callback) {\n  if (arguments.length === 2) {\n    callback = options;\n    options = {};\n  }\n\n  const defaults = {\n    batchSize: 1,\n  };\n\n  options = _.defaultsDeep({}, options, defaults);\n\n  const systemClient = this.orm.get_system_client();\n  const keyspace = this.orm.get_keyspace_name();\n\n  systemClient.connect()\n    .then(() => this.getTableListAsync())\n    .then((tables) => Promise.each(tables, (table) => importer.processTableImport(\n      systemClient,\n      fixtureDirectory,\n      keyspace,\n      table,\n      options.batchSize,\n    )))\n    .then(() => systemClient.shutdown())\n    .then(() => {\n      debug('==================================================');\n      debug(`Completed importing to keyspace: ${keyspace}`);\n      callback();\n    })\n    .catch((err) => {\n      debug(err);\n      callback(err);\n    });\n};\n\nCassandraClient.importAsync = Promise.promisify(CassandraClient.import);\n\nCassandraClient.prototype.loadSchema = function f(modelName, modelSchema) {\n  this.modelInstance[modelName] = this.orm.addModel(modelName, modelSchema);\n  this.modelInstance[modelName] = Promise.promisifyAll(this.modelInstance[modelName]);\n  return this.modelInstance[modelName];\n};\n\nCassandraClient.uuid = () => (cql.types.Uuid.random());\n\nCassandraClient.uuidFromString = (str) => (cql.types.Uuid.fromString(str));\n\nCassandraClient.uuidFromBuffer = (buf) => (new cql.types.Uuid(buf));\n\nCassandraClient.timeuuid = () => (cql.types.TimeUuid.now());\n\nCassandraClient.timeuuidFromDate = (date) => (cql.types.TimeUuid.fromDate(date));\n\nCassandraClient.timeuuidFromString = (str) => (cql.types.TimeUuid.fromString(str));\n\nCassandraClient.timeuuidFromBuffer = (buf) => (new cql.types.TimeUuid(buf));\n\nCassandraClient.maxTimeuuid = (date) => (cql.types.TimeUuid.max(date));\n\nCassandraClient.minTimeuuid = (date) => (cql.types.TimeUuid.min(date));\n\nCassandraClient.prototype.doBatch = function f(queries, options, callback) {\n  if (arguments.length === 2) {\n    callback = options;\n    options = {};\n  }\n\n  const defaults = {\n    prepare: true,\n  };\n\n  options = _.defaultsDeep({}, options, defaults);\n\n  const randomModel = this.modelInstance[Object.keys(this.modelInstance)[0]];\n  const beforeHooks = [];\n\n  let batchResult;\n  Promise.all(beforeHooks)\n    .then(() => {\n      if (queries.length > 1) {\n        return randomModel.execute_batchAsync(queries, options);\n      }\n      if (queries.length > 0) {\n        debug('single query provided for batch request, applying as non batch query');\n        return randomModel.execute_queryAsync(queries[0].query, queries[0].params, options);\n      }\n      debug('no queries provided for batch request, empty array found, doing nothing');\n      return {};\n    })\n    .then((response) => {\n      batchResult = response;\n      for (let i = 0; i < queries.length; i++) {\n        const afterHookResponse = queries[i].after_hook();\n        if (afterHookResponse !== true) {\n          callback(afterHookResponse);\n          return;\n        }\n      }\n      callback(null, batchResult);\n    })\n    .catch((err) => {\n      callback(err);\n    });\n};\n\nCassandraClient.prototype.doBatchAsync = Promise.promisify(CassandraClient.prototype.doBatch);\n\nCassandraClient.doBatch = function f(queries, options, callback) {\n  if (arguments.length === 2) {\n    callback = options;\n    options = {};\n  }\n\n  const defaults = {\n    prepare: true,\n  };\n\n  options = _.defaultsDeep({}, options, defaults);\n\n  CassandraClient.prototype.doBatch.call(CassandraClient, queries, options, callback);\n};\n\nCassandraClient.doBatchAsync = Promise.promisify(CassandraClient.doBatch);\n\nCassandraClient._translateFileNameToModelName = (fileName) => (\n  fileName.slice(0, fileName.lastIndexOf('.')).replace('Model', '')\n);\n\nObject.defineProperties(CassandraClient, {\n  consistencies: {\n    get() {\n      return cql.types.consistencies;\n    },\n  },\n  datatypes: {\n    get() {\n      return cql.types;\n    },\n  },\n  driver: {\n    get() {\n      return cql;\n    },\n  },\n  instance: {\n    get() {\n      return CassandraClient.modelInstance;\n    },\n  },\n  close: {\n    get() {\n      return CassandraClient.orm.close;\n    },\n  },\n  closeAsync: {\n    get() {\n      return Promise.promisify(CassandraClient.orm.close);\n    },\n  },\n});\n\nObject.defineProperties(CassandraClient.prototype, {\n  consistencies: {\n    get() {\n      return cql.types.consistencies;\n    },\n  },\n  datatypes: {\n    get() {\n      return cql.types;\n    },\n  },\n  driver: {\n    get() {\n      return cql;\n    },\n  },\n  instance: {\n    get() {\n      return this.modelInstance;\n    },\n  },\n  close: {\n    get() {\n      return this.orm.close;\n    },\n  },\n  closeAsync: {\n    get() {\n      return Promise.promisify(this.orm.close);\n    },\n  },\n});\n\nCassandraClient.prototype.uuid = CassandraClient.uuid;\nCassandraClient.prototype.uuidFromString = CassandraClient.uuidFromString;\nCassandraClient.prototype.uuidFromBuffer = CassandraClient.uuidFromBuffer;\nCassandraClient.prototype.timeuuid = CassandraClient.timeuuid;\nCassandraClient.prototype.timeuuidFromDate = CassandraClient.timeuuidFromDate;\nCassandraClient.prototype.timeuuidFromString = CassandraClient.timeuuidFromString;\nCassandraClient.prototype.timeuuidFromBuffer = CassandraClient.timeuuidFromBuffer;\nCassandraClient.prototype.maxTimeuuid = CassandraClient.maxTimeuuid;\nCassandraClient.prototype.minTimeuuid = CassandraClient.minTimeuuid;\n\nCassandraClient.prototype._translateFileNameToModelName = CassandraClient._translateFileNameToModelName;\n\nmodule.exports = CassandraClient;\n"]}

@@ -184,2 +184,2 @@ 'use strict';

module.exports = buildError;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/orm/apollo_error.js"],"names":["util","require","AERROR_TYPES","unspecified","msg","ERR_NAME_PREFIX","buildError","f","args","argsarray","name","length","shift","errorTemplate","errorMsg","format","apply","concat","error","Error","module","exports"],"mappings":"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","file":"apollo_error.js","sourcesContent":["const util = require('util');\n\nconst AERROR_TYPES = {\n  unspecified: {\n    msg: 'Unspecified error ->',\n  },\n  'model.validator.invalidconfig': {\n    msg: '%s',\n  },\n  'model.validator.invalidudt': {\n    msg: '%s',\n  },\n  'model.validator.invalidudf': {\n    msg: '%s',\n  },\n  'model.validator.invaliduda': {\n    msg: '%s',\n  },\n  'model.validator.invalidschema': {\n    msg: '%s',\n  },\n  'model.validator.invalidvalue': {\n    msg: '%s',\n  },\n  'model.tablecreation.invalidname': {\n    msg: 'Table names only allow alphanumeric and _ and must start with a letter, got %s',\n  },\n  'model.tablecreation.dbschemaquery': {\n    msg: 'Error while retrieveing Schema of DB Table \"%s\"',\n  },\n  'model.tablecreation.schemamismatch': {\n    msg: 'Given Schema does not match existing DB Table \"%s\"\\n%s',\n  },\n  'model.tablecreation.schemanotfound': {\n    msg: 'No DB Table was found for Given Schema -> %s',\n  },\n  'model.tablecreation.dbcreate': {\n    msg: 'Error while creating DB Table -> %s',\n  },\n  'model.tablecreation.dbalter': {\n    msg: 'Error while altering DB Table -> %s',\n  },\n  'model.tablecreation.dbdrop': {\n    msg: 'Error while dropping DB Table -> %s',\n  },\n  'model.tablecreation.dbindexcreate': {\n    msg: 'Error while creating index on DB Table -> %s',\n  },\n  'model.tablecreation.dbindexdrop': {\n    msg: 'Error while dropping index on DB Table -> %s',\n  },\n  'model.tablecreation.matviewcreate': {\n    msg: 'Error while creating materialized view on DB Table -> %s',\n  },\n  'model.tablecreation.matviewdrop': {\n    msg: 'Error while dropping materialized view on DB Table -> %s',\n  },\n  'model.find.invalidop': {\n    msg: 'Invalid field relation: unknown operator: \"%s\"',\n  },\n  'model.find.invalidexpr': {\n    msg: '$expr must be an object containing the index name as string and query as string.',\n  },\n  'model.find.invalidsolrquery': {\n    msg: '$solr_query must be a string containing the query for solr.',\n  },\n  'model.find.invalidorder': {\n    msg: 'Invalid $orderby query, $orderby must be an object',\n  },\n  'model.find.invalidgroup': {\n    msg: 'Invalid $groupby query, $groupby must be an array',\n  },\n  'model.find.multiorder': {\n    msg: 'Invalid $orderby query: only one clause per object is allowed',\n  },\n  'model.find.invalidordertype': {\n    msg: 'Invalid $orderby query, allowed order: $asc / $desc, given \"%s\"',\n  },\n  'model.find.limittype': {\n    msg: '$limit must be an integer, given value \"%s\"',\n  },\n  'model.find.invalidinop': {\n    msg: 'Invalid $in query. $in must be an array',\n  },\n  'model.find.invalidcontainsop': {\n    msg: 'Invalid $contains query, $contains operator is only valid for indexed collections',\n  },\n  'model.find.invalidcontainskeyop': {\n    msg: 'Invalid $contains_key query, $contains_key operator is only valid for indexed map collections',\n  },\n  'model.find.invalidtoken': {\n    msg: 'Invalid $token query. $token must be an object with operator values',\n  },\n  'model.find.invalidtokenop': {\n    msg: 'Invalid operator: \"%s\" in $token query',\n  },\n  'model.find.streamerror': {\n    msg: 'Invalid stream query -> %s',\n  },\n  'model.find.eachrowerror': {\n    msg: 'Invalid eachRow query -> %s',\n  },\n  'model.find.cberror': {\n    msg: 'No valid callback function was provided',\n  },\n  'model.find.dberror': {\n    msg: 'Error during find query on DB -> %s',\n  },\n  'model.save.unsetkey': {\n    msg: 'Primary Key Field: %s must have a value',\n  },\n  'model.save.unsetrequired': {\n    msg: 'Required Field: %s must have a value',\n  },\n  'model.save.invaliddefaultvalue': {\n    msg: 'Invalid Default value: \"%s\" for Field: %s (Type: %s)',\n  },\n  'model.save.dberror': {\n    msg: 'Error during save query on DB -> %s',\n  },\n  'model.save.before.error': {\n    msg: 'Error in before_save lifecycle function',\n  },\n  'model.save.after.error': {\n    msg: 'Error in after_save lifecycle function',\n  },\n  'model.update.unsetkey': {\n    msg: 'Primary Key Field: %s must have a value',\n  },\n  'model.update.unsetrequired': {\n    msg: 'Required Field: %s must have a value',\n  },\n  'model.update.invaliddefaultvalue': {\n    msg: 'Invalid Default value: \"%s\" for Field: %s (Type: %s)',\n  },\n  'model.update.invalidreplaceop': {\n    msg: 'Invalid $replace operation -> %s',\n  },\n  'model.update.invalidprependop': {\n    msg: 'Invalid $prepend operation -> %s',\n  },\n  'model.update.dberror': {\n    msg: 'Error during update query on DB -> %s',\n  },\n  'model.update.before.error': {\n    msg: 'Error in before_update lifecycle function',\n  },\n  'model.update.after.error': {\n    msg: 'Error in after_update lifecycle function',\n  },\n  'model.delete.dberror': {\n    msg: 'Error during delete query on DB -> %s',\n  },\n  'model.delete.before.error': {\n    msg: 'Error in before_delete lifecycle function',\n  },\n  'model.delete.after.error': {\n    msg: 'Error in after_delete lifecycle function',\n  },\n};\n\nconst ERR_NAME_PREFIX = 'apollo';\n\nconst buildError = function f(...args) {\n  const argsarray = args;\n  const name = argsarray.length ? argsarray.shift() : '_none_given_';\n\n  const errorTemplate = AERROR_TYPES[name] || AERROR_TYPES.unspecified;\n  const errorMsg = argsarray.length ?\n    util.format.apply(this, [errorTemplate.msg].concat(argsarray)) :\n    errorTemplate.msg;\n\n  const error = new Error(errorMsg);\n  error.name = (ERR_NAME_PREFIX ? util.format('%s.', ERR_NAME_PREFIX) : '') + name;\n\n  return error;\n};\n\nmodule.exports = buildError;\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/orm/apollo_error.js"],"names":["util","require","AERROR_TYPES","unspecified","msg","ERR_NAME_PREFIX","buildError","f","args","argsarray","name","length","shift","errorTemplate","errorMsg","format","apply","concat","error","Error","module","exports"],"mappings":"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","file":"apollo_error.js","sourcesContent":["const util = require('util');\n\nconst AERROR_TYPES = {\n  unspecified: {\n    msg: 'Unspecified error ->',\n  },\n  'model.validator.invalidconfig': {\n    msg: '%s',\n  },\n  'model.validator.invalidudt': {\n    msg: '%s',\n  },\n  'model.validator.invalidudf': {\n    msg: '%s',\n  },\n  'model.validator.invaliduda': {\n    msg: '%s',\n  },\n  'model.validator.invalidschema': {\n    msg: '%s',\n  },\n  'model.validator.invalidvalue': {\n    msg: '%s',\n  },\n  'model.tablecreation.invalidname': {\n    msg: 'Table names only allow alphanumeric and _ and must start with a letter, got %s',\n  },\n  'model.tablecreation.dbschemaquery': {\n    msg: 'Error while retrieveing Schema of DB Table \"%s\"',\n  },\n  'model.tablecreation.schemamismatch': {\n    msg: 'Given Schema does not match existing DB Table \"%s\"\\n%s',\n  },\n  'model.tablecreation.schemanotfound': {\n    msg: 'No DB Table was found for Given Schema -> %s',\n  },\n  'model.tablecreation.dbcreate': {\n    msg: 'Error while creating DB Table -> %s',\n  },\n  'model.tablecreation.dbalter': {\n    msg: 'Error while altering DB Table -> %s',\n  },\n  'model.tablecreation.dbdrop': {\n    msg: 'Error while dropping DB Table -> %s',\n  },\n  'model.tablecreation.dbindexcreate': {\n    msg: 'Error while creating index on DB Table -> %s',\n  },\n  'model.tablecreation.dbindexdrop': {\n    msg: 'Error while dropping index on DB Table -> %s',\n  },\n  'model.tablecreation.matviewcreate': {\n    msg: 'Error while creating materialized view on DB Table -> %s',\n  },\n  'model.tablecreation.matviewdrop': {\n    msg: 'Error while dropping materialized view on DB Table -> %s',\n  },\n  'model.find.invalidop': {\n    msg: 'Invalid field relation: unknown operator: \"%s\"',\n  },\n  'model.find.invalidexpr': {\n    msg: '$expr must be an object containing the index name as string and query as string.',\n  },\n  'model.find.invalidsolrquery': {\n    msg: '$solr_query must be a string containing the query for solr.',\n  },\n  'model.find.invalidorder': {\n    msg: 'Invalid $orderby query, $orderby must be an object',\n  },\n  'model.find.invalidgroup': {\n    msg: 'Invalid $groupby query, $groupby must be an array',\n  },\n  'model.find.multiorder': {\n    msg: 'Invalid $orderby query: only one clause per object is allowed',\n  },\n  'model.find.invalidordertype': {\n    msg: 'Invalid $orderby query, allowed order: $asc / $desc, given \"%s\"',\n  },\n  'model.find.limittype': {\n    msg: '$limit must be an integer, given value \"%s\"',\n  },\n  'model.find.invalidinop': {\n    msg: 'Invalid $in query. $in must be an array',\n  },\n  'model.find.invalidcontainsop': {\n    msg: 'Invalid $contains query, $contains operator is only valid for indexed collections',\n  },\n  'model.find.invalidcontainskeyop': {\n    msg: 'Invalid $contains_key query, $contains_key operator is only valid for indexed map collections',\n  },\n  'model.find.invalidtoken': {\n    msg: 'Invalid $token query. $token must be an object with operator values',\n  },\n  'model.find.invalidtokenop': {\n    msg: 'Invalid operator: \"%s\" in $token query',\n  },\n  'model.find.streamerror': {\n    msg: 'Invalid stream query -> %s',\n  },\n  'model.find.eachrowerror': {\n    msg: 'Invalid eachRow query -> %s',\n  },\n  'model.find.cberror': {\n    msg: 'No valid callback function was provided',\n  },\n  'model.find.dberror': {\n    msg: 'Error during find query on DB -> %s',\n  },\n  'model.save.unsetkey': {\n    msg: 'Primary Key Field: %s must have a value',\n  },\n  'model.save.unsetrequired': {\n    msg: 'Required Field: %s must have a value',\n  },\n  'model.save.invaliddefaultvalue': {\n    msg: 'Invalid Default value: \"%s\" for Field: %s (Type: %s)',\n  },\n  'model.save.dberror': {\n    msg: 'Error during save query on DB -> %s',\n  },\n  'model.save.before.error': {\n    msg: 'Error in before_save lifecycle function',\n  },\n  'model.save.after.error': {\n    msg: 'Error in after_save lifecycle function',\n  },\n  'model.update.unsetkey': {\n    msg: 'Primary Key Field: %s must have a value',\n  },\n  'model.update.unsetrequired': {\n    msg: 'Required Field: %s must have a value',\n  },\n  'model.update.invaliddefaultvalue': {\n    msg: 'Invalid Default value: \"%s\" for Field: %s (Type: %s)',\n  },\n  'model.update.invalidreplaceop': {\n    msg: 'Invalid $replace operation -> %s',\n  },\n  'model.update.invalidprependop': {\n    msg: 'Invalid $prepend operation -> %s',\n  },\n  'model.update.dberror': {\n    msg: 'Error during update query on DB -> %s',\n  },\n  'model.update.before.error': {\n    msg: 'Error in before_update lifecycle function',\n  },\n  'model.update.after.error': {\n    msg: 'Error in after_update lifecycle function',\n  },\n  'model.delete.dberror': {\n    msg: 'Error during delete query on DB -> %s',\n  },\n  'model.delete.before.error': {\n    msg: 'Error in before_delete lifecycle function',\n  },\n  'model.delete.after.error': {\n    msg: 'Error in after_delete lifecycle function',\n  },\n};\n\nconst ERR_NAME_PREFIX = 'apollo';\n\nconst buildError = function f(...args) {\n  const argsarray = args;\n  const name = argsarray.length ? argsarray.shift() : '_none_given_';\n\n  const errorTemplate = AERROR_TYPES[name] || AERROR_TYPES.unspecified;\n  const errorMsg = argsarray.length\n    ? util.format.apply(this, [errorTemplate.msg].concat(argsarray))\n    : errorTemplate.msg;\n\n  const error = new Error(errorMsg);\n  error.name = (ERR_NAME_PREFIX ? util.format('%s.', ERR_NAME_PREFIX) : '') + name;\n\n  return error;\n};\n\nmodule.exports = buildError;\n"]}

@@ -165,2 +165,5 @@ 'use strict';

outputMView.where_clause = parser.get_mview_where_clause(outputSchema, outputMView).trim();
} else {
// some versions of cassandra/scylla return IS NOT null instead of IS NOT NULL
outputMView.where_clause = outputMView.where_clause.replace(/IS NOT null/g, 'IS NOT NULL');
}

@@ -258,2 +261,2 @@ if (_.isPlainObject(outputMView.filters)) {

module.exports = normalizer;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/utils/normalizer.js"],"names":["_","require","util","parser","arraySort","a","b","normalizeTypeDef","typeDef","formattedTypeDef","replace","frozenMatch","match","length","slice","normalizer","normalize_replication_option","replicationOptions","normalizedReplicationOptions","Object","keys","forEach","key","parseInt","normalize_query_option","options","queryOptions","prepare","consistency","fetchSize","autoPage","hints","pageState","retry","serialConsistency","customPayload","isIdempotent","readTimeout","retryOnTimeout","routingIndexes","routingKey","routingNames","timestamp","normalize_user_defined_type","fieldType","normalize_primary_key","outputSchema","i","clustering_order","toUpperCase","normalize_fields","modelSchema","fields","fieldName","type","virtual","includes","typeMaps","staticMaps","static","normalize_materialized_views","materialized_views","materializedViewName","outputMView","pkeyIndex","partitionIndex","select","push","sort","where_clause","get_mview_where_clause","trim","isPlainObject","filters","normalize_indexes","indexes","indexNameList","split","toLowerCase","format","normalize_custom_indexes","custom_index","custom_indexes","customArraySort","on","using","remove","cindex","normalize_model_schema","cloneDeep","normalizableSchemaProperties","schemaProperty","remove_dependent_views_from_normalized_schema","normalizedDBSchema","dbSchema","dependentViews","dbViewName","isArray","viewName","module","exports"],"mappings":"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","file":"normalizer.js","sourcesContent":["const _ = require('lodash');\nconst util = require('util');\n\nconst parser = require('./parser');\n\nconst arraySort = (a, b) => {\n  if (a > b) return 1;\n  if (a < b) return -1;\n  return 0;\n};\n\nconst normalizeTypeDef = (typeDef) => {\n  const formattedTypeDef = typeDef.replace(/[\\s]/g, '').replace(/varchar/g, 'text').replace(/frozen/ig, 'frozen');\n  const frozenMatch = formattedTypeDef.match(/frozen</g);\n  if (frozenMatch && frozenMatch.length) return formattedTypeDef.replace(/frozen</g, '').slice(0, -1 * frozenMatch.length);\n  return formattedTypeDef;\n};\n\nconst normalizer = {\n  normalize_replication_option(replicationOptions) {\n    const normalizedReplicationOptions = replicationOptions;\n    Object.keys(normalizedReplicationOptions).forEach((key) => {\n      if (key === 'class') {\n        normalizedReplicationOptions[key] = normalizedReplicationOptions[key].replace('org.apache.cassandra.locator.', '');\n        return;\n      }\n      normalizedReplicationOptions[key] = parseInt(normalizedReplicationOptions[key], 10);\n    });\n    return normalizedReplicationOptions;\n  },\n\n  normalize_query_option(options) {\n    const queryOptions = { prepare: options.prepare };\n    if (options.consistency) queryOptions.consistency = options.consistency;\n    if (options.fetchSize) queryOptions.fetchSize = options.fetchSize;\n    if (options.autoPage) queryOptions.autoPage = options.autoPage;\n    if (options.hints) queryOptions.hints = options.hints;\n    if (options.pageState) queryOptions.pageState = options.pageState;\n    if (options.retry) queryOptions.retry = options.retry;\n    if (options.serialConsistency) queryOptions.serialConsistency = options.serialConsistency;\n    if (options.customPayload) queryOptions.customPayload = options.customPayload;\n    if (options.isIdempotent) queryOptions.isIdempotent = options.isIdempotent;\n    if (options.readTimeout) queryOptions.readTimeout = options.readTimeout;\n    if (options.retry) queryOptions.retry = options.retry;\n    if (options.retryOnTimeout) queryOptions.retryOnTimeout = options.retryOnTimeout;\n    if (options.routingIndexes) queryOptions.routingIndexes = options.routingIndexes;\n    if (options.routingKey) queryOptions.routingKey = options.routingKey;\n    if (options.routingNames) queryOptions.routingNames = options.routingNames;\n    if (options.timestamp) queryOptions.timestamp = options.timestamp;\n    return queryOptions;\n  },\n\n  normalize_user_defined_type(fieldType) {\n    return normalizeTypeDef(fieldType);\n  },\n\n  normalize_primary_key(outputSchema) {\n    if (outputSchema.key && typeof outputSchema.key[0] === 'string') {\n      outputSchema.key[0] = [outputSchema.key[0]];\n    }\n\n    if (outputSchema.key && outputSchema.key.length) {\n      for (let i = 1; i < outputSchema.key.length; i++) {\n        if (!outputSchema.clustering_order) outputSchema.clustering_order = {};\n        if (!outputSchema.clustering_order[outputSchema.key[i]]) {\n          outputSchema.clustering_order[outputSchema.key[i]] = 'ASC';\n        }\n\n        // eslint-disable-next-line max-len\n        outputSchema.clustering_order[outputSchema.key[i]] = outputSchema.clustering_order[outputSchema.key[i]].toUpperCase();\n      }\n    }\n  },\n\n  normalize_fields(modelSchema, outputSchema) {\n    Object.keys(outputSchema.fields).forEach((fieldName) => {\n      if (typeof (outputSchema.fields[fieldName]) === 'string') {\n        outputSchema.fields[fieldName] = { type: outputSchema.fields[fieldName] };\n      }\n\n      if (fieldName === 'solr_query' || outputSchema.fields[fieldName].virtual) {\n        delete outputSchema.fields[fieldName];\n        return;\n      }\n\n      if (outputSchema.fields[fieldName].typeDef) {\n        outputSchema.fields[fieldName] = {\n          type: outputSchema.fields[fieldName].type,\n          typeDef: outputSchema.fields[fieldName].typeDef,\n        };\n      } else {\n        outputSchema.fields[fieldName] = { type: outputSchema.fields[fieldName].type };\n      }\n\n      if (outputSchema.fields[fieldName].type === 'varchar') {\n        outputSchema.fields[fieldName].type = 'text';\n      }\n\n      if (['map', 'list', 'set', 'frozen'].includes(outputSchema.fields[fieldName].type)) {\n        if (modelSchema.typeMaps && modelSchema.typeMaps[fieldName]) {\n          outputSchema.fields[fieldName].typeDef = normalizeTypeDef(modelSchema.typeMaps[fieldName]);\n        } else {\n          outputSchema.fields[fieldName].typeDef = normalizeTypeDef(outputSchema.fields[fieldName].typeDef);\n        }\n      }\n\n      if (modelSchema.staticMaps && modelSchema.staticMaps[fieldName] === true) {\n        outputSchema.fields[fieldName].static = true;\n      } else if (modelSchema.fields[fieldName].static) {\n        outputSchema.fields[fieldName].static = true;\n      }\n    });\n  },\n\n  normalize_materialized_views(outputSchema) {\n    if (!outputSchema.materialized_views) {\n      outputSchema.materialized_views = {};\n    }\n\n    Object.keys(outputSchema.materialized_views).forEach((materializedViewName) => {\n      const outputMView = outputSchema.materialized_views[materializedViewName];\n      // make parition key an array\n      if (outputMView.key && typeof outputMView.key[0] === 'string') {\n        outputMView.key[0] = [outputMView.key[0]];\n      }\n\n      // add clustering_order for all clustering keys\n      if (outputMView.key && outputMView.key.length) {\n        for (let i = 1; i < outputMView.key.length; i++) {\n          if (!outputMView.clustering_order) {\n            outputMView.clustering_order = {};\n          }\n          if (!outputMView.clustering_order[outputMView.key[i]]) {\n            outputMView.clustering_order[outputMView.key[i]] = 'ASC';\n          }\n          // eslint-disable-next-line max-len\n          outputMView.clustering_order[outputMView.key[i]] = outputMView.clustering_order[outputMView.key[i]].toUpperCase();\n        }\n      }\n\n      // add all non existent primary key items to select and sort them\n      for (let pkeyIndex = 0; pkeyIndex < outputMView.key.length; pkeyIndex++) {\n        if (pkeyIndex === 0) {\n          for (let partitionIndex = 0; partitionIndex < outputMView.key[pkeyIndex].length; partitionIndex++) {\n            if (!outputMView.select.includes(outputMView.key[pkeyIndex][partitionIndex])) {\n              outputMView.select.push(outputMView.key[pkeyIndex][partitionIndex]);\n            }\n          }\n        } else if (!outputMView.select.includes(outputMView.key[pkeyIndex])) {\n          outputMView.select.push(outputMView.key[pkeyIndex]);\n        }\n      }\n\n      // check if select has * and then add all fields to select\n      if (outputMView.select[0] === '*') {\n        outputMView.select = Object.keys(outputSchema.fields);\n      }\n\n      outputMView.select.sort(arraySort);\n\n      if (!outputMView.where_clause) {\n        outputMView.where_clause = parser.get_mview_where_clause(outputSchema, outputMView).trim();\n      }\n      if (_.isPlainObject(outputMView.filters)) {\n        delete outputMView.filters;\n      }\n    });\n  },\n\n  normalize_indexes(outputSchema) {\n    if (!outputSchema.indexes) {\n      outputSchema.indexes = [];\n    }\n    for (let i = 0; i < outputSchema.indexes.length; i++) {\n      const indexNameList = outputSchema.indexes[i].replace(/[\"\\s]/g, '').split(/[()]/g);\n      if (indexNameList.length > 1) {\n        indexNameList[0] = indexNameList[0].toLowerCase();\n        if (indexNameList[0] === 'values') outputSchema.indexes[i] = indexNameList[1];\n        else outputSchema.indexes[i] = util.format('%s(%s)', indexNameList[0], indexNameList[1]);\n      } else {\n        outputSchema.indexes[i] = indexNameList[0];\n      }\n    }\n    outputSchema.indexes.sort(arraySort);\n  },\n\n  normalize_custom_indexes(outputSchema) {\n    if (outputSchema.custom_index) {\n      outputSchema.custom_indexes = [outputSchema.custom_index];\n      delete outputSchema.custom_index;\n    }\n\n    if (outputSchema.custom_indexes) {\n      const customArraySort = (a, b) => {\n        if (a.on > b.on) return 1;\n        if (a.on < b.on) return -1;\n\n        if (a.using > b.using) return 1;\n        if (a.using < b.using) return -1;\n\n        if (a.options > b.options) return 1;\n        if (a.options < b.options) return -1;\n\n        return 0;\n      };\n\n      outputSchema.custom_indexes.sort(customArraySort);\n    } else {\n      outputSchema.custom_indexes = [];\n    }\n\n    outputSchema.custom_indexes = _.remove(outputSchema.custom_indexes, (cindex) => (cindex.on !== 'solr_query'));\n  },\n\n  normalize_model_schema(modelSchema) {\n    const outputSchema = _.cloneDeep(modelSchema, true);\n    const normalizableSchemaProperties = [\n      'fields', 'key', 'clustering_order', 'materialized_views', 'indexes', 'custom_index', 'custom_indexes',\n    ];\n\n    Object.keys(outputSchema).forEach((schemaProperty) => {\n      if (!normalizableSchemaProperties.includes(schemaProperty)) {\n        delete outputSchema[schemaProperty];\n      }\n    });\n\n    this.normalize_fields(modelSchema, outputSchema);\n    this.normalize_primary_key(outputSchema);\n    this.normalize_materialized_views(outputSchema);\n    this.normalize_indexes(outputSchema);\n    this.normalize_custom_indexes(outputSchema);\n\n    return outputSchema;\n  },\n\n  remove_dependent_views_from_normalized_schema(normalizedDBSchema, dbSchema, fieldName) {\n    const dependentViews = [];\n    Object.keys(normalizedDBSchema.materialized_views).forEach((dbViewName) => {\n      if (normalizedDBSchema.materialized_views[dbViewName].select.includes(fieldName)) {\n        dependentViews.push(dbViewName);\n      } else if (normalizedDBSchema.materialized_views[dbViewName].select[0] === '*') {\n        dependentViews.push(dbViewName);\n      } else if (normalizedDBSchema.materialized_views[dbViewName].key.includes(fieldName)) {\n        dependentViews.push(dbViewName);\n      } else if (_.isArray(normalizedDBSchema.materialized_views[dbViewName].key[0])\n                  && normalizedDBSchema.materialized_views[dbViewName].key[0].includes(fieldName)) {\n        dependentViews.push(dbViewName);\n      }\n    });\n    dependentViews.forEach((viewName) => {\n      normalizedDBSchema.materialized_views[viewName] = {};\n    });\n  },\n};\n\nmodule.exports = normalizer;\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/utils/normalizer.js"],"names":["_","require","util","parser","arraySort","a","b","normalizeTypeDef","typeDef","formattedTypeDef","replace","frozenMatch","match","length","slice","normalizer","normalize_replication_option","replicationOptions","normalizedReplicationOptions","Object","keys","forEach","key","parseInt","normalize_query_option","options","queryOptions","prepare","consistency","fetchSize","autoPage","hints","pageState","retry","serialConsistency","customPayload","isIdempotent","readTimeout","retryOnTimeout","routingIndexes","routingKey","routingNames","timestamp","normalize_user_defined_type","fieldType","normalize_primary_key","outputSchema","i","clustering_order","toUpperCase","normalize_fields","modelSchema","fields","fieldName","type","virtual","includes","typeMaps","staticMaps","static","normalize_materialized_views","materialized_views","materializedViewName","outputMView","pkeyIndex","partitionIndex","select","push","sort","where_clause","get_mview_where_clause","trim","isPlainObject","filters","normalize_indexes","indexes","indexNameList","split","toLowerCase","format","normalize_custom_indexes","custom_index","custom_indexes","customArraySort","on","using","remove","cindex","normalize_model_schema","cloneDeep","normalizableSchemaProperties","schemaProperty","remove_dependent_views_from_normalized_schema","normalizedDBSchema","dbSchema","dependentViews","dbViewName","isArray","viewName","module","exports"],"mappings":"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","file":"normalizer.js","sourcesContent":["const _ = require('lodash');\nconst util = require('util');\n\nconst parser = require('./parser');\n\nconst arraySort = (a, b) => {\n  if (a > b) return 1;\n  if (a < b) return -1;\n  return 0;\n};\n\nconst normalizeTypeDef = (typeDef) => {\n  const formattedTypeDef = typeDef.replace(/[\\s]/g, '').replace(/varchar/g, 'text').replace(/frozen/ig, 'frozen');\n  const frozenMatch = formattedTypeDef.match(/frozen</g);\n  if (frozenMatch && frozenMatch.length) return formattedTypeDef.replace(/frozen</g, '').slice(0, -1 * frozenMatch.length);\n  return formattedTypeDef;\n};\n\nconst normalizer = {\n  normalize_replication_option(replicationOptions) {\n    const normalizedReplicationOptions = replicationOptions;\n    Object.keys(normalizedReplicationOptions).forEach((key) => {\n      if (key === 'class') {\n        normalizedReplicationOptions[key] = normalizedReplicationOptions[key].replace('org.apache.cassandra.locator.', '');\n        return;\n      }\n      normalizedReplicationOptions[key] = parseInt(normalizedReplicationOptions[key], 10);\n    });\n    return normalizedReplicationOptions;\n  },\n\n  normalize_query_option(options) {\n    const queryOptions = { prepare: options.prepare };\n    if (options.consistency) queryOptions.consistency = options.consistency;\n    if (options.fetchSize) queryOptions.fetchSize = options.fetchSize;\n    if (options.autoPage) queryOptions.autoPage = options.autoPage;\n    if (options.hints) queryOptions.hints = options.hints;\n    if (options.pageState) queryOptions.pageState = options.pageState;\n    if (options.retry) queryOptions.retry = options.retry;\n    if (options.serialConsistency) queryOptions.serialConsistency = options.serialConsistency;\n    if (options.customPayload) queryOptions.customPayload = options.customPayload;\n    if (options.isIdempotent) queryOptions.isIdempotent = options.isIdempotent;\n    if (options.readTimeout) queryOptions.readTimeout = options.readTimeout;\n    if (options.retry) queryOptions.retry = options.retry;\n    if (options.retryOnTimeout) queryOptions.retryOnTimeout = options.retryOnTimeout;\n    if (options.routingIndexes) queryOptions.routingIndexes = options.routingIndexes;\n    if (options.routingKey) queryOptions.routingKey = options.routingKey;\n    if (options.routingNames) queryOptions.routingNames = options.routingNames;\n    if (options.timestamp) queryOptions.timestamp = options.timestamp;\n    return queryOptions;\n  },\n\n  normalize_user_defined_type(fieldType) {\n    return normalizeTypeDef(fieldType);\n  },\n\n  normalize_primary_key(outputSchema) {\n    if (outputSchema.key && typeof outputSchema.key[0] === 'string') {\n      outputSchema.key[0] = [outputSchema.key[0]];\n    }\n\n    if (outputSchema.key && outputSchema.key.length) {\n      for (let i = 1; i < outputSchema.key.length; i++) {\n        if (!outputSchema.clustering_order) outputSchema.clustering_order = {};\n        if (!outputSchema.clustering_order[outputSchema.key[i]]) {\n          outputSchema.clustering_order[outputSchema.key[i]] = 'ASC';\n        }\n\n        // eslint-disable-next-line max-len\n        outputSchema.clustering_order[outputSchema.key[i]] = outputSchema.clustering_order[outputSchema.key[i]].toUpperCase();\n      }\n    }\n  },\n\n  normalize_fields(modelSchema, outputSchema) {\n    Object.keys(outputSchema.fields).forEach((fieldName) => {\n      if (typeof (outputSchema.fields[fieldName]) === 'string') {\n        outputSchema.fields[fieldName] = { type: outputSchema.fields[fieldName] };\n      }\n\n      if (fieldName === 'solr_query' || outputSchema.fields[fieldName].virtual) {\n        delete outputSchema.fields[fieldName];\n        return;\n      }\n\n      if (outputSchema.fields[fieldName].typeDef) {\n        outputSchema.fields[fieldName] = {\n          type: outputSchema.fields[fieldName].type,\n          typeDef: outputSchema.fields[fieldName].typeDef,\n        };\n      } else {\n        outputSchema.fields[fieldName] = { type: outputSchema.fields[fieldName].type };\n      }\n\n      if (outputSchema.fields[fieldName].type === 'varchar') {\n        outputSchema.fields[fieldName].type = 'text';\n      }\n\n      if (['map', 'list', 'set', 'frozen'].includes(outputSchema.fields[fieldName].type)) {\n        if (modelSchema.typeMaps && modelSchema.typeMaps[fieldName]) {\n          outputSchema.fields[fieldName].typeDef = normalizeTypeDef(modelSchema.typeMaps[fieldName]);\n        } else {\n          outputSchema.fields[fieldName].typeDef = normalizeTypeDef(outputSchema.fields[fieldName].typeDef);\n        }\n      }\n\n      if (modelSchema.staticMaps && modelSchema.staticMaps[fieldName] === true) {\n        outputSchema.fields[fieldName].static = true;\n      } else if (modelSchema.fields[fieldName].static) {\n        outputSchema.fields[fieldName].static = true;\n      }\n    });\n  },\n\n  normalize_materialized_views(outputSchema) {\n    if (!outputSchema.materialized_views) {\n      outputSchema.materialized_views = {};\n    }\n\n    Object.keys(outputSchema.materialized_views).forEach((materializedViewName) => {\n      const outputMView = outputSchema.materialized_views[materializedViewName];\n      // make parition key an array\n      if (outputMView.key && typeof outputMView.key[0] === 'string') {\n        outputMView.key[0] = [outputMView.key[0]];\n      }\n\n      // add clustering_order for all clustering keys\n      if (outputMView.key && outputMView.key.length) {\n        for (let i = 1; i < outputMView.key.length; i++) {\n          if (!outputMView.clustering_order) {\n            outputMView.clustering_order = {};\n          }\n          if (!outputMView.clustering_order[outputMView.key[i]]) {\n            outputMView.clustering_order[outputMView.key[i]] = 'ASC';\n          }\n          // eslint-disable-next-line max-len\n          outputMView.clustering_order[outputMView.key[i]] = outputMView.clustering_order[outputMView.key[i]].toUpperCase();\n        }\n      }\n\n      // add all non existent primary key items to select and sort them\n      for (let pkeyIndex = 0; pkeyIndex < outputMView.key.length; pkeyIndex++) {\n        if (pkeyIndex === 0) {\n          for (let partitionIndex = 0; partitionIndex < outputMView.key[pkeyIndex].length; partitionIndex++) {\n            if (!outputMView.select.includes(outputMView.key[pkeyIndex][partitionIndex])) {\n              outputMView.select.push(outputMView.key[pkeyIndex][partitionIndex]);\n            }\n          }\n        } else if (!outputMView.select.includes(outputMView.key[pkeyIndex])) {\n          outputMView.select.push(outputMView.key[pkeyIndex]);\n        }\n      }\n\n      // check if select has * and then add all fields to select\n      if (outputMView.select[0] === '*') {\n        outputMView.select = Object.keys(outputSchema.fields);\n      }\n\n      outputMView.select.sort(arraySort);\n\n      if (!outputMView.where_clause) {\n        outputMView.where_clause = parser.get_mview_where_clause(outputSchema, outputMView).trim();\n      } else {\n        // some versions of cassandra/scylla return IS NOT null instead of IS NOT NULL\n        outputMView.where_clause = outputMView.where_clause.replace(/IS NOT null/g, 'IS NOT NULL');\n      }\n      if (_.isPlainObject(outputMView.filters)) {\n        delete outputMView.filters;\n      }\n    });\n  },\n\n  normalize_indexes(outputSchema) {\n    if (!outputSchema.indexes) {\n      outputSchema.indexes = [];\n    }\n    for (let i = 0; i < outputSchema.indexes.length; i++) {\n      const indexNameList = outputSchema.indexes[i].replace(/[\"\\s]/g, '').split(/[()]/g);\n      if (indexNameList.length > 1) {\n        indexNameList[0] = indexNameList[0].toLowerCase();\n        if (indexNameList[0] === 'values') outputSchema.indexes[i] = indexNameList[1];\n        else outputSchema.indexes[i] = util.format('%s(%s)', indexNameList[0], indexNameList[1]);\n      } else {\n        outputSchema.indexes[i] = indexNameList[0];\n      }\n    }\n    outputSchema.indexes.sort(arraySort);\n  },\n\n  normalize_custom_indexes(outputSchema) {\n    if (outputSchema.custom_index) {\n      outputSchema.custom_indexes = [outputSchema.custom_index];\n      delete outputSchema.custom_index;\n    }\n\n    if (outputSchema.custom_indexes) {\n      const customArraySort = (a, b) => {\n        if (a.on > b.on) return 1;\n        if (a.on < b.on) return -1;\n\n        if (a.using > b.using) return 1;\n        if (a.using < b.using) return -1;\n\n        if (a.options > b.options) return 1;\n        if (a.options < b.options) return -1;\n\n        return 0;\n      };\n\n      outputSchema.custom_indexes.sort(customArraySort);\n    } else {\n      outputSchema.custom_indexes = [];\n    }\n\n    outputSchema.custom_indexes = _.remove(outputSchema.custom_indexes, (cindex) => (cindex.on !== 'solr_query'));\n  },\n\n  normalize_model_schema(modelSchema) {\n    const outputSchema = _.cloneDeep(modelSchema, true);\n    const normalizableSchemaProperties = [\n      'fields', 'key', 'clustering_order', 'materialized_views', 'indexes', 'custom_index', 'custom_indexes',\n    ];\n\n    Object.keys(outputSchema).forEach((schemaProperty) => {\n      if (!normalizableSchemaProperties.includes(schemaProperty)) {\n        delete outputSchema[schemaProperty];\n      }\n    });\n\n    this.normalize_fields(modelSchema, outputSchema);\n    this.normalize_primary_key(outputSchema);\n    this.normalize_materialized_views(outputSchema);\n    this.normalize_indexes(outputSchema);\n    this.normalize_custom_indexes(outputSchema);\n\n    return outputSchema;\n  },\n\n  remove_dependent_views_from_normalized_schema(normalizedDBSchema, dbSchema, fieldName) {\n    const dependentViews = [];\n    Object.keys(normalizedDBSchema.materialized_views).forEach((dbViewName) => {\n      if (normalizedDBSchema.materialized_views[dbViewName].select.includes(fieldName)) {\n        dependentViews.push(dbViewName);\n      } else if (normalizedDBSchema.materialized_views[dbViewName].select[0] === '*') {\n        dependentViews.push(dbViewName);\n      } else if (normalizedDBSchema.materialized_views[dbViewName].key.includes(fieldName)) {\n        dependentViews.push(dbViewName);\n      } else if (_.isArray(normalizedDBSchema.materialized_views[dbViewName].key[0])\n                  && normalizedDBSchema.materialized_views[dbViewName].key[0].includes(fieldName)) {\n        dependentViews.push(dbViewName);\n      }\n    });\n    dependentViews.forEach((viewName) => {\n      normalizedDBSchema.materialized_views[viewName] = {};\n    });\n  },\n};\n\nmodule.exports = normalizer;\n"]}

@@ -110,2 +110,2 @@ 'use strict';

module.exports = TYPE_MAP;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/validators/datatypes.js"],"names":["Promise","require","util","check","dseDriver","e","cql","promisifyAll","validators","is_array","obj","array","is_object","object","is_long","types","Long","is_decimal","BigDecimal","is_integer","integer","is_var_int","Integer","is_boolean","is_number","number","is_string","string","is_local_date","LocalDate","is_local_time","LocalTime","is_date","date","Date","is_buffer","Buffer","is_timeuuid","TimeUuid","is_uuid","Uuid","is_inet","InetAddress","is_frozen","TYPE_MAP","ascii","validator","bigint","blob","boolean","counter","decimal","double","float","inet","int","list","map","set","smallint","text","time","timestamp","timeuuid","tinyint","uuid","varchar","varint","frozen","generic_type_validator","f","fieldtype","message","value","propName","fieldType","format","type","module","exports"],"mappings":"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","file":"datatypes.js","sourcesContent":["const Promise = require('bluebird');\nconst util = require('util');\nconst check = require('check-types');\n\nlet dseDriver;\ntry {\n  // eslint-disable-next-line import/no-extraneous-dependencies, import/no-unresolved\n  dseDriver = require('dse-driver');\n} catch (e) {\n  dseDriver = null;\n}\n\nconst cql = Promise.promisifyAll(dseDriver || require('cassandra-driver'));\n\nconst validators = {};\nvalidators.is_array = (obj) => (check.array(obj));\nvalidators.is_object = (obj) => (check.object(obj));\nvalidators.is_long = (obj) => ((obj instanceof cql.types.Long));\nvalidators.is_decimal = (obj) => ((obj instanceof cql.types.BigDecimal));\nvalidators.is_integer = (obj) => (check.integer(obj));\nvalidators.is_var_int = (obj) => ((obj instanceof cql.types.Integer));\nvalidators.is_boolean = (obj) => ((obj === true || obj === false));\nvalidators.is_number = (obj) => (check.number(obj));\nvalidators.is_string = (obj) => (check.string(obj));\nvalidators.is_local_date = (obj) => ((obj instanceof cql.types.LocalDate));\nvalidators.is_local_time = (obj) => ((obj instanceof cql.types.LocalTime));\nvalidators.is_date = (obj) => (check.date(new Date(obj)));\nvalidators.is_buffer = (obj) => ((obj instanceof Buffer));\nvalidators.is_timeuuid = (obj) => ((obj instanceof cql.types.TimeUuid));\nvalidators.is_uuid = (obj) => ((obj instanceof cql.types.Uuid));\nvalidators.is_inet = (obj) => ((obj instanceof cql.types.InetAddress));\nvalidators.is_frozen = (obj) => ((validators.is_array(obj) || validators.is_object(obj)));\n\nconst TYPE_MAP = {\n  ascii: { validator: validators.is_string },\n  bigint: { validator: validators.is_long },\n  blob: { validator: validators.is_buffer },\n  boolean: { validator: validators.is_boolean },\n  counter: { validator: validators.is_long },\n  date: { validator: validators.is_local_date },\n  decimal: { validator: validators.is_decimal },\n  double: { validator: validators.is_number },\n  float: { validator: validators.is_number },\n  inet: { validator: validators.is_inet },\n  int: { validator: validators.is_integer },\n  list: { validator: validators.is_array },\n  map: { validator: validators.is_object },\n  set: { validator: validators.is_array },\n  smallint: { validator: validators.is_integer },\n  text: { validator: validators.is_string },\n  time: { validator: validators.is_local_time },\n  timestamp: { validator: validators.is_date },\n  timeuuid: { validator: validators.is_timeuuid },\n  tinyint: { validator: validators.is_integer },\n  uuid: { validator: validators.is_uuid },\n  varchar: { validator: validators.is_string },\n  varint: { validator: validators.is_var_int },\n  frozen: { validator: validators.is_frozen },\n};\n\n\nTYPE_MAP.generic_type_validator = function f(fieldtype) {\n  if (!this[fieldtype]) return null;\n\n  return {\n    validator: this[fieldtype].validator,\n    message(value, propName, fieldType) {\n      return util.format('Invalid Value: \"%s\" for Field: %s (Type: %s)', value, propName, fieldType);\n    },\n    type: 'type_validator',\n  };\n};\n\nmodule.exports = TYPE_MAP;\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/validators/datatypes.js"],"names":["Promise","require","util","check","dseDriver","e","cql","promisifyAll","validators","is_array","obj","array","is_object","object","is_long","types","Long","is_decimal","BigDecimal","is_integer","integer","is_var_int","Integer","is_boolean","is_number","number","is_string","string","is_local_date","LocalDate","is_local_time","LocalTime","is_date","date","Date","is_buffer","Buffer","is_timeuuid","TimeUuid","is_uuid","Uuid","is_inet","InetAddress","is_frozen","TYPE_MAP","ascii","validator","bigint","blob","boolean","counter","decimal","double","float","inet","int","list","map","set","smallint","text","time","timestamp","timeuuid","tinyint","uuid","varchar","varint","frozen","generic_type_validator","f","fieldtype","message","value","propName","fieldType","format","type","module","exports"],"mappings":"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","file":"datatypes.js","sourcesContent":["const Promise = require('bluebird');\nconst util = require('util');\nconst check = require('check-types');\n\nlet dseDriver;\ntry {\n  // eslint-disable-next-line import/no-extraneous-dependencies, import/no-unresolved\n  dseDriver = require('dse-driver');\n} catch (e) {\n  dseDriver = null;\n}\n\nconst cql = Promise.promisifyAll(dseDriver || require('cassandra-driver'));\n\nconst validators = {};\nvalidators.is_array = (obj) => (check.array(obj));\nvalidators.is_object = (obj) => (check.object(obj));\nvalidators.is_long = (obj) => ((obj instanceof cql.types.Long));\nvalidators.is_decimal = (obj) => ((obj instanceof cql.types.BigDecimal));\nvalidators.is_integer = (obj) => (check.integer(obj));\nvalidators.is_var_int = (obj) => ((obj instanceof cql.types.Integer));\nvalidators.is_boolean = (obj) => ((obj === true || obj === false));\nvalidators.is_number = (obj) => (check.number(obj));\nvalidators.is_string = (obj) => (check.string(obj));\nvalidators.is_local_date = (obj) => ((obj instanceof cql.types.LocalDate));\nvalidators.is_local_time = (obj) => ((obj instanceof cql.types.LocalTime));\nvalidators.is_date = (obj) => (check.date(new Date(obj)));\nvalidators.is_buffer = (obj) => ((obj instanceof Buffer));\nvalidators.is_timeuuid = (obj) => ((obj instanceof cql.types.TimeUuid));\nvalidators.is_uuid = (obj) => ((obj instanceof cql.types.Uuid));\nvalidators.is_inet = (obj) => ((obj instanceof cql.types.InetAddress));\nvalidators.is_frozen = (obj) => ((validators.is_array(obj) || validators.is_object(obj)));\n\nconst TYPE_MAP = {\n  ascii: { validator: validators.is_string },\n  bigint: { validator: validators.is_long },\n  blob: { validator: validators.is_buffer },\n  boolean: { validator: validators.is_boolean },\n  counter: { validator: validators.is_long },\n  date: { validator: validators.is_local_date },\n  decimal: { validator: validators.is_decimal },\n  double: { validator: validators.is_number },\n  float: { validator: validators.is_number },\n  inet: { validator: validators.is_inet },\n  int: { validator: validators.is_integer },\n  list: { validator: validators.is_array },\n  map: { validator: validators.is_object },\n  set: { validator: validators.is_array },\n  smallint: { validator: validators.is_integer },\n  text: { validator: validators.is_string },\n  time: { validator: validators.is_local_time },\n  timestamp: { validator: validators.is_date },\n  timeuuid: { validator: validators.is_timeuuid },\n  tinyint: { validator: validators.is_integer },\n  uuid: { validator: validators.is_uuid },\n  varchar: { validator: validators.is_string },\n  varint: { validator: validators.is_var_int },\n  frozen: { validator: validators.is_frozen },\n};\n\nTYPE_MAP.generic_type_validator = function f(fieldtype) {\n  if (!this[fieldtype]) return null;\n\n  return {\n    validator: this[fieldtype].validator,\n    message(value, propName, fieldType) {\n      return util.format('Invalid Value: \"%s\" for Field: %s (Type: %s)', value, propName, fieldType);\n    },\n    type: 'type_validator',\n  };\n};\n\nmodule.exports = TYPE_MAP;\n"]}

@@ -401,2 +401,2 @@ 'use strict';

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","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","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","type_validation","Array","fieldrule","type","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', fieldtype, fieldName)));\n    }\n    if (['map', 'list', 'set', 'frozen'].includes(fieldtype)) {\n      if (!fieldObject.typeDef) {\n        throw (new Error(util.format('Missing typeDef for field type \"%s\" on field: %s', fieldtype, fieldName)));\n      }\n      if (typeof fieldObject.typeDef !== 'string') {\n        throw (new Error(util.format('Invalid typeDef for field type \"%s\" on field: %s', fieldtype, fieldName)));\n      }\n    }\n    if (!(this.is_field_default_value_valid(modelSchema, fieldName))) {\n      throw (new Error(util.format('Invalid default value for field: %s(%s)', fieldName, fieldtype)));\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    const field = modelSchema.fields[fieldname];\n\n    if (typeFieldValidator) {\n      if (!(field.rule && field.rule.type_validation === false)) {\n        validators.push(typeFieldValidator);\n      }\n    }\n\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(`Type of field \"${fieldName}\" 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)) {\n      return true;\n    }\n    if (modelSchema.key[0] instanceof Array && 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","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","type_validation","Array","fieldrule","type","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,YAAUC,WAAV,EAAuBC,SAAvB,EAAkC;AAChC,QAAMC,mBAAmB,EAAzB;AACA,QAAIF,YAAYG,OAAhB,EAAyB;AACvB,UAAIH,YAAYG,OAAZ,CAAoBC,UAAxB,EAAoC;AAClC,YAAMC,mBAAmB;AACvBC,qBAAWN,YAAYG,OAAZ,CAAoBC,UAApB,CAA+BE,SAA/B,IAA4C,WADhC;AAEvBC,qBAAWP,YAAYG,OAAZ,CAAoBC,UAApB,CAA+BG,SAA/B,IAA4C;AAFhC,SAAzB;AAIAL,yBAAiBM,IAAjB,CAAsBH,iBAAiBC,SAAvC;AACAJ,yBAAiBM,IAAjB,CAAsBH,iBAAiBE,SAAvC;AACD;;AAED,UAAIP,YAAYG,OAAZ,CAAoBM,QAAxB,EAAkC;AAChC,YAAMC,iBAAiB;AACrBC,eAAKX,YAAYG,OAAZ,CAAoBM,QAApB,CAA6BE,GAA7B,IAAoC;AADpB,SAAvB;AAGAT,yBAAiBM,IAAjB,CAAsBE,eAAeC,GAArC;AACD;AACF;AACD,WAAOpB,EAAEqB,GAAF,CAAMZ,YAAYa,MAAlB,EAA0BZ,SAA1B,KAAwCC,iBAAiBY,QAAjB,CAA0Bb,SAA1B,CAA/C;AACD,GAxBa;AAyBdc,iBAAef,WAAf,EAA4BgB,WAA5B,EAAyCf,SAAzC,EAAoD;AAClD,QAAI,CAACe,WAAL,EAAkB;AAChB,YAAO,IAAIC,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,2CAAZ,EAAyDjB,SAAzD,CAAV,CAAP;AACD;AACD,QAAMkB,YAAY,KAAKC,cAAL,CAAoBpB,WAApB,EAAiCC,SAAjC,CAAlB;AACA,QAAI,CAACV,EAAEqB,GAAF,CAAMlB,SAAN,EAAiByB,SAAjB,CAAL,EAAkC;AAChC,YAAO,IAAIF,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,uCAAZ,EAAqDC,SAArD,EAAgElB,SAAhE,CAAV,CAAP;AACD;AACD,QAAI,CAAC,KAAD,EAAQ,MAAR,EAAgB,KAAhB,EAAuB,QAAvB,EAAiCa,QAAjC,CAA0CK,SAA1C,CAAJ,EAA0D;AACxD,UAAI,CAACH,YAAYK,OAAjB,EAA0B;AACxB,cAAO,IAAIJ,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,kDAAZ,EAAgEC,SAAhE,EAA2ElB,SAA3E,CAAV,CAAP;AACD;AACD,UAAI,OAAOe,YAAYK,OAAnB,KAA+B,QAAnC,EAA6C;AAC3C,cAAO,IAAIJ,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,kDAAZ,EAAgEC,SAAhE,EAA2ElB,SAA3E,CAAV,CAAP;AACD;AACF;AACD,QAAI,CAAE,KAAKqB,4BAAL,CAAkCtB,WAAlC,EAA+CC,SAA/C,CAAN,EAAkE;AAChE,YAAO,IAAIgB,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,yCAAZ,EAAuDjB,SAAvD,EAAkEkB,SAAlE,CAAV,CAAP;AACD;AACF,GA5Ca;;AA8CdI,uBAAqBvB,WAArB,EAAkC;AAAA;;AAChC,QAAI,OAAQA,YAAYW,GAAZ,CAAgB,CAAhB,CAAR,KAAgC,QAApC,EAA8C;AAC5C,UAAI,CAAC,KAAKZ,SAAL,CAAeC,WAAf,EAA4BA,YAAYW,GAAZ,CAAgB,CAAhB,CAA5B,CAAL,EAAsD;AACpD,cAAO,IAAIM,KAAJ,CAAU,+CAAV,CAAP;AACD;AACD,UAAIjB,YAAYa,MAAZ,CAAmBb,YAAYW,GAAZ,CAAgB,CAAhB,CAAnB,KAA0CX,YAAYa,MAAZ,CAAmBb,YAAYW,GAAZ,CAAgB,CAAhB,CAAnB,EAAuCa,OAArF,EAA8F;AAC5F,cAAO,IAAIP,KAAJ,CAAU,2EAAV,CAAP;AACD;AACF,KAPD,MAOO,IAAI1B,EAAEkC,OAAF,CAAUzB,YAAYW,GAAZ,CAAgB,CAAhB,CAAV,CAAJ,EAAmC;AACxC,UAAIX,YAAYW,GAAZ,CAAgB,CAAhB,EAAmBe,MAAnB,KAA8B,CAAlC,EAAqC;AACnC,cAAO,IAAIT,KAAJ,CAAU,oCAAV,CAAP;AACD;AACDjB,kBAAYW,GAAZ,CAAgB,CAAhB,EAAmBgB,OAAnB,CAA2B,UAACC,iBAAD,EAAuB;AAChD,YAAK,OAAQA,iBAAR,KAA+B,QAAhC,IAA6C,CAAC,MAAK7B,SAAL,CAAeC,WAAf,EAA4B4B,iBAA5B,CAAlD,EAAkG;AAChG,gBAAO,IAAIX,KAAJ,CAAU,yDAAV,CAAP;AACD;AACD,YAAIjB,YAAYa,MAAZ,CAAmBe,iBAAnB,KAAyC5B,YAAYa,MAAZ,CAAmBe,iBAAnB,EAAsCJ,OAAnF,EAA4F;AAC1F,gBAAO,IAAIP,KAAJ,CAAU,yFAAV,CAAP;AACD;AACF,OAPD;AAQD,KAZM,MAYA;AACL,YAAO,IAAIA,KAAJ,CAAU,oEAAV,CAAP;AACD;;AAEDjB,gBAAYW,GAAZ,CAAgBgB,OAAhB,CAAwB,UAACE,eAAD,EAAkBC,eAAlB,EAAsC;AAC5D,UAAIA,kBAAkB,CAAtB,EAAyB;AACvB,YAAK,OAAQD,eAAR,KAA6B,QAA9B,IAA2C,CAAC,MAAK9B,SAAL,CAAeC,WAAf,EAA4B6B,eAA5B,CAAhD,EAA8F;AAC5F,gBAAO,IAAIZ,KAAJ,CAAU,2CAAV,CAAP;AACD;AACD,YAAIjB,YAAYa,MAAZ,CAAmBgB,eAAnB,KAAuC7B,YAAYa,MAAZ,CAAmBgB,eAAnB,EAAoCL,OAA/E,EAAwF;AACtF,gBAAO,IAAIP,KAAJ,CAAU,sEAAV,CAAP;AACD;AACF;AACF,KATD;;AAWA,QAAIjB,YAAY+B,gBAAhB,EAAkC;AAChC,UAAI,CAACxC,EAAEyC,aAAF,CAAgBhC,YAAY+B,gBAA5B,CAAL,EAAoD;AAClD,cAAO,IAAId,KAAJ,CAAU,iEAAV,CAAP;AACD;;AAED1B,QAAEoC,OAAF,CAAU3B,YAAY+B,gBAAtB,EAAwC,UAACE,eAAD,EAAkBC,mBAAlB,EAA0C;AAChF,YAAI,CAAC,CAAC,KAAD,EAAQ,MAAR,EAAgBpB,QAAhB,CAAyBmB,gBAAgBE,WAAhB,EAAzB,CAAL,EAA8D;AAC5D,gBAAO,IAAIlB,KAAJ,CAAU,2DAAV,CAAP;AACD;AACD,YAAIjB,YAAYW,GAAZ,CAAgByB,OAAhB,CAAwBF,mBAAxB,IAA+C,CAAnD,EAAsD;AACpD,gBAAO,IAAIjB,KAAJ,CAAU,gEAAV,CAAP;AACD;AACF,OAPD;AAQD;AACF,GA/Fa;;AAiGdoB,6BAA2BrC,WAA3B,EAAwCsC,sBAAxC,EAAgEC,oBAAhE,EAAsF;AAAA;;AACpF,QAAI,CAAChD,EAAEyC,aAAF,CAAgBM,sBAAhB,CAAL,EAA8C;AAC5C,YAAO,IAAIrB,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,2DAAZ,EAAyEqB,oBAAzE,CAAV,CAAP;AACD;;AAED,QAAI,CAACD,uBAAuBE,MAAxB,IAAkC,CAACF,uBAAuB3B,GAA9D,EAAmE;AACjE,YAAO,IAAIM,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,gEAAZ,EAA8EqB,oBAA9E,CAAV,CAAP;AACD;;AAED,QAAI,CAAChD,EAAEkC,OAAF,CAAUa,uBAAuBE,MAAjC,CAAD,IAA6C,CAACjD,EAAEkC,OAAF,CAAUa,uBAAuB3B,GAAjC,CAAlD,EAAyF;AACvF,YAAO,IAAIM,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,yFAAZ,EAAuGqB,oBAAvG,CAAV,CAAP;AACD;;AAEDD,2BAAuBE,MAAvB,CAA8Bb,OAA9B,CAAsC,UAACc,2BAAD,EAAiC;AACrE,UAAK,OAAQA,2BAAR,KAAyC,QAA1C,IACK,EAAE,OAAK1C,SAAL,CAAeC,WAAf,EAA4ByC,2BAA5B,KACFA,gCAAgC,GADhC,CADT,EAE+C;AAC7C,cAAO,IAAIxB,KAAJ,CAAUxB,KAAKyB,MAAL,CACf,iGADe,EAEfqB,oBAFe,CAAV,CAAP;AAID;;AAED,UAAIvC,YAAYa,MAAZ,CAAmB4B,2BAAnB,KACGzC,YAAYa,MAAZ,CAAmB4B,2BAAnB,EAAgDjB,OADvD,EACgE;AAC9D,cAAO,IAAIP,KAAJ,CAAUxB,KAAKyB,MAAL,CACf,6FACE,uCAFa,EAGfqB,oBAHe,CAAV,CAAP;AAKD;AACF,KAlBD;;AAoBA;AACA,QAAI,OAAQD,uBAAuB3B,GAAvB,CAA2B,CAA3B,CAAR,KAA2C,QAA/C,EAAyD;AACvD,UAAI,CAAC,KAAKZ,SAAL,CAAeC,WAAf,EAA4BsC,uBAAuB3B,GAAvB,CAA2B,CAA3B,CAA5B,CAAL,EAAiE;AAC/D,cAAO,IAAIM,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,0EAAZ,EAAwFqB,oBAAxF,CAAV,CAAP;AACD;AACD,UAAIvC,YAAYa,MAAZ,CAAmByB,uBAAuB3B,GAAvB,CAA2B,CAA3B,CAAnB,KACCX,YAAYa,MAAZ,CAAmByB,uBAAuB3B,GAAvB,CAA2B,CAA3B,CAAnB,EAAkDa,OADvD,EACgE;AAC9D,cAAO,IAAIP,KAAJ,CAAUxB,KAAKyB,MAAL,CACf,gGADe,EAEfqB,oBAFe,CAAV,CAAP;AAID;AACF,KAXD,MAWO,IAAIhD,EAAEkC,OAAF,CAAUa,uBAAuB3B,GAAvB,CAA2B,CAA3B,CAAV,CAAJ,EAA8C;AACnD,UAAI2B,uBAAuB3B,GAAvB,CAA2B,CAA3B,EAA8Be,MAA9B,KAAyC,CAA7C,EAAgD;AAC9C,cAAO,IAAIT,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,2DAAZ,EAAyEqB,oBAAzE,CAAV,CAAP;AACD;AACDD,6BAAuB3B,GAAvB,CAA2B,CAA3B,EAA8BgB,OAA9B,CAAsC,UAACe,iCAAD,EAAuC;AAC3E,YAAK,OAAQA,iCAAR,KAA+C,QAAhD,IACG,CAAC,OAAK3C,SAAL,CAAeC,WAAf,EAA4B0C,iCAA5B,CADR,EACwE;AACtE,gBAAO,IAAIzB,KAAJ,CAAUxB,KAAKyB,MAAL,CACf,+EADe,EAEfqB,oBAFe,CAAV,CAAP;AAID;AACD,YAAIvC,YAAYa,MAAZ,CAAmB6B,iCAAnB,KACC1C,YAAYa,MAAZ,CAAmB6B,iCAAnB,EAAsDlB,OAD3D,EACoE;AAClE,gBAAO,IAAIP,KAAJ,CAAUxB,KAAKyB,MAAL,CACf,iFACE,oCAFa,EAGfqB,oBAHe,CAAV,CAAP;AAKD;AACF,OAhBD;AAiBD,KArBM,MAqBA;AACL,YAAO,IAAItB,KAAJ,CAAUxB,KAAKyB,MAAL,CACf,0FADe,EAEfqB,oBAFe,CAAV,CAAP;AAID;;AAEDD,2BAAuB3B,GAAvB,CAA2BgB,OAA3B,CAAmC,UAACgB,+BAAD,EAAkCC,+BAAlC,EAAsE;AACvG,UAAIA,kCAAkC,CAAtC,EAAyC;AACvC,YAAK,OAAQD,+BAAR,KAA6C,QAA9C,IACG,CAAC,OAAK5C,SAAL,CAAeC,WAAf,EAA4B2C,+BAA5B,CADR,EACsE;AACpE,gBAAO,IAAI1B,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,iEAAZ,EAA+EqB,oBAA/E,CAAV,CAAP;AACD;AACD,YAAIvC,YAAYa,MAAZ,CAAmB8B,+BAAnB,KACC3C,YAAYa,MAAZ,CAAmB8B,+BAAnB,EAAoDnB,OADzD,EACkE;AAChE,gBAAO,IAAIP,KAAJ,CAAUxB,KAAKyB,MAAL,CACf,6FADe,EAEfqB,oBAFe,CAAV,CAAP;AAID;AACF;AACF,KAdD;;AAgBA,QAAID,uBAAuBP,gBAA3B,EAA6C;AAC3C,UAAI,CAACxC,EAAEyC,aAAF,CAAgBM,uBAAuBP,gBAAvC,CAAL,EAA+D;AAC7D,cAAO,IAAId,KAAJ,CAAUxB,KAAKyB,MAAL,CACf,uFADe,EAEfqB,oBAFe,CAAV,CAAP;AAID;;AAEDhD,QAAEoC,OAAF,CAAUW,uBAAuBP,gBAAjC,EAAmD,UAACc,iBAAD,EAAoBC,oBAApB,EAA6C;AAC9F,YAAI,CAAC,CAAC,KAAD,EAAQ,MAAR,EAAgBhC,QAAhB,CAAyB+B,kBAAkBV,WAAlB,EAAzB,CAAL,EAAgE;AAC9D,gBAAO,IAAIlB,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,iFAAZ,EAA+FqB,oBAA/F,CAAV,CAAP;AACD;AACD,YAAID,uBAAuB3B,GAAvB,CAA2ByB,OAA3B,CAAmCU,oBAAnC,IAA2D,CAA/D,EAAkE;AAChE,gBAAO,IAAI7B,KAAJ,CAAUxB,KAAKyB,MAAL,CACf,sFADe,EAEfqB,oBAFe,CAAV,CAAP;AAID;AACF,OAVD;AAWD;AACF,GA9Ma;;AAgNdQ,iBAAe/C,WAAf,EAA4BgD,QAA5B,EAAsC;AACpC,QAAI,OAAOA,QAAP,KAAoB,QAAxB,EAAkC;AAChC,YAAO,IAAI/B,KAAJ,CAAU,qCAAV,CAAP;AACD;;AAED,QAAMgC,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,EAAsCrB,QAAtC,CAA+CmC,cAAc,CAAd,CAA/C,CAAL,EAAuE;AACrE,cAAO,IAAIhC,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,oCAAZ,EAAkD8B,QAAlD,CAAV,CAAP;AACD;AACD,UAAI,CAAC,KAAKjD,SAAL,CAAeC,WAAf,EAA4BiD,cAAc,CAAd,CAA5B,CAAL,EAAoD;AAClD,cAAO,IAAIhC,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,wEAAZ,EAAsF+B,cAAc,CAAd,CAAtF,CAAV,CAAP;AACD;AACD,UAAIjD,YAAYa,MAAZ,CAAmBoC,cAAc,CAAd,CAAnB,KAAwCjD,YAAYa,MAAZ,CAAmBoC,cAAc,CAAd,CAAnB,EAAqCzB,OAAjF,EAA0F;AACxF,cAAO,IAAIP,KAAJ,CAAU,0EAAV,CAAP;AACD;AACF,KAXD,MAWO;AACL,UAAI,CAAC,KAAKlB,SAAL,CAAeC,WAAf,EAA4BiD,cAAc,CAAd,CAA5B,CAAL,EAAoD;AAClD,cAAO,IAAIhC,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,mEAAZ,EAAiF+B,cAAc,CAAd,CAAjF,CAAV,CAAP;AACD;AACD,UAAIjD,YAAYa,MAAZ,CAAmBoC,cAAc,CAAd,CAAnB,KAAwCjD,YAAYa,MAAZ,CAAmBoC,cAAc,CAAd,CAAnB,EAAqCzB,OAAjF,EAA0F;AACxF,cAAO,IAAIP,KAAJ,CAAU,0EAAV,CAAP;AACD;AACF;AACF,GAzOa;;AA2OdmC,wBAAsBpD,WAAtB,EAAmCqD,WAAnC,EAAgD;AAC9C,QAAI,CAAC9D,EAAEyC,aAAF,CAAgBqB,WAAhB,CAAL,EAAmC;AACjC,YAAO,IAAIpC,KAAJ,CAAU,gEAAV,CAAP;AACD;AACD,QAAK,OAAQoC,YAAYC,EAApB,KAA4B,QAA7B,IAA0C,CAAC,KAAKvD,SAAL,CAAeC,WAAf,EAA4BqD,YAAYC,EAAxC,CAA/C,EAA4F;AAC1F,YAAO,IAAIrC,KAAJ,CAAU,iGAAV,CAAP;AACD;AACD,QAAIjB,YAAYa,MAAZ,CAAmBwC,YAAYC,EAA/B,KAAsCtD,YAAYa,MAAZ,CAAmBwC,YAAYC,EAA/B,EAAmC9B,OAA7E,EAAsF;AACpF,YAAO,IAAIP,KAAJ,CAAU,mFAAV,CAAP;AACD;AACD,QAAI,OAAQoC,YAAYE,KAApB,KAA+B,QAAnC,EAA6C;AAC3C,YAAO,IAAItC,KAAJ,CAAU,8DAAV,CAAP;AACD;AACD,QAAI,CAAC1B,EAAEyC,aAAF,CAAgBqB,YAAYlD,OAA5B,CAAL,EAA2C;AACzC,YAAO,IAAIc,KAAJ,CAAU,6EACb,iDADG,CAAP;AAED;AACF,GA5Pa;;AA8PduC,wBAAsBxD,WAAtB,EAAmC;AAAA;;AACjC,QAAI,CAACA,WAAL,EAAkB;AAChB,YAAO,IAAIiB,KAAJ,CAAU,4BAAV,CAAP;AACD;;AAED,QAAI,CAAC1B,EAAEyC,aAAF,CAAgBhC,YAAYa,MAA5B,CAAD,IAAwC4C,OAAOC,IAAP,CAAY1D,YAAYa,MAAxB,EAAgCa,MAAhC,KAA2C,CAAvF,EAA0F;AACxF,YAAO,IAAIT,KAAJ,CAAU,qDAAV,CAAP;AACD;;AAED,QAAI,CAACjB,YAAYW,GAAb,IAAoB,CAACpB,EAAEkC,OAAF,CAAUzB,YAAYW,GAAtB,CAAzB,EAAqD;AACnD,YAAO,IAAIM,KAAJ,CAAU,qFAAV,CAAP;AACD;;AAED1B,MAAEoC,OAAF,CAAU3B,YAAYa,MAAtB,EAA8B,UAACG,WAAD,EAAcf,SAAd,EAA4B;AACxD,aAAKc,cAAL,CAAoBf,WAApB,EAAiCgB,WAAjC,EAA8Cf,SAA9C;AACD,KAFD;;AAIA,SAAKsB,oBAAL,CAA0BvB,WAA1B;;AAEA,QAAIA,YAAY2D,kBAAhB,EAAoC;AAClC,UAAI,CAACpE,EAAEyC,aAAF,CAAgBhC,YAAY2D,kBAA5B,CAAL,EAAsD;AACpD,cAAO,IAAI1C,KAAJ,CAAU,oEAAV,CAAP;AACD;AACD1B,QAAEoC,OAAF,CAAU3B,YAAY2D,kBAAtB,EAA0C,UAACrB,sBAAD,EAAyBC,oBAAzB,EAAkD;AAC1F,eAAKF,0BAAL,CAAgCrC,WAAhC,EAA6CsC,sBAA7C,EAAqEC,oBAArE;AACD,OAFD;AAGD;;AAED,QAAIvC,YAAY4D,OAAhB,EAAyB;AACvB,UAAI,CAACrE,EAAEkC,OAAF,CAAUzB,YAAY4D,OAAtB,CAAL,EAAqC;AACnC,cAAO,IAAI3C,KAAJ,CAAU,gDAAV,CAAP;AACD;;AAEDjB,kBAAY4D,OAAZ,CAAoBjC,OAApB,CAA4B,UAACqB,QAAD,EAAc;AACxC,eAAKD,cAAL,CAAoB/C,WAApB,EAAiCgD,QAAjC;AACD,OAFD;AAGD;;AAED,QAAIhD,YAAY6D,YAAZ,IAA4B7D,YAAY8D,cAA5C,EAA4D;AAC1D,YAAO,IAAI7C,KAAJ,CAAU,gGAAV,CAAP;AACD;;AAED,QAAIjB,YAAY6D,YAAhB,EAA8B;AAC5B,WAAKT,qBAAL,CAA2BpD,WAA3B,EAAwCA,YAAY6D,YAApD;AACD;;AAED,QAAI7D,YAAY8D,cAAhB,EAAgC;AAC9B,UAAI,CAACvE,EAAEkC,OAAF,CAAUzB,YAAY8D,cAAtB,CAAL,EAA4C;AAC1C,cAAO,IAAI7C,KAAJ,CAAU,8EAAV,CAAP;AACD;AACDjB,kBAAY8D,cAAZ,CAA2BnC,OAA3B,CAAmC,UAAC0B,WAAD,EAAiB;AAClD,eAAKD,qBAAL,CAA2BpD,WAA3B,EAAwCqD,WAAxC;AACD,OAFD;AAGD;AACF,GApTa;;AAsTdU,yBAAuBC,IAAvB,EAA6BC,SAA7B,EAAwC;AACtC,QAAI,CAAC1E,EAAEyC,aAAF,CAAgBgC,IAAhB,CAAL,EAA4B;AAC1B,YAAO,IAAI/C,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,0DAAZ,EAAwE+C,SAAxE,CAAV,CAAP;AACD;AACD,QAAI,OAAOD,KAAKE,SAAZ,KAA0B,UAA9B,EAA0C;AACxC,YAAO,IAAIjD,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,kDAAZ,EAAgE+C,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,eAAO1E,KAAKyB,MAAL,CAAYiD,OAAZ,CAAP;AACD,OAFc,CAEbG,IAFa,CAER,IAFQ,EAEFN,KAAKG,OAFH,CAAf;AAGD;AACD,QAAI,OAAOH,KAAKG,OAAZ,KAAwB,UAA5B,EAAwC;AACtC,YAAO,IAAIlD,KAAJ,CAAUxB,KAAKyB,MAAL,CAAY,kEAAZ,EAAgF+C,SAAhF,CAAV,CAAP;AACD;AACD,WAAOD,IAAP;AACD,GAzUa;;AA2UdI,iCAA+BG,KAA/B,EAAsCC,QAAtC,EAAgDrD,SAAhD,EAA2D;AACzD,WAAO1B,KAAKyB,MAAL,CAAY,8CAAZ,EAA4DqD,KAA5D,EAAmEC,QAAnE,EAA6ErD,SAA7E,CAAP;AACD,GA7Ua;;AA+UdsD,yBAAuBC,UAAvB,EAAmCH,KAAnC,EAA0C;AACxC,QAAIA,SAAS,IAAT,IAAkBhF,EAAEyC,aAAF,CAAgBuC,KAAhB,KAA0BA,MAAMI,YAAtD,EAAqE;AACnE,aAAO,IAAP;AACD;;AAED,SAAK,IAAIC,IAAI,CAAb,EAAgBA,IAAIF,WAAWhD,MAA/B,EAAuCkD,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,GA5Va;;AA8VdU,iBAAe7E,WAAf,EAA4BiE,SAA5B,EAAuC;AAAA;;AACrC,QAAMS,aAAa,EAAnB;AACA,QAAMvD,YAAY,KAAKC,cAAL,CAAoBpB,WAApB,EAAiCiE,SAAjC,CAAlB;AACA,QAAMa,qBAAqBpF,UAAUqF,sBAAV,CAAiC5D,SAAjC,CAA3B;AACA,QAAM6D,QAAQhF,YAAYa,MAAZ,CAAmBoD,SAAnB,CAAd;;AAEA,QAAIa,kBAAJ,EAAwB;AACtB,UAAI,EAAEE,MAAMhB,IAAN,IAAcgB,MAAMhB,IAAN,CAAWiB,eAAX,KAA+B,KAA/C,CAAJ,EAA2D;AACzDP,mBAAWlE,IAAX,CAAgBsE,kBAAhB;AACD;AACF;;AAED,QAAI,OAAOE,MAAMhB,IAAb,KAAsB,WAA1B,EAAuC;AACrC,UAAI,OAAOgB,MAAMhB,IAAb,KAAsB,UAA1B,EAAsC;AACpCgB,cAAMhB,IAAN,GAAa;AACXE,qBAAWc,MAAMhB,IADN;AAEXG,mBAAS,KAAKC;AAFH,SAAb;AAIAM,mBAAWlE,IAAX,CAAgBwE,MAAMhB,IAAtB;AACD,OAND,MAMO,IAAIkB,MAAMzD,OAAN,CAAcuD,MAAMhB,IAAN,CAAWU,UAAzB,CAAJ,EAA0C;AAC/CM,cAAMhB,IAAN,CAAWU,UAAX,CAAsB/C,OAAtB,CAA8B,UAACwD,SAAD,EAAe;AAC3CT,qBAAWlE,IAAX,CAAgB,OAAKuD,sBAAL,CAA4BoB,SAA5B,EAAuClB,SAAvC,CAAhB;AACD,SAFD;AAGD,OAJM,MAIA,IAAIe,MAAMhB,IAAN,CAAWE,SAAf,EAA0B;AAC/BQ,mBAAWlE,IAAX,CAAgB,KAAKuD,sBAAL,CAA4BiB,MAAMhB,IAAlC,EAAwCC,SAAxC,CAAhB;AACD;AACF;;AAED,WAAOS,UAAP;AACD,GA3Xa;;AA6XdtD,iBAAepB,WAAf,EAA4BC,SAA5B,EAAuC;AACrC,QAAMe,cAAchB,YAAYa,MAAZ,CAAmBZ,SAAnB,CAApB;;AAEA,QAAI,OAAOe,WAAP,KAAuB,QAA3B,EAAqC;AACnC,aAAOA,WAAP;AACD;AACD,QAAIzB,EAAEyC,aAAF,CAAgBhB,WAAhB,CAAJ,EAAkC;AAChC,aAAOA,YAAYoE,IAAnB;AACD;AACD,UAAO,IAAInE,KAAJ,CAAW,kBAAiBhB,SAAU,wBAAtC,CAAP;AACD,GAvYa;;AAyYdoF,oBAAkBrF,WAAlB,EAA+BC,SAA/B,EAA0C;AACxC,QAAID,YAAYa,MAAZ,CAAmBZ,SAAnB,EAA8B+D,IAA9B,IAAsChE,YAAYa,MAAZ,CAAmBZ,SAAnB,EAA8B+D,IAA9B,CAAmCsB,QAA7E,EAAuF;AACrF,aAAO,IAAP;AACD;AACD,WAAO,KAAP;AACD,GA9Ya;;AAgZdC,uBAAqBvF,WAArB,EAAkCC,SAAlC,EAA6C;AAC3C,QAAID,YAAYW,GAAZ,CAAgBG,QAAhB,CAAyBb,SAAzB,CAAJ,EAAyC;AACvC,aAAO,IAAP;AACD;AACD,QAAID,YAAYW,GAAZ,CAAgB,CAAhB,aAA8BuE,KAA9B,IAAuClF,YAAYW,GAAZ,CAAgB,CAAhB,EAAmBG,QAAnB,CAA4Bb,SAA5B,CAA3C,EAAmF;AACjF,aAAO,IAAP;AACD;AACD,WAAO,KAAP;AACD,GAxZa;;AA0ZdqB,+BAA6BtB,WAA7B,EAA0CC,SAA1C,EAAqD;AACnD,QAAIV,EAAEyC,aAAF,CAAgBhC,YAAYa,MAAZ,CAAmBZ,SAAnB,CAAhB,KAAkDD,YAAYa,MAAZ,CAAmBZ,SAAnB,EAA8BuF,OAApF,EAA6F;AAC3F,UAAIjG,EAAEyC,aAAF,CAAgBhC,YAAYa,MAAZ,CAAmBZ,SAAnB,EAA8BuF,OAA9C,KACG,CAAExF,YAAYa,MAAZ,CAAmBZ,SAAnB,EAA8BuF,OAA9B,CAAsCb,YAD/C,EAC8D;AAC5D,eAAO,CAAC,KAAD,EAAQ,MAAR,EAAgB,KAAhB,EAAuB,QAAvB,EAAiC7D,QAAjC,CAA0Cd,YAAYa,MAAZ,CAAmBZ,SAAnB,EAA8BmF,IAAxE,CAAP;AACD;AACD,aAAO,IAAP;AACD;AACD,WAAO,IAAP;AACD;;AAnaa,CAAhB;;AAuaAK,OAAOC,OAAP,GAAiB/F,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  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', fieldtype, fieldName)));\n    }\n    if (['map', 'list', 'set', 'frozen'].includes(fieldtype)) {\n      if (!fieldObject.typeDef) {\n        throw (new Error(util.format('Missing typeDef for field type \"%s\" on field: %s', fieldtype, fieldName)));\n      }\n      if (typeof fieldObject.typeDef !== 'string') {\n        throw (new Error(util.format('Invalid typeDef for field type \"%s\" on field: %s', fieldtype, fieldName)));\n      }\n    }\n    if (!(this.is_field_default_value_valid(modelSchema, fieldName))) {\n      throw (new Error(util.format('Invalid default value for field: %s(%s)', fieldName, fieldtype)));\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    const field = modelSchema.fields[fieldname];\n\n    if (typeFieldValidator) {\n      if (!(field.rule && field.rule.type_validation === false)) {\n        validators.push(typeFieldValidator);\n      }\n    }\n\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(`Type of field \"${fieldName}\" 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)) {\n      return true;\n    }\n    if (modelSchema.key[0] instanceof Array && 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.8.0",
"version": "2.9.0",
"dependencies": {
"JSONStream": "^1.3.1",
"async": "^1.5.2",
"async": "^2.6.4",
"babel-polyfill": "^6.26.0",

@@ -14,2 +13,3 @@ "bluebird": "^3.4.6",

"deep-diff": "^0.3.4",
"JSONStream": "^1.3.1",
"lodash": "^4.17.15",

@@ -29,19 +29,16 @@ "object-hash": "1.1.4",

"cross-env": "^5.0.5",
"echo-cli": "^1.0.8",
"elasticsearch": "^13.3.1",
"eslint": "^4.9.0",
"eslint-config-airbnb-base": "^12.1.0",
"echo-cli": "^2.0.0",
"eslint": "^8.26.0",
"eslint-config-airbnb-base": "^15.0.0",
"eslint-plugin-import": "^2.8.0",
"gremlin": "^2.6.0",
"istanbul": "^0.4.5",
"mocha": "^5.2.0",
"mocha-logger": "1.0.5",
"mocha": "^10.1.0",
"mocha-logger": "1.0.8",
"mocha-silent-reporter": "^1.0.0",
"nyc": "^11.2.1",
"nyc": "^15.1.0",
"vows": "^0.8.3"
},
"optionalDependencies": {},
"author": {
"name": "Mahafuzur Rahman",
"url": "https://www.codinglogs.com"
"url": "http://express-cassandra.readthedocs.io"
},

@@ -58,3 +55,3 @@ "scripts": {

"license": "LGPL-3.0",
"description": "Cassandra Object Models (ORM/ODM/OGM) for NodeJS with Elassandra & JanusGraph Support",
"description": "Cassandra Object Models (ORM/ODM/OGM) for NodeJS with support for Apache Cassandra, ScyllaDB, Datastax Enterprise, Elassandra & JanusGraph.",
"repository": {

@@ -73,2 +70,4 @@ "type": "git",

"apache-cassandra",
"scylla",
"scylladb",
"datastax",

@@ -95,4 +94,4 @@ "dse",

"engines": {
"node": ">= 4"
"node": ">= 12"
}
}

@@ -10,8 +10,6 @@ [![Build Status](https://app.travis-ci.com/masumsoft/express-cassandra.svg?branch=master)](https://app.travis-ci.com/masumsoft/express-cassandra)

Express-Cassandra is a Cassandra ORM/ODM/OGM for NodeJS with Elassandra & JanusGraph Support.
Express-Cassandra is a Cassandra ORM/ODM/OGM for NodeJS with support for Apache Cassandra, ScyllaDB, Datastax Enterprise, Elassandra & JanusGraph.
No more hassling with raw cql queries from your nodejs web frameworks. Express-Cassandra automatically loads your models and provides you with object oriented mapping to your cassandra tables like a standard ORM/ODM. Built in support for [Elassandra](http://www.elassandra.io/) and [JanusGraph](http://janusgraph.org/) allows you to automatically manage synced elasticsearch and janusgraph indexes stored in cassandra.
No more hassling with raw cql queries from your nodejs web frameworks. Express-Cassandra automatically loads your models and provides you with object oriented mapping to your cassandra/scylladb tables like a standard ORM/ODM. Built in support for [Cassandra](https://cassandra.apache.org/), [ScyllaDB](https://www.scylladb.com/), [Elassandra](http://www.elassandra.io/) and [JanusGraph](http://janusgraph.org/) allows you to automatically manage schema, graph and data models from your javascript codebase. Models are written as javascript modules and they automatically create the underlying db tables, indexes, materialized views, graphs etc. Afterwards you can save, update, delete and query your data using supported model methods. It's decoupled nature allows you to use it with many popular node frameworks without much hassle.
Express-cassandra enables your nodejs app to manage a highly available distributed data store capable of handling large dataset with powerful query features powered by cassandra, elasticsearch and janusgraph combined. Express-cassandra empowers you to manage and query this truely distributed datastore with search, analytics and graph computing functionality from nodejs like you are just dealing with javascript objects and methods. Models are written as javascript modules and they automatically create the underlying db tables, indexes, materialized views, graphs etc. Afterwards you can save, update, delete and query your data using supported model methods. It's decoupled nature allows you to use it with many popular node frameworks without much hassle.
If you are using elassandra, then saved data in cassandra automatically syncs with elasticsearch indexes defined in your schema. You can then do any query [elasticsearch](https://www.elastic.co/products/elasticsearch) indexes support.

@@ -22,12 +20,20 @@

## Our Sponsors: ##
<table><tr>
<td align="center" width="300" ><a href="https://astra.dev/3shh4EF"><img src="https://www.datastax.com/sites/default/files/2021-07/astra-negative-square.png" width="90" height="90" alt="Astra DB" /><br />Astra DB</a><br/>Use Node/Express with DataStax Astra DB - built on Apache Cassandra.</td>
</tr></table>
<table>
<tr>
<td align="center" width="300" >
<a href="https://astra.dev/3shh4EF">
<img src="https://www.datastax.com/sites/default/files/2021-07/astra-negative-square.png" width="90" height="90" alt="Astra DB" />
<br/>Astra DB
</a>
<br/>Use Node/Express with DataStax Astra DB - built on Apache Cassandra.
</td>
</tr>
</table>
## Supported Features
* supports the latest cassandra 4.x and older stable 3.x releases
* supports the latest cassandra 4.x, 3.x and scylladb 5.x versions
* compatible with datastax enterprise solr search and dse graph
* support for elassandra index management and search queries
* support for janusgraph graph management and tinkerpop3 gremlin queries
* compatible with datastax enterprise solr search and dse graph
* full featured CRUD operations and data type validations

@@ -44,3 +50,3 @@ * full support for collections and other advanced data types

* optional support for query debug and progress logs
* most of the bleeding edge cassandra features are supported
* most of the bleeding edge cassandra and scylladb features are supported

@@ -51,3 +57,3 @@ This module internally uses [cassandra-driver](https://github.com/datastax/nodejs-driver).

For apache cassandra version 4.x, 3.x or datastax enterprise
For apache cassandra 4.x, 3.x, scylladb 5.x or datastax enterprise 6.x, 5.x

@@ -68,3 +74,3 @@ npm install express-cassandra

Please note that if you use the legacy cassandra 2.x compliant version then please use the corresponding README.md file for that version. The following documentation is for version 4.x, 3.x and datastax enterprise 6.x/5.x only. The materialized view support and several other part of the documentation is strictly applicable for cassandra 4.x/3.x or dse 6.x/5.x and will not work in earlier versions of cassandra.
Please note that if you use the legacy cassandra 2.x compliant version then please use the corresponding README.md file for that version. The following documentation is for version 4.x, 3.x and datastax enterprise 6.x/5.x only. The materialized view support and several other part of the documentation is strictly applicable for cassandra 4.x/3.x or scylladb 5.x or dse 6.x/5.x and will not work in earlier versions of cassandra.

@@ -77,7 +83,7 @@ # Documentation

A detailed changelog for released versions are available in the [changelog](./CHANGELOG.md) section.
A detailed changelog for released versions is available in the [changelog](./CHANGELOG.md) section.
# Contributing
All contributions, bug reports, bug fixes, documentation improvements, enhancements and ideas are welcome.
All kinds of contributions, bug reports, bug fixes, documentation improvements, enhancements and ideas are welcome.

@@ -92,2 +98,4 @@ A detailed overview on how to contribute can be found in the [contributing guide](./CONTRIBUTING.md).

* ScyllaDB, and ScyllaDB Cloud, are registered trademarks of ScyllaDB, Inc.
* DataStax, Titan, and TitanDB are registered trademark of DataStax, Inc. and its subsidiaries in the United States and/or other countries.

@@ -94,0 +102,0 @@

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

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 too big to display

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

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