-first commit
This commit is contained in:
88
node_modules/@redis/time-series/dist/lib/commands/MRANGE_GROUPBY.js
generated
vendored
Normal file
88
node_modules/@redis/time-series/dist/lib/commands/MRANGE_GROUPBY.js
generated
vendored
Normal file
@@ -0,0 +1,88 @@
|
||||
"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
|
||||
Reference in New Issue
Block a user