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

123 lines
3.1 KiB
TypeScript

import { CommandParser } from '@redis/client/dist/lib/client/parser';
import { RedisArgument, Command } from '@redis/client/dist/lib/RESP/types';
import { Timestamp, transformTimestampArgument, SamplesRawReply, transformSamplesReply } from './helpers';
import { TimeSeriesAggregationType } from './CREATERULE';
import { Resp2Reply } from '@redis/client/dist/lib/RESP/types';
export const TIME_SERIES_BUCKET_TIMESTAMP = {
LOW: '-',
MIDDLE: '~',
END: '+'
};
export type TimeSeriesBucketTimestamp = typeof TIME_SERIES_BUCKET_TIMESTAMP[keyof typeof TIME_SERIES_BUCKET_TIMESTAMP];
export interface TsRangeOptions {
LATEST?: boolean;
FILTER_BY_TS?: Array<Timestamp>;
FILTER_BY_VALUE?: {
min: number;
max: number;
};
COUNT?: number;
ALIGN?: Timestamp;
AGGREGATION?: {
ALIGN?: Timestamp;
type: TimeSeriesAggregationType;
timeBucket: Timestamp;
BUCKETTIMESTAMP?: TimeSeriesBucketTimestamp;
EMPTY?: boolean;
};
}
export function parseRangeArguments(
parser: CommandParser,
fromTimestamp: Timestamp,
toTimestamp: Timestamp,
options?: TsRangeOptions
) {
parser.push(
transformTimestampArgument(fromTimestamp),
transformTimestampArgument(toTimestamp)
);
if (options?.LATEST) {
parser.push('LATEST');
}
if (options?.FILTER_BY_TS) {
parser.push('FILTER_BY_TS');
for (const timestamp of options.FILTER_BY_TS) {
parser.push(transformTimestampArgument(timestamp));
}
}
if (options?.FILTER_BY_VALUE) {
parser.push(
'FILTER_BY_VALUE',
options.FILTER_BY_VALUE.min.toString(),
options.FILTER_BY_VALUE.max.toString()
);
}
if (options?.COUNT !== undefined) {
parser.push('COUNT', options.COUNT.toString());
}
if (options?.AGGREGATION) {
if (options?.ALIGN !== undefined) {
parser.push('ALIGN', transformTimestampArgument(options.ALIGN));
}
parser.push(
'AGGREGATION',
options.AGGREGATION.type,
transformTimestampArgument(options.AGGREGATION.timeBucket)
);
if (options.AGGREGATION.BUCKETTIMESTAMP) {
parser.push(
'BUCKETTIMESTAMP',
options.AGGREGATION.BUCKETTIMESTAMP
);
}
if (options.AGGREGATION.EMPTY) {
parser.push('EMPTY');
}
}
}
export function transformRangeArguments(
parser: CommandParser,
key: RedisArgument,
fromTimestamp: Timestamp,
toTimestamp: Timestamp,
options?: TsRangeOptions
) {
parser.pushKey(key);
parseRangeArguments(parser, fromTimestamp, toTimestamp, options);
}
export default {
IS_READ_ONLY: true,
/**
* Gets samples from a time series within a time range
* @param args - Arguments passed to the {@link transformRangeArguments} function
*/
parseCommand(...args: Parameters<typeof transformRangeArguments>) {
const parser = args[0];
parser.push('TS.RANGE');
transformRangeArguments(...args);
},
transformReply: {
2(reply: Resp2Reply<SamplesRawReply>) {
return transformSamplesReply[2](reply);
},
3(reply: SamplesRawReply) {
return transformSamplesReply[3](reply);
}
}
} as const satisfies Command;