1
0
mirror of https://github.com/redis/node-redis.git synced 2025-08-04 15:02:09 +03:00

V5 bringing RESP3, Sentinel and TypeMapping to node-redis

RESP3 Support
   - Some commands responses in RESP3 aren't stable yet and therefore return an "untyped" ReplyUnion.
 
Sentinel

TypeMapping

Correctly types Multi commands

Note: some API changes to be further documented in v4-to-v5.md
This commit is contained in:
Shaya Potter
2024-10-15 17:46:52 +03:00
committed by GitHub
parent 2fc79bdfb3
commit b2d35c5286
1174 changed files with 45931 additions and 36274 deletions

View File

@@ -1,53 +1,65 @@
import { RedisCommandArgument, RedisCommandArguments } from '.';
import { GeoCoordinates } from './generic-transformers';
import { RedisArgument, CommandArguments, NumberReply, Command } from '../RESP/types';
import { GeoCoordinates } from './GEOSEARCH';
export const FIRST_KEY_INDEX = 1;
interface GeoMember extends GeoCoordinates {
member: RedisCommandArgument;
export interface GeoMember extends GeoCoordinates {
member: RedisArgument;
}
interface NX {
NX?: true;
export interface GeoAddOptions {
condition?: 'NX' | 'XX';
/**
* @deprecated Use `{ condition: 'NX' }` instead.
*/
NX?: boolean;
/**
* @deprecated Use `{ condition: 'XX' }` instead.
*/
XX?: boolean;
CH?: boolean;
}
interface XX {
XX?: true;
}
type SetGuards = NX | XX;
interface GeoAddCommonOptions {
CH?: true;
}
type GeoAddOptions = SetGuards & GeoAddCommonOptions;
export function transformArguments(
key: RedisCommandArgument, toAdd: GeoMember | Array<GeoMember>,
export default {
FIRST_KEY_INDEX: 1,
IS_READ_ONLY: false,
transformArguments(
key: RedisArgument,
toAdd: GeoMember | Array<GeoMember>,
options?: GeoAddOptions
): RedisCommandArguments {
) {
const args = ['GEOADD', key];
if ((options as NX)?.NX) {
args.push('NX');
} else if ((options as XX)?.XX) {
args.push('XX');
if (options?.condition) {
args.push(options.condition);
} else if (options?.NX) {
args.push('NX');
} else if (options?.XX) {
args.push('XX');
}
if (options?.CH) {
args.push('CH');
args.push('CH');
}
for (const { longitude, latitude, member } of (Array.isArray(toAdd) ? toAdd : [toAdd])) {
args.push(
longitude.toString(),
latitude.toString(),
member
);
if (Array.isArray(toAdd)) {
for (const member of toAdd) {
pushMember(args, member);
}
} else {
pushMember(args, toAdd);
}
return args;
}
},
transformReply: undefined as unknown as () => NumberReply
} as const satisfies Command;
export declare function transformReply(): number;
function pushMember(
args: CommandArguments,
{ longitude, latitude, member }: GeoMember
) {
args.push(
longitude.toString(),
latitude.toString(),
member
);
}