2018-08-08 14:13:48 -05:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
|
|
module.exports = function (db, module) {
|
2019-07-09 12:46:49 -04:00
|
|
|
var helpers = require('./helpers');
|
2018-08-08 14:13:48 -05:00
|
|
|
|
|
|
|
|
var query = db.query.bind(db);
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.flushdb = async function () {
|
|
|
|
|
await query(`DROP SCHEMA "public" CASCADE`);
|
|
|
|
|
await query(`CREATE SCHEMA "public"`);
|
2018-08-08 14:13:48 -05:00
|
|
|
};
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.emptydb = async function () {
|
|
|
|
|
await query(`DELETE FROM "legacy_object"`);
|
2018-08-08 14:13:48 -05:00
|
|
|
};
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.exists = async function (key) {
|
2018-08-08 14:13:48 -05:00
|
|
|
if (!key) {
|
2019-07-09 12:46:49 -04:00
|
|
|
return;
|
2018-08-08 14:13:48 -05:00
|
|
|
}
|
|
|
|
|
|
2018-11-21 20:40:40 -05:00
|
|
|
if (Array.isArray(key)) {
|
2019-07-09 12:46:49 -04:00
|
|
|
const res = await query({
|
2018-11-21 21:10:56 -05:00
|
|
|
name: 'existsArray',
|
2018-11-21 20:40:40 -05:00
|
|
|
text: `
|
|
|
|
|
SELECT o."_key" k
|
|
|
|
|
FROM "legacy_object_live" o
|
|
|
|
|
WHERE o."_key" = ANY($1::TEXT[])`,
|
|
|
|
|
values: [key],
|
|
|
|
|
});
|
2019-07-09 12:46:49 -04:00
|
|
|
return key.map(function (k) {
|
|
|
|
|
return res.rows.some(r => r.k === k);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
const res = await query({
|
|
|
|
|
name: 'exists',
|
|
|
|
|
text: `
|
|
|
|
|
SELECT EXISTS(SELECT *
|
2018-11-21 20:40:40 -05:00
|
|
|
FROM "legacy_object_live"
|
|
|
|
|
WHERE "_key" = $1::TEXT
|
|
|
|
|
LIMIT 1) e`,
|
2019-07-09 12:46:49 -04:00
|
|
|
values: [key],
|
|
|
|
|
});
|
|
|
|
|
return res.rows[0].e;
|
2018-08-08 14:13:48 -05:00
|
|
|
};
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.delete = async function (key) {
|
2018-08-08 14:13:48 -05:00
|
|
|
if (!key) {
|
2019-07-09 12:46:49 -04:00
|
|
|
return;
|
2018-08-08 14:13:48 -05:00
|
|
|
}
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
await query({
|
2018-08-08 14:13:48 -05:00
|
|
|
name: 'delete',
|
|
|
|
|
text: `
|
|
|
|
|
DELETE FROM "legacy_object"
|
|
|
|
|
WHERE "_key" = $1::TEXT`,
|
|
|
|
|
values: [key],
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.deleteAll = async function (keys) {
|
2018-08-08 14:13:48 -05:00
|
|
|
if (!Array.isArray(keys) || !keys.length) {
|
2019-07-09 12:46:49 -04:00
|
|
|
return;
|
2018-08-08 14:13:48 -05:00
|
|
|
}
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
await query({
|
2018-08-08 14:13:48 -05:00
|
|
|
name: 'deleteAll',
|
|
|
|
|
text: `
|
|
|
|
|
DELETE FROM "legacy_object"
|
|
|
|
|
WHERE "_key" = ANY($1::TEXT[])`,
|
|
|
|
|
values: [keys],
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.get = async function (key) {
|
2018-08-08 14:13:48 -05:00
|
|
|
if (!key) {
|
2019-07-09 12:46:49 -04:00
|
|
|
return;
|
2018-08-08 14:13:48 -05:00
|
|
|
}
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
const res = await query({
|
2018-08-08 14:13:48 -05:00
|
|
|
name: 'get',
|
|
|
|
|
text: `
|
|
|
|
|
SELECT s."data" t
|
|
|
|
|
FROM "legacy_object_live" o
|
|
|
|
|
INNER JOIN "legacy_string" s
|
|
|
|
|
ON o."_key" = s."_key"
|
|
|
|
|
AND o."type" = s."type"
|
|
|
|
|
WHERE o."_key" = $1::TEXT
|
|
|
|
|
LIMIT 1`,
|
|
|
|
|
values: [key],
|
|
|
|
|
});
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
return res.rows.length ? res.rows[0].t : null;
|
|
|
|
|
};
|
2018-08-08 14:13:48 -05:00
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.set = async function (key, value) {
|
2018-08-08 14:13:48 -05:00
|
|
|
if (!key) {
|
2019-07-09 12:46:49 -04:00
|
|
|
return;
|
2018-08-08 14:13:48 -05:00
|
|
|
}
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
await module.transaction(async function (client) {
|
|
|
|
|
var query = client.query.bind(client);
|
|
|
|
|
await helpers.ensureLegacyObjectType(client, key, 'string');
|
|
|
|
|
await query({
|
|
|
|
|
name: 'set',
|
|
|
|
|
text: `
|
2018-08-08 14:13:48 -05:00
|
|
|
INSERT INTO "legacy_string" ("_key", "data")
|
|
|
|
|
VALUES ($1::TEXT, $2::TEXT)
|
2019-07-09 12:46:49 -04:00
|
|
|
ON CONFLICT ("_key")
|
|
|
|
|
DO UPDATE SET "data" = $2::TEXT`,
|
|
|
|
|
values: [key, value],
|
2018-08-08 14:13:48 -05:00
|
|
|
});
|
2019-07-09 12:46:49 -04:00
|
|
|
});
|
2018-08-08 14:13:48 -05:00
|
|
|
};
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.increment = async function (key) {
|
2018-08-08 14:13:48 -05:00
|
|
|
if (!key) {
|
2019-07-09 12:46:49 -04:00
|
|
|
return;
|
2018-08-08 14:13:48 -05:00
|
|
|
}
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
return await module.transaction(async function (client) {
|
|
|
|
|
var query = client.query.bind(client);
|
|
|
|
|
await helpers.ensureLegacyObjectType(client, key, 'string');
|
|
|
|
|
const res = await query({
|
|
|
|
|
name: 'increment',
|
|
|
|
|
text: `
|
2018-08-08 14:13:48 -05:00
|
|
|
INSERT INTO "legacy_string" ("_key", "data")
|
|
|
|
|
VALUES ($1::TEXT, '1')
|
2019-07-09 12:46:49 -04:00
|
|
|
ON CONFLICT ("_key")
|
|
|
|
|
DO UPDATE SET "data" = ("legacy_string"."data"::NUMERIC + 1)::TEXT
|
2018-08-08 14:13:48 -05:00
|
|
|
RETURNING "data" d`,
|
2019-07-09 12:46:49 -04:00
|
|
|
values: [key],
|
2018-08-08 14:13:48 -05:00
|
|
|
});
|
2019-07-09 12:46:49 -04:00
|
|
|
return parseFloat(res.rows[0].d);
|
|
|
|
|
});
|
2018-08-08 14:13:48 -05:00
|
|
|
};
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.rename = async function (oldKey, newKey) {
|
|
|
|
|
await module.transaction(async function (client) {
|
|
|
|
|
var query = client.query.bind(client);
|
|
|
|
|
await query({
|
|
|
|
|
name: 'deleteRename',
|
|
|
|
|
text: `
|
|
|
|
|
DELETE FROM "legacy_object"
|
|
|
|
|
WHERE "_key" = $1::TEXT`,
|
|
|
|
|
values: [newKey],
|
|
|
|
|
});
|
|
|
|
|
await query({
|
|
|
|
|
name: 'rename',
|
|
|
|
|
text: `
|
2018-08-08 14:13:48 -05:00
|
|
|
UPDATE "legacy_object"
|
2019-07-09 12:46:49 -04:00
|
|
|
SET "_key" = $2::TEXT
|
|
|
|
|
WHERE "_key" = $1::TEXT`,
|
|
|
|
|
values: [oldKey, newKey],
|
2018-08-08 14:13:48 -05:00
|
|
|
});
|
2019-07-09 12:46:49 -04:00
|
|
|
});
|
2018-08-08 14:13:48 -05:00
|
|
|
};
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.type = async function (key) {
|
|
|
|
|
const res = await query({
|
2018-08-08 14:13:48 -05:00
|
|
|
name: 'type',
|
|
|
|
|
text: `
|
|
|
|
|
SELECT "type"::TEXT t
|
|
|
|
|
FROM "legacy_object_live"
|
|
|
|
|
WHERE "_key" = $1::TEXT
|
|
|
|
|
LIMIT 1`,
|
|
|
|
|
values: [key],
|
|
|
|
|
});
|
2019-07-09 12:46:49 -04:00
|
|
|
|
|
|
|
|
return res.rows.length ? res.rows[0].t : null;
|
2018-08-08 14:13:48 -05:00
|
|
|
};
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
async function doExpire(key, date) {
|
|
|
|
|
await query({
|
2018-08-08 14:13:48 -05:00
|
|
|
name: 'expire',
|
|
|
|
|
text: `
|
|
|
|
|
UPDATE "legacy_object"
|
|
|
|
|
SET "expireAt" = $2::TIMESTAMPTZ
|
|
|
|
|
WHERE "_key" = $1::TEXT`,
|
|
|
|
|
values: [key, date],
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.expire = async function (key, seconds) {
|
|
|
|
|
await doExpire(key, new Date(((Date.now() / 1000) + seconds) * 1000));
|
2018-08-08 14:13:48 -05:00
|
|
|
};
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.expireAt = async function (key, timestamp) {
|
|
|
|
|
await doExpire(key, new Date(timestamp * 1000));
|
2018-08-08 14:13:48 -05:00
|
|
|
};
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.pexpire = async function (key, ms) {
|
|
|
|
|
await doExpire(key, new Date(Date.now() + parseInt(ms, 10)));
|
2018-08-08 14:13:48 -05:00
|
|
|
};
|
|
|
|
|
|
2019-07-09 12:46:49 -04:00
|
|
|
module.pexpireAt = async function (key, timestamp) {
|
|
|
|
|
await doExpire(key, new Date(timestamp));
|
2018-08-08 14:13:48 -05:00
|
|
|
};
|
|
|
|
|
};
|