msys.gcm.gcm_classify_error
Last updated March 2020
Name
msys.gcm.gcm_classify_error — Determine the delivery status of the "DLV_Response_Status" variable
Synopsis
msys.gcm.gcm_classify_error(status);
Description
This function returns the delivery status of the "DLV_Response_Status" variable. It classifies the "DLV_Response_Status" variable as one of the following:
-
msys.delivery.DELIVERY_SUCCESS
-
msys.delivery.DELIVERY_TEMPFAILED
-
msys.delivery.DELIVERY_PERMFAILED
require("strict")
require("msys.delivery")
require("msys.gcm")
require("msys.extended.message")
local mod = {}
function mod:generic_delivery_msg_dispose(msg)
local status = msg:context_get(msys.core.ECMESS_CTX_MESS, "DLV_Response_Status")
if status == "" then
return msys.delivery.DELIVERY_CONTINUE
-- "DLV_Response_Status" varies depending upon protocol
-- but a message is treated as ok or delivered if and
-- only if the DLV_Response_Status does not exist.
elseif (msys.gcm.gcm_classify_error(tonumber(status))==msys.delivery.DELIVERY_PERMFAILED) or
(msys.gcm.gcm_classify_error(tonumber(status))==msys.delivery.DELIVERY_TEMPFAILED) then
-- reset context variable for DLV_Response_Status
msg:context_delete(msys.core.ECMESS_CTX_MESS, "DLV_Response_Status")
msg:inject(msg:mailfrom(), "defaultNumber@deliverSMPP")
return msys.delivery.DELIVERY_DONE
else
print(status, " unknown disposition!\n")
end
end
msys.registerModule("convert", mod);
Note
When a message fails, you can use the generic_delivery_msg_dispose callout and reroute the message to another channel. Use the msg:get_delivery_method function to determine the protocol of the message.
Enable this function with the statement require('msys.gcm');
.
See Also
Was this page helpful?