Just when you think something’s gonna be easy...
Attempting to download a bunch of old email assets before purging them, I noticed “Edit Code » Download HTML” wasn’t serving up a file.
data:image/s3,"s3://crabby-images/ef51e/ef51e1043e19a48d5ccbf3c47e87864eaf05f085" alt=""
Checking the F12 Console revealed a fatal JS error:
data:image/s3,"s3://crabby-images/9a4ae/9a4aefab4797f977fd6702e14292b5b1b2ed770c" alt=""
Turns out whoever wrote the downloadHTML
function at Marketo made the mistake of thinking the browser-standard btoa
method works on any text. Nope!
data:image/s3,"s3://crabby-images/d5c7b/d5c7bc58d5124a312d172e010c08aaf809fa9f70" alt=""
See, btoa
— despite being mistakenly used, in countless broken scenarios, as if it’s an all-purpose Base64 encoder — only works on Latin-1 input. That is, the 128 ASCII characters plus the first non-ASCII block of 128 symbols & characters, nothing more.
btoa
throws a fatal error on characters outside of this range. And many of the client’s emails use everyday characters that happen to be outside of Latin-1, like the single curly quote/apostrophe ’
and curly double quotes “”
and em dashes —
. (All of which I recommend highly and use on this very blog.)
data:image/s3,"s3://crabby-images/17388/1738858106184ce70fc56959149b732a07eb77c0" alt=""
data:image/s3,"s3://crabby-images/b05f9/b05f9e44a16f0bc5e500bf3a73085828e4925da7" alt=""
Obviously, the problem would be exponentially worse in a non-Latin language where every character except certain punctuation is outside the range.
What the code should do (I’ll open a Support Case) is just leave the HTML unencoded:
this.encode = function(data){
return "data:text/html," + encodeURIComponent(data);
}
Meantime, the workaround is just Select All → Copy → Paste from the Edit Code window, more annoying but it does work.