1
0
mirror of https://github.com/redis/node-redis.git synced 2025-08-03 04:01:40 +03:00
Files
Bobby I. 20c16e0c2c (docs) add jsdoc comments to command parsers (#2984)
* (docs) bloom: add jsdocs for all commands

* (docs) json: add jsdocs

* (docs) search: add jsdocs for all commands

* (docs) jsdocs for std commands

* (docs) jsdoc comments to time series commands
2025-06-03 14:38:07 +03:00

97 lines
2.6 KiB
TypeScript

import { CommandParser } from '../client/parser';
import { RedisArgument, SimpleStringReply, BlobStringReply, NullReply, Command } from '../RESP/types';
export interface SetOptions {
expiration?: {
type: 'EX' | 'PX' | 'EXAT' | 'PXAT';
value: number;
} | {
type: 'KEEPTTL';
} | 'KEEPTTL';
/**
* @deprecated Use `expiration` { type: 'EX', value: number } instead
*/
EX?: number;
/**
* @deprecated Use `expiration` { type: 'PX', value: number } instead
*/
PX?: number;
/**
* @deprecated Use `expiration` { type: 'EXAT', value: number } instead
*/
EXAT?: number;
/**
* @deprecated Use `expiration` { type: 'PXAT', value: number } instead
*/
PXAT?: number;
/**
* @deprecated Use `expiration` 'KEEPTTL' instead
*/
KEEPTTL?: boolean;
condition?: 'NX' | 'XX';
/**
* @deprecated Use `{ condition: 'NX' }` instead.
*/
NX?: boolean;
/**
* @deprecated Use `{ condition: 'XX' }` instead.
*/
XX?: boolean;
GET?: boolean;
}
export default {
/**
* Constructs the SET command
*
* @param parser - The command parser
* @param key - The key to set
* @param value - The value to set
* @param options - Additional options for the SET command
* @see https://redis.io/commands/set/
*/
parseCommand(parser: CommandParser, key: RedisArgument, value: RedisArgument | number, options?: SetOptions) {
parser.push('SET');
parser.pushKey(key);
parser.push(typeof value === 'number' ? value.toString() : value);
if (options?.expiration) {
if (typeof options.expiration === 'string') {
parser.push(options.expiration);
} else if (options.expiration.type === 'KEEPTTL') {
parser.push('KEEPTTL');
} else {
parser.push(
options.expiration.type,
options.expiration.value.toString()
);
}
} else if (options?.EX !== undefined) {
parser.push('EX', options.EX.toString());
} else if (options?.PX !== undefined) {
parser.push('PX', options.PX.toString());
} else if (options?.EXAT !== undefined) {
parser.push('EXAT', options.EXAT.toString());
} else if (options?.PXAT !== undefined) {
parser.push('PXAT', options.PXAT.toString());
} else if (options?.KEEPTTL) {
parser.push('KEEPTTL');
}
if (options?.condition) {
parser.push(options.condition);
} else if (options?.NX) {
parser.push('NX');
} else if (options?.XX) {
parser.push('XX');
}
if (options?.GET) {
parser.push('GET');
}
},
transformReply: undefined as unknown as () => SimpleStringReply<'OK'> | BlobStringReply | NullReply
} as const satisfies Command;