generated from tpl/purs
50 lines
1.2 KiB
JavaScript
50 lines
1.2 KiB
JavaScript
'use strict';
|
|
|
|
var pg = require('pg');
|
|
|
|
exports.newPool = function(config) {
|
|
return function(onSuccess, onError) {
|
|
onSuccess(new pg.Pool(config));
|
|
};
|
|
};
|
|
|
|
exports.withConnection = function(pool) {
|
|
return function(body) {
|
|
return function(onSuccess, onError) {
|
|
pool.connect(function(err, client, done) {
|
|
if (err !== null) {
|
|
onError(err);
|
|
return;
|
|
}
|
|
body(client)(function(r) {
|
|
done();
|
|
onSuccess(r);
|
|
}, function(e) {
|
|
done();
|
|
onError(e);
|
|
});
|
|
});
|
|
};
|
|
};
|
|
};
|
|
|
|
exports._query = function(client) {
|
|
return function(sql) {
|
|
return function(values) {
|
|
return function(onSuccess, onError) {
|
|
client.query({
|
|
text: sql,
|
|
values: values,
|
|
rowMode: 'array',
|
|
}, function(err, result) {
|
|
if (err !== null) {
|
|
onError(err);
|
|
return;
|
|
}
|
|
onSuccess(result.rows);
|
|
});
|
|
};
|
|
};
|
|
};
|
|
};
|