@upstash/redis 0.0.0-ci.efe72030 → 0.0.0-ci.f0c37f55-20231010

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.
Files changed (154) hide show
  1. package/README.md +20 -18
  2. package/esm/deps/deno.land/x/base64@v0.2.1/base.js +100 -0
  3. package/esm/deps/deno.land/x/base64@v0.2.1/base64url.js +9 -0
  4. package/esm/deps/deno.land/x/sha1@v1.0.3/deps.js +1 -0
  5. package/esm/deps/deno.land/x/sha1@v1.0.3/mod.js +191 -0
  6. package/esm/deps/denopkg.com/chiefbiiko/std-encoding@v1.0.0/mod.js +50 -0
  7. package/esm/pkg/commands/command.js +12 -3
  8. package/esm/pkg/commands/getdel.js +9 -0
  9. package/esm/pkg/commands/hgetall.js +0 -4
  10. package/esm/pkg/commands/hrandfield.js +39 -0
  11. package/esm/pkg/commands/json_arrappend.js +9 -0
  12. package/esm/pkg/commands/json_arrindex.js +9 -0
  13. package/esm/pkg/commands/json_arrinsert.js +9 -0
  14. package/esm/pkg/commands/json_arrlen.js +9 -0
  15. package/esm/pkg/commands/json_arrpop.js +9 -0
  16. package/esm/pkg/commands/json_arrtrim.js +12 -0
  17. package/esm/pkg/commands/json_clear.js +9 -0
  18. package/esm/pkg/commands/json_del.js +9 -0
  19. package/esm/pkg/commands/json_forget.js +9 -0
  20. package/esm/pkg/commands/json_get.js +30 -0
  21. package/esm/pkg/commands/json_mget.js +9 -0
  22. package/esm/pkg/commands/json_numincrby.js +9 -0
  23. package/esm/pkg/commands/json_nummultby.js +9 -0
  24. package/esm/pkg/commands/json_objkeys.js +9 -0
  25. package/esm/pkg/commands/json_objlen.js +9 -0
  26. package/esm/pkg/commands/json_resp.js +9 -0
  27. package/esm/pkg/commands/json_set.js +18 -0
  28. package/esm/pkg/commands/json_strappend.js +9 -0
  29. package/esm/pkg/commands/json_strlen.js +9 -0
  30. package/esm/pkg/commands/json_toggle.js +9 -0
  31. package/esm/pkg/commands/json_type.js +9 -0
  32. package/esm/pkg/commands/lmove.js +9 -0
  33. package/esm/pkg/commands/mod.js +27 -0
  34. package/esm/pkg/commands/scan.js +3 -0
  35. package/esm/pkg/commands/set.js +16 -4
  36. package/esm/pkg/commands/smismember.js +9 -0
  37. package/esm/pkg/commands/xadd.js +26 -0
  38. package/esm/pkg/commands/xrange.js +36 -0
  39. package/esm/pkg/commands/zdiffstore.js +9 -0
  40. package/esm/pkg/commands/zmscore.js +10 -0
  41. package/esm/pkg/http.js +100 -3
  42. package/esm/pkg/pipeline.js +170 -12
  43. package/esm/pkg/redis.js +220 -2
  44. package/esm/pkg/script.js +77 -0
  45. package/esm/platforms/cloudflare.js +10 -2
  46. package/esm/platforms/fastly.js +6 -0
  47. package/esm/platforms/node_with_fetch.js +26 -1
  48. package/esm/platforms/nodejs.js +24 -1
  49. package/esm/version.js +1 -0
  50. package/package.json +53 -58
  51. package/script/deps/deno.land/x/base64@v0.2.1/base.js +104 -0
  52. package/script/deps/deno.land/x/base64@v0.2.1/base64url.js +13 -0
  53. package/script/deps/deno.land/x/sha1@v1.0.3/deps.js +6 -0
  54. package/script/deps/deno.land/x/sha1@v1.0.3/mod.js +196 -0
  55. package/script/deps/denopkg.com/chiefbiiko/std-encoding@v1.0.0/mod.js +55 -0
  56. package/script/pkg/commands/command.js +12 -3
  57. package/script/pkg/commands/getdel.js +13 -0
  58. package/script/pkg/commands/hgetall.js +0 -4
  59. package/script/pkg/commands/hrandfield.js +43 -0
  60. package/script/pkg/commands/json_arrappend.js +13 -0
  61. package/script/pkg/commands/json_arrindex.js +13 -0
  62. package/script/pkg/commands/json_arrinsert.js +13 -0
  63. package/script/pkg/commands/json_arrlen.js +13 -0
  64. package/script/pkg/commands/json_arrpop.js +13 -0
  65. package/script/pkg/commands/json_arrtrim.js +16 -0
  66. package/script/pkg/commands/json_clear.js +13 -0
  67. package/script/pkg/commands/json_del.js +13 -0
  68. package/script/pkg/commands/json_forget.js +13 -0
  69. package/script/pkg/commands/json_get.js +34 -0
  70. package/script/pkg/commands/json_mget.js +13 -0
  71. package/script/pkg/commands/json_numincrby.js +13 -0
  72. package/script/pkg/commands/json_nummultby.js +13 -0
  73. package/script/pkg/commands/json_objkeys.js +13 -0
  74. package/script/pkg/commands/json_objlen.js +13 -0
  75. package/script/pkg/commands/json_resp.js +13 -0
  76. package/script/pkg/commands/json_set.js +22 -0
  77. package/script/pkg/commands/json_strappend.js +13 -0
  78. package/script/pkg/commands/json_strlen.js +13 -0
  79. package/script/pkg/commands/json_toggle.js +13 -0
  80. package/script/pkg/commands/json_type.js +13 -0
  81. package/script/pkg/commands/lmove.js +13 -0
  82. package/script/pkg/commands/mod.js +27 -0
  83. package/script/pkg/commands/scan.js +3 -0
  84. package/script/pkg/commands/set.js +16 -4
  85. package/script/pkg/commands/smismember.js +13 -0
  86. package/script/pkg/commands/xadd.js +30 -0
  87. package/script/pkg/commands/xrange.js +40 -0
  88. package/script/pkg/commands/zdiffstore.js +13 -0
  89. package/script/pkg/commands/zmscore.js +14 -0
  90. package/script/pkg/http.js +100 -3
  91. package/script/pkg/pipeline.js +169 -11
  92. package/script/pkg/redis.js +219 -1
  93. package/script/pkg/script.js +81 -0
  94. package/script/platforms/cloudflare.js +10 -2
  95. package/script/platforms/fastly.js +6 -0
  96. package/script/platforms/node_with_fetch.js +26 -1
  97. package/script/platforms/nodejs.js +24 -1
  98. package/script/version.js +4 -0
  99. package/types/deps/deno.land/x/base64@v0.2.1/base.d.ts +5 -0
  100. package/types/deps/deno.land/x/base64@v0.2.1/base64url.d.ts +1 -0
  101. package/types/deps/deno.land/x/sha1@v1.0.3/deps.d.ts +1 -0
  102. package/types/deps/deno.land/x/sha1@v1.0.3/mod.d.ts +26 -0
  103. package/types/deps/denopkg.com/chiefbiiko/std-encoding@v1.0.0/mod.d.ts +3 -0
  104. package/types/pkg/commands/command.d.ts +5 -5
  105. package/types/pkg/commands/getdel.d.ts +7 -0
  106. package/types/pkg/commands/hdel.d.ts +1 -1
  107. package/types/pkg/commands/hrandfield.d.ts +9 -0
  108. package/types/pkg/commands/json_arrappend.d.ts +7 -0
  109. package/types/pkg/commands/json_arrindex.d.ts +13 -0
  110. package/types/pkg/commands/json_arrinsert.d.ts +7 -0
  111. package/types/pkg/commands/json_arrlen.d.ts +7 -0
  112. package/types/pkg/commands/json_arrpop.d.ts +7 -0
  113. package/types/pkg/commands/json_arrtrim.d.ts +7 -0
  114. package/types/pkg/commands/json_clear.d.ts +7 -0
  115. package/types/pkg/commands/json_del.d.ts +7 -0
  116. package/types/pkg/commands/json_forget.d.ts +7 -0
  117. package/types/pkg/commands/json_get.d.ts +15 -0
  118. package/types/pkg/commands/json_mget.d.ts +7 -0
  119. package/types/pkg/commands/json_numincrby.d.ts +7 -0
  120. package/types/pkg/commands/json_nummultby.d.ts +7 -0
  121. package/types/pkg/commands/json_objkeys.d.ts +7 -0
  122. package/types/pkg/commands/json_objlen.d.ts +7 -0
  123. package/types/pkg/commands/json_resp.d.ts +7 -0
  124. package/types/pkg/commands/json_set.d.ts +18 -0
  125. package/types/pkg/commands/json_strappend.d.ts +7 -0
  126. package/types/pkg/commands/json_strlen.d.ts +7 -0
  127. package/types/pkg/commands/json_toggle.d.ts +7 -0
  128. package/types/pkg/commands/json_type.d.ts +7 -0
  129. package/types/pkg/commands/lmove.d.ts +12 -0
  130. package/types/pkg/commands/mod.d.ts +27 -0
  131. package/types/pkg/commands/scan.d.ts +2 -1
  132. package/types/pkg/commands/script_flush.d.ts +1 -1
  133. package/types/pkg/commands/set.d.ts +31 -2
  134. package/types/pkg/commands/smembers.d.ts +2 -2
  135. package/types/pkg/commands/smismember.d.ts +7 -0
  136. package/types/pkg/commands/type.d.ts +1 -1
  137. package/types/pkg/commands/xadd.d.ts +31 -0
  138. package/types/pkg/commands/xrange.d.ts +9 -0
  139. package/types/pkg/commands/zadd.d.ts +3 -3
  140. package/types/pkg/commands/zdiffstore.d.ts +7 -0
  141. package/types/pkg/commands/zinterstore.d.ts +1 -1
  142. package/types/pkg/commands/zmscore.d.ts +7 -0
  143. package/types/pkg/commands/zrange.d.ts +1 -1
  144. package/types/pkg/commands/zunionstore.d.ts +1 -1
  145. package/types/pkg/http.d.ts +48 -7
  146. package/types/pkg/pipeline.d.ts +255 -125
  147. package/types/pkg/redis.d.ts +169 -13
  148. package/types/pkg/script.d.ts +42 -0
  149. package/types/pkg/types.d.ts +27 -1
  150. package/types/platforms/cloudflare.d.ts +9 -8
  151. package/types/platforms/fastly.d.ts +3 -7
  152. package/types/platforms/node_with_fetch.d.ts +3 -22
  153. package/types/platforms/nodejs.d.ts +4 -7
  154. package/types/version.d.ts +1 -0
@@ -1,21 +1,17 @@
1
- import { CommandOptions, DelCommand, ExistsCommand, FlushAllCommand, MGetCommand, PingCommand, ScoreMember, ScriptExistsCommand, SetCommandOptions, TouchCommand, UnlinkCommand, ZAddCommandOptions, ZAddCommandOptionsWithIncr, ZRangeCommandOptions } from "./commands/mod.js";
1
+ import { CommandOptions, DelCommand, ExistsCommand, FlushAllCommand, JsonGetCommand, MGetCommand, PingCommand, ScoreMember, ScriptExistsCommand, SetCommandOptions, TouchCommand, UnlinkCommand, ZAddCommandOptions, ZAddCommandOptionsWithIncr, ZRangeCommandOptions } from "./commands/mod.js";
2
2
  import { Requester, UpstashRequest, UpstashResponse } from "./http.js";
3
3
  import { Pipeline } from "./pipeline.js";
4
4
  import type { CommandArgs } from "./types.js";
5
- export declare type RedisOptions = {
6
- /**
7
- * Automatically try to deserialize the returned data from upstash using `JSON.deserialize`
8
- *
9
- * @default true
10
- */
11
- automaticDeserialization?: boolean;
12
- };
5
+ import { Script } from "./script.js";
6
+ import type { RedisOptions, Telemetry } from "./types.js";
7
+ export type { RedisOptions } from "./types.js";
13
8
  /**
14
9
  * Serverless redis client for upstash.
15
10
  */
16
11
  export declare class Redis {
17
12
  protected client: Requester;
18
13
  protected opts?: CommandOptions<any, any>;
14
+ protected enableTelemetry: boolean;
19
15
  /**
20
16
  * Create a new redis client
21
17
  *
@@ -28,16 +24,123 @@ export declare class Redis {
28
24
  * ```
29
25
  */
30
26
  constructor(client: Requester, opts?: RedisOptions);
27
+ get json(): {
28
+ /**
29
+ * @see https://redis.io/commands/json.arrappend
30
+ */
31
+ arrappend: (key: string, path: string, ...values: unknown[]) => Promise<(number | null)[]>;
32
+ /**
33
+ * @see https://redis.io/commands/json.arrindex
34
+ */
35
+ arrindex: (key: string, path: string, value: unknown, start?: number | undefined, stop?: number | undefined) => Promise<(number | null)[]>;
36
+ /**
37
+ * @see https://redis.io/commands/json.arrinsert
38
+ */
39
+ arrinsert: (key: string, path: string, index: number, ...values: unknown[]) => Promise<(number | null)[]>;
40
+ /**
41
+ * @see https://redis.io/commands/json.arrlen
42
+ */
43
+ arrlen: (key: string, path?: string | undefined) => Promise<(number | null)[]>;
44
+ /**
45
+ * @see https://redis.io/commands/json.arrpop
46
+ */
47
+ arrpop: (key: string, path?: string | undefined, index?: number | undefined) => Promise<unknown[]>;
48
+ /**
49
+ * @see https://redis.io/commands/json.arrtrim
50
+ */
51
+ arrtrim: (key: string, path?: string | undefined, start?: number | undefined, stop?: number | undefined) => Promise<(number | null)[]>;
52
+ /**
53
+ * @see https://redis.io/commands/json.clear
54
+ */
55
+ clear: (key: string, path?: string | undefined) => Promise<number>;
56
+ /**
57
+ * @see https://redis.io/commands/json.del
58
+ */
59
+ del: (key: string, path?: string | undefined) => Promise<number>;
60
+ /**
61
+ * @see https://redis.io/commands/json.forget
62
+ */
63
+ forget: (key: string, path?: string | undefined) => Promise<number>;
64
+ /**
65
+ * @see https://redis.io/commands/json.get
66
+ */
67
+ get: (...args: CommandArgs<typeof JsonGetCommand>) => Promise<any>;
68
+ /**
69
+ * @see https://redis.io/commands/json.mget
70
+ */
71
+ mget: (keys: string[], path: string) => Promise<any>;
72
+ /**
73
+ * @see https://redis.io/commands/json.numincrby
74
+ */
75
+ numincrby: (key: string, path: string, value: number) => Promise<(number | null)[]>;
76
+ /**
77
+ * @see https://redis.io/commands/json.nummultby
78
+ */
79
+ nummultby: (key: string, path: string, value: number) => Promise<(number | null)[]>;
80
+ /**
81
+ * @see https://redis.io/commands/json.objkeys
82
+ */
83
+ objkeys: (key: string, path?: string | undefined) => Promise<(string[] | null)[]>;
84
+ /**
85
+ * @see https://redis.io/commands/json.objlen
86
+ */
87
+ objlen: (key: string, path?: string | undefined) => Promise<(number | null)[]>;
88
+ /**
89
+ * @see https://redis.io/commands/json.resp
90
+ */
91
+ resp: (key: string, path?: string | undefined) => Promise<any>;
92
+ /**
93
+ * @see https://redis.io/commands/json.set
94
+ */
95
+ set: (key: string, path: string, value: string | number | boolean | Record<string, unknown> | (string | number | boolean | Record<string, unknown>)[], opts?: {
96
+ nx: true;
97
+ xx?: undefined;
98
+ } | {
99
+ nx?: undefined;
100
+ xx: true;
101
+ } | undefined) => Promise<"OK" | null>;
102
+ /**
103
+ * @see https://redis.io/commands/json.strappend
104
+ */
105
+ strappend: (key: string, path: string, value: string) => Promise<(number | null)[]>;
106
+ /**
107
+ * @see https://redis.io/commands/json.strlen
108
+ */
109
+ strlen: (key: string, path?: string | undefined) => Promise<(number | null)[]>;
110
+ /**
111
+ * @see https://redis.io/commands/json.toggle
112
+ */
113
+ toggle: (key: string, path: string) => Promise<number[]>;
114
+ /**
115
+ * @see https://redis.io/commands/json.type
116
+ */
117
+ type: (key: string, path?: string | undefined) => Promise<string[]>;
118
+ };
31
119
  /**
32
120
  * Wrap a new middleware around the HTTP client.
33
121
  */
34
122
  use: <TResult = unknown>(middleware: (r: UpstashRequest, next: <TResult_1 = unknown>(req: UpstashRequest) => Promise<UpstashResponse<TResult_1>>) => Promise<UpstashResponse<TResult>>) => void;
123
+ /**
124
+ * Technically this is not private, we can hide it from intellisense by doing this
125
+ */
126
+ protected addTelemetry: (telemetry: Telemetry) => void;
127
+ createScript(script: string): Script;
35
128
  /**
36
129
  * Create a new pipeline that allows you to send requests in bulk.
37
130
  *
38
131
  * @see {@link Pipeline}
39
132
  */
40
- pipeline: () => Pipeline;
133
+ pipeline: () => Pipeline<[]>;
134
+ /**
135
+ * Create a new transaction to allow executing multiple steps atomically.
136
+ *
137
+ * All the commands in a transaction are serialized and executed sequentially. A request sent by
138
+ * another client will never be served in the middle of the execution of a Redis Transaction. This
139
+ * guarantees that the commands are executed as a single isolated operation.
140
+ *
141
+ * @see {@link Pipeline}
142
+ */
143
+ multi: () => Pipeline<[]>;
41
144
  /**
42
145
  * @see https://redis.io/commands/append
43
146
  */
@@ -115,6 +218,10 @@ export declare class Redis {
115
218
  * @see https://redis.io/commands/getbit
116
219
  */
117
220
  getbit: (key: string, offset: number) => Promise<0 | 1>;
221
+ /**
222
+ * @see https://redis.io/commands/getdel
223
+ */
224
+ getdel: <TData>(key: string) => Promise<TData | null>;
118
225
  /**
119
226
  * @see https://redis.io/commands/getrange
120
227
  */
@@ -126,7 +233,7 @@ export declare class Redis {
126
233
  /**
127
234
  * @see https://redis.io/commands/hdel
128
235
  */
129
- hdel: (key: string, field: string) => Promise<0 | 1>;
236
+ hdel: (key: string, ...fields: string[]) => Promise<0 | 1>;
130
237
  /**
131
238
  * @see https://redis.io/commands/hexists
132
239
  */
@@ -165,6 +272,14 @@ export declare class Redis {
165
272
  hmset: <TData>(key: string, kv: {
166
273
  [field: string]: TData;
167
274
  }) => Promise<"OK">;
275
+ /**
276
+ * @see https://redis.io/commands/hrandfield
277
+ */
278
+ hrandfield: {
279
+ (key: string): Promise<string>;
280
+ (key: string, count: number): Promise<string[]>;
281
+ <TData extends Record<string, unknown>>(key: string, count: number, withValues: boolean): Promise<Partial<TData>>;
282
+ };
168
283
  /**
169
284
  * @see https://redis.io/commands/hscan
170
285
  */
@@ -215,6 +330,10 @@ export declare class Redis {
215
330
  * @see https://redis.io/commands/llen
216
331
  */
217
332
  llen: (key: string) => Promise<number>;
333
+ /**
334
+ * @see https://redis.io/commands/lmove
335
+ */
336
+ lmove: <TData = string>(source: string, destination: string, whereFrom: "left" | "right", whereTo: "left" | "right") => Promise<TData>;
218
337
  /**
219
338
  * @see https://redis.io/commands/lpop
220
339
  */
@@ -354,7 +473,7 @@ export declare class Redis {
354
473
  /**
355
474
  * @see https://redis.io/commands/set
356
475
  */
357
- set: <TData>(key: string, value: TData, opts?: SetCommandOptions | undefined) => Promise<TData>;
476
+ set: <TData>(key: string, value: TData, opts?: SetCommandOptions) => Promise<"OK" | TData | null>;
358
477
  /**
359
478
  * @see https://redis.io/commands/setbit
360
479
  */
@@ -383,10 +502,14 @@ export declare class Redis {
383
502
  * @see https://redis.io/commands/sismember
384
503
  */
385
504
  sismember: <TData>(key: string, member: TData) => Promise<0 | 1>;
505
+ /**
506
+ * @see https://redis.io/commands/smismember
507
+ */
508
+ smismember: <TMembers extends unknown[]>(key: string, members: TMembers) => Promise<(0 | 1)[]>;
386
509
  /**
387
510
  * @see https://redis.io/commands/smembers
388
511
  */
389
- smembers: (key: string) => Promise<string[]>;
512
+ smembers: <TData extends unknown[] = string[]>(key: string) => Promise<TData>;
390
513
  /**
391
514
  * @see https://redis.io/commands/smove
392
515
  */
@@ -439,6 +562,31 @@ export declare class Redis {
439
562
  * @see https://redis.io/commands/unlink
440
563
  */
441
564
  unlink: (...args: CommandArgs<typeof UnlinkCommand>) => Promise<number>;
565
+ /**
566
+ * @see https://redis.io/commands/xadd
567
+ */
568
+ xadd: (key: string, id: string, entries: {
569
+ [field: string]: unknown;
570
+ }, opts?: {
571
+ nomkStream?: boolean | undefined;
572
+ trim?: (({
573
+ type: "MAXLEN" | "maxlen";
574
+ threshold: number;
575
+ } | {
576
+ type: "MINID" | "minid";
577
+ threshold: string;
578
+ }) & ({
579
+ comparison: "~";
580
+ limit?: number | undefined;
581
+ } | {
582
+ comparison: "=";
583
+ limit?: undefined;
584
+ })) | undefined;
585
+ } | undefined) => Promise<string>;
586
+ /**
587
+ * @see https://redis.io/commands/xrange
588
+ */
589
+ xrange: (key: string, start: string, end: string, count?: number | undefined) => Promise<Record<string, Record<string, unknown>>>;
442
590
  /**
443
591
  * @see https://redis.io/commands/zadd
444
592
  */
@@ -451,6 +599,10 @@ export declare class Redis {
451
599
  * @see https://redis.io/commands/zcount
452
600
  */
453
601
  zcount: (key: string, min: string | number, max: string | number) => Promise<number>;
602
+ /**
603
+ * @see https://redis.io/commands/zdiffstore
604
+ */
605
+ zdiffstore: (destination: string, numkeys: number, ...keys: string[]) => Promise<number>;
454
606
  /**
455
607
  * @see https://redis.io/commands/zincrby
456
608
  */
@@ -463,6 +615,10 @@ export declare class Redis {
463
615
  * @see https://redis.io/commands/zlexcount
464
616
  */
465
617
  zlexcount: (key: string, min: string, max: string) => Promise<number>;
618
+ /**
619
+ * @see https://redis.io/commands/zmscore
620
+ */
621
+ zmscore: (key: string, members: unknown[]) => Promise<number[] | null>;
466
622
  /**
467
623
  * @see https://redis.io/commands/zpopmax
468
624
  */
@@ -0,0 +1,42 @@
1
+ import { Redis } from "./redis.js";
2
+ /**
3
+ * Creates a new script.
4
+ *
5
+ * Scripts offer the ability to optimistically try to execute a script without having to send the
6
+ * entire script to the server. If the script is loaded on the server, it tries again by sending
7
+ * the entire script. Afterwards, the script is cached on the server.
8
+ *
9
+ * @example
10
+ * ```ts
11
+ * const redis = new Redis({...})
12
+ *
13
+ * const script = redis.createScript<string>("return ARGV[1];")
14
+ * const arg1 = await script.eval([], ["Hello World"])
15
+ * assertEquals(arg1, "Hello World")
16
+ * ```
17
+ */
18
+ export declare class Script<TResult = unknown> {
19
+ readonly script: string;
20
+ readonly sha1: string;
21
+ private readonly redis;
22
+ constructor(redis: Redis, script: string);
23
+ /**
24
+ * Send an `EVAL` command to redis.
25
+ */
26
+ eval(keys: string[], args: string[]): Promise<TResult>;
27
+ /**
28
+ * Calculates the sha1 hash of the script and then calls `EVALSHA`.
29
+ */
30
+ evalsha(keys: string[], args: string[]): Promise<TResult>;
31
+ /**
32
+ * Optimistically try to run `EVALSHA` first.
33
+ * If the script is not loaded in redis, it will fall back and try again with `EVAL`.
34
+ *
35
+ * Following calls will be able to use the cached script
36
+ */
37
+ exec(keys: string[], args: string[]): Promise<TResult>;
38
+ /**
39
+ * Compute the sha1 hash of the script and return its hex representation.
40
+ */
41
+ private digest;
42
+ }
@@ -1 +1,27 @@
1
- export declare type CommandArgs<TCommand extends new (...args: any) => any> = ConstructorParameters<TCommand>[0];
1
+ export type CommandArgs<TCommand extends new (...args: any) => any> = ConstructorParameters<TCommand>[0];
2
+ export type Telemetry = {
3
+ /**
4
+ * Upstash-Telemetry-Sdk
5
+ * @example @upstash/redis@v1.1.1
6
+ */
7
+ sdk?: string;
8
+ /**
9
+ * Upstash-Telemetry-Platform
10
+ * @example cloudflare
11
+ */
12
+ platform?: string;
13
+ /**
14
+ * Upstash-Telemetry-Runtime
15
+ * @example node@v18
16
+ */
17
+ runtime?: string;
18
+ };
19
+ export type RedisOptions = {
20
+ /**
21
+ * Automatically try to deserialize the returned data from upstash using `JSON.deserialize`
22
+ *
23
+ * @default true
24
+ */
25
+ automaticDeserialization?: boolean;
26
+ enableTelemetry?: boolean;
27
+ };
@@ -1,11 +1,15 @@
1
1
  import * as core from "../pkg/redis.js";
2
- import type { Requester, RetryConfig, UpstashRequest, UpstashResponse } from "../pkg/http.js";
2
+ import type { Requester, UpstashRequest, UpstashResponse } from "../pkg/http.js";
3
+ import { RequesterConfig } from "../pkg/http.js";
4
+ type Env = {
5
+ UPSTASH_DISABLE_TELEMETRY?: string;
6
+ };
3
7
  export type { Requester, UpstashRequest, UpstashResponse };
4
8
  /**
5
9
  * Connection credentials for upstash redis.
6
10
  * Get them from https://console.upstash.com/redis/<uuid>
7
11
  */
8
- export declare type RedisConfigCloudflare = {
12
+ export type RedisConfigCloudflare = {
9
13
  /**
10
14
  * UPSTASH_REDIS_REST_URL
11
15
  */
@@ -14,11 +18,7 @@ export declare type RedisConfigCloudflare = {
14
18
  * UPSTASH_REDIS_REST_TOKEN
15
19
  */
16
20
  token: string;
17
- /**
18
- * Configure the retry behaviour in case of network errors
19
- */
20
- retry?: RetryConfig;
21
- } & core.RedisOptions;
21
+ } & core.RedisOptions & RequesterConfig & Env;
22
22
  /**
23
23
  * Serverless redis client for upstash.
24
24
  */
@@ -34,9 +34,10 @@ export declare class Redis extends core.Redis {
34
34
  * });
35
35
  * ```
36
36
  */
37
- constructor(config: RedisConfigCloudflare);
37
+ constructor(config: RedisConfigCloudflare, env?: Env);
38
38
  static fromEnv(env?: {
39
39
  UPSTASH_REDIS_REST_URL: string;
40
40
  UPSTASH_REDIS_REST_TOKEN: string;
41
+ UPSTASH_DISABLE_TELEMETRY?: string;
41
42
  }, opts?: Omit<RedisConfigCloudflare, "url" | "token">): Redis;
42
43
  }
@@ -1,11 +1,11 @@
1
1
  import * as core from "../pkg/redis.js";
2
- import type { Requester, RetryConfig, UpstashRequest, UpstashResponse } from "../pkg/http.js";
2
+ import type { Requester, RequesterConfig, UpstashRequest, UpstashResponse } from "../pkg/http.js";
3
3
  export type { Requester, UpstashRequest, UpstashResponse };
4
4
  /**
5
5
  * Connection credentials for upstash redis.
6
6
  * Get them from https://console.upstash.com/redis/<uuid>
7
7
  */
8
- export declare type RedisConfigFastly = {
8
+ export type RedisConfigFastly = {
9
9
  /**
10
10
  * UPSTASH_REDIS_REST_URL
11
11
  */
@@ -20,11 +20,7 @@ export declare type RedisConfigFastly = {
20
20
  * referenced by name.
21
21
  */
22
22
  backend: string;
23
- /**
24
- * Configure the retry behaviour in case of network errors
25
- */
26
- retry?: RetryConfig;
27
- } & core.RedisOptions;
23
+ } & core.RedisOptions & RequesterConfig;
28
24
  /**
29
25
  * Serverless redis client for upstash.
30
26
  */
@@ -1,12 +1,12 @@
1
1
  import * as core from "../pkg/redis.js";
2
- import { Requester, RetryConfig, UpstashRequest, UpstashResponse } from "../pkg/http.js";
2
+ import { Requester, RequesterConfig, UpstashRequest, UpstashResponse } from "../pkg/http.js";
3
3
  import "isomorphic-fetch";
4
4
  export type { Requester, UpstashRequest, UpstashResponse };
5
5
  /**
6
6
  * Connection credentials for upstash redis.
7
7
  * Get them from https://console.upstash.com/redis/<uuid>
8
8
  */
9
- export declare type RedisConfigNodejs = {
9
+ export type RedisConfigNodejs = {
10
10
  /**
11
11
  * UPSTASH_REDIS_REST_URL
12
12
  */
@@ -15,26 +15,7 @@ export declare type RedisConfigNodejs = {
15
15
  * UPSTASH_REDIS_REST_TOKEN
16
16
  */
17
17
  token: string;
18
- /**
19
- * An agent allows you to reuse connections to reduce latency for multiple sequential requests.
20
- *
21
- * This is a node specific implementation and is not supported in various runtimes like Vercel
22
- * edge functions.
23
- *
24
- * @example
25
- * ```ts
26
- * import https from "https"
27
- *
28
- * const options: RedisConfigNodejs = {
29
- * agent: new https.Agent({ keepAlive: true })
30
- * }
31
- * ```
32
- */
33
- /**
34
- * Configure the retry behaviour in case of network errors
35
- */
36
- retry?: RetryConfig;
37
- } & core.RedisOptions;
18
+ } & core.RedisOptions & RequesterConfig;
38
19
  /**
39
20
  * Serverless redis client for upstash.
40
21
  */
@@ -1,11 +1,11 @@
1
1
  import * as core from "../pkg/redis.js";
2
- import { Requester, RetryConfig, UpstashRequest, UpstashResponse } from "../pkg/http.js";
2
+ import { Requester, RequesterConfig, UpstashRequest, UpstashResponse } from "../pkg/http.js";
3
3
  export type { Requester, UpstashRequest, UpstashResponse };
4
4
  /**
5
5
  * Connection credentials for upstash redis.
6
6
  * Get them from https://console.upstash.com/redis/<uuid>
7
7
  */
8
- export declare type RedisConfigNodejs = {
8
+ export type RedisConfigNodejs = {
9
9
  /**
10
10
  * UPSTASH_REDIS_REST_URL
11
11
  */
@@ -29,11 +29,8 @@ export declare type RedisConfigNodejs = {
29
29
  * }
30
30
  * ```
31
31
  */
32
- /**
33
- * Configure the retry behaviour in case of network errors
34
- */
35
- retry?: RetryConfig;
36
- } & core.RedisOptions;
32
+ agent?: any;
33
+ } & core.RedisOptions & RequesterConfig;
37
34
  /**
38
35
  * Serverless redis client for upstash.
39
36
  */
@@ -0,0 +1 @@
1
+ export declare const VERSION = "v0.0.0-ci.f0c37f55-20231010";