UNPKG

orange-orm

Version:

Object Relational Mapper

82 lines (75 loc) 2.05 kB
var wrapQuery = require('./wrapQuery'); var encodeDate = require('../pg/encodeDate'); const encodeBinary = require('../nodeSqlite/encodeBinary'); const decodeBinary = require('../nodeSqlite/decodeBinary'); var deleteFromSql = require('../pg/deleteFromSql'); var selectForUpdateSql = require('../pg/selectForUpdateSql'); var limitAndOffset = require('../pg/limitAndOffset'); var formatDateOut = require('../pg/formatDateOut'); var insertSql = require('../pg/insertSql'); var insert = require('../pg/insert'); var quote = require('../pg/quote'); function newResolveTransaction(domain, pool, { readonly = false } = {}) { var rdb = { poolFactory: pool }; if (!pool.connect) pool = pool(); rdb.engine = 'pg'; rdb.encodeDate = encodeDate; rdb.encodeBinary = encodeBinary; rdb.decodeBinary = decodeBinary; rdb.formatDateOut = formatDateOut; rdb.deleteFromSql = deleteFromSql; rdb.selectForUpdateSql = selectForUpdateSql; rdb.lastInsertedIsSeparate = false; rdb.insertSql = insertSql; rdb.insert = insert; rdb.multipleStatements = true; rdb.limitAndOffset = limitAndOffset; rdb.accept = function(caller) { caller.visitPg(); }; rdb.aggregateCount = 0; rdb.quote = quote; rdb.cache = {}; if (readonly) { rdb.dbClient = { executeQuery: function(query, callback) { pool.connect((err, client, done) => { if (err) { return callback(err); } try { wrapQuery(domain, client)(query, (err, res) => { done(); callback(err, res); }); } catch (e) { done(); callback(e); } }); } }; domain.rdb = rdb; return (onSuccess) => onSuccess(); } return function(onSuccess, onError) { pool.connect(onConnected); function onConnected(err, client, done) { try { if (err) { onError(err); return; } client.executeQuery = wrapQuery(domain, client); rdb.dbClient = client; rdb.dbClientDone = done; domain.rdb = rdb; onSuccess(); } catch (e) { onError(e); } } }; } module.exports = newResolveTransaction;