dev/zhi #1
38
install.mjs
38
install.mjs
@@ -455,6 +455,44 @@ async function configure(env) {
|
|||||||
|
|
||||||
log('\n Add the following to your shell profile:', 'yellow');
|
log('\n Add the following to your shell profile:', 'yellow');
|
||||||
log(` source ${envFile}`, 'cyan');
|
log(` source ${envFile}`, 'cyan');
|
||||||
|
|
||||||
|
// Update OpenClaw plugins.load.paths configuration
|
||||||
|
log('\n Updating OpenClaw plugin configuration...', 'blue');
|
||||||
|
const openclawConfigPath = join(env.openclawDir || homedir(), '.openclaw', 'config.json');
|
||||||
|
|
||||||
|
if (existsSync(openclawConfigPath)) {
|
||||||
|
try {
|
||||||
|
const configContent = readFileSync(openclawConfigPath, 'utf8');
|
||||||
|
const config = JSON.parse(configContent);
|
||||||
|
|
||||||
|
// Ensure plugins.load.paths exists
|
||||||
|
if (!config.plugins) {
|
||||||
|
config.plugins = {};
|
||||||
|
}
|
||||||
|
if (!config.plugins.load) {
|
||||||
|
config.plugins.load = {};
|
||||||
|
}
|
||||||
|
if (!config.plugins.load.paths) {
|
||||||
|
config.plugins.load.paths = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add paddedcell skills path if not already present
|
||||||
|
const skillsPath = join(env.openclawDir || homedir(), '.openclaw', 'skills', 'paddedcell');
|
||||||
|
if (!config.plugins.load.paths.includes(skillsPath)) {
|
||||||
|
config.plugins.load.paths.push(skillsPath);
|
||||||
|
writeFileSync(openclawConfigPath, JSON.stringify(config, null, 2));
|
||||||
|
logSuccess(`Added plugin path to OpenClaw config: ${skillsPath}`);
|
||||||
|
} else {
|
||||||
|
log(' Plugin path already in OpenClaw config', 'green');
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
logWarning(`Failed to update OpenClaw config: ${err.message}`);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
logWarning(`OpenClaw config not found at ${openclawConfigPath}`);
|
||||||
|
log(' Please manually add the following to your OpenClaw config:', 'yellow');
|
||||||
|
log(` plugins.load.paths: ["${join(env.openclawDir || homedir(), '.openclaw', 'skills', 'paddedcell')}"]`, 'cyan');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// ============================================================================
|
// ============================================================================
|
||||||
|
|||||||
@@ -178,6 +178,13 @@ func adminInitCmd() *cobra.Command {
|
|||||||
Use: "admin init",
|
Use: "admin init",
|
||||||
Short: "Initialize pass_mgr with admin key",
|
Short: "Initialize pass_mgr with admin key",
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Run: func(cmd *cobra.Command, args []string) {
|
||||||
|
// Require --key-path parameter
|
||||||
|
if keyPath == "" {
|
||||||
|
fmt.Fprintln(os.Stderr, "Error: --key-path is required")
|
||||||
|
fmt.Fprintln(os.Stderr, "Usage: pass_mgr admin init --key-path <path-to-key-file>")
|
||||||
|
fmt.Fprintln(os.Stderr, "The key file must contain a password with at least 6 characters")
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
if err := initAdmin(keyPath); err != nil {
|
if err := initAdmin(keyPath); err != nil {
|
||||||
fmt.Fprintf(os.Stderr, "Error: %v\n", err)
|
fmt.Fprintf(os.Stderr, "Error: %v\n", err)
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
@@ -185,7 +192,7 @@ func adminInitCmd() *cobra.Command {
|
|||||||
fmt.Println("pass_mgr initialized successfully")
|
fmt.Println("pass_mgr initialized successfully")
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
cmd.Flags().StringVar(&keyPath, "key-path", "", "Path to admin key file (optional)")
|
cmd.Flags().StringVar(&keyPath, "key-path", "", "Path to admin key file (required, password must be >= 6 chars)")
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -258,20 +265,15 @@ func initAdmin(keyPath string) error {
|
|||||||
return fmt.Errorf("failed to create admin directory: %w", err)
|
return fmt.Errorf("failed to create admin directory: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
var key []byte
|
|
||||||
if keyPath != "" {
|
|
||||||
// Read provided key
|
// Read provided key
|
||||||
var err error
|
key, err := os.ReadFile(keyPath)
|
||||||
key, err = os.ReadFile(keyPath)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("failed to read key file: %w", err)
|
return fmt.Errorf("failed to read key file: %w", err)
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
// Generate new key
|
// Validate password length (must be >= 6 characters)
|
||||||
key = make([]byte, 32)
|
if len(key) < 6 {
|
||||||
if _, err := rand.Read(key); err != nil {
|
return fmt.Errorf("password must be at least 6 characters long (got %d)", len(key))
|
||||||
return fmt.Errorf("failed to generate key: %w", err)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Save key
|
// Save key
|
||||||
|
|||||||
Reference in New Issue
Block a user