@keyv/sqlite 4.0.0 → 4.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +164 -0
- package/dist/{esm/index.d.ts → index.d.cts} +20 -3
- package/dist/{cjs/index.d.ts → index.d.ts} +20 -3
- package/dist/index.js +129 -0
- package/package.json +9 -7
- package/dist/cjs/index.js +0 -141
- package/dist/cjs/index.js.map +0 -1
- package/dist/cjs/types.d.ts +0 -19
- package/dist/cjs/types.js +0 -3
- package/dist/cjs/types.js.map +0 -1
- package/dist/esm/index.js +0 -136
- package/dist/esm/index.js.map +0 -1
- package/dist/esm/types.d.ts +0 -19
- package/dist/esm/types.js +0 -2
- package/dist/esm/types.js.map +0 -1
package/dist/index.cjs
ADDED
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __export = (target, all) => {
|
|
9
|
+
for (var name in all)
|
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
+
};
|
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
+
for (let key of __getOwnPropNames(from))
|
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
+
}
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
+
|
|
30
|
+
// src/index.ts
|
|
31
|
+
var src_exports = {};
|
|
32
|
+
__export(src_exports, {
|
|
33
|
+
KeyvSqlite: () => KeyvSqlite,
|
|
34
|
+
default: () => src_default
|
|
35
|
+
});
|
|
36
|
+
module.exports = __toCommonJS(src_exports);
|
|
37
|
+
var import_events = __toESM(require("events"), 1);
|
|
38
|
+
var import_util = require("util");
|
|
39
|
+
var import_sqlite3 = __toESM(require("sqlite3"), 1);
|
|
40
|
+
var toString = (input) => String(input).search(/^[a-zA-Z]+$/) < 0 ? "_" + input : input;
|
|
41
|
+
var KeyvSqlite = class extends import_events.default {
|
|
42
|
+
ttlSupport;
|
|
43
|
+
opts;
|
|
44
|
+
namespace;
|
|
45
|
+
close;
|
|
46
|
+
query;
|
|
47
|
+
constructor(keyvOptions) {
|
|
48
|
+
super();
|
|
49
|
+
this.ttlSupport = false;
|
|
50
|
+
let options = {
|
|
51
|
+
dialect: "sqlite",
|
|
52
|
+
uri: "sqlite://:memory:"
|
|
53
|
+
};
|
|
54
|
+
if (typeof keyvOptions === "string") {
|
|
55
|
+
options.uri = keyvOptions;
|
|
56
|
+
} else {
|
|
57
|
+
options = {
|
|
58
|
+
...options,
|
|
59
|
+
...keyvOptions
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
options.db = options.uri.replace(/^sqlite:\/\//, "");
|
|
63
|
+
options.connect = async () => new Promise((resolve, reject) => {
|
|
64
|
+
const database = new import_sqlite3.default.Database(options.db, (error) => {
|
|
65
|
+
if (error) {
|
|
66
|
+
reject(error);
|
|
67
|
+
} else {
|
|
68
|
+
if (options.busyTimeout) {
|
|
69
|
+
database.configure("busyTimeout", options.busyTimeout);
|
|
70
|
+
}
|
|
71
|
+
resolve(database);
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
}).then((database) => ({ query: (0, import_util.promisify)(database.all).bind(database), close: (0, import_util.promisify)(database.close).bind(database) }));
|
|
75
|
+
this.opts = {
|
|
76
|
+
table: "keyv",
|
|
77
|
+
keySize: 255,
|
|
78
|
+
...options
|
|
79
|
+
};
|
|
80
|
+
this.opts.table = toString(this.opts.table);
|
|
81
|
+
const createTable = `CREATE TABLE IF NOT EXISTS ${this.opts.table}(key VARCHAR(${Number(this.opts.keySize)}) PRIMARY KEY, value TEXT )`;
|
|
82
|
+
const connected = this.opts.connect().then(async (database) => database.query(createTable).then(() => database)).catch((error) => this.emit("error", error));
|
|
83
|
+
this.query = async (sqlString, ...parameter) => connected.then(async (database) => database.query(sqlString, ...parameter));
|
|
84
|
+
this.close = async () => connected.then((database) => database.close);
|
|
85
|
+
}
|
|
86
|
+
async get(key) {
|
|
87
|
+
const select = `SELECT * FROM ${this.opts.table} WHERE key = ?`;
|
|
88
|
+
const rows = await this.query(select, key);
|
|
89
|
+
const row = rows[0];
|
|
90
|
+
if (row === void 0) {
|
|
91
|
+
return void 0;
|
|
92
|
+
}
|
|
93
|
+
return row.value;
|
|
94
|
+
}
|
|
95
|
+
async getMany(keys) {
|
|
96
|
+
const select = `SELECT * FROM ${this.opts.table} WHERE key IN (SELECT value FROM json_each(?))`;
|
|
97
|
+
const rows = await this.query(select, JSON.stringify(keys));
|
|
98
|
+
return keys.map((key) => {
|
|
99
|
+
const row = rows.find((row2) => row2.key === key);
|
|
100
|
+
return row ? row.value : void 0;
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
async set(key, value) {
|
|
104
|
+
const upsert = `INSERT INTO ${this.opts.table} (key, value)
|
|
105
|
+
VALUES(?, ?)
|
|
106
|
+
ON CONFLICT(key)
|
|
107
|
+
DO UPDATE SET value=excluded.value;`;
|
|
108
|
+
return this.query(upsert, key, value);
|
|
109
|
+
}
|
|
110
|
+
async delete(key) {
|
|
111
|
+
const select = `SELECT * FROM ${this.opts.table} WHERE key = ?`;
|
|
112
|
+
const del = `DELETE FROM ${this.opts.table} WHERE key = ?`;
|
|
113
|
+
const rows = await this.query(select, key);
|
|
114
|
+
const row = rows[0];
|
|
115
|
+
if (row === void 0) {
|
|
116
|
+
return false;
|
|
117
|
+
}
|
|
118
|
+
await this.query(del, key);
|
|
119
|
+
return true;
|
|
120
|
+
}
|
|
121
|
+
async deleteMany(keys) {
|
|
122
|
+
const del = `DELETE FROM ${this.opts.table} WHERE key IN (SELECT value FROM json_each(?))`;
|
|
123
|
+
const results = await this.getMany(keys);
|
|
124
|
+
if (results.every((x) => x === void 0)) {
|
|
125
|
+
return false;
|
|
126
|
+
}
|
|
127
|
+
await this.query(del, JSON.stringify(keys));
|
|
128
|
+
return true;
|
|
129
|
+
}
|
|
130
|
+
async clear() {
|
|
131
|
+
const del = `DELETE FROM ${this.opts.table} WHERE key LIKE ?`;
|
|
132
|
+
await this.query(del, this.namespace ? `${this.namespace}:%` : "%");
|
|
133
|
+
}
|
|
134
|
+
async *iterator(namespace) {
|
|
135
|
+
const limit = Number.parseInt(this.opts.iterationLimit, 10) || 10;
|
|
136
|
+
async function* iterate(offset, options, query) {
|
|
137
|
+
const select = `SELECT * FROM ${options.table} WHERE key LIKE ? LIMIT ? OFFSET ?`;
|
|
138
|
+
const iterator = await query(select, [`${namespace ? namespace + ":" : ""}%`, limit, offset]);
|
|
139
|
+
const entries = [...iterator];
|
|
140
|
+
if (entries.length === 0) {
|
|
141
|
+
return;
|
|
142
|
+
}
|
|
143
|
+
for (const entry of entries) {
|
|
144
|
+
offset += 1;
|
|
145
|
+
yield [entry.key, entry.value];
|
|
146
|
+
}
|
|
147
|
+
yield* iterate(offset, options, query);
|
|
148
|
+
}
|
|
149
|
+
yield* iterate(0, this.opts, this.query);
|
|
150
|
+
}
|
|
151
|
+
async has(key) {
|
|
152
|
+
const exists = `SELECT EXISTS ( SELECT * FROM ${this.opts.table} WHERE key = ? )`;
|
|
153
|
+
const result = await this.query(exists, key);
|
|
154
|
+
return Object.values(result[0])[0] === 1;
|
|
155
|
+
}
|
|
156
|
+
async disconnect() {
|
|
157
|
+
await this.close();
|
|
158
|
+
}
|
|
159
|
+
};
|
|
160
|
+
var src_default = KeyvSqlite;
|
|
161
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
162
|
+
0 && (module.exports = {
|
|
163
|
+
KeyvSqlite
|
|
164
|
+
});
|
|
@@ -1,6 +1,22 @@
|
|
|
1
1
|
import EventEmitter from 'events';
|
|
2
|
-
import {
|
|
3
|
-
|
|
2
|
+
import { KeyvStoreAdapter, StoredData } from 'keyv';
|
|
3
|
+
|
|
4
|
+
type DbQuery = (sqlString: string, ...parameter: unknown[]) => Promise<any>;
|
|
5
|
+
type DbClose = () => Promise<void>;
|
|
6
|
+
type KeyvSqliteOptions = {
|
|
7
|
+
dialect?: string;
|
|
8
|
+
uri?: string;
|
|
9
|
+
busyTimeout?: number;
|
|
10
|
+
table?: string;
|
|
11
|
+
keySize?: number;
|
|
12
|
+
db?: string;
|
|
13
|
+
iterationLimit?: number | string;
|
|
14
|
+
connect?: () => Promise<{
|
|
15
|
+
query: DbQuery;
|
|
16
|
+
close: DbClose;
|
|
17
|
+
}>;
|
|
18
|
+
};
|
|
19
|
+
|
|
4
20
|
declare class KeyvSqlite extends EventEmitter implements KeyvStoreAdapter {
|
|
5
21
|
ttlSupport: boolean;
|
|
6
22
|
opts: KeyvSqliteOptions;
|
|
@@ -18,4 +34,5 @@ declare class KeyvSqlite extends EventEmitter implements KeyvStoreAdapter {
|
|
|
18
34
|
has(key: string): Promise<boolean>;
|
|
19
35
|
disconnect(): Promise<void>;
|
|
20
36
|
}
|
|
21
|
-
|
|
37
|
+
|
|
38
|
+
export { KeyvSqlite, KeyvSqlite as default };
|
|
@@ -1,6 +1,22 @@
|
|
|
1
1
|
import EventEmitter from 'events';
|
|
2
|
-
import {
|
|
3
|
-
|
|
2
|
+
import { KeyvStoreAdapter, StoredData } from 'keyv';
|
|
3
|
+
|
|
4
|
+
type DbQuery = (sqlString: string, ...parameter: unknown[]) => Promise<any>;
|
|
5
|
+
type DbClose = () => Promise<void>;
|
|
6
|
+
type KeyvSqliteOptions = {
|
|
7
|
+
dialect?: string;
|
|
8
|
+
uri?: string;
|
|
9
|
+
busyTimeout?: number;
|
|
10
|
+
table?: string;
|
|
11
|
+
keySize?: number;
|
|
12
|
+
db?: string;
|
|
13
|
+
iterationLimit?: number | string;
|
|
14
|
+
connect?: () => Promise<{
|
|
15
|
+
query: DbQuery;
|
|
16
|
+
close: DbClose;
|
|
17
|
+
}>;
|
|
18
|
+
};
|
|
19
|
+
|
|
4
20
|
declare class KeyvSqlite extends EventEmitter implements KeyvStoreAdapter {
|
|
5
21
|
ttlSupport: boolean;
|
|
6
22
|
opts: KeyvSqliteOptions;
|
|
@@ -18,4 +34,5 @@ declare class KeyvSqlite extends EventEmitter implements KeyvStoreAdapter {
|
|
|
18
34
|
has(key: string): Promise<boolean>;
|
|
19
35
|
disconnect(): Promise<void>;
|
|
20
36
|
}
|
|
21
|
-
|
|
37
|
+
|
|
38
|
+
export { KeyvSqlite, KeyvSqlite as default };
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
// src/index.ts
|
|
2
|
+
import EventEmitter from "events";
|
|
3
|
+
import { promisify } from "util";
|
|
4
|
+
import sqlite3 from "sqlite3";
|
|
5
|
+
var toString = (input) => String(input).search(/^[a-zA-Z]+$/) < 0 ? "_" + input : input;
|
|
6
|
+
var KeyvSqlite = class extends EventEmitter {
|
|
7
|
+
ttlSupport;
|
|
8
|
+
opts;
|
|
9
|
+
namespace;
|
|
10
|
+
close;
|
|
11
|
+
query;
|
|
12
|
+
constructor(keyvOptions) {
|
|
13
|
+
super();
|
|
14
|
+
this.ttlSupport = false;
|
|
15
|
+
let options = {
|
|
16
|
+
dialect: "sqlite",
|
|
17
|
+
uri: "sqlite://:memory:"
|
|
18
|
+
};
|
|
19
|
+
if (typeof keyvOptions === "string") {
|
|
20
|
+
options.uri = keyvOptions;
|
|
21
|
+
} else {
|
|
22
|
+
options = {
|
|
23
|
+
...options,
|
|
24
|
+
...keyvOptions
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
options.db = options.uri.replace(/^sqlite:\/\//, "");
|
|
28
|
+
options.connect = async () => new Promise((resolve, reject) => {
|
|
29
|
+
const database = new sqlite3.Database(options.db, (error) => {
|
|
30
|
+
if (error) {
|
|
31
|
+
reject(error);
|
|
32
|
+
} else {
|
|
33
|
+
if (options.busyTimeout) {
|
|
34
|
+
database.configure("busyTimeout", options.busyTimeout);
|
|
35
|
+
}
|
|
36
|
+
resolve(database);
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
}).then((database) => ({ query: promisify(database.all).bind(database), close: promisify(database.close).bind(database) }));
|
|
40
|
+
this.opts = {
|
|
41
|
+
table: "keyv",
|
|
42
|
+
keySize: 255,
|
|
43
|
+
...options
|
|
44
|
+
};
|
|
45
|
+
this.opts.table = toString(this.opts.table);
|
|
46
|
+
const createTable = `CREATE TABLE IF NOT EXISTS ${this.opts.table}(key VARCHAR(${Number(this.opts.keySize)}) PRIMARY KEY, value TEXT )`;
|
|
47
|
+
const connected = this.opts.connect().then(async (database) => database.query(createTable).then(() => database)).catch((error) => this.emit("error", error));
|
|
48
|
+
this.query = async (sqlString, ...parameter) => connected.then(async (database) => database.query(sqlString, ...parameter));
|
|
49
|
+
this.close = async () => connected.then((database) => database.close);
|
|
50
|
+
}
|
|
51
|
+
async get(key) {
|
|
52
|
+
const select = `SELECT * FROM ${this.opts.table} WHERE key = ?`;
|
|
53
|
+
const rows = await this.query(select, key);
|
|
54
|
+
const row = rows[0];
|
|
55
|
+
if (row === void 0) {
|
|
56
|
+
return void 0;
|
|
57
|
+
}
|
|
58
|
+
return row.value;
|
|
59
|
+
}
|
|
60
|
+
async getMany(keys) {
|
|
61
|
+
const select = `SELECT * FROM ${this.opts.table} WHERE key IN (SELECT value FROM json_each(?))`;
|
|
62
|
+
const rows = await this.query(select, JSON.stringify(keys));
|
|
63
|
+
return keys.map((key) => {
|
|
64
|
+
const row = rows.find((row2) => row2.key === key);
|
|
65
|
+
return row ? row.value : void 0;
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
async set(key, value) {
|
|
69
|
+
const upsert = `INSERT INTO ${this.opts.table} (key, value)
|
|
70
|
+
VALUES(?, ?)
|
|
71
|
+
ON CONFLICT(key)
|
|
72
|
+
DO UPDATE SET value=excluded.value;`;
|
|
73
|
+
return this.query(upsert, key, value);
|
|
74
|
+
}
|
|
75
|
+
async delete(key) {
|
|
76
|
+
const select = `SELECT * FROM ${this.opts.table} WHERE key = ?`;
|
|
77
|
+
const del = `DELETE FROM ${this.opts.table} WHERE key = ?`;
|
|
78
|
+
const rows = await this.query(select, key);
|
|
79
|
+
const row = rows[0];
|
|
80
|
+
if (row === void 0) {
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
await this.query(del, key);
|
|
84
|
+
return true;
|
|
85
|
+
}
|
|
86
|
+
async deleteMany(keys) {
|
|
87
|
+
const del = `DELETE FROM ${this.opts.table} WHERE key IN (SELECT value FROM json_each(?))`;
|
|
88
|
+
const results = await this.getMany(keys);
|
|
89
|
+
if (results.every((x) => x === void 0)) {
|
|
90
|
+
return false;
|
|
91
|
+
}
|
|
92
|
+
await this.query(del, JSON.stringify(keys));
|
|
93
|
+
return true;
|
|
94
|
+
}
|
|
95
|
+
async clear() {
|
|
96
|
+
const del = `DELETE FROM ${this.opts.table} WHERE key LIKE ?`;
|
|
97
|
+
await this.query(del, this.namespace ? `${this.namespace}:%` : "%");
|
|
98
|
+
}
|
|
99
|
+
async *iterator(namespace) {
|
|
100
|
+
const limit = Number.parseInt(this.opts.iterationLimit, 10) || 10;
|
|
101
|
+
async function* iterate(offset, options, query) {
|
|
102
|
+
const select = `SELECT * FROM ${options.table} WHERE key LIKE ? LIMIT ? OFFSET ?`;
|
|
103
|
+
const iterator = await query(select, [`${namespace ? namespace + ":" : ""}%`, limit, offset]);
|
|
104
|
+
const entries = [...iterator];
|
|
105
|
+
if (entries.length === 0) {
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
for (const entry of entries) {
|
|
109
|
+
offset += 1;
|
|
110
|
+
yield [entry.key, entry.value];
|
|
111
|
+
}
|
|
112
|
+
yield* iterate(offset, options, query);
|
|
113
|
+
}
|
|
114
|
+
yield* iterate(0, this.opts, this.query);
|
|
115
|
+
}
|
|
116
|
+
async has(key) {
|
|
117
|
+
const exists = `SELECT EXISTS ( SELECT * FROM ${this.opts.table} WHERE key = ? )`;
|
|
118
|
+
const result = await this.query(exists, key);
|
|
119
|
+
return Object.values(result[0])[0] === 1;
|
|
120
|
+
}
|
|
121
|
+
async disconnect() {
|
|
122
|
+
await this.close();
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
var src_default = KeyvSqlite;
|
|
126
|
+
export {
|
|
127
|
+
KeyvSqlite,
|
|
128
|
+
src_default as default
|
|
129
|
+
};
|
package/package.json
CHANGED
|
@@ -1,18 +1,19 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@keyv/sqlite",
|
|
3
|
-
"version": "4.0.
|
|
3
|
+
"version": "4.0.1",
|
|
4
4
|
"description": "SQLite storage adapter for Keyv",
|
|
5
|
-
"
|
|
6
|
-
"
|
|
7
|
-
"
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "dist/index.cjs",
|
|
7
|
+
"module": "dist/index.js",
|
|
8
|
+
"types": "dist/index.d.ts",
|
|
8
9
|
"exports": {
|
|
9
10
|
".": {
|
|
10
|
-
"require": "./dist/
|
|
11
|
-
"import": "./dist/
|
|
11
|
+
"require": "./dist/index.cjs",
|
|
12
|
+
"import": "./dist/index.js"
|
|
12
13
|
}
|
|
13
14
|
},
|
|
14
15
|
"scripts": {
|
|
15
|
-
"build": "rm -rf dist &&
|
|
16
|
+
"build": "rm -rf dist && tsup src/index.ts --format cjs,esm --dts --clean",
|
|
16
17
|
"prepare": "yarn build",
|
|
17
18
|
"test": "xo --fix && vitest run --coverage",
|
|
18
19
|
"test:ci": "xo && vitest --run --sequence.setupFiles=list",
|
|
@@ -20,6 +21,7 @@
|
|
|
20
21
|
},
|
|
21
22
|
"xo": {
|
|
22
23
|
"rules": {
|
|
24
|
+
"import/no-named-as-default": "off",
|
|
23
25
|
"unicorn/prefer-module": "off",
|
|
24
26
|
"n/file-extension-in-import": "off",
|
|
25
27
|
"unicorn/prefer-event-target": "off",
|
package/dist/cjs/index.js
DELETED
|
@@ -1,141 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const events_1 = __importDefault(require("events"));
|
|
7
|
-
const util_1 = require("util");
|
|
8
|
-
const sqlite3_1 = __importDefault(require("sqlite3"));
|
|
9
|
-
const toString = (input) => String(input).search(/^[a-zA-Z]+$/) < 0 ? '_' + input : input;
|
|
10
|
-
class KeyvSqlite extends events_1.default {
|
|
11
|
-
ttlSupport;
|
|
12
|
-
opts;
|
|
13
|
-
namespace;
|
|
14
|
-
close;
|
|
15
|
-
query;
|
|
16
|
-
constructor(keyvOptions) {
|
|
17
|
-
super();
|
|
18
|
-
this.ttlSupport = false;
|
|
19
|
-
let options = {
|
|
20
|
-
dialect: 'sqlite',
|
|
21
|
-
uri: 'sqlite://:memory:',
|
|
22
|
-
};
|
|
23
|
-
if (typeof keyvOptions === 'string') {
|
|
24
|
-
options.uri = keyvOptions;
|
|
25
|
-
}
|
|
26
|
-
else {
|
|
27
|
-
options = {
|
|
28
|
-
...options,
|
|
29
|
-
...keyvOptions,
|
|
30
|
-
};
|
|
31
|
-
}
|
|
32
|
-
options.db = options.uri.replace(/^sqlite:\/\//, '');
|
|
33
|
-
options.connect = async () => new Promise((resolve, reject) => {
|
|
34
|
-
const database = new sqlite3_1.default.Database(options.db, error => {
|
|
35
|
-
/* c8 ignore next 2 */
|
|
36
|
-
if (error) {
|
|
37
|
-
reject(error);
|
|
38
|
-
}
|
|
39
|
-
else {
|
|
40
|
-
if (options.busyTimeout) {
|
|
41
|
-
database.configure('busyTimeout', options.busyTimeout);
|
|
42
|
-
}
|
|
43
|
-
resolve(database);
|
|
44
|
-
}
|
|
45
|
-
});
|
|
46
|
-
})
|
|
47
|
-
// @ts-expect-error - db is unknown
|
|
48
|
-
.then(database => ({ query: (0, util_1.promisify)(database.all).bind(database), close: (0, util_1.promisify)(database.close).bind(database) }));
|
|
49
|
-
this.opts = {
|
|
50
|
-
table: 'keyv',
|
|
51
|
-
keySize: 255,
|
|
52
|
-
...options,
|
|
53
|
-
};
|
|
54
|
-
this.opts.table = toString(this.opts.table);
|
|
55
|
-
const createTable = `CREATE TABLE IF NOT EXISTS ${this.opts.table}(key VARCHAR(${Number(this.opts.keySize)}) PRIMARY KEY, value TEXT )`;
|
|
56
|
-
// @ts-expect-error - db is
|
|
57
|
-
const connected = this.opts.connect()
|
|
58
|
-
.then(async (database) => database.query(createTable).then(() => database))
|
|
59
|
-
.catch(error => this.emit('error', error));
|
|
60
|
-
this.query = async (sqlString, ...parameter) => connected
|
|
61
|
-
.then(async (database) => database.query(sqlString, ...parameter));
|
|
62
|
-
this.close = async () => connected.then(database => database.close);
|
|
63
|
-
}
|
|
64
|
-
async get(key) {
|
|
65
|
-
const select = `SELECT * FROM ${this.opts.table} WHERE key = ?`;
|
|
66
|
-
const rows = await this.query(select, key);
|
|
67
|
-
const row = rows[0];
|
|
68
|
-
if (row === undefined) {
|
|
69
|
-
return undefined;
|
|
70
|
-
}
|
|
71
|
-
return row.value;
|
|
72
|
-
}
|
|
73
|
-
async getMany(keys) {
|
|
74
|
-
const select = `SELECT * FROM ${this.opts.table} WHERE key IN (SELECT value FROM json_each(?))`;
|
|
75
|
-
const rows = await this.query(select, JSON.stringify(keys));
|
|
76
|
-
return keys.map(key => {
|
|
77
|
-
const row = rows.find((row) => row.key === key);
|
|
78
|
-
return (row ? row.value : undefined);
|
|
79
|
-
});
|
|
80
|
-
}
|
|
81
|
-
async set(key, value) {
|
|
82
|
-
const upsert = `INSERT INTO ${this.opts.table} (key, value)
|
|
83
|
-
VALUES(?, ?)
|
|
84
|
-
ON CONFLICT(key)
|
|
85
|
-
DO UPDATE SET value=excluded.value;`;
|
|
86
|
-
return this.query(upsert, key, value);
|
|
87
|
-
}
|
|
88
|
-
async delete(key) {
|
|
89
|
-
const select = `SELECT * FROM ${this.opts.table} WHERE key = ?`;
|
|
90
|
-
const del = `DELETE FROM ${this.opts.table} WHERE key = ?`;
|
|
91
|
-
const rows = await this.query(select, key);
|
|
92
|
-
const row = rows[0];
|
|
93
|
-
if (row === undefined) {
|
|
94
|
-
return false;
|
|
95
|
-
}
|
|
96
|
-
await this.query(del, key);
|
|
97
|
-
return true;
|
|
98
|
-
}
|
|
99
|
-
async deleteMany(keys) {
|
|
100
|
-
const del = `DELETE FROM ${this.opts.table} WHERE key IN (SELECT value FROM json_each(?))`;
|
|
101
|
-
const results = await this.getMany(keys);
|
|
102
|
-
if (results.every(x => x === undefined)) {
|
|
103
|
-
return false;
|
|
104
|
-
}
|
|
105
|
-
await this.query(del, JSON.stringify(keys));
|
|
106
|
-
return true;
|
|
107
|
-
}
|
|
108
|
-
async clear() {
|
|
109
|
-
const del = `DELETE FROM ${this.opts.table} WHERE key LIKE ?`;
|
|
110
|
-
await this.query(del, this.namespace ? `${this.namespace}:%` : '%');
|
|
111
|
-
}
|
|
112
|
-
async *iterator(namespace) {
|
|
113
|
-
const limit = Number.parseInt(this.opts.iterationLimit, 10) || 10;
|
|
114
|
-
// @ts-expect-error - iterate
|
|
115
|
-
async function* iterate(offset, options, query) {
|
|
116
|
-
const select = `SELECT * FROM ${options.table} WHERE key LIKE ? LIMIT ? OFFSET ?`;
|
|
117
|
-
const iterator = await query(select, [`${namespace ? namespace + ':' : ''}%`, limit, offset]);
|
|
118
|
-
const entries = [...iterator];
|
|
119
|
-
if (entries.length === 0) {
|
|
120
|
-
return;
|
|
121
|
-
}
|
|
122
|
-
for (const entry of entries) {
|
|
123
|
-
offset += 1;
|
|
124
|
-
yield [entry.key, entry.value];
|
|
125
|
-
}
|
|
126
|
-
yield* iterate(offset, options, query);
|
|
127
|
-
}
|
|
128
|
-
yield* iterate(0, this.opts, this.query);
|
|
129
|
-
}
|
|
130
|
-
async has(key) {
|
|
131
|
-
const exists = `SELECT EXISTS ( SELECT * FROM ${this.opts.table} WHERE key = ? )`;
|
|
132
|
-
const result = await this.query(exists, key);
|
|
133
|
-
return Object.values(result[0])[0] === 1;
|
|
134
|
-
}
|
|
135
|
-
async disconnect() {
|
|
136
|
-
await this.close();
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
exports.default = KeyvSqlite;
|
|
140
|
-
module.exports = KeyvSqlite;
|
|
141
|
-
//# sourceMappingURL=index.js.map
|
package/dist/cjs/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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"}
|
package/dist/cjs/types.d.ts
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
export type DbQuery = (sqlString: string, ...parameter: unknown[]) => Promise<any>;
|
|
2
|
-
export type DbClose = () => Promise<void>;
|
|
3
|
-
export type KeyvSqliteOptions = {
|
|
4
|
-
dialect?: string;
|
|
5
|
-
uri?: string;
|
|
6
|
-
busyTimeout?: number;
|
|
7
|
-
table?: string;
|
|
8
|
-
keySize?: number;
|
|
9
|
-
db?: string;
|
|
10
|
-
iterationLimit?: number | string;
|
|
11
|
-
connect?: () => Promise<{
|
|
12
|
-
query: DbQuery;
|
|
13
|
-
close: DbClose;
|
|
14
|
-
}>;
|
|
15
|
-
};
|
|
16
|
-
export type Db = {
|
|
17
|
-
query: DbQuery;
|
|
18
|
-
close: DbClose;
|
|
19
|
-
};
|
package/dist/cjs/types.js
DELETED
package/dist/cjs/types.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":""}
|
package/dist/esm/index.js
DELETED
|
@@ -1,136 +0,0 @@
|
|
|
1
|
-
import EventEmitter from 'events';
|
|
2
|
-
import { promisify } from 'util';
|
|
3
|
-
import sqlite3 from 'sqlite3';
|
|
4
|
-
const toString = (input) => String(input).search(/^[a-zA-Z]+$/) < 0 ? '_' + input : input;
|
|
5
|
-
class KeyvSqlite extends EventEmitter {
|
|
6
|
-
ttlSupport;
|
|
7
|
-
opts;
|
|
8
|
-
namespace;
|
|
9
|
-
close;
|
|
10
|
-
query;
|
|
11
|
-
constructor(keyvOptions) {
|
|
12
|
-
super();
|
|
13
|
-
this.ttlSupport = false;
|
|
14
|
-
let options = {
|
|
15
|
-
dialect: 'sqlite',
|
|
16
|
-
uri: 'sqlite://:memory:',
|
|
17
|
-
};
|
|
18
|
-
if (typeof keyvOptions === 'string') {
|
|
19
|
-
options.uri = keyvOptions;
|
|
20
|
-
}
|
|
21
|
-
else {
|
|
22
|
-
options = {
|
|
23
|
-
...options,
|
|
24
|
-
...keyvOptions,
|
|
25
|
-
};
|
|
26
|
-
}
|
|
27
|
-
options.db = options.uri.replace(/^sqlite:\/\//, '');
|
|
28
|
-
options.connect = async () => new Promise((resolve, reject) => {
|
|
29
|
-
const database = new sqlite3.Database(options.db, error => {
|
|
30
|
-
/* c8 ignore next 2 */
|
|
31
|
-
if (error) {
|
|
32
|
-
reject(error);
|
|
33
|
-
}
|
|
34
|
-
else {
|
|
35
|
-
if (options.busyTimeout) {
|
|
36
|
-
database.configure('busyTimeout', options.busyTimeout);
|
|
37
|
-
}
|
|
38
|
-
resolve(database);
|
|
39
|
-
}
|
|
40
|
-
});
|
|
41
|
-
})
|
|
42
|
-
// @ts-expect-error - db is unknown
|
|
43
|
-
.then(database => ({ query: promisify(database.all).bind(database), close: promisify(database.close).bind(database) }));
|
|
44
|
-
this.opts = {
|
|
45
|
-
table: 'keyv',
|
|
46
|
-
keySize: 255,
|
|
47
|
-
...options,
|
|
48
|
-
};
|
|
49
|
-
this.opts.table = toString(this.opts.table);
|
|
50
|
-
const createTable = `CREATE TABLE IF NOT EXISTS ${this.opts.table}(key VARCHAR(${Number(this.opts.keySize)}) PRIMARY KEY, value TEXT )`;
|
|
51
|
-
// @ts-expect-error - db is
|
|
52
|
-
const connected = this.opts.connect()
|
|
53
|
-
.then(async (database) => database.query(createTable).then(() => database))
|
|
54
|
-
.catch(error => this.emit('error', error));
|
|
55
|
-
this.query = async (sqlString, ...parameter) => connected
|
|
56
|
-
.then(async (database) => database.query(sqlString, ...parameter));
|
|
57
|
-
this.close = async () => connected.then(database => database.close);
|
|
58
|
-
}
|
|
59
|
-
async get(key) {
|
|
60
|
-
const select = `SELECT * FROM ${this.opts.table} WHERE key = ?`;
|
|
61
|
-
const rows = await this.query(select, key);
|
|
62
|
-
const row = rows[0];
|
|
63
|
-
if (row === undefined) {
|
|
64
|
-
return undefined;
|
|
65
|
-
}
|
|
66
|
-
return row.value;
|
|
67
|
-
}
|
|
68
|
-
async getMany(keys) {
|
|
69
|
-
const select = `SELECT * FROM ${this.opts.table} WHERE key IN (SELECT value FROM json_each(?))`;
|
|
70
|
-
const rows = await this.query(select, JSON.stringify(keys));
|
|
71
|
-
return keys.map(key => {
|
|
72
|
-
const row = rows.find((row) => row.key === key);
|
|
73
|
-
return (row ? row.value : undefined);
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
async set(key, value) {
|
|
77
|
-
const upsert = `INSERT INTO ${this.opts.table} (key, value)
|
|
78
|
-
VALUES(?, ?)
|
|
79
|
-
ON CONFLICT(key)
|
|
80
|
-
DO UPDATE SET value=excluded.value;`;
|
|
81
|
-
return this.query(upsert, key, value);
|
|
82
|
-
}
|
|
83
|
-
async delete(key) {
|
|
84
|
-
const select = `SELECT * FROM ${this.opts.table} WHERE key = ?`;
|
|
85
|
-
const del = `DELETE FROM ${this.opts.table} WHERE key = ?`;
|
|
86
|
-
const rows = await this.query(select, key);
|
|
87
|
-
const row = rows[0];
|
|
88
|
-
if (row === undefined) {
|
|
89
|
-
return false;
|
|
90
|
-
}
|
|
91
|
-
await this.query(del, key);
|
|
92
|
-
return true;
|
|
93
|
-
}
|
|
94
|
-
async deleteMany(keys) {
|
|
95
|
-
const del = `DELETE FROM ${this.opts.table} WHERE key IN (SELECT value FROM json_each(?))`;
|
|
96
|
-
const results = await this.getMany(keys);
|
|
97
|
-
if (results.every(x => x === undefined)) {
|
|
98
|
-
return false;
|
|
99
|
-
}
|
|
100
|
-
await this.query(del, JSON.stringify(keys));
|
|
101
|
-
return true;
|
|
102
|
-
}
|
|
103
|
-
async clear() {
|
|
104
|
-
const del = `DELETE FROM ${this.opts.table} WHERE key LIKE ?`;
|
|
105
|
-
await this.query(del, this.namespace ? `${this.namespace}:%` : '%');
|
|
106
|
-
}
|
|
107
|
-
async *iterator(namespace) {
|
|
108
|
-
const limit = Number.parseInt(this.opts.iterationLimit, 10) || 10;
|
|
109
|
-
// @ts-expect-error - iterate
|
|
110
|
-
async function* iterate(offset, options, query) {
|
|
111
|
-
const select = `SELECT * FROM ${options.table} WHERE key LIKE ? LIMIT ? OFFSET ?`;
|
|
112
|
-
const iterator = await query(select, [`${namespace ? namespace + ':' : ''}%`, limit, offset]);
|
|
113
|
-
const entries = [...iterator];
|
|
114
|
-
if (entries.length === 0) {
|
|
115
|
-
return;
|
|
116
|
-
}
|
|
117
|
-
for (const entry of entries) {
|
|
118
|
-
offset += 1;
|
|
119
|
-
yield [entry.key, entry.value];
|
|
120
|
-
}
|
|
121
|
-
yield* iterate(offset, options, query);
|
|
122
|
-
}
|
|
123
|
-
yield* iterate(0, this.opts, this.query);
|
|
124
|
-
}
|
|
125
|
-
async has(key) {
|
|
126
|
-
const exists = `SELECT EXISTS ( SELECT * FROM ${this.opts.table} WHERE key = ? )`;
|
|
127
|
-
const result = await this.query(exists, key);
|
|
128
|
-
return Object.values(result[0])[0] === 1;
|
|
129
|
-
}
|
|
130
|
-
async disconnect() {
|
|
131
|
-
await this.close();
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
export default KeyvSqlite;
|
|
135
|
-
module.exports = KeyvSqlite;
|
|
136
|
-
//# sourceMappingURL=index.js.map
|
package/dist/esm/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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"}
|
package/dist/esm/types.d.ts
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
export type DbQuery = (sqlString: string, ...parameter: unknown[]) => Promise<any>;
|
|
2
|
-
export type DbClose = () => Promise<void>;
|
|
3
|
-
export type KeyvSqliteOptions = {
|
|
4
|
-
dialect?: string;
|
|
5
|
-
uri?: string;
|
|
6
|
-
busyTimeout?: number;
|
|
7
|
-
table?: string;
|
|
8
|
-
keySize?: number;
|
|
9
|
-
db?: string;
|
|
10
|
-
iterationLimit?: number | string;
|
|
11
|
-
connect?: () => Promise<{
|
|
12
|
-
query: DbQuery;
|
|
13
|
-
close: DbClose;
|
|
14
|
-
}>;
|
|
15
|
-
};
|
|
16
|
-
export type Db = {
|
|
17
|
-
query: DbQuery;
|
|
18
|
-
close: DbClose;
|
|
19
|
-
};
|
package/dist/esm/types.js
DELETED
package/dist/esm/types.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":""}
|