natureco-cli 2.6.0 → 2.6.2

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "natureco-cli",
3
- "version": "2.6.0",
3
+ "version": "2.6.2",
4
4
  "description": "NatureCo AI Bot Terminal Interface",
5
5
  "main": "bin/natureco.js",
6
6
  "bin": {
@@ -211,7 +211,7 @@ body::before{
211
211
  <div class="header-bot-name" id="header-bot-name">Nature Bot</div>
212
212
  <div class="header-bot-model" id="header-bot-model">NatureCo</div>
213
213
  </div>
214
- <div class="version-badge" id="version-badge">v2.6.0</div>
214
+ <div class="version-badge" id="version-badge">v2.6.2</div>
215
215
  </div>
216
216
  <div class="messages" id="messages"></div>
217
217
  <div class="input-area">
@@ -341,7 +341,7 @@ function dashboard(action) {
341
341
  apiKey: cfg.apiKey,
342
342
  defaultBot: cfg.defaultBot,
343
343
  defaultBotId: cfg.defaultBotId,
344
- version: 'v2.6.0',
344
+ version: 'v2.6.2',
345
345
  bots: cfg.bots || [],
346
346
  telegramToken: cfg.telegramToken || null,
347
347
  whatsappConnected: cfg.whatsappConnected || false,
@@ -70,49 +70,35 @@ async function doctor(options) {
70
70
  }
71
71
  }
72
72
 
73
- // 3. API key kontrolü
73
+ // 3. Provider URL kontrolü (v2.x)
74
74
  total++;
75
75
  criticalTotal++;
76
- let apiKeyValid = false;
77
- if (config && config.apiKey) {
78
- try {
79
- const response = await fetch('https://api.natureco.me/api/v1/bots', {
80
- headers: { 'Authorization': `Bearer ${config.apiKey}` },
81
- });
82
-
83
- if (response.ok) {
84
- console.log(chalk.green('✅ API key:'), chalk.white(config.apiKey.slice(0, 8) + '...'));
85
- passed++;
86
- criticalPassed++;
87
- apiKeyValid = true;
88
- results.push({ status: 'ok', message: 'API key geçerli' });
89
- } else {
90
- console.log(chalk.red('❌ API key:'), chalk.white('Geçersiz'));
91
- results.push({ status: 'error', message: 'API key geçersiz', fix: 'Setup çalıştırılacak' });
92
- }
93
- } catch (err) {
94
- console.log(chalk.red('❌ API key:'), chalk.white('Test edilemedi'));
95
- results.push({ status: 'error', message: 'API key test edilemedi' });
96
- }
76
+ let providerValid = false;
77
+ if (config && config.providerUrl) {
78
+ console.log(chalk.green('✅ Provider URL:'), chalk.white(config.providerUrl));
79
+ passed++;
80
+ criticalPassed++;
81
+ providerValid = true;
82
+ results.push({ status: 'ok', message: 'Provider URL ayarlanmış' });
97
83
  } else {
98
- console.log(chalk.yellow('⚠️ API key:'), chalk.white('Kayıtlı değil'));
99
- results.push({ status: 'warning', message: 'API key yok', fix: 'Setup çalıştırılacak' });
84
+ console.log(chalk.red(' Provider URL:'), chalk.white('Ayarlanmamış'));
85
+ results.push({ status: 'error', message: 'Provider URL yok', fix: 'Setup çalıştırılacak' });
100
86
  }
101
87
 
102
- if (shouldFix && !apiKeyValid) {
88
+ if (shouldFix && !providerValid) {
103
89
  console.log(chalk.yellow(' 🔧 Setup başlatılıyor...'));
104
90
  console.log(chalk.gray(' Lütfen setup\'ı manuel çalıştırın: natureco setup'));
105
91
  }
106
92
 
107
- // 4. Varsayılan bot kontrolü
93
+ // 4. Provider Model kontrolü (v2.x)
108
94
  total++;
109
- if (config && config.defaultBot && config.defaultBotId) {
110
- console.log(chalk.green('✅ Varsayılan bot:'), chalk.white(config.defaultBot));
95
+ if (config && config.providerModel) {
96
+ console.log(chalk.green('✅ Provider Model:'), chalk.white(config.providerModel));
111
97
  passed++;
112
- results.push({ status: 'ok', message: 'Varsayılan bot ayarlanmış' });
98
+ results.push({ status: 'ok', message: 'Provider model ayarlanmış' });
113
99
  } else {
114
- console.log(chalk.yellow('⚠️ Varsayılan bot:'), chalk.white('Ayarlanmamış'));
115
- results.push({ status: 'warning', message: 'Varsayılan bot yok', fix: 'Setup ile ayarlanabilir' });
100
+ console.log(chalk.yellow('⚠️ Provider Model:'), chalk.white('Ayarlanmamış'));
101
+ results.push({ status: 'warning', message: 'Provider model yok', fix: 'Setup ile ayarlanabilir' });
116
102
  }
117
103
 
118
104
  // 5. Skills kontrolü
@@ -225,39 +211,71 @@ async function doctor(options) {
225
211
  }
226
212
 
227
213
  // 13. Gateway kontrolü (opsiyonel)
228
- const gatewayRunning = await checkPort(3847);
229
- if (gatewayRunning) {
230
- console.log(chalk.green('✅ Gateway:'), chalk.white('Çalışıyor (port 3847)'));
231
- results.push({ status: 'ok', message: 'Gateway çalışıyor', optional: true });
214
+ const gatewayPidFile = path.join(CONFIG_DIR, 'gateway.pid');
215
+ let gatewayRunning = false;
216
+
217
+ if (fs.existsSync(gatewayPidFile)) {
218
+ try {
219
+ const pid = parseInt(fs.readFileSync(gatewayPidFile, 'utf-8').trim());
220
+
221
+ // Check if process is running
222
+ try {
223
+ process.kill(pid, 0); // Signal 0 checks if process exists
224
+ gatewayRunning = true;
225
+ console.log(chalk.green('✅ Gateway:'), chalk.white(`Çalışıyor (PID: ${pid})`));
226
+ results.push({ status: 'ok', message: 'Gateway çalışıyor', optional: true });
227
+ } catch {
228
+ console.log(chalk.yellow('⚠️ Gateway:'), chalk.white('PID dosyası var ama process çalışmıyor'));
229
+ results.push({ status: 'warning', message: 'Gateway PID stale', fix: 'natureco gateway start', optional: true });
230
+ }
231
+ } catch {
232
+ console.log(chalk.gray('⚪ Gateway:'), chalk.white('PID dosyası okunamadı'));
233
+ results.push({ status: 'info', message: 'Gateway PID okunamadı', optional: true });
234
+ }
232
235
  } else {
233
236
  console.log(chalk.gray('⚪ Gateway:'), chalk.white('Çalışmıyor'));
234
237
  results.push({ status: 'info', message: 'Gateway çalışmıyor', fix: 'natureco gateway start', optional: true });
235
238
  }
236
239
 
237
- // 14. Internet bağlantısı kontrolü
240
+ // 14. Tavily API key kontrolü (web search için)
241
+ total++;
242
+ if (config && config.tavilyApiKey) {
243
+ console.log(chalk.green('✅ Tavily API:'), chalk.white(config.tavilyApiKey.slice(0, 10) + '...'));
244
+ passed++;
245
+ results.push({ status: 'ok', message: 'Tavily API key ayarlanmış' });
246
+ } else {
247
+ console.log(chalk.yellow('⚠️ Tavily API:'), chalk.white('Ayarlanmamış (web search çalışmayacak)'));
248
+ results.push({ status: 'warning', message: 'Tavily API key yok', fix: 'natureco config set tavilyApiKey tvly_xxx' });
249
+ }
250
+
251
+ // 15. Provider erişim kontrolü
238
252
  total++;
239
253
  criticalTotal++;
240
- try {
241
- const response = await fetch('https://api.natureco.me/health', {
242
- method: 'GET',
243
- signal: AbortSignal.timeout(5000),
244
- });
245
-
246
- if (response.ok || response.status === 404) {
247
- console.log(chalk.green('✅ Internet:'), chalk.white('api.natureco.me erişilebilir'));
254
+ if (config && config.providerUrl) {
255
+ try {
256
+ // Extract base URL for health check
257
+ const baseUrl = config.providerUrl.replace(/\/v1.*$/, '');
258
+
259
+ const response = await fetch(baseUrl, {
260
+ method: 'GET',
261
+ signal: AbortSignal.timeout(5000),
262
+ });
263
+
264
+ // Any response (even 404) means provider is reachable
265
+ console.log(chalk.green('✅ Provider Erişim:'), chalk.white('Provider erişilebilir'));
248
266
  passed++;
249
267
  criticalPassed++;
250
- results.push({ status: 'ok', message: 'API erişilebilir' });
251
- } else {
252
- console.log(chalk.yellow('⚠️ Internet:'), chalk.white('API yanıt vermiyor'));
253
- results.push({ status: 'warning', message: 'API yanıt vermiyor' });
268
+ results.push({ status: 'ok', message: 'Provider erişilebilir' });
269
+ } catch (err) {
270
+ console.log(chalk.red('❌ Provider Erişim:'), chalk.white('Provider erişilemiyor'));
271
+ results.push({ status: 'error', message: 'Provider erişilemiyor' });
254
272
  }
255
- } catch (err) {
256
- console.log(chalk.red(' Internet:'), chalk.white('api.natureco.me erişilemiyor'));
257
- results.push({ status: 'error', message: 'API erişilemiyor' });
273
+ } else {
274
+ console.log(chalk.gray(' Provider Erişim:'), chalk.white('Provider URL ayarlanmamış'));
275
+ results.push({ status: 'info', message: 'Provider URL yok' });
258
276
  }
259
277
 
260
- // 15. Güncelleme kontrolü
278
+ // 16. Güncelleme kontrolü
261
279
  total++;
262
280
  try {
263
281
  const packageJson = require('../../package.json');
@@ -128,7 +128,7 @@ async function startGateway() {
128
128
 
129
129
  async function runGatewayWorker() {
130
130
  // This runs in the background
131
- log('gateway', 'Starting NatureCo Gateway v2.6.0...', 'green');
131
+ log('gateway', 'Starting NatureCo Gateway v2.6.2...', 'green');
132
132
 
133
133
  // Load config
134
134
  const { getConfig } = require('../utils/config');
@@ -382,6 +382,13 @@ async function startTelegramProvider(config) {
382
382
  return;
383
383
  }
384
384
 
385
+ // Access control - check allowed chats
386
+ const allowedChats = config.telegramAllowedChats || [];
387
+ if (allowedChats.length > 0 && !allowedChats.includes(String(chatId))) {
388
+ log('telegram', `Blocked message from chat ${chatId} (not in allowed list)`, 'yellow');
389
+ return;
390
+ }
391
+
385
392
  log('telegram', `Inbound message from chat ${chatId} (${messageText.length} chars)`, 'cyan');
386
393
 
387
394
  try {
@@ -15,8 +15,18 @@ async function telegram(action) {
15
15
  return statusTelegram();
16
16
  }
17
17
 
18
+ if (action === 'allow') {
19
+ const chatId = process.argv[4];
20
+ if (!chatId) {
21
+ console.log(chalk.red('\n❌ Chat ID belirtmelisiniz\n'));
22
+ console.log(chalk.gray('Kullanım: natureco telegram allow <chatId>\n'));
23
+ process.exit(1);
24
+ }
25
+ return allowChat(chatId);
26
+ }
27
+
18
28
  console.log(chalk.red('\n❌ Unknown action\n'));
19
- console.log(chalk.gray('Available actions: connect, disconnect, status\n'));
29
+ console.log(chalk.gray('Available actions: connect, disconnect, status, allow\n'));
20
30
  process.exit(1);
21
31
  }
22
32
 
@@ -50,6 +60,24 @@ async function connectTelegram() {
50
60
  },
51
61
  ]);
52
62
 
63
+ console.log(chalk.yellow('\n⏳ Telegram Chat ID almak için:\n'));
64
+ console.log(chalk.gray('1. Telegram\'da @userinfobot veya @getmyid_bot\'a mesaj gönder'));
65
+ console.log(chalk.gray('2. Sana chat ID\'ni söyleyecek'));
66
+ console.log(chalk.gray('3. Chat ID\'yi buraya gir (örnek: 123456789)\n'));
67
+
68
+ const chatIdAnswer = await inquirer.prompt([
69
+ {
70
+ type: 'input',
71
+ name: 'chatId',
72
+ message: 'Telegram Chat ID\'n:',
73
+ validate: (val) => {
74
+ if (val.trim() === '') return 'Chat ID boş olamaz';
75
+ if (!/^-?\d+$/.test(val.trim())) return 'Geçersiz Chat ID formatı (sadece rakam olmalı)';
76
+ return true;
77
+ },
78
+ },
79
+ ]);
80
+
53
81
  // Telegram için bot ID oluştur (timestamp-based)
54
82
  const botId = `telegram_${Date.now()}`;
55
83
 
@@ -58,12 +86,15 @@ async function connectTelegram() {
58
86
  // Save to config (v2.x - no backend call)
59
87
  config.telegramToken = answers.token.trim();
60
88
  config.telegramBotId = botId;
89
+ config.telegramAllowedChats = [chatIdAnswer.chatId.trim()];
61
90
  saveConfig(config);
62
91
 
63
92
  console.log(chalk.green('✅ Telegram bot token kaydedildi!\n'));
64
93
  console.log(chalk.cyan('Bot ID:'), chalk.white(botId));
65
94
  console.log(chalk.cyan('Token:'), chalk.white(answers.token.slice(0, 20) + '...'));
95
+ console.log(chalk.cyan('İzin verilen chat:'), chalk.white(chatIdAnswer.chatId.trim()));
66
96
  console.log(chalk.gray('\nSession kaydedildi: ~/.natureco/config.json'));
97
+ console.log(chalk.gray('Başka chat eklemek için: natureco telegram allow <chatId>'));
67
98
 
68
99
  console.log(chalk.green('\n✅ Kurulum tamamlandı!\n'));
69
100
  console.log(chalk.yellow('Gateway ile başlatmak için:'), chalk.cyan('natureco gateway start'));
@@ -97,6 +128,7 @@ async function disconnectTelegram() {
97
128
  // Remove from config
98
129
  delete config.telegramToken;
99
130
  delete config.telegramBotId;
131
+ delete config.telegramAllowedChats;
100
132
  saveConfig(config);
101
133
 
102
134
  console.log(chalk.green('\n✅ Telegram disconnected\n'));
@@ -120,7 +152,51 @@ function statusTelegram() {
120
152
  console.log(chalk.cyan('Bot ID:'), chalk.white(config.telegramBotId));
121
153
  }
122
154
 
155
+ // Show allowed chats
156
+ const allowedChats = config.telegramAllowedChats || [];
157
+ if (allowedChats.length === 0) {
158
+ console.log(chalk.cyan('İzin listesi:'), chalk.gray('Boş (herkesten mesaj kabul edilir)'));
159
+ } else {
160
+ console.log(chalk.cyan('İzin listesi:'));
161
+ allowedChats.forEach(chatId => console.log(chalk.white(` - ${chatId}`)));
162
+ }
163
+
123
164
  console.log(chalk.gray('\nDisconnect with: natureco telegram disconnect\n'));
124
165
  }
125
166
 
167
+ function allowChat(chatId) {
168
+ const config = getConfig();
169
+
170
+ if (!config.telegramToken) {
171
+ console.log(chalk.red('\n❌ Telegram not connected\n'));
172
+ console.log(chalk.gray('Connect first with: natureco telegram connect\n'));
173
+ process.exit(1);
174
+ }
175
+
176
+ // Validate chat ID (should be numeric, can be negative for groups)
177
+ const normalized = chatId.trim();
178
+
179
+ if (!/^-?\d+$/.test(normalized)) {
180
+ console.log(chalk.red('\n❌ Geçersiz Chat ID formatı\n'));
181
+ console.log(chalk.gray('Chat ID sadece rakamlardan oluşmalı (örnek: 123456789 veya -123456789)\n'));
182
+ process.exit(1);
183
+ }
184
+
185
+ const allowedChats = config.telegramAllowedChats || [];
186
+
187
+ if (allowedChats.includes(normalized)) {
188
+ console.log(chalk.yellow('\n⚠️ Bu chat ID zaten izin listesinde\n'));
189
+ return;
190
+ }
191
+
192
+ allowedChats.push(normalized);
193
+ config.telegramAllowedChats = allowedChats;
194
+ saveConfig(config);
195
+
196
+ console.log(chalk.green('\n✅ Chat ID izin listesine eklendi\n'));
197
+ console.log(chalk.cyan('Chat ID:'), chalk.white(normalized));
198
+ console.log(chalk.cyan('Toplam:'), chalk.white(`${allowedChats.length} chat`));
199
+ console.log(chalk.gray('\nGateway\'i yeniden başlatın: natureco gateway stop && natureco gateway start\n'));
200
+ }
201
+
126
202
  module.exports = telegram;
package/src/utils/api.js CHANGED
@@ -1,4 +1,4 @@
1
- // NatureCo CLI v2.6.0 - Universal LLM Provider Support
1
+ // NatureCo CLI v2.6.2 - Universal LLM Provider Support
2
2
  // Supports: OpenAI, Groq, Together, Fireworks, Perplexity, Mistral, DeepSeek, OpenRouter, Ollama, LM Studio, Anthropic
3
3
 
4
4
  const fs = require('fs');