@kubun/db-adapter 0.5.0 → 0.6.0
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/lib/postgres.d.ts +1 -0
- package/lib/postgres.js +5 -5
- package/lib/sqlite.d.ts +1 -0
- package/lib/sqlite.js +1 -1
- package/lib/types.d.ts +1 -0
- package/package.json +1 -1
package/lib/postgres.d.ts
CHANGED
|
@@ -12,6 +12,7 @@ export declare class AbstractPostgresAdapter<T extends AdapterTypes = PostgresTy
|
|
|
12
12
|
encodeJSON(value: unknown): unknown;
|
|
13
13
|
encodeTimestamp(value: Date): string;
|
|
14
14
|
decodeTimestamp(value: string): Date;
|
|
15
|
+
coerceFilterValue(value: unknown): unknown;
|
|
15
16
|
createSearchIndex(db: Kysely<unknown>, config: SearchIndexConfig): Promise<void>;
|
|
16
17
|
dropSearchIndex(db: Kysely<unknown>, modelID: string): Promise<void>;
|
|
17
18
|
updateSearchEntry(db: Kysely<unknown>, modelID: string, documentID: string, fields: Record<string, string>, fieldNames: Array<string>): Promise<void>;
|
package/lib/postgres.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{sql as e}from"kysely";export class AbstractPostgresAdapter{functions={now:"now()"};types={binary:"bytea",json:"jsonb",text:"text",timestamp:"timestamptz(3)",uuid:"uuid"};encodeBinary(e){return e}encodeJSON(e){return e}encodeTimestamp(e){return e.toISOString()}decodeTimestamp(e){return new Date(e)}async createSearchIndex(t,r){let a=`fts_${r.modelID}`,c=`k_${r.modelID}`;await e`
|
|
1
|
+
import{sql as e}from"kysely";export class AbstractPostgresAdapter{functions={now:"now()"};types={binary:"bytea",json:"jsonb",text:"text",timestamp:"timestamptz(3)",uuid:"uuid"};encodeBinary(e){return e}encodeJSON(e){return e}encodeTimestamp(e){return e.toISOString()}decodeTimestamp(e){return new Date(e)}coerceFilterValue(e){return"boolean"==typeof e?e?"true":"false":e}async createSearchIndex(t,r){let a=`fts_${r.modelID}`,c=`k_${r.modelID}`;await e`
|
|
2
2
|
CREATE TABLE IF NOT EXISTS ${e.ref(a)} (
|
|
3
3
|
document_id TEXT PRIMARY KEY REFERENCES ${e.ref(c)}(id) ON DELETE CASCADE,
|
|
4
4
|
search_vector tsvector
|
|
@@ -6,10 +6,10 @@ import{sql as e}from"kysely";export class AbstractPostgresAdapter{functions={now
|
|
|
6
6
|
`.execute(t),await e`
|
|
7
7
|
CREATE INDEX IF NOT EXISTS ${e.ref(`ftsi_${r.modelID}`)}
|
|
8
8
|
ON ${e.ref(a)} USING GIN(search_vector)
|
|
9
|
-
`.execute(t)}async dropSearchIndex(t,r){let a=`fts_${r}`;await e`DROP TABLE IF EXISTS ${e.ref(a)} CASCADE`.execute(t)}async updateSearchEntry(t,r,a,c,n){let
|
|
10
|
-
INSERT INTO ${e.ref(
|
|
11
|
-
VALUES (${a}, ${
|
|
12
|
-
ON CONFLICT (document_id) DO UPDATE SET search_vector = ${
|
|
9
|
+
`.execute(t)}async dropSearchIndex(t,r){let a=`fts_${r}`;await e`DROP TABLE IF EXISTS ${e.ref(a)} CASCADE`.execute(t)}async updateSearchEntry(t,r,a,c,n){let o=`fts_${r}`,s=n.map(t=>{let r=c[t]??"";return e`to_tsvector('simple', ${r})`}).reduce((t,r)=>e`${t} || ${r}`);await e`
|
|
10
|
+
INSERT INTO ${e.ref(o)} (document_id, search_vector)
|
|
11
|
+
VALUES (${a}, ${s})
|
|
12
|
+
ON CONFLICT (document_id) DO UPDATE SET search_vector = ${s}
|
|
13
13
|
`.execute(t)}async removeSearchEntry(t,r,a){let c=`fts_${r}`;await e`DELETE FROM ${e.ref(c)} WHERE document_id = ${a}`.execute(t)}async searchIndex(t,r){let a=`fts_${r.modelID}`;return(await e`
|
|
14
14
|
SELECT document_id, ts_rank(search_vector, plainto_tsquery('simple', ${r.query})) AS rank
|
|
15
15
|
FROM ${e.ref(a)}
|
package/lib/sqlite.d.ts
CHANGED
|
@@ -12,6 +12,7 @@ export declare class AbstractSQLiteAdapter<T extends AdapterTypes = SQLiteTypes>
|
|
|
12
12
|
encodeJSON(value: unknown): string;
|
|
13
13
|
encodeTimestamp(value: Date): number;
|
|
14
14
|
decodeTimestamp(value: number): Date;
|
|
15
|
+
coerceFilterValue(value: unknown): unknown;
|
|
15
16
|
createSearchIndex(db: Kysely<unknown>, config: SearchIndexConfig): Promise<void>;
|
|
16
17
|
dropSearchIndex(db: Kysely<unknown>, modelID: string): Promise<void>;
|
|
17
18
|
updateSearchEntry(db: Kysely<unknown>, modelID: string, documentID: string, fields: Record<string, string>, fieldNames: Array<string>): Promise<void>;
|
package/lib/sqlite.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{sql as e}from"kysely";export class AbstractSQLiteAdapter{functions={now:e`(unixepoch())`};types={binary:"blob",json:"jsonb",text:"text",timestamp:"integer",uuid:"text"};encodeBinary(e){return e}encodeJSON(e){return JSON.stringify(e)}encodeTimestamp(e){return Math.floor(e.getTime()/1e3)}decodeTimestamp(e){return new Date(1e3*e)}async createSearchIndex(t,r){let a=`fts_${r.modelID}`,n=["document_id UNINDEXED",...r.fields].join(", ");await e`CREATE VIRTUAL TABLE IF NOT EXISTS ${e.ref(a)} USING fts5(${e.raw(n)})`.execute(t)}async dropSearchIndex(t,r){let a=`fts_${r}`;await e`DROP TABLE IF EXISTS ${e.ref(a)}`.execute(t)}async updateSearchEntry(t,r,a,n,
|
|
1
|
+
import{sql as e}from"kysely";export class AbstractSQLiteAdapter{functions={now:e`(unixepoch())`};types={binary:"blob",json:"jsonb",text:"text",timestamp:"integer",uuid:"text"};encodeBinary(e){return e}encodeJSON(e){return JSON.stringify(e)}encodeTimestamp(e){return Math.floor(e.getTime()/1e3)}decodeTimestamp(e){return new Date(1e3*e)}coerceFilterValue(e){return"boolean"==typeof e?+!!e:e}async createSearchIndex(t,r){let a=`fts_${r.modelID}`,n=["document_id UNINDEXED",...r.fields].join(", ");await e`CREATE VIRTUAL TABLE IF NOT EXISTS ${e.ref(a)} USING fts5(${e.raw(n)})`.execute(t)}async dropSearchIndex(t,r){let a=`fts_${r}`;await e`DROP TABLE IF EXISTS ${e.ref(a)}`.execute(t)}async updateSearchEntry(t,r,a,n,c){let i=`fts_${r}`;await e`DELETE FROM ${e.ref(i)} WHERE document_id = ${a}`.execute(t);let o=["document_id",...c].join(", "),d=[a,...c.map(e=>n[e]??"")].map(t=>e.lit(t));await e`INSERT INTO ${e.ref(i)} (${e.raw(o)}) VALUES (${e.join(d)})`.execute(t)}async removeSearchEntry(t,r,a){let n=`fts_${r}`;await e`DELETE FROM ${e.ref(n)} WHERE document_id = ${a}`.execute(t)}async searchIndex(t,r){let a=`fts_${r.modelID}`;return(await e`
|
|
2
2
|
SELECT document_id, rank FROM ${e.ref(a)}
|
|
3
3
|
WHERE ${e.ref(a)} MATCH ${r.query}
|
|
4
4
|
ORDER BY rank
|
package/lib/types.d.ts
CHANGED
|
@@ -39,6 +39,7 @@ export type AbstractAdapter<T extends AdapterTypes = AdapterTypes> = {
|
|
|
39
39
|
updateSearchEntry(db: Kysely<unknown>, modelID: string, documentID: string, fields: Record<string, string>, fieldNames: Array<string>): Promise<void>;
|
|
40
40
|
removeSearchEntry(db: Kysely<unknown>, modelID: string, documentID: string): Promise<void>;
|
|
41
41
|
searchIndex(db: Kysely<unknown>, params: SearchQuery): Promise<Array<SearchHit>>;
|
|
42
|
+
coerceFilterValue(value: unknown): unknown;
|
|
42
43
|
};
|
|
43
44
|
export type Adapter<T extends AdapterTypes = AdapterTypes> = AbstractAdapter<T> & {
|
|
44
45
|
dialect: Dialect;
|