natureco-cli 2.13.5 → 2.13.7

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.13.5",
3
+ "version": "2.13.7",
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.13.5</div>
214
+ <div class="version-badge" id="version-badge">v2.13.7</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.13.5',
344
+ version: 'v2.13.7',
345
345
  bots: cfg.bots || [],
346
346
  telegramToken: cfg.telegramToken || null,
347
347
  whatsappConnected: cfg.whatsappConnected || false,
@@ -60,6 +60,7 @@ async function migrate(options) {
60
60
  telegram: null,
61
61
  whatsapp: false,
62
62
  scripts: 0,
63
+ skills: 0,
63
64
  };
64
65
 
65
66
  // 1. Memory migration
@@ -416,8 +417,39 @@ async function migrate(options) {
416
417
  console.log(chalk.gray('⚠️ WhatsApp session migration atlandı:', err.message));
417
418
  }
418
419
 
420
+ // 5. Skills migration
421
+ try {
422
+ const openclawSkillsDir = path.join(openclawDir, 'workspace', 'skills');
423
+ const naturecSkillsDir = path.join(os.homedir(), '.natureco', 'skills');
424
+
425
+ if (fs.existsSync(openclawSkillsDir)) {
426
+ fs.mkdirSync(naturecSkillsDir, { recursive: true });
427
+
428
+ const skills = fs.readdirSync(openclawSkillsDir);
429
+
430
+ for (const skill of skills) {
431
+ const src = path.join(openclawSkillsDir, skill);
432
+ const dst = path.join(naturecSkillsDir, skill);
433
+
434
+ // Skip if not a directory
435
+ if (!fs.statSync(src).isDirectory()) continue;
436
+
437
+ // Copy directory recursively
438
+ fs.cpSync(src, dst, { recursive: true });
439
+ report.skills++;
440
+ }
441
+
442
+ if (report.skills > 0) {
443
+ console.log(chalk.green(`✅ Skills: ${report.skills} skill migrate edildi`));
444
+ console.log(chalk.gray(` Konum: ~/.natureco/skills/`));
445
+ }
446
+ }
447
+ } catch (err) {
448
+ console.log(chalk.gray('⚠️ Skills migration atlandı:', err.message));
449
+ }
450
+
419
451
  // Print migration report
420
- console.log(chalk.green('✅ Migration tamamlandı!\n'));
452
+ console.log(chalk.green('\n✅ Migration tamamlandı!\n'));
421
453
 
422
454
  if (report.memory) {
423
455
  // Extract string facts for display (handle both string and object formats)
package/src/utils/api.js CHANGED
@@ -736,6 +736,26 @@ TOOL SELECTION GUIDE:
736
736
  systemPrompt += `\n\nFor GitHub MCP, prefer list_issues over search_issues when listing issues.`;
737
737
  }
738
738
 
739
+ // Add available skills information
740
+ const skillsDir = path.join(homeDir, '.natureco', 'skills');
741
+ if (fs.existsSync(skillsDir)) {
742
+ try {
743
+ const skills = fs.readdirSync(skillsDir).filter(f => {
744
+ const skillPath = path.join(skillsDir, f);
745
+ return fs.statSync(skillPath).isDirectory();
746
+ });
747
+
748
+ if (skills.length > 0) {
749
+ systemPrompt += `\n\nAVAILABLE SKILLS:`;
750
+ systemPrompt += `\nYou have ${skills.length} custom skills installed in ~/.natureco/skills/`;
751
+ systemPrompt += `\nSkills: ${skills.join(', ')}`;
752
+ systemPrompt += `\nThese skills may contain specialized scripts, tools, or workflows the user has configured.`;
753
+ }
754
+ } catch (err) {
755
+ // Silently skip if skills directory can't be read
756
+ }
757
+ }
758
+
739
759
  return sendMessageToProvider(apiKey, message, conversationId, systemPrompt);
740
760
  }
741
761
 
@@ -23,8 +23,8 @@ function loadMemory(botId) {
23
23
 
24
24
  if (!fs.existsSync(filePath)) {
25
25
  return {
26
- name: null,
27
- botName: null,
26
+ name: '',
27
+ botName: '',
28
28
  preferences: [],
29
29
  facts: [],
30
30
  lastSeen: null,
@@ -33,7 +33,16 @@ function loadMemory(botId) {
33
33
 
34
34
  try {
35
35
  const content = fs.readFileSync(filePath, 'utf8');
36
- const memory = JSON.parse(content);
36
+ const data = JSON.parse(content);
37
+
38
+ // Return with safe defaults for all fields
39
+ const memory = {
40
+ name: data.name || '',
41
+ botName: data.botName || '',
42
+ preferences: data.preferences || [],
43
+ facts: data.facts || [],
44
+ lastSeen: data.lastSeen || null,
45
+ };
37
46
 
38
47
  // Migrate old format to new format
39
48
  if (Array.isArray(memory.preferences) && memory.preferences.length > 0 && typeof memory.preferences[0] === 'string') {
@@ -43,16 +52,11 @@ function loadMemory(botId) {
43
52
  memory.facts = memory.facts.map(f => ({ value: f, score: 5, updatedAt: new Date().toISOString() }));
44
53
  }
45
54
 
46
- // Ensure botName field exists
47
- if (!memory.hasOwnProperty('botName')) {
48
- memory.botName = null;
49
- }
50
-
51
55
  return memory;
52
56
  } catch {
53
57
  return {
54
- name: null,
55
- botName: null,
58
+ name: '',
59
+ botName: '',
56
60
  preferences: [],
57
61
  facts: [],
58
62
  lastSeen: null,
@@ -196,32 +200,38 @@ function extractMemoryFromMessage(message) {
196
200
  function getMemoryPrompt(botId) {
197
201
  const memory = loadMemory(botId);
198
202
 
199
- if (!memory.name && !memory.botName && memory.preferences.length === 0 && memory.facts.length === 0) {
203
+ // Safe defaults for all fields
204
+ const name = memory.name || '';
205
+ const botName = memory.botName || '';
206
+ const preferences = memory.preferences || [];
207
+ const facts = memory.facts || [];
208
+
209
+ if (!name && !botName && preferences.length === 0 && facts.length === 0) {
200
210
  return '';
201
211
  }
202
212
 
203
213
  const parts = [];
204
214
 
205
215
  // Add bot name if set
206
- if (memory.botName) {
207
- parts.push(`Your name is ${memory.botName}.`);
216
+ if (botName) {
217
+ parts.push(`Your name is ${botName}.`);
208
218
  }
209
219
 
210
220
  // Add user memory section
211
- if (memory.name || memory.preferences.length > 0 || memory.facts.length > 0) {
221
+ if (name || preferences.length > 0 || facts.length > 0) {
212
222
  parts.push('## Kullanıcı Hafızası');
213
223
 
214
- if (memory.name) {
215
- parts.push(`İsim: ${memory.name}`);
224
+ if (name) {
225
+ parts.push(`İsim: ${name}`);
216
226
  }
217
227
 
218
- if (memory.preferences.length > 0) {
219
- const sorted = memory.preferences.sort((a, b) => b.score - a.score);
228
+ if (preferences.length > 0) {
229
+ const sorted = preferences.sort((a, b) => b.score - a.score);
220
230
  parts.push(`Tercihler: ${sorted.map(p => p.value).join(', ')}`);
221
231
  }
222
232
 
223
- if (memory.facts.length > 0) {
224
- const sorted = memory.facts.sort((a, b) => b.score - a.score);
233
+ if (facts.length > 0) {
234
+ const sorted = facts.sort((a, b) => b.score - a.score);
225
235
  parts.push(`Bilgiler: ${sorted.map(f => f.value).join(', ')}`);
226
236
  }
227
237
  }