Files
micro-service-api/node_modules/@redis/client/dist/lib/commands/XPENDING_RANGE.js
2025-11-11 12:36:06 +07:00

49 lines
1.7 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.default = {
CACHEABLE: true,
IS_READ_ONLY: true,
/**
* Constructs the XPENDING command with range parameters to get detailed information about pending messages
*
* @param parser - The command parser
* @param key - The stream key
* @param group - Name of the consumer group
* @param start - Start of ID range (use '-' for minimum ID)
* @param end - End of ID range (use '+' for maximum ID)
* @param count - Maximum number of messages to return
* @param options - Additional filtering options
* @returns Array of pending message details
* @see https://redis.io/commands/xpending/
*/
parseCommand(parser, key, group, start, end, count, options) {
parser.push('XPENDING');
parser.pushKey(key);
parser.push(group);
if (options?.IDLE !== undefined) {
parser.push('IDLE', options.IDLE.toString());
}
parser.push(start, end, count.toString());
if (options?.consumer) {
parser.push(options.consumer);
}
},
/**
* Transforms the raw XPENDING RANGE reply into a structured array of message details
*
* @param reply - Raw reply from Redis
* @returns Array of objects containing message ID, consumer, idle time, and delivery count
*/
transformReply(reply) {
return reply.map(pending => {
const unwrapped = pending;
return {
id: unwrapped[0],
consumer: unwrapped[1],
millisecondsSinceLastDelivery: unwrapped[2],
deliveriesCounter: unwrapped[3]
};
});
}
};
//# sourceMappingURL=XPENDING_RANGE.js.map