@dongdev/fca-unofficial 2.0.28 → 2.0.30

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/CHANGELOG.md CHANGED
@@ -119,3 +119,9 @@ Too lazy to write changelog, sorry! (will write changelog in the next release, t
119
119
 
120
120
  ## v2.0.27 - 2025-10-18
121
121
  - Hotfix / auto bump
122
+
123
+ ## v2.0.28 - 2025-10-18
124
+ - Hotfix / auto bump
125
+
126
+ ## v2.0.29 - 2025-10-19
127
+ - Hotfix / auto bump
@@ -1,18 +1,40 @@
1
1
  // func/checkUpdate.js
2
2
  const logger = require("./logger");
3
3
  const fs = require("fs");
4
+ const path = require("path");
4
5
  const { exec } = require("child_process");
5
6
  const pkgName = "@dongdev/fca-unofficial";
6
7
 
8
+ const TEMP_DIR = path.join(process.cwd(), "temp");
9
+ const LOCK_FILE = path.join(TEMP_DIR, ".fca-update-lock.json");
10
+ const RESTART_COOLDOWN_MS = 10 * 60 * 1000;
11
+
7
12
  function execPromise(cmd) {
8
13
  return new Promise((resolve, reject) => {
9
- exec(cmd, (error, stdout, stderr) => {
14
+ exec(cmd, { cwd: process.cwd() }, (error, stdout, stderr) => {
10
15
  if (error) return reject({ error, stderr });
11
16
  resolve({ stdout, stderr });
12
17
  });
13
18
  });
14
19
  }
15
20
 
21
+ function ensureTemp() {
22
+ try { fs.mkdirSync(TEMP_DIR, { recursive: true }); } catch { }
23
+ }
24
+
25
+ function readLock() {
26
+ try { return JSON.parse(fs.readFileSync(LOCK_FILE, "utf8")); } catch { return null; }
27
+ }
28
+
29
+ function writeLock(data) {
30
+ ensureTemp();
31
+ try { fs.writeFileSync(LOCK_FILE, JSON.stringify(data)); } catch { }
32
+ }
33
+
34
+ function clearLock() {
35
+ try { fs.unlinkSync(LOCK_FILE); } catch { }
36
+ }
37
+
16
38
  function getInstalledVersion() {
17
39
  try {
18
40
  const p = require.resolve(`${pkgName}/package.json`, { paths: [process.cwd(), __dirname] });
@@ -22,32 +44,68 @@ function getInstalledVersion() {
22
44
  }
23
45
  }
24
46
 
47
+ async function getInstalledVersionByNpm() {
48
+ try {
49
+ const { stdout } = await execPromise(`npm ls ${pkgName} --json --depth=0`);
50
+ const json = JSON.parse(stdout || "{}");
51
+ const v = json?.dependencies?.[pkgName]?.version;
52
+ return v || null;
53
+ } catch {
54
+ return null;
55
+ }
56
+ }
57
+
25
58
  async function _checkAndUpdateVersionImpl() {
59
+ const lock = readLock();
60
+ if (lock && Date.now() - (lock.ts || 0) < RESTART_COOLDOWN_MS) {
61
+ logger("Skip auto-update due to recent attempt", "info");
62
+ return;
63
+ }
64
+
26
65
  logger("Checking version...", "info");
27
66
  const latest = (await execPromise(`npm view ${pkgName} version`)).stdout.trim();
28
- const installed = getInstalledVersion();
29
- if (!installed || installed !== latest) {
30
- logger(`New version available (${latest}). Current version (${installed || "not installed"}). Updating...`, "info");
67
+
68
+ let installed = getInstalledVersion();
69
+ if (!installed) installed = await getInstalledVersionByNpm();
70
+
71
+ if (installed && installed === latest) {
72
+ clearLock();
73
+ logger(`You're already on the latest version - ${latest}`, "info");
74
+ return;
75
+ }
76
+
77
+ if (lock && lock.latest === latest && Date.now() - (lock.ts || 0) < RESTART_COOLDOWN_MS) {
78
+ logger("Update already attempted recently, skipping restart loop", "info");
79
+ return;
80
+ }
81
+
82
+ logger(`New version available (${latest}). Current version (${installed || "not installed"}). Updating...`, "info");
83
+
84
+ try {
85
+ const { stderr } = await execPromise(`npm i ${pkgName}@latest`);
86
+ if (stderr) logger(stderr, "error");
87
+ } catch (e) {
88
+ logger(`Error running npm install: ${e.error || e}. Trying to install from GitHub...`, "error");
31
89
  try {
32
- const { stderr } = await execPromise(`npm i ${pkgName}@latest`);
90
+ const { stderr } = await execPromise("npm i https://github.com/Donix-VN/fca-unofficial");
33
91
  if (stderr) logger(stderr, "error");
34
- logger(`Updated fca to the latest version: ${latest}, Restart to apply`, "info");
35
- process.exit(1);
36
- } catch (e) {
37
- logger(`Error running npm install: ${e.error || e}. Trying to install from GitHub...`, "error");
38
- try {
39
- const { stderr } = await execPromise("npm i https://github.com/Donix-VN/fca-unofficial");
40
- if (stderr) logger(stderr, "error");
41
- logger(`Installed from GitHub successfully: ${latest}`, "info");
42
- return;
43
- } catch (gitErr) {
44
- logger(`Error installing from GitHub: ${gitErr.error || gitErr}`, "error");
45
- throw (gitErr.error || gitErr);
46
- }
92
+ } catch (gitErr) {
93
+ writeLock({ ts: Date.now(), latest, status: "failed" });
94
+ logger(`Error installing from GitHub: ${gitErr.error || gitErr}`, "error");
95
+ throw (gitErr.error || gitErr);
47
96
  }
97
+ }
98
+
99
+ let after = getInstalledVersion();
100
+ if (!after) after = await getInstalledVersionByNpm();
101
+
102
+ if (after && after === latest) {
103
+ writeLock({ ts: Date.now(), latest, status: "updated" });
104
+ logger(`Updated fca to the latest version: ${latest}, Restart to apply`, "info");
105
+ process.exit(1);
48
106
  } else {
49
- logger(`You're already on the latest version - ${latest}`, "info");
50
- return;
107
+ writeLock({ ts: Date.now(), latest, status: "mismatch" });
108
+ logger(`Installed but version mismatch (have: ${after || "unknown"}, want: ${latest}). Skip restart to avoid loop`, "error");
51
109
  }
52
110
  }
53
111
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dongdev/fca-unofficial",
3
- "version": "2.0.28",
3
+ "version": "2.0.30",
4
4
  "description": "Unofficial Facebook Chat API for Node.js - Interact with Facebook Messenger programmatically",
5
5
  "main": "index.js",
6
6
  "types": "index.d.ts",