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 +1 -1
- package/src/commands/dashboard.js +2 -2
- package/src/commands/migrate.js +33 -1
- package/src/utils/api.js +20 -0
- package/src/utils/memory.js +30 -20
package/package.json
CHANGED
|
@@ -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.
|
|
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.
|
|
344
|
+
version: 'v2.13.7',
|
|
345
345
|
bots: cfg.bots || [],
|
|
346
346
|
telegramToken: cfg.telegramToken || null,
|
|
347
347
|
whatsappConnected: cfg.whatsappConnected || false,
|
package/src/commands/migrate.js
CHANGED
|
@@ -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
|
|
package/src/utils/memory.js
CHANGED
|
@@ -23,8 +23,8 @@ function loadMemory(botId) {
|
|
|
23
23
|
|
|
24
24
|
if (!fs.existsSync(filePath)) {
|
|
25
25
|
return {
|
|
26
|
-
name:
|
|
27
|
-
botName:
|
|
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
|
|
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:
|
|
55
|
-
botName:
|
|
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
|
-
|
|
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 (
|
|
207
|
-
parts.push(`Your name is ${
|
|
216
|
+
if (botName) {
|
|
217
|
+
parts.push(`Your name is ${botName}.`);
|
|
208
218
|
}
|
|
209
219
|
|
|
210
220
|
// Add user memory section
|
|
211
|
-
if (
|
|
221
|
+
if (name || preferences.length > 0 || facts.length > 0) {
|
|
212
222
|
parts.push('## Kullanıcı Hafızası');
|
|
213
223
|
|
|
214
|
-
if (
|
|
215
|
-
parts.push(`İsim: ${
|
|
224
|
+
if (name) {
|
|
225
|
+
parts.push(`İsim: ${name}`);
|
|
216
226
|
}
|
|
217
227
|
|
|
218
|
-
if (
|
|
219
|
-
const sorted =
|
|
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 (
|
|
224
|
-
const sorted =
|
|
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
|
}
|