UNPKG

redis-smq

Version:

A simple high-performance Redis message queue for Node.js.

62 lines 3.45 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports._deleteMessage = _deleteMessage; const redis_smq_common_1 = require("redis-smq-common"); const scripts_js_1 = require("../../../common/redis-client/scripts/scripts.js"); const redis_keys_js_1 = require("../../../common/redis-keys/redis-keys.js"); const index_js_1 = require("../../queue/index.js"); const index_js_2 = require("../errors/index.js"); const index_js_3 = require("../types/index.js"); const _get_message_js_1 = require("./_get-message.js"); function _deleteMessage(redisClient, messageId, cb) { const keys = []; const argv = []; const ids = typeof messageId === 'string' ? [messageId] : messageId; argv.push(index_js_1.EQueueProperty.QUEUE_TYPE, index_js_1.EQueueProperty.MESSAGES_COUNT, index_js_1.EQueueType.PRIORITY_QUEUE, index_js_1.EQueueType.LIFO_QUEUE, index_js_1.EQueueType.FIFO_QUEUE, index_js_3.EMessageProperty.STATUS, index_js_3.EMessagePropertyStatus.PROCESSING, index_js_3.EMessagePropertyStatus.ACKNOWLEDGED, index_js_3.EMessagePropertyStatus.PENDING, index_js_3.EMessagePropertyStatus.SCHEDULED, index_js_3.EMessagePropertyStatus.DEAD_LETTERED, index_js_3.EMessagePropertyStatus.UNACK_DELAYING, index_js_3.EMessagePropertyStatus.UNACK_REQUEUING); redis_smq_common_1.async.each(ids, (id, _, done) => { (0, _get_message_js_1._getMessage)(redisClient, id, (err, message) => { if (err) done(err); else if (!message) done(new redis_smq_common_1.CallbackEmptyReplyError()); else { const { keyQueueScheduled, keyQueueDelayed, keyQueueRequeued, keyQueueProperties, keyQueueDL, keyQueueAcknowledged, keyQueuePriorityPending, keyQueuePending, } = redis_keys_js_1.redisKeys.getQueueKeys(message.getDestinationQueue(), message.getConsumerGroupId()); const { keyMessage } = redis_keys_js_1.redisKeys.getMessageKeys(id); keys.push(keyQueueScheduled, keyQueueDelayed, keyQueueRequeued, keyMessage, keyQueueProperties, keyQueuePending, keyQueueDL, keyQueueAcknowledged, keyQueuePriorityPending); argv.push(id); done(); } }); }, (err) => { if (err) cb(err); else if (keys.length && argv.length) { redisClient.runScript(scripts_js_1.ELuaScriptName.DELETE_MESSAGE, keys, argv, (err, reply) => { if (err) cb(err); else if (reply !== 'OK') { if (reply === 'MESSAGE_NOT_FOUND') { cb(new index_js_2.MessageMessageNotFoundError()); } else if (reply === 'MESSAGE_IN_PROCESS') { cb(new index_js_2.MessageMessageInProcessError()); } else if (reply === 'MESSAGE_NOT_DELETED') { cb(new index_js_2.MessageMessageNotDeletedError()); } else if (reply === 'INVALID_PARAMETERS') { cb(new index_js_2.MessageInvalidParametersError()); } else { cb(new index_js_2.MessageError()); } } else cb(); }); } else cb(); }); } //# sourceMappingURL=_delete-message.js.map