@lvnt/release-radar 1.1.7 → 1.2.0

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.
Files changed (2) hide show
  1. package/dist/index.js +38 -1
  2. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -23,14 +23,29 @@ const notifier = new Notifier(bot, CHAT_ID);
23
23
  const checker = new Checker(configData.tools, storage, notifier);
24
24
  // Track scheduled task for rescheduling
25
25
  let scheduledTask = null;
26
+ let lastCheckTime = null;
27
+ let nextCheckTime = null;
28
+ function calculateNextCheckTime(intervalHours) {
29
+ const now = new Date();
30
+ const next = new Date(now);
31
+ next.setMinutes(0, 0, 0);
32
+ next.setHours(Math.ceil(now.getHours() / intervalHours) * intervalHours);
33
+ if (next <= now) {
34
+ next.setHours(next.getHours() + intervalHours);
35
+ }
36
+ return next;
37
+ }
26
38
  function scheduleChecks(intervalHours) {
27
39
  if (scheduledTask) {
28
40
  scheduledTask.stop();
29
41
  }
42
+ nextCheckTime = calculateNextCheckTime(intervalHours);
30
43
  const cronExpression = `0 */${intervalHours} * * *`;
31
44
  scheduledTask = cron.schedule(cronExpression, async () => {
32
45
  console.log(`[${new Date().toISOString()}] Running scheduled check`);
46
+ lastCheckTime = new Date();
33
47
  await checker.checkAll();
48
+ nextCheckTime = calculateNextCheckTime(intervalHours);
34
49
  });
35
50
  console.log(`Scheduled checks every ${intervalHours} hours`);
36
51
  }
@@ -39,7 +54,9 @@ bot.onText(/\/check/, async (msg) => {
39
54
  if (msg.chat.id.toString() !== CHAT_ID)
40
55
  return;
41
56
  await bot.sendMessage(CHAT_ID, 'Checking for updates...');
57
+ lastCheckTime = new Date();
42
58
  await checker.checkAll();
59
+ nextCheckTime = calculateNextCheckTime(configData.checkIntervalHours);
43
60
  await bot.sendMessage(CHAT_ID, 'Check complete.');
44
61
  });
45
62
  bot.onText(/\/status/, async (msg) => {
@@ -49,9 +66,29 @@ bot.onText(/\/status/, async (msg) => {
49
66
  const lines = Object.entries(state.versions)
50
67
  .map(([name, version]) => `${name}: ${version}`)
51
68
  .sort();
52
- const message = lines.length > 0
69
+ let message = lines.length > 0
53
70
  ? lines.join('\n')
54
71
  : 'No versions tracked yet. Run /check first.';
72
+ // Add timing info
73
+ message += '\n\n---';
74
+ if (lastCheckTime) {
75
+ const ago = Math.round((Date.now() - lastCheckTime.getTime()) / 60000);
76
+ message += `\nLast check: ${ago} min ago`;
77
+ }
78
+ else {
79
+ message += '\nLast check: not yet';
80
+ }
81
+ if (nextCheckTime) {
82
+ const mins = Math.round((nextCheckTime.getTime() - Date.now()) / 60000);
83
+ if (mins > 0) {
84
+ const hours = Math.floor(mins / 60);
85
+ const remainingMins = mins % 60;
86
+ message += `\nNext check: in ${hours > 0 ? hours + 'h ' : ''}${remainingMins}m`;
87
+ }
88
+ else {
89
+ message += '\nNext check: soon';
90
+ }
91
+ }
55
92
  await bot.sendMessage(CHAT_ID, message);
56
93
  });
57
94
  bot.onText(/\/interval$/, async (msg) => {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lvnt/release-radar",
3
- "version": "1.1.7",
3
+ "version": "1.2.0",
4
4
  "description": "Monitor tool versions and notify via Telegram when updates are detected",
5
5
  "main": "dist/index.js",
6
6
  "bin": {