hazelcast-client
Version:
Hazelcast - open source In-Memory Data Grid - client for NodeJS
54 lines • 2.36 kB
JavaScript
var ClientMessage = require('../ClientMessage');
var BitsUtil_1 = require('../BitsUtil');
var MapMessageType_1 = require('./MapMessageType');
var REQUEST_TYPE = MapMessageType_1.MapMessageType.MAP_EXECUTEONKEYS;
var RESPONSE_TYPE = 117;
var RETRYABLE = false;
var MapExecuteOnKeysCodec = (function () {
function MapExecuteOnKeysCodec() {
}
MapExecuteOnKeysCodec.calculateSize = function (name, entryProcessor, keys) {
var dataSize = 0;
dataSize += BitsUtil_1.BitsUtil.calculateSizeString(name);
dataSize += BitsUtil_1.BitsUtil.calculateSizeData(entryProcessor);
dataSize += BitsUtil_1.BitsUtil.INT_SIZE_IN_BYTES;
keys.forEach(function (keysItem) {
dataSize += BitsUtil_1.BitsUtil.calculateSizeData(keysItem);
});
return dataSize;
};
MapExecuteOnKeysCodec.encodeRequest = function (name, entryProcessor, keys) {
var clientMessage = ClientMessage.newClientMessage(this.calculateSize(name, entryProcessor, keys));
clientMessage.setMessageType(REQUEST_TYPE);
clientMessage.setRetryable(RETRYABLE);
clientMessage.appendString(name);
clientMessage.appendData(entryProcessor);
clientMessage.appendInt32(keys.length);
keys.forEach(function (keysItem) {
clientMessage.appendData(keysItem);
});
clientMessage.updateFrameLength();
return clientMessage;
};
MapExecuteOnKeysCodec.decodeResponse = function (clientMessage, toObjectFunction) {
if (toObjectFunction === void 0) { toObjectFunction = null; }
var parameters = { 'response': null };
var responseSize = clientMessage.readInt32();
var response = [];
for (var responseIndex = 0; responseIndex < responseSize; responseIndex++) {
var responseItem;
var responseItemKey;
var responseItemVal;
responseItemKey = clientMessage.readData();
responseItemVal = clientMessage.readData();
responseItem = [responseItemKey, responseItemVal];
response.push(responseItem);
}
parameters['response'] = response;
return parameters;
};
return MapExecuteOnKeysCodec;
}());
exports.MapExecuteOnKeysCodec = MapExecuteOnKeysCodec;
//# sourceMappingURL=MapExecuteOnKeysCodec.js.map
;