@hocuspocus/extension-sqlite 1.0.0-alpha.1 → 1.0.0-alpha.5
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/hocuspocus-sqlite.cjs +3 -3
- package/dist/hocuspocus-sqlite.cjs.map +1 -1
- package/dist/hocuspocus-sqlite.esm.js +2 -2
- package/dist/hocuspocus-sqlite.esm.js.map +1 -1
- package/dist/packages/common/src/CloseEvents.d.ts +23 -0
- package/dist/packages/common/src/index.d.ts +1 -0
- package/dist/packages/provider/src/HocuspocusCloudProvider.d.ts +4 -3
- package/dist/packages/provider/src/HocuspocusProvider.d.ts +9 -4
- package/dist/packages/server/src/Connection.d.ts +1 -1
- package/dist/packages/server/src/Hocuspocus.d.ts +11 -3
- package/dist/packages/server/src/index.d.ts +2 -0
- package/dist/packages/server/src/types.d.ts +5 -8
- package/package.json +4 -4
- package/src/SQLite.ts +2 -2
- package/dist/packages/server/src/CloseEvents.d.ts +0 -4
|
@@ -4,12 +4,12 @@ Object.defineProperty(exports, '__esModule', { value: true });
|
|
|
4
4
|
|
|
5
5
|
var extensionDatabase = require('@hocuspocus/extension-database');
|
|
6
6
|
var sqlite3 = require('sqlite3');
|
|
7
|
-
var
|
|
7
|
+
var kleur = require('kleur');
|
|
8
8
|
|
|
9
9
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
10
10
|
|
|
11
11
|
var sqlite3__default = /*#__PURE__*/_interopDefaultLegacy(sqlite3);
|
|
12
|
-
var
|
|
12
|
+
var kleur__default = /*#__PURE__*/_interopDefaultLegacy(kleur);
|
|
13
13
|
|
|
14
14
|
class SQLite extends extensionDatabase.Database {
|
|
15
15
|
/**
|
|
@@ -50,7 +50,7 @@ class SQLite extends extensionDatabase.Database {
|
|
|
50
50
|
};
|
|
51
51
|
}
|
|
52
52
|
async onListen() {
|
|
53
|
-
console.warn(` ${
|
|
53
|
+
console.warn(` ${kleur__default["default"].yellow('The SQLite extension is intended to be used in a local development environment, not in a production environment.')}`);
|
|
54
54
|
console.log();
|
|
55
55
|
}
|
|
56
56
|
async onConfigure() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hocuspocus-sqlite.cjs","sources":["../src/SQLite.ts"],"sourcesContent":["import { Database, DatabaseConfiguration } from '@hocuspocus/extension-database'\nimport sqlite3 from 'sqlite3'\nimport
|
|
1
|
+
{"version":3,"file":"hocuspocus-sqlite.cjs","sources":["../src/SQLite.ts"],"sourcesContent":["import { Database, DatabaseConfiguration } from '@hocuspocus/extension-database'\nimport sqlite3 from 'sqlite3'\nimport kleur from 'kleur'\n\nexport interface SQLiteConfiguration extends DatabaseConfiguration {\n /**\n * Valid values are filenames, \":memory:\" for an anonymous in-memory database and an empty\n * string for an anonymous disk-based database. Anonymous databases are not persisted and\n * when closing the database handle, their contents are lost.\n *\n * https://github.com/mapbox/node-sqlite3/wiki/API#new-sqlite3databasefilename-mode-callback\n */\n database: string,\n /**\n * The database schema to create.\n */\n schema: string,\n}\n\nexport class SQLite extends Database {\n db?: sqlite3.Database\n\n configuration: SQLiteConfiguration = {\n database: ':memory:',\n schema: `CREATE TABLE IF NOT EXISTS \"documents\" (\n \"name\" varchar(255) NOT NULL,\n \"data\" blob NOT NULL\n );`,\n fetchUpdates: async ({ documentName }) => {\n return new Promise((resolve, reject) => {\n this.db?.all('SELECT data FROM \"documents\" WHERE name = $name ORDER BY rowid', {\n $name: documentName,\n }, (error, rows) => {\n if (error) {\n reject(error)\n }\n\n resolve(rows.map(row => row.data))\n })\n })\n },\n storeUpdate: async ({ documentName, update }) => {\n this.db?.run('INSERT INTO \"documents\" (\"name\", \"data\") VALUES ($name, $data)', {\n $name: documentName,\n $data: update,\n })\n },\n }\n\n /**\n * Constructor\n */\n constructor(configuration?: Partial<SQLiteConfiguration>) {\n super({})\n\n this.configuration = {\n ...this.configuration,\n ...configuration,\n }\n }\n\n async onListen() {\n console.warn(` ${kleur.yellow('The SQLite extension is intended to be used in a local development environment, not in a production environment.')}`)\n console.log()\n }\n\n async onConfigure() {\n this.db = new sqlite3.Database(this.configuration.database)\n\n this.db.run(this.configuration.schema)\n }\n}\n"],"names":["Database","kleur","sqlite3"],"mappings":";;;;;;;;;;;;;MAmBa,MAAO,SAAQA,0BAAQ;;;;IAiClC,YAAY,aAA4C;QACtD,KAAK,CAAC,EAAE,CAAC,CAAA;QA/BX,kBAAa,GAAwB;YACnC,QAAQ,EAAE,UAAU;YACpB,MAAM,EAAE;;;OAGL;YACH,YAAY,EAAE,OAAO,EAAE,YAAY,EAAE;gBACnC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM;;oBACjC,MAAA,IAAI,CAAC,EAAE,0CAAE,GAAG,CAAC,gEAAgE,EAAE;wBAC7E,KAAK,EAAE,YAAY;qBACpB,EAAE,CAAC,KAAK,EAAE,IAAI;wBACb,IAAI,KAAK,EAAE;4BACT,MAAM,CAAC,KAAK,CAAC,CAAA;yBACd;wBAED,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC,CAAA;qBACnC,CAAC,CAAA;iBACH,CAAC,CAAA;aACH;YACD,WAAW,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE;;gBAC1C,MAAA,IAAI,CAAC,EAAE,0CAAE,GAAG,CAAC,gEAAgE,EAAE;oBAC7E,KAAK,EAAE,YAAY;oBACnB,KAAK,EAAE,MAAM;iBACd,CAAC,CAAA;aACH;SACF,CAAA;QAQC,IAAI,CAAC,aAAa,GAAG;YACnB,GAAG,IAAI,CAAC,aAAa;YACrB,GAAG,aAAa;SACjB,CAAA;KACF;IAED,MAAM,QAAQ;QACZ,OAAO,CAAC,IAAI,CAAC,KAAKC,yBAAK,CAAC,MAAM,CAAC,kHAAkH,CAAC,EAAE,CAAC,CAAA;QACrJ,OAAO,CAAC,GAAG,EAAE,CAAA;KACd;IAED,MAAM,WAAW;QACf,IAAI,CAAC,EAAE,GAAG,IAAIC,2BAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAA;QAE3D,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAA;KACvC;;;;;"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Database } from '@hocuspocus/extension-database';
|
|
2
2
|
import sqlite3 from 'sqlite3';
|
|
3
|
-
import
|
|
3
|
+
import kleur from 'kleur';
|
|
4
4
|
|
|
5
5
|
class SQLite extends Database {
|
|
6
6
|
/**
|
|
@@ -41,7 +41,7 @@ class SQLite extends Database {
|
|
|
41
41
|
};
|
|
42
42
|
}
|
|
43
43
|
async onListen() {
|
|
44
|
-
console.warn(` ${
|
|
44
|
+
console.warn(` ${kleur.yellow('The SQLite extension is intended to be used in a local development environment, not in a production environment.')}`);
|
|
45
45
|
console.log();
|
|
46
46
|
}
|
|
47
47
|
async onConfigure() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hocuspocus-sqlite.esm.js","sources":["../src/SQLite.ts"],"sourcesContent":["import { Database, DatabaseConfiguration } from '@hocuspocus/extension-database'\nimport sqlite3 from 'sqlite3'\nimport
|
|
1
|
+
{"version":3,"file":"hocuspocus-sqlite.esm.js","sources":["../src/SQLite.ts"],"sourcesContent":["import { Database, DatabaseConfiguration } from '@hocuspocus/extension-database'\nimport sqlite3 from 'sqlite3'\nimport kleur from 'kleur'\n\nexport interface SQLiteConfiguration extends DatabaseConfiguration {\n /**\n * Valid values are filenames, \":memory:\" for an anonymous in-memory database and an empty\n * string for an anonymous disk-based database. Anonymous databases are not persisted and\n * when closing the database handle, their contents are lost.\n *\n * https://github.com/mapbox/node-sqlite3/wiki/API#new-sqlite3databasefilename-mode-callback\n */\n database: string,\n /**\n * The database schema to create.\n */\n schema: string,\n}\n\nexport class SQLite extends Database {\n db?: sqlite3.Database\n\n configuration: SQLiteConfiguration = {\n database: ':memory:',\n schema: `CREATE TABLE IF NOT EXISTS \"documents\" (\n \"name\" varchar(255) NOT NULL,\n \"data\" blob NOT NULL\n );`,\n fetchUpdates: async ({ documentName }) => {\n return new Promise((resolve, reject) => {\n this.db?.all('SELECT data FROM \"documents\" WHERE name = $name ORDER BY rowid', {\n $name: documentName,\n }, (error, rows) => {\n if (error) {\n reject(error)\n }\n\n resolve(rows.map(row => row.data))\n })\n })\n },\n storeUpdate: async ({ documentName, update }) => {\n this.db?.run('INSERT INTO \"documents\" (\"name\", \"data\") VALUES ($name, $data)', {\n $name: documentName,\n $data: update,\n })\n },\n }\n\n /**\n * Constructor\n */\n constructor(configuration?: Partial<SQLiteConfiguration>) {\n super({})\n\n this.configuration = {\n ...this.configuration,\n ...configuration,\n }\n }\n\n async onListen() {\n console.warn(` ${kleur.yellow('The SQLite extension is intended to be used in a local development environment, not in a production environment.')}`)\n console.log()\n }\n\n async onConfigure() {\n this.db = new sqlite3.Database(this.configuration.database)\n\n this.db.run(this.configuration.schema)\n }\n}\n"],"names":[],"mappings":";;;;MAmBa,MAAO,SAAQ,QAAQ;;;;IAiClC,YAAY,aAA4C;QACtD,KAAK,CAAC,EAAE,CAAC,CAAA;QA/BX,kBAAa,GAAwB;YACnC,QAAQ,EAAE,UAAU;YACpB,MAAM,EAAE;;;OAGL;YACH,YAAY,EAAE,OAAO,EAAE,YAAY,EAAE;gBACnC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM;;oBACjC,MAAA,IAAI,CAAC,EAAE,0CAAE,GAAG,CAAC,gEAAgE,EAAE;wBAC7E,KAAK,EAAE,YAAY;qBACpB,EAAE,CAAC,KAAK,EAAE,IAAI;wBACb,IAAI,KAAK,EAAE;4BACT,MAAM,CAAC,KAAK,CAAC,CAAA;yBACd;wBAED,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,CAAC,CAAA;qBACnC,CAAC,CAAA;iBACH,CAAC,CAAA;aACH;YACD,WAAW,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE;;gBAC1C,MAAA,IAAI,CAAC,EAAE,0CAAE,GAAG,CAAC,gEAAgE,EAAE;oBAC7E,KAAK,EAAE,YAAY;oBACnB,KAAK,EAAE,MAAM;iBACd,CAAC,CAAA;aACH;SACF,CAAA;QAQC,IAAI,CAAC,aAAa,GAAG;YACnB,GAAG,IAAI,CAAC,aAAa;YACrB,GAAG,aAAa;SACjB,CAAA;KACF;IAED,MAAM,QAAQ;QACZ,OAAO,CAAC,IAAI,CAAC,KAAK,KAAK,CAAC,MAAM,CAAC,kHAAkH,CAAC,EAAE,CAAC,CAAA;QACrJ,OAAO,CAAC,GAAG,EAAE,CAAA;KACd;IAED,MAAM,WAAW;QACf,IAAI,CAAC,EAAE,GAAG,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAA;QAE3D,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAA;KACvC;;;;;"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export interface CloseEvent {
|
|
2
|
+
code: number;
|
|
3
|
+
reason: string;
|
|
4
|
+
}
|
|
5
|
+
/**
|
|
6
|
+
* The server successfully processed the request, asks that the requester reset
|
|
7
|
+
* its document view, and is not returning any content.
|
|
8
|
+
*/
|
|
9
|
+
export declare const ResetConnection: CloseEvent;
|
|
10
|
+
/**
|
|
11
|
+
* Similar to Forbidden, but specifically for use when authentication is required and has
|
|
12
|
+
* failed or has not yet been provided.
|
|
13
|
+
*/
|
|
14
|
+
export declare const Unauthorized: CloseEvent;
|
|
15
|
+
/**
|
|
16
|
+
* The request contained valid data and was understood by the server, but the server
|
|
17
|
+
* is refusing action.
|
|
18
|
+
*/
|
|
19
|
+
export declare const Forbidden: CloseEvent;
|
|
20
|
+
/**
|
|
21
|
+
* The server timed out waiting for the request.
|
|
22
|
+
*/
|
|
23
|
+
export declare const ConnectionTimeout: CloseEvent;
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import { HocuspocusProvider,
|
|
2
|
-
export
|
|
1
|
+
import { HocuspocusProvider, HocuspocusProviderConfiguration } from './HocuspocusProvider';
|
|
2
|
+
export declare type HocuspocusCloudProviderConfiguration = Required<Pick<HocuspocusProviderConfiguration, 'name'>> & Partial<HocuspocusProviderConfiguration> & AdditionalHocuspocusCloudProviderConfiguration;
|
|
3
|
+
export interface AdditionalHocuspocusCloudProviderConfiguration {
|
|
3
4
|
/**
|
|
4
5
|
* A Hocuspocus Cloud key, get one here: https://hocuspocus.cloud/
|
|
5
6
|
*/
|
|
6
7
|
key: string;
|
|
7
8
|
}
|
|
8
9
|
export declare class HocuspocusCloudProvider extends HocuspocusProvider {
|
|
9
|
-
constructor(
|
|
10
|
+
constructor(configuration: HocuspocusCloudProviderConfiguration);
|
|
10
11
|
}
|
|
@@ -10,7 +10,8 @@ export declare enum WebSocketStatus {
|
|
|
10
10
|
Connected = "connected",
|
|
11
11
|
Disconnected = "disconnected"
|
|
12
12
|
}
|
|
13
|
-
export
|
|
13
|
+
export declare type HocuspocusProviderConfiguration = Required<Pick<CompleteHocuspocusProviderConfiguration, 'url' | 'name'>> & Partial<CompleteHocuspocusProviderConfiguration>;
|
|
14
|
+
export interface CompleteHocuspocusProviderConfiguration {
|
|
14
15
|
/**
|
|
15
16
|
* URL of your @hocuspocus/server instance
|
|
16
17
|
*/
|
|
@@ -104,9 +105,13 @@ export interface HocuspocusProviderOptions {
|
|
|
104
105
|
onDestroy: () => void;
|
|
105
106
|
onAwarenessUpdate: (states: any) => void;
|
|
106
107
|
onAwarenessChange: (states: any) => void;
|
|
108
|
+
/**
|
|
109
|
+
* Don’t output any warnings.
|
|
110
|
+
*/
|
|
111
|
+
quiet: boolean;
|
|
107
112
|
}
|
|
108
113
|
export declare class HocuspocusProvider extends EventEmitter {
|
|
109
|
-
|
|
114
|
+
configuration: CompleteHocuspocusProviderConfiguration;
|
|
110
115
|
subscribedToBroadcastChannel: boolean;
|
|
111
116
|
webSocket: WebSocket | null;
|
|
112
117
|
shouldConnect: boolean;
|
|
@@ -120,8 +125,8 @@ export declare class HocuspocusProvider extends EventEmitter {
|
|
|
120
125
|
resolve: (value?: any) => void;
|
|
121
126
|
reject: (reason?: any) => void;
|
|
122
127
|
} | null;
|
|
123
|
-
constructor(
|
|
124
|
-
|
|
128
|
+
constructor(configuration: HocuspocusProviderConfiguration);
|
|
129
|
+
setConfiguration(configuration?: Partial<HocuspocusProviderConfiguration>): void;
|
|
125
130
|
connect(): Promise<void>;
|
|
126
131
|
createWebSocketConnection(): Promise<unknown>;
|
|
127
132
|
resolveConnectionAttempt(): void;
|
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
import AsyncLock from 'async-lock';
|
|
3
3
|
import WebSocket from 'ws';
|
|
4
4
|
import { IncomingMessage as HTTPIncomingMessage } from 'http';
|
|
5
|
+
import { CloseEvent } from '@hocuspocus/common';
|
|
5
6
|
import Document from './Document';
|
|
6
|
-
import { CloseEvent } from './types';
|
|
7
7
|
import { MessageLogger } from './Debugger';
|
|
8
8
|
declare class Connection {
|
|
9
9
|
webSocket: WebSocket;
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
import WebSocket, { WebSocketServer } from 'ws';
|
|
3
3
|
import { IncomingMessage, Server as HTTPServer } from 'http';
|
|
4
4
|
import { Configuration, Hook } from './types';
|
|
5
|
+
import Document from './Document';
|
|
5
6
|
import { MessageLogger } from './Debugger';
|
|
6
7
|
import { onListenPayload } from '.';
|
|
7
8
|
export declare const defaultConfiguration: {
|
|
@@ -15,7 +16,7 @@ export declare const defaultConfiguration: {
|
|
|
15
16
|
*/
|
|
16
17
|
export declare class Hocuspocus {
|
|
17
18
|
configuration: Configuration;
|
|
18
|
-
documents: Map<
|
|
19
|
+
documents: Map<string, Document>;
|
|
19
20
|
httpServer?: HTTPServer;
|
|
20
21
|
webSocketServer?: WebSocketServer;
|
|
21
22
|
debugger: MessageLogger;
|
|
@@ -23,7 +24,7 @@ export declare class Hocuspocus {
|
|
|
23
24
|
* Configure the server
|
|
24
25
|
*/
|
|
25
26
|
configure(configuration: Partial<Configuration>): Hocuspocus;
|
|
26
|
-
get
|
|
27
|
+
get requiresAuthentication(): boolean;
|
|
27
28
|
/**
|
|
28
29
|
* Start the server
|
|
29
30
|
*/
|
|
@@ -46,7 +47,14 @@ export declare class Hocuspocus {
|
|
|
46
47
|
*/
|
|
47
48
|
destroy(): Promise<any>;
|
|
48
49
|
/**
|
|
49
|
-
*
|
|
50
|
+
* The `handleConnection` method receives incoming WebSocket connections,
|
|
51
|
+
* runs all hooks:
|
|
52
|
+
*
|
|
53
|
+
* - onConnect for all connections
|
|
54
|
+
* - onAuthenticate only if required
|
|
55
|
+
*
|
|
56
|
+
* … and if nothings fails it’ll fully establish the connection and
|
|
57
|
+
* load the Document then.
|
|
50
58
|
*/
|
|
51
59
|
handleConnection(incoming: WebSocket, request: IncomingMessage, documentName: string, context?: any): void;
|
|
52
60
|
/**
|
|
@@ -25,8 +25,9 @@ export interface AwarenessUpdate {
|
|
|
25
25
|
updated: Array<any>;
|
|
26
26
|
removed: Array<any>;
|
|
27
27
|
}
|
|
28
|
-
export interface
|
|
28
|
+
export interface ConnectionConfiguration {
|
|
29
29
|
readOnly: boolean;
|
|
30
|
+
requiresAuthentication: boolean;
|
|
30
31
|
isAuthenticated: boolean;
|
|
31
32
|
}
|
|
32
33
|
export interface Extension {
|
|
@@ -87,7 +88,7 @@ export interface onAuthenticatePayload {
|
|
|
87
88
|
requestParameters: URLSearchParams;
|
|
88
89
|
socketId: string;
|
|
89
90
|
token: string;
|
|
90
|
-
connection:
|
|
91
|
+
connection: ConnectionConfiguration;
|
|
91
92
|
}
|
|
92
93
|
export interface onConnectPayload {
|
|
93
94
|
documentName: string;
|
|
@@ -96,7 +97,7 @@ export interface onConnectPayload {
|
|
|
96
97
|
requestHeaders: IncomingHttpHeaders;
|
|
97
98
|
requestParameters: URLSearchParams;
|
|
98
99
|
socketId: string;
|
|
99
|
-
connection:
|
|
100
|
+
connection: ConnectionConfiguration;
|
|
100
101
|
}
|
|
101
102
|
export interface onLoadDocumentPayload {
|
|
102
103
|
context: any;
|
|
@@ -106,7 +107,7 @@ export interface onLoadDocumentPayload {
|
|
|
106
107
|
requestHeaders: IncomingHttpHeaders;
|
|
107
108
|
requestParameters: URLSearchParams;
|
|
108
109
|
socketId: string;
|
|
109
|
-
connection:
|
|
110
|
+
connection: ConnectionConfiguration;
|
|
110
111
|
}
|
|
111
112
|
export interface onChangePayload {
|
|
112
113
|
clientsCount: number;
|
|
@@ -152,7 +153,3 @@ export interface onConfigurePayload {
|
|
|
152
153
|
yjsVersion: string;
|
|
153
154
|
instance: Hocuspocus;
|
|
154
155
|
}
|
|
155
|
-
export interface CloseEvent {
|
|
156
|
-
code: number;
|
|
157
|
-
reason: string;
|
|
158
|
-
}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@hocuspocus/extension-sqlite",
|
|
3
3
|
"description": "a generic Hocuspocus persistence driver for the sqlite",
|
|
4
|
-
"version": "1.0.0-alpha.
|
|
4
|
+
"version": "1.0.0-alpha.5",
|
|
5
5
|
"homepage": "https://hocuspocus.dev",
|
|
6
6
|
"keywords": [
|
|
7
7
|
"hocuspocus",
|
|
@@ -26,8 +26,8 @@
|
|
|
26
26
|
"dist"
|
|
27
27
|
],
|
|
28
28
|
"dependencies": {
|
|
29
|
-
"@hocuspocus/extension-database": "^1.0.0-alpha.
|
|
30
|
-
"
|
|
29
|
+
"@hocuspocus/extension-database": "^1.0.0-alpha.5",
|
|
30
|
+
"kleur": "^4.1.4",
|
|
31
31
|
"sqlite3": "^5.0.2"
|
|
32
32
|
},
|
|
33
33
|
"publishConfig": {
|
|
@@ -36,5 +36,5 @@
|
|
|
36
36
|
"devDependencies": {
|
|
37
37
|
"@types/sqlite3": "^3.1.7"
|
|
38
38
|
},
|
|
39
|
-
"gitHead": "
|
|
39
|
+
"gitHead": "90e3f0955922515ccf1d643b7b43c4ad20387735"
|
|
40
40
|
}
|
package/src/SQLite.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Database, DatabaseConfiguration } from '@hocuspocus/extension-database'
|
|
2
2
|
import sqlite3 from 'sqlite3'
|
|
3
|
-
import
|
|
3
|
+
import kleur from 'kleur'
|
|
4
4
|
|
|
5
5
|
export interface SQLiteConfiguration extends DatabaseConfiguration {
|
|
6
6
|
/**
|
|
@@ -60,7 +60,7 @@ export class SQLite extends Database {
|
|
|
60
60
|
}
|
|
61
61
|
|
|
62
62
|
async onListen() {
|
|
63
|
-
console.warn(` ${
|
|
63
|
+
console.warn(` ${kleur.yellow('The SQLite extension is intended to be used in a local development environment, not in a production environment.')}`)
|
|
64
64
|
console.log()
|
|
65
65
|
}
|
|
66
66
|
|