@rljson/io 0.0.23 → 0.0.26

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/io-mem.d.ts CHANGED
@@ -1,11 +1,12 @@
1
1
  import { JsonValue } from '@rljson/json';
2
- import { Rljson, TableCfg } from '@rljson/rljson';
2
+ import { Rljson, TableCfg, TableKey } from '@rljson/rljson';
3
3
  import { Io } from './io.ts';
4
4
  /**
5
5
  * In-Memory implementation of the Rljson Io interface.
6
6
  */
7
7
  export declare class IoMem implements Io {
8
8
  constructor();
9
+ init(): Promise<void>;
9
10
  static example: () => Promise<IoMem>;
10
11
  isReady(): Promise<void>;
11
12
  dump(): Promise<Rljson>;
@@ -22,6 +23,7 @@ export declare class IoMem implements Io {
22
23
  write(request: {
23
24
  data: Rljson;
24
25
  }): Promise<void>;
26
+ tableExists(tableKey: TableKey): Promise<boolean>;
25
27
  createOrExtendTable(request: {
26
28
  tableCfg: TableCfg;
27
29
  }): Promise<void>;
@@ -32,6 +34,8 @@ export declare class IoMem implements Io {
32
34
  private _init;
33
35
  private _initTableCfgs;
34
36
  private _createOrExtendTable;
37
+ private _createTable;
38
+ private _extendTable;
35
39
  private _dump;
36
40
  private _dumpTable;
37
41
  private _write;
@@ -1,4 +1,4 @@
1
- import { TableCfg, TableKey } from '@rljson/rljson';
1
+ import { Rljson, TableCfg, TableKey } from '@rljson/rljson';
2
2
  import { Io } from './io.ts';
3
3
  /**
4
4
  * Provides utility functions for the Io interface.
@@ -11,18 +11,27 @@ export declare class IoTools {
11
11
  */
12
12
  constructor(io: Io);
13
13
  /**
14
- * Initializes the revisions table.
14
+ * Returns the table configuration of the tableCfgs table.
15
15
  */
16
- initRevisionsTable: () => Promise<void>;
16
+ static get tableCfgsTableCfg(): TableCfg;
17
17
  /**
18
- * Returns the table configuration of the tableCfgs table.
18
+ * Initializes the revisions table.
19
19
  */
20
- get tableCfgsTableCfg(): TableCfg;
20
+ initRevisionsTable: () => Promise<void>;
21
21
  /**
22
22
  * Example object for test purposes
23
23
  * @returns An instance of io tools
24
24
  */
25
25
  static example: () => Promise<IoTools>;
26
+ /**
27
+ * Throws if the table does not exist
28
+ */
29
+ throwWhenTableDoesNotExist(table: TableKey): Promise<void>;
30
+ /**
31
+ * Throws if any of the tables in rljson do not exist
32
+ * @param rljson - The Rljson object to check
33
+ */
34
+ throwWhenTablesDoNotExist(rljson: Rljson): Promise<void>;
26
35
  /**
27
36
  * Returns a list with all table names
28
37
  */
package/dist/io.d.ts CHANGED
@@ -1,6 +1,8 @@
1
1
  import { JsonValue } from '@rljson/json';
2
- import { Rljson, TableCfg } from '@rljson/rljson';
2
+ import { Rljson, TableCfg, TableKey } from '@rljson/rljson';
3
3
  export interface Io {
4
+ /** Starts the initialization */
5
+ init(): Promise<void>;
4
6
  /** A promise resolving once the Io interface is ready
5
7
  *
6
8
  * 💡 Use @rljson/is-ready
@@ -12,6 +14,10 @@ export interface Io {
12
14
  dumpTable(request: {
13
15
  table: string;
14
16
  }): Promise<Rljson>;
17
+ /**
18
+ * Returns true if the table exists
19
+ */
20
+ tableExists(tableKey: TableKey): Promise<boolean>;
15
21
  /**
16
22
  * Creates a table with a given config.
17
23
  * If the table already exists, new columns are added to the existing table.
@@ -34,7 +40,7 @@ export interface Io {
34
40
  readRows(request: {
35
41
  table: string;
36
42
  where: {
37
- [column: string]: JsonValue;
43
+ [column: string]: JsonValue | null;
38
44
  };
39
45
  }): Promise<Rljson>;
40
46
  /** Returns the number of rows in the given table */
package/dist/io.js CHANGED
@@ -3,8 +3,8 @@ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { en
3
3
  var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
4
4
  import { hip, hsh } from "@rljson/hash";
5
5
  import { IsReady } from "@rljson/is-ready";
6
- import { jsonValueTypes, copy, equals } from "@rljson/json";
7
- import { iterateTablesSync } from "@rljson/rljson";
6
+ import { copy, equals } from "@rljson/json";
7
+ import { iterateTables, throwOnInvalidTableCfg, iterateTablesSync } from "@rljson/rljson";
8
8
  // @license
9
9
  const _IoTools = class _IoTools {
10
10
  /**
@@ -17,13 +17,13 @@ const _IoTools = class _IoTools {
17
17
  */
18
18
  __publicField(this, "initRevisionsTable", async () => {
19
19
  const tableCfg = {
20
- version: 1,
21
20
  key: "revisions",
22
21
  type: "ingredients",
23
22
  isHead: true,
24
23
  isRoot: true,
25
24
  isShared: false,
26
25
  columns: [
26
+ { key: "_hash", type: "string" },
27
27
  { key: "table", type: "string" },
28
28
  { key: "predecessor", type: "string" },
29
29
  { key: "successor", type: "string" },
@@ -38,7 +38,7 @@ const _IoTools = class _IoTools {
38
38
  /**
39
39
  * Returns the table configuration of the tableCfgs table.
40
40
  */
41
- get tableCfgsTableCfg() {
41
+ static get tableCfgsTableCfg() {
42
42
  const tableCfg = hip({
43
43
  _hash: "",
44
44
  key: "tableCfgs",
@@ -46,7 +46,7 @@ const _IoTools = class _IoTools {
46
46
  isHead: false,
47
47
  isRoot: false,
48
48
  isShared: true,
49
- version: 1,
49
+ previous: "",
50
50
  columns: [
51
51
  { key: "_hash", type: "string" },
52
52
  { key: "key", type: "string" },
@@ -54,12 +54,40 @@ const _IoTools = class _IoTools {
54
54
  { key: "isHead", type: "boolean" },
55
55
  { key: "isRoot", type: "boolean" },
56
56
  { key: "isShared", type: "boolean" },
57
- { key: "version", type: "number" },
57
+ { key: "previous", type: "string" },
58
58
  { key: "columns", type: "jsonArray" }
59
59
  ]
60
60
  });
61
61
  return tableCfg;
62
62
  }
63
+ /**
64
+ * Throws if the table does not exist
65
+ */
66
+ async throwWhenTableDoesNotExist(table) {
67
+ const exists = await this.io.tableExists(table);
68
+ if (!exists) {
69
+ throw new Error(`Table "${table}" not found`);
70
+ }
71
+ }
72
+ /**
73
+ * Throws if any of the tables in rljson do not exist
74
+ * @param rljson - The Rljson object to check
75
+ */
76
+ async throwWhenTablesDoNotExist(rljson) {
77
+ try {
78
+ await iterateTables(rljson, async (tableKey) => {
79
+ const exists = await this.io.tableExists(tableKey);
80
+ if (!exists) {
81
+ throw new Error(`Table "${tableKey}" not found`);
82
+ }
83
+ });
84
+ } catch (e) {
85
+ const missingTables = e.map((e2) => e2.tableKey);
86
+ throw new Error(
87
+ `The following tables do not exist: ${missingTables.join(", ")}`
88
+ );
89
+ }
90
+ }
63
91
  /**
64
92
  * Returns a list with all table names
65
93
  */
@@ -102,13 +130,7 @@ const _IoTools = class _IoTools {
102
130
  */
103
131
  async throwWhenTableIsNotCompatible(update) {
104
132
  const prefix = `Invalid update of table able "${update.key}"`;
105
- for (const column of update.columns) {
106
- if (!jsonValueTypes.includes(column.type)) {
107
- throw new Error(
108
- `${prefix}: Column "${column.key}" has an unsupported type "${column.type}"`
109
- );
110
- }
111
- }
133
+ throwOnInvalidTableCfg(update);
112
134
  const existing = await this.tableCfgOrNull(update.key);
113
135
  if (existing) {
114
136
  if (existing.columns.length > update.columns.length) {
@@ -150,6 +172,8 @@ const _IoTools = class _IoTools {
150
172
  */
151
173
  __publicField(_IoTools, "example", async () => {
152
174
  const io = await IoMem.example();
175
+ await io.init();
176
+ await io.isReady();
153
177
  return new _IoTools(io);
154
178
  });
155
179
  let IoTools = _IoTools;
@@ -166,7 +190,7 @@ const _IoMem = class _IoMem {
166
190
  __publicField(this, "_mem", hip({}));
167
191
  // ...........................................................................
168
192
  __publicField(this, "_initTableCfgs", () => {
169
- const tableCfg = this._ioTools.tableCfgsTableCfg;
193
+ const tableCfg = IoTools.tableCfgsTableCfg;
170
194
  this._mem.tableCfgs = hip({
171
195
  _data: [tableCfg],
172
196
  _type: "ingredients",
@@ -174,7 +198,9 @@ const _IoMem = class _IoMem {
174
198
  });
175
199
  hip(this._mem, { updateExistingHashes: true, throwOnWrongHashes: false });
176
200
  });
177
- this._init();
201
+ }
202
+ init() {
203
+ return this._init();
178
204
  }
179
205
  // ...........................................................................
180
206
  // General
@@ -208,21 +234,24 @@ const _IoMem = class _IoMem {
208
234
  }
209
235
  // ...........................................................................
210
236
  // Table management
237
+ async tableExists(tableKey) {
238
+ const table = this._mem[tableKey];
239
+ return table ? true : false;
240
+ }
211
241
  createOrExtendTable(request) {
212
242
  return this._createOrExtendTable(request);
213
243
  }
214
244
  async tableCfgs() {
215
245
  const tables = this._mem.tableCfgs._data;
216
246
  const newestVersion = {};
217
- for (const table of tables) {
247
+ for (let i = tables.length - 1; i >= 0; i--) {
248
+ const table = tables[i];
218
249
  const existing = newestVersion[table.key];
219
250
  if (!existing) {
220
251
  newestVersion[table.key] = table;
221
- } else if (table.version > existing.version) {
222
- newestVersion[table.key] = table;
223
252
  }
224
253
  }
225
- const resultData = Object.values(newestVersion);
254
+ const resultData = Object.values(newestVersion).reverse();
226
255
  return hip({
227
256
  tableCfgs: {
228
257
  _type: "ingredients",
@@ -239,27 +268,38 @@ const _IoMem = class _IoMem {
239
268
  }
240
269
  // ...........................................................................
241
270
  async _createOrExtendTable(request) {
242
- var _a;
243
- await this._ioTools.throwWhenTableIsNotCompatible(request.tableCfg);
244
- const { type, key } = request.tableCfg;
245
- const newConfig = hsh(request.tableCfg);
246
- const existingConfig = this._mem.tableCfgs._data.find(
247
- (cfg) => cfg._hash === newConfig._hash
248
- );
271
+ const tableCfg = request.tableCfg;
272
+ await this._ioTools.throwWhenTableIsNotCompatible(tableCfg);
273
+ const { type, key } = tableCfg;
274
+ const newConfig = hsh(tableCfg);
275
+ const existingConfig = await this._ioTools.tableCfgOrNull(key);
249
276
  if (!existingConfig) {
250
- this._mem.tableCfgs._data.push(newConfig);
251
- this._mem.tableCfgs._hash = "";
252
- hip(this._mem.tableCfgs, {
253
- updateExistingHashes: false,
254
- throwOnWrongHashes: false
255
- });
277
+ this._createTable(newConfig, type, key);
278
+ } else {
279
+ this._extendTable(existingConfig, newConfig);
256
280
  }
281
+ }
282
+ // ...........................................................................
283
+ _createTable(newConfig, type, tableKey) {
284
+ var _a;
285
+ newConfig = hsh(newConfig);
286
+ this._mem.tableCfgs._data.push(newConfig);
257
287
  const table = {
258
288
  _data: [],
259
289
  _type: type,
260
290
  _tableCfg: newConfig._hash
261
291
  };
262
- (_a = this._mem)[key] ?? (_a[key] = hip(table));
292
+ (_a = this._mem)[tableKey] ?? (_a[tableKey] = hip(table));
293
+ }
294
+ // ...........................................................................
295
+ _extendTable(existingConfig, newConfig) {
296
+ if (existingConfig.columns.length === newConfig.columns.length) {
297
+ return;
298
+ }
299
+ newConfig = hsh(newConfig);
300
+ this._mem.tableCfgs._data.push(newConfig);
301
+ const table = this._mem[newConfig.key];
302
+ table._tableCfg = newConfig._hash;
263
303
  }
264
304
  // ...........................................................................
265
305
  async _dump() {
@@ -267,10 +307,8 @@ const _IoMem = class _IoMem {
267
307
  }
268
308
  // ...........................................................................
269
309
  async _dumpTable(request) {
310
+ await this._ioTools.throwWhenTableDoesNotExist(request.table);
270
311
  const table = this._mem[request.table];
271
- if (!table) {
272
- throw new Error(`Table ${request.table} not found`);
273
- }
274
312
  return {
275
313
  [request.table]: copy(table)
276
314
  };
@@ -279,13 +317,10 @@ const _IoMem = class _IoMem {
279
317
  async _write(request) {
280
318
  const addedData = hsh(request.data);
281
319
  const tables = Object.keys(addedData);
320
+ await this._ioTools.throwWhenTablesDoNotExist(request.data);
282
321
  for (const table of tables) {
283
322
  if (table.startsWith("_")) {
284
323
  continue;
285
- } else {
286
- if (!this._mem[table]) {
287
- throw new Error(`Table ${table} does not exist`);
288
- }
289
324
  }
290
325
  const oldTable = this._mem[table];
291
326
  const newTable = addedData[table];
@@ -307,10 +342,8 @@ const _IoMem = class _IoMem {
307
342
  }
308
343
  // ...........................................................................
309
344
  async _readRows(request) {
345
+ await this._ioTools.throwWhenTableDoesNotExist(request.table);
310
346
  const table = this._mem[request.table];
311
- if (!table) {
312
- throw new Error(`Table ${request.table} not found`);
313
- }
314
347
  const result = {
315
348
  [request.table]: {
316
349
  _data: table._data.filter((row) => {
@@ -442,3 +475,4 @@ export {
442
475
  calcReverseRefs,
443
476
  exampleIo
444
477
  };
478
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"io.js","sources":["../src/io-tools.ts","../src/io-mem.ts","../src/io.ts","../src/reverse-ref.ts"],"sourcesContent":["// @license\n// Copyright (c) 2025 Rljson\n//\n// Use of this source code is governed by terms that can be\n// found in the LICENSE file in the root of this package.\n\nimport { hip } from '@rljson/hash';\nimport {\n  iterateTables,\n  Rljson,\n  TableCfg,\n  TableKey,\n  throwOnInvalidTableCfg,\n} from '@rljson/rljson';\n\nimport { IoMem } from './io-mem.ts';\nimport { Io } from './io.ts';\n\n/**\n * Provides utility functions for the Io interface.\n */\nexport class IoTools {\n  /**\n   * Constructor\n   * @param io The Io interface to use\n   */\n  constructor(public readonly io: Io) {}\n\n  /**\n   * Returns the table configuration of the tableCfgs table.\n   */\n  static get tableCfgsTableCfg() {\n    const tableCfg = hip<TableCfg>({\n      _hash: '',\n      key: 'tableCfgs',\n      type: 'ingredients',\n      isHead: false,\n      isRoot: false,\n      isShared: true,\n      previous: '',\n\n      columns: [\n        { key: '_hash', type: 'string' },\n        { key: 'key', type: 'string' },\n        { key: 'type', type: 'string' },\n        { key: 'isHead', type: 'boolean' },\n        { key: 'isRoot', type: 'boolean' },\n        { key: 'isShared', type: 'boolean' },\n        { key: 'previous', type: 'string' },\n        { key: 'columns', type: 'jsonArray' },\n      ],\n    });\n\n    return tableCfg;\n  }\n\n  /**\n   * Initializes the revisions table.\n   */\n  initRevisionsTable = async () => {\n    const tableCfg: TableCfg = {\n      key: 'revisions',\n      type: 'ingredients',\n      isHead: true,\n      isRoot: true,\n      isShared: false,\n\n      columns: [\n        { key: '_hash', type: 'string' },\n        { key: 'table', type: 'string' },\n        { key: 'predecessor', type: 'string' },\n        { key: 'successor', type: 'string' },\n        { key: 'timestamp', type: 'number' },\n        { key: 'id', type: 'string' },\n      ],\n    };\n\n    await this.io.createOrExtendTable({ tableCfg });\n  };\n\n  /**\n   * Example object for test purposes\n   * @returns An instance of io tools\n   */\n  static example = async () => {\n    const io = await IoMem.example();\n    await io.init();\n    await io.isReady();\n    return new IoTools(io);\n  };\n\n  /**\n   * Throws if the table does not exist\n   */\n  async throwWhenTableDoesNotExist(table: TableKey): Promise<void> {\n    const exists = await this.io.tableExists(table);\n    if (!exists) {\n      throw new Error(`Table \"${table}\" not found`);\n    }\n  }\n\n  /**\n   * Throws if any of the tables in rljson do not exist\n   * @param rljson - The Rljson object to check\n   */\n  async throwWhenTablesDoNotExist(rljson: Rljson): Promise<void> {\n    try {\n      await iterateTables(rljson, async (tableKey) => {\n        const exists = await this.io.tableExists(tableKey);\n        if (!exists) {\n          throw new Error(`Table \"${tableKey}\" not found`);\n        }\n      });\n    } catch (e) {\n      const missingTables = (e as Array<any>).map((e) => e.tableKey);\n\n      throw new Error(\n        `The following tables do not exist: ${missingTables.join(', ')}`,\n      );\n    }\n  }\n\n  /**\n   * Returns a list with all table names\n   */\n  async allTableKeys(): Promise<string[]> {\n    const result = (await this.io.tableCfgs()).tableCfgs._data.map(\n      (e) => e.key,\n    );\n    return result;\n  }\n\n  /**\n   * Returns the configuration of a given table\n   */\n  async tableCfg(table: TableKey): Promise<TableCfg> {\n    const tableCfg = await this.tableCfgOrNull(table);\n    if (!tableCfg) {\n      throw new Error(`Table \"${table}\" not found`);\n    }\n\n    return tableCfg!;\n  }\n\n  /**\n   * Returns the configuration of a given table or null if it does not exist.\n\n   */\n  async tableCfgOrNull(table: TableKey): Promise<TableCfg | null> {\n    const tableCfgs = await this.io.tableCfgs();\n    const tableCfg = tableCfgs.tableCfgs._data.find((e) => e.key === table);\n    return tableCfg ?? null;\n  }\n\n  /**\n   * Returns a list of all column names of a given table\n   */\n  async allColumnKeys(table: TableKey): Promise<string[]> {\n    const tableCfg = await this.tableCfg(table);\n    const result = tableCfg.columns.map((column) => column.key);\n    return result;\n  }\n\n  /**\n   * Throws when a table update is not compatible with the current table\n   * configuration.\n   */\n  async throwWhenTableIsNotCompatible(update: TableCfg): Promise<void> {\n    const prefix = `Invalid update of table able \"${update.key}\"`;\n\n    throwOnInvalidTableCfg(update);\n\n    // Check compatibility with existing table\n    const existing = await this.tableCfgOrNull(update.key);\n    if (existing) {\n      // Have columns been deleted?\n      if (existing.columns.length > update.columns.length) {\n        const deletedColumnKeys = existing.columns\n          .map((column) => column.key)\n          .filter(\n            (key) => !update.columns.some((column) => column.key === key),\n          );\n        if (deletedColumnKeys.length > 0) {\n          const deletedColumns = deletedColumnKeys.join(', ');\n          throw new Error(\n            `${prefix}: Columns must not be deleted. ` +\n              `Deleted columns: ${deletedColumns}}`,\n          );\n        }\n      }\n\n      // Have column keys changed?\n      for (let i = 0; i < existing.columns.length; i++) {\n        const before = existing.columns[i].key;\n        const after = update.columns[i].key;\n        if (before !== after) {\n          throw new Error(\n            `${prefix}: ` +\n              `Column keys must not change! ` +\n              `Column \"${before}\" was renamed into \"${after}\".`,\n          );\n        }\n      }\n\n      // Have column types changed?\n      for (let i = 0; i < existing.columns.length; i++) {\n        const column = existing.columns[i].key;\n        const before = existing.columns[i].type;\n        const after = update.columns[i].type;\n        if (before !== after) {\n          throw new Error(\n            `${prefix}: ` +\n              `Column types must not change! ` +\n              `Type of column \"${column}\" was changed from \"${before}\" to ${after}.`,\n          );\n        }\n      }\n    }\n  }\n}\n","// @license\n// Copyright (c) 2025 Rljson\n//\n// Use of this source code is governed by terms that can be\n// found in the LICENSE file in the root of this package.\n\nimport { hip, hsh } from '@rljson/hash';\nimport { IsReady } from '@rljson/is-ready';\nimport { copy, equals, JsonValue } from '@rljson/json';\nimport {\n  ContentType,\n  Rljson,\n  TableCfg,\n  TableKey,\n  TableType,\n} from '@rljson/rljson';\n\nimport { IoTools } from './io-tools.ts';\nimport { Io } from './io.ts';\n\n/**\n * In-Memory implementation of the Rljson Io interface.\n */\nexport class IoMem implements Io {\n  // ...........................................................................\n  // Constructor & example\n  constructor() {}\n\n  init(): Promise<void> {\n    return this._init();\n  }\n\n  static example = async () => {\n    return new IoMem();\n  };\n\n  // ...........................................................................\n  // General\n  isReady() {\n    return this._isReady.promise;\n  }\n\n  // ...........................................................................\n  // Dump\n\n  dump(): Promise<Rljson> {\n    return this._dump();\n  }\n\n  async dumpTable(request: { table: string }): Promise<Rljson> {\n    return this._dumpTable(request);\n  }\n\n  // ...........................................................................\n  // Rows\n\n  readRows(request: {\n    table: string;\n    where: { [column: string]: JsonValue };\n  }): Promise<Rljson> {\n    return this._readRows(request);\n  }\n\n  async rowCount(table: string): Promise<number> {\n    const tableData = this._mem[table] as TableType;\n    if (!tableData) {\n      throw new Error(`Table \"${table}\" not found`);\n    }\n    return Promise.resolve(tableData._data.length);\n  }\n\n  // ...........................................................................\n  // Write\n\n  write(request: { data: Rljson }): Promise<void> {\n    return this._write(request);\n  }\n\n  // ...........................................................................\n  // Table management\n  async tableExists(tableKey: TableKey): Promise<boolean> {\n    const table = this._mem[tableKey] as TableType;\n    return table ? true : false;\n  }\n\n  createOrExtendTable(request: { tableCfg: TableCfg }): Promise<void> {\n    return this._createOrExtendTable(request);\n  }\n\n  async tableCfgs(): Promise<Rljson> {\n    const tables = this._mem.tableCfgs._data as TableCfg[];\n\n    // Take the latest version of each type key\n    const newestVersion: Record<TableKey, TableCfg> = {};\n    for (let i = tables.length - 1; i >= 0; i--) {\n      const table = tables[i];\n      const existing = newestVersion[table.key];\n      if (!existing) {\n        newestVersion[table.key] = table;\n      }\n    }\n\n    const resultData = Object.values(newestVersion).reverse();\n\n    return hip({\n      tableCfgs: {\n        _type: 'ingredients',\n        _data: resultData,\n      },\n    } as Rljson);\n  }\n\n  // ######################\n  // Private\n  // ######################\n\n  private _ioTools!: IoTools;\n\n  private _isReady = new IsReady();\n\n  private _mem: Rljson = hip({} as Rljson);\n\n  // ...........................................................................\n  private async _init() {\n    this._ioTools = new IoTools(this);\n    this._initTableCfgs();\n    await this._ioTools.initRevisionsTable();\n\n    this._isReady.resolve();\n  }\n\n  // ...........................................................................\n  private _initTableCfgs = () => {\n    const tableCfg = IoTools.tableCfgsTableCfg;\n\n    this._mem.tableCfgs = hip({\n      _data: [tableCfg],\n      _type: 'ingredients',\n      _tableCfg: tableCfg._hash as string,\n    });\n\n    hip(this._mem, { updateExistingHashes: true, throwOnWrongHashes: false });\n  };\n\n  // ...........................................................................\n  private async _createOrExtendTable(request: {\n    tableCfg: TableCfg;\n  }): Promise<void> {\n    // Make sure that the table config is compatible\n    // with an potential existing table\n    const tableCfg = request.tableCfg;\n    await this._ioTools.throwWhenTableIsNotCompatible(tableCfg);\n\n    const { type, key } = tableCfg;\n\n    // Recreate hashes in the case the existing hashes are wrong\n    const newConfig = hsh(tableCfg);\n\n    // Find an existing table config with the same hash\n    const existingConfig = await this._ioTools.tableCfgOrNull(key);\n\n    // Write the new config into the database\n    if (!existingConfig) {\n      this._createTable(newConfig, type, key);\n    } else {\n      this._extendTable(existingConfig, newConfig);\n    }\n  }\n\n  // ...........................................................................\n  private _createTable(\n    newConfig: TableCfg,\n    type: ContentType,\n    tableKey: TableKey,\n  ) {\n    // Write the table config into the database\n    newConfig = hsh(newConfig);\n    this._mem.tableCfgs._data.push(newConfig);\n\n    // Create a table and write it into the database\n    const table: TableType = {\n      _data: [],\n      _type: type,\n      _tableCfg: newConfig._hash as string,\n    };\n\n    this._mem[tableKey] ??= hip(table);\n  }\n\n  // ...........................................................................\n  private _extendTable(existingConfig: TableCfg, newConfig: TableCfg) {\n    // No columns added? Return.\n    if (existingConfig.columns.length === newConfig.columns.length) {\n      return;\n    }\n\n    // Write the new table config into the database\n    newConfig = hsh(newConfig);\n    this._mem.tableCfgs._data.push(newConfig);\n\n    // Update the config of the existing table\n    const table = this._mem[newConfig.key] as TableType;\n    table._tableCfg = newConfig._hash as string;\n  }\n\n  // ...........................................................................\n\n  private async _dump(): Promise<Rljson> {\n    return copy(this._mem);\n  }\n\n  // ...........................................................................\n  private async _dumpTable(request: { table: string }): Promise<Rljson> {\n    await this._ioTools.throwWhenTableDoesNotExist(request.table);\n\n    const table = this._mem[request.table] as TableType;\n\n    return {\n      [request.table]: copy(table),\n    };\n  }\n\n  // ...........................................................................\n  private async _write(request: { data: Rljson }): Promise<void> {\n    const addedData = hsh(request.data);\n    const tables = Object.keys(addedData);\n\n    await this._ioTools.throwWhenTablesDoNotExist(request.data);\n\n    for (const table of tables) {\n      if (table.startsWith('_')) {\n        continue;\n      }\n\n      const oldTable = this._mem[table] as TableType;\n      const newTable = addedData[table] as TableType;\n\n      // Make sure oldTable and newTable have the same type\n      if (oldTable._type !== newTable._type) {\n        throw new Error(\n          `Table ${table} has different types: \"${oldTable._type}\" vs \"${newTable._type}\"`,\n        );\n      }\n\n      // Table exists. Merge data\n      for (const item of newTable._data) {\n        const hash = item._hash;\n        const exists = oldTable._data.find((i) => i._hash === hash);\n        if (!exists) {\n          oldTable._data.push(item as any);\n        }\n      }\n    }\n\n    // Recalc main hashes\n    (this._mem as any)._hash = '';\n    hip(this._mem, { updateExistingHashes: false, throwOnWrongHashes: false });\n  }\n\n  // ...........................................................................\n  private async _readRows(request: {\n    table: string;\n    where: { [column: string]: JsonValue };\n  }): Promise<Rljson> {\n    await this._ioTools.throwWhenTableDoesNotExist(request.table);\n\n    const table = this._mem[request.table] as TableType;\n\n    const result: Rljson = {\n      [request.table]: {\n        _data: table._data.filter((row) => {\n          for (const column in request.where) {\n            const a = row[column];\n            const b = request.where[column];\n            if (!equals(a, b)) {\n              return false;\n            }\n          }\n          return true;\n        }),\n      },\n    } as any;\n\n    return result;\n  }\n}\n","// @license\n// Copyright (c) 2025 Rljson\n//\n// Use of this source code is governed by terms that can be\n// found in the LICENSE file in the root of this package.\n\nimport { JsonValue } from '@rljson/json';\nimport { Rljson, TableCfg, TableKey } from '@rljson/rljson';\n\n// .............................................................................\nexport interface Io {\n  // ...........................................................................\n  // General\n\n  /** Starts the initialization */\n  init(): Promise<void>;\n\n  /** A promise resolving once the Io interface is ready\n   *\n   * 💡 Use @rljson/is-ready\n   */\n  isReady(): Promise<void>;\n\n  // ...........................................................................\n  // Dump\n\n  /** Returns the complete db content as Rljson */\n  dump(): Promise<Rljson>;\n\n  /** Returns the dump of a complete table */\n  dumpTable(request: { table: string }): Promise<Rljson>;\n\n  // ...........................................................................\n  // Tables\n\n  /**\n   * Returns true if the table exists\n   */\n  tableExists(tableKey: TableKey): Promise<boolean>;\n\n  /**\n   * Creates a table with a given config.\n   * If the table already exists, new columns are added to the existing table.\n   * If the table does not exist, it is created with the given config.\n   * If the table exists and columns are removed, an error is thrown.\n   * If the table exists and the column type is changed, an error is thrown.\n   */\n  createOrExtendTable(request: { tableCfg: TableCfg }): Promise<void>;\n\n  /**\n   * Returns a json structure returning current table configurations\n   */\n  tableCfgs(): Promise<Rljson>;\n\n  // ...........................................................................\n  // Write\n\n  /** Writes Rljson data into the database */\n  write(request: { data: Rljson }): Promise<void>;\n\n  // ...........................................................................\n  // Read rows\n\n  /** Queries a list of rows */\n  readRows(request: {\n    table: string;\n    where: { [column: string]: JsonValue | null };\n  }): Promise<Rljson>;\n\n  /** Returns the number of rows in the given table */\n  rowCount(table: string): Promise<number>;\n}\n\n// .............................................................................\nexport const exampleIo =\n  'Checkout @rljson/io-mem for an example implementation';\n","// @license\n// Copyright (c) 2025 Rljson\n//\n// Use of this source code is governed by terms that can be\n// found in the LICENSE file in the root of this package.\n\nimport { Json } from '@rljson/json';\nimport {\n  Buffet,\n  Cake,\n  iterateTablesSync,\n  Layer,\n  Ref,\n  Rljson,\n  TableKey,\n} from '@rljson/rljson';\n\n// .............................................................................\n/**\n * Describes a row that references a child table row\n */\nexport interface ParentRef {\n  /**\n   * The parent table that references the child table\n   */\n  [parentTable: TableKey]: {\n    /**\n     * The parent row that references the child row\n     */\n    [parentRow: Ref]: {\n      /**\n       * Details about the reference, e.g. an array index etc.\n       */\n      details?: Json;\n    };\n  };\n}\n\n// .............................................................................\n/**\n * Describes the parent table rows referencing a child table row\n */\nexport interface ReverseRefs {\n  /**\n   * The child table we need the referencing rows for\n   */\n  [childTable: TableKey]: {\n    /**\n     * The row hashwe need the referencing rows for\n     */\n    [childRow: Ref]: ParentRef;\n  };\n}\n\n// .............................................................................\n/**\n * Calculates the reverse references for a given rljson object\n */\nexport const calcReverseRefs = (rljson: Rljson): ReverseRefs => {\n  const result: ReverseRefs = {};\n\n  // ......................\n  // Prepare data structure\n  iterateTablesSync(rljson, (childTableKey, table) => {\n    const childTable: { [childRowHash: string]: ParentRef } = {};\n    result[childTableKey] = childTable;\n    for (const childRow of table._data) {\n      childTable[childRow._hash] = {};\n    }\n  });\n\n  // ............................\n  // Generate reverse references\n  iterateTablesSync(rljson, (parentTableKey, parentTable) => {\n    // Iterate all rows of each table\n    for (const parentTableRow of parentTable._data) {\n      // Find out whe other tables & rows are referenced by this row\n      // Write these information intto result\n      switch (parentTable._type) {\n        case 'ingredients':\n          _writeIngredientRefs(parentTableKey, parentTableRow, result);\n          break;\n\n        case 'layers': {\n          _writeLayerRefs(parentTableKey, parentTableRow, result);\n          break;\n        }\n\n        case 'sliceIds': {\n          // Slice ids do not reference other tables\n          break;\n        }\n\n        case 'cakes': {\n          _writeCakeRefs(parentTableKey, parentTableRow, result);\n          break;\n        }\n\n        case 'buffets': {\n          _writeBuffetRefs(parentTableKey, parentTableRow, result);\n          break;\n        }\n      }\n    }\n  });\n\n  return result;\n};\n\n// .............................................................................\nconst _writeIngredientRefs = (\n  parentTableName: TableKey,\n  parentRow: Json,\n  result: ReverseRefs,\n) => {\n  const parentRowHash = parentRow._hash as string;\n\n  for (const parentColumnName in parentRow) {\n    if (parentColumnName.startsWith('_')) {\n      continue;\n    }\n\n    if (!parentColumnName.endsWith('Ref')) {\n      continue;\n    }\n\n    const childTableName = parentColumnName.slice(0, -3);\n    const childRowHash = parentRow[parentColumnName] as string;\n\n    _write(\n      result,\n      childTableName,\n      childRowHash,\n      parentTableName,\n      parentRowHash,\n    );\n  }\n};\n\n// .............................................................................\nconst _writeLayerRefs = (\n  parentTableName: TableKey,\n  parentRow: Layer,\n  result: ReverseRefs,\n) => {\n  const childTableName = parentRow.ingredientsTable;\n  const parentRowHash = parentRow._hash as string;\n\n  for (const sliceId in parentRow.assign) {\n    if (sliceId.startsWith('_')) {\n      continue;\n    }\n\n    const sliceHash = parentRow.assign[sliceId] as string;\n\n    _write(result, childTableName, sliceHash, parentTableName, parentRowHash);\n  }\n};\n\n// .............................................................................\nconst _writeCakeRefs = (\n  parentTableName: TableKey,\n  parentRow: Cake,\n  result: ReverseRefs,\n) => {\n  const parentRowHash = parentRow._hash as string;\n\n  for (const layer in parentRow.layers) {\n    const childTableName = parentRow.layersTable;\n    const childRowHash = parentRow.layers[layer] as string;\n    _write(\n      result,\n      childTableName,\n      childRowHash,\n      parentTableName,\n      parentRowHash,\n    );\n  }\n};\n\n// .............................................................................\nconst _writeBuffetRefs = (\n  parentTableName: TableKey,\n  parentRow: Buffet,\n  result: ReverseRefs,\n) => {\n  const parentRowHash = parentRow._hash as string;\n\n  for (const item of parentRow.items) {\n    const childTableName = item.table;\n    const childRowHash = item.ref;\n    _write(\n      result,\n      childTableName,\n      childRowHash,\n      parentTableName,\n      parentRowHash,\n    );\n  }\n};\n\n// .............................................................................\nconst _write = (\n  result: ReverseRefs,\n  childTableName: string,\n  childRowHash: string,\n  parentTableName: string,\n  parentRowHash: string,\n) => {\n  const referencesForChildTable = (result[childTableName] ??= {});\n  const referencesForChildTableRow = (referencesForChildTable[childRowHash] ??=\n    {});\n\n  referencesForChildTableRow[parentTableName] ??= {};\n  referencesForChildTableRow[parentTableName][parentRowHash] ??= {};\n};\n"],"names":["e"],"mappings":"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"}
@@ -4,59 +4,7 @@
4
4
  // Use of this source code is governed by terms that can be
5
5
  // found in the LICENSE file in the root of this package.
6
6
 
7
- import { hip, hsh } from '@rljson/hash';
8
- import { Rljson, TableCfg } from '@rljson/rljson';
9
-
10
- import { IoMem } from './io-mem.ts';
11
-
12
7
  // Run »pnpm updateGoldens« when you change this file
13
- export const example = async () => {
14
- const ioMem = new IoMem();
15
-
16
- const row = { keyA2: 'a2' };
17
- const rowWithHash = hsh(row);
18
-
19
- // Create a table config first
20
- const tableCfg = hip<TableCfg>({
21
- key: 'tableA',
22
- type: 'ingredients',
23
- columns: [],
24
- version: 1,
25
- isHead: true,
26
- isRoot: true,
27
- isShared: false,
28
- });
29
-
30
- await ioMem.write({
31
- data: {
32
- tableCfgs: {
33
- _type: 'ingredients',
34
- _data: [tableCfg],
35
- },
36
- },
37
- });
38
-
39
- // Create a table first
40
- await ioMem.createOrExtendTable({ tableCfg: tableCfg });
41
-
42
- // Write data into the table
43
- await ioMem.write({
44
- data: {
45
- tableA: {
46
- _type: 'ingredients',
47
- _data: [row],
48
- },
49
- },
50
- });
51
-
52
- // Read data from the table
53
- const data: Rljson = await ioMem.readRows({
54
- table: 'tableA',
55
- where: { _hash: (rowWithHash as any)._hash },
56
- });
57
-
58
- // Print the return rljson data
59
- console.log(JSON.stringify(data, null, 2));
60
- };
8
+ export const example = async () => {};
61
9
 
62
10
  // example();
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@rljson/io",
3
- "version": "0.0.23",
4
- "packageManager": "pnpm@10.6.2",
3
+ "version": "0.0.26",
4
+ "packageManager": "pnpm@10.9.0",
5
5
  "description": "Low level interface for reading and writing RLJSON data",
6
6
  "homepage": "https://github.com/rljson/io",
7
7
  "bugs": "https://github.com/rljson/io/issues",
@@ -29,9 +29,9 @@
29
29
  "updateGoldens": "cross-env UPDATE_GOLDENS=true pnpm test"
30
30
  },
31
31
  "devDependencies": {
32
- "@types/node": "^22.15.2",
33
- "@typescript-eslint/eslint-plugin": "^8.31.0",
34
- "@typescript-eslint/parser": "^8.31.0",
32
+ "@types/node": "^22.15.3",
33
+ "@typescript-eslint/eslint-plugin": "^8.31.1",
34
+ "@typescript-eslint/parser": "^8.31.1",
35
35
  "@vitest/coverage-v8": "^3.1.2",
36
36
  "cross-env": "^7.0.3",
37
37
  "eslint": "^9.25.1",
@@ -41,7 +41,7 @@
41
41
  "jsdoc": "^4.0.4",
42
42
  "read-pkg": "^9.0.1",
43
43
  "typescript": "~5.8.3",
44
- "typescript-eslint": "^8.31.0",
44
+ "typescript-eslint": "^8.31.1",
45
45
  "vite": "^6.3.3",
46
46
  "vite-node": "^3.1.2",
47
47
  "vite-plugin-dts": "^4.5.3",
@@ -59,7 +59,7 @@
59
59
  "@rljson/hash": "^0.0.15",
60
60
  "@rljson/is-ready": "^0.0.17",
61
61
  "@rljson/json": "^0.0.21",
62
- "@rljson/rljson": "^0.0.42",
62
+ "@rljson/rljson": "^0.0.46",
63
63
  "@rljson/validate": "^0.0.10"
64
64
  }
65
65
  }