@within-7/minto 0.0.5 → 0.0.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/dist/components/PromptInput.js +4 -3
- package/dist/components/PromptInput.js.map +3 -3
- package/dist/components/SubagentProgress.js +6 -2
- package/dist/components/SubagentProgress.js.map +2 -2
- package/dist/components/TaskCard.js +2 -2
- package/dist/components/TaskCard.js.map +2 -2
- package/dist/components/TodoPanel.js +0 -1
- package/dist/components/TodoPanel.js.map +2 -2
- package/dist/components/messages/UserToolResultMessage/utils.js +2 -2
- package/dist/components/messages/UserToolResultMessage/utils.js.map +2 -2
- package/dist/entrypoints/cli.js +1 -0
- package/dist/entrypoints/cli.js.map +2 -2
- package/dist/index.js.map +1 -1
- package/dist/query.js.map +2 -2
- package/dist/screens/REPL.js +13 -12
- package/dist/screens/REPL.js.map +3 -3
- package/dist/services/hookExecutor.js +5 -3
- package/dist/services/hookExecutor.js.map +2 -2
- package/dist/utils/marketplaceManager.js +2 -1
- package/dist/utils/marketplaceManager.js.map +2 -2
- package/dist/utils/model.js +25 -0
- package/dist/utils/model.js.map +2 -2
- package/dist/utils/pluginValidator.js +9 -7
- package/dist/utils/pluginValidator.js.map +2 -2
- package/dist/utils/theme.js +36 -4
- package/dist/utils/theme.js.map +2 -2
- package/package.json +2 -2
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/utils/pluginValidator.ts"],
|
|
4
|
-
"sourcesContent": ["/**\n * Plugin Validation System\n *\n * Validates plugin manifests and component files for correctness.\n * Checks for proper structure, required fields, and file existence.\n */\n\nimport fs from 'fs'\nimport path from 'path'\nimport matter from 'gray-matter'\nimport semver from 'semver'\nimport { z } from 'zod'\nimport { PluginManifestSchema, type PluginManifest, type HookEvent } from '../types/plugin.js'\n\n/**\n * Validation error details\n */\nexport interface ValidationError {\n type: 'manifest' | 'agent' | 'command' | 'skill' | 'hook' | 'mcp' | 'dependency' | 'engine'\n file?: string\n message: string\n details?: any\n}\n\n/**\n * Validation warning details\n */\nexport interface ValidationWarning {\n type: string\n file?: string\n message: string\n}\n\n/**\n * Complete validation result\n */\nexport interface ValidationResult {\n valid: boolean\n errors: ValidationError[]\n warnings: ValidationWarning[]\n}\n\n/**\n * Agent YAML frontmatter schema\n */\nconst AgentFrontmatterSchema = z.object({\n name: z.string().min(1, 'Agent name is required'),\n description: z.string().min(1, 'Agent description is required'),\n tools: z.union([\n z.string(), // \"*\" for all tools\n z.array(z.string()).min(1, 'At least one tool must be specified'),\n ]).optional(),\n model: z.string().optional(),\n})\n\n/**\n * Command YAML frontmatter schema\n */\nconst CommandFrontmatterSchema = z.object({\n name: z.string().min(1, 'Command name is required'),\n description: z.string().optional(),\n aliases: z.array(z.string()).optional(),\n enabled: z.boolean().optional(),\n hidden: z.boolean().optional(),\n progressMessage: z.string().optional(),\n argNames: z.array(z.string()).optional(),\n 'allowed-tools': z.array(z.string()).optional(),\n})\n\n/**\n * Skill YAML frontmatter schema\n */\nconst SkillFrontmatterSchema = z.object({\n name: z.string().min(1, 'Skill name is required'),\n description: z.string().min(1, 'Skill description is required'),\n})\n\n/**\n * Hook configuration schema\n */\nconst HookConfigSchema = z.object({\n event: z.enum([\n 'PreToolUse',\n 'PostToolUse',\n 'UserPromptSubmit',\n 'SessionStart',\n 'SessionEnd',\n 'Stop',\n 'SubagentStop',\n 'Notification',\n 'PreCompact',\n ] as const),\n matcher: z.string().optional(),\n type: z.enum(['command', 'message', 'notification']),\n command: z.string().optional(),\n message: z.string().optional(),\n blocking: z.boolean().optional(),\n timeout: z.number().optional(),\n})\n\n/**\n * MCP Server configuration schema\n */\nconst MCPServerConfigSchema = z.object({\n command: z.string().min(1, 'MCP server command is required'),\n args: z.array(z.string()).optional(),\n env: z.record(z.string()).optional(),\n timeout: z.number().optional(),\n})\n\n/**\n * Validate complete plugin including manifest and all components\n */\nexport async function validatePlugin(pluginPath: string): Promise<ValidationResult> {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check if plugin directory exists\n if (!fs.existsSync(pluginPath)) {\n return {\n valid: false,\n errors: [{\n type: 'manifest',\n message: `Plugin directory does not exist: ${pluginPath}`,\n }],\n warnings: [],\n }\n }\n\n // Check if it's a directory\n const stats = fs.statSync(pluginPath)\n if (!stats.isDirectory()) {\n return {\n valid: false,\n errors: [{\n type: 'manifest',\n message: `Plugin path is not a directory: ${pluginPath}`,\n }],\n warnings: [],\n }\n }\n\n // Validate manifest\n const manifestPath = path.join(pluginPath, 'plugin.json')\n if (!fs.existsSync(manifestPath)) {\n return {\n valid: false,\n errors: [{\n type: 'manifest',\n file: 'plugin.json',\n message: 'Plugin manifest (plugin.json) not found',\n }],\n warnings: [],\n }\n }\n\n let manifest: PluginManifest\n try {\n const manifestContent = fs.readFileSync(manifestPath, 'utf-8')\n const manifestData = JSON.parse(manifestContent)\n\n // Validate with Zod schema\n const manifestResult = validateManifest(manifestData)\n errors.push(...manifestResult.errors)\n warnings.push(...manifestResult.warnings)\n\n if (!manifestResult.valid) {\n return { valid: false, errors, warnings }\n }\n\n manifest = manifestData as PluginManifest\n } catch (error) {\n return {\n valid: false,\n errors: [{\n type: 'manifest',\n file: 'plugin.json',\n message: `Failed to parse manifest: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n }],\n warnings: [],\n }\n }\n\n // Validate engines compatibility\n if (manifest.engines) {\n const engineResult = await validateEngines(manifest.engines)\n errors.push(...engineResult.errors)\n warnings.push(...engineResult.warnings)\n }\n\n // Validate agent files\n if (manifest.agents && manifest.agents.length > 0) {\n for (const agentFile of manifest.agents) {\n const agentPath = path.join(pluginPath, agentFile)\n const result = validateAgentFile(agentPath)\n errors.push(...result.errors)\n warnings.push(...result.warnings)\n }\n }\n\n // Validate command files\n if (manifest.commands && manifest.commands.length > 0) {\n for (const commandFile of manifest.commands) {\n const commandPath = path.join(pluginPath, commandFile)\n const result = validateCommandFile(commandPath)\n errors.push(...result.errors)\n warnings.push(...result.warnings)\n }\n }\n\n // Validate skill files\n if (manifest.skills && manifest.skills.length > 0) {\n for (const skillFile of manifest.skills) {\n const skillPath = path.join(pluginPath, skillFile)\n const result = validateSkillFile(skillPath)\n errors.push(...result.errors)\n warnings.push(...result.warnings)\n }\n }\n\n // Validate hook files\n if (manifest.hooks && manifest.hooks.length > 0) {\n for (const hookFile of manifest.hooks) {\n const hookPath = path.join(pluginPath, hookFile)\n const result = validateHookFile(hookPath)\n errors.push(...result.errors)\n warnings.push(...result.warnings)\n }\n }\n\n // Validate MCP server configs\n if (manifest.mcpServers && manifest.mcpServers.length > 0) {\n for (const mcpFile of manifest.mcpServers) {\n const mcpPath = path.join(pluginPath, mcpFile)\n const result = validateMCPServerFile(mcpPath)\n errors.push(...result.errors)\n warnings.push(...result.warnings)\n }\n }\n\n // Check for unused files warning\n const componentFiles = new Set([\n ...(manifest.agents || []),\n ...(manifest.commands || []),\n ...(manifest.skills || []),\n ...(manifest.hooks || []),\n ...(manifest.mcpServers || []),\n ])\n\n if (componentFiles.size === 0) {\n warnings.push({\n type: 'manifest',\n message: 'Plugin has no components (agents, commands, skills, hooks, or MCP servers)',\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate plugin manifest schema\n */\nexport function validateManifest(manifest: any): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check if manifest is an object\n if (!manifest || typeof manifest !== 'object') {\n return {\n valid: false,\n errors: [{\n type: 'manifest',\n message: 'Manifest must be a valid JSON object',\n }],\n warnings: [],\n }\n }\n\n // Validate with Zod schema\n try {\n PluginManifestSchema.parse(manifest)\n } catch (error) {\n if (error instanceof z.ZodError) {\n for (const issue of error.errors) {\n errors.push({\n type: 'manifest',\n message: `${issue.path.join('.')}: ${issue.message}`,\n details: issue,\n })\n }\n } else {\n errors.push({\n type: 'manifest',\n message: `Manifest validation failed: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n }\n\n // Additional validations\n if (manifest.name && !/^[a-z0-9-]+$/.test(manifest.name)) {\n errors.push({\n type: 'manifest',\n message: 'Plugin name must be lowercase alphanumeric with hyphens only',\n details: { name: manifest.name },\n })\n }\n\n // Validate version format (semver)\n if (manifest.version && !semver.valid(manifest.version)) {\n errors.push({\n type: 'manifest',\n message: `Invalid version format: ${manifest.version}. Must follow semver (e.g., 1.0.0)`,\n details: { version: manifest.version },\n })\n }\n\n // Validate URLs\n if (manifest.homepage) {\n try {\n new URL(manifest.homepage)\n } catch {\n errors.push({\n type: 'manifest',\n message: `Invalid homepage URL: ${manifest.homepage}`,\n })\n }\n }\n\n if (manifest.repository) {\n try {\n new URL(manifest.repository)\n } catch {\n errors.push({\n type: 'manifest',\n message: `Invalid repository URL: ${manifest.repository}`,\n })\n }\n }\n\n // Warn about missing optional but recommended fields\n if (!manifest.description) {\n warnings.push({\n type: 'manifest',\n message: 'Missing recommended field: description',\n })\n }\n\n if (!manifest.author) {\n warnings.push({\n type: 'manifest',\n message: 'Missing recommended field: author',\n })\n }\n\n if (!manifest.license) {\n warnings.push({\n type: 'manifest',\n message: 'Missing recommended field: license',\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate engine version requirements\n */\nasync function validateEngines(engines: { minto?: string; 'claude-code'?: string; node?: string }): Promise<ValidationResult> {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Validate minto version\n if (engines.minto) {\n const validRange = semver.validRange(engines.minto)\n if (!validRange) {\n errors.push({\n type: 'engine',\n message: `Invalid minto version range: ${engines.minto}`,\n details: { engine: 'minto', range: engines.minto },\n })\n } else {\n // Check compatibility with current version\n try {\n const { VERSION } = await import('../version.js')\n if (!semver.satisfies(VERSION, engines.minto)) {\n warnings.push({\n type: 'engine',\n message: `Plugin requires minto ${engines.minto}, but current version is ${VERSION}`,\n })\n }\n } catch {\n // Unable to check current version, skip this validation\n }\n }\n }\n\n // Validate node version\n if (engines.node) {\n const validRange = semver.validRange(engines.node)\n if (!validRange) {\n errors.push({\n type: 'engine',\n message: `Invalid node version range: ${engines.node}`,\n details: { engine: 'node', range: engines.node },\n })\n } else {\n // Check compatibility with current node version\n if (!semver.satisfies(process.version, engines.node)) {\n warnings.push({\n type: 'engine',\n message: `Plugin requires node ${engines.node}, but current version is ${process.version}`,\n })\n }\n }\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate agent file\n */\nexport function validateAgentFile(filePath: string): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check file exists\n if (!fs.existsSync(filePath)) {\n return {\n valid: false,\n errors: [{\n type: 'agent',\n file: filePath,\n message: `Agent file not found: ${filePath}`,\n }],\n warnings: [],\n }\n }\n\n // Check file extension\n const ext = path.extname(filePath)\n if (ext !== '.md' && ext !== '.markdown') {\n warnings.push({\n type: 'agent',\n file: filePath,\n message: `Agent file should have .md or .markdown extension, got: ${ext}`,\n })\n }\n\n // Parse YAML frontmatter\n try {\n const content = fs.readFileSync(filePath, 'utf-8')\n const parsed = matter(content)\n\n // Validate frontmatter exists\n if (!parsed.data || Object.keys(parsed.data).length === 0) {\n errors.push({\n type: 'agent',\n file: filePath,\n message: 'Agent file must have YAML frontmatter',\n })\n return { valid: false, errors, warnings }\n }\n\n // Validate frontmatter schema\n try {\n AgentFrontmatterSchema.parse(parsed.data)\n } catch (error) {\n if (error instanceof z.ZodError) {\n for (const issue of error.errors) {\n errors.push({\n type: 'agent',\n file: filePath,\n message: `Frontmatter ${issue.path.join('.')}: ${issue.message}`,\n details: issue,\n })\n }\n }\n }\n\n // Check for content\n if (!parsed.content || parsed.content.trim().length === 0) {\n warnings.push({\n type: 'agent',\n file: filePath,\n message: 'Agent file has no content after frontmatter',\n })\n }\n\n // Validate tools field\n if (parsed.data.tools) {\n if (Array.isArray(parsed.data.tools)) {\n if (parsed.data.tools.length === 0) {\n errors.push({\n type: 'agent',\n file: filePath,\n message: 'Tools array cannot be empty (use \"*\" for all tools or omit the field)',\n })\n }\n } else if (parsed.data.tools !== '*') {\n errors.push({\n type: 'agent',\n file: filePath,\n message: 'Tools must be an array of tool names or \"*\" for all tools',\n details: { tools: parsed.data.tools },\n })\n }\n }\n\n } catch (error) {\n errors.push({\n type: 'agent',\n file: filePath,\n message: `Failed to parse agent file: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate command file\n */\nexport function validateCommandFile(filePath: string): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check file exists\n if (!fs.existsSync(filePath)) {\n return {\n valid: false,\n errors: [{\n type: 'command',\n file: filePath,\n message: `Command file not found: ${filePath}`,\n }],\n warnings: [],\n }\n }\n\n // Check file extension\n const ext = path.extname(filePath)\n if (ext !== '.md' && ext !== '.markdown') {\n warnings.push({\n type: 'command',\n file: filePath,\n message: `Command file should have .md or .markdown extension, got: ${ext}`,\n })\n }\n\n // Parse YAML frontmatter\n try {\n const content = fs.readFileSync(filePath, 'utf-8')\n const parsed = matter(content)\n\n // Validate frontmatter exists\n if (!parsed.data || Object.keys(parsed.data).length === 0) {\n errors.push({\n type: 'command',\n file: filePath,\n message: 'Command file must have YAML frontmatter',\n })\n return { valid: false, errors, warnings }\n }\n\n // Validate frontmatter schema\n try {\n CommandFrontmatterSchema.parse(parsed.data)\n } catch (error) {\n if (error instanceof z.ZodError) {\n for (const issue of error.errors) {\n errors.push({\n type: 'command',\n file: filePath,\n message: `Frontmatter ${issue.path.join('.')}: ${issue.message}`,\n details: issue,\n })\n }\n }\n }\n\n // Check for content\n if (!parsed.content || parsed.content.trim().length === 0) {\n warnings.push({\n type: 'command',\n file: filePath,\n message: 'Command file has no content after frontmatter',\n })\n }\n\n // Validate name matches filename\n const filename = path.basename(filePath, path.extname(filePath))\n if (parsed.data.name && parsed.data.name !== filename) {\n warnings.push({\n type: 'command',\n file: filePath,\n message: `Command name \"${parsed.data.name}\" does not match filename \"${filename}\"`,\n })\n }\n\n } catch (error) {\n errors.push({\n type: 'command',\n file: filePath,\n message: `Failed to parse command file: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate skill file\n */\nexport function validateSkillFile(filePath: string): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check file exists\n if (!fs.existsSync(filePath)) {\n return {\n valid: false,\n errors: [{\n type: 'skill',\n file: filePath,\n message: `Skill file not found: ${filePath}`,\n }],\n warnings: [],\n }\n }\n\n // Check file extension\n const ext = path.extname(filePath)\n if (ext !== '.md' && ext !== '.markdown') {\n warnings.push({\n type: 'skill',\n file: filePath,\n message: `Skill file should have .md or .markdown extension, got: ${ext}`,\n })\n }\n\n // Parse YAML frontmatter\n try {\n const content = fs.readFileSync(filePath, 'utf-8')\n const parsed = matter(content)\n\n // Validate frontmatter exists\n if (!parsed.data || Object.keys(parsed.data).length === 0) {\n errors.push({\n type: 'skill',\n file: filePath,\n message: 'Skill file must have YAML frontmatter',\n })\n return { valid: false, errors, warnings }\n }\n\n // Validate frontmatter schema\n try {\n SkillFrontmatterSchema.parse(parsed.data)\n } catch (error) {\n if (error instanceof z.ZodError) {\n for (const issue of error.errors) {\n errors.push({\n type: 'skill',\n file: filePath,\n message: `Frontmatter ${issue.path.join('.')}: ${issue.message}`,\n details: issue,\n })\n }\n }\n }\n\n // Check for content\n if (!parsed.content || parsed.content.trim().length === 0) {\n warnings.push({\n type: 'skill',\n file: filePath,\n message: 'Skill file has no content after frontmatter',\n })\n }\n\n } catch (error) {\n errors.push({\n type: 'skill',\n file: filePath,\n message: `Failed to parse skill file: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate hook file\n */\nexport function validateHookFile(filePath: string): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check file exists\n if (!fs.existsSync(filePath)) {\n return {\n valid: false,\n errors: [{\n type: 'hook',\n file: filePath,\n message: `Hook file not found: ${filePath}`,\n }],\n warnings: [],\n }\n }\n\n // Check file extension\n const ext = path.extname(filePath)\n const validExtensions = ['.js', '.mjs', '.ts', '.tsx', '.json']\n if (!validExtensions.includes(ext)) {\n errors.push({\n type: 'hook',\n file: filePath,\n message: `Hook file must have extension: ${validExtensions.join(', ')}. Got: ${ext}`,\n })\n return { valid: false, errors, warnings }\n }\n\n // For JSON hook configs, validate structure\n if (ext === '.json') {\n try {\n const content = fs.readFileSync(filePath, 'utf-8')\n const config = JSON.parse(content)\n\n // Validate hook config schema\n try {\n HookConfigSchema.parse(config)\n } catch (error) {\n if (error instanceof z.ZodError) {\n for (const issue of error.errors) {\n errors.push({\n type: 'hook',\n file: filePath,\n message: `Hook config ${issue.path.join('.')}: ${issue.message}`,\n details: issue,\n })\n }\n }\n }\n\n // Type-specific validation\n if (config.type === 'command' && !config.command) {\n errors.push({\n type: 'hook',\n file: filePath,\n message: 'Hook type \"command\" requires a \"command\" field',\n })\n }\n\n if (config.type === 'message' && !config.message) {\n errors.push({\n type: 'hook',\n file: filePath,\n message: 'Hook type \"message\" requires a \"message\" field',\n })\n }\n\n } catch (error) {\n errors.push({\n type: 'hook',\n file: filePath,\n message: `Failed to parse hook config: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n } else {\n // For JS/TS files, just check they're readable\n try {\n fs.readFileSync(filePath, 'utf-8')\n } catch (error) {\n errors.push({\n type: 'hook',\n file: filePath,\n message: `Failed to read hook file: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n\n // Warn about JS/TS hooks needing runtime validation\n warnings.push({\n type: 'hook',\n file: filePath,\n message: 'JavaScript/TypeScript hooks will be validated at runtime',\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate MCP server configuration file\n */\nexport function validateMCPServerFile(filePath: string): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check file exists\n if (!fs.existsSync(filePath)) {\n return {\n valid: false,\n errors: [{\n type: 'mcp',\n file: filePath,\n message: `MCP server config file not found: ${filePath}`,\n }],\n warnings: [],\n }\n }\n\n // Check file extension\n const ext = path.extname(filePath)\n if (ext !== '.json') {\n errors.push({\n type: 'mcp',\n file: filePath,\n message: `MCP server config must be a JSON file, got: ${ext}`,\n })\n return { valid: false, errors, warnings }\n }\n\n // Parse and validate JSON\n try {\n const content = fs.readFileSync(filePath, 'utf-8')\n const config = JSON.parse(content)\n\n // Validate MCP config schema\n try {\n MCPServerConfigSchema.parse(config)\n } catch (error) {\n if (error instanceof z.ZodError) {\n for (const issue of error.errors) {\n errors.push({\n type: 'mcp',\n file: filePath,\n message: `MCP config ${issue.path.join('.')}: ${issue.message}`,\n details: issue,\n })\n }\n }\n }\n\n // Validate command is not empty\n if (config.command && config.command.trim().length === 0) {\n errors.push({\n type: 'mcp',\n file: filePath,\n message: 'MCP server command cannot be empty',\n })\n }\n\n // Warn about timeout\n if (config.timeout && config.timeout < 1000) {\n warnings.push({\n type: 'mcp',\n file: filePath,\n message: `MCP server timeout is very low (${config.timeout}ms), consider increasing`,\n })\n }\n\n } catch (error) {\n errors.push({\n type: 'mcp',\n file: filePath,\n message: `Failed to parse MCP server config: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate plugin dependencies\n */\nexport function validateDependencies(\n dependencies: Record<string, string>,\n installedPackages?: Set<string>\n): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n for (const [pkg, version] of Object.entries(dependencies)) {\n // Validate version format\n const validRange = semver.validRange(version)\n if (!validRange) {\n errors.push({\n type: 'dependency',\n message: `Invalid version range for ${pkg}: ${version}`,\n details: { package: pkg, version },\n })\n }\n\n // Check if installed (if provided)\n if (installedPackages && !installedPackages.has(pkg)) {\n warnings.push({\n type: 'dependency',\n message: `Dependency not installed: ${pkg}@${version}`,\n })\n }\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Batch validate multiple plugins\n */\nexport async function validatePlugins(pluginPaths: string[]): Promise<Map<string, ValidationResult>> {\n const results = new Map<string, ValidationResult>()\n\n await Promise.all(\n pluginPaths.map(async (pluginPath) => {\n const result = await validatePlugin(pluginPath)\n results.set(pluginPath, result)\n })\n )\n\n return results\n}\n\n/**\n * Format validation result as human-readable string\n */\nexport function formatValidationResult(result: ValidationResult, pluginName?: string): string {\n const lines: string[] = []\n\n if (pluginName) {\n lines.push(`Plugin: ${pluginName}`)\n }\n\n if (result.valid) {\n lines.push('\u2713 Validation passed')\n } else {\n lines.push(`\u2717 Validation failed with ${result.errors.length} error(s)`)\n }\n\n if (result.errors.length > 0) {\n lines.push('\\nErrors:')\n for (const error of result.errors) {\n const location = error.file ? ` (${error.file})` : ''\n lines.push(` \u2022 [${error.type}]${location} ${error.message}`)\n }\n }\n\n if (result.warnings.length > 0) {\n lines.push('\\nWarnings:')\n for (const warning of result.warnings) {\n const location = warning.file ? ` (${warning.file})` : ''\n lines.push(` \u2022 [${warning.type}]${location} ${warning.message}`)\n }\n }\n\n return lines.join('\\n')\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
4
|
+
"sourcesContent": ["/**\n * Plugin Validation System\n *\n * Validates plugin manifests and component files for correctness.\n * Checks for proper structure, required fields, and file existence.\n */\n\nimport fs from 'fs'\nimport path from 'path'\nimport matter from 'gray-matter'\nimport semver from 'semver'\nimport { z } from 'zod'\nimport { PluginManifestSchema, type PluginManifest, type HookEvent } from '../types/plugin.js'\n\n/**\n * Validation error details\n */\nexport interface ValidationError {\n type: 'manifest' | 'agent' | 'command' | 'skill' | 'hook' | 'mcp' | 'dependency' | 'engine'\n file?: string\n message: string\n details?: any\n}\n\n/**\n * Validation warning details\n */\nexport interface ValidationWarning {\n type: string\n file?: string\n message: string\n}\n\n/**\n * Complete validation result\n */\nexport interface ValidationResult {\n valid: boolean\n errors: ValidationError[]\n warnings: ValidationWarning[]\n}\n\n/**\n * Agent YAML frontmatter schema\n */\nconst AgentFrontmatterSchema = z.object({\n name: z.string().min(1, 'Agent name is required'),\n description: z.string().min(1, 'Agent description is required'),\n tools: z.union([\n z.string(), // \"*\" for all tools\n z.array(z.string()).min(1, 'At least one tool must be specified'),\n ]).optional(),\n model: z.string().optional(),\n})\n\n/**\n * Command YAML frontmatter schema\n */\nconst CommandFrontmatterSchema = z.object({\n name: z.string().min(1, 'Command name is required'),\n description: z.string().optional(),\n aliases: z.array(z.string()).optional(),\n enabled: z.boolean().optional(),\n hidden: z.boolean().optional(),\n progressMessage: z.string().optional(),\n argNames: z.array(z.string()).optional(),\n 'allowed-tools': z.array(z.string()).optional(),\n})\n\n/**\n * Skill YAML frontmatter schema\n */\nconst SkillFrontmatterSchema = z.object({\n name: z.string().min(1, 'Skill name is required'),\n description: z.string().min(1, 'Skill description is required'),\n})\n\n/**\n * Hook configuration schema\n */\nconst HookConfigSchema = z.object({\n event: z.enum([\n 'PreToolUse',\n 'PostToolUse',\n 'UserPromptSubmit',\n 'SessionStart',\n 'SessionEnd',\n 'Stop',\n 'SubagentStop',\n 'Notification',\n 'PreCompact',\n ] as const),\n matcher: z.string().optional(),\n type: z.enum(['command', 'message', 'notification']),\n command: z.string().optional(),\n message: z.string().optional(),\n blocking: z.boolean().optional(),\n timeout: z.number().optional(),\n})\n\n/**\n * MCP Server configuration schema\n */\nconst MCPServerConfigSchema = z.object({\n command: z.string().min(1, 'MCP server command is required'),\n args: z.array(z.string()).optional(),\n env: z.record(z.string()).optional(),\n timeout: z.number().optional(),\n})\n\n/**\n * Validate complete plugin including manifest and all components\n */\nexport async function validatePlugin(pluginPath: string): Promise<ValidationResult> {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check if plugin directory exists\n if (!fs.existsSync(pluginPath)) {\n return {\n valid: false,\n errors: [{\n type: 'manifest',\n message: `Plugin directory does not exist: ${pluginPath}`,\n }],\n warnings: [],\n }\n }\n\n // Check if it's a directory\n const stats = fs.statSync(pluginPath)\n if (!stats.isDirectory()) {\n return {\n valid: false,\n errors: [{\n type: 'manifest',\n message: `Plugin path is not a directory: ${pluginPath}`,\n }],\n warnings: [],\n }\n }\n\n // Validate manifest\n const manifestPath = path.join(pluginPath, 'plugin.json')\n if (!fs.existsSync(manifestPath)) {\n return {\n valid: false,\n errors: [{\n type: 'manifest',\n file: 'plugin.json',\n message: 'Plugin manifest (plugin.json) not found',\n }],\n warnings: [],\n }\n }\n\n let manifest: PluginManifest\n try {\n const manifestContent = fs.readFileSync(manifestPath, 'utf-8')\n const manifestData = JSON.parse(manifestContent)\n\n // Validate with Zod schema\n const manifestResult = validateManifest(manifestData)\n errors.push(...manifestResult.errors)\n warnings.push(...manifestResult.warnings)\n\n if (!manifestResult.valid) {\n return { valid: false, errors, warnings }\n }\n\n manifest = manifestData as PluginManifest\n } catch (error) {\n return {\n valid: false,\n errors: [{\n type: 'manifest',\n file: 'plugin.json',\n message: `Failed to parse manifest: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n }],\n warnings: [],\n }\n }\n\n // Validate engines compatibility\n if (manifest.engines) {\n const engineResult = await validateEngines(manifest.engines)\n errors.push(...engineResult.errors)\n warnings.push(...engineResult.warnings)\n }\n\n // Validate agent files\n if (manifest.agents && manifest.agents.length > 0) {\n for (const agentFile of manifest.agents) {\n const agentPath = path.join(pluginPath, agentFile)\n const result = validateAgentFile(agentPath)\n errors.push(...result.errors)\n warnings.push(...result.warnings)\n }\n }\n\n // Validate command files\n if (manifest.commands && manifest.commands.length > 0) {\n for (const commandFile of manifest.commands) {\n const commandPath = path.join(pluginPath, commandFile)\n const result = validateCommandFile(commandPath)\n errors.push(...result.errors)\n warnings.push(...result.warnings)\n }\n }\n\n // Validate skill files\n if (manifest.skills && manifest.skills.length > 0) {\n for (const skillFile of manifest.skills) {\n const skillPath = path.join(pluginPath, skillFile)\n const result = validateSkillFile(skillPath)\n errors.push(...result.errors)\n warnings.push(...result.warnings)\n }\n }\n\n // Validate hook files\n if (manifest.hooks && manifest.hooks.length > 0) {\n for (const hookFile of manifest.hooks) {\n const hookPath = path.join(pluginPath, hookFile)\n const result = validateHookFile(hookPath)\n errors.push(...result.errors)\n warnings.push(...result.warnings)\n }\n }\n\n // Validate MCP server configs\n // mcpServers can be either an array of file paths or an object with inline configs\n if (manifest.mcpServers) {\n if (Array.isArray(manifest.mcpServers) && manifest.mcpServers.length > 0) {\n for (const mcpFile of manifest.mcpServers) {\n const mcpPath = path.join(pluginPath, mcpFile)\n const result = validateMCPServerFile(mcpPath)\n errors.push(...result.errors)\n warnings.push(...result.warnings)\n }\n }\n // If it's an object (inline configs), skip file validation\n }\n\n // Check for unused files warning\n const componentFiles = new Set([\n ...(manifest.agents || []),\n ...(manifest.commands || []),\n ...(manifest.skills || []),\n ...(manifest.hooks || []),\n ...(Array.isArray(manifest.mcpServers) ? manifest.mcpServers : []),\n ])\n\n if (componentFiles.size === 0) {\n warnings.push({\n type: 'manifest',\n message: 'Plugin has no components (agents, commands, skills, hooks, or MCP servers)',\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate plugin manifest schema\n */\nexport function validateManifest(manifest: any): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check if manifest is an object\n if (!manifest || typeof manifest !== 'object') {\n return {\n valid: false,\n errors: [{\n type: 'manifest',\n message: 'Manifest must be a valid JSON object',\n }],\n warnings: [],\n }\n }\n\n // Validate with Zod schema\n try {\n PluginManifestSchema.parse(manifest)\n } catch (error) {\n if (error instanceof z.ZodError) {\n for (const issue of error.errors) {\n errors.push({\n type: 'manifest',\n message: `${issue.path.join('.')}: ${issue.message}`,\n details: issue,\n })\n }\n } else {\n errors.push({\n type: 'manifest',\n message: `Manifest validation failed: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n }\n\n // Additional validations\n if (manifest.name && !/^[a-z0-9-]+$/.test(manifest.name)) {\n errors.push({\n type: 'manifest',\n message: 'Plugin name must be lowercase alphanumeric with hyphens only',\n details: { name: manifest.name },\n })\n }\n\n // Validate version format (semver)\n if (manifest.version && !semver.valid(manifest.version)) {\n errors.push({\n type: 'manifest',\n message: `Invalid version format: ${manifest.version}. Must follow semver (e.g., 1.0.0)`,\n details: { version: manifest.version },\n })\n }\n\n // Validate URLs\n if (manifest.homepage) {\n try {\n new URL(manifest.homepage)\n } catch {\n errors.push({\n type: 'manifest',\n message: `Invalid homepage URL: ${manifest.homepage}`,\n })\n }\n }\n\n if (manifest.repository) {\n try {\n new URL(manifest.repository)\n } catch {\n errors.push({\n type: 'manifest',\n message: `Invalid repository URL: ${manifest.repository}`,\n })\n }\n }\n\n // Warn about missing optional but recommended fields\n if (!manifest.description) {\n warnings.push({\n type: 'manifest',\n message: 'Missing recommended field: description',\n })\n }\n\n if (!manifest.author) {\n warnings.push({\n type: 'manifest',\n message: 'Missing recommended field: author',\n })\n }\n\n if (!manifest.license) {\n warnings.push({\n type: 'manifest',\n message: 'Missing recommended field: license',\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate engine version requirements\n */\nasync function validateEngines(engines: { minto?: string; 'claude-code'?: string; node?: string }): Promise<ValidationResult> {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Validate minto version\n if (engines.minto) {\n const validRange = semver.validRange(engines.minto)\n if (!validRange) {\n errors.push({\n type: 'engine',\n message: `Invalid minto version range: ${engines.minto}`,\n details: { engine: 'minto', range: engines.minto },\n })\n } else {\n // Check compatibility with current version\n try {\n const { VERSION } = await import('../version.js')\n if (!semver.satisfies(VERSION, engines.minto)) {\n warnings.push({\n type: 'engine',\n message: `Plugin requires minto ${engines.minto}, but current version is ${VERSION}`,\n })\n }\n } catch {\n // Unable to check current version, skip this validation\n }\n }\n }\n\n // Validate node version\n if (engines.node) {\n const validRange = semver.validRange(engines.node)\n if (!validRange) {\n errors.push({\n type: 'engine',\n message: `Invalid node version range: ${engines.node}`,\n details: { engine: 'node', range: engines.node },\n })\n } else {\n // Check compatibility with current node version\n if (!semver.satisfies(process.version, engines.node)) {\n warnings.push({\n type: 'engine',\n message: `Plugin requires node ${engines.node}, but current version is ${process.version}`,\n })\n }\n }\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate agent file\n */\nexport function validateAgentFile(filePath: string): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check file exists\n if (!fs.existsSync(filePath)) {\n return {\n valid: false,\n errors: [{\n type: 'agent',\n file: filePath,\n message: `Agent file not found: ${filePath}`,\n }],\n warnings: [],\n }\n }\n\n // Check file extension\n const ext = path.extname(filePath)\n if (ext !== '.md' && ext !== '.markdown') {\n warnings.push({\n type: 'agent',\n file: filePath,\n message: `Agent file should have .md or .markdown extension, got: ${ext}`,\n })\n }\n\n // Parse YAML frontmatter\n try {\n const content = fs.readFileSync(filePath, 'utf-8')\n const parsed = matter(content)\n\n // Validate frontmatter exists\n if (!parsed.data || Object.keys(parsed.data).length === 0) {\n errors.push({\n type: 'agent',\n file: filePath,\n message: 'Agent file must have YAML frontmatter',\n })\n return { valid: false, errors, warnings }\n }\n\n // Validate frontmatter schema\n try {\n AgentFrontmatterSchema.parse(parsed.data)\n } catch (error) {\n if (error instanceof z.ZodError) {\n for (const issue of error.errors) {\n errors.push({\n type: 'agent',\n file: filePath,\n message: `Frontmatter ${issue.path.join('.')}: ${issue.message}`,\n details: issue,\n })\n }\n }\n }\n\n // Check for content\n if (!parsed.content || parsed.content.trim().length === 0) {\n warnings.push({\n type: 'agent',\n file: filePath,\n message: 'Agent file has no content after frontmatter',\n })\n }\n\n // Validate tools field\n if (parsed.data.tools) {\n if (Array.isArray(parsed.data.tools)) {\n if (parsed.data.tools.length === 0) {\n errors.push({\n type: 'agent',\n file: filePath,\n message: 'Tools array cannot be empty (use \"*\" for all tools or omit the field)',\n })\n }\n } else if (parsed.data.tools !== '*') {\n errors.push({\n type: 'agent',\n file: filePath,\n message: 'Tools must be an array of tool names or \"*\" for all tools',\n details: { tools: parsed.data.tools },\n })\n }\n }\n\n } catch (error) {\n errors.push({\n type: 'agent',\n file: filePath,\n message: `Failed to parse agent file: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate command file\n */\nexport function validateCommandFile(filePath: string): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check file exists\n if (!fs.existsSync(filePath)) {\n return {\n valid: false,\n errors: [{\n type: 'command',\n file: filePath,\n message: `Command file not found: ${filePath}`,\n }],\n warnings: [],\n }\n }\n\n // Check file extension\n const ext = path.extname(filePath)\n if (ext !== '.md' && ext !== '.markdown') {\n warnings.push({\n type: 'command',\n file: filePath,\n message: `Command file should have .md or .markdown extension, got: ${ext}`,\n })\n }\n\n // Parse YAML frontmatter\n try {\n const content = fs.readFileSync(filePath, 'utf-8')\n const parsed = matter(content)\n\n // Validate frontmatter exists\n if (!parsed.data || Object.keys(parsed.data).length === 0) {\n errors.push({\n type: 'command',\n file: filePath,\n message: 'Command file must have YAML frontmatter',\n })\n return { valid: false, errors, warnings }\n }\n\n // Validate frontmatter schema\n try {\n CommandFrontmatterSchema.parse(parsed.data)\n } catch (error) {\n if (error instanceof z.ZodError) {\n for (const issue of error.errors) {\n errors.push({\n type: 'command',\n file: filePath,\n message: `Frontmatter ${issue.path.join('.')}: ${issue.message}`,\n details: issue,\n })\n }\n }\n }\n\n // Check for content\n if (!parsed.content || parsed.content.trim().length === 0) {\n warnings.push({\n type: 'command',\n file: filePath,\n message: 'Command file has no content after frontmatter',\n })\n }\n\n // Validate name matches filename\n const filename = path.basename(filePath, path.extname(filePath))\n if (parsed.data.name && parsed.data.name !== filename) {\n warnings.push({\n type: 'command',\n file: filePath,\n message: `Command name \"${parsed.data.name}\" does not match filename \"${filename}\"`,\n })\n }\n\n } catch (error) {\n errors.push({\n type: 'command',\n file: filePath,\n message: `Failed to parse command file: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate skill file\n */\nexport function validateSkillFile(filePath: string): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check file exists\n if (!fs.existsSync(filePath)) {\n return {\n valid: false,\n errors: [{\n type: 'skill',\n file: filePath,\n message: `Skill file not found: ${filePath}`,\n }],\n warnings: [],\n }\n }\n\n // Check file extension\n const ext = path.extname(filePath)\n if (ext !== '.md' && ext !== '.markdown') {\n warnings.push({\n type: 'skill',\n file: filePath,\n message: `Skill file should have .md or .markdown extension, got: ${ext}`,\n })\n }\n\n // Parse YAML frontmatter\n try {\n const content = fs.readFileSync(filePath, 'utf-8')\n const parsed = matter(content)\n\n // Validate frontmatter exists\n if (!parsed.data || Object.keys(parsed.data).length === 0) {\n errors.push({\n type: 'skill',\n file: filePath,\n message: 'Skill file must have YAML frontmatter',\n })\n return { valid: false, errors, warnings }\n }\n\n // Validate frontmatter schema\n try {\n SkillFrontmatterSchema.parse(parsed.data)\n } catch (error) {\n if (error instanceof z.ZodError) {\n for (const issue of error.errors) {\n errors.push({\n type: 'skill',\n file: filePath,\n message: `Frontmatter ${issue.path.join('.')}: ${issue.message}`,\n details: issue,\n })\n }\n }\n }\n\n // Check for content\n if (!parsed.content || parsed.content.trim().length === 0) {\n warnings.push({\n type: 'skill',\n file: filePath,\n message: 'Skill file has no content after frontmatter',\n })\n }\n\n } catch (error) {\n errors.push({\n type: 'skill',\n file: filePath,\n message: `Failed to parse skill file: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate hook file\n */\nexport function validateHookFile(filePath: string): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check file exists\n if (!fs.existsSync(filePath)) {\n return {\n valid: false,\n errors: [{\n type: 'hook',\n file: filePath,\n message: `Hook file not found: ${filePath}`,\n }],\n warnings: [],\n }\n }\n\n // Check file extension\n const ext = path.extname(filePath)\n const validExtensions = ['.js', '.mjs', '.ts', '.tsx', '.json']\n if (!validExtensions.includes(ext)) {\n errors.push({\n type: 'hook',\n file: filePath,\n message: `Hook file must have extension: ${validExtensions.join(', ')}. Got: ${ext}`,\n })\n return { valid: false, errors, warnings }\n }\n\n // For JSON hook configs, validate structure\n if (ext === '.json') {\n try {\n const content = fs.readFileSync(filePath, 'utf-8')\n const config = JSON.parse(content)\n\n // Validate hook config schema\n try {\n HookConfigSchema.parse(config)\n } catch (error) {\n if (error instanceof z.ZodError) {\n for (const issue of error.errors) {\n errors.push({\n type: 'hook',\n file: filePath,\n message: `Hook config ${issue.path.join('.')}: ${issue.message}`,\n details: issue,\n })\n }\n }\n }\n\n // Type-specific validation\n if (config.type === 'command' && !config.command) {\n errors.push({\n type: 'hook',\n file: filePath,\n message: 'Hook type \"command\" requires a \"command\" field',\n })\n }\n\n if (config.type === 'message' && !config.message) {\n errors.push({\n type: 'hook',\n file: filePath,\n message: 'Hook type \"message\" requires a \"message\" field',\n })\n }\n\n } catch (error) {\n errors.push({\n type: 'hook',\n file: filePath,\n message: `Failed to parse hook config: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n } else {\n // For JS/TS files, just check they're readable\n try {\n fs.readFileSync(filePath, 'utf-8')\n } catch (error) {\n errors.push({\n type: 'hook',\n file: filePath,\n message: `Failed to read hook file: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n\n // Warn about JS/TS hooks needing runtime validation\n warnings.push({\n type: 'hook',\n file: filePath,\n message: 'JavaScript/TypeScript hooks will be validated at runtime',\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate MCP server configuration file\n */\nexport function validateMCPServerFile(filePath: string): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n // Check file exists\n if (!fs.existsSync(filePath)) {\n return {\n valid: false,\n errors: [{\n type: 'mcp',\n file: filePath,\n message: `MCP server config file not found: ${filePath}`,\n }],\n warnings: [],\n }\n }\n\n // Check file extension\n const ext = path.extname(filePath)\n if (ext !== '.json') {\n errors.push({\n type: 'mcp',\n file: filePath,\n message: `MCP server config must be a JSON file, got: ${ext}`,\n })\n return { valid: false, errors, warnings }\n }\n\n // Parse and validate JSON\n try {\n const content = fs.readFileSync(filePath, 'utf-8')\n const config = JSON.parse(content)\n\n // Validate MCP config schema\n try {\n MCPServerConfigSchema.parse(config)\n } catch (error) {\n if (error instanceof z.ZodError) {\n for (const issue of error.errors) {\n errors.push({\n type: 'mcp',\n file: filePath,\n message: `MCP config ${issue.path.join('.')}: ${issue.message}`,\n details: issue,\n })\n }\n }\n }\n\n // Validate command is not empty\n if (config.command && config.command.trim().length === 0) {\n errors.push({\n type: 'mcp',\n file: filePath,\n message: 'MCP server command cannot be empty',\n })\n }\n\n // Warn about timeout\n if (config.timeout && config.timeout < 1000) {\n warnings.push({\n type: 'mcp',\n file: filePath,\n message: `MCP server timeout is very low (${config.timeout}ms), consider increasing`,\n })\n }\n\n } catch (error) {\n errors.push({\n type: 'mcp',\n file: filePath,\n message: `Failed to parse MCP server config: ${error instanceof Error ? error.message : String(error)}`,\n details: error,\n })\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Validate plugin dependencies\n */\nexport function validateDependencies(\n dependencies: Record<string, string>,\n installedPackages?: Set<string>\n): ValidationResult {\n const errors: ValidationError[] = []\n const warnings: ValidationWarning[] = []\n\n for (const [pkg, version] of Object.entries(dependencies)) {\n // Validate version format\n const validRange = semver.validRange(version)\n if (!validRange) {\n errors.push({\n type: 'dependency',\n message: `Invalid version range for ${pkg}: ${version}`,\n details: { package: pkg, version },\n })\n }\n\n // Check if installed (if provided)\n if (installedPackages && !installedPackages.has(pkg)) {\n warnings.push({\n type: 'dependency',\n message: `Dependency not installed: ${pkg}@${version}`,\n })\n }\n }\n\n return {\n valid: errors.length === 0,\n errors,\n warnings,\n }\n}\n\n/**\n * Batch validate multiple plugins\n */\nexport async function validatePlugins(pluginPaths: string[]): Promise<Map<string, ValidationResult>> {\n const results = new Map<string, ValidationResult>()\n\n await Promise.all(\n pluginPaths.map(async (pluginPath) => {\n const result = await validatePlugin(pluginPath)\n results.set(pluginPath, result)\n })\n )\n\n return results\n}\n\n/**\n * Format validation result as human-readable string\n */\nexport function formatValidationResult(result: ValidationResult, pluginName?: string): string {\n const lines: string[] = []\n\n if (pluginName) {\n lines.push(`Plugin: ${pluginName}`)\n }\n\n if (result.valid) {\n lines.push('\u2713 Validation passed')\n } else {\n lines.push(`\u2717 Validation failed with ${result.errors.length} error(s)`)\n }\n\n if (result.errors.length > 0) {\n lines.push('\\nErrors:')\n for (const error of result.errors) {\n const location = error.file ? ` (${error.file})` : ''\n lines.push(` \u2022 [${error.type}]${location} ${error.message}`)\n }\n }\n\n if (result.warnings.length > 0) {\n lines.push('\\nWarnings:')\n for (const warning of result.warnings) {\n const location = warning.file ? ` (${warning.file})` : ''\n lines.push(` \u2022 [${warning.type}]${location} ${warning.message}`)\n }\n }\n\n return lines.join('\\n')\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
package/dist/utils/theme.js
CHANGED
|
@@ -18,7 +18,15 @@ const lightTheme = {
|
|
|
18
18
|
removed: "#ffa8b4",
|
|
19
19
|
addedDimmed: "#c7e1cb",
|
|
20
20
|
removedDimmed: "#fdd2d8"
|
|
21
|
-
}
|
|
21
|
+
},
|
|
22
|
+
brand: "#D4BBFF",
|
|
23
|
+
dimmedText: "#888",
|
|
24
|
+
mutedText: "#999",
|
|
25
|
+
secondaryTextNew: "#666",
|
|
26
|
+
selectionBg: "#3C3C3C",
|
|
27
|
+
info: "#3399ff",
|
|
28
|
+
dim: "#aaa",
|
|
29
|
+
primaryText: "#000"
|
|
22
30
|
};
|
|
23
31
|
const lightDaltonizedTheme = {
|
|
24
32
|
bashBorder: "#FF6E57",
|
|
@@ -39,7 +47,15 @@ const lightDaltonizedTheme = {
|
|
|
39
47
|
removed: "#ffcccc",
|
|
40
48
|
addedDimmed: "#d1e7fd",
|
|
41
49
|
removedDimmed: "#ffe9e9"
|
|
42
|
-
}
|
|
50
|
+
},
|
|
51
|
+
brand: "#3366ff",
|
|
52
|
+
dimmedText: "#888",
|
|
53
|
+
mutedText: "#999",
|
|
54
|
+
secondaryTextNew: "#666",
|
|
55
|
+
selectionBg: "#3C3C3C",
|
|
56
|
+
info: "#3366ff",
|
|
57
|
+
dim: "#aaa",
|
|
58
|
+
primaryText: "#000"
|
|
43
59
|
};
|
|
44
60
|
const darkTheme = {
|
|
45
61
|
bashBorder: "#FF6E57",
|
|
@@ -60,7 +76,15 @@ const darkTheme = {
|
|
|
60
76
|
removed: "#7a2936",
|
|
61
77
|
addedDimmed: "#47584a",
|
|
62
78
|
removedDimmed: "#69484d"
|
|
63
|
-
}
|
|
79
|
+
},
|
|
80
|
+
brand: "#D4BBFF",
|
|
81
|
+
dimmedText: "#666",
|
|
82
|
+
mutedText: "#555",
|
|
83
|
+
secondaryTextNew: "#999",
|
|
84
|
+
selectionBg: "#3C3C3C",
|
|
85
|
+
info: "#5DADE2",
|
|
86
|
+
dim: "#444",
|
|
87
|
+
primaryText: "#fff"
|
|
64
88
|
};
|
|
65
89
|
const darkDaltonizedTheme = {
|
|
66
90
|
bashBorder: "#FF6E57",
|
|
@@ -81,7 +105,15 @@ const darkDaltonizedTheme = {
|
|
|
81
105
|
removed: "#660000",
|
|
82
106
|
addedDimmed: "#3e515b",
|
|
83
107
|
removedDimmed: "#3e2c2c"
|
|
84
|
-
}
|
|
108
|
+
},
|
|
109
|
+
brand: "#99ccff",
|
|
110
|
+
dimmedText: "#666",
|
|
111
|
+
mutedText: "#555",
|
|
112
|
+
secondaryTextNew: "#999",
|
|
113
|
+
selectionBg: "#3C3C3C",
|
|
114
|
+
info: "#99ccff",
|
|
115
|
+
dim: "#444",
|
|
116
|
+
primaryText: "#fff"
|
|
85
117
|
};
|
|
86
118
|
function getTheme(overrideTheme) {
|
|
87
119
|
const config = getGlobalConfig();
|
package/dist/utils/theme.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../src/utils/theme.ts"],
|
|
4
|
-
"sourcesContent": ["import { getGlobalConfig } from './config'\n\nexport interface Theme {\n bashBorder: string\n minto: string\n noting: string\n permission: string\n secondaryBorder: string\n text: string\n secondaryText: string\n suggestion: string\n success: string\n error: string\n warning: string\n primary: string\n secondary: string\n diff: {\n added: string\n removed: string\n addedDimmed: string\n removedDimmed: string\n }\n}\n\nconst lightTheme: Theme = {\n bashBorder: '#FF6E57',\n minto: '#FFC233',\n noting: '#222222',\n permission: '#e9c61aff',\n secondaryBorder: '#999',\n text: '#000',\n secondaryText: '#666',\n suggestion: '#32e98aff',\n success: '#2c7a39',\n error: '#ab2b3f',\n warning: '#966c1e',\n primary: '#000',\n secondary: '#666',\n diff: {\n added: '#69db7c',\n removed: '#ffa8b4',\n addedDimmed: '#c7e1cb',\n removedDimmed: '#fdd2d8',\n },\n}\n\nconst lightDaltonizedTheme: Theme = {\n bashBorder: '#FF6E57',\n minto: '#FFC233',\n noting: '#222222',\n permission: '#3366ff',\n secondaryBorder: '#999',\n text: '#000',\n secondaryText: '#666',\n suggestion: '#3366ff',\n success: '#006699',\n error: '#cc0000',\n warning: '#ff9900',\n primary: '#000',\n secondary: '#666',\n diff: {\n added: '#99ccff',\n removed: '#ffcccc',\n addedDimmed: '#d1e7fd',\n removedDimmed: '#ffe9e9',\n },\n}\n\nconst darkTheme: Theme = {\n bashBorder: '#FF6E57',\n minto: '#FFC233',\n noting: '#222222',\n permission: '#b1b9f9',\n secondaryBorder: '#888',\n text: '#fff',\n secondaryText: '#999',\n suggestion: '#b1b9f9',\n success: '#4eba65',\n error: '#ff6b80',\n warning: '#ffc107',\n primary: '#fff',\n secondary: '#999',\n diff: {\n added: '#225c2b',\n removed: '#7a2936',\n addedDimmed: '#47584a',\n removedDimmed: '#69484d',\n },\n}\n\nconst darkDaltonizedTheme: Theme = {\n bashBorder: '#FF6E57',\n minto: '#FFC233',\n noting: '#222222',\n permission: '#99ccff',\n secondaryBorder: '#888',\n text: '#fff',\n secondaryText: '#999',\n suggestion: '#99ccff',\n success: '#3399ff',\n error: '#ff6666',\n warning: '#ffcc00',\n primary: '#fff',\n secondary: '#999',\n diff: {\n added: '#004466',\n removed: '#660000',\n addedDimmed: '#3e515b',\n removedDimmed: '#3e2c2c',\n },\n}\n\nexport type ThemeNames = 'dark' | 'light' | 'light-daltonized' | 'dark-daltonized'\n\nexport function getTheme(overrideTheme?: ThemeNames): Theme {\n const config = getGlobalConfig()\n switch (overrideTheme ?? config.theme) {\n case 'light':\n return lightTheme\n case 'light-daltonized':\n return lightDaltonizedTheme\n case 'dark-daltonized':\n return darkDaltonizedTheme\n default:\n return darkTheme\n }\n}\n"],
|
|
5
|
-
"mappings": "AAAA,SAAS,uBAAuB;
|
|
4
|
+
"sourcesContent": ["import { getGlobalConfig } from './config'\n\nexport interface Theme {\n bashBorder: string\n minto: string\n noting: string\n permission: string\n secondaryBorder: string\n text: string\n secondaryText: string\n suggestion: string\n success: string\n error: string\n warning: string\n primary: string\n secondary: string\n diff: {\n added: string\n removed: string\n addedDimmed: string\n removedDimmed: string\n }\n // Additional color properties used in components\n brand: string\n dimmedText: string\n mutedText: string\n secondaryTextNew: string\n selectionBg: string\n info: string\n dim: string\n primaryText: string\n}\n\nconst lightTheme: Theme = {\n bashBorder: '#FF6E57',\n minto: '#FFC233',\n noting: '#222222',\n permission: '#e9c61aff',\n secondaryBorder: '#999',\n text: '#000',\n secondaryText: '#666',\n suggestion: '#32e98aff',\n success: '#2c7a39',\n error: '#ab2b3f',\n warning: '#966c1e',\n primary: '#000',\n secondary: '#666',\n diff: {\n added: '#69db7c',\n removed: '#ffa8b4',\n addedDimmed: '#c7e1cb',\n removedDimmed: '#fdd2d8',\n },\n brand: '#D4BBFF',\n dimmedText: '#888',\n mutedText: '#999',\n secondaryTextNew: '#666',\n selectionBg: '#3C3C3C',\n info: '#3399ff',\n dim: '#aaa',\n primaryText: '#000',\n}\n\nconst lightDaltonizedTheme: Theme = {\n bashBorder: '#FF6E57',\n minto: '#FFC233',\n noting: '#222222',\n permission: '#3366ff',\n secondaryBorder: '#999',\n text: '#000',\n secondaryText: '#666',\n suggestion: '#3366ff',\n success: '#006699',\n error: '#cc0000',\n warning: '#ff9900',\n primary: '#000',\n secondary: '#666',\n diff: {\n added: '#99ccff',\n removed: '#ffcccc',\n addedDimmed: '#d1e7fd',\n removedDimmed: '#ffe9e9',\n },\n brand: '#3366ff',\n dimmedText: '#888',\n mutedText: '#999',\n secondaryTextNew: '#666',\n selectionBg: '#3C3C3C',\n info: '#3366ff',\n dim: '#aaa',\n primaryText: '#000',\n}\n\nconst darkTheme: Theme = {\n bashBorder: '#FF6E57',\n minto: '#FFC233',\n noting: '#222222',\n permission: '#b1b9f9',\n secondaryBorder: '#888',\n text: '#fff',\n secondaryText: '#999',\n suggestion: '#b1b9f9',\n success: '#4eba65',\n error: '#ff6b80',\n warning: '#ffc107',\n primary: '#fff',\n secondary: '#999',\n diff: {\n added: '#225c2b',\n removed: '#7a2936',\n addedDimmed: '#47584a',\n removedDimmed: '#69484d',\n },\n brand: '#D4BBFF',\n dimmedText: '#666',\n mutedText: '#555',\n secondaryTextNew: '#999',\n selectionBg: '#3C3C3C',\n info: '#5DADE2',\n dim: '#444',\n primaryText: '#fff',\n}\n\nconst darkDaltonizedTheme: Theme = {\n bashBorder: '#FF6E57',\n minto: '#FFC233',\n noting: '#222222',\n permission: '#99ccff',\n secondaryBorder: '#888',\n text: '#fff',\n secondaryText: '#999',\n suggestion: '#99ccff',\n success: '#3399ff',\n error: '#ff6666',\n warning: '#ffcc00',\n primary: '#fff',\n secondary: '#999',\n diff: {\n added: '#004466',\n removed: '#660000',\n addedDimmed: '#3e515b',\n removedDimmed: '#3e2c2c',\n },\n brand: '#99ccff',\n dimmedText: '#666',\n mutedText: '#555',\n secondaryTextNew: '#999',\n selectionBg: '#3C3C3C',\n info: '#99ccff',\n dim: '#444',\n primaryText: '#fff',\n}\n\nexport type ThemeNames = 'dark' | 'light' | 'light-daltonized' | 'dark-daltonized'\n\nexport function getTheme(overrideTheme?: ThemeNames): Theme {\n const config = getGlobalConfig()\n switch (overrideTheme ?? config.theme) {\n case 'light':\n return lightTheme\n case 'light-daltonized':\n return lightDaltonizedTheme\n case 'dark-daltonized':\n return darkDaltonizedTheme\n default:\n return darkTheme\n }\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,uBAAuB;AAiChC,MAAM,aAAoB;AAAA,EACxB,YAAY;AAAA,EACZ,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,YAAY;AAAA,EACZ,iBAAiB;AAAA,EACjB,MAAM;AAAA,EACN,eAAe;AAAA,EACf,YAAY;AAAA,EACZ,SAAS;AAAA,EACT,OAAO;AAAA,EACP,SAAS;AAAA,EACT,SAAS;AAAA,EACT,WAAW;AAAA,EACX,MAAM;AAAA,IACJ,OAAO;AAAA,IACP,SAAS;AAAA,IACT,aAAa;AAAA,IACb,eAAe;AAAA,EACjB;AAAA,EACA,OAAO;AAAA,EACP,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,kBAAkB;AAAA,EAClB,aAAa;AAAA,EACb,MAAM;AAAA,EACN,KAAK;AAAA,EACL,aAAa;AACf;AAEA,MAAM,uBAA8B;AAAA,EAClC,YAAY;AAAA,EACZ,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,YAAY;AAAA,EACZ,iBAAiB;AAAA,EACjB,MAAM;AAAA,EACN,eAAe;AAAA,EACf,YAAY;AAAA,EACZ,SAAS;AAAA,EACT,OAAO;AAAA,EACP,SAAS;AAAA,EACT,SAAS;AAAA,EACT,WAAW;AAAA,EACX,MAAM;AAAA,IACJ,OAAO;AAAA,IACP,SAAS;AAAA,IACT,aAAa;AAAA,IACb,eAAe;AAAA,EACjB;AAAA,EACA,OAAO;AAAA,EACP,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,kBAAkB;AAAA,EAClB,aAAa;AAAA,EACb,MAAM;AAAA,EACN,KAAK;AAAA,EACL,aAAa;AACf;AAEA,MAAM,YAAmB;AAAA,EACvB,YAAY;AAAA,EACZ,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,YAAY;AAAA,EACZ,iBAAiB;AAAA,EACjB,MAAM;AAAA,EACN,eAAe;AAAA,EACf,YAAY;AAAA,EACZ,SAAS;AAAA,EACT,OAAO;AAAA,EACP,SAAS;AAAA,EACT,SAAS;AAAA,EACT,WAAW;AAAA,EACX,MAAM;AAAA,IACJ,OAAO;AAAA,IACP,SAAS;AAAA,IACT,aAAa;AAAA,IACb,eAAe;AAAA,EACjB;AAAA,EACA,OAAO;AAAA,EACP,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,kBAAkB;AAAA,EAClB,aAAa;AAAA,EACb,MAAM;AAAA,EACN,KAAK;AAAA,EACL,aAAa;AACf;AAEA,MAAM,sBAA6B;AAAA,EACjC,YAAY;AAAA,EACZ,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,YAAY;AAAA,EACZ,iBAAiB;AAAA,EACjB,MAAM;AAAA,EACN,eAAe;AAAA,EACf,YAAY;AAAA,EACZ,SAAS;AAAA,EACT,OAAO;AAAA,EACP,SAAS;AAAA,EACT,SAAS;AAAA,EACT,WAAW;AAAA,EACX,MAAM;AAAA,IACJ,OAAO;AAAA,IACP,SAAS;AAAA,IACT,aAAa;AAAA,IACb,eAAe;AAAA,EACjB;AAAA,EACA,OAAO;AAAA,EACP,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,kBAAkB;AAAA,EAClB,aAAa;AAAA,EACb,MAAM;AAAA,EACN,KAAK;AAAA,EACL,aAAa;AACf;AAIO,SAAS,SAAS,eAAmC;AAC1D,QAAM,SAAS,gBAAgB;AAC/B,UAAQ,iBAAiB,OAAO,OAAO;AAAA,IACrC,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AACH,aAAO;AAAA,IACT;AACE,aAAO;AAAA,EACX;AACF;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@within-7/minto",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.7",
|
|
4
4
|
"bin": {
|
|
5
5
|
"minto": "cli.js",
|
|
6
6
|
"mt": "cli.js"
|
|
@@ -35,7 +35,7 @@
|
|
|
35
35
|
"format:check": "prettier --check \"src/**/*.{ts,tsx,js,jsx,json}\"",
|
|
36
36
|
"lint": "eslint . --ext .ts,.tsx,.js --max-warnings 0",
|
|
37
37
|
"lint:fix": "eslint . --ext .ts,.tsx,.js --fix",
|
|
38
|
-
"test": "bun test",
|
|
38
|
+
"test": "cd tests && bun test",
|
|
39
39
|
"typecheck": "tsc --noEmit",
|
|
40
40
|
"prepare": "",
|
|
41
41
|
"publish:dev": "node scripts/publish-dev.js",
|