message.handlebars 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. <!DOCTYPE html>
  2. <html dir="ltr" xmlns="http://www.w3.org/1999/xhtml">
  3. <head lang="en">
  4. <meta http-equiv=X-UA-Compatible content="IE=edge" />
  5. <meta content="text/html;charset=utf-8" http-equiv=Content-Type />
  6. <meta name=viewport content="user-scalable=1.0,initial-scale=1.0,minimum-scale=1.0,maximum-scale=1.0" />
  7. <meta name=apple-mobile-web-app-capable content=yes />
  8. <meta name=format-detection content="telephone=no" />
  9. <meta name="robots" content="noindex,nofollow">
  10. <link type=text/css href="/styles/style.css" media="screen" rel="stylesheet" title="CSS" />
  11. {{{customCSSTags}}}
  12. <link rel="apple-touch-icon" href="/favicon-303x303.png" />
  13. <script type="text/javascript" src="scripts/common-0.0.1{{min}}.js"></script>
  14. {{{customJSTags}}}
  15. <title id="topTitle">{{{title}}}</title>
  16. </head>
  17. <body>
  18. <div id=container style=max-height:100vh>
  19. <div id=mastheadx></div>
  20. <div id=masthead style="background:url(logo.png) 0px 0px;background-color:#036;background-repeat:no-repeat;height:66px;width:100%;overflow:hidden">
  21. <div style="float:left;text-shadow: 1px 1px 2px #000">{{{titlehtml}}}</div>
  22. <div style=float:left;height:66px;color:#c8c8c8;padding-left:14px;padding-top:7px>
  23. <strong><font style="font-size:46px;font-family:Arial,Helvetica,sans-serif;text-shadow: 1px 1px 2px #000">{{{title1}}}</font></strong>
  24. </div>
  25. <div style=float:left;height:66px;color:#c8c8c8;padding-left:5px;padding-top:14px>
  26. <strong><font style="font-size:14px;font-family:Arial,Helvetica,sans-serif;text-shadow: 1px 1px 2px #000">{{{title2}}}</font></strong>
  27. </div>
  28. </div>
  29. <div id=page_content style=max-height:calc(100vh-138px)>
  30. <div id=column_l>
  31. <h1 id="mainTitle"></h1>
  32. <p id="mainMessage"></p>
  33. <br />
  34. </div>
  35. <div id=footer>
  36. <table cellpadding=0 cellspacing=10 style=width:100%>
  37. <tr>
  38. <td style=text-align:left></td>
  39. <td style=text-align:right>
  40. <a href=terms>Terms &amp; Privacy</a>
  41. </td>
  42. </tr>
  43. </table>
  44. </div>
  45. </div>
  46. </div>
  47. <script>
  48. var random = '{{{randomlength}}}' // Random length string for BREACH mitigation
  49. var titleid = parseInt('{{{titleid}}}');
  50. var msgid = parseInt('{{{msgid}}}');
  51. var domainurl = decodeURIComponent('{{{domainurl}}}');
  52. var arg1 = decodeURIComponent('{{{arg1}}}');
  53. var arg2 = decodeURIComponent('{{{arg2}}}');
  54. var urlargs = parseUriArgs();
  55. var title = '';
  56. if (titleid == 1) { title = "Account Verification"; }
  57. if (titleid == 2) { title = "Desktop Sharing"; }
  58. if (titleid == 3) { title = "Server Under Maintenance"; }
  59. if (titleid == 4) { title = "Terminal Sharing"; }
  60. QH('topTitle', Q('topTitle').innerText + ' - ' + title);
  61. QH('mainTitle', title);
  62. var msg = '';
  63. switch (msgid) {
  64. case 1: { msg = "ERROR: Invalid domain."; break; }
  65. case 2: { msg = format("ERROR: Invalid username \"{0}\".", arg1); break; }
  66. case 3: { msg = format("ERROR: Invalid e-mail \"{0}\" for user \"{1}\".", arg1, arg2); break; }
  67. case 4: { msg = format("E-mail \"{0}\" for user \"{1}\" already verified.", arg1, arg2); break; }
  68. case 5: { msg = format("E-mail \"{0}\" already in use on a different account. Change the email address and try again.", arg1); break; }
  69. case 6: { msg = format("Verified email {0} for user account {1}.", '<b>' + arg1 + '</b>', '<b>' + arg2 + '</b>'); break; }
  70. case 7: { msg = format("E-mail \"{0}\" for user \"{1}\" not verified.", arg1, arg2); break; }
  71. case 8: {
  72. msg = '<div>' + format("Password for account {0} has been reset to:", '<b>' + arg1 + '</b>') + '</div><div style=padding:14px;font-size:18px><b>' + arg2 + '</b></div>';
  73. msg += "Login and go to the \"My Account\" tab to update your password.";
  74. break;
  75. }
  76. case 9: { msg = "ERROR: Invalid account check."; break; }
  77. case 10: { msg = "ERROR: Invalid account check, verification url is only valid for 30 minutes."; break; }
  78. case 11: { msg = "Sharing link not valid yet."; break; }
  79. case 12: { msg = "Sharing link is expired."; break; }
  80. case 13: {
  81. var loginUrl = 'login?loginscreen=1' + (urlargs.key ? '&key=' + urlargs.key : '');
  82. msg = "If you are an administrator, [login here].".replace('[', '<a href=' + loginUrl + '>').replace(']', '</a>');
  83. break;
  84. }
  85. case 14: { msg = '<a href=' + window.location.href + '&confirm=1>' + "Click here to reset your account password." + '</a>'; break; }
  86. }
  87. // Add login page link
  88. if ((msgid != 11) && (msgid != 12) && (msgid != 13) && (msgid != 14)) { msg += ' <a href="' + domainurl + (urlargs.key ? ('?key=' + urlargs.key) : '') + '">' + "Go to login page" + '</a>.' }
  89. QH('mainMessage', msg);
  90. function format(format) { var args = Array.prototype.slice.call(arguments, 1); return format.replace(/{(\d+)}/g, function (match, number) { return typeof args[number] != 'undefined' ? args[number] : match; }); };
  91. // Parse URL arguments, only keep safe values
  92. function parseUriArgs() {
  93. var href = window.document.location.href;
  94. if (href.endsWith('#')) { href = href.substring(0, href.length - 1); }
  95. var name, r = {}, parsedUri = href.split(/[\?&|]/);
  96. parsedUri.splice(0, 1);
  97. for (var j in parsedUri) {
  98. var arg = parsedUri[j], i = arg.indexOf('=');
  99. name = arg.substring(0, i);
  100. r[name] = arg.substring(i + 1);
  101. if (!isSafeString(r[name])) { delete r[name]; } else { var x = parseInt(r[name]); if (x == r[name]) { r[name] = x; } }
  102. }
  103. return r;
  104. }
  105. </script>
  106. </body>
  107. </html>