pj
Version:
Create SQL strings for PostgreSQL by interfacing with a javascript API
343 lines (251 loc) • 21.9 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
// third-party modules
var _classer = require('classer');
var _classer2 = _interopRequireDefault(_classer);
var _pg = require('pg');
var _pg2 = _interopRequireDefault(_pg);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
// local classes
/**
* static:
**/
// connection string regex parser
// const R_CONNECT = /^\s*(?:(?:(?:(\w+):\/\/)?(\w+)(?::([^@]+))?@)?(\w+)?\/)?(\w+)(\?.+)\s*$/;
var R_CONNECT = /^\s*([\w\-]+)?(:[^@]+)?@([^:\/?\s]+)?(:\d+)?\/([^?\s]+)\s*/;
// connection defaults
var H_CONNECT_DEFAULTS = {
protocol: 'postgres',
user: 'root',
host: 'localhost'
};
// connect to database using string
var connect_string = function connect_string(s_connect) {
// parse connection string
var m_connect = R_CONNECT.exec(s_connect);
// invalid connection string
if (!m_connect) return local.fail('invalid connection string: "' + s_connect + '"');
// construct full postgres connection string
return ''
// protocol
+ (false || H_CONNECT_DEFAULTS.protocol) + '://'
// user
+ (m_connect[1] || H_CONNECT_DEFAULTS.user)
// password
+ (m_connect[2] ? m_connect[2] : '') + '@'
// host
+ (m_connect[3] || H_CONNECT_DEFAULTS.host)
// port
+ (m_connect[4] ? m_connect[4] : '') + '/'
// database
+ m_connect[5];
};
// escape string literal
var escape_literal = function escape_literal(s_value) {
return s_value.replace(/'/g, '\'\'').replace(/\t/g, '\\t').replace(/\n/g, '\\n');
};
//
var valuify = function valuify(z_value) {
switch (typeof z_value === 'undefined' ? 'undefined' : _typeof(z_value)) {
case 'string':
return '\'' + escape_literal(z_value) + '\'';
case 'number':
return z_value;
case 'boolean':
return z_value ? 'TRUE' : 'FALSE';
case 'object':
// null
if (null === z_value) {
return null;
}
// raw sql
else if ('string' === typeof z_value.raw) {
return z_value.raw;
}
// default
return escape_literal(JSON.stringify(z_value));
case 'function':
return z_value() + '';
default:
throw 'unable to convert into safe value: "${z_value}"';
}
};
//
var H_WRITERS = {
// convert hash query to string query
insert: function insert(h_query) {
// ref insert list
var a_inserts = h_query.insert;
// prep list of rows that have been observed from first element
var a_keys = Object.keys(a_inserts[0]);
// build columns part of sql string
var s_keys = a_keys.map(function (s_key) {
return '"' + s_key + '"';
}).join(',');
// build values part of sql string
var a_rows = [];
// each insert row
a_inserts.forEach(function (h_row) {
// list of values to insert for this row
var a_values = [];
// each key-value pair in row
for (var s_key in h_row) {
// key is missing from accepted values section
if (-1 === a_keys.indexOf(s_key)) {
return local.fail('new key "${s_key}" introduced after first element in insert chain');
}
// append to values
a_values.push(valuify(h_row[s_key]));
}
// push row to values list
a_rows.push('(' + a_values.join(',') + ')');
});
//
var s_tail = '';
//
if (h_query.conflict_target && h_query.conflict_action) {
s_tail += 'on conflict ' + h_query.conflict_target + ' ' + h_query.conflict_action;
}
// prep sql query string
return 'insert into "' + h_query.into + '" (' + s_keys + ') values ' + a_rows.join(',') + ' ' + s_tail;
}
};
/**
* class:
**/
var local = (0, _classer2.default)('pj', function (z_config) {
//
var a_queue = [];
// connection string
var s_connection = function () {
// setup postgres connection
switch (typeof z_config === 'undefined' ? 'undefined' : _typeof(z_config)) {
// config given as string
case 'string':
// connection string
return connect_string(z_config);
}
return false;
}();
//
if (!s_connection) return local.fail('failed to understand connection config argument');
//
local.info('connecting to postgres w/ ' + s_connection);
// postgres client
var y_client = new _pg2.default.Client(s_connection);
// initiate connection
y_client.connect(function (e_connect) {
// connection error
if (e_connect) {
local.fail('failed to connect');
}
//
next_query();
});
//
var next_query = function next_query() {
// queue is not empty
if (a_queue.length) {
// shift first query from beginning
var h_query = a_queue.shift();
// execute query
y_client.query(h_query.sql, h_query.callback);
}
};
// submit a query to be executed
var submit_query = function submit_query(s_query, f_okay) {
// push to queue
a_queue.push({
sql: s_query,
callback: f_okay
});
// queue was empty
if (1 === a_queue.length) {
// initiate
next_query();
}
};
// query-building for insertion
var qb_insert = function qb_insert(h_query) {
// default insert hash
h_query.insert = h_query.insert || [];
//
var self = {
// insert rows
insert: function insert(z_values) {
// list of rows to insert simultaneously
if (Array.isArray(z_values)) {
var _h_query$insert;
// append to existing insertion list
(_h_query$insert = h_query.insert).push.apply(_h_query$insert, _toConsumableArray(z_values));
}
// values hash
else if ('object' === (typeof z_values === 'undefined' ? 'undefined' : _typeof(z_values))) {
// single row to append to insertion list
h_query.insert.push(z_values);
}
// other type
else {
local.fail('invalid type for insertion argument');
}
// normal insert actions
return self;
},
// on conflict
on_conflict: function on_conflict(s_target) {
// set conflict target
h_query.conflict_target = '(' + s_target + ')';
// next action hash
return {
// do nothing
do_nothing: function do_nothing() {
// set conflict action
h_query.conflict_action = 'do nothing';
// normal insert actions
return self;
}
};
},
//
debug: function debug() {
// generate sql
var s_sql = H_WRITERS.insert(h_query);
debugger;
return self;
},
//
exec: function exec(f_okay) {
// generate sql
var s_sql = H_WRITERS.insert(h_query);
// submit
submit_query(s_sql, function (e_insert, w_result) {
// insert error
if (e_insert) {
local.fail(e_insert);
}
//
if ('function' === typeof f_okay) {
f_okay(w_result);
}
});
}
};
//
return self;
};
//
return _classer2.default.operator(function () {}, {
// start of an insert query
into: function into(s_table) {
return qb_insert({
into: s_table
});
}
});
});
exports.default = local;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["pj.js"],"names":[],"mappings":";;;;;;;;;;AAEA;;;;AACA;;;;;;;;;;;;;;;;AAUA,IAAM,YAAY,4DAAZ;;;AAGN,IAAM,qBAAqB;AAC1B,WAAU,UAAV;AACA,OAAM,MAAN;AACA,OAAM,WAAN;CAHK;;;AAQN,IAAM,iBAAiB,SAAjB,cAAiB,CAAC,SAAD,EAAe;;;AAGrC,KAAI,YAAY,UAAU,IAAV,CAAe,SAAf,CAAZ;;;AAHiC,KAMlC,CAAC,SAAD,EAAY,OAAO,MAAM,IAAN,kCAA0C,eAA1C,CAAP,CAAf;;;AANqC,QAS9B;;KAEH,SAAS,mBAAmB,QAAnB,CAFN,GAEmC,KAFnC;;KAIH,UAAU,CAAV,KAAgB,mBAAmB,IAAnB,CAJb;;KAMF,UAAU,CAAV,IAAc,UAAU,CAAV,CAAd,GAA4B,EAA5B,CANE,GAM8B,GAN9B;;KAQH,UAAU,CAAV,KAAgB,mBAAmB,IAAnB,CARb;;KAUF,UAAU,CAAV,IAAc,UAAU,CAAV,CAAd,GAA4B,EAA5B,CAVE,GAU8B,GAV9B;;IAYJ,UAAU,CAAV,CAZI,CAT8B;CAAf;;;AAyBvB,IAAM,iBAAiB,SAAjB,cAAiB,CAAC,OAAD,EAAa;AACnC,QAAO,QACL,OADK,CACG,IADH,EACS,MADT,EAEL,OAFK,CAEG,KAFH,EAEU,KAFV,EAGL,OAHK,CAGG,KAHH,EAGU,KAHV,CAAP,CADmC;CAAb;;;AAQvB,IAAM,UAAU,SAAV,OAAU,CAAC,OAAD,EAAa;AAC5B,gBAAc,wDAAd;AACC,OAAK,QAAL;AACC,iBAAW,eAAe,OAAf,QAAX,CADD;;AADD,OAIM,QAAL;AACC,UAAO,OAAP,CADD;;AAJD,OAOM,SAAL;AACC,UAAO,UAAS,MAAT,GAAiB,OAAjB,CADR;;AAPD,OAUM,QAAL;;AAEC,OAAG,SAAS,OAAT,EAAkB;AACpB,WAAO,IAAP,CADoB;;;AAArB,QAIK,IAAG,aAAa,OAAO,QAAQ,GAAR,EAAa;AACxC,YAAO,QAAQ,GAAR,CADiC;KAApC;;;AANN,UAWQ,eACN,KAAK,SAAL,CAAe,OAAf,CADM,CAAP,CAXD;;AAVD,OAyBM,UAAL;AACC,UAAO,YAAU,EAAV,CADR;;AAzBD;AA6BE,SAAM,iDAAN,CADD;AA5BD,EAD4B;CAAb;;;AAmChB,IAAM,YAAY;;;;AAGjB,yBAAO,SAAS;;;AAGf,MAAI,YAAY,QAAQ,MAAR;;;AAHD,MAMX,SAAS,OAAO,IAAP,CAAY,UAAU,CAAV,CAAZ,CAAT;;;AANW,MASX,SAAS,OAAO,GAAP,CAAW;gBAAa;GAAb,CAAX,CAAkC,IAAlC,CAAuC,GAAvC,CAAT;;;AATW,MAYX,SAAS,EAAT;;;AAZW,WAef,CAAU,OAAV,CAAkB,UAAC,KAAD,EAAW;;;AAG5B,OAAI,WAAW,EAAX;;;AAHwB,QAMxB,IAAI,KAAJ,IAAa,KAAjB,EAAwB;;;AAGvB,QAAG,CAAC,CAAD,KAAO,OAAO,OAAP,CAAe,KAAf,CAAP,EAA8B;AAChC,YAAO,MAAM,IAAN,CAAW,mEAAX,CAAP,CADgC;KAAjC;;;AAHuB,YAQvB,CAAS,IAAT,CAAc,QAAQ,MAAM,KAAN,CAAR,CAAd,EARuB;IAAxB;;;AAN4B,SAkB5B,CAAO,IAAP,OAAgB,SAAS,IAAT,CAAc,GAAd,OAAhB,EAlB4B;GAAX,CAAlB;;;AAfe,MAqCX,SAAS,EAAT;;;AArCW,MAwCZ,QAAQ,eAAR,IAA2B,QAAQ,eAAR,EAAyB;AACtD,8BAAyB,QAAQ,eAAR,SAA2B,QAAQ,eAAR,CADE;GAAvD;;;AAxCe,2BA6CQ,QAAQ,IAAR,WAAkB,uBAAkB,OAAO,IAAP,CAAY,GAAZ,UAAoB,MAA/E,CA7Ce;EAHC;CAAZ;;;;;AAyDN,IAAM,QAAQ,uBAAQ,IAAR,EAAc,UAAS,QAAT,EAAmB;;;AAG9C,KAAI,UAAU,EAAV;;;AAH0C,KAM1C,eAAe,YAAO;;;AAGzB,iBAAc,0DAAd;;;AAGC,QAAK,QAAL;;AAEC,WAAO,eAAe,QAAf,CAAP,CAFD;AAHD,GAHyB;;AAWzB,SAAO,KAAP,CAXyB;EAAN,EAAhB;;;AAN0C,KAqB3C,CAAC,YAAD,EAAe,OAAO,MAAM,IAAN,CAAW,iDAAX,CAAP,CAAlB;;;AArB8C,MAwB9C,CAAM,IAAN,gCAAwC,YAAxC;;;AAxB8C,KA2B1C,WAAW,IAAI,aAAG,MAAH,CAAU,YAAd,CAAX;;;AA3B0C,SA8B9C,CAAS,OAAT,CAAiB,UAAC,SAAD,EAAe;;;AAG/B,MAAG,SAAH,EAAc;AACb,SAAM,IAAN,CAAW,mBAAX,EADa;GAAd;;;AAH+B,YAQ/B,GAR+B;EAAf,CAAjB;;;AA9B8C,KA0CxC,aAAa,SAAb,UAAa,GAAM;;;AAGxB,MAAG,QAAQ,MAAR,EAAgB;;AAElB,OAAI,UAAU,QAAQ,KAAR,EAAV;;;AAFc,WAKlB,CAAS,KAAT,CAAe,QAAQ,GAAR,EAAa,QAAQ,QAAR,CAA5B,CALkB;GAAnB;EAHkB;;;AA1C2B,KAuDxC,eAAe,SAAf,YAAe,CAAC,OAAD,EAAU,MAAV,EAAqB;;;AAGzC,UAAQ,IAAR,CAAa;AACZ,QAAK,OAAL;AACA,aAAU,MAAV;GAFD;;;AAHyC,MAStC,MAAM,QAAQ,MAAR,EAAgB;;AAExB,gBAFwB;GAAzB;EAToB;;;AAvDyB,KAuExC,YAAY,SAAZ,SAAY,CAAC,OAAD,EAAa;;;AAG9B,UAAQ,MAAR,GAAiB,QAAQ,MAAR,IAAkB,EAAlB;;;AAHa,MAMxB,OAAO;;;;AAGZ,2BAAO,UAAU;;;AAGhB,QAAG,MAAM,OAAN,CAAc,QAAd,CAAH,EAA4B;;;;AAG3B,gCAAQ,MAAR,EAAe,IAAf,2CAAuB,SAAvB,EAH2B;;;AAA5B,SAMK,IAAG,qBAAoB,2DAApB,EAA8B;;;AAGrC,cAAQ,MAAR,CAAe,IAAf,CAAoB,QAApB,EAHqC;;;AAAjC,UAMA;AACJ,aAAM,IAAN,CAAW,qCAAX,EADI;OANA;;;AATW,WAoBT,IAAP,CApBgB;IAHL;;;;AA2BZ,qCAAY,UAAU;;;AAGrB,YAAQ,eAAR,SAA8B,cAA9B;;;AAHqB,WAMd;;;;AAGN,uCAAa;;;AAGZ,cAAQ,eAAR,GAA0B,YAA1B;;;AAHY,aAML,IAAP,CANY;MAHP;KAAP,CANqB;IA3BV;;;;AAgDZ,2BAAQ;;;AAGP,QAAI,QAAQ,UAAU,MAAV,CAAiB,OAAjB,CAAR,CAHG;;AAKP,aALO;AAMP,WAAO,IAAP,CANO;IAhDI;;;;AA0DZ,uBAAK,QAAQ;;;AAGZ,QAAI,QAAQ,UAAU,MAAV,CAAiB,OAAjB,CAAR;;;AAHQ,gBAMZ,CAAa,KAAb,EAAoB,UAAC,QAAD,EAAW,QAAX,EAAwB;;;AAG3C,SAAG,QAAH,EAAa;AACZ,YAAM,IAAN,CAAW,QAAX,EADY;MAAb;;;AAH2C,SAQxC,eAAe,OAAO,MAAP,EAAe;AAChC,aAAO,QAAP,EADgC;MAAjC;KARmB,CAApB,CANY;IA1DD;GAAP;;;AANwB,SAsFvB,IAAP,CAtF8B;EAAb;;;AAvE4B,QAkKvC,kBAAQ,QAAR,CAAiB,YAAW,EAAX,EAErB;;;;AAGF,sBAAK,SAAS;AACb,UAAO,UAAU;AAChB,UAAM,OAAN;IADM,CAAP,CADa;GAHZ;EAFI,CAAP,CAlK8C;CAAnB,CAAtB;;kBA+KS","file":"pj.js","sourcesContent":["\n// third-party modules\nimport classer from 'classer';\nimport pg from 'pg';\n\n// local classes\n\n/**\n* static:\n**/\n\n// connection string regex parser\n// const R_CONNECT = /^\\s*(?:(?:(?:(\\w+):\\/\\/)?(\\w+)(?::([^@]+))?@)?(\\w+)?\\/)?(\\w+)(\\?.+)\\s*$/;\nconst R_CONNECT = /^\\s*([\\w\\-]+)?(:[^@]+)?@([^:\\/?\\s]+)?(:\\d+)?\\/([^?\\s]+)\\s*/;\n\n// connection defaults\nconst H_CONNECT_DEFAULTS = {\n\tprotocol: 'postgres',\n\tuser: 'root',\n\thost: 'localhost',\n};\n\n\n// connect to database using string\nconst connect_string = (s_connect) => {\n\n\t// parse connection string\n\tvar m_connect = R_CONNECT.exec(s_connect);\n\n\t// invalid connection string\n\tif(!m_connect) return local.fail(`invalid connection string: \"${s_connect}\"`);\n\n\t// construct full postgres connection string\n\treturn ''\n\t\t\t// protocol\n\t\t\t+(false || H_CONNECT_DEFAULTS.protocol)+'://'\n\t\t\t// user\n\t\t\t+(m_connect[1] || H_CONNECT_DEFAULTS.user)\n\t\t\t\t// password\n\t\t\t\t+(m_connect[2]? m_connect[2]: '')+'@'\n\t\t\t// host\n\t\t\t+(m_connect[3] || H_CONNECT_DEFAULTS.host)\n\t\t\t\t// port\n\t\t\t\t+(m_connect[4]? m_connect[4]: '')+'/'\n\t\t\t// database\n\t\t\t+m_connect[5];\n};\n\n// escape string literal\nconst escape_literal = (s_value) => {\n\treturn s_value\n\t\t.replace(/'/g, '\\'\\'')\n\t\t.replace(/\\t/g, '\\\\t')\n\t\t.replace(/\\n/g, '\\\\n');\n};\n\n//\nconst valuify = (z_value) => {\n\tswitch(typeof z_value) {\n\t\tcase 'string':\n\t\t\treturn `'${escape_literal(z_value)}'`;\n\n\t\tcase 'number':\n\t\t\treturn z_value;\n\n\t\tcase 'boolean':\n\t\t\treturn z_value? 'TRUE': 'FALSE';\n\n\t\tcase 'object':\n\t\t\t// null\n\t\t\tif(null === z_value) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\t// raw sql\n\t\t\telse if('string' === typeof z_value.raw) {\n\t\t\t\treturn z_value.raw;\n\t\t\t}\n\n\t\t\t// default\n\t\t\treturn escape_literal(\n\t\t\t\tJSON.stringify(z_value)\n\t\t\t);\n\n\t\tcase 'function':\n\t\t\treturn z_value()+'';\n\n\t\tdefault:\n\t\t\tthrow 'unable to convert into safe value: \"${z_value}\"';\n\t}\n};\n\n// \nconst H_WRITERS = {\n\n\t// convert hash query to string query\n\tinsert(h_query) {\n\n\t\t// ref insert list\n\t\tlet a_inserts = h_query.insert;\n\n\t\t// prep list of rows that have been observed from first element\n\t\tlet a_keys = Object.keys(a_inserts[0]);\n\n\t\t// build columns part of sql string\n\t\tlet s_keys = a_keys.map(s_key => `\"${s_key}\"`).join(',');\n\n\t\t// build values part of sql string\n\t\tlet a_rows = [];\n\n\t\t// each insert row\n\t\ta_inserts.forEach((h_row) => {\n\n\t\t\t// list of values to insert for this row\n\t\t\tlet a_values = [];\n\n\t\t\t// each key-value pair in row\n\t\t\tfor(let s_key in h_row) {\n\n\t\t\t\t// key is missing from accepted values section\n\t\t\t\tif(-1 === a_keys.indexOf(s_key)) {\n\t\t\t\t\treturn local.fail('new key \"${s_key}\" introduced after first element in insert chain');\n\t\t\t\t}\n\n\t\t\t\t// append to values\n\t\t\t\ta_values.push(valuify(h_row[s_key]));\n\t\t\t}\n\n\t\t\t// push row to values list\n\t\t\ta_rows.push(`(${a_values.join(',')})`);\n\t\t});\n\n\t\t//\n\t\tlet s_tail = '';\n\n\t\t//\n\t\tif(h_query.conflict_target && h_query.conflict_action) {\n\t\t\ts_tail += `on conflict ${h_query.conflict_target} ${h_query.conflict_action}`;\n\t\t}\n\n\t\t// prep sql query string\n\t\treturn `insert into \"${h_query.into}\" (${s_keys}) values ${a_rows.join(',')} ${s_tail}`;\n\t},\n};\n\n\n\n/**\n* class:\n**/\nconst local = classer('pj', function(z_config) {\n\n\t//\n\tlet a_queue = [];\n\n\t// connection string\n\tlet s_connection = (() => {\n\n\t\t// setup postgres connection\n\t\tswitch(typeof z_config) {\n\n\t\t\t// config given as string\n\t\t\tcase 'string':\n\t\t\t\t// connection string\n\t\t\t\treturn connect_string(z_config);\n\t\t}\n\n\t\treturn false;\n\t})();\n\n\t//\n\tif(!s_connection) return local.fail('failed to understand connection config argument');\n\n\t//\n\tlocal.info(`connecting to postgres w/ ${s_connection}`);\n\n\t// postgres client\n\tlet y_client = new pg.Client(s_connection);\n\n\t// initiate connection\n\ty_client.connect((e_connect) => {\n\n\t\t// connection error\n\t\tif(e_connect) {\n\t\t\tlocal.fail('failed to connect');\n\t\t}\n\n\t\t// \n\t\tnext_query();\n\t});\n\n\t//\n\tconst next_query = () => {\n\n\t\t// queue is not empty\n\t\tif(a_queue.length) {\n\t\t\t// shift first query from beginning\n\t\t\tlet h_query = a_queue.shift();\n\n\t\t\t// execute query\n\t\t\ty_client.query(h_query.sql, h_query.callback);\n\t\t}\n\t};\n\n\t// submit a query to be executed\n\tconst submit_query = (s_query, f_okay) => {\n\n\t\t// push to queue\n\t\ta_queue.push({\n\t\t\tsql: s_query,\n\t\t\tcallback: f_okay,\n\t\t});\n\n\t\t// queue was empty\n\t\tif(1 === a_queue.length) {\n\t\t\t// initiate\n\t\t\tnext_query();\n\t\t}\n\t};\n\n\t// query-building for insertion\n\tconst qb_insert = (h_query) => {\n\n\t\t// default insert hash\n\t\th_query.insert = h_query.insert || [];\n\n\t\t//\n\t\tconst self = {\n\n\t\t\t// insert rows\n\t\t\tinsert(z_values) {\n\n\t\t\t\t// list of rows to insert simultaneously\n\t\t\t\tif(Array.isArray(z_values)) {\n\n\t\t\t\t\t// append to existing insertion list\n\t\t\t\t\th_query.insert.push(...z_values);\n\t\t\t\t}\n\t\t\t\t// values hash\n\t\t\t\telse if('object' === typeof z_values) {\n\n\t\t\t\t\t// single row to append to insertion list\n\t\t\t\t\th_query.insert.push(z_values);\n\t\t\t\t}\n\t\t\t\t// other type\n\t\t\t\telse {\n\t\t\t\t\tlocal.fail('invalid type for insertion argument');\n\t\t\t\t}\n\n\t\t\t\t// normal insert actions\n\t\t\t\treturn self;\n\t\t\t},\n\n\t\t\t// on conflict\n\t\t\ton_conflict(s_target) {\n\n\t\t\t\t// set conflict target\n\t\t\t\th_query.conflict_target = `(${s_target})`;\n\n\t\t\t\t// next action hash\n\t\t\t\treturn {\n\n\t\t\t\t\t// do nothing\n\t\t\t\t\tdo_nothing() {\n\n\t\t\t\t\t\t// set conflict action\n\t\t\t\t\t\th_query.conflict_action = 'do nothing';\n\n\t\t\t\t\t\t// normal insert actions\n\t\t\t\t\t\treturn self;\n\t\t\t\t\t},\n\t\t\t\t};\n\t\t\t},\n\n\t\t\t//\n\t\t\tdebug() {\n\n\t\t\t\t// generate sql\n\t\t\t\tlet s_sql = H_WRITERS.insert(h_query);\n\n\t\t\t\tdebugger;\n\t\t\t\treturn self;\n\t\t\t},\n\n\t\t\t//\n\t\t\texec(f_okay) {\n\n\t\t\t\t// generate sql\n\t\t\t\tlet s_sql = H_WRITERS.insert(h_query);\n\n\t\t\t\t// submit\n\t\t\t\tsubmit_query(s_sql, (e_insert, w_result) => {\n\n\t\t\t\t\t// insert error\n\t\t\t\t\tif(e_insert) {\n\t\t\t\t\t\tlocal.fail(e_insert);\n\t\t\t\t\t}\n\n\t\t\t\t\t//\n\t\t\t\t\tif('function' === typeof f_okay) {\n\t\t\t\t\t\tf_okay(w_result);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t},\n\t\t};\n\n\t\t//\n\t\treturn self;\n\t};\n\n\n\t//\n\treturn classer.operator(function() {\n\n\t}, {\n\n\t\t// start of an insert query\n\t\tinto(s_table) {\n\t\t\treturn qb_insert({\n\t\t\t\tinto: s_table,\n\t\t\t});\n\t\t},\n\t});\n});\n\nexport default local;\n"],"sourceRoot":"/source/"}
;