catto.js 0.8.4 → 0.8.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/TelegramBot.js CHANGED
@@ -114,8 +114,15 @@ module.exports = class extends EventEmitter {
114
114
  return this;
115
115
  }
116
116
  parseInitData(qs) {
117
+ if (typeof qs !== "string") {
118
+ return !1;
119
+ }
117
120
  var dcs = decodeURIComponent(qs).split("&").sort();
118
- var hash = dcs.find(a => a.startsWith("hash=")).split("=")[1];
121
+ var hash = dcs.find(a => a.startsWith("hash="));
122
+ if (!hash) {
123
+ return !1;
124
+ }
125
+ hash = hash.split("=")[1];
119
126
  dcs = dcs.filter(a => !a.startsWith("hash=")).join("\n");
120
127
  var secretKey = crypto.createHmac("sha256", "WebAppData").update(this.options.token).digest();
121
128
  var checkHash = crypto.createHmac("sha256", secretKey).update(dcs).digest("hex");
package/cjs_client.js CHANGED
@@ -3,17 +3,47 @@
3
3
  // catto.js
4
4
 
5
5
  (() => {
6
+ var symbol = "%";
7
+
6
8
  var incid = -1;
7
9
  var cache = {};
10
+ var ignoret = !1;
11
+ var dstartcode = "output += `<span id=\"_cattojs_d%\">`;\ncfs[%] = function() {\nvar ignoret = !0;\n";
12
+ var dendcode = "};\ncfs[%]();\noutput += `</span>`;\n";
8
13
  function render(code) {
9
- code = code.split("&lt;").join("<").split("&gt;").join(">");
10
- var parts = code.split(/<%c(?:lient)?(?!\*)(?!=) +(.+?) +%>/g);
14
+ code = code.split("&lt;").join("<").split("&gt;").join(">").split("&amp;").join("&");
15
+ var parts = code.split(new RegExp(`<${symbol}c(?:lient)?(\\*)?(?!=) +(.+?) +${symbol}>`, "g"));
11
16
  var output = "";
12
17
  var compile = "";
18
+ var dstreak = 0;
19
+ var did = 0;
20
+ var cfs = {};
13
21
  parts.forEach((part, index) => {
14
- compile += ((index + 1) % 2 < 1 ? `${part}\n` : `output += ${JSON.stringify(part)}.replace(/<%c(?:lient)?(\\*)?= +(.+?) +%>/g, (_, t, g) => __rpf(t, g, eval(g), !0)).replace(/<%c(?:lient)?(\\*)?- +(.+?) +%>/g, (_, t, g) => __rpf(t, g, eval(g), !1)).replace(/<%c(lient)\\*?# +(.+?) +%>/g, "");\n`);
22
+ if ((index + 1) % 3 == 2) {
23
+ if (part == "*") {
24
+ dstreak++;
25
+ } else if (dstreak) {
26
+ dstreak = -1;
27
+ } else {
28
+ dstreak = 0;
29
+ }
30
+ return;
31
+ }
32
+ if (dstreak == 1 && (index + 1) % 3 < 1) {
33
+ compile += dstartcode.split("%").join(++incid);
34
+ did = incid;
35
+ }
36
+ if (dstreak == -1) {
37
+ dstreak = 0;
38
+ compile += dendcode.split("%").join(did);
39
+ }
40
+ compile += ((index + 1) % 3 < 1 ? `${part}\n` : `output += ${JSON.stringify(part)}.replace(/<${symbol.replace("\\", "\\\\")}c(?:lient)?(\\*)?= +(.+?) +${symbol.replace("\\", "\\\\")}>/g, (_, t, g) => __rpf(t, g, eval(g), !0, ignoret)).replace(/<${symbol.replace("\\", "\\\\")}c(?:lient)?(\\*)?- +(.+?) +${symbol.replace("\\", "\\\\")}>/g, (_, t, g) => __rpf(t, g, eval(g), !1, ignoret)).replace(/<${symbol.replace("\\", "\\\\")}c(lient)\\*?# +(.+?) +${symbol.replace("\\", "\\\\")}>/g, "");\n`);
41
+ if (dstreak && !parts[index + 2]) {
42
+ dstreak = 0;
43
+ compile += dendcode.split("%").join(did);
44
+ }
15
45
  });
16
- window.__rpf = (t, g, result, r) => {
46
+ function __rpf(t, g, result, r, ignoret) {
17
47
  if (result === void 0) {
18
48
  return "undefined";
19
49
  }
@@ -23,7 +53,7 @@
23
53
  if (r) {
24
54
  result = result.split("<").join("&lt;").split(">").join("&gt;");
25
55
  }
26
- if (t) {
56
+ if (!ignoret && t) {
27
57
  function update(id, code, format) {
28
58
  var result2 = eval(code);
29
59
  if (format) {
@@ -31,16 +61,31 @@
31
61
  }
32
62
  if (cache[id] != result2) {
33
63
  cache[id] = result2;
34
- document.querySelector(`#_cattojs_d${id}`).innerHTML = eval(code);
64
+ try {
65
+ document.querySelector(`#_cattojs_d${id}`).innerHTML = result2;
66
+ } catch(e) {
67
+ throw `Dynamic element #${id} was deleted.`;
68
+ }
35
69
  }
36
70
  }
37
71
  setInterval(update.bind(null, ++incid, g, r), 1);
38
72
  return `<span id="_cattojs_d${incid}">${result}</span>`;
39
73
  }
40
74
  return result;
41
- };
75
+ }
42
76
  eval(compile);
43
- delete window.__rpf;
77
+ function updateb(inf) {
78
+ output = "";
79
+ var id = inf[0];
80
+ inf[1]();
81
+ if (cache[id] != output) {
82
+ cache[id] = output;
83
+ document.querySelector(`#_cattojs_d${id}`).innerHTML = output;
84
+ }
85
+ }
86
+ if (Object.keys(cfs).length) {
87
+ setInterval(() => Object.entries(cfs).forEach(updateb), 1);
88
+ }
44
89
  return output;
45
90
  }
46
91
  window.addEventListener("DOMContentLoaded", () => {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "catto.js",
3
- "version": "0.8.4",
3
+ "version": "0.8.6",
4
4
  "description": "Universal module for everything.",
5
5
  "main": "index.js",
6
6
  "scripts": {
@@ -39,7 +39,7 @@
39
39
  },
40
40
  "homepage": "https://github.com/BoryaGames/catto.js#readme",
41
41
  "devDependencies": {
42
- "jest": "^29.4.1"
42
+ "jest": "^29.7.0"
43
43
  },
44
44
  "dependencies": {
45
45
  "body-parser": "^1.20.2",