keyv 4.0.2 → 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/.nyc_output/17c338d1-cd21-4d2f-9d97-398f18a945cf.json +1 -0
- package/.nyc_output/67b1f344-0eec-41a3-a665-c824c346e898.json +1 -0
- package/.nyc_output/adb04494-7d0a-443f-9130-94b19c3fa19c.json +1 -0
- package/.nyc_output/processinfo/17c338d1-cd21-4d2f-9d97-398f18a945cf.json +1 -0
- package/.nyc_output/processinfo/67b1f344-0eec-41a3-a665-c824c346e898.json +1 -0
- package/.nyc_output/processinfo/adb04494-7d0a-443f-9130-94b19c3fa19c.json +1 -0
- package/.nyc_output/processinfo/index.json +1 -0
- package/README.md +97 -13
- package/package.json +18 -19
- package/src/index.js +31 -23
- package/test/test.js +130 -0
- package/test/testdb.sqlite +0 -0
- package/LICENSE +0 -21
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"/Users/jaredwray/src/github.com/jaredwray/keyv/packages/keyv/src/index.js":{"path":"/Users/jaredwray/src/github.com/jaredwray/keyv/packages/keyv/src/index.js","statementMap":{"0":{"start":{"line":3,"column":21},"end":{"line":3,"column":38}},"1":{"start":{"line":4,"column":14},"end":{"line":4,"column":36}},"2":{"start":{"line":7,"column":0},"end":{"line":9,"column":2}},"3":{"start":{"line":8,"column":1},"end":{"line":8,"column":24}},"4":{"start":{"line":11,"column":18},"end":{"line":28,"column":1}},"5":{"start":{"line":12,"column":18},"end":{"line":21,"column":2}},"6":{"start":{"line":22,"column":1},"end":{"line":25,"column":2}},"7":{"start":{"line":23,"column":18},"end":{"line":23,"column":66}},"8":{"start":{"line":24,"column":2},"end":{"line":24,"column":51}},"9":{"start":{"line":27,"column":1},"end":{"line":27,"column":18}},"10":{"start":{"line":32,"column":2},"end":{"line":32,"column":10}},"11":{"start":{"line":33,"column":2},"end":{"line":41,"column":4}},"12":{"start":{"line":43,"column":2},"end":{"line":46,"column":3}},"13":{"start":{"line":44,"column":26},"end":{"line":44,"column":54}},"14":{"start":{"line":45,"column":3},"end":{"line":45,"column":47}},"15":{"start":{"line":48,"column":2},"end":{"line":50,"column":3}},"16":{"start":{"line":49,"column":3},"end":{"line":49,"column":67}},"17":{"start":{"line":49,"column":40},"end":{"line":49,"column":65}},"18":{"start":{"line":52,"column":2},"end":{"line":52,"column":50}},"19":{"start":{"line":56,"column":2},"end":{"line":56,"column":41}},"20":{"start":{"line":60,"column":22},"end":{"line":60,"column":45}},"21":{"start":{"line":61,"column":20},"end":{"line":61,"column":29}},"22":{"start":{"line":62,"column":2},"end":{"line":76,"column":6}},"23":{"start":{"line":63,"column":15},"end":{"line":63,"column":37}},"24":{"start":{"line":64,"column":17},"end":{"line":64,"column":80}},"25":{"start":{"line":66,"column":4},"end":{"line":68,"column":5}},"26":{"start":{"line":67,"column":5},"end":{"line":67,"column":22}},"27":{"start":{"line":70,"column":4},"end":{"line":73,"column":5}},"28":{"start":{"line":71,"column":5},"end":{"line":71,"column":22}},"29":{"start":{"line":72,"column":5},"end":{"line":72,"column":22}},"30":{"start":{"line":75,"column":4},"end":{"line":75,"column":56}},"31":{"start":{"line":80,"column":22},"end":{"line":80,"column":45}},"32":{"start":{"line":81,"column":2},"end":{"line":83,"column":3}},"33":{"start":{"line":82,"column":3},"end":{"line":82,"column":23}},"34":{"start":{"line":85,"column":2},"end":{"line":87,"column":3}},"35":{"start":{"line":86,"column":3},"end":{"line":86,"column":19}},"36":{"start":{"line":89,"column":20},"end":{"line":89,"column":29}},"37":{"start":{"line":91,"column":2},"end":{"line":102,"column":21}},"38":{"start":{"line":93,"column":20},"end":{"line":93,"column":73}},"39":{"start":{"line":94,"column":4},"end":{"line":96,"column":5}},"40":{"start":{"line":95,"column":5},"end":{"line":95,"column":55}},"41":{"start":{"line":98,"column":4},"end":{"line":98,"column":31}},"42":{"start":{"line":99,"column":4},"end":{"line":99,"column":38}},"43":{"start":{"line":101,"column":18},"end":{"line":101,"column":52}},"44":{"start":{"line":102,"column":15},"end":{"line":102,"column":19}},"45":{"start":{"line":106,"column":22},"end":{"line":106,"column":45}},"46":{"start":{"line":107,"column":20},"end":{"line":107,"column":29}},"47":{"start":{"line":108,"column":2},"end":{"line":109,"column":42}},"48":{"start":{"line":109,"column":15},"end":{"line":109,"column":40}},"49":{"start":{"line":113,"column":20},"end":{"line":113,"column":29}},"50":{"start":{"line":114,"column":2},"end":{"line":115,"column":30}},"51":{"start":{"line":115,"column":15},"end":{"line":115,"column":28}},"52":{"start":{"line":119,"column":0},"end":{"line":119,"column":22}}},"fnMap":{"0":{"name":"(anonymous_0)","decl":{"start":{"line":7,"column":26},"end":{"line":7,"column":27}},"loc":{"start":{"line":7,"column":38},"end":{"line":9,"column":1}},"line":7},"1":{"name":"(anonymous_1)","decl":{"start":{"line":11,"column":18},"end":{"line":11,"column":19}},"loc":{"start":{"line":11,"column":29},"end":{"line":28,"column":1}},"line":11},"2":{"name":"(anonymous_2)","decl":{"start":{"line":31,"column":1},"end":{"line":31,"column":2}},"loc":{"start":{"line":31,"column":27},"end":{"line":53,"column":2}},"line":31},"3":{"name":"(anonymous_3)","decl":{"start":{"line":49,"column":31},"end":{"line":49,"column":32}},"loc":{"start":{"line":49,"column":40},"end":{"line":49,"column":65}},"line":49},"4":{"name":"(anonymous_4)","decl":{"start":{"line":55,"column":1},"end":{"line":55,"column":2}},"loc":{"start":{"line":55,"column":20},"end":{"line":57,"column":2}},"line":55},"5":{"name":"(anonymous_5)","decl":{"start":{"line":59,"column":1},"end":{"line":59,"column":2}},"loc":{"start":{"line":59,"column":19},"end":{"line":77,"column":2}},"line":59},"6":{"name":"(anonymous_6)","decl":{"start":{"line":63,"column":9},"end":{"line":63,"column":10}},"loc":{"start":{"line":63,"column":15},"end":{"line":63,"column":37}},"line":63},"7":{"name":"(anonymous_7)","decl":{"start":{"line":64,"column":9},"end":{"line":64,"column":10}},"loc":{"start":{"line":64,"column":17},"end":{"line":64,"column":80}},"line":64},"8":{"name":"(anonymous_8)","decl":{"start":{"line":65,"column":9},"end":{"line":65,"column":10}},"loc":{"start":{"line":65,"column":17},"end":{"line":76,"column":4}},"line":65},"9":{"name":"(anonymous_9)","decl":{"start":{"line":79,"column":1},"end":{"line":79,"column":2}},"loc":{"start":{"line":79,"column":22},"end":{"line":103,"column":2}},"line":79},"10":{"name":"(anonymous_10)","decl":{"start":{"line":92,"column":9},"end":{"line":92,"column":10}},"loc":{"start":{"line":92,"column":15},"end":{"line":100,"column":4}},"line":92},"11":{"name":"(anonymous_11)","decl":{"start":{"line":101,"column":9},"end":{"line":101,"column":10}},"loc":{"start":{"line":101,"column":18},"end":{"line":101,"column":52}},"line":101},"12":{"name":"(anonymous_12)","decl":{"start":{"line":102,"column":9},"end":{"line":102,"column":10}},"loc":{"start":{"line":102,"column":15},"end":{"line":102,"column":19}},"line":102},"13":{"name":"(anonymous_13)","decl":{"start":{"line":105,"column":1},"end":{"line":105,"column":2}},"loc":{"start":{"line":105,"column":13},"end":{"line":110,"column":2}},"line":105},"14":{"name":"(anonymous_14)","decl":{"start":{"line":109,"column":9},"end":{"line":109,"column":10}},"loc":{"start":{"line":109,"column":15},"end":{"line":109,"column":40}},"line":109},"15":{"name":"(anonymous_15)","decl":{"start":{"line":112,"column":1},"end":{"line":112,"column":2}},"loc":{"start":{"line":112,"column":9},"end":{"line":116,"column":2}},"line":112},"16":{"name":"(anonymous_16)","decl":{"start":{"line":115,"column":9},"end":{"line":115,"column":10}},"loc":{"start":{"line":115,"column":15},"end":{"line":115,"column":28}},"line":115}},"branchMap":{"0":{"loc":{"start":{"line":22,"column":1},"end":{"line":25,"column":2}},"type":"if","locations":[{"start":{"line":22,"column":1},"end":{"line":25,"column":2}},{"start":{"line":22,"column":1},"end":{"line":25,"column":2}}],"line":22},"1":{"loc":{"start":{"line":22,"column":5},"end":{"line":22,"column":35}},"type":"binary-expr","locations":[{"start":{"line":22,"column":5},"end":{"line":22,"column":20}},{"start":{"line":22,"column":24},"end":{"line":22,"column":35}}],"line":22},"2":{"loc":{"start":{"line":23,"column":18},"end":{"line":23,"column":66}},"type":"binary-expr","locations":[{"start":{"line":23,"column":18},"end":{"line":23,"column":33}},{"start":{"line":23,"column":37},"end":{"line":23,"column":66}}],"line":23},"3":{"loc":{"start":{"line":39,"column":3},"end":{"line":39,"column":44}},"type":"cond-expr","locations":[{"start":{"line":39,"column":31},"end":{"line":39,"column":38}},{"start":{"line":39,"column":41},"end":{"line":39,"column":44}}],"line":39},"4":{"loc":{"start":{"line":43,"column":2},"end":{"line":46,"column":3}},"type":"if","locations":[{"start":{"line":43,"column":2},"end":{"line":46,"column":3}},{"start":{"line":43,"column":2},"end":{"line":46,"column":3}}],"line":43},"5":{"loc":{"start":{"line":48,"column":2},"end":{"line":50,"column":3}},"type":"if","locations":[{"start":{"line":48,"column":2},"end":{"line":50,"column":3}},{"start":{"line":48,"column":2},"end":{"line":50,"column":3}}],"line":48},"6":{"loc":{"start":{"line":64,"column":17},"end":{"line":64,"column":80}},"type":"cond-expr","locations":[{"start":{"line":64,"column":46},"end":{"line":64,"column":73}},{"start":{"line":64,"column":76},"end":{"line":64,"column":80}}],"line":64},"7":{"loc":{"start":{"line":66,"column":4},"end":{"line":68,"column":5}},"type":"if","locations":[{"start":{"line":66,"column":4},"end":{"line":68,"column":5}},{"start":{"line":66,"column":4},"end":{"line":68,"column":5}}],"line":66},"8":{"loc":{"start":{"line":66,"column":8},"end":{"line":66,"column":43}},"type":"binary-expr","locations":[{"start":{"line":66,"column":8},"end":{"line":66,"column":26}},{"start":{"line":66,"column":30},"end":{"line":66,"column":43}}],"line":66},"9":{"loc":{"start":{"line":70,"column":4},"end":{"line":73,"column":5}},"type":"if","locations":[{"start":{"line":70,"column":4},"end":{"line":73,"column":5}},{"start":{"line":70,"column":4},"end":{"line":73,"column":5}}],"line":70},"10":{"loc":{"start":{"line":70,"column":8},"end":{"line":70,"column":69}},"type":"binary-expr","locations":[{"start":{"line":70,"column":8},"end":{"line":70,"column":40}},{"start":{"line":70,"column":44},"end":{"line":70,"column":69}}],"line":70},"11":{"loc":{"start":{"line":75,"column":11},"end":{"line":75,"column":55}},"type":"cond-expr","locations":[{"start":{"line":75,"column":38},"end":{"line":75,"column":42}},{"start":{"line":75,"column":45},"end":{"line":75,"column":55}}],"line":75},"12":{"loc":{"start":{"line":75,"column":12},"end":{"line":75,"column":34}},"type":"binary-expr","locations":[{"start":{"line":75,"column":12},"end":{"line":75,"column":19}},{"start":{"line":75,"column":23},"end":{"line":75,"column":34}}],"line":75},"13":{"loc":{"start":{"line":81,"column":2},"end":{"line":83,"column":3}},"type":"if","locations":[{"start":{"line":81,"column":2},"end":{"line":83,"column":3}},{"start":{"line":81,"column":2},"end":{"line":83,"column":3}}],"line":81},"14":{"loc":{"start":{"line":85,"column":2},"end":{"line":87,"column":3}},"type":"if","locations":[{"start":{"line":85,"column":2},"end":{"line":87,"column":3}},{"start":{"line":85,"column":2},"end":{"line":87,"column":3}}],"line":85},"15":{"loc":{"start":{"line":93,"column":20},"end":{"line":93,"column":73}},"type":"cond-expr","locations":[{"start":{"line":93,"column":49},"end":{"line":93,"column":65}},{"start":{"line":93,"column":69},"end":{"line":93,"column":73}}],"line":93},"16":{"loc":{"start":{"line":94,"column":4},"end":{"line":96,"column":5}},"type":"if","locations":[{"start":{"line":94,"column":4},"end":{"line":96,"column":5}},{"start":{"line":94,"column":4},"end":{"line":96,"column":5}}],"line":94}},"s":{"0":1,"1":1,"2":1,"3":0,"4":1,"5":3,"6":3,"7":2,"8":2,"9":1,"10":197,"11":197,"12":197,"13":3,"14":3,"15":197,"16":188,"17":1,"18":197,"19":95,"20":46,"21":46,"22":46,"23":46,"24":46,"25":46,"26":9,"27":37,"28":5,"29":5,"30":32,"31":39,"32":39,"33":34,"34":39,"35":1,"36":39,"37":39,"38":39,"39":39,"40":1,"41":38,"42":38,"43":38,"44":38,"45":10,"46":10,"47":10,"48":10,"49":163,"50":163,"51":163,"52":1},"f":{"0":0,"1":3,"2":197,"3":1,"4":95,"5":46,"6":46,"7":46,"8":46,"9":39,"10":39,"11":38,"12":38,"13":10,"14":10,"15":163,"16":163},"b":{"0":[2,1],"1":[3,3],"2":[2,2],"3":[2,195],"4":[3,194],"5":[188,9],"6":[37,9],"7":[9,37],"8":[46,37],"9":[5,32],"10":[37,13],"11":[1,31],"12":[32,1],"13":[34,5],"14":[1,38],"15":[6,33],"16":[1,38]},"_coverageSchema":"1a1c01bbd47fc00a2c39e90264f33305004495a9","hash":"a1f9f50840413fbf8dec11cc75e741387da8a6d0","contentHash":"0ecb4ae8fe157ca1a77008538c0b536709aa7c13d364d4266adea5319bee04f1"}}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"parent":"67b1f344-0eec-41a3-a665-c824c346e898","pid":4476,"argv":["/Users/jaredwray/.nvm/versions/node/v16.13.1/bin/node","/Users/jaredwray/src/github.com/jaredwray/keyv/node_modules/update-notifier/check.js","{\"pkg\":{\"name\":\"ava\",\"version\":\"3.15.0\"},\"distTag\":\"latest\"}"],"execArgv":[],"cwd":"/Users/jaredwray/src/github.com/jaredwray/keyv/packages/keyv","time":1643754172416,"ppid":4475,"coverageFilename":"/Users/jaredwray/src/github.com/jaredwray/keyv/packages/keyv/.nyc_output/17c338d1-cd21-4d2f-9d97-398f18a945cf.json","externalId":"","uuid":"17c338d1-cd21-4d2f-9d97-398f18a945cf","files":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"parent":null,"pid":4475,"argv":["/Users/jaredwray/.nvm/versions/node/v16.13.1/bin/node","/Users/jaredwray/src/github.com/jaredwray/keyv/packages/keyv/node_modules/.bin/ava","--serial"],"execArgv":[],"cwd":"/Users/jaredwray/src/github.com/jaredwray/keyv/packages/keyv","time":1643754172273,"ppid":4474,"coverageFilename":"/Users/jaredwray/src/github.com/jaredwray/keyv/packages/keyv/.nyc_output/67b1f344-0eec-41a3-a665-c824c346e898.json","externalId":"","uuid":"67b1f344-0eec-41a3-a665-c824c346e898","files":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"parent":"67b1f344-0eec-41a3-a665-c824c346e898","pid":4477,"argv":["/Users/jaredwray/.nvm/versions/node/v16.13.1/bin/node","/Users/jaredwray/src/github.com/jaredwray/keyv/node_modules/ava/lib/worker/subprocess.js"],"execArgv":[],"cwd":"/Users/jaredwray/src/github.com/jaredwray/keyv/packages/keyv","time":1643754172556,"ppid":4475,"coverageFilename":"/Users/jaredwray/src/github.com/jaredwray/keyv/packages/keyv/.nyc_output/adb04494-7d0a-443f-9130-94b19c3fa19c.json","externalId":"","uuid":"adb04494-7d0a-443f-9130-94b19c3fa19c","files":["/Users/jaredwray/src/github.com/jaredwray/keyv/packages/keyv/src/index.js"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"processes":{"17c338d1-cd21-4d2f-9d97-398f18a945cf":{"parent":"67b1f344-0eec-41a3-a665-c824c346e898","children":[]},"67b1f344-0eec-41a3-a665-c824c346e898":{"parent":null,"children":["17c338d1-cd21-4d2f-9d97-398f18a945cf","adb04494-7d0a-443f-9130-94b19c3fa19c"]},"adb04494-7d0a-443f-9130-94b19c3fa19c":{"parent":"67b1f344-0eec-41a3-a665-c824c346e898","children":[]}},"files":{"/Users/jaredwray/src/github.com/jaredwray/keyv/packages/keyv/src/index.js":["adb04494-7d0a-443f-9130-94b19c3fa19c"]},"externalIds":{}}
|
package/README.md
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
<h1 align="center">
|
|
2
|
-
<img width="250" src="https://
|
|
2
|
+
<img width="250" src="https://jaredwray.com/images/keyv.svg" alt="keyv">
|
|
3
3
|
<br>
|
|
4
4
|
<br>
|
|
5
5
|
</h1>
|
|
6
6
|
|
|
7
7
|
> Simple key-value storage with support for multiple backends
|
|
8
8
|
|
|
9
|
-
[](https://github.com/jaredwray/keyv/actions/workflows/tests.yaml)
|
|
10
|
+
[](https://codecov.io/gh/jaredwray/keyv)
|
|
11
11
|
[](https://www.npmjs.com/package/keyv)
|
|
12
12
|
[](https://www.npmjs.com/package/keyv)
|
|
13
13
|
|
|
@@ -44,6 +44,7 @@ npm install --save @keyv/mongo
|
|
|
44
44
|
npm install --save @keyv/sqlite
|
|
45
45
|
npm install --save @keyv/postgres
|
|
46
46
|
npm install --save @keyv/mysql
|
|
47
|
+
npm install --save @keyv/etcd
|
|
47
48
|
```
|
|
48
49
|
|
|
49
50
|
Create a new Keyv instance, passing your connection string if applicable. Keyv will automatically load the correct storage adapter.
|
|
@@ -58,6 +59,7 @@ const keyv = new Keyv('mongodb://user:pass@localhost:27017/dbname');
|
|
|
58
59
|
const keyv = new Keyv('sqlite://path/to/database.sqlite');
|
|
59
60
|
const keyv = new Keyv('postgresql://user:pass@localhost:5432/dbname');
|
|
60
61
|
const keyv = new Keyv('mysql://user:pass@localhost:3306/dbname');
|
|
62
|
+
const keyv = new Keyv('etcd://localhost:2379');
|
|
61
63
|
|
|
62
64
|
// Handle DB connection errors
|
|
63
65
|
keyv.on('error', err => console.log('Connection Error', err));
|
|
@@ -100,15 +102,16 @@ const keyv = new Keyv({ serialize: JSON.stringify, deserialize: JSON.parse });
|
|
|
100
102
|
|
|
101
103
|
## Official Storage Adapters
|
|
102
104
|
|
|
103
|
-
The official storage adapters are covered by [over 150 integration tests](https://
|
|
105
|
+
The official storage adapters are covered by [over 150 integration tests](https://github.com/jaredwray/keyv/actions/workflows/tests.yaml) to guarantee consistent behaviour. They are lightweight, efficient wrappers over the DB clients making use of indexes and native TTLs where available.
|
|
104
106
|
|
|
105
|
-
Database | Adapter | Native TTL
|
|
106
|
-
|
|
107
|
-
Redis | [@keyv/redis](https://github.com/
|
|
108
|
-
MongoDB | [@keyv/mongo](https://github.com/
|
|
109
|
-
SQLite | [@keyv/sqlite](https://github.com/
|
|
110
|
-
PostgreSQL | [@keyv/postgres](https://github.com/
|
|
111
|
-
MySQL | [@keyv/mysql](https://github.com/
|
|
107
|
+
Database | Adapter | Native TTL
|
|
108
|
+
---|---|---
|
|
109
|
+
Redis | [@keyv/redis](https://github.com/jaredwray/keyv/tree/master/packages/redis) | Yes
|
|
110
|
+
MongoDB | [@keyv/mongo](https://github.com/jaredwray/keyv/tree/master/packages/mongo) | Yes
|
|
111
|
+
SQLite | [@keyv/sqlite](https://github.com/jaredwray/keyv/tree/master/packages/sqlite) | No
|
|
112
|
+
PostgreSQL | [@keyv/postgres](https://github.com/jaredwray/keyv/tree/master/packages/postgres) | No
|
|
113
|
+
MySQL | [@keyv/mysql](https://github.com/jaredwray/keyv/tree/master/packages/mysql) | No
|
|
114
|
+
Etcd | [@keyv/etcd](https://github.com/jaredwray/keyv/tree/master/packages/etcd) | Yes
|
|
112
115
|
|
|
113
116
|
## Third-party Storage Adapters
|
|
114
117
|
|
|
@@ -142,9 +145,12 @@ The following are third-party storage adapters compatible with Keyv:
|
|
|
142
145
|
- [quick-lru](https://github.com/sindresorhus/quick-lru) - Simple "Least Recently Used" (LRU) cache
|
|
143
146
|
- [keyv-file](https://github.com/zaaack/keyv-file) - File system storage adapter for Keyv
|
|
144
147
|
- [keyv-dynamodb](https://www.npmjs.com/package/keyv-dynamodb) - DynamoDB storage adapter for Keyv
|
|
148
|
+
- [keyv-lru](https://www.npmjs.com/package/keyv-lru) - LRU storage adapter for Keyv
|
|
149
|
+
- [keyv-null](https://www.npmjs.com/package/keyv-null) - Null storage adapter for Keyv
|
|
145
150
|
- [keyv-firestore ](https://github.com/goto-bus-stop/keyv-firestore) – Firebase Cloud Firestore adapter for Keyv
|
|
146
151
|
- [keyv-mssql](https://github.com/pmorgan3/keyv-mssql) - Microsoft Sql Server adapter for Keyv
|
|
147
|
-
- [keyv-memcache](https://github.com/jaredwray/keyv
|
|
152
|
+
- [keyv-memcache](https://github.com/jaredwray/keyv/tree/master/packages/memcache) - Memcache storage adapter for Keyv
|
|
153
|
+
- [keyv-azuretable](https://github.com/howlowck/keyv-azuretable) - Azure Table Storage/API adapter for Keyv
|
|
148
154
|
|
|
149
155
|
## Add Cache Support to your Module
|
|
150
156
|
|
|
@@ -283,6 +289,84 @@ Delete all entries in the current namespace.
|
|
|
283
289
|
|
|
284
290
|
Returns a promise which is resolved when the entries have been cleared.
|
|
285
291
|
|
|
292
|
+
# How to Contribute
|
|
293
|
+
|
|
294
|
+
In this section of the documentation we will cover:
|
|
295
|
+
|
|
296
|
+
1) How to set up this repository locally
|
|
297
|
+
2) How to get started with running commands
|
|
298
|
+
3) How to contribute changes using Pull Requests
|
|
299
|
+
|
|
300
|
+
## Dependencies
|
|
301
|
+
|
|
302
|
+
This package requires the following dependencies to run:
|
|
303
|
+
|
|
304
|
+
1) [Yarn V1](https://yarnpkg.com/getting-started/install)
|
|
305
|
+
2) [Lerna](https://lerna.js.org/)
|
|
306
|
+
3) [Docker](https://docs.docker.com/get-docker/)
|
|
307
|
+
|
|
308
|
+
## Setting up your workspace
|
|
309
|
+
|
|
310
|
+
To contribute to this repository, start by setting up this project locally:
|
|
311
|
+
|
|
312
|
+
1) Fork this repository into your Git account
|
|
313
|
+
2) Clone the forked repository to your local directory using `git clone`
|
|
314
|
+
3) Install any of the above missing dependencies
|
|
315
|
+
|
|
316
|
+
## Launching the project
|
|
317
|
+
|
|
318
|
+
Once the project is installed locally, you are ready to start up its services:
|
|
319
|
+
|
|
320
|
+
1) Ensure that your Docker service is running.
|
|
321
|
+
2) From the root directory of your project, run the `yarn` command in the command prompt to install yarn.
|
|
322
|
+
3) Run the `yarn bootstrap` command to install any necessary dependencies.
|
|
323
|
+
4) Run `yarn test:services:start` to start up this project's Docker container. The container will launch all services within your workspace.
|
|
324
|
+
|
|
325
|
+
## Available Commands
|
|
326
|
+
|
|
327
|
+
Once the project is running, you can execute a variety of commands. The root workspace and each subpackage contain a `package.json` file with a `scripts` field listing all the commands that can be executed from that directory. This project also supports native `yarn`, `lerna`, and `docker` commands.
|
|
328
|
+
|
|
329
|
+
Here, we'll cover the primary commands that can be executed from the root directory. Unless otherwise noted, these commands can also be executed from a subpackage. If executed from a subpackage, they will only affect that subpackage, rather than the entire workspace.
|
|
330
|
+
|
|
331
|
+
### `yarn`
|
|
332
|
+
|
|
333
|
+
The `yarn` command installs yarn in the workspace.
|
|
334
|
+
|
|
335
|
+
### `yarn bootstrap`
|
|
336
|
+
|
|
337
|
+
The `yarn bootstrap` command installs all dependencies in the workspace.
|
|
338
|
+
|
|
339
|
+
### `yarn test:services:start`
|
|
340
|
+
|
|
341
|
+
The `yarn test:services:start` command starts up the project's Docker container, launching all services in the workspace. This command must be executed from the root directory.
|
|
342
|
+
|
|
343
|
+
### `yarn test:services:stop`
|
|
344
|
+
|
|
345
|
+
The `yarn test:services:stop` command brings down the project's Docker container, halting all services. This command must be executed from the root directory.
|
|
346
|
+
|
|
347
|
+
### `yarn test`
|
|
348
|
+
|
|
349
|
+
The `yarn test` command runs all tests in the workspace.
|
|
350
|
+
|
|
351
|
+
### `yarn clean`
|
|
352
|
+
|
|
353
|
+
The `yarn clean` command removes yarn and all dependencies installed by yarn. After executing this command, you must repeat the steps in *Setting up your workspace* to rebuild your workspace.
|
|
354
|
+
|
|
355
|
+
## Contributing Changes
|
|
356
|
+
|
|
357
|
+
Now that you've set up your workspace, you're ready to contribute changes to the `keyv` repository.
|
|
358
|
+
|
|
359
|
+
1) Make any changes that you would like to contribute in your local workspace.
|
|
360
|
+
2) After making these changes, ensure that the project's tests still pass by executing the `yarn test` command in the root directory.
|
|
361
|
+
3) Commit your changes and push them to your forked repository.
|
|
362
|
+
4) Navigate to the original `keyv` repository and go the *Pull Requests* tab.
|
|
363
|
+
5) Click the *New pull request* button, and open a pull request for the branch in your repository that contains your changes.
|
|
364
|
+
6) Once your pull request is created, ensure that all checks have passed and that your branch has no conflicts with the base branch. If there are any issues, resolve these changes in your local repository, and then commit and push them to git.
|
|
365
|
+
7) Similarly, respond to any reviewer comments or requests for changes by making edits to your local repository and pushing them to Git.
|
|
366
|
+
8) Once the pull request has been reviewed, those with write access to the branch will be able to merge your changes into the `keyv` repository.
|
|
367
|
+
|
|
368
|
+
If you need more information on the steps to create a pull request, you can find a detailed walkthrough in the [Github documentation](https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/creating-a-pull-request-from-a-fork)
|
|
369
|
+
|
|
286
370
|
## License
|
|
287
371
|
|
|
288
|
-
MIT © Luke Childs
|
|
372
|
+
MIT © Jared Wray & Luke Childs
|
package/package.json
CHANGED
|
@@ -1,19 +1,22 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "keyv",
|
|
3
|
-
"version": "4.0
|
|
3
|
+
"version": "4.1.0",
|
|
4
4
|
"description": "Simple key-value storage with support for multiple backends",
|
|
5
5
|
"main": "src/index.js",
|
|
6
6
|
"scripts": {
|
|
7
|
-
"test": "xo && nyc ava
|
|
8
|
-
"
|
|
9
|
-
"
|
|
7
|
+
"test": "xo && nyc ava --serial",
|
|
8
|
+
"coverage": "nyc report --reporter=text-lcov > coverage.lcov",
|
|
9
|
+
"clean": "rm -rf node_modules && rm -rf .nyc_output && rm -rf coverage.lcov && rm -rf ./test/testdb.sqlite"
|
|
10
10
|
},
|
|
11
11
|
"xo": {
|
|
12
|
-
"extends": "xo-lukechilds"
|
|
12
|
+
"extends": "xo-lukechilds",
|
|
13
|
+
"rules": {
|
|
14
|
+
"unicorn/prefer-module": 0
|
|
15
|
+
}
|
|
13
16
|
},
|
|
14
17
|
"repository": {
|
|
15
18
|
"type": "git",
|
|
16
|
-
"url": "git+https://github.com/
|
|
19
|
+
"url": "git+https://github.com/jaredwray/keyv.git"
|
|
17
20
|
},
|
|
18
21
|
"keywords": [
|
|
19
22
|
"key",
|
|
@@ -22,28 +25,24 @@
|
|
|
22
25
|
"cache",
|
|
23
26
|
"ttl"
|
|
24
27
|
],
|
|
25
|
-
"author": "
|
|
28
|
+
"author": "Jared Wray <me@jaredwray.com> (http://jaredwray.com)",
|
|
26
29
|
"license": "MIT",
|
|
27
30
|
"bugs": {
|
|
28
|
-
"url": "https://github.com/
|
|
31
|
+
"url": "https://github.com/jaredwray/keyv/issues"
|
|
29
32
|
},
|
|
30
|
-
"homepage": "https://github.com/
|
|
33
|
+
"homepage": "https://github.com/jaredwray/keyv",
|
|
31
34
|
"dependencies": {
|
|
32
35
|
"json-buffer": "3.0.1"
|
|
33
36
|
},
|
|
34
37
|
"devDependencies": {
|
|
35
|
-
"ava": "^2.2.0",
|
|
36
|
-
"coveralls": "^3.0.0",
|
|
37
|
-
"eslint-config-xo-lukechilds": "^1.0.0",
|
|
38
|
-
"@keyv/mongo": "*",
|
|
39
|
-
"@keyv/mysql": "*",
|
|
40
|
-
"@keyv/postgres": "*",
|
|
41
|
-
"@keyv/redis": "*",
|
|
42
|
-
"@keyv/sqlite": "*",
|
|
43
38
|
"@keyv/test-suite": "*",
|
|
44
|
-
"
|
|
39
|
+
"ava": "^3.15.0",
|
|
40
|
+
"eslint-config-xo-lukechilds": "^1.0.0",
|
|
41
|
+
"eslint-plugin-promise": "^5.1.1",
|
|
42
|
+
"nyc": "^15.1.0",
|
|
43
|
+
"pify": "5.0.0",
|
|
45
44
|
"this": "^1.0.2",
|
|
46
45
|
"timekeeper": "^2.0.0",
|
|
47
|
-
"xo": "^0.
|
|
46
|
+
"xo": "^0.46.3"
|
|
48
47
|
}
|
|
49
48
|
}
|
package/src/index.js
CHANGED
|
@@ -3,44 +3,50 @@
|
|
|
3
3
|
const EventEmitter = require('events');
|
|
4
4
|
const JSONB = require('json-buffer');
|
|
5
5
|
|
|
6
|
-
|
|
6
|
+
// eslint-disable-next-line no-extend-native
|
|
7
|
+
BigInt.prototype.toJSON = function () {
|
|
8
|
+
return this.toString();
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
const loadStore = options => {
|
|
7
12
|
const adapters = {
|
|
8
|
-
redis:
|
|
9
|
-
mongodb:
|
|
10
|
-
mongo:
|
|
11
|
-
sqlite:
|
|
12
|
-
postgresql:
|
|
13
|
-
postgres:
|
|
14
|
-
mysql:
|
|
13
|
+
redis: '@keyv/redis',
|
|
14
|
+
mongodb: '@keyv/mongo',
|
|
15
|
+
mongo: '@keyv/mongo',
|
|
16
|
+
sqlite: '@keyv/sqlite',
|
|
17
|
+
postgresql: '@keyv/postgres',
|
|
18
|
+
postgres: '@keyv/postgres',
|
|
19
|
+
mysql: '@keyv/mysql',
|
|
20
|
+
etcd: '@keyv/etcd',
|
|
15
21
|
};
|
|
16
|
-
if (
|
|
17
|
-
const adapter =
|
|
18
|
-
return new (adapters[adapter]
|
|
22
|
+
if (options.adapter || options.uri) {
|
|
23
|
+
const adapter = options.adapter || /^[^:]*/.exec(options.uri)[0];
|
|
24
|
+
return new (require(adapters[adapter]))(options);
|
|
19
25
|
}
|
|
20
26
|
|
|
21
27
|
return new Map();
|
|
22
28
|
};
|
|
23
29
|
|
|
24
30
|
class Keyv extends EventEmitter {
|
|
25
|
-
constructor(uri,
|
|
31
|
+
constructor(uri, options) {
|
|
26
32
|
super();
|
|
27
33
|
this.opts = Object.assign(
|
|
28
34
|
{
|
|
29
35
|
namespace: 'keyv',
|
|
30
36
|
serialize: JSONB.stringify,
|
|
31
|
-
deserialize: JSONB.parse
|
|
37
|
+
deserialize: JSONB.parse,
|
|
32
38
|
},
|
|
33
39
|
(typeof uri === 'string') ? { uri } : uri,
|
|
34
|
-
|
|
40
|
+
options,
|
|
35
41
|
);
|
|
36
42
|
|
|
37
43
|
if (!this.opts.store) {
|
|
38
|
-
const
|
|
39
|
-
this.opts.store = loadStore(
|
|
44
|
+
const adapterOptions = Object.assign({}, this.opts);
|
|
45
|
+
this.opts.store = loadStore(adapterOptions);
|
|
40
46
|
}
|
|
41
47
|
|
|
42
48
|
if (typeof this.opts.store.on === 'function') {
|
|
43
|
-
this.opts.store.on('error',
|
|
49
|
+
this.opts.store.on('error', error => this.emit('error', error));
|
|
44
50
|
}
|
|
45
51
|
|
|
46
52
|
this.opts.store.namespace = this.opts.namespace;
|
|
@@ -50,16 +56,14 @@ class Keyv extends EventEmitter {
|
|
|
50
56
|
return `${this.opts.namespace}:${key}`;
|
|
51
57
|
}
|
|
52
58
|
|
|
53
|
-
get(key,
|
|
59
|
+
get(key, options) {
|
|
54
60
|
const keyPrefixed = this._getKeyPrefix(key);
|
|
55
61
|
const { store } = this.opts;
|
|
56
62
|
return Promise.resolve()
|
|
57
63
|
.then(() => store.get(keyPrefixed))
|
|
64
|
+
.then(data => (typeof data === 'string') ? this.opts.deserialize(data) : data)
|
|
58
65
|
.then(data => {
|
|
59
|
-
|
|
60
|
-
})
|
|
61
|
-
.then(data => {
|
|
62
|
-
if (data === undefined) {
|
|
66
|
+
if (data === undefined || data === null) {
|
|
63
67
|
return undefined;
|
|
64
68
|
}
|
|
65
69
|
|
|
@@ -68,7 +72,7 @@ class Keyv extends EventEmitter {
|
|
|
68
72
|
return undefined;
|
|
69
73
|
}
|
|
70
74
|
|
|
71
|
-
return (
|
|
75
|
+
return (options && options.raw) ? data : data.value;
|
|
72
76
|
});
|
|
73
77
|
}
|
|
74
78
|
|
|
@@ -87,6 +91,10 @@ class Keyv extends EventEmitter {
|
|
|
87
91
|
return Promise.resolve()
|
|
88
92
|
.then(() => {
|
|
89
93
|
const expires = (typeof ttl === 'number') ? (Date.now() + ttl) : null;
|
|
94
|
+
if (typeof value === 'symbol') {
|
|
95
|
+
this.emit('error', 'symbol cannot be serialized');
|
|
96
|
+
}
|
|
97
|
+
|
|
90
98
|
value = { value, expires };
|
|
91
99
|
return this.opts.serialize(value);
|
|
92
100
|
})
|
package/test/test.js
ADDED
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
const test = require('ava');
|
|
2
|
+
const { default: keyvTestSuite, keyvOfficialTests } = require('@keyv/test-suite');
|
|
3
|
+
const Keyv = require('this');
|
|
4
|
+
const tk = require('timekeeper');
|
|
5
|
+
const KeyvSqlite = require('@keyv/sqlite');
|
|
6
|
+
|
|
7
|
+
keyvOfficialTests(test, Keyv, 'sqlite://test/testdb.sqlite', 'sqlite://non/existent/database.sqlite');
|
|
8
|
+
const store = () => new KeyvSqlite({ uri: 'sqlite://test/testdb.sqlite', busyTimeout: 3000 });
|
|
9
|
+
keyvTestSuite(test, Keyv, store);
|
|
10
|
+
|
|
11
|
+
test.serial('Keyv is a class', t => {
|
|
12
|
+
t.is(typeof Keyv, 'function');
|
|
13
|
+
t.throws(() => Keyv()); // eslint-disable-line new-cap
|
|
14
|
+
t.notThrows(() => new Keyv());
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
test.serial('Keyv accepts storage adapters', async t => {
|
|
18
|
+
const store = new Map();
|
|
19
|
+
const keyv = new Keyv({ store });
|
|
20
|
+
t.is(store.size, 0);
|
|
21
|
+
await keyv.set('foo', 'bar');
|
|
22
|
+
t.is(await keyv.get('foo'), 'bar');
|
|
23
|
+
t.is(store.size, 1);
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
test.serial('Keyv passes tll info to stores', async t => {
|
|
27
|
+
t.plan(1);
|
|
28
|
+
const store = new Map();
|
|
29
|
+
const storeSet = store.set;
|
|
30
|
+
store.set = (key, value, ttl) => {
|
|
31
|
+
t.is(ttl, 100);
|
|
32
|
+
storeSet.call(store, key, value, ttl);
|
|
33
|
+
};
|
|
34
|
+
|
|
35
|
+
const keyv = new Keyv({ store });
|
|
36
|
+
await keyv.set('foo', 'bar', 100);
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
test.serial('Keyv respects default tll option', async t => {
|
|
40
|
+
const store = new Map();
|
|
41
|
+
const keyv = new Keyv({ store, ttl: 100 });
|
|
42
|
+
await keyv.set('foo', 'bar');
|
|
43
|
+
t.is(await keyv.get('foo'), 'bar');
|
|
44
|
+
tk.freeze(Date.now() + 150);
|
|
45
|
+
t.is(await keyv.get('foo'), undefined);
|
|
46
|
+
t.is(store.size, 0);
|
|
47
|
+
tk.reset();
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
test.serial('.set(key, val, ttl) overwrites default tll option', async t => {
|
|
51
|
+
const startTime = Date.now();
|
|
52
|
+
tk.freeze(startTime);
|
|
53
|
+
const store = new Map();
|
|
54
|
+
const keyv = new Keyv({ store, ttl: 200 });
|
|
55
|
+
await keyv.set('foo', 'bar');
|
|
56
|
+
await keyv.set('fizz', 'buzz', 100);
|
|
57
|
+
await keyv.set('ping', 'pong', 300);
|
|
58
|
+
t.is(await keyv.get('foo'), 'bar');
|
|
59
|
+
t.is(await keyv.get('fizz'), 'buzz');
|
|
60
|
+
t.is(await keyv.get('ping'), 'pong');
|
|
61
|
+
tk.freeze(startTime + 150);
|
|
62
|
+
t.is(await keyv.get('foo'), 'bar');
|
|
63
|
+
t.is(await keyv.get('fizz'), undefined);
|
|
64
|
+
t.is(await keyv.get('ping'), 'pong');
|
|
65
|
+
tk.freeze(startTime + 250);
|
|
66
|
+
t.is(await keyv.get('foo'), undefined);
|
|
67
|
+
t.is(await keyv.get('ping'), 'pong');
|
|
68
|
+
tk.freeze(startTime + 350);
|
|
69
|
+
t.is(await keyv.get('ping'), undefined);
|
|
70
|
+
tk.reset();
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
test.serial('.set(key, val, ttl) where ttl is "0" overwrites default tll option and sets key to never expire', async t => {
|
|
74
|
+
const startTime = Date.now();
|
|
75
|
+
tk.freeze(startTime);
|
|
76
|
+
const store = new Map();
|
|
77
|
+
const keyv = new Keyv({ store, ttl: 200 });
|
|
78
|
+
await keyv.set('foo', 'bar', 0);
|
|
79
|
+
t.is(await keyv.get('foo'), 'bar');
|
|
80
|
+
tk.freeze(startTime + 250);
|
|
81
|
+
t.is(await keyv.get('foo'), 'bar');
|
|
82
|
+
tk.reset();
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
test.serial('.get(key, {raw: true}) returns the raw object instead of the value', async t => {
|
|
86
|
+
const store = new Map();
|
|
87
|
+
const keyv = new Keyv({ store });
|
|
88
|
+
await keyv.set('foo', 'bar');
|
|
89
|
+
const value = await keyv.get('foo');
|
|
90
|
+
const rawObject = await keyv.get('foo', { raw: true });
|
|
91
|
+
t.is(value, 'bar');
|
|
92
|
+
t.is(rawObject.value, 'bar');
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
test.serial('Keyv uses custom serializer when provided instead of json-buffer', async t => {
|
|
96
|
+
t.plan(3);
|
|
97
|
+
const store = new Map();
|
|
98
|
+
const serialize = data => {
|
|
99
|
+
t.pass();
|
|
100
|
+
return JSON.stringify(data);
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
const deserialize = data => {
|
|
104
|
+
t.pass();
|
|
105
|
+
return JSON.parse(data);
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
const keyv = new Keyv({ store, serialize, deserialize });
|
|
109
|
+
await keyv.set('foo', 'bar');
|
|
110
|
+
t.is(await keyv.get('foo'), 'bar');
|
|
111
|
+
});
|
|
112
|
+
|
|
113
|
+
test.serial('Keyv supports async serializer/deserializer', async t => {
|
|
114
|
+
t.plan(3);
|
|
115
|
+
const store = new Map();
|
|
116
|
+
|
|
117
|
+
const serialize = async data => {
|
|
118
|
+
t.pass();
|
|
119
|
+
return JSON.stringify(data);
|
|
120
|
+
};
|
|
121
|
+
|
|
122
|
+
const deserialize = async data => {
|
|
123
|
+
t.pass();
|
|
124
|
+
return JSON.parse(data);
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
const keyv = new Keyv({ store, serialize, deserialize });
|
|
128
|
+
await keyv.set('foo', 'bar');
|
|
129
|
+
t.is(await keyv.get('foo'), 'bar');
|
|
130
|
+
});
|
|
Binary file
|
package/LICENSE
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
MIT License
|
|
2
|
-
|
|
3
|
-
Copyright (c) 2017 Luke Childs
|
|
4
|
-
|
|
5
|
-
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
-
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
-
in the Software without restriction, including without limitation the rights
|
|
8
|
-
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
-
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
-
furnished to do so, subject to the following conditions:
|
|
11
|
-
|
|
12
|
-
The above copyright notice and this permission notice shall be included in all
|
|
13
|
-
copies or substantial portions of the Software.
|
|
14
|
-
|
|
15
|
-
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
-
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
-
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
-
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
-
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
-
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
-
SOFTWARE.
|