@fxjs/db-driver
Advanced tools
Comparing version 0.0.4 to 0.0.5
@@ -80,7 +80,7 @@ /// <reference types="@fibjs/types" /> | ||
class Driver<ConnType = any> { | ||
class Driver<CONN_TYPE = any> { | ||
static getDriver( | ||
name: FxDbDriverNS.DriverType | string | ||
): any | ||
static create<CreateConnType = any> (options: ConnectionInputArgs | string): Driver<CreateConnType> | ||
static create<CreateCONN_TYPE = any> (options: ConnectionInputArgs | string): Driver<CreateCONN_TYPE> | ||
@@ -108,4 +108,4 @@ constructor (options: ConnectionInputArgs | string) | ||
connection: ConnType | ||
pool?: FibPoolNS.FibPoolFunction<ConnType> | ||
connection: CONN_TYPE | ||
pool?: FibPoolNS.FibPoolFunction<CONN_TYPE> | ||
@@ -118,3 +118,3 @@ // knex: FXJSKnex.FXJSKnexModule.KnexInstance | ||
reopen: { | ||
(): ConnType | ||
(): CONN_TYPE | ||
} | ||
@@ -125,3 +125,3 @@ /** | ||
open: { | ||
(): ConnType | ||
(): CONN_TYPE | ||
} | ||
@@ -140,3 +140,9 @@ /** | ||
} | ||
/** | ||
* @description get connection instance but don't change internal status | ||
*/ | ||
getConnection (): CONN_TYPE | ||
connectionPool (callback: (connection: CONN_TYPE) => any): any | ||
[ext_key: string]: any | ||
@@ -143,0 +149,0 @@ } |
@@ -17,3 +17,3 @@ Object.defineProperty(exports, "__esModule", { value: true }); | ||
pool.timeout = Utils.forceInteger(pool.timeout, 1000); | ||
Utils.mountPoolToDb(driver); | ||
Utils.mountPoolToDriver(driver, pool); | ||
} | ||
@@ -83,3 +83,5 @@ else { | ||
*/ | ||
open() { return null; } | ||
open() { | ||
return this.connection = this.getConnection(); | ||
} | ||
/** | ||
@@ -93,2 +95,11 @@ * @override | ||
ping() { } | ||
/** | ||
* @override | ||
*/ | ||
getConnection() { return null; } | ||
connectionPool(callback) { | ||
if (this.isPool) | ||
return this.pool((conn) => callback(conn)); | ||
return callback(this.open()); | ||
} | ||
} | ||
@@ -149,13 +160,3 @@ Driver.getDriver = function getDriver(name) { | ||
} | ||
reopen() { | ||
try { | ||
this.close(); | ||
} | ||
catch (error) { } | ||
return this.open(); | ||
} | ||
open() { | ||
this.close(); | ||
return this.connection = db.openMySQL(this.uri); | ||
} | ||
open() { return super.open(); } | ||
close() { | ||
@@ -170,2 +171,3 @@ if (this.connection) | ||
rollback() { return this.connection.rollback(); } | ||
getConnection() { return db.openMySQL(this.uri); } | ||
execute(sql) { | ||
@@ -184,12 +186,3 @@ if (this.isPool) | ||
} | ||
reopen() { | ||
try { | ||
this.close(); | ||
} | ||
catch (error) { } | ||
return this.open(); | ||
} | ||
open() { | ||
return this.connection = db.openSQLite(this.uri); | ||
} | ||
open() { return super.open(); } | ||
close() { | ||
@@ -204,2 +197,3 @@ if (this.connection) | ||
rollback() { return this.connection.rollback(); } | ||
getConnection() { return db.openSQLite(this.uri); } | ||
execute(sql) { | ||
@@ -218,12 +212,3 @@ if (this.isPool) | ||
} | ||
reopen() { | ||
try { | ||
this.close(); | ||
} | ||
catch (error) { } | ||
return this.open(); | ||
} | ||
open() { | ||
return this.connection = db.openRedis(this.uri); | ||
} | ||
open() { return super.open(); } | ||
close() { | ||
@@ -253,2 +238,3 @@ if (this.connection) | ||
} | ||
getConnection() { return db.openRedis(this.uri); } | ||
} | ||
@@ -267,5 +253,3 @@ class MongoDriver extends Driver { | ||
} | ||
open() { | ||
return this.connection = db.openMongoDB(this.uri); | ||
} | ||
open() { return super.open(); } | ||
close() { | ||
@@ -286,2 +270,3 @@ if (this.connection) | ||
} | ||
getConnection() { return db.openMongoDB(this.uri); } | ||
} |
@@ -1,1 +0,1 @@ | ||
"use strict";function _interopDefault(e){return e&&"object"==typeof e&&"default"in e?e.default:e}var db=_interopDefault(require("db")),url=_interopDefault(require("url")),assert=_interopDefault(require("assert")),coroutine=_interopDefault(require("coroutine")),util=_interopDefault(require("util")),net=_interopDefault(require("net")),uuid=_interopDefault(require("uuid")),querystring=_interopDefault(require("querystring")),timers=_interopDefault(require("timers"));function unwrapExports(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}function createCommonjsModule(e,t){return e(t={exports:{}},t.exports),t.exports}function setPropertyByPath(e,t,n,o="."){if("string"==typeof t)t=t.split(o);else if(!Array.isArray(t))return;let r,i=t.shift();if(0==t.length)return void(e[i]=n);"object"!=typeof e[i]&&(e[i]={});let s=e[i]=e[i]||{};for(;t.length>0;)s[r=t.shift()]=s[r]||{},t.length>0?s=s[r]:s[r]!==n&&(s[r]=n)}function transformStringValue(e,{arrayFormat:t="comma"}={}){return"comma"===t&&"string"==typeof e&&e.indexOf(",")>-1&&(e=e.split(",")),e}var lib=function(e,{arrayFormat:t="comma"}={}){e||(e={});const n={};let o=e;if("string"==typeof o)o=querystring.parse(o).toJSON();else{if("object"!=typeof o)return n;"function"==typeof o.toJSON&&(o=o.toJSON())}return Object.keys(o).sort().forEach(e=>{const r=transformStringValue(o[e],{arrayFormat:t});e.indexOf(".")>-1?setPropertyByPath(n,e,r):n[e]=r}),n};const Pool=function(e,t,n){var o=e;util.isFunction(e)&&(o={create:e,maxsize:t,timeout:n});var r=o.create,i=o.destroy||(e=>{util.isFunction(e.close)&&e.close(),util.isFunction(e.destroy)&&e.destroy(),util.isFunction(e.dispose)&&e.dispose()});t=o.maxsize||10;var s=(n=o.timeout||6e4)/10;s<10&&(s=10);var c,u=o.retry||1,l=[],a=[],p=0,f=0,h=new coroutine.Semaphore(t);function m(){for(var e,t=(new Date).getTime();p&&t-(e=l[0]).time.getTime()>n;)l=l.slice(1),p--,void 0!==e.o&&coroutine.start(i,e.o);p?c||(c=timers.setInterval(m,s)):c&&(c.clear(),c=null)}function d(e,t,n){for(var o=0;o<a.length;o++){var r=a[o];if(r.name===e)return a.splice(o,1),r.o=t,r.e=n,void r.ev.set()}void 0===n&&(l[p++]={o:t,name:e,time:new Date})}function g(e){for(var t,n,o=0;;)try{t=r(e);break}catch(e){if(++o>=u){n=e;break}}d(e,t,n)}var y=(...e)=>{var t,n,o=e[0],r=e[1],s=o;util.isFunction(o)&&(r=o,s="");var c=!1;if(m(),h.acquire(),p)for(var u=p-1;u>=0;u--)if(l[u].name===s){c=!0,n=l[u].o,l.splice(u,1),p--;break}if(!c){coroutine.start(g,s);var y={name:s,ev:new coroutine.Event};if(a.push(y),y.ev.wait(),y.e)throw h.post(),y.e;n=y.o}f++;try{t=r(n),d(s,n)}catch(e){throw void 0!==n&&coroutine.start(i,n),e}finally{f--,h.post(),m()}return t};return y.connections=(()=>p),y.info=(()=>({maxsize:t,count:p,running:f,wait:h.count(),timeout:n})),y.clear=(()=>{n=-1,m()}),y};var lib$1=Pool,utils=createCommonjsModule(function(e,t){function n(e,t){try{e=parseInt(e)}catch(t){e=null}return(null===e||isNaN(e))&&(e=t),e}function o(e){if(!e||!0===e)return{};if("object"!=typeof e)return{};const{maxsize:t,timeout:n,retry:o}=e||{};return{maxsize:t,timeout:n,retry:o}}Object.defineProperty(t,"__esModule",{value:!0}),t.driverUUid=function(){return uuid.node().hex()},t.filterDriverType=function(e){switch(e){case"sqlite:":return"sqlite";case"mysql:":return"mysql";case"redis:":return"redis";case"mongodb:":return"mongodb";default:return"unknown"}},t.forceInteger=n,t.castQueryStringToBoolean=function(e){switch(e){case"1":case"true":case"y":return!0;case"0":case"false":case"no":case"n":case"":return!1;default:return!!e}},t.ensureSuffix=function(e="",t="//"){if(!e||"string"!=typeof e)return"";const n=e.lastIndexOf(t);return e.slice(n)!==t&&(e+=t),e},t.parseConnectionString=function(e){let t=(e=e||{})instanceof net.Url?e:null;return"string"==typeof e?e={protocol:(t=url.parse(e)).protocol||null,slashes:t.slashes||!1,query:t.query||null,username:t.username||null,password:t.password||null,host:t.host||null,hostname:t.hostname||null,port:t.port||null,href:t.href||null,database:function(e="",t="/"){return e&&"string"==typeof e?(e.slice(0,t.length)===t&&(e=e.slice(t.length)),e):""}(t.pathname,"/")||null,pathname:t.pathname||null}:"object"!=typeof e&&(e={}),e.user&&!e.username&&(e.username=e.user),delete e.user,"string"==typeof e.query&&(e.query=lib(e.query)),e.query=Object.assign({},e.query),e=Object.assign({},e),(e=util.pick(e,["protocol","slashes","query","database","username","password","host","hostname","port","href","pathname"])).slashes=!!e.slashes,e.port=n(e.port,null),e},t.parsePoolConfig=o,t.mountPoolToDb=function(e){!e.pool&&e.config.pool&&(e.pool=lib$1(Object.assign({create:()=>e.open(),destroy:e=>e.close()},o(e.config.pool))))},t.arraify=function(e){return Array.isArray(e)?e:[e]}});unwrapExports(utils);var utils_1=utils.driverUUid,utils_2=utils.filterDriverType,utils_3=utils.forceInteger,utils_4=utils.castQueryStringToBoolean,utils_5=utils.ensureSuffix,utils_6=utils.parseConnectionString,utils_7=utils.parsePoolConfig,utils_8=utils.mountPoolToDb,utils_9=utils.arraify,base_class=createCommonjsModule(function(e,t){Object.defineProperty(t,"__esModule",{value:!0});class n{constructor(e){this.extend_config={pool:!1,debug:!1},e=utils.parseConnectionString(e),Object.defineProperty(this,"config",{get:()=>e}),assert.ok(!!this.config.protocol,"[driver.config] invalid protocol"),this.type=utils.filterDriverType(this.config.protocol);const t={};Object.defineProperty(this,"extend_config",{get:()=>t}),function(e){let t=!1;Object.defineProperty(e.extend_config,"pool",{set(n){"string"==typeof n&&(n=utils.castQueryStringToBoolean(n)),n?((t=utils.parsePoolConfig(n)).maxsize=utils.forceInteger(t.maxsize,100),t.timeout=utils.forceInteger(t.timeout,1e3),utils.mountPoolToDb(e)):t=!1},get:()=>t})}(this),t.pool=e.query.pool,t.debug=utils.castQueryStringToBoolean(e.query.debug),Object.defineProperty(this,"uid",{value:utils.driverUUid(),writable:!1,configurable:!1})}static create(e){return new(n.getDriver("object"==typeof e?e.protocol:e))(e)}get uri(){return url.format(Object.assign({},this.config,{slashes:"sqlite:"!==this.config.protocol&&this.config.slashes}))}get isPool(){return!!this.extend_config.pool}get isSql(){const e=this.config.protocol||"";return"mysql:"===e||e.startsWith("sqlite:")}get isNoSql(){return"mongodb:"===(this.config.protocol||"")}get isCommand(){const e=this.config.protocol||"";return"mongodb:"===e||"redis:"===e}reopen(){try{this.close()}catch(e){}return this.open()}open(){return null}close(){}ping(){}}n.getDriver=function e(t){switch(t){case"mysql":return r;case"sqlite":return i;case"redis":return s;case"mongodb":return c;default:if(t){const n=utils.filterDriverType(url.parse(t).protocol);if("unknown"!==n)return e(n)}return n}},t.Driver=n;class o extends n{constructor(){super(...arguments),this.currentDb=null}switchDb(e){}begin(){}commit(){}trans(e){return!0}rollback(){}execute(e){}}t.SQLDriver=o;class r extends o{constructor(e){super(e),this.connection=null}switchDb(e){this.execute(db.formatMySQL("use `"+db.escape(e)+"`"))}reopen(){try{this.close()}catch(e){}return this.open()}open(){return this.close(),this.connection=db.openMySQL(this.uri)}close(){this.connection&&this.connection.close()}ping(){}begin(){return this.connection.begin()}commit(){return this.connection.commit()}trans(e){return this.connection.trans(e)}rollback(){return this.connection.rollback()}execute(e){return this.isPool?this.pool(t=>t.execute(e)):(this.connection||this.open(),this.connection.execute(e))}}class i extends o{constructor(e){super(e),this.connection=null}reopen(){try{this.close()}catch(e){}return this.open()}open(){return this.connection=db.openSQLite(this.uri)}close(){this.connection&&this.connection.close()}ping(){}begin(){return this.connection.begin()}commit(){return this.connection.commit()}trans(e){return this.connection.trans(e)}rollback(){return this.connection.rollback()}execute(e){return this.isPool?this.pool(t=>t.execute(e)):(this.connection||this.open(),this.connection.execute(e))}}class s extends n{constructor(e){super(e),this.connection=null}reopen(){try{this.close()}catch(e){}return this.open()}open(){return this.connection=db.openRedis(this.uri)}close(){this.connection&&this.connection.close()}ping(){}command(e,...t){return this.isPool?this.pool(n=>n.command(e,...t)):(this.connection||this.open(),this.connection.command(e,...t))}commands(e,t){const{parallel:n=!1}=t||{},o=Object.keys(e);return n?coroutine.parallel(o,t=>({cmd:t,result:this.command(t,...utils.arraify(e[t]))})):Object.keys(e).map(t=>({cmd:t,result:this.command(t,...utils.arraify(e[t]))}))}}class c extends n{constructor(e){super(e),this.connection=null}reopen(){try{this.close()}catch(e){}return this.open()}open(){return this.connection=db.openMongoDB(this.uri)}close(){this.connection&&this.connection.close()}ping(){}command(e,t){return this.commands({[e]:t})}commands(e,t){return this.isPool?this.pool(t=>t.runCommand(e)):(this.connection||this.open(),this.connection.runCommand(e))}}});unwrapExports(base_class);var base_class_1=base_class.Driver,base_class_2=base_class.SQLDriver,lib$2=base_class.Driver;module.exports=lib$2; | ||
"use strict";function _interopDefault(e){return e&&"object"==typeof e&&"default"in e?e.default:e}var db=_interopDefault(require("db")),url=_interopDefault(require("url")),assert=_interopDefault(require("assert")),coroutine=_interopDefault(require("coroutine")),util=_interopDefault(require("util")),net=_interopDefault(require("net")),uuid=_interopDefault(require("uuid")),querystring=_interopDefault(require("querystring")),timers=_interopDefault(require("timers"));function unwrapExports(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}function createCommonjsModule(e,t){return e(t={exports:{}},t.exports),t.exports}function setPropertyByPath(e,t,n,r="."){if("string"==typeof t)t=t.split(r);else if(!Array.isArray(t))return;let o,i=t.shift();if(0==t.length)return void(e[i]=n);"object"!=typeof e[i]&&(e[i]={});let s=e[i]=e[i]||{};for(;t.length>0;)s[o=t.shift()]=s[o]||{},t.length>0?s=s[o]:s[o]!==n&&(s[o]=n)}function transformStringValue(e,{arrayFormat:t="comma"}={}){return"comma"===t&&"string"==typeof e&&e.indexOf(",")>-1&&(e=e.split(",")),e}var lib=function(e,{arrayFormat:t="comma"}={}){e||(e={});const n={};let r=e;if("string"==typeof r)r=querystring.parse(r).toJSON();else{if("object"!=typeof r)return n;"function"==typeof r.toJSON&&(r=r.toJSON())}return Object.keys(r).sort().forEach(e=>{const o=transformStringValue(r[e],{arrayFormat:t});e.indexOf(".")>-1?setPropertyByPath(n,e,o):n[e]=o}),n};const Pool=function(e,t,n){var r=e;util.isFunction(e)&&(r={create:e,maxsize:t,timeout:n});var o=r.create,i=r.destroy||(e=>{util.isFunction(e.close)&&e.close(),util.isFunction(e.destroy)&&e.destroy(),util.isFunction(e.dispose)&&e.dispose()});t=r.maxsize||10;var s=(n=r.timeout||6e4)/10;s<10&&(s=10);var u,c=r.retry||1,l=[],a=[],p=0,f=0,h=new coroutine.Semaphore(t);function m(){for(var e,t=(new Date).getTime();p&&t-(e=l[0]).time.getTime()>n;)l=l.slice(1),p--,void 0!==e.o&&coroutine.start(i,e.o);p?u||(u=timers.setInterval(m,s)):u&&(u.clear(),u=null)}function d(e,t,n){for(var r=0;r<a.length;r++){var o=a[r];if(o.name===e)return a.splice(r,1),o.o=t,o.e=n,void o.ev.set()}void 0===n&&(l[p++]={o:t,name:e,time:new Date})}function g(e){for(var t,n,r=0;;)try{t=o(e);break}catch(e){if(++r>=c){n=e;break}}d(e,t,n)}var y=(...e)=>{var t,n,r=e[0],o=e[1],s=r;util.isFunction(r)&&(o=r,s="");var u=!1;if(m(),h.acquire(),p)for(var c=p-1;c>=0;c--)if(l[c].name===s){u=!0,n=l[c].o,l.splice(c,1),p--;break}if(!u){coroutine.start(g,s);var y={name:s,ev:new coroutine.Event};if(a.push(y),y.ev.wait(),y.e)throw h.post(),y.e;n=y.o}f++;try{t=o(n),d(s,n)}catch(e){throw void 0!==n&&coroutine.start(i,n),e}finally{f--,h.post(),m()}return t};return y.connections=(()=>p),y.info=(()=>({maxsize:t,count:p,running:f,wait:h.count(),timeout:n})),y.clear=(()=>{n=-1,m()}),y};var lib$1=Pool,utils=createCommonjsModule(function(e,t){function n(e,t){try{e=parseInt(e)}catch(t){e=null}return(null===e||isNaN(e))&&(e=t),e}function r(e){if(!e||!0===e)return{};if("object"!=typeof e)return{};const{maxsize:t,timeout:n,retry:r}=e||{};return{maxsize:t,timeout:n,retry:r}}Object.defineProperty(t,"__esModule",{value:!0}),t.driverUUid=function(){return uuid.node().hex()},t.filterDriverType=function(e){switch(e){case"sqlite:":return"sqlite";case"mysql:":return"mysql";case"redis:":return"redis";case"mongodb:":return"mongodb";default:return"unknown"}},t.forceInteger=n,t.castQueryStringToBoolean=function(e){switch(e){case"1":case"true":case"y":return!0;case"0":case"false":case"no":case"n":case"":return!1;default:return!!e}},t.ensureSuffix=function(e="",t="//"){if(!e||"string"!=typeof e)return"";const n=e.lastIndexOf(t);return e.slice(n)!==t&&(e+=t),e},t.parseConnectionString=function(e){let t=(e=e||{})instanceof net.Url?e:null;return"string"==typeof e?e={protocol:(t=url.parse(e)).protocol||null,slashes:t.slashes||!1,query:t.query||null,username:t.username||null,password:t.password||null,host:t.host||null,hostname:t.hostname||null,port:t.port||null,href:t.href||null,database:function(e="",t="/"){return e&&"string"==typeof e?(e.slice(0,t.length)===t&&(e=e.slice(t.length)),e):""}(t.pathname,"/")||null,pathname:t.pathname||null}:"object"!=typeof e&&(e={}),e.user&&!e.username&&(e.username=e.user),delete e.user,"string"==typeof e.query&&(e.query=lib(e.query)),e.query=Object.assign({},e.query),e=Object.assign({},e),(e=util.pick(e,["protocol","slashes","query","database","username","password","host","hostname","port","href","pathname"])).slashes=!!e.slashes,e.port=n(e.port,null),e},t.parsePoolConfig=r,t.mountPoolToDriver=function(e,t=e.config.pool){!e.pool&&t&&(e.pool=lib$1(Object.assign({create:()=>e.getConnection(),destroy:e=>e.close()},r(t))))},t.arraify=function(e){return Array.isArray(e)?e:[e]}});unwrapExports(utils);var utils_1=utils.driverUUid,utils_2=utils.filterDriverType,utils_3=utils.forceInteger,utils_4=utils.castQueryStringToBoolean,utils_5=utils.ensureSuffix,utils_6=utils.parseConnectionString,utils_7=utils.parsePoolConfig,utils_8=utils.mountPoolToDriver,utils_9=utils.arraify,base_class=createCommonjsModule(function(e,t){Object.defineProperty(t,"__esModule",{value:!0});class n{constructor(e){this.extend_config={pool:!1,debug:!1},e=utils.parseConnectionString(e),Object.defineProperty(this,"config",{get:()=>e}),assert.ok(!!this.config.protocol,"[driver.config] invalid protocol"),this.type=utils.filterDriverType(this.config.protocol);const t={};Object.defineProperty(this,"extend_config",{get:()=>t}),function(e){let t=!1;Object.defineProperty(e.extend_config,"pool",{set(n){"string"==typeof n&&(n=utils.castQueryStringToBoolean(n)),n?((t=utils.parsePoolConfig(n)).maxsize=utils.forceInteger(t.maxsize,100),t.timeout=utils.forceInteger(t.timeout,1e3),utils.mountPoolToDriver(e,t)):t=!1},get:()=>t})}(this),t.pool=e.query.pool,t.debug=utils.castQueryStringToBoolean(e.query.debug),Object.defineProperty(this,"uid",{value:utils.driverUUid(),writable:!1,configurable:!1})}static create(e){return new(n.getDriver("object"==typeof e?e.protocol:e))(e)}get uri(){return url.format(Object.assign({},this.config,{slashes:"sqlite:"!==this.config.protocol&&this.config.slashes}))}get isPool(){return!!this.extend_config.pool}get isSql(){const e=this.config.protocol||"";return"mysql:"===e||e.startsWith("sqlite:")}get isNoSql(){return"mongodb:"===(this.config.protocol||"")}get isCommand(){const e=this.config.protocol||"";return"mongodb:"===e||"redis:"===e}reopen(){try{this.close()}catch(e){}return this.open()}open(){return this.connection=this.getConnection()}close(){}ping(){}getConnection(){return null}connectionPool(e){return this.isPool?this.pool(t=>e(t)):e(this.open())}}n.getDriver=function e(t){switch(t){case"mysql":return o;case"sqlite":return i;case"redis":return s;case"mongodb":return u;default:if(t){const n=utils.filterDriverType(url.parse(t).protocol);if("unknown"!==n)return e(n)}return n}},t.Driver=n;class r extends n{constructor(){super(...arguments),this.currentDb=null}switchDb(e){}begin(){}commit(){}trans(e){return!0}rollback(){}execute(e){}}t.SQLDriver=r;class o extends r{constructor(e){super(e),this.connection=null}switchDb(e){this.execute(db.formatMySQL("use `"+db.escape(e)+"`"))}open(){return super.open()}close(){this.connection&&this.connection.close()}ping(){}begin(){return this.connection.begin()}commit(){return this.connection.commit()}trans(e){return this.connection.trans(e)}rollback(){return this.connection.rollback()}getConnection(){return db.openMySQL(this.uri)}execute(e){return this.isPool?this.pool(t=>t.execute(e)):(this.connection||this.open(),this.connection.execute(e))}}class i extends r{constructor(e){super(e),this.connection=null}open(){return super.open()}close(){this.connection&&this.connection.close()}ping(){}begin(){return this.connection.begin()}commit(){return this.connection.commit()}trans(e){return this.connection.trans(e)}rollback(){return this.connection.rollback()}getConnection(){return db.openSQLite(this.uri)}execute(e){return this.isPool?this.pool(t=>t.execute(e)):(this.connection||this.open(),this.connection.execute(e))}}class s extends n{constructor(e){super(e),this.connection=null}open(){return super.open()}close(){this.connection&&this.connection.close()}ping(){}command(e,...t){return this.isPool?this.pool(n=>n.command(e,...t)):(this.connection||this.open(),this.connection.command(e,...t))}commands(e,t){const{parallel:n=!1}=t||{},r=Object.keys(e);return n?coroutine.parallel(r,t=>({cmd:t,result:this.command(t,...utils.arraify(e[t]))})):Object.keys(e).map(t=>({cmd:t,result:this.command(t,...utils.arraify(e[t]))}))}getConnection(){return db.openRedis(this.uri)}}class u extends n{constructor(e){super(e),this.connection=null}reopen(){try{this.close()}catch(e){}return this.open()}open(){return super.open()}close(){this.connection&&this.connection.close()}ping(){}command(e,t){return this.commands({[e]:t})}commands(e,t){return this.isPool?this.pool(t=>t.runCommand(e)):(this.connection||this.open(),this.connection.runCommand(e))}getConnection(){return db.openMongoDB(this.uri)}}});unwrapExports(base_class);var base_class_1=base_class.Driver,base_class_2=base_class.SQLDriver,lib$2=base_class.Driver;module.exports=lib$2; |
@@ -133,11 +133,11 @@ /// <reference types="@fibjs/types" /> | ||
exports.parsePoolConfig = parsePoolConfig; | ||
function mountPoolToDb(driver) { | ||
if (!driver.pool && driver.config.pool) | ||
function mountPoolToDriver(driver, poolSetting = driver.config.pool) { | ||
if (!driver.pool && poolSetting) | ||
driver.pool = FibPool(Object.assign({ create: () => { | ||
return driver.open(); | ||
}, destroy: (driver) => { | ||
return driver.close(); | ||
} }, parsePoolConfig(driver.config.pool))); | ||
return driver.getConnection(); | ||
}, destroy: (conn) => { | ||
return conn.close(); | ||
} }, parsePoolConfig(poolSetting))); | ||
} | ||
exports.mountPoolToDb = mountPoolToDb; | ||
exports.mountPoolToDriver = mountPoolToDriver; | ||
function arraify(item) { | ||
@@ -144,0 +144,0 @@ return Array.isArray(item) ? item : [item]; |
{ | ||
"name": "@fxjs/db-driver", | ||
"version": "0.0.4", | ||
"version": "0.0.5", | ||
"description": "Fibjs Db Driver", | ||
@@ -5,0 +5,0 @@ "keywords": [ |
34106
685