Files
micro-service-api/node_modules/@redis/time-series/dist/lib/commands/MRANGE_GROUPBY.js

88 lines
3.1 KiB
JavaScript
Raw Normal View History

2025-11-11 12:36:06 +07:00
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.extractResp3MRangeSources = exports.createTransformMRangeGroupByArguments = exports.parseGroupByArguments = exports.TIME_SERIES_REDUCERS = void 0;
const helpers_1 = require("./helpers");
const RANGE_1 = require("./RANGE");
const MGET_1 = require("./MGET");
exports.TIME_SERIES_REDUCERS = {
AVG: 'AVG',
SUM: 'SUM',
MIN: 'MIN',
MAX: 'MAX',
RANGE: 'RANGE',
COUNT: 'COUNT',
STD_P: 'STD.P',
STD_S: 'STD.S',
VAR_P: 'VAR.P',
VAR_S: 'VAR.S'
};
/**
* Adds GROUPBY arguments to command
* @param parser - The command parser
* @param groupBy - Group by parameters
*/
function parseGroupByArguments(parser, groupBy) {
parser.push('GROUPBY', groupBy.label, 'REDUCE', groupBy.REDUCE);
}
exports.parseGroupByArguments = parseGroupByArguments;
/**
* Creates a function that parses arguments for multi-range commands with grouping
* @param command - The command name to use (TS.MRANGE or TS.MREVRANGE)
*/
function createTransformMRangeGroupByArguments(command) {
return (parser, fromTimestamp, toTimestamp, filter, groupBy, options) => {
parser.push(command);
(0, RANGE_1.parseRangeArguments)(parser, fromTimestamp, toTimestamp, options);
(0, MGET_1.parseFilterArgument)(parser, filter);
parseGroupByArguments(parser, groupBy);
};
}
exports.createTransformMRangeGroupByArguments = createTransformMRangeGroupByArguments;
/**
* Extracts source keys from RESP3 metadata reply
* @param raw - Raw metadata from RESP3 reply
*/
function extractResp3MRangeSources(raw) {
const unwrappedMetadata2 = raw;
if (unwrappedMetadata2 instanceof Map) {
return unwrappedMetadata2.get('sources');
}
else if (unwrappedMetadata2 instanceof Array) {
return unwrappedMetadata2[1];
}
else {
return unwrappedMetadata2.sources;
}
}
exports.extractResp3MRangeSources = extractResp3MRangeSources;
exports.default = {
IS_READ_ONLY: true,
/**
* Gets samples for time series matching a filter within a time range with grouping
* @param parser - The command parser
* @param fromTimestamp - Start timestamp for range
* @param toTimestamp - End timestamp for range
* @param filter - Filter to match time series keys
* @param groupBy - Group by parameters
* @param options - Optional parameters for the command
*/
parseCommand: createTransformMRangeGroupByArguments('TS.MRANGE'),
transformReply: {
2(reply, _, typeMapping) {
return (0, helpers_1.resp2MapToValue)(reply, ([_key, _labels, samples]) => {
return {
samples: helpers_1.transformSamplesReply[2](samples)
};
}, typeMapping);
},
3(reply) {
return (0, helpers_1.resp3MapToValue)(reply, ([_labels, _metadata1, metadata2, samples]) => {
return {
sources: extractResp3MRangeSources(metadata2),
samples: helpers_1.transformSamplesReply[3](samples)
};
});
}
},
};
//# sourceMappingURL=MRANGE_GROUPBY.js.map