@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 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 { type KeyvStoreAdapter, type StoredData } from 'keyv';
3
- import { type DbClose, type DbQuery, type KeyvSqliteOptions } from './types';
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
- export default KeyvSqlite;
37
+
38
+ export { KeyvSqlite, KeyvSqlite as default };
@@ -1,6 +1,22 @@
1
1
  import EventEmitter from 'events';
2
- import { type KeyvStoreAdapter, type StoredData } from 'keyv';
3
- import { type DbClose, type DbQuery, type KeyvSqliteOptions } from './types';
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
- export default KeyvSqlite;
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.0",
3
+ "version": "4.0.1",
4
4
  "description": "SQLite storage adapter for Keyv",
5
- "main": "dist/cjs/index.js",
6
- "module": "dist/esm/index.js",
7
- "types": "dist/esm/index.d.ts",
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/cjs/index.js",
11
- "import": "./dist/esm/index.js"
11
+ "require": "./dist/index.cjs",
12
+ "import": "./dist/index.js"
12
13
  }
13
14
  },
14
15
  "scripts": {
15
- "build": "rm -rf dist && tsc --project tsconfig.cjs.json && tsc --project tsconfig.esm.json",
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
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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"}
@@ -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
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=types.js.map
@@ -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
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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"}
@@ -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
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=types.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":""}