I am looking to encrypt URL parameters for the Unsubscribe link at all the delivery templates using 64bit encryption.
there is out of the box few function but the client is specifically looking for 64 bit encryption Utf 8.
example: if the url currently that takes you to preference center is firstname.lastname@example.org&country=usa need to get encrypted to render as
LET ME KNOW
I got this one working. below is the code on the personalized block if anyone interested
var _email= recipient.email;
var _id = recipient.id;
var url = "id=" + _id + "&email=" + _email;
<%@ value object="provider" xpath="@trackingURL" %>/webApp/tstPreferenceCenter?params=<%=escapeUrl(Base64.encode(url))%>
I am copy-pasting the code that was used earlier but you can make changes as per your requirements. it is available to code but I am iterating it here. We can use the encrypt and decrypt functions to take care of.
shoot me if you need more info on how we can make use of these functions with HTTP clientrequests.
1. we need to encrypt the email id or any other field while sending out email and decrypt it once we get a response. the total process depends on how this flow is handled at your org.
Last, but not least, you can create a stored procedure in some DB (SQL Server for example) that will encrypt the data and then map it into some variable in recipient data scheme or just expose it as a SQL function.
Also, for an unsubscribe function, the nms:recipient schema has @cryptedId attribute, that is recipient id encrypted with AES with server secret. If unsubscribe mechanic feeds back to Adobe server, you can use it as a token for unsubscribe function. It is secure and does not require you of exposing any of PII data.
I thought I resolved this issue but is not working well. Looks to be working on the preview but when trying on delivery is not working. The system throws errors when trying to send the email. it complains with following error.
JST -#ID# the result of the formula for the '<%LoadLibrary('URL in the '#ID#' delivery action is not valid . JST-#ID# failed to replace tracked URLs (content htmlContent)
It seems you are using in RT templates, I don't think we can call external scripts in RT templates.
As Message center server is hosted by adobe and to make it work you need to have access to that server, else it won't work.
we have used this in web applications. the user is redirected to adobe campaign web application where we keep the above script to handle encryption and decryption.
when sending out the link with id, we send encrypted ID in the link as you mentioned and when the user clicks on the link he is directed to the web application hosted inside adobe campaign where the script takes care of decryption and we can use xtk: session write method to update the schema about subscription or unsubscription.
hope it is clear.