You've already forked node-redis
mirror of
https://github.com/redis/node-redis.git
synced 2025-08-07 13:22:56 +03:00
some commands
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
import { RedisArgument, BlobStringReply, Command } from '../RESP/types';
|
||||
import { RedisArgument, BlobStringReply, Command, CommandArguments } from '../RESP/types';
|
||||
|
||||
export interface XAddOptions {
|
||||
TRIM?: {
|
||||
@@ -9,6 +9,37 @@ export interface XAddOptions {
|
||||
};
|
||||
}
|
||||
|
||||
export function pushXAddArguments(
|
||||
args: CommandArguments,
|
||||
id: RedisArgument,
|
||||
message: Record<string, RedisArgument>,
|
||||
options?: XAddOptions
|
||||
) {
|
||||
if (options?.TRIM) {
|
||||
if (options.TRIM.strategy) {
|
||||
args.push(options.TRIM.strategy);
|
||||
}
|
||||
|
||||
if (options.TRIM.strategyModifier) {
|
||||
args.push(options.TRIM.strategyModifier);
|
||||
}
|
||||
|
||||
args.push(options.TRIM.threshold.toString());
|
||||
|
||||
if (options.TRIM.limit) {
|
||||
args.push('LIMIT', options.TRIM.limit.toString());
|
||||
}
|
||||
}
|
||||
|
||||
args.push(id);
|
||||
|
||||
for (const [key, value] of Object.entries(message)) {
|
||||
args.push(key, value);
|
||||
}
|
||||
|
||||
return args;
|
||||
}
|
||||
|
||||
export default {
|
||||
FIRST_KEY_INDEX: 1,
|
||||
IS_READ_ONLY: false,
|
||||
@@ -18,31 +49,7 @@ export default {
|
||||
message: Record<string, RedisArgument>,
|
||||
options?: XAddOptions
|
||||
) {
|
||||
const args = ['XADD', key];
|
||||
|
||||
if (options?.TRIM) {
|
||||
if (options.TRIM.strategy) {
|
||||
args.push(options.TRIM.strategy);
|
||||
}
|
||||
|
||||
if (options.TRIM.strategyModifier) {
|
||||
args.push(options.TRIM.strategyModifier);
|
||||
}
|
||||
|
||||
args.push(options.TRIM.threshold.toString());
|
||||
|
||||
if (options.TRIM.limit) {
|
||||
args.push('LIMIT', options.TRIM.limit.toString());
|
||||
}
|
||||
}
|
||||
|
||||
args.push(id);
|
||||
|
||||
for (const [key, value] of Object.entries(message)) {
|
||||
args.push(key, value);
|
||||
}
|
||||
|
||||
return args;
|
||||
return pushXAddArguments(['XADD', key], id, message, options);
|
||||
},
|
||||
transformReply: undefined as unknown as () => BlobStringReply
|
||||
} as const satisfies Command;
|
||||
|
Reference in New Issue
Block a user