js-redis-server 0.0.1 → 0.0.2
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 +235 -30
- package/dist/cli.d.ts +1 -0
- package/dist/cli.d.ts.map +1 -1
- package/dist/cli.js +191 -0
- package/dist/cli.js.map +1 -0
- package/dist/cluster.d.ts +30 -0
- package/dist/cluster.d.ts.map +1 -0
- package/dist/cluster.js +131 -0
- package/dist/cluster.js.map +1 -0
- package/dist/commands/cluster.d.ts +8 -0
- package/dist/commands/cluster.d.ts.map +1 -0
- package/dist/commands/cluster.js +190 -0
- package/dist/commands/cluster.js.map +1 -0
- package/dist/commands/command.d.ts +6 -0
- package/dist/commands/command.d.ts.map +1 -0
- package/dist/commands/command.js +381 -0
- package/dist/commands/command.js.map +1 -0
- package/dist/commands/connection.d.ts +24 -0
- package/dist/commands/connection.d.ts.map +1 -0
- package/dist/commands/connection.js +406 -0
- package/dist/commands/connection.js.map +1 -0
- package/dist/commands/hashes.d.ts +64 -0
- package/dist/commands/hashes.d.ts.map +1 -0
- package/dist/commands/hashes.js +276 -0
- package/dist/commands/hashes.js.map +1 -0
- package/dist/commands/helpers.d.ts +16 -0
- package/dist/commands/helpers.d.ts.map +1 -0
- package/dist/commands/helpers.js +77 -0
- package/dist/commands/helpers.js.map +1 -0
- package/dist/commands/index.d.ts +23 -0
- package/dist/commands/index.d.ts.map +1 -0
- package/dist/commands/index.js +177 -0
- package/dist/commands/index.js.map +1 -0
- package/dist/commands/introspection.d.ts +17 -0
- package/dist/commands/introspection.d.ts.map +1 -0
- package/dist/commands/introspection.js +54 -0
- package/dist/commands/introspection.js.map +1 -0
- package/dist/commands/keys.d.ts +47 -0
- package/dist/commands/keys.d.ts.map +1 -0
- package/dist/commands/keys.js +238 -0
- package/dist/commands/keys.js.map +1 -0
- package/dist/commands/lists.d.ts +60 -0
- package/dist/commands/lists.d.ts.map +1 -0
- package/dist/commands/lists.js +333 -0
- package/dist/commands/lists.js.map +1 -0
- package/dist/commands/scan.d.ts +24 -0
- package/dist/commands/scan.d.ts.map +1 -0
- package/dist/commands/scan.js +316 -0
- package/dist/commands/scan.js.map +1 -0
- package/dist/commands/scripts.d.ts +22 -0
- package/dist/commands/scripts.d.ts.map +1 -0
- package/dist/commands/scripts.js +195 -0
- package/dist/commands/scripts.js.map +1 -0
- package/dist/commands/sets.d.ts +61 -0
- package/dist/commands/sets.d.ts.map +1 -0
- package/dist/commands/sets.js +411 -0
- package/dist/commands/sets.js.map +1 -0
- package/dist/commands/strings.d.ts +91 -0
- package/dist/commands/strings.d.ts.map +1 -0
- package/dist/commands/strings.js +537 -0
- package/dist/commands/strings.js.map +1 -0
- package/dist/commands/transactions.d.ts +9 -0
- package/dist/commands/transactions.d.ts.map +1 -0
- package/dist/commands/transactions.js +89 -0
- package/dist/commands/transactions.js.map +1 -0
- package/dist/commands/zsets.d.ts +72 -0
- package/dist/commands/zsets.d.ts.map +1 -0
- package/dist/commands/zsets.js +360 -0
- package/dist/commands/zsets.js.map +1 -0
- package/dist/core/client-session.d.ts +60 -0
- package/dist/core/client-session.d.ts.map +1 -0
- package/dist/core/client-session.js +210 -0
- package/dist/core/client-session.js.map +1 -0
- package/dist/core/command-definition.d.ts +64 -0
- package/dist/core/command-definition.d.ts.map +1 -0
- package/dist/core/command-definition.js +10 -0
- package/dist/core/command-definition.js.map +1 -0
- package/dist/core/command-executor.d.ts +24 -0
- package/dist/core/command-executor.d.ts.map +1 -0
- package/dist/core/command-executor.js +168 -0
- package/dist/core/command-executor.js.map +1 -0
- package/dist/core/command-registry.d.ts +16 -0
- package/dist/core/command-registry.d.ts.map +1 -0
- package/dist/core/command-registry.js +35 -0
- package/dist/core/command-registry.js.map +1 -0
- package/dist/core/command-schema.d.ts +40 -0
- package/dist/core/command-schema.d.ts.map +1 -0
- package/dist/core/command-schema.js +188 -0
- package/dist/core/command-schema.js.map +1 -0
- package/dist/core/execution-policies/cluster-policy.d.ts +8 -0
- package/dist/core/execution-policies/cluster-policy.d.ts.map +1 -0
- package/dist/core/execution-policies/cluster-policy.js +61 -0
- package/dist/core/execution-policies/cluster-policy.js.map +1 -0
- package/dist/core/execution-policies/index.d.ts +16 -0
- package/dist/core/execution-policies/index.d.ts.map +1 -0
- package/dist/core/execution-policies/index.js +8 -0
- package/dist/core/execution-policies/index.js.map +1 -0
- package/dist/core/execution-policies/transaction-policy.d.ts +3 -0
- package/dist/core/execution-policies/transaction-policy.d.ts.map +1 -0
- package/dist/core/execution-policies/transaction-policy.js +25 -0
- package/dist/core/execution-policies/transaction-policy.js.map +1 -0
- package/dist/core/lua-runtime.d.ts +15 -0
- package/dist/core/lua-runtime.d.ts.map +1 -0
- package/dist/core/lua-runtime.js +173 -0
- package/dist/core/lua-runtime.js.map +1 -0
- package/dist/core/redis-context.d.ts +41 -0
- package/dist/core/redis-context.d.ts.map +1 -0
- package/dist/core/redis-context.js +46 -0
- package/dist/core/redis-context.js.map +1 -0
- package/dist/core/redis-error.d.ts +83 -0
- package/dist/core/redis-error.d.ts.map +1 -0
- package/dist/core/redis-error.js +186 -0
- package/dist/core/redis-error.js.map +1 -0
- package/dist/core/redis-result.d.ts +15 -0
- package/dist/core/redis-result.d.ts.map +1 -0
- package/dist/core/redis-result.js +26 -0
- package/dist/core/redis-result.js.map +1 -0
- package/dist/core/redis-value.d.ts +61 -0
- package/dist/core/redis-value.d.ts.map +1 -0
- package/dist/core/redis-value.js +41 -0
- package/dist/core/redis-value.js.map +1 -0
- package/dist/core/resp-encoder.d.ts +9 -0
- package/dist/core/resp-encoder.d.ts.map +1 -0
- package/dist/core/resp-encoder.js +159 -0
- package/dist/core/resp-encoder.js.map +1 -0
- package/dist/core/response-stream.d.ts +17 -0
- package/dist/core/response-stream.d.ts.map +1 -0
- package/dist/core/response-stream.js +10 -0
- package/dist/core/response-stream.js.map +1 -0
- package/dist/core/transports/connection-transport.d.ts +12 -0
- package/dist/core/transports/connection-transport.d.ts.map +1 -0
- package/dist/core/transports/connection-transport.js +3 -0
- package/dist/core/transports/connection-transport.js.map +1 -0
- package/dist/core/transports/in-memory-connection-transport.d.ts +28 -0
- package/dist/core/transports/in-memory-connection-transport.d.ts.map +1 -0
- package/dist/core/transports/in-memory-connection-transport.js +111 -0
- package/dist/core/transports/in-memory-connection-transport.js.map +1 -0
- package/dist/core/transports/resp2/decoder.d.ts +15 -0
- package/dist/core/transports/resp2/decoder.d.ts.map +1 -0
- package/dist/core/transports/resp2/decoder.js +209 -0
- package/dist/core/transports/resp2/decoder.js.map +1 -0
- package/dist/core/transports/resp2/index.d.ts +2 -12
- package/dist/core/transports/resp2/index.d.ts.map +1 -1
- package/dist/core/transports/resp2/index.js +9 -0
- package/dist/core/transports/resp2/index.js.map +1 -0
- package/dist/core/transports/resp2/server.d.ts +26 -0
- package/dist/core/transports/resp2/server.d.ts.map +1 -0
- package/dist/core/transports/resp2/server.js +83 -0
- package/dist/core/transports/resp2/server.js.map +1 -0
- package/dist/core/transports/resp2/session-adapter.d.ts +24 -0
- package/dist/core/transports/resp2/session-adapter.d.ts.map +1 -0
- package/dist/core/transports/resp2/session-adapter.js +86 -0
- package/dist/core/transports/resp2/session-adapter.js.map +1 -0
- package/dist/core/transports/socket-connection-transport.d.ts +20 -0
- package/dist/core/transports/socket-connection-transport.d.ts.map +1 -0
- package/dist/core/transports/socket-connection-transport.js +64 -0
- package/dist/core/transports/socket-connection-transport.js.map +1 -0
- package/dist/core/turn-queue.d.ts +15 -0
- package/dist/core/turn-queue.d.ts.map +1 -0
- package/dist/core/turn-queue.js +51 -0
- package/dist/core/turn-queue.js.map +1 -0
- package/dist/index.d.ts +35 -347
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +141 -0
- package/dist/index.js.map +1 -0
- package/dist/logger.d.ts +6 -0
- package/dist/logger.d.ts.map +1 -0
- package/dist/logger.js +3 -0
- package/dist/logger.js.map +1 -0
- package/dist/state/cluster-topology.d.ts +30 -0
- package/dist/state/cluster-topology.d.ts.map +1 -0
- package/dist/state/cluster-topology.js +88 -0
- package/dist/state/cluster-topology.js.map +1 -0
- package/dist/state/data-types.d.ts +40 -0
- package/dist/state/data-types.d.ts.map +1 -0
- package/dist/state/data-types.js +67 -0
- package/dist/state/data-types.js.map +1 -0
- package/dist/state/database.d.ts +44 -0
- package/dist/state/database.d.ts.map +1 -0
- package/dist/state/database.js +116 -0
- package/dist/state/database.js.map +1 -0
- package/dist/state/index.d.ts +14 -0
- package/dist/state/index.d.ts.map +1 -0
- package/dist/state/index.js +27 -0
- package/dist/state/index.js.map +1 -0
- package/dist/state/keyspace.d.ts +45 -0
- package/dist/state/keyspace.d.ts.map +1 -0
- package/dist/state/keyspace.js +180 -0
- package/dist/state/keyspace.js.map +1 -0
- package/dist/state/mutation-events.d.ts +37 -0
- package/dist/state/mutation-events.d.ts.map +1 -0
- package/dist/state/mutation-events.js +74 -0
- package/dist/state/mutation-events.js.map +1 -0
- package/dist/state/pubsub-broker.d.ts +4 -0
- package/dist/state/pubsub-broker.d.ts.map +1 -0
- package/dist/state/pubsub-broker.js +10 -0
- package/dist/state/pubsub-broker.js.map +1 -0
- package/dist/state/script-cache.d.ts +10 -0
- package/dist/state/script-cache.d.ts.map +1 -0
- package/dist/state/script-cache.js +33 -0
- package/dist/state/script-cache.js.map +1 -0
- package/dist/state/server-state.d.ts +24 -0
- package/dist/state/server-state.d.ts.map +1 -0
- package/dist/state/server-state.js +42 -0
- package/dist/state/server-state.js.map +1 -0
- package/package.json +18 -22
- package/dist/cli.mjs +0 -5923
- package/dist/cli.mjs.map +0 -1
- package/dist/commanders/custom/base-commander.d.ts +0 -19
- package/dist/commanders/custom/base-commander.d.ts.map +0 -1
- package/dist/commanders/custom/cluster-router.d.ts +0 -57
- package/dist/commanders/custom/cluster-router.d.ts.map +0 -1
- package/dist/commanders/custom/clusterCommander.d.ts +0 -39
- package/dist/commanders/custom/clusterCommander.d.ts.map +0 -1
- package/dist/commanders/custom/commander.d.ts +0 -12
- package/dist/commanders/custom/commander.d.ts.map +0 -1
- package/dist/commanders/custom/commands/metadata.d.ts +0 -101
- package/dist/commanders/custom/commands/metadata.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/client/clientSetName.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/client/clientSetName.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/client/index.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/client/index.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/cluster/clusterInfo.d.ts +0 -7
- package/dist/commanders/custom/commands/redis/cluster/clusterInfo.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/cluster/clusterNodes.d.ts +0 -7
- package/dist/commanders/custom/commands/redis/cluster/clusterNodes.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/cluster/clusterShards.d.ts +0 -7
- package/dist/commanders/custom/commands/redis/cluster/clusterShards.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/cluster/clusterSlots.d.ts +0 -7
- package/dist/commanders/custom/commands/redis/cluster/clusterSlots.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/cluster/index.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/cluster/index.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/command/index.d.ts +0 -6
- package/dist/commanders/custom/commands/redis/command/index.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/hashes/hdel.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/hashes/hdel.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/hashes/hexists.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/hashes/hexists.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/hashes/hget.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/hashes/hget.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/hashes/hgetall.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/hashes/hgetall.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/hashes/hincrby.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/hashes/hincrby.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/hashes/hincrbyfloat.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/hashes/hincrbyfloat.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/hashes/hkeys.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/hashes/hkeys.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/hashes/hlen.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/hashes/hlen.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/hashes/hmget.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/hashes/hmget.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/hashes/hmset.d.ts +0 -10
- package/dist/commanders/custom/commands/redis/data/hashes/hmset.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/hashes/hset.d.ts +0 -10
- package/dist/commanders/custom/commands/redis/data/hashes/hset.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/hashes/hvals.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/hashes/hvals.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/hashes/index.d.ts +0 -13
- package/dist/commanders/custom/commands/redis/data/hashes/index.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/index.d.ts +0 -7
- package/dist/commanders/custom/commands/redis/data/index.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/keys/dbsize.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/keys/dbsize.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/keys/del.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/keys/del.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/keys/exists.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/keys/exists.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/keys/expire.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/keys/expire.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/keys/expireat.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/keys/expireat.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/keys/flushall.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/keys/flushall.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/keys/flushdb.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/keys/flushdb.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/keys/index.d.ts +0 -11
- package/dist/commanders/custom/commands/redis/data/keys/index.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/keys/pttl.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/keys/pttl.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/keys/ttl.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/keys/ttl.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/keys/type.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/keys/type.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/lists/index.d.ts +0 -11
- package/dist/commanders/custom/commands/redis/data/lists/index.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/lists/lindex.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/lists/lindex.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/lists/llen.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/lists/llen.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/lists/lpop.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/lists/lpop.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/lists/lpush.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/lists/lpush.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/lists/lrange.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/lists/lrange.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/lists/lrem.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/lists/lrem.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/lists/lset.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/lists/lset.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/lists/ltrim.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/lists/ltrim.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/lists/rpop.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/lists/rpop.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/lists/rpush.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/lists/rpush.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/sets/index.d.ts +0 -12
- package/dist/commanders/custom/commands/redis/data/sets/index.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/sets/sadd.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/sets/sadd.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/sets/scard.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/sets/scard.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/sets/sdiff.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/sets/sdiff.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/sets/sinter.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/sets/sinter.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/sets/sismember.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/sets/sismember.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/sets/smembers.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/sets/smembers.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/sets/smove.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/sets/smove.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/sets/spop.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/sets/spop.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/sets/srandmember.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/sets/srandmember.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/sets/srem.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/sets/srem.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/sets/sunion.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/sets/sunion.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/append.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/strings/append.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/decr.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/strings/decr.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/decrby.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/strings/decrby.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/get.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/strings/get.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/getset.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/strings/getset.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/incr.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/strings/incr.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/incrby.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/strings/incrby.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/incrbyfloat.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/strings/incrbyfloat.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/index.d.ts +0 -14
- package/dist/commanders/custom/commands/redis/data/strings/index.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/mget.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/strings/mget.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/mset.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/strings/mset.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/msetnx.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/strings/msetnx.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/set.d.ts +0 -29
- package/dist/commanders/custom/commands/redis/data/strings/set.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/strings/strlen.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/strings/strlen.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/zsets/index.d.ts +0 -12
- package/dist/commanders/custom/commands/redis/data/zsets/index.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/zsets/zadd.d.ts +0 -10
- package/dist/commanders/custom/commands/redis/data/zsets/zadd.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/zsets/zcard.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/data/zsets/zcard.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/zsets/zincrby.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/zsets/zincrby.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/zsets/zrange.d.ts +0 -10
- package/dist/commanders/custom/commands/redis/data/zsets/zrange.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/zsets/zrangebyscore.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/zsets/zrangebyscore.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/zsets/zrank.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/zsets/zrank.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/zsets/zrem.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/zsets/zrem.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/zsets/zremrangebyscore.d.ts +0 -9
- package/dist/commanders/custom/commands/redis/data/zsets/zremrangebyscore.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/zsets/zrevrange.d.ts +0 -10
- package/dist/commanders/custom/commands/redis/data/zsets/zrevrange.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/zsets/zrevrank.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/zsets/zrevrank.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/data/zsets/zscore.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/data/zsets/zscore.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/index.d.ts +0 -39
- package/dist/commanders/custom/commands/redis/index.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/info.d.ts +0 -7
- package/dist/commanders/custom/commands/redis/info.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/monitor.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/monitor.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/ping.d.ts +0 -7
- package/dist/commanders/custom/commands/redis/ping.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/quit.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/quit.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/script/debug.d.ts +0 -7
- package/dist/commanders/custom/commands/redis/script/debug.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/script/eval.d.ts +0 -7
- package/dist/commanders/custom/commands/redis/script/eval.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/script/evalsha.d.ts +0 -7
- package/dist/commanders/custom/commands/redis/script/evalsha.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/script/exists.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/script/exists.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/script/flush.d.ts +0 -7
- package/dist/commanders/custom/commands/redis/script/flush.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/script/help.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/script/help.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/script/index.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/script/index.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/script/kill.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/script/kill.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/script/load.d.ts +0 -5
- package/dist/commanders/custom/commands/redis/script/load.d.ts.map +0 -1
- package/dist/commanders/custom/commands/redis/script/lua-reply.d.ts +0 -8
- package/dist/commanders/custom/commands/redis/script/lua-reply.d.ts.map +0 -1
- package/dist/commanders/custom/commands/registry.d.ts +0 -84
- package/dist/commanders/custom/commands/registry.d.ts.map +0 -1
- package/dist/commanders/custom/data-structures/hash.d.ts +0 -16
- package/dist/commanders/custom/data-structures/hash.d.ts.map +0 -1
- package/dist/commanders/custom/data-structures/list.d.ts +0 -15
- package/dist/commanders/custom/data-structures/list.d.ts.map +0 -1
- package/dist/commanders/custom/data-structures/set.d.ts +0 -16
- package/dist/commanders/custom/data-structures/set.d.ts.map +0 -1
- package/dist/commanders/custom/data-structures/stream.d.ts +0 -3
- package/dist/commanders/custom/data-structures/stream.d.ts.map +0 -1
- package/dist/commanders/custom/data-structures/string.d.ts +0 -5
- package/dist/commanders/custom/data-structures/string.d.ts.map +0 -1
- package/dist/commanders/custom/data-structures/zset.d.ts +0 -17
- package/dist/commanders/custom/data-structures/zset.d.ts.map +0 -1
- package/dist/commanders/custom/db.d.ts +0 -67
- package/dist/commanders/custom/db.d.ts.map +0 -1
- package/dist/commanders/custom/execution-context.d.ts +0 -12
- package/dist/commanders/custom/execution-context.d.ts.map +0 -1
- package/dist/commanders/custom/lua-runtime.d.ts +0 -16
- package/dist/commanders/custom/lua-runtime.d.ts.map +0 -1
- package/dist/commanders/custom/redis-kernel.d.ts +0 -46
- package/dist/commanders/custom/redis-kernel.d.ts.map +0 -1
- package/dist/commanders/custom/schema/builder.d.ts +0 -24
- package/dist/commanders/custom/schema/builder.d.ts.map +0 -1
- package/dist/commanders/custom/schema/command-adapter.d.ts +0 -25
- package/dist/commanders/custom/schema/command-adapter.d.ts.map +0 -1
- package/dist/commanders/custom/schema/index.d.ts +0 -7
- package/dist/commanders/custom/schema/index.d.ts.map +0 -1
- package/dist/commanders/custom/schema/input-mapper.d.ts +0 -28
- package/dist/commanders/custom/schema/input-mapper.d.ts.map +0 -1
- package/dist/commanders/custom/schema/registry.d.ts +0 -13
- package/dist/commanders/custom/schema/registry.d.ts.map +0 -1
- package/dist/commanders/custom/schema/resp-input-mapper.d.ts +0 -20
- package/dist/commanders/custom/schema/resp-input-mapper.d.ts.map +0 -1
- package/dist/commanders/custom/schema/types.d.ts +0 -43
- package/dist/commanders/custom/schema/types.d.ts.map +0 -1
- package/dist/core/cluster/network.d.ts +0 -24
- package/dist/core/cluster/network.d.ts.map +0 -1
- package/dist/core/errors.d.ts +0 -87
- package/dist/core/errors.d.ts.map +0 -1
- package/dist/core/transports/buffered-transport.d.ts +0 -14
- package/dist/core/transports/buffered-transport.d.ts.map +0 -1
- package/dist/core/transports/capturing-transport.d.ts +0 -19
- package/dist/core/transports/capturing-transport.d.ts.map +0 -1
- package/dist/core/transports/command-validator.d.ts +0 -12
- package/dist/core/transports/command-validator.d.ts.map +0 -1
- package/dist/core/transports/resp2/adapter.d.ts +0 -32
- package/dist/core/transports/resp2/adapter.d.ts.map +0 -1
- package/dist/core/transports/session-state.d.ts +0 -76
- package/dist/core/transports/session-state.d.ts.map +0 -1
- package/dist/core/transports/session.d.ts +0 -36
- package/dist/core/transports/session.d.ts.map +0 -1
- package/dist/index.cjs +0 -5759
- package/dist/index.cjs.map +0 -1
- package/dist/index.mjs +0 -5749
- package/dist/index.mjs.map +0 -1
- package/dist/types.d.ts +0 -54
- package/dist/types.d.ts.map +0 -1
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.t = void 0;
|
|
4
|
+
exports.parseCommandArgs = parseCommandArgs;
|
|
5
|
+
const redis_error_1 = require("./redis-error");
|
|
6
|
+
class MissingInputError extends Error {
|
|
7
|
+
constructor() {
|
|
8
|
+
super('missing input');
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
class SchemaMismatchError extends Error {
|
|
12
|
+
constructor() {
|
|
13
|
+
super('schema mismatch');
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
function parseCommandArgs(schema, input, commandName) {
|
|
17
|
+
try {
|
|
18
|
+
const result = schema.parse(input, 0, { commandName });
|
|
19
|
+
if (result.nextIndex !== input.length) {
|
|
20
|
+
throw new redis_error_1.WrongNumberOfArgumentsError(commandName);
|
|
21
|
+
}
|
|
22
|
+
return result.value;
|
|
23
|
+
}
|
|
24
|
+
catch (err) {
|
|
25
|
+
if (err instanceof MissingInputError) {
|
|
26
|
+
throw new redis_error_1.WrongNumberOfArgumentsError(commandName);
|
|
27
|
+
}
|
|
28
|
+
if (err instanceof SchemaMismatchError) {
|
|
29
|
+
throw new redis_error_1.RedisSyntaxError();
|
|
30
|
+
}
|
|
31
|
+
throw err;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
function readToken(input, index) {
|
|
35
|
+
const token = input[index];
|
|
36
|
+
if (!token) {
|
|
37
|
+
throw new MissingInputError();
|
|
38
|
+
}
|
|
39
|
+
return token;
|
|
40
|
+
}
|
|
41
|
+
function keywordMatches(actual, expected) {
|
|
42
|
+
return actual.toString().toUpperCase() === expected.toUpperCase();
|
|
43
|
+
}
|
|
44
|
+
function makeSchema(parse) {
|
|
45
|
+
return { parse };
|
|
46
|
+
}
|
|
47
|
+
exports.t = {
|
|
48
|
+
custom(parse) {
|
|
49
|
+
return makeSchema(parse);
|
|
50
|
+
},
|
|
51
|
+
key() {
|
|
52
|
+
return exports.t.bulk();
|
|
53
|
+
},
|
|
54
|
+
bulk() {
|
|
55
|
+
return makeSchema((input, index) => ({
|
|
56
|
+
value: readToken(input, index),
|
|
57
|
+
nextIndex: index + 1,
|
|
58
|
+
}));
|
|
59
|
+
},
|
|
60
|
+
string() {
|
|
61
|
+
return makeSchema((input, index) => ({
|
|
62
|
+
value: readToken(input, index).toString(),
|
|
63
|
+
nextIndex: index + 1,
|
|
64
|
+
}));
|
|
65
|
+
},
|
|
66
|
+
integer(options) {
|
|
67
|
+
return makeSchema((input, index) => {
|
|
68
|
+
const raw = readToken(input, index).toString();
|
|
69
|
+
if (!/^-?\d+$/.test(raw)) {
|
|
70
|
+
throw new redis_error_1.ExpectedIntegerError();
|
|
71
|
+
}
|
|
72
|
+
const value = Number(raw);
|
|
73
|
+
if (!Number.isSafeInteger(value)) {
|
|
74
|
+
throw new redis_error_1.ExpectedIntegerError();
|
|
75
|
+
}
|
|
76
|
+
if (options?.min !== undefined && value < options.min) {
|
|
77
|
+
throw new redis_error_1.ExpectedIntegerError();
|
|
78
|
+
}
|
|
79
|
+
if (options?.max !== undefined && value > options.max) {
|
|
80
|
+
throw new redis_error_1.ExpectedIntegerError();
|
|
81
|
+
}
|
|
82
|
+
return { value, nextIndex: index + 1 };
|
|
83
|
+
});
|
|
84
|
+
},
|
|
85
|
+
bigInteger(options) {
|
|
86
|
+
return makeSchema((input, index) => {
|
|
87
|
+
const raw = readToken(input, index).toString();
|
|
88
|
+
if (!/^-?\d+$/.test(raw)) {
|
|
89
|
+
throw new redis_error_1.ExpectedIntegerError();
|
|
90
|
+
}
|
|
91
|
+
const value = BigInt(raw);
|
|
92
|
+
if (options?.min !== undefined && value < options.min) {
|
|
93
|
+
throw new redis_error_1.ExpectedIntegerError();
|
|
94
|
+
}
|
|
95
|
+
if (options?.max !== undefined && value > options.max) {
|
|
96
|
+
throw new redis_error_1.ExpectedIntegerError();
|
|
97
|
+
}
|
|
98
|
+
return { value, nextIndex: index + 1 };
|
|
99
|
+
});
|
|
100
|
+
},
|
|
101
|
+
float() {
|
|
102
|
+
return makeSchema((input, index) => {
|
|
103
|
+
const value = Number(readToken(input, index).toString());
|
|
104
|
+
if (!Number.isFinite(value)) {
|
|
105
|
+
throw new redis_error_1.ExpectedFloatError();
|
|
106
|
+
}
|
|
107
|
+
return { value, nextIndex: index + 1 };
|
|
108
|
+
});
|
|
109
|
+
},
|
|
110
|
+
keyword(expected) {
|
|
111
|
+
return makeSchema((input, index) => {
|
|
112
|
+
const token = readToken(input, index);
|
|
113
|
+
if (!keywordMatches(token, expected)) {
|
|
114
|
+
throw new SchemaMismatchError();
|
|
115
|
+
}
|
|
116
|
+
return { value: expected, nextIndex: index + 1 };
|
|
117
|
+
});
|
|
118
|
+
},
|
|
119
|
+
optional(schema) {
|
|
120
|
+
return makeSchema((input, index, ctx) => {
|
|
121
|
+
if (index >= input.length) {
|
|
122
|
+
return { value: undefined, nextIndex: index };
|
|
123
|
+
}
|
|
124
|
+
try {
|
|
125
|
+
return schema.parse(input, index, ctx);
|
|
126
|
+
}
|
|
127
|
+
catch (err) {
|
|
128
|
+
if (err instanceof SchemaMismatchError) {
|
|
129
|
+
return { value: undefined, nextIndex: index };
|
|
130
|
+
}
|
|
131
|
+
throw err;
|
|
132
|
+
}
|
|
133
|
+
});
|
|
134
|
+
},
|
|
135
|
+
variadic(schema, options) {
|
|
136
|
+
// Greedy by design for Phase 1. Do not place another positional schema
|
|
137
|
+
// after a variadic field until the parser grows lookahead support.
|
|
138
|
+
return makeSchema((input, index, ctx) => {
|
|
139
|
+
const values = [];
|
|
140
|
+
let cursor = index;
|
|
141
|
+
while (cursor < input.length) {
|
|
142
|
+
const result = schema.parse(input, cursor, ctx);
|
|
143
|
+
values.push(result.value);
|
|
144
|
+
cursor = result.nextIndex;
|
|
145
|
+
}
|
|
146
|
+
if (options?.min !== undefined && values.length < options.min) {
|
|
147
|
+
throw new redis_error_1.WrongNumberOfArgumentsError(ctx.commandName);
|
|
148
|
+
}
|
|
149
|
+
return { value: values, nextIndex: cursor };
|
|
150
|
+
});
|
|
151
|
+
},
|
|
152
|
+
object(shape) {
|
|
153
|
+
return makeSchema((input, index, ctx) => {
|
|
154
|
+
const value = {};
|
|
155
|
+
let cursor = index;
|
|
156
|
+
const fields = Object.entries(shape);
|
|
157
|
+
for (const [name, fieldSchema] of fields) {
|
|
158
|
+
const result = fieldSchema.parse(input, cursor, ctx);
|
|
159
|
+
value[name] = result.value;
|
|
160
|
+
cursor = result.nextIndex;
|
|
161
|
+
}
|
|
162
|
+
return { value: value, nextIndex: cursor };
|
|
163
|
+
});
|
|
164
|
+
},
|
|
165
|
+
union(schemas) {
|
|
166
|
+
return makeSchema((input, index, ctx) => {
|
|
167
|
+
let commandError = null;
|
|
168
|
+
for (const schema of schemas) {
|
|
169
|
+
try {
|
|
170
|
+
return schema.parse(input, index, ctx);
|
|
171
|
+
}
|
|
172
|
+
catch (err) {
|
|
173
|
+
if (err instanceof SchemaMismatchError) {
|
|
174
|
+
continue;
|
|
175
|
+
}
|
|
176
|
+
if (err instanceof redis_error_1.RedisCommandError) {
|
|
177
|
+
commandError = err;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
if (commandError) {
|
|
182
|
+
throw commandError;
|
|
183
|
+
}
|
|
184
|
+
throw new SchemaMismatchError();
|
|
185
|
+
});
|
|
186
|
+
},
|
|
187
|
+
};
|
|
188
|
+
//# sourceMappingURL=command-schema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"command-schema.js","sourceRoot":"","sources":["../../src/core/command-schema.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { ExecutionPolicy } from './index';
|
|
2
|
+
import type { RedisClusterTopology } from '../../state';
|
|
3
|
+
export type ClusterPolicyOptions = {
|
|
4
|
+
localNodeId: string;
|
|
5
|
+
topology?: RedisClusterTopology;
|
|
6
|
+
};
|
|
7
|
+
export declare function createClusterPolicy(options: ClusterPolicyOptions): ExecutionPolicy;
|
|
8
|
+
//# sourceMappingURL=cluster-policy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cluster-policy.d.ts","sourceRoot":"","sources":["../../../src/core/execution-policies/cluster-policy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAA;AAQ9C,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAA;AAEvD,MAAM,MAAM,oBAAoB,GAAG;IACjC,WAAW,EAAE,MAAM,CAAA;IACnB,QAAQ,CAAC,EAAE,oBAAoB,CAAA;CAChC,CAAA;AAED,wBAAgB,mBAAmB,CACjC,OAAO,EAAE,oBAAoB,GAC5B,eAAe,CAqDjB"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createClusterPolicy = createClusterPolicy;
|
|
4
|
+
const redis_error_1 = require("../redis-error");
|
|
5
|
+
function createClusterPolicy(options) {
|
|
6
|
+
const transactionSlots = new WeakMap();
|
|
7
|
+
let localNodeChecked = false;
|
|
8
|
+
return {
|
|
9
|
+
name: 'cluster',
|
|
10
|
+
beforeExecute(plan, ctx) {
|
|
11
|
+
const topology = options.topology ?? ctx.server.clusterTopology;
|
|
12
|
+
if (!localNodeChecked) {
|
|
13
|
+
if (!topology.getNode(options.localNodeId)) {
|
|
14
|
+
throw new Error(`ClusterPolicy localNodeId ${options.localNodeId} is not present in topology`);
|
|
15
|
+
}
|
|
16
|
+
localNodeChecked = true;
|
|
17
|
+
}
|
|
18
|
+
if (plan.definition.name === 'select') {
|
|
19
|
+
throw new redis_error_1.RedisCommandError('SELECT is not allowed in cluster mode');
|
|
20
|
+
}
|
|
21
|
+
if (plan.definition.name === 'multi' &&
|
|
22
|
+
ctx.session.mode !== 'transaction') {
|
|
23
|
+
transactionSlots.delete(ctx.session);
|
|
24
|
+
}
|
|
25
|
+
if (ctx.session.mode === 'transaction' &&
|
|
26
|
+
(plan.definition.name === 'exec' || plan.definition.name === 'discard')) {
|
|
27
|
+
transactionSlots.delete(ctx.session);
|
|
28
|
+
}
|
|
29
|
+
const slot = validateClusterSlot(topology, options.localNodeId, plan.keys);
|
|
30
|
+
if (slot === null || ctx.session.mode !== 'transaction') {
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
const pinnedSlot = transactionSlots.get(ctx.session);
|
|
34
|
+
if (pinnedSlot === undefined) {
|
|
35
|
+
transactionSlots.set(ctx.session, slot);
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
if (pinnedSlot !== slot) {
|
|
39
|
+
throw new redis_error_1.RedisCrossSlotError();
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
function validateClusterSlot(topology, localNodeId, keys) {
|
|
45
|
+
const slot = topology.calculateSlotForKeys(keys);
|
|
46
|
+
if (slot === null) {
|
|
47
|
+
return null;
|
|
48
|
+
}
|
|
49
|
+
if (slot === -1) {
|
|
50
|
+
throw new redis_error_1.RedisCrossSlotError();
|
|
51
|
+
}
|
|
52
|
+
if (topology.nodeOwnsSlot(localNodeId, slot)) {
|
|
53
|
+
return slot;
|
|
54
|
+
}
|
|
55
|
+
const owner = topology.getSlotOwner(slot);
|
|
56
|
+
if (!owner) {
|
|
57
|
+
throw new redis_error_1.RedisClusterDownError(slot);
|
|
58
|
+
}
|
|
59
|
+
throw new redis_error_1.RedisMovedError(slot, owner.host, owner.port);
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=cluster-policy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cluster-policy.js","sourceRoot":"","sources":["../../../src/core/execution-policies/cluster-policy.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { CommandPlan } from '../command-definition';
|
|
2
|
+
import type { RedisExecutionContext } from '../redis-context';
|
|
3
|
+
import type { RedisResult } from '../redis-result';
|
|
4
|
+
import type { ResponseStream } from '../response-stream';
|
|
5
|
+
export type PolicyResult = RedisResult | void;
|
|
6
|
+
export type MaybePromise<TValue> = TValue | Promise<TValue>;
|
|
7
|
+
export interface ExecutionPolicy {
|
|
8
|
+
readonly name: string;
|
|
9
|
+
beforeExecute?(plan: CommandPlan, ctx: RedisExecutionContext): MaybePromise<PolicyResult>;
|
|
10
|
+
afterExecute?(plan: CommandPlan, ctx: RedisExecutionContext, result: RedisResult): MaybePromise<RedisResult>;
|
|
11
|
+
onStream?(plan: CommandPlan, ctx: RedisExecutionContext, stream: ResponseStream): MaybePromise<ResponseStream | void>;
|
|
12
|
+
}
|
|
13
|
+
export { createTransactionPolicy } from './transaction-policy';
|
|
14
|
+
export type { ClusterPolicyOptions } from './cluster-policy';
|
|
15
|
+
export { createClusterPolicy } from './cluster-policy';
|
|
16
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/execution-policies/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAA;AACxD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAC7D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAA;AAClD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAA;AAExD,MAAM,MAAM,YAAY,GAAG,WAAW,GAAG,IAAI,CAAA;AAC7C,MAAM,MAAM,YAAY,CAAC,MAAM,IAAI,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;AAE3D,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IAErB,aAAa,CAAC,CACZ,IAAI,EAAE,WAAW,EACjB,GAAG,EAAE,qBAAqB,GACzB,YAAY,CAAC,YAAY,CAAC,CAAA;IAE7B,YAAY,CAAC,CACX,IAAI,EAAE,WAAW,EACjB,GAAG,EAAE,qBAAqB,EAC1B,MAAM,EAAE,WAAW,GAClB,YAAY,CAAC,WAAW,CAAC,CAAA;IAE5B,QAAQ,CAAC,CACP,IAAI,EAAE,WAAW,EACjB,GAAG,EAAE,qBAAqB,EAC1B,MAAM,EAAE,cAAc,GACrB,YAAY,CAAC,cAAc,GAAG,IAAI,CAAC,CAAA;CACvC;AAED,OAAO,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAA;AAC9D,YAAY,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAA;AAC5D,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createClusterPolicy = exports.createTransactionPolicy = void 0;
|
|
4
|
+
var transaction_policy_1 = require("./transaction-policy");
|
|
5
|
+
Object.defineProperty(exports, "createTransactionPolicy", { enumerable: true, get: function () { return transaction_policy_1.createTransactionPolicy; } });
|
|
6
|
+
var cluster_policy_1 = require("./cluster-policy");
|
|
7
|
+
Object.defineProperty(exports, "createClusterPolicy", { enumerable: true, get: function () { return cluster_policy_1.createClusterPolicy; } });
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/execution-policies/index.ts"],"names":[],"mappings":";;;AA6BA,2DAA8D;AAArD,6HAAA,uBAAuB,OAAA;AAEhC,mDAAsD;AAA7C,qHAAA,mBAAmB,OAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction-policy.d.ts","sourceRoot":"","sources":["../../../src/core/execution-policies/transaction-policy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,SAAS,CAAA;AAI9C,wBAAgB,uBAAuB,IAAI,eAAe,CAuBzD"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createTransactionPolicy = createTransactionPolicy;
|
|
4
|
+
const redis_result_1 = require("../redis-result");
|
|
5
|
+
const redis_value_1 = require("../redis-value");
|
|
6
|
+
function createTransactionPolicy() {
|
|
7
|
+
return {
|
|
8
|
+
name: 'transaction',
|
|
9
|
+
beforeExecute(plan, ctx) {
|
|
10
|
+
if (ctx.session.mode !== 'transaction') {
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
if (plan.flags.includes('transaction')) {
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
if (plan.definition.capabilities?.pushOnly) {
|
|
17
|
+
ctx.session.markTransactionDirty();
|
|
18
|
+
return redis_result_1.RedisResult.error(`${plan.definition.name.toUpperCase()} is not allowed in transactions`);
|
|
19
|
+
}
|
|
20
|
+
ctx.session.queueTransaction(plan);
|
|
21
|
+
return redis_result_1.RedisResult.create(redis_value_1.RedisValue.simpleString('QUEUED'));
|
|
22
|
+
},
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=transaction-policy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction-policy.js","sourceRoot":"","sources":["../../../src/core/execution-policies/transaction-policy.ts"],"names":[],"mappings":";;AAIA,0DAuBC;AA1BD,kDAA6C;AAC7C,gDAA2C;AAE3C,SAAgB,uBAAuB;IACrC,OAAO;QACL,IAAI,EAAE,aAAa;QACnB,aAAa,CAAC,IAAI,EAAE,GAAG;YACrB,IAAI,GAAG,CAAC,OAAO,CAAC,IAAI,KAAK,aAAa,EAAE,CAAC;gBACvC,OAAM;YACR,CAAC;YAED,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,EAAE,CAAC;gBACvC,OAAM;YACR,CAAC;YAED,IAAI,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,QAAQ,EAAE,CAAC;gBAC3C,GAAG,CAAC,OAAO,CAAC,oBAAoB,EAAE,CAAA;gBAClC,OAAO,0BAAW,CAAC,KAAK,CACtB,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,EAAE,iCAAiC,CACvE,CAAA;YACH,CAAC;YAED,GAAG,CAAC,OAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAA;YAClC,OAAO,0BAAW,CAAC,MAAM,CAAC,wBAAU,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAA;QAC9D,CAAC;KACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { type LuaWasmModule, type ReplyValue } from 'lua-redis-wasm';
|
|
2
|
+
import type { RedisExecutionContext } from './redis-context';
|
|
3
|
+
import { RedisValue } from './redis-value';
|
|
4
|
+
export type LuaReplyValue = ReplyValue;
|
|
5
|
+
export declare class RedisLuaRuntime {
|
|
6
|
+
private readonly hostState;
|
|
7
|
+
private readonly engine;
|
|
8
|
+
constructor(module: LuaWasmModule);
|
|
9
|
+
eval(script: Buffer, keys: readonly Buffer[], args: readonly Buffer[], ctx: RedisExecutionContext, sha: string): ReplyValue;
|
|
10
|
+
private runRedisCommand;
|
|
11
|
+
}
|
|
12
|
+
export declare function getDefaultRedisLuaRuntime(): Promise<RedisLuaRuntime>;
|
|
13
|
+
export declare function createRedisLuaRuntime(): Promise<RedisLuaRuntime>;
|
|
14
|
+
export declare function luaReplyToRedisValue(value: ReplyValue): RedisValue;
|
|
15
|
+
//# sourceMappingURL=lua-runtime.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lua-runtime.d.ts","sourceRoot":"","sources":["../../src/core/lua-runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,aAAa,EAClB,KAAK,UAAU,EAChB,MAAM,gBAAgB,CAAA;AAQvB,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAA;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAO1C,MAAM,MAAM,aAAa,GAAG,UAAU,CAAA;AAEtC,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAuC;IACjE,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAW;gBAEtB,MAAM,EAAE,aAAa;IAQjC,IAAI,CACF,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,SAAS,MAAM,EAAE,EACvB,IAAI,EAAE,SAAS,MAAM,EAAE,EACvB,GAAG,EAAE,qBAAqB,EAC1B,GAAG,EAAE,MAAM,GACV,UAAU;IAgBb,OAAO,CAAC,eAAe;CAoCxB;AAID,wBAAsB,yBAAyB,IAAI,OAAO,CAAC,eAAe,CAAC,CAG1E;AAED,wBAAsB,qBAAqB,IAAI,OAAO,CAAC,eAAe,CAAC,CAGtE;AAED,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,UAAU,GAAG,UAAU,CA0BlE"}
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RedisLuaRuntime = void 0;
|
|
4
|
+
exports.getDefaultRedisLuaRuntime = getDefaultRedisLuaRuntime;
|
|
5
|
+
exports.createRedisLuaRuntime = createRedisLuaRuntime;
|
|
6
|
+
exports.luaReplyToRedisValue = luaReplyToRedisValue;
|
|
7
|
+
const lua_redis_wasm_1 = require("lua-redis-wasm");
|
|
8
|
+
const redis_error_1 = require("./redis-error");
|
|
9
|
+
const redis_value_1 = require("./redis-value");
|
|
10
|
+
class RedisLuaRuntime {
|
|
11
|
+
hostState = { ctx: null, sha: '' };
|
|
12
|
+
engine;
|
|
13
|
+
constructor(module) {
|
|
14
|
+
this.engine = module.create({
|
|
15
|
+
redisCall: args => this.runRedisCommand(args),
|
|
16
|
+
redisPcall: args => this.runRedisCommand(args),
|
|
17
|
+
log: () => { },
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
eval(script, keys, args, ctx, sha) {
|
|
21
|
+
if (this.hostState.ctx) {
|
|
22
|
+
throw new redis_error_1.RedisCommandError('Lua runtime is already executing a script');
|
|
23
|
+
}
|
|
24
|
+
this.hostState.ctx = ctx;
|
|
25
|
+
this.hostState.sha = sha;
|
|
26
|
+
try {
|
|
27
|
+
return this.engine.evalWithArgs(script, [...keys], [...args]);
|
|
28
|
+
}
|
|
29
|
+
finally {
|
|
30
|
+
this.hostState.ctx = null;
|
|
31
|
+
this.hostState.sha = '';
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
runRedisCommand(args) {
|
|
35
|
+
const ctx = this.hostState.ctx;
|
|
36
|
+
if (!ctx) {
|
|
37
|
+
throw new Error('ERR Lua runtime is not initialized');
|
|
38
|
+
}
|
|
39
|
+
if (args.length === 0) {
|
|
40
|
+
return redisErrorToLuaReply(new redis_error_1.ScriptCallNoCommandError());
|
|
41
|
+
}
|
|
42
|
+
let plan;
|
|
43
|
+
try {
|
|
44
|
+
plan = ctx.executor.plan(args[0], args.slice(1));
|
|
45
|
+
}
|
|
46
|
+
catch (err) {
|
|
47
|
+
if (err instanceof redis_error_1.UnknownRedisCommandError) {
|
|
48
|
+
return redisErrorToLuaReply(new redis_error_1.ScriptUnknownCommandError(this.hostState.sha));
|
|
49
|
+
}
|
|
50
|
+
if (err instanceof redis_error_1.RedisCommandError) {
|
|
51
|
+
return redisErrorToLuaReply(err);
|
|
52
|
+
}
|
|
53
|
+
throw err;
|
|
54
|
+
}
|
|
55
|
+
if (plan.flags.includes('noscript')) {
|
|
56
|
+
return redisErrorToLuaReply(new redis_error_1.ScriptUnknownCommandError(this.hostState.sha));
|
|
57
|
+
}
|
|
58
|
+
const result = ctx.executor.executePlanSync(plan, ctx);
|
|
59
|
+
return redisValueToLuaReply(result.value);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
exports.RedisLuaRuntime = RedisLuaRuntime;
|
|
63
|
+
let defaultRuntimePromise = null;
|
|
64
|
+
async function getDefaultRedisLuaRuntime() {
|
|
65
|
+
defaultRuntimePromise ??= createRedisLuaRuntime();
|
|
66
|
+
return defaultRuntimePromise;
|
|
67
|
+
}
|
|
68
|
+
async function createRedisLuaRuntime() {
|
|
69
|
+
const module = await (0, lua_redis_wasm_1.load)();
|
|
70
|
+
return new RedisLuaRuntime(module);
|
|
71
|
+
}
|
|
72
|
+
function luaReplyToRedisValue(value) {
|
|
73
|
+
if (value === null || value === undefined) {
|
|
74
|
+
return redis_value_1.RedisValue.null();
|
|
75
|
+
}
|
|
76
|
+
if (typeof value === 'number' || typeof value === 'bigint') {
|
|
77
|
+
return redis_value_1.RedisValue.integer(value);
|
|
78
|
+
}
|
|
79
|
+
if (Buffer.isBuffer(value)) {
|
|
80
|
+
return redis_value_1.RedisValue.bulkString(value);
|
|
81
|
+
}
|
|
82
|
+
if (Array.isArray(value)) {
|
|
83
|
+
return redis_value_1.RedisValue.array(value.map(luaReplyToRedisValue));
|
|
84
|
+
}
|
|
85
|
+
if ('ok' in value) {
|
|
86
|
+
return redis_value_1.RedisValue.simpleString(value.ok.toString());
|
|
87
|
+
}
|
|
88
|
+
if ('err' in value) {
|
|
89
|
+
return luaErrorToRedisValue(value.err.toString());
|
|
90
|
+
}
|
|
91
|
+
return redis_value_1.RedisValue.bulkString(Buffer.from(String(value)));
|
|
92
|
+
}
|
|
93
|
+
function redisValueToLuaReply(value) {
|
|
94
|
+
switch (value.kind) {
|
|
95
|
+
case 'simple-string':
|
|
96
|
+
return { ok: Buffer.from(value.value) };
|
|
97
|
+
case 'bulk-string':
|
|
98
|
+
return value.value;
|
|
99
|
+
case 'integer':
|
|
100
|
+
return value.value;
|
|
101
|
+
case 'double':
|
|
102
|
+
return Buffer.from(formatNumber(value.value));
|
|
103
|
+
case 'boolean':
|
|
104
|
+
return value.value ? 1 : 0;
|
|
105
|
+
case 'big-number':
|
|
106
|
+
return Buffer.from(value.value.toString());
|
|
107
|
+
case 'verbatim':
|
|
108
|
+
return value.value;
|
|
109
|
+
case 'array':
|
|
110
|
+
return value.items.map(redisValueToLuaReply);
|
|
111
|
+
case 'set':
|
|
112
|
+
return value.items.map(redisValueToLuaReply);
|
|
113
|
+
case 'map':
|
|
114
|
+
return value.entries.flatMap(([key, entryValue]) => [
|
|
115
|
+
redisValueToLuaReply(key),
|
|
116
|
+
redisValueToLuaReply(entryValue),
|
|
117
|
+
]);
|
|
118
|
+
case 'push':
|
|
119
|
+
return [Buffer.from(value.name), ...value.items.map(redisValueToLuaReply)];
|
|
120
|
+
case 'null':
|
|
121
|
+
case 'null-array':
|
|
122
|
+
return null;
|
|
123
|
+
case 'error':
|
|
124
|
+
return {
|
|
125
|
+
err: Buffer.from(formatRedisErrorValue(value)),
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
function redisErrorToLuaReply(err) {
|
|
130
|
+
return {
|
|
131
|
+
err: Buffer.from(formatRedisError(err.message, err.code)),
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
function luaErrorToRedisValue(message) {
|
|
135
|
+
const match = /^([A-Z][A-Z0-9]*) (.+)$/.exec(message);
|
|
136
|
+
if (!match) {
|
|
137
|
+
return redis_value_1.RedisValue.error(message, 'ERR');
|
|
138
|
+
}
|
|
139
|
+
return redis_value_1.RedisValue.error(match[2], match[1]);
|
|
140
|
+
}
|
|
141
|
+
function formatRedisErrorValue(value) {
|
|
142
|
+
return formatRedisError(value.message, value.code);
|
|
143
|
+
}
|
|
144
|
+
function formatRedisError(message, code) {
|
|
145
|
+
const sanitizedMessage = sanitizeErrorText(message);
|
|
146
|
+
if (!code) {
|
|
147
|
+
return sanitizedMessage;
|
|
148
|
+
}
|
|
149
|
+
const sanitizedCode = sanitizeErrorText(code);
|
|
150
|
+
if (sanitizedMessage.startsWith(`${sanitizedCode} `)) {
|
|
151
|
+
return sanitizedMessage;
|
|
152
|
+
}
|
|
153
|
+
return `${sanitizedCode} ${sanitizedMessage}`;
|
|
154
|
+
}
|
|
155
|
+
function formatNumber(value) {
|
|
156
|
+
if (Number.isNaN(value)) {
|
|
157
|
+
return 'nan';
|
|
158
|
+
}
|
|
159
|
+
if (value === Infinity) {
|
|
160
|
+
return 'inf';
|
|
161
|
+
}
|
|
162
|
+
if (value === -Infinity) {
|
|
163
|
+
return '-inf';
|
|
164
|
+
}
|
|
165
|
+
if (Object.is(value, -0)) {
|
|
166
|
+
return '-0';
|
|
167
|
+
}
|
|
168
|
+
return value.toString();
|
|
169
|
+
}
|
|
170
|
+
function sanitizeErrorText(value) {
|
|
171
|
+
return value.replace(/[\r\n]+/g, ' ');
|
|
172
|
+
}
|
|
173
|
+
//# sourceMappingURL=lua-runtime.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lua-runtime.js","sourceRoot":"","sources":["../../src/core/lua-runtime.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import type { RedisDatabase, RedisServerState } from '../state';
|
|
2
|
+
import type { CommandExecutor } from './command-executor';
|
|
3
|
+
import type { CommandPlan } from './command-definition';
|
|
4
|
+
import type { RedisResult } from './redis-result';
|
|
5
|
+
import type { RespVersion } from './resp-encoder';
|
|
6
|
+
export type ParkRequest<TValue> = {
|
|
7
|
+
waitFor: Promise<TValue | null>;
|
|
8
|
+
timeoutMs?: number;
|
|
9
|
+
signal: AbortSignal;
|
|
10
|
+
};
|
|
11
|
+
export type ParkHandler = <TValue>(request: ParkRequest<TValue>) => Promise<TValue | null>;
|
|
12
|
+
export type ClientSessionMode = 'normal' | 'transaction' | 'subscribed';
|
|
13
|
+
export interface RedisClientSession {
|
|
14
|
+
readonly id: string;
|
|
15
|
+
readonly selectedDatabase: number;
|
|
16
|
+
readonly mode: ClientSessionMode;
|
|
17
|
+
readonly protocolVersion: RespVersion;
|
|
18
|
+
setProtocolVersion(version: RespVersion): void;
|
|
19
|
+
selectDatabase(database: number): void;
|
|
20
|
+
beginTransaction(): void;
|
|
21
|
+
queueTransaction(plan: CommandPlan): void;
|
|
22
|
+
drainTransaction(): CommandPlan[];
|
|
23
|
+
discardTransaction(): void;
|
|
24
|
+
markTransactionDirty(): void;
|
|
25
|
+
isTransactionDirty(): boolean;
|
|
26
|
+
executeTransaction(plans: readonly CommandPlan[]): Promise<RedisResult>;
|
|
27
|
+
watch(keys: readonly Buffer[]): void;
|
|
28
|
+
unwatch(): void;
|
|
29
|
+
isWatchDirty(): boolean;
|
|
30
|
+
}
|
|
31
|
+
export interface RedisExecutionContext {
|
|
32
|
+
readonly db: RedisDatabase;
|
|
33
|
+
readonly server: RedisServerState;
|
|
34
|
+
readonly session: RedisClientSession;
|
|
35
|
+
readonly executor: CommandExecutor;
|
|
36
|
+
readonly signal: AbortSignal;
|
|
37
|
+
park: ParkHandler;
|
|
38
|
+
}
|
|
39
|
+
export declare function createDefaultParkHandler(): ParkHandler;
|
|
40
|
+
export declare function createNoopParkHandler(): ParkHandler;
|
|
41
|
+
//# sourceMappingURL=redis-context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis-context.d.ts","sourceRoot":"","sources":["../../src/core/redis-context.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAA;AAC/D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AACzD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAA;AACvD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AACjD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAEjD,MAAM,MAAM,WAAW,CAAC,MAAM,IAAI;IAChC,OAAO,EAAE,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAA;IAC/B,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,WAAW,CAAA;CACpB,CAAA;AAED,MAAM,MAAM,WAAW,GAAG,CAAC,MAAM,EAC/B,OAAO,EAAE,WAAW,CAAC,MAAM,CAAC,KACzB,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAA;AAE3B,MAAM,MAAM,iBAAiB,GAAG,QAAQ,GAAG,aAAa,GAAG,YAAY,CAAA;AAEvE,MAAM,WAAW,kBAAkB;IACjC,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAA;IACnB,QAAQ,CAAC,gBAAgB,EAAE,MAAM,CAAA;IACjC,QAAQ,CAAC,IAAI,EAAE,iBAAiB,CAAA;IAChC,QAAQ,CAAC,eAAe,EAAE,WAAW,CAAA;IACrC,kBAAkB,CAAC,OAAO,EAAE,WAAW,GAAG,IAAI,CAAA;IAC9C,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACtC,gBAAgB,IAAI,IAAI,CAAA;IACxB,gBAAgB,CAAC,IAAI,EAAE,WAAW,GAAG,IAAI,CAAA;IACzC,gBAAgB,IAAI,WAAW,EAAE,CAAA;IACjC,kBAAkB,IAAI,IAAI,CAAA;IAC1B,oBAAoB,IAAI,IAAI,CAAA;IAC5B,kBAAkB,IAAI,OAAO,CAAA;IAC7B,kBAAkB,CAAC,KAAK,EAAE,SAAS,WAAW,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC,CAAA;IACvE,KAAK,CAAC,IAAI,EAAE,SAAS,MAAM,EAAE,GAAG,IAAI,CAAA;IACpC,OAAO,IAAI,IAAI,CAAA;IACf,YAAY,IAAI,OAAO,CAAA;CACxB;AAED,MAAM,WAAW,qBAAqB;IACpC,QAAQ,CAAC,EAAE,EAAE,aAAa,CAAA;IAC1B,QAAQ,CAAC,MAAM,EAAE,gBAAgB,CAAA;IACjC,QAAQ,CAAC,OAAO,EAAE,kBAAkB,CAAA;IACpC,QAAQ,CAAC,QAAQ,EAAE,eAAe,CAAA;IAClC,QAAQ,CAAC,MAAM,EAAE,WAAW,CAAA;IAC5B,IAAI,EAAE,WAAW,CAAA;CAClB;AAED,wBAAgB,wBAAwB,IAAI,WAAW,CA0CtD;AAED,wBAAgB,qBAAqB,IAAI,WAAW,CAEnD"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createDefaultParkHandler = createDefaultParkHandler;
|
|
4
|
+
exports.createNoopParkHandler = createNoopParkHandler;
|
|
5
|
+
function createDefaultParkHandler() {
|
|
6
|
+
return request => new Promise((resolve, reject) => {
|
|
7
|
+
if (request.signal.aborted) {
|
|
8
|
+
reject(createAbortError());
|
|
9
|
+
return;
|
|
10
|
+
}
|
|
11
|
+
let settled = false;
|
|
12
|
+
let timer;
|
|
13
|
+
const cleanup = () => {
|
|
14
|
+
if (timer) {
|
|
15
|
+
clearTimeout(timer);
|
|
16
|
+
}
|
|
17
|
+
request.signal.removeEventListener('abort', onAbort);
|
|
18
|
+
};
|
|
19
|
+
const settle = (callback) => {
|
|
20
|
+
if (settled)
|
|
21
|
+
return;
|
|
22
|
+
settled = true;
|
|
23
|
+
cleanup();
|
|
24
|
+
callback();
|
|
25
|
+
};
|
|
26
|
+
const onAbort = () => {
|
|
27
|
+
settle(() => reject(createAbortError()));
|
|
28
|
+
};
|
|
29
|
+
request.signal.addEventListener('abort', onAbort, { once: true });
|
|
30
|
+
if (request.timeoutMs !== undefined) {
|
|
31
|
+
timer = setTimeout(() => {
|
|
32
|
+
settle(() => resolve(null));
|
|
33
|
+
}, request.timeoutMs);
|
|
34
|
+
}
|
|
35
|
+
request.waitFor.then(value => settle(() => resolve(value)), err => settle(() => reject(err)));
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
function createNoopParkHandler() {
|
|
39
|
+
return createDefaultParkHandler();
|
|
40
|
+
}
|
|
41
|
+
function createAbortError() {
|
|
42
|
+
const err = new Error('The operation was aborted');
|
|
43
|
+
err.name = 'AbortError';
|
|
44
|
+
return err;
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=redis-context.js.map
|