flat-cache 4.0.0 → 5.0.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/README.md CHANGED
@@ -1,4 +1,5 @@
1
1
  # flat-cache
2
+
2
3
  > A stupidly simple key/value storage using files to persist the data
3
4
 
4
5
  [![NPM Version](https://img.shields.io/npm/v/flat-cache.svg?style=flat)](https://npmjs.org/package/flat-cache)
@@ -15,19 +16,19 @@ npm i --save flat-cache
15
16
  ## Usage
16
17
 
17
18
  ```js
18
- var flatCache = require('flat-cache')
19
+ const flatCache = require('flat-cache');
19
20
  // loads the cache, if one does not exists for the given
20
21
  // Id a new one will be prepared to be created
21
- var cache = flatCache.load('cacheId');
22
+ const cache = flatCache.load('cacheId');
22
23
 
23
24
  // sets a key on the cache
24
25
  cache.setKey('key', { foo: 'var' });
25
26
 
26
27
  // get a key from the cache
27
- cache.getKey('key') // { foo: 'var' }
28
+ cache.getKey('key'); // { foo: 'var' }
28
29
 
29
30
  // fetch the entire persisted object
30
- cache.all() // { 'key': { foo: 'var' } }
31
+ cache.all(); // { 'key': { foo: 'var' } }
31
32
 
32
33
  // remove a key
33
34
  cache.removeKey('key'); // removes a key from the cache
@@ -38,11 +39,11 @@ cache.save(); // very important, if you don't save no changes will be persisted.
38
39
 
39
40
  // loads the cache from a given directory, if one does
40
41
  // not exists for the given Id a new one will be prepared to be created
41
- var cache = flatCache.load('cacheId', path.resolve('./path/to/folder'));
42
+ const cache = flatCache.load('cacheId', path.resolve('./path/to/folder'));
42
43
 
43
44
  // The following methods are useful to clear the cache
44
45
  // delete a given cache
45
- flatCache.clearCacheById('cacheId') // removes the cacheId document if one exists.
46
+ flatCache.clearCacheById('cacheId'); // removes the cacheId document if one exists.
46
47
 
47
48
  // delete all cache
48
49
  flatCache.clearAll(); // remove the cache directory
@@ -56,6 +57,7 @@ To make that possible we need to store the `fileSize` and `modificationTime` of
56
57
  storage was needed and Bam! this module was born.
57
58
 
58
59
  ## Important notes
60
+
59
61
  - If no directory is especified when the `load` method is called, a folder named `.cache` will be created
60
62
  inside the module directory when `cache.save` is called. If you're committing your `node_modules` to any vcs, you
61
63
  might want to ignore the default `.cache` folder, or specify a custom directory.
@@ -68,8 +70,5 @@ storage was needed and Bam! this module was born.
68
70
 
69
71
  ## License
70
72
 
71
- MIT
72
-
73
- ## Changelog
73
+ [MIT](LISCENCE) © [Jared Wray](https://jaredwray.com)
74
74
 
75
- [changelog](./changelog.md)
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "flat-cache",
3
- "version": "4.0.0",
3
+ "version": "5.0.0",
4
4
  "description": "A stupidly simple key/value storage using files to persist some data",
5
5
  "repository": "jaredwray/flat-cache",
6
6
  "license": "MIT",
@@ -15,24 +15,18 @@
15
15
  "src/utils.js"
16
16
  ],
17
17
  "engines": {
18
- "node": ">=16"
18
+ "node": ">=18"
19
19
  },
20
20
  "precommit": [
21
- "npm run verify --silent"
21
+ "npm run test"
22
22
  ],
23
23
  "prepush": [
24
- "npm run verify --silent"
24
+ "npm run test"
25
25
  ],
26
26
  "scripts": {
27
- "eslint": "eslint --cache --cache-location=node_modules/.cache/ ./src/**/*.js ./test/**/*.js",
28
27
  "clean": "rimraf ./node_modules ./package-lock.json ./yarn.lock ./coverage",
29
- "eslint-fix": "npm run eslint -- --fix",
30
- "autofix": "npm run eslint-fix",
31
- "check": "npm run eslint",
32
- "verify": "npm run eslint && npm run test:cache",
33
- "test:cache": "c8 mocha -R spec test/specs",
34
- "test:ci:cache": "c8 --reporter=lcov mocha -R spec test/specs",
35
- "test": "npm run verify --silent"
28
+ "test:ci": "xo && c8 --reporter=lcov mocha -R spec test/specs",
29
+ "test": "xo --fix && c8 mocha -R spec test/specs"
36
30
  },
37
31
  "keywords": [
38
32
  "json cache",
@@ -43,20 +37,25 @@
43
37
  "cache"
44
38
  ],
45
39
  "devDependencies": {
46
- "c8": "^8.0.1",
40
+ "c8": "^9.1.0",
47
41
  "chai": "^4.3.10",
48
- "eslint": "^8.56.0",
49
- "eslint-config-prettier": "^9.1.0",
50
- "eslint-plugin-mocha": "^10.2.0",
51
- "eslint-plugin-prettier": "^5.0.1",
52
42
  "glob-expand": "^0.2.1",
53
- "mocha": "^10.2.0",
54
- "prettier": "^3.1.1",
55
- "write": "^2.0.0"
43
+ "mocha": "^10.4.0",
44
+ "rimraf": "^5.0.7",
45
+ "sinon": "^18.0.0",
46
+ "webpack": "^5.91.0",
47
+ "write": "^2.0.0",
48
+ "xo": "^0.58.0"
56
49
  },
57
50
  "dependencies": {
58
- "flatted": "^3.2.9",
59
- "keyv": "^4.5.4",
60
- "rimraf": "^5.0.5"
51
+ "flatted": "^3.3.1",
52
+ "keyv": "^4.5.4"
53
+ },
54
+ "xo": {
55
+ "rules": {
56
+ "unicorn/prefer-module": "off",
57
+ "n/prefer-global/process": "off",
58
+ "unicorn/prevent-abbreviations": "off"
59
+ }
61
60
  }
62
61
  }
package/src/cache.js CHANGED
@@ -1,12 +1,12 @@
1
- var path = require('path');
2
- var fs = require('fs');
3
- var Keyv = require('keyv');
4
- var utils = require('./utils');
5
- var del = require('./del');
6
- var writeJSON = utils.writeJSON;
7
-
8
- var cache = {
9
- /**
1
+ /* eslint-disable unicorn/no-this-assignment, no-unused-expressions */
2
+ const path = require('node:path');
3
+ const fs = require('node:fs');
4
+ const Keyv = require('keyv');
5
+ const {writeJSON, tryParse} = require('./utils.js');
6
+ const {del} = require('./del.js');
7
+
8
+ const cache = {
9
+ /**
10
10
  * Load a cache identified by the given Id. If the element does not exists, then initialize an empty
11
11
  * cache storage. If specified `cacheDir` will be used as the directory to persist the data to. If omitted
12
12
  * then the cache module directory `./cache` will be used instead
@@ -15,154 +15,151 @@ var cache = {
15
15
  * @param docId {String} the id of the cache, would also be used as the name of the file cache
16
16
  * @param [cacheDir] {String} directory for the cache entry
17
17
  */
18
- load: function (docId, cacheDir) {
19
- var me = this;
18
+ load(documentId, cacheDir) {
19
+ const me = this;
20
+ me.keyv = new Keyv();
20
21
 
21
- me.keyv = new Keyv();
22
+ me.__visited = {};
23
+ me.__persisted = {};
22
24
 
23
- me.__visited = {};
24
- me.__persisted = {};
25
- me._pathToFile = cacheDir ? path.resolve(cacheDir, docId) : path.resolve(__dirname, '../.cache/', docId);
25
+ me._pathToFile = cacheDir ? path.resolve(cacheDir, documentId) : path.resolve(__dirname, '../.cache/', documentId);
26
26
 
27
- if (fs.existsSync(me._pathToFile)) {
28
- me._persisted = utils.tryParse(me._pathToFile, {});
29
- }
30
- },
27
+ if (fs.existsSync(me._pathToFile)) {
28
+ me._persisted = tryParse(me._pathToFile, {});
29
+ }
30
+ },
31
31
 
32
- get _persisted() {
33
- return this.__persisted;
34
- },
32
+ get _persisted() {
33
+ return this.__persisted;
34
+ },
35
35
 
36
- set _persisted(value) {
37
- this.__persisted = value;
38
- this.keyv.set('persisted', value);
39
- },
36
+ set _persisted(value) {
37
+ this.__persisted = value;
38
+ },
40
39
 
41
- get _visited() {
42
- return this.__visited;
43
- },
40
+ get _visited() {
41
+ return this.__visited;
42
+ },
44
43
 
45
- set _visited(value) {
46
- this.__visited = value;
47
- this.keyv.set('visited', value);
48
- },
44
+ set _visited(value) {
45
+ this.__visited = value;
46
+ },
49
47
 
50
- /**
48
+ /**
51
49
  * Load the cache from the provided file
52
50
  * @method loadFile
53
51
  * @param {String} pathToFile the path to the file containing the info for the cache
54
52
  */
55
- loadFile: function (pathToFile) {
56
- var me = this;
57
- var dir = path.dirname(pathToFile);
58
- var fName = path.basename(pathToFile);
53
+ loadFile(pathToFile) {
54
+ const me = this;
55
+ const dir = path.dirname(pathToFile);
56
+ const fName = path.basename(pathToFile);
59
57
 
60
- me.load(fName, dir);
61
- },
58
+ me.load(fName, dir);
59
+ },
62
60
 
63
- /**
61
+ /**
64
62
  * Returns the entire persisted object
65
63
  * @method all
66
64
  * @returns {*}
67
65
  */
68
- all: function () {
69
- return this._persisted;
70
- },
71
-
72
- keys: function () {
73
- return Object.keys(this._persisted);
74
- },
75
- /**
76
- * sets a key to a given value
66
+ all() {
67
+ return this._persisted;
68
+ },
69
+
70
+ keys() {
71
+ return Object.keys(this._persisted);
72
+ },
73
+ /**
74
+ * Sets a key to a given value
77
75
  * @method setKey
78
76
  * @param key {string} the key to set
79
77
  * @param value {object} the value of the key. Could be any object that can be serialized with JSON.stringify
80
78
  */
81
- setKey: function (key, value) {
82
- this._visited[key] = true;
83
- this._persisted[key] = value;
84
- },
85
- /**
86
- * remove a given key from the cache
79
+ setKey(key, value) {
80
+ this._visited[key] = true;
81
+ this._persisted[key] = value;
82
+ },
83
+ /**
84
+ * Remove a given key from the cache
87
85
  * @method removeKey
88
86
  * @param key {String} the key to remove from the object
89
87
  */
90
- removeKey: function (key) {
91
- delete this._visited[key]; // esfmt-ignore-line
92
- delete this._persisted[key]; // esfmt-ignore-line
93
- },
94
- /**
88
+ removeKey(key) {
89
+ delete this._visited[key]; // Esfmt-ignore-line
90
+ delete this._persisted[key]; // Esfmt-ignore-line
91
+ },
92
+ /**
95
93
  * Return the value of the provided key
96
94
  * @method getKey
97
95
  * @param key {String} the name of the key to retrieve
98
96
  * @returns {*} the value from the key
99
97
  */
100
- getKey: function (key) {
101
- this._visited[key] = true;
102
- return this._persisted[key];
103
- },
98
+ getKey(key) {
99
+ this._visited[key] = true;
100
+ return this._persisted[key];
101
+ },
104
102
 
105
- /**
103
+ /**
106
104
  * Remove keys that were not accessed/set since the
107
105
  * last time the `prune` method was called.
108
106
  * @method _prune
109
107
  * @private
110
108
  */
111
- _prune: function () {
112
- var me = this;
113
- var obj = {};
109
+ _prune() {
110
+ const me = this;
111
+ const object = {};
114
112
 
115
- var keys = Object.keys(me._visited);
113
+ const keys = Object.keys(me._visited);
116
114
 
117
- // no keys visited for either get or set value
118
- if (keys.length === 0) {
119
- return;
120
- }
115
+ // No keys visited for either get or set value
116
+ if (keys.length === 0) {
117
+ return;
118
+ }
121
119
 
122
- keys.forEach(function (key) {
123
- obj[key] = me._persisted[key];
124
- });
120
+ for (const key of keys) {
121
+ object[key] = me._persisted[key];
122
+ }
125
123
 
126
- me._visited = {};
127
- me._persisted = obj;
128
- },
124
+ me._visited = {};
125
+ me._persisted = object;
126
+ },
129
127
 
130
- /**
128
+ /**
131
129
  * Save the state of the cache identified by the docId to disk
132
130
  * as a JSON structure
133
131
  * @param [noPrune=false] {Boolean} whether to remove from cache the non visited files
134
132
  * @method save
135
133
  */
136
- save: function (noPrune) {
137
- var me = this;
138
-
139
- !noPrune && me._prune();
140
- writeJSON(me._pathToFile, me._persisted);
141
- },
142
-
143
- /**
144
- * remove the file where the cache is persisted
134
+ save(noPrune) {
135
+ const me = this;
136
+ !noPrune && me._prune();
137
+ writeJSON(me._pathToFile, me._persisted);
138
+ },
139
+
140
+ /**
141
+ * Remove the file where the cache is persisted
145
142
  * @method removeCacheFile
146
143
  * @return {Boolean} true or false if the file was successfully deleted
147
144
  */
148
- removeCacheFile: function () {
149
- return del(this._pathToFile);
150
- },
151
- /**
145
+ removeCacheFile() {
146
+ return del(this._pathToFile);
147
+ },
148
+ /**
152
149
  * Destroy the file cache and cache content.
153
150
  * @method destroy
154
151
  */
155
- destroy: function () {
156
- var me = this;
157
- me._visited = {};
158
- me._persisted = {};
152
+ destroy() {
153
+ const me = this;
154
+ me._visited = {};
155
+ me._persisted = {};
159
156
 
160
- me.removeCacheFile();
161
- },
157
+ me.removeCacheFile();
158
+ },
162
159
  };
163
160
 
164
161
  module.exports = {
165
- /**
162
+ /**
166
163
  * Alias for create. Should be considered depreacted. Will be removed in next releases
167
164
  *
168
165
  * @method load
@@ -170,11 +167,11 @@ module.exports = {
170
167
  * @param [cacheDir] {String} directory for the cache entry
171
168
  * @returns {cache} cache instance
172
169
  */
173
- load: function (docId, cacheDir) {
174
- return this.create(docId, cacheDir);
175
- },
170
+ load(documentId, cacheDir) {
171
+ return this.create(documentId, cacheDir);
172
+ },
176
173
 
177
- /**
174
+ /**
178
175
  * Load a cache identified by the given Id. If the element does not exists, then initialize an empty
179
176
  * cache storage.
180
177
  *
@@ -183,18 +180,18 @@ module.exports = {
183
180
  * @param [cacheDir] {String} directory for the cache entry
184
181
  * @returns {cache} cache instance
185
182
  */
186
- create: function (docId, cacheDir) {
187
- var obj = Object.create(cache);
188
- obj.load(docId, cacheDir);
189
- return obj;
190
- },
191
-
192
- createFromFile: function (filePath) {
193
- var obj = Object.create(cache);
194
- obj.loadFile(filePath);
195
- return obj;
196
- },
197
- /**
183
+ create(documentId, cacheDir) {
184
+ const object = Object.create(cache);
185
+ object.load(documentId, cacheDir);
186
+ return object;
187
+ },
188
+
189
+ createFromFile(filePath) {
190
+ const object = Object.create(cache);
191
+ object.loadFile(filePath);
192
+ return object;
193
+ },
194
+ /**
198
195
  * Clear the cache identified by the given id. Caches stored in a different cache directory can be deleted directly
199
196
  *
200
197
  * @method clearCache
@@ -202,17 +199,17 @@ module.exports = {
202
199
  * @param cacheDir {String} the directory where the cache file was written
203
200
  * @returns {Boolean} true if the cache folder was deleted. False otherwise
204
201
  */
205
- clearCacheById: function (docId, cacheDir) {
206
- var filePath = cacheDir ? path.resolve(cacheDir, docId) : path.resolve(__dirname, '../.cache/', docId);
207
- return del(filePath);
208
- },
209
- /**
202
+ clearCacheById(documentId, cacheDir) {
203
+ const filePath = cacheDir ? path.resolve(cacheDir, documentId) : path.resolve(__dirname, '../.cache/', documentId);
204
+ return del(filePath);
205
+ },
206
+ /**
210
207
  * Remove all cache stored in the cache directory
211
208
  * @method clearAll
212
209
  * @returns {Boolean} true if the cache folder was deleted. False otherwise
213
210
  */
214
- clearAll: function (cacheDir) {
215
- var filePath = cacheDir ? path.resolve(cacheDir) : path.resolve(__dirname, '../.cache/');
216
- return del(filePath);
217
- },
211
+ clearAll(cacheDir) {
212
+ const filePath = cacheDir ? path.resolve(cacheDir) : path.resolve(__dirname, '../.cache/');
213
+ return del(filePath);
214
+ },
218
215
  };
package/src/del.js CHANGED
@@ -1,13 +1,31 @@
1
- var rimraf = require('rimraf').sync;
2
- var fs = require('fs');
3
-
4
- module.exports = function del(file) {
5
- if (fs.existsSync(file)) {
6
- //if rimraf doesn't throw then the file has been deleted or didn't exist
7
- rimraf(file, {
8
- glob: false,
9
- });
10
- return true;
11
- }
12
- return false;
13
- };
1
+ const fs = require('node:fs');
2
+ const path = require('node:path');
3
+
4
+ function del(targetPath) {
5
+ if (!fs.existsSync(targetPath)) {
6
+ return false;
7
+ }
8
+
9
+ try {
10
+ if (fs.statSync(targetPath).isDirectory()) {
11
+ // If it's a directory, delete its contents first
12
+ for (const file of fs.readdirSync(targetPath)) {
13
+ const currentPath = path.join(targetPath, file);
14
+
15
+ if (fs.statSync(currentPath).isFile()) {
16
+ fs.unlinkSync(currentPath); // Delete file
17
+ }
18
+ }
19
+
20
+ fs.rmdirSync(targetPath); // Delete the now-empty directory
21
+ } else {
22
+ fs.unlinkSync(targetPath); // If it's a file, delete it directly
23
+ }
24
+
25
+ return true;
26
+ } catch (error) {
27
+ console.error(`Error while deleting ${targetPath}: ${error.message}`);
28
+ }
29
+ }
30
+
31
+ module.exports = {del};
package/src/utils.js CHANGED
@@ -1,44 +1,43 @@
1
- var fs = require('fs');
2
- var path = require('path');
3
- var flatted = require('flatted');
1
+ const fs = require('node:fs');
2
+ const path = require('node:path');
3
+ const flatted = require('flatted');
4
4
 
5
- module.exports = {
6
- tryParse: function (filePath, defaultValue) {
7
- var result;
8
- try {
9
- result = this.readJSON(filePath);
10
- } catch (ex) {
11
- result = defaultValue;
12
- }
13
- return result;
14
- },
5
+ function tryParse(filePath, defaultValue) {
6
+ let result;
7
+ try {
8
+ result = readJSON(filePath);
9
+ } catch {
10
+ result = defaultValue;
11
+ }
15
12
 
16
- /**
17
- * Read json file synchronously using flatted
18
- *
19
- * @method readJSON
20
- * @param {String} filePath Json filepath
21
- * @returns {*} parse result
22
- */
23
- readJSON: function (filePath) {
24
- return flatted.parse(
25
- fs.readFileSync(filePath, {
26
- encoding: 'utf8',
27
- })
28
- );
29
- },
13
+ return result;
14
+ }
30
15
 
31
- /**
32
- * Write json file synchronously using circular-json
33
- *
34
- * @method writeJSON
35
- * @param {String} filePath Json filepath
36
- * @param {*} data Object to serialize
37
- */
38
- writeJSON: function (filePath, data) {
39
- fs.mkdirSync(path.dirname(filePath), {
40
- recursive: true,
41
- });
42
- fs.writeFileSync(filePath, flatted.stringify(data));
43
- },
44
- };
16
+ /**
17
+ * Read json file synchronously using flatted
18
+ *
19
+ * @param {String} filePath Json filepath
20
+ * @returns {*} parse result
21
+ */
22
+ function readJSON(filePath) {
23
+ return flatted.parse(
24
+ fs.readFileSync(filePath, {
25
+ encoding: 'utf8',
26
+ }),
27
+ );
28
+ }
29
+
30
+ /**
31
+ * Write json file synchronously using circular-json
32
+ *
33
+ * @param {String} filePath Json filepath
34
+ * @param {*} data Object to serialize
35
+ */
36
+ function writeJSON(filePath, data) {
37
+ fs.mkdirSync(path.dirname(filePath), {
38
+ recursive: true,
39
+ });
40
+ fs.writeFileSync(filePath, flatted.stringify(data));
41
+ }
42
+
43
+ module.exports = {tryParse, readJSON, writeJSON};
package/changelog.md DELETED
@@ -1,328 +0,0 @@
1
-
2
- # flat-cache - Changelog
3
- ## v3.0.4
4
- - **Refactoring**
5
- - add files by name to the list of exported files - [89a2698]( https://github.com/royriojas/flat-cache/commit/89a2698 ), [Roy Riojas](https://github.com/Roy Riojas), 08/11/2020 02:35:39
6
-
7
-
8
- ## v3.0.3
9
- - **Bug Fixes**
10
- - Fix wrong eslint command - [f268e42]( https://github.com/royriojas/flat-cache/commit/f268e42 ), [Roy Riojas](https://github.com/Roy Riojas), 08/11/2020 02:15:04
11
-
12
-
13
- ## v3.0.2
14
- - **Refactoring**
15
- - Update the files paths - [6983a80]( https://github.com/royriojas/flat-cache/commit/6983a80 ), [Roy Riojas](https://github.com/Roy Riojas), 08/11/2020 01:58:39
16
-
17
-
18
- - Move code to src/ - [18ed6e8]( https://github.com/royriojas/flat-cache/commit/18ed6e8 ), [Roy Riojas](https://github.com/Roy Riojas), 08/11/2020 01:57:17
19
-
20
-
21
- - Change eslint-cache location - [beed74c]( https://github.com/royriojas/flat-cache/commit/beed74c ), [Roy Riojas](https://github.com/Roy Riojas), 08/11/2020 01:48:32
22
-
23
-
24
- ## v3.0.1
25
- - **Refactoring**
26
- - Remove unused deps - [8c6d9dc]( https://github.com/royriojas/flat-cache/commit/8c6d9dc ), [Roy Riojas](https://github.com/Roy Riojas), 08/11/2020 01:43:29
27
-
28
-
29
- ## v3.0.0
30
- - **Refactoring**
31
- - Fix engines - [52b824c]( https://github.com/royriojas/flat-cache/commit/52b824c ), [Roy Riojas](https://github.com/Roy Riojas), 08/11/2020 01:01:52
32
-
33
-
34
- - **Other changes**
35
- - Replace write with combination of mkdir and writeFile ([#49](https://github.com/royriojas/flat-cache/issues/49)) - [ef48276]( https://github.com/royriojas/flat-cache/commit/ef48276 ), [Bogdan Chadkin](https://github.com/Bogdan Chadkin), 08/11/2020 00:17:15
36
-
37
- Node v10 introduced a great "recursive" option for mkdir which allows to
38
- get rid from mkdirp package and easily rewrite "write" package usage
39
- with two function calls.
40
-
41
- https://nodejs.org/api/fs.html#fs_fs_mkdir_path_options_callback
42
- - Added a testcase for clearAll ([#48](https://github.com/royriojas/flat-cache/issues/48)) - [45b51ca]( https://github.com/royriojas/flat-cache/commit/45b51ca ), [Aaron Chen](https://github.com/Aaron Chen), 21/05/2020 08:40:03
43
-
44
-
45
- - requet node>=10 - [a5c482c]( https://github.com/royriojas/flat-cache/commit/a5c482c ), [yumetodo](https://github.com/yumetodo), 10/04/2020 23:14:53
46
-
47
- thanks @SuperITMan
48
-
49
- - Update README.md - [29fe40b]( https://github.com/royriojas/flat-cache/commit/29fe40b ), [Roy Riojas](https://github.com/Roy Riojas), 10/04/2020 20:08:05
50
-
51
-
52
- - reduce vulnerability to 1 - [e9db1b2]( https://github.com/royriojas/flat-cache/commit/e9db1b2 ), [yumetodo](https://github.com/yumetodo), 30/03/2020 11:10:43
53
-
54
-
55
- - reduce vulnerabilities dependencies to 8 - [b58d196]( https://github.com/royriojas/flat-cache/commit/b58d196 ), [yumetodo](https://github.com/yumetodo), 30/03/2020 10:54:56
56
-
57
-
58
- - use prettier instead of esbeautifier - [03b1db7]( https://github.com/royriojas/flat-cache/commit/03b1db7 ), [yumetodo](https://github.com/yumetodo), 30/03/2020 10:27:14
59
-
60
-
61
- - update proxyquire - [c2f048d]( https://github.com/royriojas/flat-cache/commit/c2f048d ), [yumetodo](https://github.com/yumetodo), 30/03/2020 10:16:16
62
-
63
-
64
- - update flatted and mocha - [a0e56da]( https://github.com/royriojas/flat-cache/commit/a0e56da ), [yumetodo](https://github.com/yumetodo), 30/03/2020 09:46:45
65
-
66
- mocha > mkdirp is updated
67
- istanble >>> optimist > minimist is not updated
68
-
69
- - drop support node.js < 10 in develop - [beba691]( https://github.com/royriojas/flat-cache/commit/beba691 ), [yumetodo](https://github.com/yumetodo), 18/03/2020 01:31:09
70
-
71
- see mkdirp
72
-
73
- - npm aufit fix(still remains) - [ce166cb]( https://github.com/royriojas/flat-cache/commit/ce166cb ), [yumetodo](https://github.com/yumetodo), 18/03/2020 01:18:08
74
-
75
- 37 vulnerabilities required manual review and could not be updated
76
-
77
- - updtate sinon - [9f2d1b6]( https://github.com/royriojas/flat-cache/commit/9f2d1b6 ), [yumetodo](https://github.com/yumetodo), 18/03/2020 01:17:51
78
-
79
-
80
- - apply eslint-plugin-mocha - [07343b5]( https://github.com/royriojas/flat-cache/commit/07343b5 ), [yumetodo](https://github.com/yumetodo), 13/03/2020 22:17:21
81
-
82
-
83
- - Less strint version check ([#44](https://github.com/royriojas/flat-cache/issues/44)) - [92aca1c]( https://github.com/royriojas/flat-cache/commit/92aca1c ), [Wojciech Maj](https://github.com/Wojciech Maj), 13/11/2019 16:18:25
84
-
85
- * Use ^ version matching for production dependencies
86
-
87
- * Run npm audit fix
88
-
89
- - **Bug Fixes**
90
- - update dependencies and use eslint directly - [73fbed2]( https://github.com/royriojas/flat-cache/commit/73fbed2 ), [yumetodo](https://github.com/yumetodo), 18/03/2020 01:17:27
91
-
92
-
93
- ## v2.0.1
94
- - **Refactoring**
95
- - upgrade node modules to latest versions - [6402ed3]( https://github.com/royriojas/flat-cache/commit/6402ed3 ), [Roy Riojas](https://github.com/Roy Riojas), 08/01/2019 18:47:05
96
-
97
-
98
- ## v2.0.0
99
- - **Bug Fixes**
100
- - upgrade package.json lock file - [8d21c7b]( https://github.com/royriojas/flat-cache/commit/8d21c7b ), [Roy Riojas](https://github.com/Roy Riojas), 08/01/2019 17:03:13
101
-
102
-
103
- - Use the same versions of node_js that eslint use - [8d23379]( https://github.com/royriojas/flat-cache/commit/8d23379 ), [Roy Riojas](https://github.com/Roy Riojas), 08/01/2019 16:25:11
104
-
105
-
106
- - **Other changes**
107
- - Replace circular-json with flatted ([#36](https://github.com/royriojas/flat-cache/issues/36)) - [b93aced]( https://github.com/royriojas/flat-cache/commit/b93aced ), [C. K. Tang](https://github.com/C. K. Tang), 08/01/2019 17:03:01
108
-
109
-
110
- - Change JSON parser from circular-json to flatted & 1 more changes ([#37](https://github.com/royriojas/flat-cache/issues/37)) - [745e65a]( https://github.com/royriojas/flat-cache/commit/745e65a ), [Andy Chen](https://github.com/Andy Chen), 08/01/2019 16:17:20
111
-
112
- * Change JSON parser from circular-json to flatted & 1 more changes
113
-
114
- * Change JSON parser from circular-json
115
- * Audited 2 vulnerabilities
116
-
117
- * Update package.json
118
-
119
- * Update Engine require
120
-
121
- * There's a bunch of dependencies in this pkg requires node >=4, so I changed it to 4
122
-
123
- * Remove and add node versions
124
-
125
- * I have seen this pkg is not available with node 0.12 so I removed it
126
- * I have added a popular used LTS version of node - 10
127
-
128
- ## v1.3.4
129
- - **Refactoring**
130
- - Add del.js and utils.js to the list of files to be beautified - [9d0ca9b]( https://github.com/royriojas/flat-cache/commit/9d0ca9b ), [Roy Riojas](https://github.com/Roy Riojas), 14/11/2018 12:19:02
131
-
132
-
133
- ## v1.3.3
134
- - **Refactoring**
135
- - Make sure package-lock.json is up to date - [a7d2598]( https://github.com/royriojas/flat-cache/commit/a7d2598 ), [Roy Riojas](https://github.com/Roy Riojas), 14/11/2018 11:36:08
136
-
137
-
138
- - **Other changes**
139
- - Removed the need for del ([#33](https://github.com/royriojas/flat-cache/issues/33)) - [c429012]( https://github.com/royriojas/flat-cache/commit/c429012 ), [S. Gilroy](https://github.com/S. Gilroy), 13/11/2018 13:56:37
140
-
141
- * Removed the need for del
142
-
143
- Removed the need for del as newer versions have broken backwards
144
- compatibility. del mainly uses rimraf for deleting folders
145
- and files, replaceing it with rimraf only is a minimal change.
146
-
147
- * Disable glob on rimraf calls
148
-
149
- * Added glob disable to wrong call
150
-
151
- * Wrapped rimraf to simplify solution
152
-
153
- ## v1.3.2
154
- - **Refactoring**
155
- - remove yarn.lock file - [704c6c4]( https://github.com/royriojas/flat-cache/commit/704c6c4 ), [Roy Riojas](https://github.com/Roy Riojas), 07/11/2018 15:41:08
156
-
157
-
158
- - **Other changes**
159
- - replace circular-json with flatted ([#23](https://github.com/royriojas/flat-cache/issues/23))" - [db12d74]( https://github.com/royriojas/flat-cache/commit/db12d74 ), [Roy Riojas](https://github.com/Roy Riojas), 07/11/2018 15:40:39
160
-
161
- This reverts commit 00f689277a75e85fef28e6a048fad227afc525e6.
162
-
163
- ## v1.3.1
164
- - **Refactoring**
165
- - upgrade deps to remove some security warnings - [f405719]( https://github.com/royriojas/flat-cache/commit/f405719 ), [Roy Riojas](https://github.com/Roy Riojas), 06/11/2018 12:07:31
166
-
167
-
168
- - **Bug Fixes**
169
- - replace circular-json with flatted ([#23](https://github.com/royriojas/flat-cache/issues/23)) - [00f6892]( https://github.com/royriojas/flat-cache/commit/00f6892 ), [Terry](https://github.com/Terry), 05/11/2018 18:44:16
170
-
171
-
172
- - **Other changes**
173
- - update del to v3.0.0 ([#26](https://github.com/royriojas/flat-cache/issues/26)) - [d42883f]( https://github.com/royriojas/flat-cache/commit/d42883f ), [Patrick Silva](https://github.com/Patrick Silva), 03/11/2018 01:00:44
174
-
175
- Closes <a target="_blank" class="info-link" href="https://github.com/royriojas/flat-cache/issues/25"><span>#25</span></a>
176
- ## v1.3.0
177
- - **Other changes**
178
- - Added #all method ([#16](https://github.com/royriojas/flat-cache/issues/16)) - [12293be]( https://github.com/royriojas/flat-cache/commit/12293be ), [Ozair Patel](https://github.com/Ozair Patel), 25/09/2017 14:46:38
179
-
180
- * Added #all method
181
-
182
- * Added #all method test
183
-
184
- * Updated readme
185
-
186
- * Added yarn.lock
187
-
188
- * Added more keys for #all test
189
-
190
- * Beautified file
191
-
192
- - fix changelog title style ([#14](https://github.com/royriojas/flat-cache/issues/14)) - [af8338a]( https://github.com/royriojas/flat-cache/commit/af8338a ), [前端小武](https://github.com/前端小武), 19/12/2016 20:34:48
193
-
194
-
195
- ## v1.2.2
196
- - **Bug Fixes**
197
- - Do not crash if cache file is invalid JSON. ([#13](https://github.com/royriojas/flat-cache/issues/13)) - [87beaa6]( https://github.com/royriojas/flat-cache/commit/87beaa6 ), [Roy Riojas](https://github.com/Roy Riojas), 19/12/2016 18:03:35
198
-
199
- Fixes <a target="_blank" class="info-link" href="https://github.com/royriojas/flat-cache/issues/12"><span>#12</span></a>
200
-
201
- Not sure under which situations a cache file might exist that does
202
- not contain a valid JSON structure, but just in case to cover
203
- the possibility of this happening a try catch block has been added
204
-
205
- If the cache is somehow not valid the cache will be discarded an a
206
- a new cache will be stored instead
207
- - **Other changes**
208
- - Added travis ci support for modern node versions ([#11](https://github.com/royriojas/flat-cache/issues/11)) - [1c2b1f7]( https://github.com/royriojas/flat-cache/commit/1c2b1f7 ), [Amila Welihinda](https://github.com/Amila Welihinda), 10/11/2016 23:47:52
209
-
210
-
211
- - Bumping `circular-son` version ([#10](https://github.com/royriojas/flat-cache/issues/10)) - [4d5e861]( https://github.com/royriojas/flat-cache/commit/4d5e861 ), [Andrea Giammarchi](https://github.com/Andrea Giammarchi), 02/08/2016 07:13:52
212
-
213
- As mentioned in https://github.com/WebReflection/circular-json/issues/25 `circular-json` wan't rightly implementing the license field.
214
-
215
- Latest version bump changed only that bit so that ESLint should now be happy.
216
- ## v1.2.1
217
- - **Bug Fixes**
218
- - Add missing utils.js file to the package. closes [#8](https://github.com/royriojas/flat-cache/issues/8) - [ec10cf2]( https://github.com/royriojas/flat-cache/commit/ec10cf2 ), [Roy Riojas](https://github.com/Roy Riojas), 01/08/2016 02:18:57
219
-
220
-
221
- ## v1.2.0
222
- - **Documentation**
223
- - Add documentation about noPrune option - [23e11f9]( https://github.com/royriojas/flat-cache/commit/23e11f9 ), [Roy Riojas](https://github.com/Roy Riojas), 01/08/2016 02:06:49
224
-
225
-
226
- ## v1.0.11
227
- - **Features**
228
- - Add noPrune option to cache.save() method. closes [#7](https://github.com/royriojas/flat-cache/issues/7) - [2c8016a]( https://github.com/royriojas/flat-cache/commit/2c8016a ), [Roy Riojas](https://github.com/Roy Riojas), 01/08/2016 02:00:29
229
-
230
-
231
- - Add json read and write utility based on circular-json - [c31081e]( https://github.com/royriojas/flat-cache/commit/c31081e ), [Jean Ponchon](https://github.com/Jean Ponchon), 28/07/2016 08:58:17
232
-
233
-
234
- - **Bug Fixes**
235
- - Remove UTF16 BOM stripping - [4a41e22]( https://github.com/royriojas/flat-cache/commit/4a41e22 ), [Jean Ponchon](https://github.com/Jean Ponchon), 29/07/2016 02:18:06
236
-
237
- Since we control both writing and reading of JSON stream, there no needs
238
- to handle unicode BOM.
239
- - Use circular-json to handle circular references (fix [#5](https://github.com/royriojas/flat-cache/issues/5)) - [cd7aeed]( https://github.com/royriojas/flat-cache/commit/cd7aeed ), [Jean Ponchon](https://github.com/Jean Ponchon), 25/07/2016 11:11:59
240
-
241
-
242
- - **Tests Related fixes**
243
- - Add missing file from eslint test - [d6fa3c3]( https://github.com/royriojas/flat-cache/commit/d6fa3c3 ), [Jean Ponchon](https://github.com/Jean Ponchon), 29/07/2016 02:15:51
244
-
245
-
246
- - Add test for circular json serialization / deserialization - [07d2ddd]( https://github.com/royriojas/flat-cache/commit/07d2ddd ), [Jean Ponchon](https://github.com/Jean Ponchon), 28/07/2016 08:59:36
247
-
248
-
249
- - **Refactoring**
250
- - Remove unused read-json-sync - [2be1c24]( https://github.com/royriojas/flat-cache/commit/2be1c24 ), [Jean Ponchon](https://github.com/Jean Ponchon), 28/07/2016 08:59:18
251
-
252
-
253
- - **Build Scripts Changes**
254
- - travis tests on 0.12 and 4x - [3a613fd]( https://github.com/royriojas/flat-cache/commit/3a613fd ), [royriojas](https://github.com/royriojas), 15/11/2015 14:34:40
255
-
256
-
257
- ## v1.0.10
258
- - **Build Scripts Changes**
259
- - add eslint-fix task - [fd29e52]( https://github.com/royriojas/flat-cache/commit/fd29e52 ), [royriojas](https://github.com/royriojas), 01/11/2015 15:04:08
260
-
261
-
262
- - make sure the test script also verify beautification and linting of files before running tests - [e94e176]( https://github.com/royriojas/flat-cache/commit/e94e176 ), [royriojas](https://github.com/royriojas), 01/11/2015 11:54:48
263
-
264
-
265
- - **Other changes**
266
- - add clearAll for cacheDir - [97383d9]( https://github.com/royriojas/flat-cache/commit/97383d9 ), [xieyaowu](https://github.com/xieyaowu), 31/10/2015 21:02:18
267
-
268
-
269
- ## v1.0.9
270
- - **Bug Fixes**
271
- - wrong default values for changelogx user repo name - [7bb52d1]( https://github.com/royriojas/flat-cache/commit/7bb52d1 ), [royriojas](https://github.com/royriojas), 11/09/2015 15:59:30
272
-
273
-
274
- ## v1.0.8
275
- - **Build Scripts Changes**
276
- - test against node 4 - [c395b66]( https://github.com/royriojas/flat-cache/commit/c395b66 ), [royriojas](https://github.com/royriojas), 11/09/2015 15:51:39
277
-
278
-
279
- ## v1.0.7
280
- - **Other changes**
281
- - Move dependencies into devDep - [7e47099]( https://github.com/royriojas/flat-cache/commit/7e47099 ), [Bogdan Chadkin](https://github.com/Bogdan Chadkin), 11/09/2015 15:10:57
282
-
283
-
284
- - **Documentation**
285
- - Add missing changelog link - [f51197a]( https://github.com/royriojas/flat-cache/commit/f51197a ), [royriojas](https://github.com/royriojas), 11/09/2015 14:48:05
286
-
287
-
288
- ## v1.0.6
289
- - **Build Scripts Changes**
290
- - Add helpers/code check scripts - [bdb82f3]( https://github.com/royriojas/flat-cache/commit/bdb82f3 ), [royriojas](https://github.com/royriojas), 11/09/2015 14:44:31
291
-
292
-
293
- ## v1.0.5
294
- - **Documentation**
295
- - better description for the module - [436817f]( https://github.com/royriojas/flat-cache/commit/436817f ), [royriojas](https://github.com/royriojas), 11/09/2015 14:35:33
296
-
297
-
298
- - **Other changes**
299
- - Update dependencies - [be88aa3]( https://github.com/royriojas/flat-cache/commit/be88aa3 ), [Bogdan Chadkin](https://github.com/Bogdan Chadkin), 11/09/2015 13:47:41
300
-
301
-
302
- ## v1.0.4
303
- - **Refactoring**
304
- - load a cache file using the full filepath - [b8f68c2]( https://github.com/royriojas/flat-cache/commit/b8f68c2 ), [Roy Riojas](https://github.com/Roy Riojas), 30/08/2015 04:19:14
305
-
306
-
307
- - **Documentation**
308
- - Add documentation about `clearAll` and `clearCacheById` - [13947c1]( https://github.com/royriojas/flat-cache/commit/13947c1 ), [Roy Riojas](https://github.com/Roy Riojas), 01/03/2015 23:44:05
309
-
310
-
311
- - **Features**
312
- - Add methods to remove the cache documents created - [af40443]( https://github.com/royriojas/flat-cache/commit/af40443 ), [Roy Riojas](https://github.com/Roy Riojas), 01/03/2015 23:39:27
313
-
314
-
315
- ## v1.0.1
316
- - **Other changes**
317
- - Update README.md - [c2b6805]( https://github.com/royriojas/flat-cache/commit/c2b6805 ), [Roy Riojas](https://github.com/Roy Riojas), 26/02/2015 04:28:07
318
-
319
-
320
- ## v1.0.0
321
- - **Refactoring**
322
- - flat-cache v.1.0.0 - [c984274]( https://github.com/royriojas/flat-cache/commit/c984274 ), [Roy Riojas](https://github.com/Roy Riojas), 26/02/2015 04:11:50
323
-
324
-
325
- - **Other changes**
326
- - Initial commit - [d43cccf]( https://github.com/royriojas/flat-cache/commit/d43cccf ), [Roy Riojas](https://github.com/Roy Riojas), 26/02/2015 01:12:16
327
-
328
-