datanautics 3.0.0 → 4.1.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/CHANGELOG.md CHANGED
@@ -5,6 +5,22 @@ All notable changes to this project will be documented in this file.
5
5
  The format is based on [Keep a Changelog](http://keepachangelog.com/)
6
6
  and this project adheres to [Semantic Versioning](http://semver.org/).
7
7
 
8
+ ## [4.1.0] - 2025-08-11
9
+ ### Added
10
+ - time tracking for each update
11
+
12
+ ### Fixed
13
+ - setting/getting string values which contain spaces
14
+
15
+ ## [4.0.0] - 2025-06-25 (**Breaking changes!**)
16
+
17
+ ### Added
18
+
19
+ - Returned Auto-Save Mechanism as more efficient;
20
+ - Added **writer** (boolean, default true) to options, this property enables auto-syncs
21
+
22
+ ---
23
+
8
24
  ## [3.0.0] - 2025-06-20 (**Breaking changes!**)
9
25
 
10
26
  ### Removed
@@ -26,9 +26,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
26
26
  exports.defaultDatanauticsOptions = void 0;
27
27
  const console = __importStar(require("console"));
28
28
  const path_1 = require("path");
29
+ const default_dump_interval_1 = require("./default-dump-interval");
29
30
  exports.defaultDatanauticsOptions = {
31
+ dumpInterval: default_dump_interval_1.DEFAULT_DUMP_INTERVAL,
30
32
  verbose: true,
31
33
  logger: console,
32
- dumpPath: (0, path_1.resolve)(__dirname, '../../data/data.txt'),
34
+ dumpPath: (0, path_1.resolve)(__dirname, '../../data/data'),
35
+ writer: true
33
36
  };
34
37
  //# sourceMappingURL=default-datanautics-options.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"default-datanautics-options.js","sourceRoot":"","sources":["../../src/constants/default-datanautics-options.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,iDAAmC;AACnC,+BAA+B;AAIlB,QAAA,yBAAyB,GAAuB;IAC3D,OAAO,EAAE,IAAI;IACb,MAAM,EAAE,OAAO;IACf,QAAQ,EAAE,IAAA,cAAO,EAAC,SAAS,EAAE,qBAAqB,CAAC;CACpD,CAAC"}
1
+ {"version":3,"file":"default-datanautics-options.js","sourceRoot":"","sources":["../../src/constants/default-datanautics-options.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,iDAAmC;AACnC,+BAA+B;AAG/B,mEAAgE;AAEnD,QAAA,yBAAyB,GAAuB;IAC3D,YAAY,EAAE,6CAAqB;IACnC,OAAO,EAAE,IAAI;IACb,MAAM,EAAE,OAAO;IACf,QAAQ,EAAE,IAAA,cAAO,EAAC,SAAS,EAAE,iBAAiB,CAAC;IAC/C,MAAM,EAAE,IAAI;CACb,CAAC"}
@@ -0,0 +1 @@
1
+ export declare const DEFAULT_DUMP_INTERVAL: number;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DEFAULT_DUMP_INTERVAL = void 0;
4
+ exports.DEFAULT_DUMP_INTERVAL = 1000;
5
+ //# sourceMappingURL=default-dump-interval.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"default-dump-interval.js","sourceRoot":"","sources":["../../src/constants/default-dump-interval.ts"],"names":[],"mappings":";;;AAAa,QAAA,qBAAqB,GAAW,IAAI,CAAC"}
@@ -0,0 +1 @@
1
+ export declare const DUMP_EVENT: string;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DUMP_EVENT = void 0;
4
+ exports.DUMP_EVENT = 'dump';
5
+ //# sourceMappingURL=dump-event.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dump-event.js","sourceRoot":"","sources":["../../src/constants/dump-event.ts"],"names":[],"mappings":";;;AAAa,QAAA,UAAU,GAAW,MAAM,CAAC"}
@@ -1 +1,3 @@
1
+ export * from './default-dump-interval';
2
+ export * from './dump-event';
1
3
  export * from './default-datanautics-options';
@@ -14,5 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./default-dump-interval"), exports);
18
+ __exportStar(require("./dump-event"), exports);
17
19
  __exportStar(require("./default-datanautics-options"), exports);
18
20
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/constants/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,gEAA8C"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/constants/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0DAAwC;AACxC,+CAA6B;AAC7B,gEAA8C"}
@@ -1,10 +1,14 @@
1
+ /// <reference types="node" />
2
+ import { EventEmitter } from 'events';
1
3
  import { DatanauticsOptions } from './options';
2
4
  export declare class Datanautics {
3
5
  protected options: DatanauticsOptions;
4
6
  protected data: Record<string, any>;
7
+ protected timeLog: Record<string, number>;
8
+ protected eventEmitter: EventEmitter;
5
9
  constructor(options?: DatanauticsOptions);
6
- store(): boolean;
7
- protected createDump(): boolean;
10
+ store(): void;
11
+ protected createDump(): void;
8
12
  protected useDump(): void;
9
13
  set(key: string, value: any): boolean;
10
14
  get(key: string): any;
@@ -1,21 +1,40 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.Datanautics = void 0;
4
+ const events_1 = require("events");
4
5
  const fs_1 = require("fs");
5
6
  const property_accessor_1 = require("property-accessor");
6
7
  const _const_1 = require("./constants");
7
8
  class Datanautics {
8
9
  options;
9
10
  data;
11
+ timeLog;
12
+ eventEmitter;
10
13
  constructor(options) {
11
14
  this.options = { ..._const_1.defaultDatanauticsOptions, ...(options || {}) };
12
15
  this.data = {};
16
+ this.timeLog = {};
17
+ this.eventEmitter = new events_1.EventEmitter();
13
18
  if ((0, fs_1.existsSync)(this.options.dumpPath)) {
14
19
  this.useDump();
15
20
  }
16
- (0, fs_1.watchFile)(this.options.dumpPath, () => {
17
- this.useDump();
18
- });
21
+ else {
22
+ (0, fs_1.writeFileSync)(this.options.dumpPath, '', 'utf8');
23
+ }
24
+ if (options.writer) {
25
+ this.eventEmitter.on(_const_1.DUMP_EVENT, async () => {
26
+ this.createDump();
27
+ setTimeout(() => {
28
+ this.eventEmitter.emit(_const_1.DUMP_EVENT);
29
+ }, this.options.dumpInterval);
30
+ });
31
+ this.eventEmitter.emit(_const_1.DUMP_EVENT);
32
+ }
33
+ else {
34
+ (0, fs_1.watchFile)(this.options.dumpPath, () => {
35
+ this.useDump();
36
+ });
37
+ }
19
38
  }
20
39
  store() {
21
40
  return this.createDump();
@@ -27,24 +46,24 @@ class Datanautics {
27
46
  for (const key in flat) {
28
47
  const value = property_accessor_1.PropertyAccessor.get(key, this.data);
29
48
  if (value !== undefined) {
30
- data.push(`${key} ${value.toString()}`);
49
+ data.push(`${key} ${value.toString()} ${this.timeLog[key] ? this.timeLog[key] : ''}`);
31
50
  }
32
51
  }
33
52
  (0, fs_1.writeFileSync)(this.options.dumpPath, data.join('\n'), 'utf8');
34
- return true;
35
53
  }
36
54
  catch (e) {
37
55
  if (this.options.verbose) {
38
56
  this.options.logger.error(e);
39
57
  }
40
- return false;
41
58
  }
42
59
  }
43
60
  useDump() {
44
61
  const data = (0, fs_1.readFileSync)(this.options.dumpPath).toString('utf8');
45
62
  const lines = data.split('\n');
46
63
  for (const line of lines) {
47
- const [k, v,] = line.split(' ');
64
+ const [k, ...rest] = line.split(' ');
65
+ const timestamp = rest.pop();
66
+ const v = rest.join(' ');
48
67
  const key = k.trim();
49
68
  if (v !== undefined) {
50
69
  let value = v.trim();
@@ -55,11 +74,13 @@ class Datanautics {
55
74
  value = /^true$/.test(value);
56
75
  }
57
76
  property_accessor_1.PropertyAccessor.set(key, value, this.data);
77
+ this.timeLog[key] = parseInt(timestamp, 10);
58
78
  }
59
79
  }
60
80
  }
61
81
  set(key, value) {
62
- return property_accessor_1.PropertyAccessor.set(key, value, this.data) && this.createDump();
82
+ this.timeLog[key] = new Date().getTime();
83
+ return property_accessor_1.PropertyAccessor.set(key, value, this.data);
63
84
  }
64
85
  get(key) {
65
86
  return property_accessor_1.PropertyAccessor.get(key, this.data);
@@ -1 +1 @@
1
- {"version":3,"file":"datanautics.js","sourceRoot":"","sources":["../src/datanautics.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"datanautics.js","sourceRoot":"","sources":["../src/datanautics.ts"],"names":[],"mappings":"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"}
@@ -3,8 +3,10 @@ interface Logger {
3
3
  error(...args: any[]): void;
4
4
  }
5
5
  export type DatanauticsOptions = {
6
- dumpPath: string;
6
+ dumpPath?: string;
7
+ dumpInterval?: number;
7
8
  verbose?: boolean;
8
9
  logger?: Logger;
10
+ writer?: boolean;
9
11
  };
10
12
  export {};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "datanautics",
3
- "version": "3.0.0",
3
+ "version": "4.1.0",
4
4
  "description": "",
5
5
  "keywords": [
6
6
  "data store",
package/test/test.js CHANGED
@@ -8,20 +8,22 @@ const { setTimeout } = require('timers');
8
8
  const dumpPath = resolve(__dirname, './data.txt');
9
9
  const data = { user: { firstname: 'John', lastname: 'Doe' }, score: [27] };
10
10
 
11
- const db = new Datanautics({ dumpPath });
11
+ const writer = new Datanautics({ dumpPath, writer: true });
12
+ const reader = new Datanautics({ dumpPath, writer: false });
12
13
 
13
- assert.equal(db.set('user.firstname', data.user.firstname), true);
14
- assert.equal(db.set('user.lastname', data.user.lastname), true);
15
- assert.equal(db.set('score[0]', data.score[0]), true);
14
+ assert.equal(writer.set('user.firstname', data.user.firstname), true);
15
+ assert.equal(writer.set('user.lastname', data.user.lastname), true);
16
+ assert.equal(writer.set('score[0]', data.score[0]), true);
16
17
 
17
- assert.equal(db.get('user.firstname'), data.user.firstname);
18
- assert.equal(db.get('user.lastname'), data.user.lastname);
19
- assert.equal(db.get('score[0]'), data.score[0]);
18
+ assert.equal(writer.get('user.firstname'), data.user.firstname);
19
+ assert.equal(writer.get('user.lastname'), data.user.lastname);
20
+ assert.equal(writer.get('score[0]'), data.score[0]);
20
21
 
21
22
  setTimeout(() => {
22
- // const storedData = readFileSync(dumpPath).toString();
23
- // assert.equal(storedData, JSON.stringify(data, null, 2));
24
- // unlinkSync(dumpPath);
23
+
24
+ assert.equal(reader.get('user.firstname'), data.user.firstname);
25
+ assert.equal(reader.get('user.lastname'), data.user.lastname);
26
+ assert.equal(reader.get('score[0]'), data.score[0]);
25
27
  console.log('tests passed');
26
28
  process.exit(0);
27
- }, 1000);
29
+ }, 2000);