@upstash/redis 0.0.0-ci.f55d85c5 → 0.0.0-ci.fb6b986f-20221006
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 +36 -274
- package/esm/deps/deno.land/x/base64@v0.2.1/base.js +100 -0
- package/esm/deps/deno.land/x/base64@v0.2.1/base64url.js +9 -0
- package/esm/deps/deno.land/x/sha1@v1.0.3/deps.js +1 -0
- package/esm/deps/deno.land/x/sha1@v1.0.3/mod.js +191 -0
- package/esm/deps/denopkg.com/chiefbiiko/std-encoding@v1.0.0/mod.js +50 -0
- package/esm/pkg/commands/lpos.js +19 -0
- package/esm/pkg/commands/mod.js +1 -0
- package/esm/pkg/commands/scan.js +3 -0
- package/esm/pkg/commands/script_exists.js +1 -10
- package/esm/pkg/commands/sdiffstore.js +1 -1
- package/esm/pkg/commands/set.js +16 -4
- package/esm/pkg/commands/zmscore.js +10 -0
- package/esm/pkg/commands/zrange.js +6 -0
- package/esm/pkg/http.js +88 -9
- package/esm/pkg/pipeline.js +20 -1
- package/esm/pkg/redis.js +36 -1
- package/esm/pkg/script.js +77 -0
- package/esm/platforms/cloudflare.js +5 -25
- package/esm/platforms/fastly.js +4 -25
- package/esm/platforms/node_with_fetch.js +4 -25
- package/esm/platforms/nodejs.js +4 -25
- package/package.json +10 -37
- package/script/deps/deno.land/x/base64@v0.2.1/base.js +104 -0
- package/script/deps/deno.land/x/base64@v0.2.1/base64url.js +13 -0
- package/script/deps/deno.land/x/sha1@v1.0.3/deps.js +6 -0
- package/script/deps/deno.land/x/sha1@v1.0.3/mod.js +196 -0
- package/script/deps/denopkg.com/chiefbiiko/std-encoding@v1.0.0/mod.js +55 -0
- package/script/pkg/commands/lpos.js +23 -0
- package/script/pkg/commands/mod.js +1 -0
- package/script/pkg/commands/scan.js +3 -0
- package/script/pkg/commands/script_exists.js +1 -10
- package/script/pkg/commands/sdiffstore.js +1 -1
- package/script/pkg/commands/set.js +16 -4
- package/script/pkg/commands/zmscore.js +14 -0
- package/script/pkg/commands/zrange.js +6 -0
- package/script/pkg/http.js +88 -9
- package/script/pkg/pipeline.js +19 -0
- package/script/pkg/redis.js +35 -0
- package/script/pkg/script.js +81 -0
- package/script/platforms/cloudflare.js +5 -25
- package/script/platforms/fastly.js +4 -25
- package/script/platforms/node_with_fetch.js +4 -25
- package/script/platforms/nodejs.js +4 -25
- package/types/deps/deno.land/x/base64@v0.2.1/base.d.ts +5 -0
- package/types/deps/deno.land/x/base64@v0.2.1/base64url.d.ts +1 -0
- package/types/deps/deno.land/x/sha1@v1.0.3/deps.d.ts +1 -0
- package/types/deps/deno.land/x/sha1@v1.0.3/mod.d.ts +26 -0
- package/types/deps/denopkg.com/chiefbiiko/std-encoding@v1.0.0/mod.d.ts +3 -0
- package/types/pkg/commands/bitop.d.ts +0 -1
- package/types/pkg/commands/bitpos.d.ts +1 -1
- package/types/pkg/commands/hmset.d.ts +2 -2
- package/types/pkg/commands/lpop.d.ts +1 -1
- package/types/pkg/commands/lpos.d.ts +15 -0
- package/types/pkg/commands/mget.d.ts +1 -1
- package/types/pkg/commands/mod.d.ts +1 -0
- package/types/pkg/commands/rpop.d.ts +2 -2
- package/types/pkg/commands/scan.d.ts +1 -0
- package/types/pkg/commands/script_exists.d.ts +2 -4
- package/types/pkg/commands/sdiffstore.d.ts +1 -1
- package/types/pkg/commands/set.d.ts +31 -2
- package/types/pkg/commands/sinterstore.d.ts +2 -2
- package/types/pkg/commands/spop.d.ts +2 -2
- package/types/pkg/commands/zadd.d.ts +1 -1
- package/types/pkg/commands/zmscore.d.ts +7 -0
- package/types/pkg/commands/zrange.d.ts +7 -0
- package/types/pkg/http.d.ts +27 -3
- package/types/pkg/pipeline.d.ts +19 -7
- package/types/pkg/redis.d.ts +29 -11
- package/types/pkg/script.d.ts +42 -0
- package/types/platforms/cloudflare.d.ts +6 -2
- package/types/platforms/fastly.d.ts +5 -1
- package/types/platforms/node_with_fetch.d.ts +20 -1
- package/types/platforms/nodejs.d.ts +20 -1
package/esm/platforms/nodejs.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// deno-lint-ignore-file
|
|
2
2
|
import * as core from "../pkg/redis.js";
|
|
3
|
-
import {
|
|
3
|
+
import { HttpClient, } from "../pkg/http.js";
|
|
4
4
|
/**
|
|
5
5
|
* Serverless redis client for upstash.
|
|
6
6
|
*/
|
|
@@ -20,8 +20,9 @@ export class Redis extends core.Redis {
|
|
|
20
20
|
/\r|\n/.test(configOrRequester.token)) {
|
|
21
21
|
console.warn("The redis token contains whitespace or newline, which can cause errors!");
|
|
22
22
|
}
|
|
23
|
-
const client =
|
|
23
|
+
const client = new HttpClient({
|
|
24
24
|
baseUrl: configOrRequester.url,
|
|
25
|
+
retry: configOrRequester.retry,
|
|
25
26
|
headers: { authorization: `Bearer ${configOrRequester.token}` },
|
|
26
27
|
// agent: configOrRequester.agent,
|
|
27
28
|
});
|
|
@@ -53,28 +54,6 @@ export class Redis extends core.Redis {
|
|
|
53
54
|
if (!token) {
|
|
54
55
|
throw new Error("Unable to find environment variable: `UPSTASH_REDIS_REST_TOKEN`");
|
|
55
56
|
}
|
|
56
|
-
return new Redis({ url, token
|
|
57
|
+
return new Redis({ ...config, url, token });
|
|
57
58
|
}
|
|
58
59
|
}
|
|
59
|
-
function defaultRequester(config) {
|
|
60
|
-
return {
|
|
61
|
-
request: async function (req) {
|
|
62
|
-
if (!req.path) {
|
|
63
|
-
req.path = [];
|
|
64
|
-
}
|
|
65
|
-
const res = await fetch([config.baseUrl, ...req.path].join("/"), {
|
|
66
|
-
method: "POST",
|
|
67
|
-
headers: { "Content-Type": "application/json", ...config.headers },
|
|
68
|
-
body: JSON.stringify(req.body),
|
|
69
|
-
keepalive: true,
|
|
70
|
-
// @ts-ignore
|
|
71
|
-
agent: config.agent,
|
|
72
|
-
});
|
|
73
|
-
const body = (await res.json());
|
|
74
|
-
if (!res.ok) {
|
|
75
|
-
throw new UpstashError(body.error);
|
|
76
|
-
}
|
|
77
|
-
return body;
|
|
78
|
-
},
|
|
79
|
-
};
|
|
80
|
-
}
|
package/package.json
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
"main": "./script/platforms/nodejs.js",
|
|
4
4
|
"types": "./types/platforms/nodejs.d.ts",
|
|
5
5
|
"name": "@upstash/redis",
|
|
6
|
-
"version": "v0.0.0-ci.
|
|
6
|
+
"version": "v0.0.0-ci.fb6b986f-20221006",
|
|
7
7
|
"description": "An HTTP/REST based Redis client built on top of Upstash REST API.",
|
|
8
8
|
"repository": {
|
|
9
9
|
"type": "git",
|
|
@@ -16,50 +16,23 @@
|
|
|
16
16
|
"edge",
|
|
17
17
|
"upstash"
|
|
18
18
|
],
|
|
19
|
-
"author": "Andreas Thomas <
|
|
19
|
+
"author": "Andreas Thomas <dev@chronark.com>",
|
|
20
20
|
"license": "MIT",
|
|
21
21
|
"bugs": {
|
|
22
22
|
"url": "https://github.com/upstash/upstash-redis/issues"
|
|
23
23
|
},
|
|
24
|
+
"homepage": "https://github.com/upstash/upstash-redis#readme",
|
|
24
25
|
"dependencies": {
|
|
25
26
|
"isomorphic-fetch": "^3.0.0"
|
|
26
27
|
},
|
|
27
|
-
"
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
"devDependencies": {
|
|
34
|
-
"@size-limit/preset-small-lib": "latest",
|
|
35
|
-
"size-limit": "latest"
|
|
36
|
-
},
|
|
37
|
-
"size-limit": [
|
|
38
|
-
{
|
|
39
|
-
"path": "esm/platforms/nodejs.js",
|
|
40
|
-
"limit": "5 KB"
|
|
41
|
-
},
|
|
42
|
-
{
|
|
43
|
-
"path": "esm/platforms/fastly.js",
|
|
44
|
-
"limit": "5 KB"
|
|
45
|
-
},
|
|
46
|
-
{
|
|
47
|
-
"path": "esm/platforms/cloudflare.js",
|
|
48
|
-
"limit": "5 KB"
|
|
49
|
-
},
|
|
50
|
-
{
|
|
51
|
-
"path": "script/platforms/nodejs.js",
|
|
52
|
-
"limit": "10 KB"
|
|
53
|
-
},
|
|
54
|
-
{
|
|
55
|
-
"path": "script/platforms/fastly.js",
|
|
56
|
-
"limit": "10 KB"
|
|
57
|
-
},
|
|
58
|
-
{
|
|
59
|
-
"path": "script/platforms/cloudflare.js",
|
|
60
|
-
"limit": "10 KB"
|
|
28
|
+
"typesVersions": {
|
|
29
|
+
"*": {
|
|
30
|
+
"nodejs": "./types/platforms/nodejs.d.ts",
|
|
31
|
+
"cloudflare": "./types/platforms/cloudflare.d.ts",
|
|
32
|
+
"fastly": "./types/platforms/fastly.d.ts",
|
|
33
|
+
"with-fetch": "./types/platforms/node_with_fetch.d.ts"
|
|
61
34
|
}
|
|
62
|
-
|
|
35
|
+
},
|
|
63
36
|
"exports": {
|
|
64
37
|
".": {
|
|
65
38
|
"import": "./esm/platforms/nodejs.js",
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.init = void 0;
|
|
4
|
+
function getLengths(b64) {
|
|
5
|
+
const len = b64.length;
|
|
6
|
+
// if (len % 4 > 0) {
|
|
7
|
+
// throw new TypeError("Invalid string. Length must be a multiple of 4");
|
|
8
|
+
// }
|
|
9
|
+
// Trim off extra bytes after placeholder bytes are found
|
|
10
|
+
// See: https://github.com/beatgammit/base64-js/issues/42
|
|
11
|
+
let validLen = b64.indexOf("=");
|
|
12
|
+
if (validLen === -1) {
|
|
13
|
+
validLen = len;
|
|
14
|
+
}
|
|
15
|
+
const placeHoldersLen = validLen === len ? 0 : 4 - (validLen % 4);
|
|
16
|
+
return [validLen, placeHoldersLen];
|
|
17
|
+
}
|
|
18
|
+
function init(lookup, revLookup, urlsafe = false) {
|
|
19
|
+
function _byteLength(validLen, placeHoldersLen) {
|
|
20
|
+
return Math.floor(((validLen + placeHoldersLen) * 3) / 4 - placeHoldersLen);
|
|
21
|
+
}
|
|
22
|
+
function tripletToBase64(num) {
|
|
23
|
+
return (lookup[(num >> 18) & 0x3f] +
|
|
24
|
+
lookup[(num >> 12) & 0x3f] +
|
|
25
|
+
lookup[(num >> 6) & 0x3f] +
|
|
26
|
+
lookup[num & 0x3f]);
|
|
27
|
+
}
|
|
28
|
+
function encodeChunk(buf, start, end) {
|
|
29
|
+
const out = new Array((end - start) / 3);
|
|
30
|
+
for (let i = start, curTriplet = 0; i < end; i += 3) {
|
|
31
|
+
out[curTriplet++] = tripletToBase64((buf[i] << 16) + (buf[i + 1] << 8) + buf[i + 2]);
|
|
32
|
+
}
|
|
33
|
+
return out.join("");
|
|
34
|
+
}
|
|
35
|
+
return {
|
|
36
|
+
// base64 is 4/3 + up to two characters of the original data
|
|
37
|
+
byteLength(b64) {
|
|
38
|
+
return _byteLength.apply(null, getLengths(b64));
|
|
39
|
+
},
|
|
40
|
+
toUint8Array(b64) {
|
|
41
|
+
const [validLen, placeHoldersLen] = getLengths(b64);
|
|
42
|
+
const buf = new Uint8Array(_byteLength(validLen, placeHoldersLen));
|
|
43
|
+
// If there are placeholders, only get up to the last complete 4 chars
|
|
44
|
+
const len = placeHoldersLen ? validLen - 4 : validLen;
|
|
45
|
+
let tmp;
|
|
46
|
+
let curByte = 0;
|
|
47
|
+
let i;
|
|
48
|
+
for (i = 0; i < len; i += 4) {
|
|
49
|
+
tmp = (revLookup[b64.charCodeAt(i)] << 18) |
|
|
50
|
+
(revLookup[b64.charCodeAt(i + 1)] << 12) |
|
|
51
|
+
(revLookup[b64.charCodeAt(i + 2)] << 6) |
|
|
52
|
+
revLookup[b64.charCodeAt(i + 3)];
|
|
53
|
+
buf[curByte++] = (tmp >> 16) & 0xff;
|
|
54
|
+
buf[curByte++] = (tmp >> 8) & 0xff;
|
|
55
|
+
buf[curByte++] = tmp & 0xff;
|
|
56
|
+
}
|
|
57
|
+
if (placeHoldersLen === 2) {
|
|
58
|
+
tmp = (revLookup[b64.charCodeAt(i)] << 2) |
|
|
59
|
+
(revLookup[b64.charCodeAt(i + 1)] >> 4);
|
|
60
|
+
buf[curByte++] = tmp & 0xff;
|
|
61
|
+
}
|
|
62
|
+
else if (placeHoldersLen === 1) {
|
|
63
|
+
tmp = (revLookup[b64.charCodeAt(i)] << 10) |
|
|
64
|
+
(revLookup[b64.charCodeAt(i + 1)] << 4) |
|
|
65
|
+
(revLookup[b64.charCodeAt(i + 2)] >> 2);
|
|
66
|
+
buf[curByte++] = (tmp >> 8) & 0xff;
|
|
67
|
+
buf[curByte++] = tmp & 0xff;
|
|
68
|
+
}
|
|
69
|
+
return buf;
|
|
70
|
+
},
|
|
71
|
+
fromUint8Array(buf) {
|
|
72
|
+
const maxChunkLength = 16383; // Must be multiple of 3
|
|
73
|
+
const len = buf.length;
|
|
74
|
+
const extraBytes = len % 3; // If we have 1 byte left, pad 2 bytes
|
|
75
|
+
const len2 = len - extraBytes;
|
|
76
|
+
const parts = new Array(Math.ceil(len2 / maxChunkLength) + (extraBytes ? 1 : 0));
|
|
77
|
+
let curChunk = 0;
|
|
78
|
+
let chunkEnd;
|
|
79
|
+
// Go through the array every three bytes, we'll deal with trailing stuff later
|
|
80
|
+
for (let i = 0; i < len2; i += maxChunkLength) {
|
|
81
|
+
chunkEnd = i + maxChunkLength;
|
|
82
|
+
parts[curChunk++] = encodeChunk(buf, i, chunkEnd > len2 ? len2 : chunkEnd);
|
|
83
|
+
}
|
|
84
|
+
let tmp;
|
|
85
|
+
// Pad the end with zeros, but make sure to not forget the extra bytes
|
|
86
|
+
if (extraBytes === 1) {
|
|
87
|
+
tmp = buf[len2];
|
|
88
|
+
parts[curChunk] = lookup[tmp >> 2] + lookup[(tmp << 4) & 0x3f];
|
|
89
|
+
if (!urlsafe)
|
|
90
|
+
parts[curChunk] += "==";
|
|
91
|
+
}
|
|
92
|
+
else if (extraBytes === 2) {
|
|
93
|
+
tmp = (buf[len2] << 8) | (buf[len2 + 1] & 0xff);
|
|
94
|
+
parts[curChunk] = lookup[tmp >> 10] +
|
|
95
|
+
lookup[(tmp >> 4) & 0x3f] +
|
|
96
|
+
lookup[(tmp << 2) & 0x3f];
|
|
97
|
+
if (!urlsafe)
|
|
98
|
+
parts[curChunk] += "=";
|
|
99
|
+
}
|
|
100
|
+
return parts.join("");
|
|
101
|
+
},
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
exports.init = init;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.fromUint8Array = exports.toUint8Array = exports.byteLength = void 0;
|
|
5
|
+
const base_js_1 = require("./base.js");
|
|
6
|
+
const lookup = [];
|
|
7
|
+
const revLookup = [];
|
|
8
|
+
const code = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_";
|
|
9
|
+
for (let i = 0, l = code.length; i < l; ++i) {
|
|
10
|
+
lookup[i] = code[i];
|
|
11
|
+
revLookup[code.charCodeAt(i)] = i;
|
|
12
|
+
}
|
|
13
|
+
_a = (0, base_js_1.init)(lookup, revLookup, true), exports.byteLength = _a.byteLength, exports.toUint8Array = _a.toUint8Array, exports.fromUint8Array = _a.fromUint8Array;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decode = exports.encode = void 0;
|
|
4
|
+
var mod_js_1 = require("../../../denopkg.com/chiefbiiko/std-encoding@v1.0.0/mod.js");
|
|
5
|
+
Object.defineProperty(exports, "encode", { enumerable: true, get: function () { return mod_js_1.encode; } });
|
|
6
|
+
Object.defineProperty(exports, "decode", { enumerable: true, get: function () { return mod_js_1.decode; } });
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.sha1 = exports.SHA1 = exports.BYTES = void 0;
|
|
4
|
+
const deps_js_1 = require("./deps.js");
|
|
5
|
+
function rotl(x, n) {
|
|
6
|
+
return (x << n) | (x >>> (32 - n));
|
|
7
|
+
}
|
|
8
|
+
/** Byte length of a SHA1 digest. */
|
|
9
|
+
exports.BYTES = 20;
|
|
10
|
+
/** A class representation of the SHA1 algorithm. */
|
|
11
|
+
class SHA1 {
|
|
12
|
+
/** Creates a SHA1 instance. */
|
|
13
|
+
constructor() {
|
|
14
|
+
Object.defineProperty(this, "hashSize", {
|
|
15
|
+
enumerable: true,
|
|
16
|
+
configurable: true,
|
|
17
|
+
writable: true,
|
|
18
|
+
value: exports.BYTES
|
|
19
|
+
});
|
|
20
|
+
Object.defineProperty(this, "_buf", {
|
|
21
|
+
enumerable: true,
|
|
22
|
+
configurable: true,
|
|
23
|
+
writable: true,
|
|
24
|
+
value: new Uint8Array(64)
|
|
25
|
+
});
|
|
26
|
+
Object.defineProperty(this, "_bufIdx", {
|
|
27
|
+
enumerable: true,
|
|
28
|
+
configurable: true,
|
|
29
|
+
writable: true,
|
|
30
|
+
value: void 0
|
|
31
|
+
});
|
|
32
|
+
Object.defineProperty(this, "_count", {
|
|
33
|
+
enumerable: true,
|
|
34
|
+
configurable: true,
|
|
35
|
+
writable: true,
|
|
36
|
+
value: void 0
|
|
37
|
+
});
|
|
38
|
+
Object.defineProperty(this, "_K", {
|
|
39
|
+
enumerable: true,
|
|
40
|
+
configurable: true,
|
|
41
|
+
writable: true,
|
|
42
|
+
value: new Uint32Array([0x5a827999, 0x6ed9eba1, 0x8f1bbcdc, 0xca62c1d6])
|
|
43
|
+
});
|
|
44
|
+
Object.defineProperty(this, "_H", {
|
|
45
|
+
enumerable: true,
|
|
46
|
+
configurable: true,
|
|
47
|
+
writable: true,
|
|
48
|
+
value: void 0
|
|
49
|
+
});
|
|
50
|
+
Object.defineProperty(this, "_finalized", {
|
|
51
|
+
enumerable: true,
|
|
52
|
+
configurable: true,
|
|
53
|
+
writable: true,
|
|
54
|
+
value: void 0
|
|
55
|
+
});
|
|
56
|
+
this.init();
|
|
57
|
+
}
|
|
58
|
+
/** Reduces the four input numbers to a single one. */
|
|
59
|
+
static F(t, b, c, d) {
|
|
60
|
+
if (t <= 19) {
|
|
61
|
+
return (b & c) | (~b & d);
|
|
62
|
+
}
|
|
63
|
+
else if (t <= 39) {
|
|
64
|
+
return b ^ c ^ d;
|
|
65
|
+
}
|
|
66
|
+
else if (t <= 59) {
|
|
67
|
+
return (b & c) | (b & d) | (c & d);
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
return b ^ c ^ d;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
/** Initializes a hash instance. */
|
|
74
|
+
init() {
|
|
75
|
+
// prettier-ignore
|
|
76
|
+
this._H = new Uint32Array([
|
|
77
|
+
0x67452301, 0xEFCDAB89, 0x98BADCFE, 0x10325476, 0xC3D2E1F0
|
|
78
|
+
]);
|
|
79
|
+
this._bufIdx = 0;
|
|
80
|
+
this._count = new Uint32Array(2);
|
|
81
|
+
this._buf.fill(0);
|
|
82
|
+
this._finalized = false;
|
|
83
|
+
return this;
|
|
84
|
+
}
|
|
85
|
+
/** Updates a hash with additional message data. */
|
|
86
|
+
update(msg, inputEncoding) {
|
|
87
|
+
if (msg === null) {
|
|
88
|
+
throw new TypeError("msg must be a string or Uint8Array.");
|
|
89
|
+
}
|
|
90
|
+
else if (typeof msg === "string") {
|
|
91
|
+
msg = (0, deps_js_1.encode)(msg, inputEncoding);
|
|
92
|
+
}
|
|
93
|
+
// process the msg as many times as possible, the rest is stored in the buffer
|
|
94
|
+
// message is processed in 512 bit (64 byte chunks)
|
|
95
|
+
for (let i = 0; i < msg.length; i++) {
|
|
96
|
+
this._buf[this._bufIdx++] = msg[i];
|
|
97
|
+
if (this._bufIdx === 64) {
|
|
98
|
+
this.transform();
|
|
99
|
+
this._bufIdx = 0;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
// counter update (number of message bits)
|
|
103
|
+
const c = this._count;
|
|
104
|
+
if ((c[0] += msg.length << 3) < msg.length << 3) {
|
|
105
|
+
c[1]++;
|
|
106
|
+
}
|
|
107
|
+
c[1] += msg.length >>> 29;
|
|
108
|
+
return this;
|
|
109
|
+
}
|
|
110
|
+
/** Finalizes a hash with additional message data. */
|
|
111
|
+
digest(outputEncoding) {
|
|
112
|
+
if (this._finalized) {
|
|
113
|
+
throw new Error("digest has already been called.");
|
|
114
|
+
}
|
|
115
|
+
this._finalized = true;
|
|
116
|
+
// append '1'
|
|
117
|
+
const b = this._buf;
|
|
118
|
+
let idx = this._bufIdx;
|
|
119
|
+
b[idx++] = 0x80;
|
|
120
|
+
// zeropad up to byte pos 56
|
|
121
|
+
while (idx !== 56) {
|
|
122
|
+
if (idx === 64) {
|
|
123
|
+
this.transform();
|
|
124
|
+
idx = 0;
|
|
125
|
+
}
|
|
126
|
+
b[idx++] = 0;
|
|
127
|
+
}
|
|
128
|
+
// append length in bits
|
|
129
|
+
const c = this._count;
|
|
130
|
+
b[56] = (c[1] >>> 24) & 0xff;
|
|
131
|
+
b[57] = (c[1] >>> 16) & 0xff;
|
|
132
|
+
b[58] = (c[1] >>> 8) & 0xff;
|
|
133
|
+
b[59] = (c[1] >>> 0) & 0xff;
|
|
134
|
+
b[60] = (c[0] >>> 24) & 0xff;
|
|
135
|
+
b[61] = (c[0] >>> 16) & 0xff;
|
|
136
|
+
b[62] = (c[0] >>> 8) & 0xff;
|
|
137
|
+
b[63] = (c[0] >>> 0) & 0xff;
|
|
138
|
+
this.transform();
|
|
139
|
+
// return the hash as byte array (20 bytes)
|
|
140
|
+
const hash = new Uint8Array(exports.BYTES);
|
|
141
|
+
for (let i = 0; i < 5; i++) {
|
|
142
|
+
hash[(i << 2) + 0] = (this._H[i] >>> 24) & 0xff;
|
|
143
|
+
hash[(i << 2) + 1] = (this._H[i] >>> 16) & 0xff;
|
|
144
|
+
hash[(i << 2) + 2] = (this._H[i] >>> 8) & 0xff;
|
|
145
|
+
hash[(i << 2) + 3] = (this._H[i] >>> 0) & 0xff;
|
|
146
|
+
}
|
|
147
|
+
// clear internal states and prepare for new hash
|
|
148
|
+
this.init();
|
|
149
|
+
return outputEncoding ? (0, deps_js_1.decode)(hash, outputEncoding) : hash;
|
|
150
|
+
}
|
|
151
|
+
/** Performs one transformation cycle. */
|
|
152
|
+
transform() {
|
|
153
|
+
const h = this._H;
|
|
154
|
+
let a = h[0];
|
|
155
|
+
let b = h[1];
|
|
156
|
+
let c = h[2];
|
|
157
|
+
let d = h[3];
|
|
158
|
+
let e = h[4];
|
|
159
|
+
// convert byte buffer to words
|
|
160
|
+
const w = new Uint32Array(80);
|
|
161
|
+
for (let i = 0; i < 16; i++) {
|
|
162
|
+
w[i] =
|
|
163
|
+
this._buf[(i << 2) + 3] |
|
|
164
|
+
(this._buf[(i << 2) + 2] << 8) |
|
|
165
|
+
(this._buf[(i << 2) + 1] << 16) |
|
|
166
|
+
(this._buf[i << 2] << 24);
|
|
167
|
+
}
|
|
168
|
+
for (let t = 0; t < 80; t++) {
|
|
169
|
+
if (t >= 16) {
|
|
170
|
+
w[t] = rotl(w[t - 3] ^ w[t - 8] ^ w[t - 14] ^ w[t - 16], 1);
|
|
171
|
+
}
|
|
172
|
+
const tmp = (rotl(a, 5) +
|
|
173
|
+
SHA1.F(t, b, c, d) +
|
|
174
|
+
e +
|
|
175
|
+
w[t] +
|
|
176
|
+
this._K[Math.floor(t / 20)]) |
|
|
177
|
+
0;
|
|
178
|
+
e = d;
|
|
179
|
+
d = c;
|
|
180
|
+
c = rotl(b, 30);
|
|
181
|
+
b = a;
|
|
182
|
+
a = tmp;
|
|
183
|
+
}
|
|
184
|
+
h[0] = (h[0] + a) | 0;
|
|
185
|
+
h[1] = (h[1] + b) | 0;
|
|
186
|
+
h[2] = (h[2] + c) | 0;
|
|
187
|
+
h[3] = (h[3] + d) | 0;
|
|
188
|
+
h[4] = (h[4] + e) | 0;
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
exports.SHA1 = SHA1;
|
|
192
|
+
/** Generates a SHA1 hash of the input data. */
|
|
193
|
+
function sha1(msg, inputEncoding, outputEncoding) {
|
|
194
|
+
return new SHA1().update(msg, inputEncoding).digest(outputEncoding);
|
|
195
|
+
}
|
|
196
|
+
exports.sha1 = sha1;
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.encode = exports.decode = void 0;
|
|
4
|
+
const base64url_js_1 = require("../../../deno.land/x/base64@v0.2.1/base64url.js");
|
|
5
|
+
const decoder = new TextDecoder();
|
|
6
|
+
const encoder = new TextEncoder();
|
|
7
|
+
/** Serializes a Uint8Array to a hexadecimal string. */
|
|
8
|
+
function toHexString(buf) {
|
|
9
|
+
return buf.reduce((hex, byte) => `${hex}${byte < 16 ? "0" : ""}${byte.toString(16)}`, "");
|
|
10
|
+
}
|
|
11
|
+
/** Deserializes a Uint8Array from a hexadecimal string. */
|
|
12
|
+
function fromHexString(hex) {
|
|
13
|
+
const len = hex.length;
|
|
14
|
+
if (len % 2 || !/^[0-9a-fA-F]+$/.test(hex)) {
|
|
15
|
+
throw new TypeError("Invalid hex string.");
|
|
16
|
+
}
|
|
17
|
+
hex = hex.toLowerCase();
|
|
18
|
+
const buf = new Uint8Array(Math.floor(len / 2));
|
|
19
|
+
const end = len / 2;
|
|
20
|
+
for (let i = 0; i < end; ++i) {
|
|
21
|
+
buf[i] = parseInt(hex.substr(i * 2, 2), 16);
|
|
22
|
+
}
|
|
23
|
+
return buf;
|
|
24
|
+
}
|
|
25
|
+
/** Decodes a Uint8Array to utf8-, base64-, or hex-encoded string. */
|
|
26
|
+
function decode(buf, encoding = "utf8") {
|
|
27
|
+
if (/^utf-?8$/i.test(encoding)) {
|
|
28
|
+
return decoder.decode(buf);
|
|
29
|
+
}
|
|
30
|
+
else if (/^base64$/i.test(encoding)) {
|
|
31
|
+
return (0, base64url_js_1.fromUint8Array)(buf);
|
|
32
|
+
}
|
|
33
|
+
else if (/^hex(?:adecimal)?$/i.test(encoding)) {
|
|
34
|
+
return toHexString(buf);
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
throw new TypeError("Unsupported string encoding.");
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
exports.decode = decode;
|
|
41
|
+
function encode(str, encoding = "utf8") {
|
|
42
|
+
if (/^utf-?8$/i.test(encoding)) {
|
|
43
|
+
return encoder.encode(str);
|
|
44
|
+
}
|
|
45
|
+
else if (/^base64$/i.test(encoding)) {
|
|
46
|
+
return (0, base64url_js_1.toUint8Array)(str);
|
|
47
|
+
}
|
|
48
|
+
else if (/^hex(?:adecimal)?$/i.test(encoding)) {
|
|
49
|
+
return fromHexString(str);
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
throw new TypeError("Unsupported string encoding.");
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
exports.encode = encode;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.LPosCommand = void 0;
|
|
4
|
+
const command_js_1 = require("./command.js");
|
|
5
|
+
/**
|
|
6
|
+
* @see https://redis.io/commands/lpos
|
|
7
|
+
*/
|
|
8
|
+
class LPosCommand extends command_js_1.Command {
|
|
9
|
+
constructor(cmd, opts) {
|
|
10
|
+
const args = ["lpos", cmd[0], cmd[1]];
|
|
11
|
+
if (typeof cmd[2]?.rank === "number") {
|
|
12
|
+
args.push("rank", cmd[2].rank);
|
|
13
|
+
}
|
|
14
|
+
if (typeof cmd[2]?.count === "number") {
|
|
15
|
+
args.push("count", cmd[2].count);
|
|
16
|
+
}
|
|
17
|
+
if (typeof cmd[2]?.maxLen === "number") {
|
|
18
|
+
args.push("maxLen", cmd[2].maxLen);
|
|
19
|
+
}
|
|
20
|
+
super(args, opts);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
exports.LPosCommand = LPosCommand;
|
|
@@ -58,6 +58,7 @@ __exportStar(require("./lindex.js"), exports);
|
|
|
58
58
|
__exportStar(require("./linsert.js"), exports);
|
|
59
59
|
__exportStar(require("./llen.js"), exports);
|
|
60
60
|
__exportStar(require("./lpop.js"), exports);
|
|
61
|
+
__exportStar(require("./lpos.js"), exports);
|
|
61
62
|
__exportStar(require("./lpush.js"), exports);
|
|
62
63
|
__exportStar(require("./lpushx.js"), exports);
|
|
63
64
|
__exportStar(require("./lrange.js"), exports);
|
|
@@ -8,16 +8,7 @@ const command_js_1 = require("./command.js");
|
|
|
8
8
|
class ScriptExistsCommand extends command_js_1.Command {
|
|
9
9
|
constructor(hashes, opts) {
|
|
10
10
|
super(["script", "exists", ...hashes], {
|
|
11
|
-
deserialize: (result) =>
|
|
12
|
-
/**
|
|
13
|
-
* This isn't very pretty but it does the job.
|
|
14
|
-
* The user facing api is clean and will return a single `string` if they provided
|
|
15
|
-
* a single script hash, and an array of strings of the same length when given an
|
|
16
|
-
* array of hashes.
|
|
17
|
-
*/
|
|
18
|
-
const parsed = result;
|
|
19
|
-
return parsed.length === 1 ? parsed[0] : parsed;
|
|
20
|
-
},
|
|
11
|
+
deserialize: (result) => result,
|
|
21
12
|
...opts,
|
|
22
13
|
});
|
|
23
14
|
}
|
|
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.SDiffStoreCommand = void 0;
|
|
4
4
|
const command_js_1 = require("./command.js");
|
|
5
5
|
/**
|
|
6
|
-
* @see https://redis.io/commands/
|
|
6
|
+
* @see https://redis.io/commands/sdiffstore
|
|
7
7
|
*/
|
|
8
8
|
class SDiffStoreCommand extends command_js_1.Command {
|
|
9
9
|
constructor(cmd, opts) {
|
|
@@ -9,17 +9,29 @@ class SetCommand extends command_js_1.Command {
|
|
|
9
9
|
constructor([key, value, opts], cmdOpts) {
|
|
10
10
|
const command = ["set", key, value];
|
|
11
11
|
if (opts) {
|
|
12
|
+
if ("nx" in opts && opts.nx) {
|
|
13
|
+
command.push("nx");
|
|
14
|
+
}
|
|
15
|
+
else if ("xx" in opts && opts.xx) {
|
|
16
|
+
command.push("xx");
|
|
17
|
+
}
|
|
18
|
+
if ("get" in opts && opts.get) {
|
|
19
|
+
command.push("get");
|
|
20
|
+
}
|
|
12
21
|
if ("ex" in opts && typeof opts.ex === "number") {
|
|
13
22
|
command.push("ex", opts.ex);
|
|
14
23
|
}
|
|
15
24
|
else if ("px" in opts && typeof opts.px === "number") {
|
|
16
25
|
command.push("px", opts.px);
|
|
17
26
|
}
|
|
18
|
-
if ("
|
|
19
|
-
command.push("
|
|
27
|
+
else if ("exat" in opts && typeof opts.exat === "number") {
|
|
28
|
+
command.push("exat", opts.exat);
|
|
20
29
|
}
|
|
21
|
-
else if ("
|
|
22
|
-
command.push("
|
|
30
|
+
else if ("pxat" in opts && typeof opts.pxat === "number") {
|
|
31
|
+
command.push("pxat", opts.pxat);
|
|
32
|
+
}
|
|
33
|
+
else if ("keepTtl" in opts && opts.keepTtl) {
|
|
34
|
+
command.push("keepTtl", opts.keepTtl);
|
|
23
35
|
}
|
|
24
36
|
}
|
|
25
37
|
super(command, cmdOpts);
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ZMScoreCommand = void 0;
|
|
4
|
+
const command_js_1 = require("./command.js");
|
|
5
|
+
/**
|
|
6
|
+
* @see https://redis.io/commands/zmscore
|
|
7
|
+
*/
|
|
8
|
+
class ZMScoreCommand extends command_js_1.Command {
|
|
9
|
+
constructor(cmd, opts) {
|
|
10
|
+
const [key, members] = cmd;
|
|
11
|
+
super(["zmscore", key, ...members], opts);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
exports.ZMScoreCommand = ZMScoreCommand;
|
|
@@ -15,6 +15,12 @@ class ZRangeCommand extends command_js_1.Command {
|
|
|
15
15
|
if (opts?.byLex) {
|
|
16
16
|
command.push("bylex");
|
|
17
17
|
}
|
|
18
|
+
if (opts?.rev) {
|
|
19
|
+
command.push("rev");
|
|
20
|
+
}
|
|
21
|
+
if (typeof opts?.count !== "undefined" && typeof opts?.offset !== "undefined") {
|
|
22
|
+
command.push("limit", opts.offset, opts.count);
|
|
23
|
+
}
|
|
18
24
|
if (opts?.withScores) {
|
|
19
25
|
command.push("withscores");
|
|
20
26
|
}
|