@secondlayer/cli 3.6.1 → 4.0.0

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.
@@ -2,19 +2,19 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/types/plugin.ts", "../src/utils/contract-id.ts", "../src/utils/format.ts", "../src/core/plugin-manager.ts", "../src/utils/clarity-conversion.ts", "../src/utils/type-mapping.ts", "../src/utils/generator-helpers.ts", "../src/generators/contract.ts", "../src/utils/abi-compat.ts", "../src/plugins/index.ts", "../src/plugins/clarinet/index.ts", "../src/plugins/actions/generators.ts", "../src/plugins/actions/index.ts", "../src/plugins/react/generators/contract.ts", "../src/utils/case-conversion.ts", "../src/plugins/react/generators/utils.ts", "../src/generators/templates/use-contract.ts", "../src/plugins/react/generators/generic.ts", "../src/plugins/react/provider/index.ts", "../src/plugins/react/index.ts", "../src/plugins/testing/generators.ts", "../src/plugins/testing/index.ts"],
4
4
  "sourcesContent": [
5
- "/**\n * Plugin system types for @secondlayer/cli\n */\n\nimport type { AbiContract } from \"@secondlayer/stacks/clarity\";\nimport type {\n\tNetworkName,\n\tResolvedContract,\n\tSecondLayerConfig,\n} from \"./config\";\n\n/**\n * Core plugin interface that all plugins must implement\n */\nexport interface SecondLayerPlugin {\n\t/** Plugin name (should be unique) */\n\tname: string;\n\n\t/** Plugin version */\n\tversion: string;\n\n\t// Lifecycle hooks\n\t/** Called after config is resolved but before generation starts */\n\tconfigResolved?: (config: ResolvedConfig) => void | Promise<void>;\n\n\t/** Called before generation starts */\n\tbeforeGenerate?: (context: GenerateContext) => void | Promise<void>;\n\n\t/** Called during generation phase - plugins can add their own outputs */\n\tgenerate?: (context: GenerateContext) => void | Promise<void>;\n\n\t/** Called after all generation is complete */\n\tafterGenerate?: (context: GenerateContext) => void | Promise<void>;\n\n\t// Transform hooks\n\t/** Transform user config before resolution */\n\ttransformConfig?: (config: UserConfig) => UserConfig | Promise<UserConfig>;\n\n\t/** Transform individual contracts during processing */\n\ttransformContract?: (\n\t\tcontract: ContractConfig,\n\t) => ContractConfig | Promise<ContractConfig>;\n\n\t/** Transform generated output before writing to disk */\n\ttransformOutput?: (\n\t\toutput: string,\n\t\ttype: OutputType,\n\t) => string | Promise<string>;\n}\n\n/**\n * User configuration (before plugin transformations)\n */\nexport type UserConfig = SecondLayerConfig;\n\n/**\n * Resolved configuration (after plugin transformations)\n */\nexport interface ResolvedConfig extends SecondLayerConfig {\n\t/** Resolved plugins array */\n\tplugins: SecondLayerPlugin[];\n}\n\n/**\n * Contract configuration that can be transformed by plugins\n */\nexport interface ContractConfig {\n\tname?: string;\n\taddress?: string | Partial<Record<NetworkName, string>>;\n\tsource?: string;\n\tabi?: AbiContract;\n\tmetadata?: Record<string, any>;\n}\n\n/**\n * Contract config from Clarinet plugin\n */\nexport interface ClarinetContractConfig extends ContractConfig {\n\t_clarinetSource: true;\n}\n\n/**\n * Contract config from direct file input\n */\nexport interface DirectFileContractConfig extends ContractConfig {\n\t_directFile: true;\n}\n\n/**\n * Union of all contract config types\n */\nexport type PluginContractConfig =\n\t| ContractConfig\n\t| ClarinetContractConfig\n\t| DirectFileContractConfig;\n\n/**\n * Type guard for Clarinet contracts\n */\nexport function isClarinetContract(\n\tc: ContractConfig,\n): c is ClarinetContractConfig {\n\treturn \"_clarinetSource\" in c && c._clarinetSource === true;\n}\n\n/**\n * Type guard for direct file contracts\n */\nexport function isDirectFileContract(\n\tc: ContractConfig,\n): c is DirectFileContractConfig {\n\treturn \"_directFile\" in c && c._directFile === true;\n}\n\n/**\n * Processed contract with resolved ABI and metadata\n */\nexport interface ProcessedContract extends ResolvedContract {\n\t/** Additional metadata added by plugins */\n\tmetadata?: Record<string, any>;\n}\n\n/**\n * Generated output from plugins\n */\nexport interface GeneratedOutput {\n\t/** File path where output should be written */\n\tpath: string;\n\n\t/** Generated content */\n\tcontent: string;\n\n\t/** Output type for transformation hooks */\n\ttype?: OutputType;\n\n\t/** Whether this output should overwrite existing files */\n\toverwrite?: boolean;\n}\n\n/**\n * Types of outputs that can be generated\n */\nexport type OutputType =\n\t| \"contracts\"\n\t| \"hooks\"\n\t| \"actions\"\n\t| \"types\"\n\t| \"utils\"\n\t| \"config\"\n\t| \"other\";\n\n/**\n * Base context available to all plugin hooks\n */\nexport interface PluginContext {\n\t/** Resolved configuration */\n\tconfig: ResolvedConfig;\n\n\t/** Logger for plugin output */\n\tlogger: Logger;\n\n\t/** Utility functions for plugins */\n\tutils: PluginUtils;\n}\n\n/**\n * Context available during generation phase\n */\nexport interface GenerateContext extends PluginContext {\n\t/** Processed contracts ready for generation */\n\tcontracts: ProcessedContract[];\n\n\t/** Map of output keys to generated content */\n\toutputs: Map<string, GeneratedOutput>;\n\n\t/** Function to augment existing outputs */\n\taugment: (outputKey: string, contractName: string, content: any) => void;\n\n\t/** Function to add new outputs */\n\taddOutput: (key: string, output: GeneratedOutput) => void;\n}\n\n/**\n * Logger interface for plugin output\n */\nexport interface Logger {\n\tinfo: (message: string) => void;\n\twarn: (message: string) => void;\n\terror: (message: string) => void;\n\tdebug: (message: string) => void;\n\tsuccess: (message: string) => void;\n}\n\n/**\n * Utility functions available to plugins\n */\nexport interface PluginUtils {\n\t/** Convert kebab-case to camelCase */\n\ttoCamelCase: (str: string) => string;\n\n\t/** Convert camelCase to kebab-case */\n\ttoKebabCase: (str: string) => string;\n\n\t/** Validate Stacks address format */\n\tvalidateAddress: (address: string) => boolean;\n\n\t/** Parse contract identifier (address.contract-name) */\n\tparseContractId: (contractId: string) => {\n\t\taddress: string;\n\t\tcontractName: string;\n\t};\n\n\t/** Format TypeScript code using prettier */\n\tformatCode: (code: string) => Promise<string>;\n\n\t/** Resolve file path relative to project root */\n\tresolvePath: (relativePath: string) => string;\n\n\t/** Check if file exists */\n\tfileExists: (path: string) => Promise<boolean>;\n\n\t/** Read file content */\n\treadFile: (path: string) => Promise<string>;\n\n\t/** Write file content */\n\twriteFile: (path: string, content: string) => Promise<void>;\n\n\t/** Create directory recursively */\n\tensureDir: (path: string) => Promise<void>;\n}\n\n/**\n * Plugin factory function type for creating plugins with options\n */\nexport type PluginFactory<TOptions = any> = (\n\toptions?: TOptions,\n) => SecondLayerPlugin;\n\n/**\n * Plugin options base interface\n */\nexport interface PluginOptions {\n\t/** Include only specific contracts/functions */\n\tinclude?: string[];\n\n\t/** Exclude specific contracts/functions */\n\texclude?: string[];\n\n\t/** Enable debug output */\n\tdebug?: boolean;\n}\n\n/**\n * Hook execution result\n */\nexport interface HookResult<T = any> {\n\t/** Whether the hook was successful */\n\tsuccess: boolean;\n\n\t/** Result data from the hook */\n\tdata?: T;\n\n\t/** Error if hook failed */\n\terror?: Error;\n\n\t/** Plugin that executed the hook */\n\tplugin: string;\n}\n\n/**\n * Plugin execution context for internal use\n */\nexport interface PluginExecutionContext {\n\t/** Current plugin being executed */\n\tcurrentPlugin?: SecondLayerPlugin;\n\n\t/** Execution phase */\n\tphase: \"config\" | \"generate\" | \"output\";\n\n\t/** Start time for performance tracking */\n\tstartTime: number;\n\n\t/** Plugin execution results */\n\tresults: Map<string, HookResult[]>;\n}\n",
5
+ "/**\n * Plugin system types for @secondlayer/cli\n */\n\nimport type { AbiContract } from \"@secondlayer/stacks/clarity\";\nimport type {\n\tNetworkName,\n\tResolvedContract,\n\tSecondLayerConfig,\n} from \"./config\";\n\n/**\n * Core plugin interface that all plugins must implement\n */\nexport interface SecondLayerPlugin {\n\t/** Plugin name (should be unique) */\n\tname: string;\n\n\t/** Plugin version */\n\tversion: string;\n\n\t// Lifecycle hooks\n\t/** Called after config is resolved but before generation starts */\n\tconfigResolved?: (config: ResolvedConfig) => void | Promise<void>;\n\n\t/** Called before generation starts */\n\tbeforeGenerate?: (context: GenerateContext) => void | Promise<void>;\n\n\t/** Called during generation phase - plugins can add their own outputs */\n\tgenerate?: (context: GenerateContext) => void | Promise<void>;\n\n\t/** Called after all generation is complete */\n\tafterGenerate?: (context: GenerateContext) => void | Promise<void>;\n\n\t// Transform hooks\n\t/** Transform user config before resolution */\n\ttransformConfig?: (config: UserConfig) => UserConfig | Promise<UserConfig>;\n\n\t/** Transform individual contracts during processing */\n\ttransformContract?: (\n\t\tcontract: ContractConfig,\n\t) => ContractConfig | Promise<ContractConfig>;\n\n\t/** Transform generated output before writing to disk */\n\ttransformOutput?: (\n\t\toutput: string,\n\t\ttype: OutputType,\n\t) => string | Promise<string>;\n}\n\n/**\n * User configuration (before plugin transformations)\n */\nexport type UserConfig = SecondLayerConfig;\n\n/**\n * Resolved configuration (after plugin transformations)\n */\nexport interface ResolvedConfig extends SecondLayerConfig {\n\t/** Resolved plugins array */\n\tplugins: SecondLayerPlugin[];\n}\n\n/**\n * Contract configuration that can be transformed by plugins\n */\nexport interface ContractConfig {\n\tname?: string;\n\taddress?: string | Partial<Record<NetworkName, string>>;\n\tsource?: string;\n\tabi?: AbiContract;\n\t// biome-ignore lint/suspicious/noExplicitAny: interop boundary or dynamic-shape value where typing adds friction without runtime safety\n\tmetadata?: Record<string, any>;\n}\n\n/**\n * Contract config from Clarinet plugin\n */\nexport interface ClarinetContractConfig extends ContractConfig {\n\t_clarinetSource: true;\n}\n\n/**\n * Contract config from direct file input\n */\nexport interface DirectFileContractConfig extends ContractConfig {\n\t_directFile: true;\n}\n\n/**\n * Union of all contract config types\n */\nexport type PluginContractConfig =\n\t| ContractConfig\n\t| ClarinetContractConfig\n\t| DirectFileContractConfig;\n\n/**\n * Type guard for Clarinet contracts\n */\nexport function isClarinetContract(\n\tc: ContractConfig,\n): c is ClarinetContractConfig {\n\treturn \"_clarinetSource\" in c && c._clarinetSource === true;\n}\n\n/**\n * Type guard for direct file contracts\n */\nexport function isDirectFileContract(\n\tc: ContractConfig,\n): c is DirectFileContractConfig {\n\treturn \"_directFile\" in c && c._directFile === true;\n}\n\n/**\n * Processed contract with resolved ABI and metadata\n */\nexport interface ProcessedContract extends ResolvedContract {\n\t/** Additional metadata added by plugins */\n\t// biome-ignore lint/suspicious/noExplicitAny: interop boundary or dynamic-shape value where typing adds friction without runtime safety\n\tmetadata?: Record<string, any>;\n}\n\n/**\n * Generated output from plugins\n */\nexport interface GeneratedOutput {\n\t/** File path where output should be written */\n\tpath: string;\n\n\t/** Generated content */\n\tcontent: string;\n\n\t/** Output type for transformation hooks */\n\ttype?: OutputType;\n\n\t/** Whether this output should overwrite existing files */\n\toverwrite?: boolean;\n}\n\n/**\n * Types of outputs that can be generated\n */\nexport type OutputType =\n\t| \"contracts\"\n\t| \"hooks\"\n\t| \"actions\"\n\t| \"types\"\n\t| \"utils\"\n\t| \"config\"\n\t| \"other\";\n\n/**\n * Base context available to all plugin hooks\n */\nexport interface PluginContext {\n\t/** Resolved configuration */\n\tconfig: ResolvedConfig;\n\n\t/** Logger for plugin output */\n\tlogger: Logger;\n\n\t/** Utility functions for plugins */\n\tutils: PluginUtils;\n}\n\n/**\n * Context available during generation phase\n */\nexport interface GenerateContext extends PluginContext {\n\t/** Processed contracts ready for generation */\n\tcontracts: ProcessedContract[];\n\n\t/** Map of output keys to generated content */\n\toutputs: Map<string, GeneratedOutput>;\n\n\t/** Function to augment existing outputs */\n\t// biome-ignore lint/suspicious/noExplicitAny: interop boundary or dynamic-shape value where typing adds friction without runtime safety\n\taugment: (outputKey: string, contractName: string, content: any) => void;\n\n\t/** Function to add new outputs */\n\taddOutput: (key: string, output: GeneratedOutput) => void;\n}\n\n/**\n * Logger interface for plugin output\n */\nexport interface Logger {\n\tinfo: (message: string) => void;\n\twarn: (message: string) => void;\n\terror: (message: string) => void;\n\tdebug: (message: string) => void;\n\tsuccess: (message: string) => void;\n}\n\n/**\n * Utility functions available to plugins\n */\nexport interface PluginUtils {\n\t/** Convert kebab-case to camelCase */\n\ttoCamelCase: (str: string) => string;\n\n\t/** Convert camelCase to kebab-case */\n\ttoKebabCase: (str: string) => string;\n\n\t/** Validate Stacks address format */\n\tvalidateAddress: (address: string) => boolean;\n\n\t/** Parse contract identifier (address.contract-name) */\n\tparseContractId: (contractId: string) => {\n\t\taddress: string;\n\t\tcontractName: string;\n\t};\n\n\t/** Format TypeScript code using prettier */\n\tformatCode: (code: string) => Promise<string>;\n\n\t/** Resolve file path relative to project root */\n\tresolvePath: (relativePath: string) => string;\n\n\t/** Check if file exists */\n\tfileExists: (path: string) => Promise<boolean>;\n\n\t/** Read file content */\n\treadFile: (path: string) => Promise<string>;\n\n\t/** Write file content */\n\twriteFile: (path: string, content: string) => Promise<void>;\n\n\t/** Create directory recursively */\n\tensureDir: (path: string) => Promise<void>;\n}\n\n/**\n * Plugin factory function type for creating plugins with options\n */\n// biome-ignore lint/suspicious/noExplicitAny: interop boundary or dynamic-shape value where typing adds friction without runtime safety\nexport type PluginFactory<TOptions = any> = (\n\toptions?: TOptions,\n) => SecondLayerPlugin;\n\n/**\n * Plugin options base interface\n */\nexport interface PluginOptions {\n\t/** Include only specific contracts/functions */\n\tinclude?: string[];\n\n\t/** Exclude specific contracts/functions */\n\texclude?: string[];\n\n\t/** Enable debug output */\n\tdebug?: boolean;\n}\n\n/**\n * Hook execution result\n */\n// biome-ignore lint/suspicious/noExplicitAny: interop boundary or dynamic-shape value where typing adds friction without runtime safety\nexport interface HookResult<T = any> {\n\t/** Whether the hook was successful */\n\tsuccess: boolean;\n\n\t/** Result data from the hook */\n\tdata?: T;\n\n\t/** Error if hook failed */\n\terror?: Error;\n\n\t/** Plugin that executed the hook */\n\tplugin: string;\n}\n\n/**\n * Plugin execution context for internal use\n */\nexport interface PluginExecutionContext {\n\t/** Current plugin being executed */\n\tcurrentPlugin?: SecondLayerPlugin;\n\n\t/** Execution phase */\n\tphase: \"config\" | \"generate\" | \"output\";\n\n\t/** Start time for performance tracking */\n\tstartTime: number;\n\n\t/** Plugin execution results */\n\tresults: Map<string, HookResult[]>;\n}\n",
6
6
  "/**\n * Parse a fully-qualified contract ID (\"address.contractName\") into its parts.\n * Throws if the input doesn't contain a dot separator.\n */\nexport function parseContractId(contractId: string): {\n\taddress: string;\n\tcontractName: string;\n} {\n\tconst dotIndex = contractId.indexOf(\".\");\n\tif (dotIndex === -1) {\n\t\tthrow new Error(\n\t\t\t`Invalid contract ID: \"${contractId}\" (expected \"address.contractName\")`,\n\t\t);\n\t}\n\treturn {\n\t\taddress: contractId.slice(0, dotIndex),\n\t\tcontractName: contractId.slice(dotIndex + 1),\n\t};\n}\n",
7
7
  "/**\n * Shared code formatting utilities using Biome\n */\n\nimport { Biome, Distribution } from \"@biomejs/js-api\";\n\nlet biome: Biome | null = null;\n\n/**\n * Lazily initialize Biome singleton\n */\nasync function getBiome(): Promise<Biome> {\n\tif (!biome) {\n\t\tbiome = await Biome.create({\n\t\t\tdistribution: Distribution.NODE,\n\t\t});\n\n\t\tbiome.applyConfiguration({\n\t\t\tformatter: {\n\t\t\t\tenabled: true,\n\t\t\t\tindentStyle: \"tab\",\n\t\t\t\tlineWidth: 80,\n\t\t\t},\n\t\t\tjavascript: {\n\t\t\t\tformatter: {\n\t\t\t\t\tsemicolons: \"always\",\n\t\t\t\t\tquoteStyle: \"single\",\n\t\t\t\t},\n\t\t\t},\n\t\t\torganizeImports: {\n\t\t\t\tenabled: true,\n\t\t\t},\n\t\t\tlinter: {\n\t\t\t\tenabled: true,\n\t\t\t},\n\t\t\tassists: {\n\t\t\t\tenabled: true,\n\t\t\t},\n\t\t});\n\n\t\tbiome.registerProjectFolder();\n\t}\n\n\treturn biome;\n}\n\n/**\n * Format TypeScript code using Biome\n */\nexport async function formatCode(code: string): Promise<string> {\n\tconst b = await getBiome();\n\n\t// Use lintContent with SafeFixes to organize imports\n\tconst linted = b.lintContent(code, {\n\t\tfilePath: \"generated.ts\",\n\t\tfixFileMode: \"SafeFixes\",\n\t});\n\n\t// Then format\n\tconst formatted = b.formatContent(linted.content, {\n\t\tfilePath: \"generated.ts\",\n\t});\n\n\treturn formatted.content;\n}\n",
8
- "/**\n * Plugin Manager for @secondlayer/cli\n * Handles plugin registration, lifecycle execution, and output management\n */\n\nimport { promises as fs } from \"fs\";\nimport path from \"path\";\nimport { isValidAddress as _validateStacksAddress } from \"@secondlayer/stacks\";\nconst validateStacksAddress = _validateStacksAddress as (\n\taddress: string,\n) => boolean;\nimport { getErrorMessage } from \"@secondlayer/shared\";\nimport { toCamelCase } from \"@secondlayer/stacks/clarity\";\nimport type {\n\tContractConfig,\n\tGenerateContext,\n\tGeneratedOutput,\n\tHookResult,\n\tLogger,\n\tPluginExecutionContext,\n\tPluginUtils,\n\tProcessedContract,\n\tResolvedConfig,\n\tSecondLayerPlugin,\n\tUserConfig,\n} from \"../types/plugin\";\nimport { isClarinetContract, isDirectFileContract } from \"../types/plugin\";\nimport { parseContractId } from \"../utils/contract-id\";\n\n/**\n * Core plugin manager that orchestrates plugin execution\n */\nexport class PluginManager {\n\tprivate plugins: SecondLayerPlugin[] = [];\n\tprivate logger: Logger;\n\tprivate utils: PluginUtils;\n\tprivate executionContext: PluginExecutionContext;\n\n\tconstructor() {\n\t\tthis.logger = this.createLogger();\n\t\tthis.utils = this.createUtils();\n\t\tthis.executionContext = {\n\t\t\tphase: \"config\",\n\t\t\tstartTime: Date.now(),\n\t\t\tresults: new Map(),\n\t\t};\n\t}\n\n\t/**\n\t * Register a plugin\n\t */\n\tregister(plugin: SecondLayerPlugin): void {\n\t\t// Validate plugin\n\t\tif (!plugin.name || !plugin.version) {\n\t\t\tthrow new Error(\"Plugin must have a name and version\");\n\t\t}\n\n\t\t// Check for duplicate plugin names\n\t\tconst existing = this.plugins.find((p) => p.name === plugin.name);\n\t\tif (existing) {\n\t\t\tthrow new Error(\n\t\t\t\t`Plugin \"${plugin.name}\" is already registered (version ${existing.version})`,\n\t\t\t);\n\t\t}\n\n\t\tthis.plugins.push(plugin);\n\t\tthis.logger.debug(`Registered plugin: ${plugin.name}@${plugin.version}`);\n\t}\n\n\t/**\n\t * Get all registered plugins\n\t */\n\tgetPlugins(): SecondLayerPlugin[] {\n\t\treturn [...this.plugins];\n\t}\n\n\t/**\n\t * Transform user config through all plugins\n\t */\n\tasync transformConfig(config: UserConfig): Promise<ResolvedConfig> {\n\t\tthis.executionContext.phase = \"config\";\n\t\tlet transformedConfig = { ...config };\n\n\t\tfor (const plugin of this.plugins) {\n\t\t\tif (plugin.transformConfig) {\n\t\t\t\tthis.executionContext.currentPlugin = plugin;\n\t\t\t\ttry {\n\t\t\t\t\tconst result = await plugin.transformConfig(transformedConfig);\n\t\t\t\t\ttransformedConfig = result;\n\t\t\t\t\tthis.recordHookResult(plugin.name, \"transformConfig\", {\n\t\t\t\t\t\tsuccess: true,\n\t\t\t\t\t});\n\t\t\t\t} catch (error) {\n\t\t\t\t\tthis.recordHookResult(plugin.name, \"transformConfig\", {\n\t\t\t\t\t\tsuccess: false,\n\t\t\t\t\t\terror:\n\t\t\t\t\t\t\terror instanceof Error\n\t\t\t\t\t\t\t\t? error\n\t\t\t\t\t\t\t\t: new Error(getErrorMessage(error)),\n\t\t\t\t\t});\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t`Plugin \"${plugin.name}\" failed during config transformation: ${getErrorMessage(error)}`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Add plugins array to resolved config\n\t\tconst resolvedConfig: ResolvedConfig = {\n\t\t\t...transformedConfig,\n\t\t\tplugins: this.plugins,\n\t\t};\n\n\t\treturn resolvedConfig;\n\t}\n\n\t/**\n\t * Transform contracts through all plugins\n\t */\n\tasync transformContracts(\n\t\tcontracts: ContractConfig[],\n\t\t_config: ResolvedConfig,\n\t): Promise<ProcessedContract[]> {\n\t\tconst processedContracts: ProcessedContract[] = [];\n\n\t\tfor (let contract of contracts) {\n\t\t\tif (isClarinetContract(contract) && contract.abi) {\n\t\t\t\tprocessedContracts.push(this.contractToProcessed(contract, \"clarinet\"));\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (isDirectFileContract(contract) && contract.abi) {\n\t\t\t\tprocessedContracts.push(this.contractToProcessed(contract, \"direct\"));\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// Transform through each plugin\n\t\t\tfor (const plugin of this.plugins) {\n\t\t\t\tif (plugin.transformContract) {\n\t\t\t\t\tthis.executionContext.currentPlugin = plugin;\n\t\t\t\t\ttry {\n\t\t\t\t\t\tcontract = await plugin.transformContract(contract);\n\t\t\t\t\t\tthis.recordHookResult(plugin.name, \"transformContract\", {\n\t\t\t\t\t\t\tsuccess: true,\n\t\t\t\t\t\t});\n\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\tthis.recordHookResult(plugin.name, \"transformContract\", {\n\t\t\t\t\t\t\tsuccess: false,\n\t\t\t\t\t\t\terror:\n\t\t\t\t\t\t\t\terror instanceof Error\n\t\t\t\t\t\t\t\t\t? error\n\t\t\t\t\t\t\t\t\t: new Error(getErrorMessage(error)),\n\t\t\t\t\t\t});\n\t\t\t\t\t\tthis.logger.warn(\n\t\t\t\t\t\t\t`Plugin \"${plugin.name}\" failed to transform contract: ${getErrorMessage(error)}`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (contract.abi) {\n\t\t\t\tprocessedContracts.push(this.contractToProcessed(contract, \"api\"));\n\t\t\t}\n\t\t}\n\n\t\treturn processedContracts;\n\t}\n\n\t/**\n\t * Execute lifecycle hooks\n\t */\n\tasync executeHook(\n\t\thookName: keyof SecondLayerPlugin,\n\t\tcontext: any,\n\t): Promise<void> {\n\t\tfor (const plugin of this.plugins) {\n\t\t\tconst hook = plugin[hookName];\n\t\t\tif (typeof hook === \"function\") {\n\t\t\t\tthis.executionContext.currentPlugin = plugin;\n\t\t\t\ttry {\n\t\t\t\t\tawait (hook as any).call(plugin, context);\n\t\t\t\t\tthis.recordHookResult(plugin.name, hookName as string, {\n\t\t\t\t\t\tsuccess: true,\n\t\t\t\t\t});\n\t\t\t\t} catch (error) {\n\t\t\t\t\tthis.recordHookResult(plugin.name, hookName as string, {\n\t\t\t\t\t\tsuccess: false,\n\t\t\t\t\t\terror:\n\t\t\t\t\t\t\terror instanceof Error\n\t\t\t\t\t\t\t\t? error\n\t\t\t\t\t\t\t\t: new Error(getErrorMessage(error)),\n\t\t\t\t\t});\n\t\t\t\t\tthis.logger.error(\n\t\t\t\t\t\t`Plugin \"${plugin.name}\" failed during ${hookName as string}: ${getErrorMessage(error)}`,\n\t\t\t\t\t);\n\t\t\t\t\t// Don't throw - allow other plugins to continue\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Execute generation phase with full context\n\t */\n\tasync executeGeneration(\n\t\tcontracts: ProcessedContract[],\n\t\tconfig: ResolvedConfig,\n\t): Promise<Map<string, GeneratedOutput>> {\n\t\tthis.executionContext.phase = \"generate\";\n\t\tconst outputs = new Map<string, GeneratedOutput>();\n\n\t\t// Create generation context\n\t\tconst context: GenerateContext = {\n\t\t\tconfig,\n\t\t\tlogger: this.logger,\n\t\t\tutils: this.utils,\n\t\t\tcontracts,\n\t\t\toutputs,\n\t\t\taugment: (outputKey: string, contractName: string, content: any) => {\n\t\t\t\tthis.augmentOutput(outputs, outputKey, contractName, content);\n\t\t\t},\n\t\t\taddOutput: (key: string, output: GeneratedOutput) => {\n\t\t\t\toutputs.set(key, output);\n\t\t\t},\n\t\t};\n\n\t\t// Execute beforeGenerate hooks\n\t\tawait this.executeHook(\"beforeGenerate\", context);\n\n\t\t// Execute generate hooks\n\t\tawait this.executeHook(\"generate\", context);\n\n\t\t// Execute afterGenerate hooks\n\t\tawait this.executeHook(\"afterGenerate\", context);\n\n\t\treturn outputs;\n\t}\n\n\t/**\n\t * Transform outputs through plugins\n\t */\n\tasync transformOutputs(\n\t\toutputs: Map<string, GeneratedOutput>,\n\t): Promise<Map<string, GeneratedOutput>> {\n\t\tthis.executionContext.phase = \"output\";\n\t\tconst transformedOutputs = new Map<string, GeneratedOutput>();\n\n\t\tfor (const [key, output] of outputs) {\n\t\t\tlet transformedContent = output.content;\n\n\t\t\tfor (const plugin of this.plugins) {\n\t\t\t\tif (plugin.transformOutput) {\n\t\t\t\t\tthis.executionContext.currentPlugin = plugin;\n\t\t\t\t\ttry {\n\t\t\t\t\t\ttransformedContent = await plugin.transformOutput(\n\t\t\t\t\t\t\ttransformedContent,\n\t\t\t\t\t\t\toutput.type || \"other\",\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.recordHookResult(plugin.name, \"transformOutput\", {\n\t\t\t\t\t\t\tsuccess: true,\n\t\t\t\t\t\t});\n\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\tthis.recordHookResult(plugin.name, \"transformOutput\", {\n\t\t\t\t\t\t\tsuccess: false,\n\t\t\t\t\t\t\terror:\n\t\t\t\t\t\t\t\terror instanceof Error\n\t\t\t\t\t\t\t\t\t? error\n\t\t\t\t\t\t\t\t\t: new Error(getErrorMessage(error)),\n\t\t\t\t\t\t});\n\t\t\t\t\t\tthis.logger.warn(\n\t\t\t\t\t\t\t`Plugin \"${plugin.name}\" failed to transform output: ${getErrorMessage(error)}`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\ttransformedOutputs.set(key, {\n\t\t\t\t...output,\n\t\t\t\tcontent: transformedContent,\n\t\t\t});\n\t\t}\n\n\t\treturn transformedOutputs;\n\t}\n\n\t/**\n\t * Write outputs to disk\n\t */\n\tasync writeOutputs(outputs: Map<string, GeneratedOutput>): Promise<void> {\n\t\tfor (const [, output] of outputs) {\n\t\t\ttry {\n\t\t\t\tconst resolvedPath = path.resolve(process.cwd(), output.path);\n\t\t\t\tawait this.utils.ensureDir(path.dirname(resolvedPath));\n\t\t\t\tawait this.utils.writeFile(resolvedPath, output.content);\n\t\t\t\t// Don't log here - let the main command handle success messaging\n\t\t\t} catch (error) {\n\t\t\t\tthis.logger.error(\n\t\t\t\t\t`Failed to write ${output.path}: ${getErrorMessage(error)}`,\n\t\t\t\t);\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Get execution results for debugging\n\t */\n\tgetExecutionResults(): Map<string, HookResult[]> {\n\t\treturn new Map(this.executionContext.results);\n\t}\n\n\t/**\n\t * Convert a contract config with an ABI into a ProcessedContract\n\t */\n\tprivate contractToProcessed(\n\t\tcontract: ContractConfig,\n\t\tsource: string,\n\t): ProcessedContract {\n\t\tconst address =\n\t\t\ttypeof contract.address === \"string\" ? contract.address : \"\";\n\t\tconst parsed = parseContractId(address);\n\t\treturn {\n\t\t\tname: contract.name || parsed.contractName || \"unknown\",\n\t\t\taddress: parsed.address || \"unknown\",\n\t\t\tcontractName: parsed.contractName || contract.name || \"unknown\",\n\t\t\tabi: contract.abi!,\n\t\t\tsource: source === \"api\" ? (\"api\" as const) : (\"local\" as const),\n\t\t\tmetadata: contract.metadata ?? { source },\n\t\t};\n\t}\n\n\t/**\n\t * Augment existing output with additional content\n\t */\n\tprivate augmentOutput(\n\t\toutputs: Map<string, GeneratedOutput>,\n\t\toutputKey: string,\n\t\tcontractName: string,\n\t\tcontent: any,\n\t): void {\n\t\tconst existing = outputs.get(outputKey);\n\t\tif (!existing) {\n\t\t\tthis.logger.warn(`Cannot augment non-existent output: ${outputKey}`);\n\t\t\treturn;\n\t\t}\n\n\t\t// Simple augmentation - append content\n\t\t// In a real implementation, this would be more sophisticated\n\t\tconst augmentedContent = `${existing.content}\\n\\n// Augmented by plugin for ${contractName}\\n${JSON.stringify(content, null, 2)}`;\n\n\t\toutputs.set(outputKey, {\n\t\t\t...existing,\n\t\t\tcontent: augmentedContent,\n\t\t});\n\t}\n\n\t/**\n\t * Record hook execution result\n\t */\n\tprivate recordHookResult(\n\t\tpluginName: string,\n\t\thookName: string,\n\t\tresult: Omit<HookResult, \"plugin\">,\n\t): void {\n\t\tconst key = `${pluginName}:${hookName}`;\n\t\tconst existing = this.executionContext.results.get(key) || [];\n\t\texisting.push({ ...result, plugin: pluginName });\n\t\tthis.executionContext.results.set(key, existing);\n\t}\n\n\t/**\n\t * Create logger instance\n\t */\n\tprivate createLogger(): Logger {\n\t\treturn {\n\t\t\tinfo: (message: string) => console.log(`ℹ️ ${message}`),\n\t\t\twarn: (message: string) => console.warn(`⚠️ ${message}`),\n\t\t\terror: (message: string) => console.error(`❌ ${message}`),\n\t\t\tdebug: (message: string) => {\n\t\t\t\tif (process.env.DEBUG) {\n\t\t\t\t\tconsole.log(`🐛 ${message}`);\n\t\t\t\t}\n\t\t\t},\n\t\t\tsuccess: (message: string) => console.log(`✅ ${message}`),\n\t\t};\n\t}\n\n\t/**\n\t * Create utils instance\n\t */\n\tprivate createUtils(): PluginUtils {\n\t\treturn {\n\t\t\ttoCamelCase,\n\n\t\t\ttoKebabCase: (str: string) => {\n\t\t\t\treturn str.replace(/[A-Z]/g, (letter) => `-${letter.toLowerCase()}`);\n\t\t\t},\n\n\t\t\tvalidateAddress: (address: string) => {\n\t\t\t\treturn validateStacksAddress(parseContractId(address).address);\n\t\t\t},\n\n\t\t\tparseContractId: (contractId: string) => {\n\t\t\t\treturn parseContractId(contractId);\n\t\t\t},\n\n\t\t\tformatCode: async (code: string) => {\n\t\t\t\tconst { formatCode } = await import(\"../utils/format\");\n\t\t\t\treturn formatCode(code);\n\t\t\t},\n\n\t\t\tresolvePath: (relativePath: string) => {\n\t\t\t\treturn path.resolve(process.cwd(), relativePath);\n\t\t\t},\n\n\t\t\tfileExists: async (filePath: string) => {\n\t\t\t\ttry {\n\t\t\t\t\tawait fs.access(filePath);\n\t\t\t\t\treturn true;\n\t\t\t\t} catch {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t},\n\n\t\t\treadFile: async (filePath: string) => {\n\t\t\t\treturn fs.readFile(filePath, \"utf-8\");\n\t\t\t},\n\n\t\t\twriteFile: async (filePath: string, content: string) => {\n\t\t\t\tawait fs.writeFile(filePath, content, \"utf-8\");\n\t\t\t},\n\n\t\t\tensureDir: async (dirPath: string) => {\n\t\t\t\tawait fs.mkdir(dirPath, { recursive: true });\n\t\t\t},\n\t\t};\n\t}\n}\n",
9
- "/**\n * Shared code-generation utility for converting TypeScript values to ClarityValue expressions.\n * Used by contract, actions, and testing generators.\n */\n\nimport {\n\ttype AbiType,\n\tisAbiBuffer,\n\tisAbiList,\n\tisAbiOptional,\n\tisAbiResponse,\n\tisAbiStringAscii,\n\tisAbiStringUtf8,\n\tisAbiTuple,\n\ttoCamelCase,\n} from \"@secondlayer/stacks/clarity\";\n\n/**\n * Generate a code string that converts a TypeScript value to a ClarityValue\n * based on the Clarity ABI argument type.\n */\nexport function generateClarityConversion(\n\targName: string,\n\targType: { type: AbiType },\n): string {\n\tconst type = argType.type;\n\n\tif (typeof type === \"string\") {\n\t\tswitch (type) {\n\t\t\tcase \"uint128\":\n\t\t\t\treturn `Cl.uint(${argName})`;\n\t\t\tcase \"int128\":\n\t\t\t\treturn `Cl.int(${argName})`;\n\t\t\tcase \"bool\":\n\t\t\t\treturn `Cl.bool(${argName})`;\n\t\t\tcase \"principal\":\n\t\t\tcase \"trait_reference\":\n\t\t\t\treturn `(() => {\n const [address, contractName] = ${argName}.split(\".\") as [string, string | undefined];\n if (!validateStacksAddress(address)) {\n throw new Error(\"Invalid Stacks address format\");\n }\n if (contractName !== undefined) {\n if (!CONTRACT_NAME_REGEX.test(contractName)) {\n throw new Error(\"Invalid contract name format: must start with letter and contain only letters, numbers, and hyphens\");\n }\n return Cl.contractPrincipal(address, contractName);\n }\n return Cl.standardPrincipal(${argName});\n })()`;\n\t\t\tdefault:\n\t\t\t\treturn `${argName}`;\n\t\t}\n\t}\n\n\tif (isAbiStringAscii(type)) {\n\t\treturn `Cl.stringAscii(${argName})`;\n\t}\n\n\tif (isAbiStringUtf8(type)) {\n\t\treturn `Cl.stringUtf8(${argName})`;\n\t}\n\n\tif (isAbiBuffer(type)) {\n\t\treturn `(() => {\n const value = ${argName};\n if (value instanceof Uint8Array) {\n return Cl.buffer(value);\n }\n if (typeof value === 'object' && value !== null && value.type && value.value) {\n switch (value.type) {\n case 'ascii':\n return Cl.bufferFromAscii(value.value);\n case 'utf8':\n return Cl.bufferFromUtf8(value.value);\n case 'hex':\n return Cl.bufferFromHex(value.value);\n default:\n throw new Error(\\`Unsupported buffer type: \\${value.type}\\`);\n }\n }\n if (typeof value === 'string') {\n if (value.startsWith('0x') || /^[0-9a-fA-F]+$/.test(value)) {\n return Cl.bufferFromHex(value);\n }\n const hasNonAscii = value.split('').some(char => char.charCodeAt(0) > 127);\n if (hasNonAscii) {\n return Cl.bufferFromUtf8(value);\n }\n return Cl.bufferFromAscii(value);\n }\n throw new Error(\\`Invalid buffer value: \\${value}\\`);\n })()`;\n\t}\n\n\tif (isAbiOptional(type)) {\n\t\tconst innerConversion = generateClarityConversion(argName, {\n\t\t\ttype: type.optional,\n\t\t});\n\t\treturn `${argName} !== null ? Cl.some(${innerConversion.replace(argName, `${argName}`)}) : Cl.none()`;\n\t}\n\n\tif (isAbiList(type)) {\n\t\tconst innerConversion = generateClarityConversion(\"item\", {\n\t\t\ttype: type.list.type,\n\t\t});\n\t\tconst maxLength = type.list.length || 100;\n\t\treturn `(() => {\n const listValue = ${argName};\n if (listValue.length > ${maxLength}) {\n throw new Error(\\`List length \\${listValue.length} exceeds max ${maxLength}\\`);\n }\n return Cl.list(listValue.map(item => ${innerConversion}));\n })()`;\n\t}\n\n\tif (isAbiTuple(type)) {\n\t\tconst requiredFields = type.tuple.map((f: { name: string }) => f.name);\n\t\tconst fieldNames = JSON.stringify(requiredFields);\n\t\tconst fields = type.tuple\n\t\t\t.map((field: { name: string; type: AbiType }) => {\n\t\t\t\tconst camelFieldName = toCamelCase(field.name);\n\t\t\t\tconst fieldConversion = generateClarityConversion(\n\t\t\t\t\t`tupleValue.${camelFieldName}`,\n\t\t\t\t\t{ type: field.type },\n\t\t\t\t);\n\t\t\t\treturn `\"${field.name}\": ${fieldConversion}`;\n\t\t\t})\n\t\t\t.join(\", \");\n\t\treturn `(() => {\n const tupleValue = ${argName};\n const requiredFields = ${fieldNames};\n for (const fieldName of requiredFields) {\n const camelName = fieldName.replace(/-([a-z])/g, (_: string, l: string) => l.toUpperCase());\n if (!(fieldName in tupleValue) && !(camelName in tupleValue)) {\n throw new Error(\\`Missing tuple field: \\${fieldName}\\`);\n }\n }\n return Cl.tuple({ ${fields} });\n })()`;\n\t}\n\n\tif (isAbiResponse(type)) {\n\t\tconst okConversion = generateClarityConversion(`responseValue.ok`, {\n\t\t\ttype: type.response.ok,\n\t\t});\n\t\tconst errConversion = generateClarityConversion(`responseValue.err`, {\n\t\t\ttype: type.response.error,\n\t\t});\n\t\treturn `(() => {\n const responseValue = ${argName};\n const hasOk = 'ok' in responseValue;\n const hasErr = 'err' in responseValue;\n if (hasOk && !hasErr) {\n return Cl.ok(${okConversion});\n }\n if (hasErr && !hasOk) {\n return Cl.error(${errConversion});\n }\n throw new Error(\"Response must have exactly 'ok' or 'err' property\");\n })()`;\n\t}\n\n\treturn `${argName}`;\n}\n",
8
+ "/**\n * Plugin Manager for @secondlayer/cli\n * Handles plugin registration, lifecycle execution, and output management\n */\n\nimport { promises as fs } from \"node:fs\";\nimport path from \"node:path\";\nimport { isValidAddress as _validateStacksAddress } from \"@secondlayer/stacks\";\nconst validateStacksAddress = _validateStacksAddress as (\n\taddress: string,\n) => boolean;\nimport { getErrorMessage } from \"@secondlayer/shared\";\nimport { toCamelCase } from \"@secondlayer/stacks/clarity\";\nimport type {\n\tContractConfig,\n\tGenerateContext,\n\tGeneratedOutput,\n\tHookResult,\n\tLogger,\n\tPluginExecutionContext,\n\tPluginUtils,\n\tProcessedContract,\n\tResolvedConfig,\n\tSecondLayerPlugin,\n\tUserConfig,\n} from \"../types/plugin\";\nimport { isClarinetContract, isDirectFileContract } from \"../types/plugin\";\nimport { parseContractId } from \"../utils/contract-id\";\n\n/**\n * Core plugin manager that orchestrates plugin execution\n */\nexport class PluginManager {\n\tprivate plugins: SecondLayerPlugin[] = [];\n\tprivate logger: Logger;\n\tprivate utils: PluginUtils;\n\tprivate executionContext: PluginExecutionContext;\n\n\tconstructor() {\n\t\tthis.logger = this.createLogger();\n\t\tthis.utils = this.createUtils();\n\t\tthis.executionContext = {\n\t\t\tphase: \"config\",\n\t\t\tstartTime: Date.now(),\n\t\t\tresults: new Map(),\n\t\t};\n\t}\n\n\t/**\n\t * Register a plugin\n\t */\n\tregister(plugin: SecondLayerPlugin): void {\n\t\t// Validate plugin\n\t\tif (!plugin.name || !plugin.version) {\n\t\t\tthrow new Error(\"Plugin must have a name and version\");\n\t\t}\n\n\t\t// Check for duplicate plugin names\n\t\tconst existing = this.plugins.find((p) => p.name === plugin.name);\n\t\tif (existing) {\n\t\t\tthrow new Error(\n\t\t\t\t`Plugin \"${plugin.name}\" is already registered (version ${existing.version})`,\n\t\t\t);\n\t\t}\n\n\t\tthis.plugins.push(plugin);\n\t\tthis.logger.debug(`Registered plugin: ${plugin.name}@${plugin.version}`);\n\t}\n\n\t/**\n\t * Get all registered plugins\n\t */\n\tgetPlugins(): SecondLayerPlugin[] {\n\t\treturn [...this.plugins];\n\t}\n\n\t/**\n\t * Transform user config through all plugins\n\t */\n\tasync transformConfig(config: UserConfig): Promise<ResolvedConfig> {\n\t\tthis.executionContext.phase = \"config\";\n\t\tlet transformedConfig = { ...config };\n\n\t\tfor (const plugin of this.plugins) {\n\t\t\tif (plugin.transformConfig) {\n\t\t\t\tthis.executionContext.currentPlugin = plugin;\n\t\t\t\ttry {\n\t\t\t\t\tconst result = await plugin.transformConfig(transformedConfig);\n\t\t\t\t\ttransformedConfig = result;\n\t\t\t\t\tthis.recordHookResult(plugin.name, \"transformConfig\", {\n\t\t\t\t\t\tsuccess: true,\n\t\t\t\t\t});\n\t\t\t\t} catch (error) {\n\t\t\t\t\tthis.recordHookResult(plugin.name, \"transformConfig\", {\n\t\t\t\t\t\tsuccess: false,\n\t\t\t\t\t\terror:\n\t\t\t\t\t\t\terror instanceof Error\n\t\t\t\t\t\t\t\t? error\n\t\t\t\t\t\t\t\t: new Error(getErrorMessage(error)),\n\t\t\t\t\t});\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t`Plugin \"${plugin.name}\" failed during config transformation: ${getErrorMessage(error)}`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Add plugins array to resolved config\n\t\tconst resolvedConfig: ResolvedConfig = {\n\t\t\t...transformedConfig,\n\t\t\tplugins: this.plugins,\n\t\t};\n\n\t\treturn resolvedConfig;\n\t}\n\n\t/**\n\t * Transform contracts through all plugins\n\t */\n\tasync transformContracts(\n\t\tcontracts: ContractConfig[],\n\t\t_config: ResolvedConfig,\n\t): Promise<ProcessedContract[]> {\n\t\tconst processedContracts: ProcessedContract[] = [];\n\n\t\tfor (let contract of contracts) {\n\t\t\tif (isClarinetContract(contract) && contract.abi) {\n\t\t\t\tprocessedContracts.push(this.contractToProcessed(contract, \"clarinet\"));\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (isDirectFileContract(contract) && contract.abi) {\n\t\t\t\tprocessedContracts.push(this.contractToProcessed(contract, \"direct\"));\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// Transform through each plugin\n\t\t\tfor (const plugin of this.plugins) {\n\t\t\t\tif (plugin.transformContract) {\n\t\t\t\t\tthis.executionContext.currentPlugin = plugin;\n\t\t\t\t\ttry {\n\t\t\t\t\t\tcontract = await plugin.transformContract(contract);\n\t\t\t\t\t\tthis.recordHookResult(plugin.name, \"transformContract\", {\n\t\t\t\t\t\t\tsuccess: true,\n\t\t\t\t\t\t});\n\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\tthis.recordHookResult(plugin.name, \"transformContract\", {\n\t\t\t\t\t\t\tsuccess: false,\n\t\t\t\t\t\t\terror:\n\t\t\t\t\t\t\t\terror instanceof Error\n\t\t\t\t\t\t\t\t\t? error\n\t\t\t\t\t\t\t\t\t: new Error(getErrorMessage(error)),\n\t\t\t\t\t\t});\n\t\t\t\t\t\tthis.logger.warn(\n\t\t\t\t\t\t\t`Plugin \"${plugin.name}\" failed to transform contract: ${getErrorMessage(error)}`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (contract.abi) {\n\t\t\t\tprocessedContracts.push(this.contractToProcessed(contract, \"api\"));\n\t\t\t}\n\t\t}\n\n\t\treturn processedContracts;\n\t}\n\n\t/**\n\t * Execute lifecycle hooks\n\t */\n\tasync executeHook(\n\t\thookName: keyof SecondLayerPlugin,\n\t\t// biome-ignore lint/suspicious/noExplicitAny: interop boundary or dynamic-shape value where typing adds friction without runtime safety\n\t\tcontext: any,\n\t): Promise<void> {\n\t\tfor (const plugin of this.plugins) {\n\t\t\tconst hook = plugin[hookName];\n\t\t\tif (typeof hook === \"function\") {\n\t\t\t\tthis.executionContext.currentPlugin = plugin;\n\t\t\t\ttry {\n\t\t\t\t\t// biome-ignore lint/suspicious/noExplicitAny: interop boundary or dynamic-shape value where typing adds friction without runtime safety\n\t\t\t\t\tawait (hook as any).call(plugin, context);\n\t\t\t\t\tthis.recordHookResult(plugin.name, hookName as string, {\n\t\t\t\t\t\tsuccess: true,\n\t\t\t\t\t});\n\t\t\t\t} catch (error) {\n\t\t\t\t\tthis.recordHookResult(plugin.name, hookName as string, {\n\t\t\t\t\t\tsuccess: false,\n\t\t\t\t\t\terror:\n\t\t\t\t\t\t\terror instanceof Error\n\t\t\t\t\t\t\t\t? error\n\t\t\t\t\t\t\t\t: new Error(getErrorMessage(error)),\n\t\t\t\t\t});\n\t\t\t\t\tthis.logger.error(\n\t\t\t\t\t\t`Plugin \"${plugin.name}\" failed during ${hookName as string}: ${getErrorMessage(error)}`,\n\t\t\t\t\t);\n\t\t\t\t\t// Don't throw - allow other plugins to continue\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Execute generation phase with full context\n\t */\n\tasync executeGeneration(\n\t\tcontracts: ProcessedContract[],\n\t\tconfig: ResolvedConfig,\n\t): Promise<Map<string, GeneratedOutput>> {\n\t\tthis.executionContext.phase = \"generate\";\n\t\tconst outputs = new Map<string, GeneratedOutput>();\n\n\t\t// Create generation context\n\t\tconst context: GenerateContext = {\n\t\t\tconfig,\n\t\t\tlogger: this.logger,\n\t\t\tutils: this.utils,\n\t\t\tcontracts,\n\t\t\toutputs,\n\t\t\t// biome-ignore lint/suspicious/noExplicitAny: interop boundary or dynamic-shape value where typing adds friction without runtime safety\n\t\t\taugment: (outputKey: string, contractName: string, content: any) => {\n\t\t\t\tthis.augmentOutput(outputs, outputKey, contractName, content);\n\t\t\t},\n\t\t\taddOutput: (key: string, output: GeneratedOutput) => {\n\t\t\t\toutputs.set(key, output);\n\t\t\t},\n\t\t};\n\n\t\t// Execute beforeGenerate hooks\n\t\tawait this.executeHook(\"beforeGenerate\", context);\n\n\t\t// Execute generate hooks\n\t\tawait this.executeHook(\"generate\", context);\n\n\t\t// Execute afterGenerate hooks\n\t\tawait this.executeHook(\"afterGenerate\", context);\n\n\t\treturn outputs;\n\t}\n\n\t/**\n\t * Transform outputs through plugins\n\t */\n\tasync transformOutputs(\n\t\toutputs: Map<string, GeneratedOutput>,\n\t): Promise<Map<string, GeneratedOutput>> {\n\t\tthis.executionContext.phase = \"output\";\n\t\tconst transformedOutputs = new Map<string, GeneratedOutput>();\n\n\t\tfor (const [key, output] of outputs) {\n\t\t\tlet transformedContent = output.content;\n\n\t\t\tfor (const plugin of this.plugins) {\n\t\t\t\tif (plugin.transformOutput) {\n\t\t\t\t\tthis.executionContext.currentPlugin = plugin;\n\t\t\t\t\ttry {\n\t\t\t\t\t\ttransformedContent = await plugin.transformOutput(\n\t\t\t\t\t\t\ttransformedContent,\n\t\t\t\t\t\t\toutput.type || \"other\",\n\t\t\t\t\t\t);\n\t\t\t\t\t\tthis.recordHookResult(plugin.name, \"transformOutput\", {\n\t\t\t\t\t\t\tsuccess: true,\n\t\t\t\t\t\t});\n\t\t\t\t\t} catch (error) {\n\t\t\t\t\t\tthis.recordHookResult(plugin.name, \"transformOutput\", {\n\t\t\t\t\t\t\tsuccess: false,\n\t\t\t\t\t\t\terror:\n\t\t\t\t\t\t\t\terror instanceof Error\n\t\t\t\t\t\t\t\t\t? error\n\t\t\t\t\t\t\t\t\t: new Error(getErrorMessage(error)),\n\t\t\t\t\t\t});\n\t\t\t\t\t\tthis.logger.warn(\n\t\t\t\t\t\t\t`Plugin \"${plugin.name}\" failed to transform output: ${getErrorMessage(error)}`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\ttransformedOutputs.set(key, {\n\t\t\t\t...output,\n\t\t\t\tcontent: transformedContent,\n\t\t\t});\n\t\t}\n\n\t\treturn transformedOutputs;\n\t}\n\n\t/**\n\t * Write outputs to disk\n\t */\n\tasync writeOutputs(outputs: Map<string, GeneratedOutput>): Promise<void> {\n\t\tfor (const [, output] of outputs) {\n\t\t\ttry {\n\t\t\t\tconst resolvedPath = path.resolve(process.cwd(), output.path);\n\t\t\t\tawait this.utils.ensureDir(path.dirname(resolvedPath));\n\t\t\t\tawait this.utils.writeFile(resolvedPath, output.content);\n\t\t\t\t// Don't log here - let the main command handle success messaging\n\t\t\t} catch (error) {\n\t\t\t\tthis.logger.error(\n\t\t\t\t\t`Failed to write ${output.path}: ${getErrorMessage(error)}`,\n\t\t\t\t);\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Get execution results for debugging\n\t */\n\tgetExecutionResults(): Map<string, HookResult[]> {\n\t\treturn new Map(this.executionContext.results);\n\t}\n\n\t/**\n\t * Convert a contract config with an ABI into a ProcessedContract\n\t */\n\tprivate contractToProcessed(\n\t\tcontract: ContractConfig,\n\t\tsource: string,\n\t): ProcessedContract {\n\t\tconst address =\n\t\t\ttypeof contract.address === \"string\" ? contract.address : \"\";\n\t\tconst parsed = parseContractId(address);\n\t\treturn {\n\t\t\tname: contract.name || parsed.contractName || \"unknown\",\n\t\t\taddress: parsed.address || \"unknown\",\n\t\t\tcontractName: parsed.contractName || contract.name || \"unknown\",\n\t\t\t// biome-ignore lint/style/noNonNullAssertion: value is non-null after preceding check or by construction; TS narrowing limitation\n\t\t\tabi: contract.abi!,\n\t\t\tsource: source === \"api\" ? (\"api\" as const) : (\"local\" as const),\n\t\t\tmetadata: contract.metadata ?? { source },\n\t\t};\n\t}\n\n\t/**\n\t * Augment existing output with additional content\n\t */\n\tprivate augmentOutput(\n\t\toutputs: Map<string, GeneratedOutput>,\n\t\toutputKey: string,\n\t\tcontractName: string,\n\t\t// biome-ignore lint/suspicious/noExplicitAny: interop boundary or dynamic-shape value where typing adds friction without runtime safety\n\t\tcontent: any,\n\t): void {\n\t\tconst existing = outputs.get(outputKey);\n\t\tif (!existing) {\n\t\t\tthis.logger.warn(`Cannot augment non-existent output: ${outputKey}`);\n\t\t\treturn;\n\t\t}\n\n\t\t// Simple augmentation - append content\n\t\t// In a real implementation, this would be more sophisticated\n\t\tconst augmentedContent = `${existing.content}\\n\\n// Augmented by plugin for ${contractName}\\n${JSON.stringify(content, null, 2)}`;\n\n\t\toutputs.set(outputKey, {\n\t\t\t...existing,\n\t\t\tcontent: augmentedContent,\n\t\t});\n\t}\n\n\t/**\n\t * Record hook execution result\n\t */\n\tprivate recordHookResult(\n\t\tpluginName: string,\n\t\thookName: string,\n\t\tresult: Omit<HookResult, \"plugin\">,\n\t): void {\n\t\tconst key = `${pluginName}:${hookName}`;\n\t\tconst existing = this.executionContext.results.get(key) || [];\n\t\texisting.push({ ...result, plugin: pluginName });\n\t\tthis.executionContext.results.set(key, existing);\n\t}\n\n\t/**\n\t * Create logger instance\n\t */\n\tprivate createLogger(): Logger {\n\t\treturn {\n\t\t\tinfo: (message: string) => console.log(`ℹ️ ${message}`),\n\t\t\twarn: (message: string) => console.warn(`⚠️ ${message}`),\n\t\t\terror: (message: string) => console.error(`❌ ${message}`),\n\t\t\tdebug: (message: string) => {\n\t\t\t\tif (process.env.DEBUG) {\n\t\t\t\t\tconsole.log(`🐛 ${message}`);\n\t\t\t\t}\n\t\t\t},\n\t\t\tsuccess: (message: string) => console.log(`✅ ${message}`),\n\t\t};\n\t}\n\n\t/**\n\t * Create utils instance\n\t */\n\tprivate createUtils(): PluginUtils {\n\t\treturn {\n\t\t\ttoCamelCase,\n\n\t\t\ttoKebabCase: (str: string) => {\n\t\t\t\treturn str.replace(/[A-Z]/g, (letter) => `-${letter.toLowerCase()}`);\n\t\t\t},\n\n\t\t\tvalidateAddress: (address: string) => {\n\t\t\t\treturn validateStacksAddress(parseContractId(address).address);\n\t\t\t},\n\n\t\t\tparseContractId: (contractId: string) => {\n\t\t\t\treturn parseContractId(contractId);\n\t\t\t},\n\n\t\t\tformatCode: async (code: string) => {\n\t\t\t\tconst { formatCode } = await import(\"../utils/format\");\n\t\t\t\treturn formatCode(code);\n\t\t\t},\n\n\t\t\tresolvePath: (relativePath: string) => {\n\t\t\t\treturn path.resolve(process.cwd(), relativePath);\n\t\t\t},\n\n\t\t\tfileExists: async (filePath: string) => {\n\t\t\t\ttry {\n\t\t\t\t\tawait fs.access(filePath);\n\t\t\t\t\treturn true;\n\t\t\t\t} catch {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t},\n\n\t\t\treadFile: async (filePath: string) => {\n\t\t\t\treturn fs.readFile(filePath, \"utf-8\");\n\t\t\t},\n\n\t\t\twriteFile: async (filePath: string, content: string) => {\n\t\t\t\tawait fs.writeFile(filePath, content, \"utf-8\");\n\t\t\t},\n\n\t\t\tensureDir: async (dirPath: string) => {\n\t\t\t\tawait fs.mkdir(dirPath, { recursive: true });\n\t\t\t},\n\t\t};\n\t}\n}\n",
9
+ "/**\n * Shared code-generation utility for converting TypeScript values to ClarityValue expressions.\n * Used by contract, actions, and testing generators.\n */\n\nimport {\n\ttype AbiType,\n\tisAbiBuffer,\n\tisAbiList,\n\tisAbiOptional,\n\tisAbiResponse,\n\tisAbiStringAscii,\n\tisAbiStringUtf8,\n\tisAbiTuple,\n\ttoCamelCase,\n} from \"@secondlayer/stacks/clarity\";\n\n/**\n * Generate a code string that converts a TypeScript value to a ClarityValue\n * based on the Clarity ABI argument type.\n */\nexport function generateClarityConversion(\n\targName: string,\n\targType: { type: AbiType },\n): string {\n\tconst type = argType.type;\n\n\tif (typeof type === \"string\") {\n\t\tswitch (type) {\n\t\t\tcase \"uint128\":\n\t\t\t\treturn `Cl.uint(${argName})`;\n\t\t\tcase \"int128\":\n\t\t\t\treturn `Cl.int(${argName})`;\n\t\t\tcase \"bool\":\n\t\t\t\treturn `Cl.bool(${argName})`;\n\t\t\tcase \"principal\":\n\t\t\tcase \"trait_reference\":\n\t\t\t\treturn `(() => {\n const [address, contractName] = ${argName}.split(\".\") as [string, string | undefined];\n if (!validateStacksAddress(address)) {\n throw new Error(\"Invalid Stacks address format\");\n }\n if (contractName !== undefined) {\n if (!CONTRACT_NAME_REGEX.test(contractName)) {\n throw new Error(\"Invalid contract name format: must start with letter and contain only letters, numbers, and hyphens\");\n }\n return Cl.contractPrincipal(address, contractName);\n }\n return Cl.standardPrincipal(${argName});\n })()`;\n\t\t\tdefault:\n\t\t\t\treturn `${argName}`;\n\t\t}\n\t}\n\n\tif (isAbiStringAscii(type)) {\n\t\treturn `Cl.stringAscii(${argName})`;\n\t}\n\n\tif (isAbiStringUtf8(type)) {\n\t\treturn `Cl.stringUtf8(${argName})`;\n\t}\n\n\tif (isAbiBuffer(type)) {\n\t\treturn `(() => {\n const value = ${argName};\n if (value instanceof Uint8Array) {\n return Cl.buffer(value);\n }\n if (typeof value === 'object' && value !== null && value.type && value.value) {\n switch (value.type) {\n case 'ascii':\n return Cl.bufferFromAscii(value.value);\n case 'utf8':\n return Cl.bufferFromUtf8(value.value);\n case 'hex':\n return Cl.bufferFromHex(value.value);\n default:\n throw new Error(\\`Unsupported buffer type: \\${value.type}\\`);\n }\n }\n if (typeof value === 'string') {\n if (value.startsWith('0x') || /^[0-9a-fA-F]+$/.test(value)) {\n return Cl.bufferFromHex(value);\n }\n const hasNonAscii = value.split('').some(char => char.charCodeAt(0) > 127);\n if (hasNonAscii) {\n return Cl.bufferFromUtf8(value);\n }\n return Cl.bufferFromAscii(value);\n }\n throw new Error(\\`Invalid buffer value: \\${value}\\`);\n })()`;\n\t}\n\n\tif (isAbiOptional(type)) {\n\t\tconst innerConversion = generateClarityConversion(argName, {\n\t\t\ttype: type.optional,\n\t\t});\n\t\treturn `${argName} !== null ? Cl.some(${innerConversion.replace(argName, `${argName}`)}) : Cl.none()`;\n\t}\n\n\tif (isAbiList(type)) {\n\t\tconst innerConversion = generateClarityConversion(\"item\", {\n\t\t\ttype: type.list.type,\n\t\t});\n\t\tconst maxLength = type.list.length || 100;\n\t\treturn `(() => {\n const listValue = ${argName};\n if (listValue.length > ${maxLength}) {\n throw new Error(\\`List length \\${listValue.length} exceeds max ${maxLength}\\`);\n }\n return Cl.list(listValue.map(item => ${innerConversion}));\n })()`;\n\t}\n\n\tif (isAbiTuple(type)) {\n\t\tconst requiredFields = type.tuple.map((f: { name: string }) => f.name);\n\t\tconst fieldNames = JSON.stringify(requiredFields);\n\t\tconst fields = type.tuple\n\t\t\t.map((field: { name: string; type: AbiType }) => {\n\t\t\t\tconst camelFieldName = toCamelCase(field.name);\n\t\t\t\tconst fieldConversion = generateClarityConversion(\n\t\t\t\t\t`tupleValue.${camelFieldName}`,\n\t\t\t\t\t{ type: field.type },\n\t\t\t\t);\n\t\t\t\treturn `\"${field.name}\": ${fieldConversion}`;\n\t\t\t})\n\t\t\t.join(\", \");\n\t\treturn `(() => {\n const tupleValue = ${argName};\n const requiredFields = ${fieldNames};\n for (const fieldName of requiredFields) {\n const camelName = fieldName.replace(/-([a-z])/g, (_: string, l: string) => l.toUpperCase());\n if (!(fieldName in tupleValue) && !(camelName in tupleValue)) {\n throw new Error(\\`Missing tuple field: \\${fieldName}\\`);\n }\n }\n return Cl.tuple({ ${fields} });\n })()`;\n\t}\n\n\tif (isAbiResponse(type)) {\n\t\tconst okConversion = generateClarityConversion(\"responseValue.ok\", {\n\t\t\ttype: type.response.ok,\n\t\t});\n\t\tconst errConversion = generateClarityConversion(\"responseValue.err\", {\n\t\t\ttype: type.response.error,\n\t\t});\n\t\treturn `(() => {\n const responseValue = ${argName};\n const hasOk = 'ok' in responseValue;\n const hasErr = 'err' in responseValue;\n if (hasOk && !hasErr) {\n return Cl.ok(${okConversion});\n }\n if (hasErr && !hasOk) {\n return Cl.error(${errConversion});\n }\n throw new Error(\"Response must have exactly 'ok' or 'err' property\");\n })()`;\n\t}\n\n\treturn `${argName}`;\n}\n",
10
10
  "/**\n * Shared type mapping utility for Clarity types to TypeScript types\n *\n * This module provides a single, consistent implementation for mapping\n * Clarity types to their TypeScript equivalents, used across all generators.\n */\n\nimport {\n\ttype AbiType,\n\tisAbiBuffer,\n\tisAbiList,\n\tisAbiOptional,\n\tisAbiResponse,\n\tisAbiStringAscii,\n\tisAbiStringUtf8,\n\tisAbiTuple,\n\ttoCamelCase,\n} from \"@secondlayer/stacks/clarity\";\n\n/**\n * Map a Clarity type to its TypeScript type string representation\n *\n * @param type - The Clarity type definition from an ABI\n * @returns The TypeScript type string (e.g., \"bigint\", \"string\", \"{ field: bigint }\")\n */\nexport function clarityTypeToTS(type: AbiType): string {\n\t// Handle string primitive types\n\tif (typeof type === \"string\") {\n\t\tswitch (type) {\n\t\t\tcase \"uint128\":\n\t\t\tcase \"int128\":\n\t\t\t\treturn \"bigint\";\n\t\t\tcase \"bool\":\n\t\t\t\treturn \"boolean\";\n\t\t\tcase \"principal\":\n\t\t\tcase \"trait_reference\":\n\t\t\t\treturn \"string\";\n\t\t\tdefault: {\n\t\t\t\t// Handle shorthand string formats (e.g., \"string-ascii\", \"string-utf8\", \"buff\")\n\t\t\t\t// Cast to string since TypeScript narrows to never in exhaustive switches\n\t\t\t\tconst typeStr = type as string;\n\t\t\t\t// Handle \"none\" type (commonly used in response types)\n\t\t\t\tif (typeStr === \"none\") {\n\t\t\t\t\treturn \"null\";\n\t\t\t\t}\n\t\t\t\tif (\n\t\t\t\t\ttypeStr.includes(\"string\") ||\n\t\t\t\t\ttypeStr.includes(\"ascii\") ||\n\t\t\t\t\ttypeStr.includes(\"utf8\")\n\t\t\t\t) {\n\t\t\t\t\treturn \"string\";\n\t\t\t\t}\n\t\t\t\tif (typeStr.includes(\"buff\")) {\n\t\t\t\t\treturn \"Uint8Array | string | { type: 'ascii' | 'utf8' | 'hex'; value: string }\";\n\t\t\t\t}\n\t\t\t\tif (typeStr.includes(\"uint\") || typeStr.includes(\"int\")) {\n\t\t\t\t\treturn \"bigint\";\n\t\t\t\t}\n\t\t\t\treturn \"any\";\n\t\t\t}\n\t\t}\n\t}\n\n\t// Handle buffer types - support flexible input\n\tif (isAbiBuffer(type)) {\n\t\treturn \"Uint8Array | string | { type: 'ascii' | 'utf8' | 'hex'; value: string }\";\n\t}\n\n\t// Handle string types\n\tif (isAbiStringAscii(type) || isAbiStringUtf8(type)) {\n\t\treturn \"string\";\n\t}\n\n\t// Handle optional types\n\tif (isAbiOptional(type)) {\n\t\tconst innerType = clarityTypeToTS(type.optional);\n\t\t// Wrap union types in parentheses for correct precedence\n\t\tif (innerType.includes(\" | \") && !innerType.startsWith(\"(\")) {\n\t\t\treturn `(${innerType}) | null`;\n\t\t}\n\t\treturn `${innerType} | null`;\n\t}\n\n\t// Handle list types\n\tif (isAbiList(type)) {\n\t\tconst innerType = clarityTypeToTS(type.list.type);\n\t\t// Wrap union types in parentheses for correct precedence\n\t\tif (innerType.includes(\" | \") && !innerType.startsWith(\"(\")) {\n\t\t\treturn `(${innerType})[]`;\n\t\t}\n\t\treturn `${innerType}[]`;\n\t}\n\n\t// Handle tuple types\n\tif (isAbiTuple(type)) {\n\t\tconst fields = type.tuple\n\t\t\t.map(\n\t\t\t\t(field: { name: string; type: AbiType }) =>\n\t\t\t\t\t`${toCamelCase(field.name)}: ${clarityTypeToTS(field.type)}`,\n\t\t\t)\n\t\t\t.join(\"; \");\n\t\treturn `{ ${fields} }`;\n\t}\n\n\t// Handle response types\n\tif (isAbiResponse(type)) {\n\t\tconst okType = clarityTypeToTS(type.response.ok);\n\t\tconst errType = clarityTypeToTS(type.response.error);\n\t\treturn `{ ok: ${okType} } | { err: ${errType} }`;\n\t}\n\n\t// Fallback for unknown types\n\treturn \"any\";\n}\n\n/**\n * Map a Clarity argument definition to its TypeScript type\n * This is a convenience wrapper that extracts the type from an argument object\n *\n * @param arg - An argument object with a `type` property\n * @returns The TypeScript type string\n */\nexport function getTypeForArg(arg: { type: AbiType }): string {\n\treturn clarityTypeToTS(arg.type);\n}\n\n/**\n * Generate a TypeScript type signature for function arguments\n *\n * @param args - Array of argument definitions with name and type\n * @returns TypeScript type string like \"{ arg1: bigint; arg2: string }\"\n */\nexport function generateArgsTypeSignature(\n\targs: readonly { name: string; type: AbiType }[],\n): string {\n\tif (args.length === 0) return \"void\";\n\n\tconst argsList = args\n\t\t.map((arg) => `${toCamelCase(arg.name)}: ${clarityTypeToTS(arg.type)}`)\n\t\t.join(\"; \");\n\treturn `{ ${argsList} }`;\n}\n",
11
11
  "/**\n * Shared utilities for plugin code generators (actions, testing).\n */\n\nimport {\n\ttype AbiType,\n\ttype FunctionArg,\n\tisAbiTuple,\n\ttoCamelCase,\n} from \"@secondlayer/stacks/clarity\";\nimport { generateClarityConversion } from \"./clarity-conversion\";\nimport { getTypeForArg } from \"./type-mapping\";\n\n/**\n * Generate a TypeScript args signature for a helper function.\n * e.g. `args: { amount: bigint; recipient: string }, `\n */\nexport function generateArgsSignature(\n\targs: ReadonlyArray<FunctionArg>,\n): string {\n\tif (args.length === 0) return \"\";\n\n\tconst argsTypes = args\n\t\t.map((arg) => {\n\t\t\tconst camelName = toCamelCase(arg.name);\n\t\t\treturn `${camelName}: ${getTypeForArg(arg)}`;\n\t\t})\n\t\t.join(\"; \");\n\n\treturn `args: { ${argsTypes} }, `;\n}\n\n/**\n * Generate Clarity argument expressions for function calls.\n * e.g. `Cl.uint(args.amount), Cl.standardPrincipal(args.recipient)`\n */\nexport function generateClarityArgs(args: ReadonlyArray<FunctionArg>): string {\n\tif (args.length === 0) return \"\";\n\n\treturn args\n\t\t.map((arg) => {\n\t\t\tconst argName = `args.${toCamelCase(arg.name)}`;\n\t\t\treturn generateClarityConversion(argName, arg);\n\t\t})\n\t\t.join(\", \");\n}\n\n/**\n * Generate Clarity conversion for a map key (tuple or simple type).\n */\nexport function generateMapKeyConversion(keyType: AbiType): string {\n\tif (isAbiTuple(keyType)) {\n\t\tconst fields = keyType.tuple\n\t\t\t.map((field: { name: string; type: AbiType }) => {\n\t\t\t\tconst camelFieldName = toCamelCase(field.name);\n\t\t\t\tconst fieldConversion = generateClarityConversion(\n\t\t\t\t\t`key.${camelFieldName}`,\n\t\t\t\t\t{ type: field.type },\n\t\t\t\t);\n\t\t\t\treturn `\"${field.name}\": ${fieldConversion}`;\n\t\t\t})\n\t\t\t.join(\", \");\n\t\treturn `Cl.tuple({ ${fields} })`;\n\t}\n\treturn generateClarityConversion(\"key\", { type: keyType });\n}\n",
12
- "import {\n\ttype AbiFunction,\n\ttype AbiMap,\n\ttype AbiVariable,\n\ttoCamelCase,\n} from \"@secondlayer/stacks/clarity\";\nimport type { ResolvedContract } from \"../types/config\";\nimport { generateClarityConversion } from \"../utils/clarity-conversion\";\nimport { formatCode } from \"../utils/format\";\nimport { generateMapKeyConversion } from \"../utils/generator-helpers\";\nimport { getTypeForArg } from \"../utils/type-mapping\";\n\n/**\n * Code generator for contract interfaces\n */\n\n/**\n * Generate shared network utilities for the generated code\n */\nfunction generateNetworkUtils(): string {\n\treturn `/**\n * API URLs for different networks\n */\nconst API_URLS: Record<'mainnet' | 'testnet' | 'devnet', string> = {\n mainnet: 'https://api.hiro.so',\n testnet: 'https://api.testnet.hiro.so',\n devnet: 'http://localhost:3999'\n};\n\n/**\n * Infer network from Stacks address prefix\n * SP/SM = mainnet, ST/SN = testnet\n */\nfunction inferNetworkFromAddress(address: string): 'mainnet' | 'testnet' | undefined {\n if (address.startsWith('SP') || address.startsWith('SM')) return 'mainnet';\n if (address.startsWith('ST') || address.startsWith('SN')) return 'testnet';\n return undefined;\n}\n\n/**\n * Get API URL, inferring network from contract address if not specified\n */\nfunction getApiUrl(\n contractAddress: string,\n explicitNetwork?: 'mainnet' | 'testnet' | 'devnet'\n): string {\n const network = explicitNetwork ?? inferNetworkFromAddress(contractAddress) ?? 'mainnet';\n return API_URLS[network];\n}`;\n}\n\n/**\n * Generate validation utilities that are inlined in generated code\n * This avoids requiring external dependencies beyond @secondlayer/stacks\n */\nfunction generateValidationUtils(): string {\n\treturn `/**\n * Contract name validation regex\n * Must start with letter, contain only letters, numbers, and hyphens, max 128 chars\n */\nconst CONTRACT_NAME_REGEX = /^[a-zA-Z][a-zA-Z0-9\\\\-]{0,127}$/;`;\n}\n\nexport async function generateContractInterface(\n\tcontracts: ResolvedContract[],\n): Promise<string> {\n\tconst imports = `import { Cl, validateStacksAddress } from '@secondlayer/stacks'`;\n\n\tconst header = `/**\n * Generated by @secondlayer/cli\n * DO NOT EDIT MANUALLY\n *\n * @requires @secondlayer/stacks - Install with: npm install @secondlayer/stacks\n */`;\n\n\tconst validationUtils = generateValidationUtils();\n\tconst networkUtils = generateNetworkUtils();\n\n\tconst contractsCode = contracts\n\t\t.map((contract) => generateContract(contract))\n\t\t.join(\"\\n\\n\");\n\n\tconst code = `${imports}\\n\\n${header}\\n\\n${validationUtils}\\n\\n${networkUtils}\\n\\n${contractsCode}`;\n\n\treturn formatCode(code);\n}\n\nfunction generateContract(contract: ResolvedContract): string {\n\tconst { name, address, contractName, abi } = contract;\n\n\tconst abiCode = generateAbiConstant(name, abi);\n\n\tconst methods = abi.functions\n\t\t.filter((func: AbiFunction) => func.access !== \"private\")\n\t\t.map((func: AbiFunction) => generateMethod(func, address, contractName))\n\t\t.join(\",\\n\\n \");\n\n\t// Generate maps object if contract has maps\n\tconst mapsObject = generateMapsObject(abi.maps || [], address, contractName);\n\n\t// Generate vars object if contract has variables (only data vars, not constants)\n\tconst varsObject = generateVarsObject(\n\t\tabi.variables || [],\n\t\taddress,\n\t\tcontractName,\n\t);\n\n\t// Generate constants object if contract has constants\n\tconst constantsObject = generateConstantsObject(\n\t\tabi.variables || [],\n\t\taddress,\n\t\tcontractName,\n\t);\n\n\t// Combine all members\n\tconst allMembers = [methods, mapsObject, varsObject, constantsObject].filter(\n\t\tBoolean,\n\t);\n\n\tconst contractCode = `export const ${name} = {\n address: '${address}',\n contractAddress: '${address}',\n contractName: '${contractName}',\n\n ${allMembers.join(\",\\n\\n \")}\n} as const`;\n\n\treturn `${abiCode}\\n\\n${contractCode}`;\n}\n\nfunction generateAbiConstant(name: string, abi: any): string {\n\tconst abiJson = JSON.stringify(abi, null, 2)\n\t\t.replace(/\"([a-zA-Z_$][a-zA-Z0-9_$]*)\":/g, \"$1:\") // Only remove quotes from valid JS identifiers\n\t\t.replace(/\"/g, \"'\"); // Use single quotes\n\n\treturn `export const ${name}Abi = ${abiJson} as const`;\n}\n\nfunction generateMethod(\n\tfunc: AbiFunction,\n\taddress: string,\n\tcontractName: string,\n): string {\n\tconst methodName = toCamelCase(func.name);\n\n\tif (func.args.length === 0) {\n\t\treturn `${methodName}() {\n return {\n contractAddress: '${address}',\n contractName: '${contractName}',\n functionName: '${func.name}',\n functionArgs: []\n }\n }`;\n\t}\n\n\tif (func.args.length === 1) {\n\t\tconst originalArgName = func.args[0].name;\n\t\tconst argName = toCamelCase(originalArgName);\n\t\tconst argType = getTypeForArg(func.args[0]);\n\t\tconst clarityConversion = generateClarityConversion(argName, func.args[0]);\n\n\t\treturn `${methodName}(...args: [{ ${argName}: ${argType} }] | [${argType}]) {\n const ${argName} = args.length === 1 && typeof args[0] === 'object' && args[0] !== null && '${argName}' in args[0]\n ? args[0].${argName}\n : args[0] as ${argType}\n \n return {\n contractAddress: '${address}',\n contractName: '${contractName}',\n functionName: '${func.name}',\n functionArgs: [${clarityConversion}]\n }\n }`;\n\t}\n\n\ttype Arg = { name: string; type: any };\n\tconst argsList = func.args\n\t\t.map((arg: Arg) => toCamelCase(arg.name))\n\t\t.join(\", \");\n\tconst argsTypes = func.args\n\t\t.map((arg: Arg) => {\n\t\t\tconst camelName = toCamelCase(arg.name);\n\t\t\treturn `${camelName}: ${getTypeForArg(arg)}`;\n\t\t})\n\t\t.join(\"; \");\n\tconst argsArray = func.args\n\t\t.map((arg: Arg) => {\n\t\t\tconst argName = toCamelCase(arg.name);\n\t\t\treturn generateClarityConversion(argName, arg);\n\t\t})\n\t\t.join(\", \");\n\tconst objectAccess = func.args\n\t\t.map((arg: Arg) => {\n\t\t\tconst camelName = toCamelCase(arg.name);\n\t\t\treturn `args[0].${camelName}`;\n\t\t})\n\t\t.join(\", \");\n\tconst positionTypes = func.args\n\t\t.map((arg: Arg) => getTypeForArg(arg))\n\t\t.join(\", \");\n\n\treturn `${methodName}(...args: [{ ${argsTypes} }] | [${positionTypes}]) {\n const [${argsList}] = args.length === 1 && typeof args[0] === 'object' && args[0] !== null\n ? [${objectAccess}]\n : args as [${positionTypes}]\n \n return {\n contractAddress: '${address}',\n contractName: '${contractName}',\n functionName: '${func.name}',\n functionArgs: [${argsArray}]\n }\n }`;\n}\n\n/**\n * Generate maps object with type-safe accessors for contract data maps\n */\nfunction generateMapsObject(\n\tmaps: readonly AbiMap[],\n\taddress: string,\n\tcontractName: string,\n): string {\n\tif (!maps || maps.length === 0) {\n\t\treturn \"\";\n\t}\n\n\tconst mapMethods = maps.map((map) => {\n\t\tconst methodName = toCamelCase(map.name);\n\t\tconst keyType = getTypeForArg({ type: map.key });\n\t\tconst valueType = getTypeForArg({ type: map.value });\n\t\tconst keyConversion = generateMapKeyConversion(map.key);\n\n\t\treturn `${methodName}: {\n async get(key: ${keyType}, options?: { network?: 'mainnet' | 'testnet' | 'devnet' }): Promise<${valueType} | null> {\n try {\n const { cvToJSON, serializeCV } = await import('@secondlayer/stacks/clarity');\n const baseUrl = getApiUrl('${address}', options?.network);\n const mapKey = ${keyConversion};\n const keyHex = serializeCV(mapKey).toString('hex');\n\n const response = await fetch(\n \\`\\${baseUrl}/v2/map_entry/${address}/${contractName}/${map.name}\\`,\n {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(keyHex)\n }\n );\n\n if (!response.ok) {\n throw new Error(\\`HTTP \\${response.status}: \\${response.statusText}\\`);\n }\n\n const result = await response.json();\n if (!result.data || result.data === '0x09') {\n return null; // none value\n }\n\n const { deserializeCV } = await import('@secondlayer/stacks/clarity');\n const cv = deserializeCV(result.data);\n const parsed = cvToJSON(cv);\n // Unwrap the (some ...) wrapper\n return parsed.value?.value ?? parsed.value ?? null;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\\`Map access failed for '${map.name}': \\${error.message}\\`);\n }\n throw error;\n }\n },\n keyType: ${JSON.stringify(map.key)} as const,\n valueType: ${JSON.stringify(map.value)} as const\n }`;\n\t});\n\n\treturn `maps: {\n ${mapMethods.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate vars object with type-safe accessors for contract data variables\n */\nfunction generateVarsObject(\n\tvariables: readonly AbiVariable[],\n\taddress: string,\n\tcontractName: string,\n): string {\n\tif (!variables || variables.length === 0) {\n\t\treturn \"\";\n\t}\n\n\t// Filter to only include mutable data variables (not constants)\n\tconst dataVars = variables.filter((v) => v.access === \"variable\");\n\n\tif (dataVars.length === 0) {\n\t\treturn \"\";\n\t}\n\n\tconst varMethods = dataVars.map((variable) => {\n\t\tconst methodName = toCamelCase(variable.name);\n\t\tconst valueType = getTypeForArg({ type: variable.type });\n\n\t\treturn `${methodName}: {\n async get(options?: { network?: 'mainnet' | 'testnet' | 'devnet' }): Promise<${valueType}> {\n try {\n const { cvToJSON, deserializeCV } = await import('@secondlayer/stacks/clarity');\n const baseUrl = getApiUrl('${address}', options?.network);\n\n const response = await fetch(\n \\`\\${baseUrl}/v2/data_var/${address}/${contractName}/${variable.name}?proof=0\\`\n );\n\n if (!response.ok) {\n throw new Error(\\`HTTP \\${response.status}: \\${response.statusText}\\`);\n }\n\n const result = await response.json();\n const cv = deserializeCV(result.data);\n const parsed = cvToJSON(cv);\n return parsed.value ?? parsed;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\\`Variable access failed for '${variable.name}': \\${error.message}\\`);\n }\n throw error;\n }\n },\n type: ${JSON.stringify(variable.type)} as const\n }`;\n\t});\n\n\treturn `vars: {\n ${varMethods.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate constants object with type-safe accessors for contract constants\n */\nfunction generateConstantsObject(\n\tvariables: readonly AbiVariable[],\n\taddress: string,\n\tcontractName: string,\n): string {\n\tif (!variables || variables.length === 0) {\n\t\treturn \"\";\n\t}\n\n\t// Filter to only include constants\n\tconst constants = variables.filter((v) => v.access === \"constant\");\n\n\tif (constants.length === 0) {\n\t\treturn \"\";\n\t}\n\n\tconst constMethods = constants.map((constant) => {\n\t\tconst methodName = toCamelCase(constant.name);\n\t\tconst valueType = getTypeForArg({ type: constant.type });\n\n\t\treturn `${methodName}: {\n async get(options?: { network?: 'mainnet' | 'testnet' | 'devnet' }): Promise<${valueType}> {\n try {\n const { cvToJSON, deserializeCV } = await import('@secondlayer/stacks/clarity');\n const baseUrl = getApiUrl('${address}', options?.network);\n\n const response = await fetch(\n \\`\\${baseUrl}/v2/constant_val/${address}/${contractName}/${constant.name}?proof=0\\`\n );\n\n if (!response.ok) {\n throw new Error(\\`HTTP \\${response.status}: \\${response.statusText}\\`);\n }\n\n const result = await response.json();\n const cv = deserializeCV(result.data);\n const parsed = cvToJSON(cv);\n return parsed.value ?? parsed;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\\`Constant access failed for '${constant.name}': \\${error.message}\\`);\n }\n throw error;\n }\n },\n type: ${JSON.stringify(constant.type)} as const\n }`;\n\t});\n\n\treturn `constants: {\n ${constMethods.join(\",\\n\\n \")}\n }`;\n}\n",
12
+ "import {\n\ttype AbiFunction,\n\ttype AbiMap,\n\ttype AbiVariable,\n\ttoCamelCase,\n} from \"@secondlayer/stacks/clarity\";\nimport type { ResolvedContract } from \"../types/config\";\nimport { generateClarityConversion } from \"../utils/clarity-conversion\";\nimport { formatCode } from \"../utils/format\";\nimport { generateMapKeyConversion } from \"../utils/generator-helpers\";\nimport { getTypeForArg } from \"../utils/type-mapping\";\n\n/**\n * Code generator for contract interfaces\n */\n\n/**\n * Generate shared network utilities for the generated code\n */\nfunction generateNetworkUtils(): string {\n\treturn `/**\n * API URLs for different networks\n */\nconst API_URLS: Record<'mainnet' | 'testnet' | 'devnet', string> = {\n mainnet: 'https://api.hiro.so',\n testnet: 'https://api.testnet.hiro.so',\n devnet: 'http://localhost:3999'\n};\n\n/**\n * Infer network from Stacks address prefix\n * SP/SM = mainnet, ST/SN = testnet\n */\nfunction inferNetworkFromAddress(address: string): 'mainnet' | 'testnet' | undefined {\n if (address.startsWith('SP') || address.startsWith('SM')) return 'mainnet';\n if (address.startsWith('ST') || address.startsWith('SN')) return 'testnet';\n return undefined;\n}\n\n/**\n * Get API URL, inferring network from contract address if not specified\n */\nfunction getApiUrl(\n contractAddress: string,\n explicitNetwork?: 'mainnet' | 'testnet' | 'devnet'\n): string {\n const network = explicitNetwork ?? inferNetworkFromAddress(contractAddress) ?? 'mainnet';\n return API_URLS[network];\n}`;\n}\n\n/**\n * Generate validation utilities that are inlined in generated code\n * This avoids requiring external dependencies beyond @secondlayer/stacks\n */\nfunction generateValidationUtils(): string {\n\treturn `/**\n * Contract name validation regex\n * Must start with letter, contain only letters, numbers, and hyphens, max 128 chars\n */\nconst CONTRACT_NAME_REGEX = /^[a-zA-Z][a-zA-Z0-9\\\\-]{0,127}$/;`;\n}\n\nexport async function generateContractInterface(\n\tcontracts: ResolvedContract[],\n): Promise<string> {\n\tconst imports = `import { Cl, validateStacksAddress } from '@secondlayer/stacks'`;\n\n\tconst header = `/**\n * Generated by @secondlayer/cli\n * DO NOT EDIT MANUALLY\n *\n * @requires @secondlayer/stacks - Install with: npm install @secondlayer/stacks\n */`;\n\n\tconst validationUtils = generateValidationUtils();\n\tconst networkUtils = generateNetworkUtils();\n\n\tconst contractsCode = contracts\n\t\t.map((contract) => generateContract(contract))\n\t\t.join(\"\\n\\n\");\n\n\tconst code = `${imports}\\n\\n${header}\\n\\n${validationUtils}\\n\\n${networkUtils}\\n\\n${contractsCode}`;\n\n\treturn formatCode(code);\n}\n\nfunction generateContract(contract: ResolvedContract): string {\n\tconst { name, address, contractName, abi } = contract;\n\n\tconst abiCode = generateAbiConstant(name, abi);\n\n\tconst methods = abi.functions\n\t\t.filter((func: AbiFunction) => func.access !== \"private\")\n\t\t.map((func: AbiFunction) => generateMethod(func, address, contractName))\n\t\t.join(\",\\n\\n \");\n\n\t// Generate maps object if contract has maps\n\tconst mapsObject = generateMapsObject(abi.maps || [], address, contractName);\n\n\t// Generate vars object if contract has variables (only data vars, not constants)\n\tconst varsObject = generateVarsObject(\n\t\tabi.variables || [],\n\t\taddress,\n\t\tcontractName,\n\t);\n\n\t// Generate constants object if contract has constants\n\tconst constantsObject = generateConstantsObject(\n\t\tabi.variables || [],\n\t\taddress,\n\t\tcontractName,\n\t);\n\n\t// Combine all members\n\tconst allMembers = [methods, mapsObject, varsObject, constantsObject].filter(\n\t\tBoolean,\n\t);\n\n\tconst contractCode = `export const ${name} = {\n address: '${address}',\n contractAddress: '${address}',\n contractName: '${contractName}',\n\n ${allMembers.join(\",\\n\\n \")}\n} as const`;\n\n\treturn `${abiCode}\\n\\n${contractCode}`;\n}\n\n// biome-ignore lint/suspicious/noExplicitAny: interop boundary or dynamic-shape value where typing adds friction without runtime safety\nfunction generateAbiConstant(name: string, abi: any): string {\n\tconst abiJson = JSON.stringify(abi, null, 2)\n\t\t.replace(/\"([a-zA-Z_$][a-zA-Z0-9_$]*)\":/g, \"$1:\") // Only remove quotes from valid JS identifiers\n\t\t.replace(/\"/g, \"'\"); // Use single quotes\n\n\treturn `export const ${name}Abi = ${abiJson} as const`;\n}\n\nfunction generateMethod(\n\tfunc: AbiFunction,\n\taddress: string,\n\tcontractName: string,\n): string {\n\tconst methodName = toCamelCase(func.name);\n\n\tif (func.args.length === 0) {\n\t\treturn `${methodName}() {\n return {\n contractAddress: '${address}',\n contractName: '${contractName}',\n functionName: '${func.name}',\n functionArgs: []\n }\n }`;\n\t}\n\n\tif (func.args.length === 1) {\n\t\tconst originalArgName = func.args[0].name;\n\t\tconst argName = toCamelCase(originalArgName);\n\t\tconst argType = getTypeForArg(func.args[0]);\n\t\tconst clarityConversion = generateClarityConversion(argName, func.args[0]);\n\n\t\treturn `${methodName}(...args: [{ ${argName}: ${argType} }] | [${argType}]) {\n const ${argName} = args.length === 1 && typeof args[0] === 'object' && args[0] !== null && '${argName}' in args[0]\n ? args[0].${argName}\n : args[0] as ${argType}\n \n return {\n contractAddress: '${address}',\n contractName: '${contractName}',\n functionName: '${func.name}',\n functionArgs: [${clarityConversion}]\n }\n }`;\n\t}\n\n\t// biome-ignore lint/suspicious/noExplicitAny: interop boundary or dynamic-shape value where typing adds friction without runtime safety\n\ttype Arg = { name: string; type: any };\n\tconst argsList = func.args\n\t\t.map((arg: Arg) => toCamelCase(arg.name))\n\t\t.join(\", \");\n\tconst argsTypes = func.args\n\t\t.map((arg: Arg) => {\n\t\t\tconst camelName = toCamelCase(arg.name);\n\t\t\treturn `${camelName}: ${getTypeForArg(arg)}`;\n\t\t})\n\t\t.join(\"; \");\n\tconst argsArray = func.args\n\t\t.map((arg: Arg) => {\n\t\t\tconst argName = toCamelCase(arg.name);\n\t\t\treturn generateClarityConversion(argName, arg);\n\t\t})\n\t\t.join(\", \");\n\tconst objectAccess = func.args\n\t\t.map((arg: Arg) => {\n\t\t\tconst camelName = toCamelCase(arg.name);\n\t\t\treturn `args[0].${camelName}`;\n\t\t})\n\t\t.join(\", \");\n\tconst positionTypes = func.args\n\t\t.map((arg: Arg) => getTypeForArg(arg))\n\t\t.join(\", \");\n\n\treturn `${methodName}(...args: [{ ${argsTypes} }] | [${positionTypes}]) {\n const [${argsList}] = args.length === 1 && typeof args[0] === 'object' && args[0] !== null\n ? [${objectAccess}]\n : args as [${positionTypes}]\n \n return {\n contractAddress: '${address}',\n contractName: '${contractName}',\n functionName: '${func.name}',\n functionArgs: [${argsArray}]\n }\n }`;\n}\n\n/**\n * Generate maps object with type-safe accessors for contract data maps\n */\nfunction generateMapsObject(\n\tmaps: readonly AbiMap[],\n\taddress: string,\n\tcontractName: string,\n): string {\n\tif (!maps || maps.length === 0) {\n\t\treturn \"\";\n\t}\n\n\tconst mapMethods = maps.map((map) => {\n\t\tconst methodName = toCamelCase(map.name);\n\t\tconst keyType = getTypeForArg({ type: map.key });\n\t\tconst valueType = getTypeForArg({ type: map.value });\n\t\tconst keyConversion = generateMapKeyConversion(map.key);\n\n\t\treturn `${methodName}: {\n async get(key: ${keyType}, options?: { network?: 'mainnet' | 'testnet' | 'devnet' }): Promise<${valueType} | null> {\n try {\n const { cvToJSON, serializeCV } = await import('@secondlayer/stacks/clarity');\n const baseUrl = getApiUrl('${address}', options?.network);\n const mapKey = ${keyConversion};\n const keyHex = serializeCV(mapKey).toString('hex');\n\n const response = await fetch(\n \\`\\${baseUrl}/v2/map_entry/${address}/${contractName}/${map.name}\\`,\n {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(keyHex)\n }\n );\n\n if (!response.ok) {\n throw new Error(\\`HTTP \\${response.status}: \\${response.statusText}\\`);\n }\n\n const result = await response.json();\n if (!result.data || result.data === '0x09') {\n return null; // none value\n }\n\n const { deserializeCV } = await import('@secondlayer/stacks/clarity');\n const cv = deserializeCV(result.data);\n const parsed = cvToJSON(cv);\n // Unwrap the (some ...) wrapper\n return parsed.value?.value ?? parsed.value ?? null;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\\`Map access failed for '${map.name}': \\${error.message}\\`);\n }\n throw error;\n }\n },\n keyType: ${JSON.stringify(map.key)} as const,\n valueType: ${JSON.stringify(map.value)} as const\n }`;\n\t});\n\n\treturn `maps: {\n ${mapMethods.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate vars object with type-safe accessors for contract data variables\n */\nfunction generateVarsObject(\n\tvariables: readonly AbiVariable[],\n\taddress: string,\n\tcontractName: string,\n): string {\n\tif (!variables || variables.length === 0) {\n\t\treturn \"\";\n\t}\n\n\t// Filter to only include mutable data variables (not constants)\n\tconst dataVars = variables.filter((v) => v.access === \"variable\");\n\n\tif (dataVars.length === 0) {\n\t\treturn \"\";\n\t}\n\n\tconst varMethods = dataVars.map((variable) => {\n\t\tconst methodName = toCamelCase(variable.name);\n\t\tconst valueType = getTypeForArg({ type: variable.type });\n\n\t\treturn `${methodName}: {\n async get(options?: { network?: 'mainnet' | 'testnet' | 'devnet' }): Promise<${valueType}> {\n try {\n const { cvToJSON, deserializeCV } = await import('@secondlayer/stacks/clarity');\n const baseUrl = getApiUrl('${address}', options?.network);\n\n const response = await fetch(\n \\`\\${baseUrl}/v2/data_var/${address}/${contractName}/${variable.name}?proof=0\\`\n );\n\n if (!response.ok) {\n throw new Error(\\`HTTP \\${response.status}: \\${response.statusText}\\`);\n }\n\n const result = await response.json();\n const cv = deserializeCV(result.data);\n const parsed = cvToJSON(cv);\n return parsed.value ?? parsed;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\\`Variable access failed for '${variable.name}': \\${error.message}\\`);\n }\n throw error;\n }\n },\n type: ${JSON.stringify(variable.type)} as const\n }`;\n\t});\n\n\treturn `vars: {\n ${varMethods.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate constants object with type-safe accessors for contract constants\n */\nfunction generateConstantsObject(\n\tvariables: readonly AbiVariable[],\n\taddress: string,\n\tcontractName: string,\n): string {\n\tif (!variables || variables.length === 0) {\n\t\treturn \"\";\n\t}\n\n\t// Filter to only include constants\n\tconst constants = variables.filter((v) => v.access === \"constant\");\n\n\tif (constants.length === 0) {\n\t\treturn \"\";\n\t}\n\n\tconst constMethods = constants.map((constant) => {\n\t\tconst methodName = toCamelCase(constant.name);\n\t\tconst valueType = getTypeForArg({ type: constant.type });\n\n\t\treturn `${methodName}: {\n async get(options?: { network?: 'mainnet' | 'testnet' | 'devnet' }): Promise<${valueType}> {\n try {\n const { cvToJSON, deserializeCV } = await import('@secondlayer/stacks/clarity');\n const baseUrl = getApiUrl('${address}', options?.network);\n\n const response = await fetch(\n \\`\\${baseUrl}/v2/constant_val/${address}/${contractName}/${constant.name}?proof=0\\`\n );\n\n if (!response.ok) {\n throw new Error(\\`HTTP \\${response.status}: \\${response.statusText}\\`);\n }\n\n const result = await response.json();\n const cv = deserializeCV(result.data);\n const parsed = cvToJSON(cv);\n return parsed.value ?? parsed;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\\`Constant access failed for '${constant.name}': \\${error.message}\\`);\n }\n throw error;\n }\n },\n type: ${JSON.stringify(constant.type)} as const\n }`;\n\t});\n\n\treturn `constants: {\n ${constMethods.join(\",\\n\\n \")}\n }`;\n}\n",
13
13
  "/**\n * ABI compatibility layer for normalizing different ABI formats\n *\n * Handles differences between:\n * - Upstream ClarityAbi types (uses `buffer`, `read_only`)\n * - Internal format (uses `buff`, `read-only`)\n */\n\nimport type {\n\tAbiContract,\n\tAbiFunction,\n\tAbiMap,\n\tAbiType,\n\tAbiVariable,\n} from \"@secondlayer/stacks/clarity\";\n\n/**\n * Normalize function access type from various formats to internal format\n */\nexport function normalizeAccess(\n\taccess: string,\n): \"public\" | \"read-only\" | \"private\" {\n\tif (access === \"read_only\") return \"read-only\";\n\treturn access as \"public\" | \"read-only\" | \"private\";\n}\n\n/**\n * Normalize a Clarity type from API format to internal format\n * Handles buffer vs buff, and recursively normalizes nested types\n */\nexport function normalizeType(type: unknown): AbiType {\n\tif (typeof type === \"string\") {\n\t\t// Handle string primitive types\n\t\tswitch (type) {\n\t\t\tcase \"uint128\":\n\t\t\tcase \"int128\":\n\t\t\tcase \"bool\":\n\t\t\tcase \"principal\":\n\t\t\tcase \"trait_reference\":\n\t\t\t\treturn type;\n\t\t\tdefault:\n\t\t\t\t// Unknown string type, return as-is\n\t\t\t\treturn type as AbiType;\n\t\t}\n\t}\n\n\tif (typeof type !== \"object\" || type === null) {\n\t\tthrow new Error(`Invalid ABI type: expected object, got ${typeof type}`);\n\t}\n\n\tconst typeObj = type as Record<string, unknown>;\n\n\t// Handle buffer vs buff (API uses buffer, we use buff)\n\tif (\"buffer\" in typeObj) {\n\t\tconst buffer = typeObj.buffer as { length?: number };\n\t\treturn {\n\t\t\tbuff: {\n\t\t\t\tlength: buffer?.length ?? 32,\n\t\t\t},\n\t\t};\n\t}\n\n\t// Already in internal format\n\tif (\"buff\" in typeObj) {\n\t\tconst buff = typeObj.buff as { length?: number };\n\t\treturn {\n\t\t\tbuff: {\n\t\t\t\tlength: buff?.length ?? 32,\n\t\t\t},\n\t\t};\n\t}\n\n\t// String types\n\tif (\"string-ascii\" in typeObj) {\n\t\tconst strAscii = typeObj[\"string-ascii\"] as { length?: number };\n\t\treturn {\n\t\t\t\"string-ascii\": {\n\t\t\t\tlength: strAscii?.length ?? 256,\n\t\t\t},\n\t\t};\n\t}\n\n\tif (\"string-utf8\" in typeObj) {\n\t\tconst strUtf8 = typeObj[\"string-utf8\"] as { length?: number };\n\t\treturn {\n\t\t\t\"string-utf8\": {\n\t\t\t\tlength: strUtf8?.length ?? 256,\n\t\t\t},\n\t\t};\n\t}\n\n\t// Response type - recursively normalize ok and error types\n\tif (\"response\" in typeObj) {\n\t\tconst response = typeObj.response as { ok?: unknown; error?: unknown };\n\t\treturn {\n\t\t\tresponse: {\n\t\t\t\tok: normalizeType(response?.ok ?? \"bool\"),\n\t\t\t\terror: normalizeType(response?.error ?? \"uint128\"),\n\t\t\t},\n\t\t};\n\t}\n\n\t// Optional type - recursively normalize inner type\n\tif (\"optional\" in typeObj) {\n\t\treturn {\n\t\t\toptional: normalizeType(typeObj.optional),\n\t\t};\n\t}\n\n\t// List type - recursively normalize element type\n\tif (\"list\" in typeObj) {\n\t\tconst list = typeObj.list as { type?: unknown; length?: number };\n\t\treturn {\n\t\t\tlist: {\n\t\t\t\ttype: normalizeType(list?.type ?? \"uint128\"),\n\t\t\t\tlength: list?.length ?? 100,\n\t\t\t},\n\t\t};\n\t}\n\n\t// Tuple type - recursively normalize field types\n\tif (\"tuple\" in typeObj) {\n\t\tconst tuple = typeObj.tuple as Array<{ name: string; type: unknown }>;\n\t\treturn {\n\t\t\ttuple: tuple.map((field) => ({\n\t\t\t\tname: field.name,\n\t\t\t\ttype: normalizeType(field.type),\n\t\t\t})),\n\t\t};\n\t}\n\n\t// Unknown type - fail explicitly\n\tthrow new Error(`Unknown ABI type structure: ${JSON.stringify(type)}`);\n}\n\n/**\n * Normalize a function definition from API format to internal format\n */\nexport function normalizeFunction(func: Record<string, unknown>): AbiFunction {\n\tconst access = normalizeAccess(func.access as string);\n\tconst args = (func.args as Array<{ name: string; type: unknown }>) ?? [];\n\tconst outputs = func.outputs as { type?: unknown } | unknown;\n\n\treturn {\n\t\tname: func.name as string,\n\t\taccess,\n\t\targs: args.map((arg) => ({\n\t\t\tname: arg.name,\n\t\t\ttype: normalizeType(arg.type),\n\t\t})),\n\t\toutputs: normalizeType(\n\t\t\ttypeof outputs === \"object\" && outputs !== null && \"type\" in outputs\n\t\t\t\t? (outputs as { type: unknown }).type\n\t\t\t\t: outputs,\n\t\t),\n\t};\n}\n\n/**\n * Normalize a map definition from API format to internal format\n */\nexport function normalizeMap(map: Record<string, unknown>): AbiMap {\n\treturn {\n\t\tname: map.name as string,\n\t\tkey: normalizeType(map.key),\n\t\tvalue: normalizeType(map.value),\n\t};\n}\n\n/**\n * Normalize a variable definition from API format to internal format\n */\nexport function normalizeVariable(\n\tvariable: Record<string, unknown>,\n): AbiVariable {\n\treturn {\n\t\tname: variable.name as string,\n\t\ttype: normalizeType(variable.type),\n\t\taccess: variable.access as \"constant\" | \"variable\",\n\t};\n}\n\n/**\n * Normalize an entire ABI from various sources to consistent internal format\n *\n * This handles ABIs from:\n * - Hiro API responses\n * - Clarinet SDK\n * - Upstream @secondlayer/stacks types\n */\nexport function normalizeAbi(abi: unknown): AbiContract {\n\tif (typeof abi !== \"object\" || abi === null) {\n\t\treturn { functions: [] };\n\t}\n\n\tconst abiObj = abi as Record<string, unknown>;\n\n\tconst functions: AbiFunction[] = [];\n\tconst maps: AbiMap[] = [];\n\tconst variables: AbiVariable[] = [];\n\n\t// Normalize functions\n\tif (Array.isArray(abiObj.functions)) {\n\t\tfor (const func of abiObj.functions) {\n\t\t\tif (typeof func === \"object\" && func !== null) {\n\t\t\t\tfunctions.push(normalizeFunction(func as Record<string, unknown>));\n\t\t\t}\n\t\t}\n\t}\n\n\t// Normalize maps\n\tif (Array.isArray(abiObj.maps)) {\n\t\tfor (const map of abiObj.maps) {\n\t\t\tif (typeof map === \"object\" && map !== null) {\n\t\t\t\tmaps.push(normalizeMap(map as Record<string, unknown>));\n\t\t\t}\n\t\t}\n\t}\n\n\t// Normalize variables\n\tif (Array.isArray(abiObj.variables)) {\n\t\tfor (const variable of abiObj.variables) {\n\t\t\tif (typeof variable === \"object\" && variable !== null) {\n\t\t\t\tvariables.push(normalizeVariable(variable as Record<string, unknown>));\n\t\t\t}\n\t\t}\n\t}\n\n\treturn {\n\t\tfunctions,\n\t\tmaps: maps.length > 0 ? maps : undefined,\n\t\tvariables: variables.length > 0 ? variables : undefined,\n\t};\n}\n",
14
- "/**\n * Plugin exports for @secondlayer/cli\n * This will be expanded as plugins are implemented\n */\n\nimport type { SecondLayerPlugin } from \"../types/plugin\";\n\n// Re-export plugin types for convenience\nexport type {\n\tSecondLayerPlugin,\n\tPluginFactory,\n\tPluginOptions,\n\tGenerateContext,\n\tPluginContext,\n\tLogger,\n\tPluginUtils,\n} from \"../types/plugin\";\n\n// Plugin utilities\nexport { PluginManager } from \"../core/plugin-manager\";\n\n// Base plugin options interface\nexport interface BasePluginOptions {\n\t/** Include only specific contracts/functions */\n\tinclude?: string[];\n\n\t/** Exclude specific contracts/functions */\n\texclude?: string[];\n\n\t/** Enable debug output */\n\tdebug?: boolean;\n}\n\n/**\n * Utility function to filter contracts/functions based on include/exclude options\n */\nexport function filterByOptions<T extends { name: string }>(\n\titems: T[],\n\toptions: BasePluginOptions = {},\n): T[] {\n\tlet filtered = items;\n\n\tif (options.include && options.include.length > 0) {\n\t\tfiltered = filtered.filter((item) =>\n\t\t\toptions.include!.some(\n\t\t\t\t(pattern) =>\n\t\t\t\t\titem.name.includes(pattern) || item.name.match(new RegExp(pattern)),\n\t\t\t),\n\t\t);\n\t}\n\n\tif (options.exclude && options.exclude.length > 0) {\n\t\tfiltered = filtered.filter(\n\t\t\t(item) =>\n\t\t\t\t!options.exclude!.some(\n\t\t\t\t\t(pattern) =>\n\t\t\t\t\t\titem.name.includes(pattern) || item.name.match(new RegExp(pattern)),\n\t\t\t\t),\n\t\t);\n\t}\n\n\treturn filtered;\n}\n\n/**\n * Utility function to create a simple plugin\n */\nexport function createPlugin(\n\tname: string,\n\tversion: string,\n\timplementation: Partial<SecondLayerPlugin>,\n): SecondLayerPlugin {\n\treturn {\n\t\tname,\n\t\tversion,\n\t\t...implementation,\n\t};\n}\n\n// Plugin exports\nexport { clarinet, hasClarinetProject } from \"./clarinet/index\";\nexport type { ClarinetPluginOptions } from \"./clarinet/index\";\n\nexport { actions } from \"./actions/index\";\nexport type { ActionsPluginOptions } from \"./actions/index\";\n\nexport { react } from \"./react/index\";\nexport type { ReactPluginOptions } from \"./react/index\";\n\nexport { testing } from \"./testing/index\";\nexport type { TestingPluginOptions } from \"./testing/index\";\n",
15
- "/**\n * Clarinet Plugin for @secondlayer/cli\n * Generates type-safe contract interfaces from local Clarity contracts using Clarinet SDK\n */\n\nimport { initSimnet } from \"@hirosystems/clarinet-sdk\";\nimport { toCamelCase } from \"@secondlayer/stacks/clarity\";\nimport { generateContractInterface } from \"../../generators/contract\";\nimport type {\n\tGenerateContext,\n\tPluginFactory,\n\tUserConfig,\n} from \"../../types/plugin\";\nimport { normalizeAbi } from \"../../utils/abi-compat\";\nimport { parseContractId } from \"../../utils/contract-id\";\n\nexport interface ClarinetPluginOptions {\n\t/** Path to Clarinet.toml file */\n\tpath?: string;\n\n\t/** Include only specific contracts */\n\tinclude?: string[];\n\n\t/** Exclude specific contracts */\n\texclude?: string[];\n\n\t/** Enable debug output */\n\tdebug?: boolean;\n}\n\n/**\n * Sanitize contract name to be a valid JavaScript identifier using camelCase\n */\nfunction sanitizeContractName(name: string): string {\n\treturn toCamelCase(name);\n}\n\n/**\n * Check if a contract is a user-defined contract (not a system contract)\n */\nasync function isUserDefinedContract(\n\tcontractId: string,\n\tmanifestPath: string,\n): Promise<boolean> {\n\tconst { address, contractName } = parseContractId(contractId);\n\n\ttry {\n\t\t// Read Clarinet.toml to get user-defined contracts\n\t\tconst { promises: fs } = await import(\"fs\");\n\t\tconst tomlContent = await fs.readFile(manifestPath, \"utf-8\");\n\n\t\t// Simple TOML parsing to find [contracts.CONTRACT_NAME] sections\n\t\tconst contractSectionRegex = /^\\[contracts\\.([^\\]]+)\\]/gm;\n\t\tconst userContracts = new Set<string>();\n\n\t\tlet match;\n\t\twhile ((match = contractSectionRegex.exec(tomlContent)) !== null) {\n\t\t\tuserContracts.add(match[1]);\n\t\t}\n\n\t\t// If the contract is explicitly defined in Clarinet.toml, it's user-defined\n\t\tif (userContracts.has(contractName)) {\n\t\t\treturn true;\n\t\t}\n\t} catch (error) {\n\t\t// If we can't read the TOML file, fall back to pattern matching\n\t}\n\n\t// Fallback: System contracts typically have specific addresses or are in the boot contracts\n\t// Common system contract patterns:\n\tconst systemContractPatterns = [\n\t\t/^pox-\\d+$/, // pox-2, pox-3, etc.\n\t\t/^bns$/, // Blockchain Name System\n\t\t/^costs-\\d+$/, // costs-2, costs-3, etc.\n\t\t/^lockup$/, // lockup contract\n\t];\n\n\t// Check if it matches any system contract pattern\n\tif (systemContractPatterns.some((pattern) => pattern.test(contractName))) {\n\t\treturn false;\n\t}\n\n\t// System contracts often use specific addresses\n\tconst systemAddresses = [\n\t\t\"SP000000000000000000002Q6VF78\", // Boot contracts address\n\t\t\"ST000000000000000000002AMW42H\", // Boot contracts address (testnet)\n\t];\n\n\tif (systemAddresses.includes(address)) {\n\t\treturn false;\n\t}\n\n\treturn true;\n}\n\n/**\n * Clarinet plugin factory\n */\nexport const clarinet: PluginFactory<ClarinetPluginOptions> = (\n\toptions = {},\n) => {\n\tconst manifestPath = options.path || \"./Clarinet.toml\";\n\tlet simnet: any;\n\n\treturn {\n\t\tname: \"@secondlayer/cli/plugin-clarinet\",\n\t\tversion: \"1.0.0\",\n\n\t\tasync transformConfig(config: UserConfig): Promise<UserConfig> {\n\t\t\ttry {\n\t\t\t\t// Initialize simnet to extract contract ABIs\n\t\t\t\tsimnet = await initSimnet(manifestPath);\n\n\t\t\t\t// Get contract interfaces from Clarinet\n\t\t\t\tconst contractInterfaces = simnet.getContractsInterfaces();\n\t\t\t\tconst contracts = [];\n\n\t\t\t\tfor (const [contractId, abi] of contractInterfaces) {\n\t\t\t\t\tconst { contractName } = parseContractId(contractId);\n\n\t\t\t\t\t// Skip system contracts\n\t\t\t\t\tif (!(await isUserDefinedContract(contractId, manifestPath))) {\n\t\t\t\t\t\tif (options.debug) {\n\t\t\t\t\t\t\tconsole.log(`🚫 Skipping system contract: ${contractId}`);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Apply user filters\n\t\t\t\t\tif (options.include && !options.include.includes(contractName)) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\t\t\t\t\tif (options.exclude && options.exclude.includes(contractName)) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Sanitize the contract name for JavaScript export\n\t\t\t\t\tconst sanitizedName = sanitizeContractName(contractName);\n\n\t\t\t\t\t// Don't set source field to avoid conflict with file resolution\n\t\t\t\t\t// Instead, we'll track this in metadata during processing\n\t\t\t\t\tcontracts.push({\n\t\t\t\t\t\tname: sanitizedName,\n\t\t\t\t\t\taddress: contractId,\n\t\t\t\t\t\tabi: normalizeAbi(abi),\n\t\t\t\t\t\t// Remove source field - this was causing the path resolution issue\n\t\t\t\t\t\t_clarinetSource: true, // Internal flag for our plugin\n\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\tif (options.debug) {\n\t\t\t\t\tconsole.log(\n\t\t\t\t\t\t`🔍 Clarinet plugin found ${contracts.length} user-defined contracts`,\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\treturn {\n\t\t\t\t\t...config,\n\t\t\t\t\tcontracts: [...(config.contracts || []), ...contracts],\n\t\t\t\t};\n\t\t\t} catch (error) {\n\t\t\t\tconst err = error as Error;\n\t\t\t\tif (options.debug) {\n\t\t\t\t\tconsole.warn(\n\t\t\t\t\t\t`⚠️ Clarinet plugin failed to load contracts: ${err.message}`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\t// If Clarinet.toml doesn't exist or fails, just return config unchanged\n\t\t\t\treturn config;\n\t\t\t}\n\t\t},\n\n\t\tasync generate(context: GenerateContext): Promise<void> {\n\t\t\t// Filter contracts that came from Clarinet\n\t\t\tconst clarinetContracts = context.contracts.filter(\n\t\t\t\t(contract) => contract.metadata?.source === \"clarinet\",\n\t\t\t);\n\n\t\t\tif (clarinetContracts.length === 0) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (options.debug) {\n\t\t\t\tcontext.logger.debug(\n\t\t\t\t\t`Generating interfaces for ${clarinetContracts.length} Clarinet contracts`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\t// Generate the main contracts file using existing generator\n\t\t\tconst contractsCode = await generateContractInterface(clarinetContracts);\n\n\t\t\tcontext.addOutput(\"contracts\", {\n\t\t\t\tpath: context.config.out,\n\t\t\t\tcontent: contractsCode,\n\t\t\t\ttype: \"contracts\",\n\t\t\t});\n\n\t\t\t// Don't log success here - let the main command handle it\n\t\t},\n\t};\n};\n\n/**\n * Utility function to check if a Clarinet project exists\n */\nexport async function hasClarinetProject(\n\tpath = \"./Clarinet.toml\",\n): Promise<boolean> {\n\ttry {\n\t\tconst { promises: fs } = await import(\"fs\");\n\t\tawait fs.access(path);\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n}\n",
16
- "/**\n * Action generators for read and write helper functions\n */\n\nimport { type AbiFunction, toCamelCase } from \"@secondlayer/stacks/clarity\";\nimport type { ProcessedContract } from \"../../types/plugin\";\nimport {\n\tgenerateArgsSignature,\n\tgenerateClarityArgs,\n} from \"../../utils/generator-helpers\";\nimport type { ActionsPluginOptions } from \"./index\";\n\n/**\n * Generate read helper functions for a contract (fixed version)\n */\nfunction generateReadHelpers(\n\tcontract: ProcessedContract,\n\toptions: ActionsPluginOptions,\n): string {\n\tconst { abi } = contract;\n\tconst functions = abi.functions || [];\n\n\tconst readOnlyFunctions = functions.filter(\n\t\t(f: AbiFunction) => f.access === \"read-only\",\n\t);\n\n\tif (readOnlyFunctions.length === 0) {\n\t\treturn \"\";\n\t}\n\n\t// Apply function filters\n\tconst filteredFunctions = readOnlyFunctions.filter((func: AbiFunction) => {\n\t\tif (\n\t\t\toptions.includeFunctions &&\n\t\t\t!options.includeFunctions.includes(func.name)\n\t\t) {\n\t\t\treturn false;\n\t\t}\n\t\tif (\n\t\t\toptions.excludeFunctions &&\n\t\t\toptions.excludeFunctions.includes(func.name)\n\t\t) {\n\t\t\treturn false;\n\t\t}\n\t\treturn true;\n\t});\n\n\tif (filteredFunctions.length === 0) {\n\t\treturn \"\";\n\t}\n\n\tconst helpers = filteredFunctions.map((func: AbiFunction) => {\n\t\tconst methodName = toCamelCase(func.name);\n\t\tconst argsSignature = generateArgsSignature(func.args);\n\t\tconst clarityArgs = generateClarityArgs(func.args);\n\n\t\treturn `async ${methodName}(${argsSignature}options?: {\n network?: 'mainnet' | 'testnet' | 'devnet';\n senderAddress?: string;\n }) {\n return await fetchCallReadOnlyFunction({\n contractAddress: '${contract.address}',\n contractName: '${contract.contractName}',\n functionName: '${func.name}',\n functionArgs: [${clarityArgs}],\n network: options?.network ?? inferNetworkFromAddress('${contract.address}') ?? 'mainnet',\n senderAddress: options?.senderAddress || 'SP000000000000000000002Q6VF78'\n });\n }`;\n\t});\n\n\treturn `read: {\n ${helpers.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate write helper functions for a contract (fixed version)\n */\nfunction generateWriteHelpers(\n\tcontract: ProcessedContract,\n\toptions: ActionsPluginOptions,\n): string {\n\tconst { abi } = contract;\n\tconst functions = abi.functions || [];\n\tconst envVarName = options.senderKeyEnv ?? \"STX_SENDER_KEY\";\n\n\tconst publicFunctions = functions.filter(\n\t\t(f: AbiFunction) => f.access === \"public\",\n\t);\n\n\tif (publicFunctions.length === 0) {\n\t\treturn \"\";\n\t}\n\n\t// Apply function filters\n\tconst filteredFunctions = publicFunctions.filter((func: AbiFunction) => {\n\t\tif (\n\t\t\toptions.includeFunctions &&\n\t\t\t!options.includeFunctions.includes(func.name)\n\t\t) {\n\t\t\treturn false;\n\t\t}\n\t\tif (\n\t\t\toptions.excludeFunctions &&\n\t\t\toptions.excludeFunctions.includes(func.name)\n\t\t) {\n\t\t\treturn false;\n\t\t}\n\t\treturn true;\n\t});\n\n\tif (filteredFunctions.length === 0) {\n\t\treturn \"\";\n\t}\n\n\tconst helpers = filteredFunctions.map((func: AbiFunction) => {\n\t\tconst methodName = toCamelCase(func.name);\n\t\tconst argsSignature = generateArgsSignature(func.args);\n\t\tconst clarityArgs = generateClarityArgs(func.args);\n\n\t\treturn `async ${methodName}(${argsSignature}senderKey?: string, options?: {\n network?: 'mainnet' | 'testnet' | 'devnet';\n fee?: string | number | undefined;\n nonce?: bigint;\n anchorMode?: 1 | 2 | 3; // AnchorMode: OnChainOnly = 1, OffChainOnly = 2, Any = 3\n postConditions?: PostCondition[];\n validateWithAbi?: boolean;\n }) {\n const resolvedSenderKey = senderKey ?? process.env.${envVarName};\n if (!resolvedSenderKey) {\n throw new Error('senderKey required: pass as argument or set ${envVarName} env var');\n }\n const { network = 'mainnet', ...txOptions } = options ?? {};\n\n return await makeContractCall({\n contractAddress: '${contract.address}',\n contractName: '${contract.contractName}',\n functionName: '${func.name}',\n functionArgs: [${clarityArgs}],\n senderKey: resolvedSenderKey,\n network,\n validateWithAbi: true,\n ...txOptions\n });\n }`;\n\t});\n\n\treturn `write: {\n ${helpers.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate action helpers (read and write functions) for a contract\n */\nexport async function generateActionHelpers(\n\tcontract: ProcessedContract,\n\toptions: ActionsPluginOptions,\n): Promise<string> {\n\tconst readHelpers = generateReadHelpers(contract, options);\n\tconst writeHelpers = generateWriteHelpers(contract, options);\n\n\tif (!readHelpers && !writeHelpers) {\n\t\treturn \"\";\n\t}\n\n\tconst helpers = [readHelpers, writeHelpers].filter(Boolean);\n\treturn helpers.join(\",\\n\\n\");\n}\n",
17
- "/**\n * Actions Plugin for @secondlayer/cli\n * Generates read and write helper functions for direct blockchain interaction\n */\n\nimport type {\n\t// UserConfig,\n\tGenerateContext,\n\tPluginFactory,\n} from \"../../types/plugin\";\nimport { generateActionHelpers } from \"./generators\";\n\nexport interface ActionsPluginOptions {\n\t/** Include only specific contracts */\n\tinclude?: string[];\n\n\t/** Exclude specific contracts */\n\texclude?: string[];\n\n\t/** Include only specific functions */\n\tincludeFunctions?: string[];\n\n\t/** Exclude specific functions */\n\texcludeFunctions?: string[];\n\n\t/** Enable debug output */\n\tdebug?: boolean;\n\n\t/** Environment variable name for default sender key (default: \"STX_SENDER_KEY\") */\n\tsenderKeyEnv?: string;\n}\n\n/**\n * Actions plugin factory\n */\nexport const actions: PluginFactory<ActionsPluginOptions> = (options = {}) => {\n\treturn {\n\t\tname: \"@secondlayer/cli/plugin-actions\",\n\t\tversion: \"1.0.0\",\n\n\t\tasync generate(context: GenerateContext): Promise<void> {\n\t\t\tconst { contracts } = context;\n\n\t\t\t// Filter contracts based on options\n\t\t\tconst filteredContracts = contracts.filter((contract) => {\n\t\t\t\tif (options.include && !options.include.includes(contract.name)) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\tif (options.exclude && options.exclude.includes(contract.name)) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\treturn true;\n\t\t\t});\n\n\t\t\tif (filteredContracts.length === 0) {\n\t\t\t\tif (options.debug) {\n\t\t\t\t\tcontext.logger.debug(\"Actions plugin: No contracts to process\");\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (options.debug) {\n\t\t\t\tcontext.logger.debug(\n\t\t\t\t\t`Actions plugin: Generating read/write helpers for ${filteredContracts.length} contracts`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\t// Collect all helpers for all contracts\n\t\t\tconst contractHelpers = new Map<string, string>();\n\n\t\t\tfor (const contract of filteredContracts) {\n\t\t\t\tconst actionsCode = await generateActionHelpers(contract, options);\n\t\t\t\tif (actionsCode) {\n\t\t\t\t\tcontractHelpers.set(contract.name, actionsCode);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Inject all helpers into the output\n\t\t\tif (contractHelpers.size > 0) {\n\t\t\t\tconst existingOutput = context.outputs.get(\"contracts\");\n\t\t\t\tif (existingOutput) {\n\t\t\t\t\tlet modifiedContent = addRequiredImports(existingOutput.content);\n\n\t\t\t\t\t// Inject helpers for each contract\n\t\t\t\t\tfor (const [contractName, helpersCode] of contractHelpers) {\n\t\t\t\t\t\tmodifiedContent = injectHelpersIntoContract(\n\t\t\t\t\t\t\tmodifiedContent,\n\t\t\t\t\t\t\tcontractName,\n\t\t\t\t\t\t\thelpersCode,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\tcontext.outputs.set(\"contracts\", {\n\t\t\t\t\t\t...existingOutput,\n\t\t\t\t\t\tcontent: modifiedContent,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t};\n};\n\n/**\n * Add required imports for fetchCallReadOnlyFunction, makeContractCall, and PostCondition\n */\nfunction addRequiredImports(content: string): string {\n\t// Find the existing @secondlayer/stacks import line\n\tconst stacksImportRegex =\n\t\t/import\\s+\\{([^}]+)\\}\\s+from\\s+['\"]@secondlayer\\/stacks['\"];/;\n\tconst match = content.match(stacksImportRegex);\n\n\tif (match) {\n\t\tlet updatedContent = content;\n\n\t\t// Add fetchCallReadOnlyFunction and makeContractCall from @secondlayer/stacks/clarity\n\t\tif (!updatedContent.includes(\"fetchCallReadOnlyFunction\")) {\n\t\t\tupdatedContent = updatedContent.replace(\n\t\t\t\tstacksImportRegex,\n\t\t\t\t`${match[0]}\\nimport { fetchCallReadOnlyFunction, makeContractCall } from '@secondlayer/stacks/clarity';`,\n\t\t\t);\n\t\t}\n\n\t\t// Add type import for PostCondition if not present\n\t\tif (!updatedContent.includes(\"type PostCondition\")) {\n\t\t\tupdatedContent = updatedContent.replace(\n\t\t\t\tstacksImportRegex,\n\t\t\t\t`${match[0]}\\nimport type { PostCondition } from '@secondlayer/stacks';`,\n\t\t\t);\n\t\t}\n\n\t\treturn updatedContent;\n\t}\n\n\treturn content;\n}\n\n/**\n * Inject read/write helpers into a specific contract object in the output\n */\nfunction injectHelpersIntoContract(\n\tcontent: string,\n\tcontractName: string,\n\thelpersCode: string,\n): string {\n\t// Use a more precise regex to find the entire contract object\n\tconst contractPattern = new RegExp(\n\t\t`(export const ${contractName} = \\\\{[\\\\s\\\\S]*?)\\\\n\\\\} as const;`,\n\t\t\"g\",\n\t);\n\n\treturn content.replace(contractPattern, (_, contractBody) => {\n\t\t// Remove any trailing comma and whitespace from the contract body\n\t\tconst cleanBody = contractBody.replace(/,\\s*$/, \"\");\n\n\t\t// Add proper indentation to lines that start top-level properties\n\t\tconst indentedHelpersCode = helpersCode\n\t\t\t.split(\"\\n\")\n\t\t\t.map((line) => {\n\t\t\t\t// Only add indentation to lines that start with a property name (like \"write:\")\n\t\t\t\tif (line.match(/^[a-zA-Z_$][a-zA-Z0-9_$]*\\s*:/)) {\n\t\t\t\t\treturn ` ${line}`;\n\t\t\t\t}\n\t\t\t\treturn line;\n\t\t\t})\n\t\t\t.join(\"\\n\");\n\n\t\t// Add the helpers with proper formatting\n\t\treturn `${cleanBody},\n\n${indentedHelpersCode}\n} as const;`;\n\t});\n}\n",
14
+ "/**\n * Plugin exports for @secondlayer/cli\n * This will be expanded as plugins are implemented\n */\n\nimport type { SecondLayerPlugin } from \"../types/plugin\";\n\n// Re-export plugin types for convenience\nexport type {\n\tSecondLayerPlugin,\n\tPluginFactory,\n\tPluginOptions,\n\tGenerateContext,\n\tPluginContext,\n\tLogger,\n\tPluginUtils,\n} from \"../types/plugin\";\n\n// Plugin utilities\nexport { PluginManager } from \"../core/plugin-manager\";\n\n// Base plugin options interface\nexport interface BasePluginOptions {\n\t/** Include only specific contracts/functions */\n\tinclude?: string[];\n\n\t/** Exclude specific contracts/functions */\n\texclude?: string[];\n\n\t/** Enable debug output */\n\tdebug?: boolean;\n}\n\n/**\n * Utility function to filter contracts/functions based on include/exclude options\n */\nexport function filterByOptions<T extends { name: string }>(\n\titems: T[],\n\toptions: BasePluginOptions = {},\n): T[] {\n\tlet filtered = items;\n\n\tif (options.include && options.include.length > 0) {\n\t\tfiltered = filtered.filter((item) =>\n\t\t\toptions.include?.some(\n\t\t\t\t(pattern) =>\n\t\t\t\t\titem.name.includes(pattern) || item.name.match(new RegExp(pattern)),\n\t\t\t),\n\t\t);\n\t}\n\n\tif (options.exclude && options.exclude.length > 0) {\n\t\tfiltered = filtered.filter(\n\t\t\t(item) =>\n\t\t\t\t!options.exclude?.some(\n\t\t\t\t\t(pattern) =>\n\t\t\t\t\t\titem.name.includes(pattern) || item.name.match(new RegExp(pattern)),\n\t\t\t\t),\n\t\t);\n\t}\n\n\treturn filtered;\n}\n\n/**\n * Utility function to create a simple plugin\n */\nexport function createPlugin(\n\tname: string,\n\tversion: string,\n\timplementation: Partial<SecondLayerPlugin>,\n): SecondLayerPlugin {\n\treturn {\n\t\tname,\n\t\tversion,\n\t\t...implementation,\n\t};\n}\n\n// Plugin exports\nexport { clarinet, hasClarinetProject } from \"./clarinet/index\";\nexport type { ClarinetPluginOptions } from \"./clarinet/index\";\n\nexport { actions } from \"./actions/index\";\nexport type { ActionsPluginOptions } from \"./actions/index\";\n\nexport { react } from \"./react/index\";\nexport type { ReactPluginOptions } from \"./react/index\";\n\nexport { testing } from \"./testing/index\";\nexport type { TestingPluginOptions } from \"./testing/index\";\n",
15
+ "/**\n * Clarinet Plugin for @secondlayer/cli\n * Generates type-safe contract interfaces from local Clarity contracts using Clarinet SDK\n */\n\nimport { initSimnet } from \"@hirosystems/clarinet-sdk\";\nimport { toCamelCase } from \"@secondlayer/stacks/clarity\";\nimport { generateContractInterface } from \"../../generators/contract\";\nimport type {\n\tGenerateContext,\n\tPluginFactory,\n\tUserConfig,\n} from \"../../types/plugin\";\nimport { normalizeAbi } from \"../../utils/abi-compat\";\nimport { parseContractId } from \"../../utils/contract-id\";\n\nexport interface ClarinetPluginOptions {\n\t/** Path to Clarinet.toml file */\n\tpath?: string;\n\n\t/** Include only specific contracts */\n\tinclude?: string[];\n\n\t/** Exclude specific contracts */\n\texclude?: string[];\n\n\t/** Enable debug output */\n\tdebug?: boolean;\n}\n\n/**\n * Sanitize contract name to be a valid JavaScript identifier using camelCase\n */\nfunction sanitizeContractName(name: string): string {\n\treturn toCamelCase(name);\n}\n\n/**\n * Check if a contract is a user-defined contract (not a system contract)\n */\nasync function isUserDefinedContract(\n\tcontractId: string,\n\tmanifestPath: string,\n): Promise<boolean> {\n\tconst { address, contractName } = parseContractId(contractId);\n\n\ttry {\n\t\t// Read Clarinet.toml to get user-defined contracts\n\t\tconst { promises: fs } = await import(\"node:fs\");\n\t\tconst tomlContent = await fs.readFile(manifestPath, \"utf-8\");\n\n\t\t// Simple TOML parsing to find [contracts.CONTRACT_NAME] sections\n\t\tconst contractSectionRegex = /^\\[contracts\\.([^\\]]+)\\]/gm;\n\t\tconst userContracts = new Set<string>();\n\n\t\tlet match: RegExpExecArray | null = contractSectionRegex.exec(tomlContent);\n\t\twhile (match !== null) {\n\t\t\tuserContracts.add(match[1]);\n\t\t\tmatch = contractSectionRegex.exec(tomlContent);\n\t\t}\n\n\t\t// If the contract is explicitly defined in Clarinet.toml, it's user-defined\n\t\tif (userContracts.has(contractName)) {\n\t\t\treturn true;\n\t\t}\n\t} catch (error) {\n\t\t// If we can't read the TOML file, fall back to pattern matching\n\t}\n\n\t// Fallback: System contracts typically have specific addresses or are in the boot contracts\n\t// Common system contract patterns:\n\tconst systemContractPatterns = [\n\t\t/^pox-\\d+$/, // pox-2, pox-3, etc.\n\t\t/^bns$/, // Blockchain Name System\n\t\t/^costs-\\d+$/, // costs-2, costs-3, etc.\n\t\t/^lockup$/, // lockup contract\n\t];\n\n\t// Check if it matches any system contract pattern\n\tif (systemContractPatterns.some((pattern) => pattern.test(contractName))) {\n\t\treturn false;\n\t}\n\n\t// System contracts often use specific addresses\n\tconst systemAddresses = [\n\t\t\"SP000000000000000000002Q6VF78\", // Boot contracts address\n\t\t\"ST000000000000000000002AMW42H\", // Boot contracts address (testnet)\n\t];\n\n\tif (systemAddresses.includes(address)) {\n\t\treturn false;\n\t}\n\n\treturn true;\n}\n\n/**\n * Clarinet plugin factory\n */\nexport const clarinet: PluginFactory<ClarinetPluginOptions> = (\n\toptions = {},\n) => {\n\tconst manifestPath = options.path || \"./Clarinet.toml\";\n\t// biome-ignore lint/suspicious/noExplicitAny: interop boundary or dynamic-shape value where typing adds friction without runtime safety\n\tlet simnet: any;\n\n\treturn {\n\t\tname: \"@secondlayer/cli/plugin-clarinet\",\n\t\tversion: \"1.0.0\",\n\n\t\tasync transformConfig(config: UserConfig): Promise<UserConfig> {\n\t\t\ttry {\n\t\t\t\t// Initialize simnet to extract contract ABIs\n\t\t\t\tsimnet = await initSimnet(manifestPath);\n\n\t\t\t\t// Get contract interfaces from Clarinet\n\t\t\t\tconst contractInterfaces = simnet.getContractsInterfaces();\n\t\t\t\tconst contracts = [];\n\n\t\t\t\tfor (const [contractId, abi] of contractInterfaces) {\n\t\t\t\t\tconst { contractName } = parseContractId(contractId);\n\n\t\t\t\t\t// Skip system contracts\n\t\t\t\t\tif (!(await isUserDefinedContract(contractId, manifestPath))) {\n\t\t\t\t\t\tif (options.debug) {\n\t\t\t\t\t\t\tconsole.log(`🚫 Skipping system contract: ${contractId}`);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Apply user filters\n\t\t\t\t\tif (options.include && !options.include.includes(contractName)) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\t\t\t\t\tif (options.exclude?.includes(contractName)) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Sanitize the contract name for JavaScript export\n\t\t\t\t\tconst sanitizedName = sanitizeContractName(contractName);\n\n\t\t\t\t\t// Don't set source field to avoid conflict with file resolution\n\t\t\t\t\t// Instead, we'll track this in metadata during processing\n\t\t\t\t\tcontracts.push({\n\t\t\t\t\t\tname: sanitizedName,\n\t\t\t\t\t\taddress: contractId,\n\t\t\t\t\t\tabi: normalizeAbi(abi),\n\t\t\t\t\t\t// Remove source field - this was causing the path resolution issue\n\t\t\t\t\t\t_clarinetSource: true, // Internal flag for our plugin\n\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\tif (options.debug) {\n\t\t\t\t\tconsole.log(\n\t\t\t\t\t\t`🔍 Clarinet plugin found ${contracts.length} user-defined contracts`,\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\treturn {\n\t\t\t\t\t...config,\n\t\t\t\t\tcontracts: [...(config.contracts || []), ...contracts],\n\t\t\t\t};\n\t\t\t} catch (error) {\n\t\t\t\tconst err = error as Error;\n\t\t\t\tif (options.debug) {\n\t\t\t\t\tconsole.warn(\n\t\t\t\t\t\t`⚠️ Clarinet plugin failed to load contracts: ${err.message}`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\t// If Clarinet.toml doesn't exist or fails, just return config unchanged\n\t\t\t\treturn config;\n\t\t\t}\n\t\t},\n\n\t\tasync generate(context: GenerateContext): Promise<void> {\n\t\t\t// Filter contracts that came from Clarinet\n\t\t\tconst clarinetContracts = context.contracts.filter(\n\t\t\t\t(contract) => contract.metadata?.source === \"clarinet\",\n\t\t\t);\n\n\t\t\tif (clarinetContracts.length === 0) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (options.debug) {\n\t\t\t\tcontext.logger.debug(\n\t\t\t\t\t`Generating interfaces for ${clarinetContracts.length} Clarinet contracts`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\t// Generate the main contracts file using existing generator\n\t\t\tconst contractsCode = await generateContractInterface(clarinetContracts);\n\n\t\t\tcontext.addOutput(\"contracts\", {\n\t\t\t\tpath: context.config.out,\n\t\t\t\tcontent: contractsCode,\n\t\t\t\ttype: \"contracts\",\n\t\t\t});\n\n\t\t\t// Don't log success here - let the main command handle it\n\t\t},\n\t};\n};\n\n/**\n * Utility function to check if a Clarinet project exists\n */\nexport async function hasClarinetProject(\n\tpath = \"./Clarinet.toml\",\n): Promise<boolean> {\n\ttry {\n\t\tconst { promises: fs } = await import(\"node:fs\");\n\t\tawait fs.access(path);\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n}\n",
16
+ "/**\n * Action generators for read and write helper functions\n */\n\nimport { type AbiFunction, toCamelCase } from \"@secondlayer/stacks/clarity\";\nimport type { ProcessedContract } from \"../../types/plugin\";\nimport {\n\tgenerateArgsSignature,\n\tgenerateClarityArgs,\n} from \"../../utils/generator-helpers\";\nimport type { ActionsPluginOptions } from \"./index\";\n\n/**\n * Generate read helper functions for a contract (fixed version)\n */\nfunction generateReadHelpers(\n\tcontract: ProcessedContract,\n\toptions: ActionsPluginOptions,\n): string {\n\tconst { abi } = contract;\n\tconst functions = abi.functions || [];\n\n\tconst readOnlyFunctions = functions.filter(\n\t\t(f: AbiFunction) => f.access === \"read-only\",\n\t);\n\n\tif (readOnlyFunctions.length === 0) {\n\t\treturn \"\";\n\t}\n\n\t// Apply function filters\n\tconst filteredFunctions = readOnlyFunctions.filter((func: AbiFunction) => {\n\t\tif (\n\t\t\toptions.includeFunctions &&\n\t\t\t!options.includeFunctions.includes(func.name)\n\t\t) {\n\t\t\treturn false;\n\t\t}\n\t\tif (options.excludeFunctions?.includes(func.name)) {\n\t\t\treturn false;\n\t\t}\n\t\treturn true;\n\t});\n\n\tif (filteredFunctions.length === 0) {\n\t\treturn \"\";\n\t}\n\n\tconst helpers = filteredFunctions.map((func: AbiFunction) => {\n\t\tconst methodName = toCamelCase(func.name);\n\t\tconst argsSignature = generateArgsSignature(func.args);\n\t\tconst clarityArgs = generateClarityArgs(func.args);\n\n\t\treturn `async ${methodName}(${argsSignature}options?: {\n network?: 'mainnet' | 'testnet' | 'devnet';\n senderAddress?: string;\n }) {\n return await fetchCallReadOnlyFunction({\n contractAddress: '${contract.address}',\n contractName: '${contract.contractName}',\n functionName: '${func.name}',\n functionArgs: [${clarityArgs}],\n network: options?.network ?? inferNetworkFromAddress('${contract.address}') ?? 'mainnet',\n senderAddress: options?.senderAddress || 'SP000000000000000000002Q6VF78'\n });\n }`;\n\t});\n\n\treturn `read: {\n ${helpers.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate write helper functions for a contract (fixed version)\n */\nfunction generateWriteHelpers(\n\tcontract: ProcessedContract,\n\toptions: ActionsPluginOptions,\n): string {\n\tconst { abi } = contract;\n\tconst functions = abi.functions || [];\n\tconst envVarName = options.senderKeyEnv ?? \"STX_SENDER_KEY\";\n\n\tconst publicFunctions = functions.filter(\n\t\t(f: AbiFunction) => f.access === \"public\",\n\t);\n\n\tif (publicFunctions.length === 0) {\n\t\treturn \"\";\n\t}\n\n\t// Apply function filters\n\tconst filteredFunctions = publicFunctions.filter((func: AbiFunction) => {\n\t\tif (\n\t\t\toptions.includeFunctions &&\n\t\t\t!options.includeFunctions.includes(func.name)\n\t\t) {\n\t\t\treturn false;\n\t\t}\n\t\tif (options.excludeFunctions?.includes(func.name)) {\n\t\t\treturn false;\n\t\t}\n\t\treturn true;\n\t});\n\n\tif (filteredFunctions.length === 0) {\n\t\treturn \"\";\n\t}\n\n\tconst helpers = filteredFunctions.map((func: AbiFunction) => {\n\t\tconst methodName = toCamelCase(func.name);\n\t\tconst argsSignature = generateArgsSignature(func.args);\n\t\tconst clarityArgs = generateClarityArgs(func.args);\n\n\t\treturn `async ${methodName}(${argsSignature}senderKey?: string, options?: {\n network?: 'mainnet' | 'testnet' | 'devnet';\n fee?: string | number | undefined;\n nonce?: bigint;\n anchorMode?: 1 | 2 | 3; // AnchorMode: OnChainOnly = 1, OffChainOnly = 2, Any = 3\n postConditions?: PostCondition[];\n validateWithAbi?: boolean;\n }) {\n const resolvedSenderKey = senderKey ?? process.env.${envVarName};\n if (!resolvedSenderKey) {\n throw new Error('senderKey required: pass as argument or set ${envVarName} env var');\n }\n const { network = 'mainnet', ...txOptions } = options ?? {};\n\n return await makeContractCall({\n contractAddress: '${contract.address}',\n contractName: '${contract.contractName}',\n functionName: '${func.name}',\n functionArgs: [${clarityArgs}],\n senderKey: resolvedSenderKey,\n network,\n validateWithAbi: true,\n ...txOptions\n });\n }`;\n\t});\n\n\treturn `write: {\n ${helpers.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate action helpers (read and write functions) for a contract\n */\nexport async function generateActionHelpers(\n\tcontract: ProcessedContract,\n\toptions: ActionsPluginOptions,\n): Promise<string> {\n\tconst readHelpers = generateReadHelpers(contract, options);\n\tconst writeHelpers = generateWriteHelpers(contract, options);\n\n\tif (!readHelpers && !writeHelpers) {\n\t\treturn \"\";\n\t}\n\n\tconst helpers = [readHelpers, writeHelpers].filter(Boolean);\n\treturn helpers.join(\",\\n\\n\");\n}\n",
17
+ "/**\n * Actions Plugin for @secondlayer/cli\n * Generates read and write helper functions for direct blockchain interaction\n */\n\nimport type {\n\t// UserConfig,\n\tGenerateContext,\n\tPluginFactory,\n} from \"../../types/plugin\";\nimport { generateActionHelpers } from \"./generators\";\n\nexport interface ActionsPluginOptions {\n\t/** Include only specific contracts */\n\tinclude?: string[];\n\n\t/** Exclude specific contracts */\n\texclude?: string[];\n\n\t/** Include only specific functions */\n\tincludeFunctions?: string[];\n\n\t/** Exclude specific functions */\n\texcludeFunctions?: string[];\n\n\t/** Enable debug output */\n\tdebug?: boolean;\n\n\t/** Environment variable name for default sender key (default: \"STX_SENDER_KEY\") */\n\tsenderKeyEnv?: string;\n}\n\n/**\n * Actions plugin factory\n */\nexport const actions: PluginFactory<ActionsPluginOptions> = (options = {}) => {\n\treturn {\n\t\tname: \"@secondlayer/cli/plugin-actions\",\n\t\tversion: \"1.0.0\",\n\n\t\tasync generate(context: GenerateContext): Promise<void> {\n\t\t\tconst { contracts } = context;\n\n\t\t\t// Filter contracts based on options\n\t\t\tconst filteredContracts = contracts.filter((contract) => {\n\t\t\t\tif (options.include && !options.include.includes(contract.name)) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\tif (options.exclude?.includes(contract.name)) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\treturn true;\n\t\t\t});\n\n\t\t\tif (filteredContracts.length === 0) {\n\t\t\t\tif (options.debug) {\n\t\t\t\t\tcontext.logger.debug(\"Actions plugin: No contracts to process\");\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (options.debug) {\n\t\t\t\tcontext.logger.debug(\n\t\t\t\t\t`Actions plugin: Generating read/write helpers for ${filteredContracts.length} contracts`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\t// Collect all helpers for all contracts\n\t\t\tconst contractHelpers = new Map<string, string>();\n\n\t\t\tfor (const contract of filteredContracts) {\n\t\t\t\tconst actionsCode = await generateActionHelpers(contract, options);\n\t\t\t\tif (actionsCode) {\n\t\t\t\t\tcontractHelpers.set(contract.name, actionsCode);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Inject all helpers into the output\n\t\t\tif (contractHelpers.size > 0) {\n\t\t\t\tconst existingOutput = context.outputs.get(\"contracts\");\n\t\t\t\tif (existingOutput) {\n\t\t\t\t\tlet modifiedContent = addRequiredImports(existingOutput.content);\n\n\t\t\t\t\t// Inject helpers for each contract\n\t\t\t\t\tfor (const [contractName, helpersCode] of contractHelpers) {\n\t\t\t\t\t\tmodifiedContent = injectHelpersIntoContract(\n\t\t\t\t\t\t\tmodifiedContent,\n\t\t\t\t\t\t\tcontractName,\n\t\t\t\t\t\t\thelpersCode,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\tcontext.outputs.set(\"contracts\", {\n\t\t\t\t\t\t...existingOutput,\n\t\t\t\t\t\tcontent: modifiedContent,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t};\n};\n\n/**\n * Add required imports for fetchCallReadOnlyFunction, makeContractCall, and PostCondition\n */\nfunction addRequiredImports(content: string): string {\n\t// Find the existing @secondlayer/stacks import line\n\tconst stacksImportRegex =\n\t\t/import\\s+\\{([^}]+)\\}\\s+from\\s+['\"]@secondlayer\\/stacks['\"];/;\n\tconst match = content.match(stacksImportRegex);\n\n\tif (match) {\n\t\tlet updatedContent = content;\n\n\t\t// Add fetchCallReadOnlyFunction and makeContractCall from @secondlayer/stacks/clarity\n\t\tif (!updatedContent.includes(\"fetchCallReadOnlyFunction\")) {\n\t\t\tupdatedContent = updatedContent.replace(\n\t\t\t\tstacksImportRegex,\n\t\t\t\t`${match[0]}\\nimport { fetchCallReadOnlyFunction, makeContractCall } from '@secondlayer/stacks/clarity';`,\n\t\t\t);\n\t\t}\n\n\t\t// Add type import for PostCondition if not present\n\t\tif (!updatedContent.includes(\"type PostCondition\")) {\n\t\t\tupdatedContent = updatedContent.replace(\n\t\t\t\tstacksImportRegex,\n\t\t\t\t`${match[0]}\\nimport type { PostCondition } from '@secondlayer/stacks';`,\n\t\t\t);\n\t\t}\n\n\t\treturn updatedContent;\n\t}\n\n\treturn content;\n}\n\n/**\n * Inject read/write helpers into a specific contract object in the output\n */\nfunction injectHelpersIntoContract(\n\tcontent: string,\n\tcontractName: string,\n\thelpersCode: string,\n): string {\n\t// Use a more precise regex to find the entire contract object\n\tconst contractPattern = new RegExp(\n\t\t`(export const ${contractName} = \\\\{[\\\\s\\\\S]*?)\\\\n\\\\} as const;`,\n\t\t\"g\",\n\t);\n\n\treturn content.replace(contractPattern, (_, contractBody) => {\n\t\t// Remove any trailing comma and whitespace from the contract body\n\t\tconst cleanBody = contractBody.replace(/,\\s*$/, \"\");\n\n\t\t// Add proper indentation to lines that start top-level properties\n\t\tconst indentedHelpersCode = helpersCode\n\t\t\t.split(\"\\n\")\n\t\t\t.map((line) => {\n\t\t\t\t// Only add indentation to lines that start with a property name (like \"write:\")\n\t\t\t\tif (line.match(/^[a-zA-Z_$][a-zA-Z0-9_$]*\\s*:/)) {\n\t\t\t\t\treturn ` ${line}`;\n\t\t\t\t}\n\t\t\t\treturn line;\n\t\t\t})\n\t\t\t.join(\"\\n\");\n\n\t\t// Add the helpers with proper formatting\n\t\treturn `${cleanBody},\n\n${indentedHelpersCode}\n} as const;`;\n\t});\n}\n",
18
18
  "/**\n * Contract-specific hooks generator for React plugin\n */\n\nimport type { AbiFunction } from \"@secondlayer/stacks/clarity\";\nimport type { AbiMap, AbiVariable } from \"@secondlayer/stacks/clarity\";\nimport type { ProcessedContract } from \"../../../types/plugin\";\nimport { formatCode } from \"../../../utils/format\";\nimport {\n\tcapitalize,\n\tclarityTypeToTS,\n\tgenerateArgNames,\n\tgenerateArgsType,\n\tgenerateEnabledCondition,\n\tgenerateHookArgsSignature,\n\tgenerateObjectArgs,\n\ttoCamelCase,\n} from \"./utils\";\n\nexport async function generateContractHooks(\n\tcontracts: ProcessedContract[],\n\texcludeList: string[] = [],\n): Promise<string> {\n\tconst imports = `import { useQuery, useMutation, useQueryClient } from '@tanstack/react-query'\nimport { useCallback } from 'react'\nimport { useSecondLayerConfig } from './provider'\nimport { request } from '@secondlayer/stacks/connect'\nimport type { PostCondition } from '@secondlayer/stacks'\nimport { ${contracts.map((c) => c.name).join(\", \")} } from './contracts'`;\n\n\tconst header = `/**\n * Generated contract-specific React hooks\n * DO NOT EDIT MANUALLY\n */`;\n\n\tconst hooksCode = contracts\n\t\t.map((contract) => generateContractHookMethods(contract, excludeList))\n\t\t.filter(Boolean)\n\t\t.join(\"\\n\\n\");\n\n\tconst code = `${imports}\\n\\n${header}\\n\\n${hooksCode}`;\n\n\treturn formatCode(code);\n}\n\nfunction generateContractHookMethods(\n\tcontract: ProcessedContract,\n\texcludeList: string[],\n): string {\n\tconst { abi, name, address, contractName } = contract;\n\tconst functions = abi.functions || [];\n\tconst maps = abi.maps || [];\n\tconst variables = abi.variables || [];\n\n\tconst readOnlyFunctions = functions.filter(\n\t\t(f: AbiFunction) => f.access === \"read-only\",\n\t);\n\tconst publicFunctions = functions.filter(\n\t\t(f: AbiFunction) => f.access === \"public\",\n\t);\n\n\tconst readHooks = readOnlyFunctions\n\t\t.map((func: AbiFunction) => {\n\t\t\tconst hookName = `use${capitalize(name)}${capitalize(toCamelCase(func.name))}`;\n\t\t\t// Check if this specific hook is excluded\n\t\t\tif (excludeList.includes(hookName)) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\treturn generateReadHook(func, name);\n\t\t})\n\t\t.filter(Boolean);\n\n\tconst writeHooks = publicFunctions\n\t\t.map((func: AbiFunction) => {\n\t\t\tconst hookName = `use${capitalize(name)}${capitalize(toCamelCase(func.name))}`;\n\t\t\t// Check if this specific hook is excluded\n\t\t\tif (excludeList.includes(hookName)) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\treturn generateWriteHook(func, name);\n\t\t})\n\t\t.filter(Boolean);\n\n\t// Generate hooks for maps\n\tconst mapHooks = maps\n\t\t.map((map: AbiMap) => {\n\t\t\tconst hookName = `use${capitalize(name)}${capitalize(toCamelCase(map.name))}`;\n\t\t\tif (excludeList.includes(hookName)) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\treturn generateMapHook(map, name, address, contractName);\n\t\t})\n\t\t.filter(Boolean);\n\n\t// Generate hooks for data variables\n\tconst dataVars = variables.filter(\n\t\t(v: AbiVariable) => v.access === \"variable\",\n\t);\n\tconst varHooks = dataVars\n\t\t.map((variable: AbiVariable) => {\n\t\t\tconst hookName = `use${capitalize(name)}${capitalize(toCamelCase(variable.name))}`;\n\t\t\tif (excludeList.includes(hookName)) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\treturn generateVarHook(variable, name, address, contractName);\n\t\t})\n\t\t.filter(Boolean);\n\n\t// Generate hooks for constants\n\tconst constants = variables.filter(\n\t\t(v: AbiVariable) => v.access === \"constant\",\n\t);\n\tconst constantHooks = constants\n\t\t.map((constant: AbiVariable) => {\n\t\t\tconst hookName = `use${capitalize(name)}${capitalize(toCamelCase(constant.name))}`;\n\t\t\tif (excludeList.includes(hookName)) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\treturn generateConstantHook(constant, name, address, contractName);\n\t\t})\n\t\t.filter(Boolean);\n\n\tconst allHooks = [\n\t\t...readHooks,\n\t\t...writeHooks,\n\t\t...mapHooks,\n\t\t...varHooks,\n\t\t...constantHooks,\n\t];\n\n\t// If all hooks for this contract are excluded, return empty string\n\tif (allHooks.length === 0) {\n\t\treturn \"\";\n\t}\n\n\treturn allHooks.join(\"\\n\\n\");\n}\n\nfunction generateReadHook(func: AbiFunction, contractName: string): string {\n\tconst hookName = `use${capitalize(contractName)}${capitalize(toCamelCase(func.name))}`;\n\tconst argsSignature = generateHookArgsSignature(func.args);\n\tconst enabledParam =\n\t\tfunc.args.length > 0\n\t\t\t? \", options?: { enabled?: boolean }\"\n\t\t\t: \"options?: { enabled?: boolean }\";\n\n\t// Generate proper return type from function outputs\n\tconst returnType = clarityTypeToTS(func.outputs);\n\n\treturn `export function ${hookName}(${argsSignature}${enabledParam}) {\n const config = useSecondLayerConfig()\n\n return useQuery<${returnType}>({\n queryKey: ['${func.name}', ${contractName}.address, ${generateArgNames(func.args)}],\n queryFn: () => ${contractName}.read.${toCamelCase(func.name)}(${generateArgNames(func.args) ? `{ ${generateObjectArgs(func.args)} }, ` : \"\"}{\n network: config.network,\n senderAddress: config.senderAddress || 'SP000000000000000000002Q6VF78'\n }),\n ${func.args.length > 0 ? `enabled: ${generateEnabledCondition(func.args)} && (options?.enabled ?? true),` : \"\"}\n ...options\n })\n}`;\n}\n\nfunction generateWriteHook(func: AbiFunction, contractName: string): string {\n\tconst hookName = `use${capitalize(contractName)}${capitalize(toCamelCase(func.name))}`;\n\tconst argsType = generateArgsType(func.args);\n\n\treturn `export function ${hookName}() {\n const config = useSecondLayerConfig()\n const queryClient = useQueryClient()\n \n const mutation = useMutation({\n mutationFn: async (params: {\n args: ${argsType};\n options?: {\n postConditions?: PostCondition[];\n attachment?: string;\n onFinish?: (data: any) => void;\n onCancel?: () => void;\n };\n }) => {\n const { args, options = {} } = params\n const contractCallData = ${contractName}.${toCamelCase(func.name)}(args)\n const { contractAddress, contractName: name, functionName, functionArgs } = contractCallData\n const network = config.network || 'mainnet'\n const contract = \\`\\${contractAddress}.\\${name}\\`\n\n const result = await request('stx_callContract', {\n contract,\n functionName,\n functionArgs,\n network,\n ...options\n })\n\n options.onFinish?.(result)\n return result\n },\n onSuccess: () => {\n // Invalidate relevant queries on success\n queryClient.invalidateQueries({ queryKey: ['stacks-account'] })\n },\n onError: (error) => {\n console.error('Contract call failed:', error)\n }\n })\n\n const ${toCamelCase(func.name)} = useCallback(async (\n args: ${argsType},\n options?: {\n postConditions?: PostCondition[];\n attachment?: string;\n onFinish?: (data: any) => void;\n onCancel?: () => void;\n }\n ) => {\n return mutation.mutateAsync({ args, options })\n }, [mutation])\n\n return {\n ${toCamelCase(func.name)},\n // Expose mutation state\n isPending: mutation.isPending,\n isError: mutation.isError,\n isSuccess: mutation.isSuccess,\n error: mutation.error,\n data: mutation.data,\n reset: mutation.reset\n }\n}`;\n}\n\n/**\n * Generate a hook for reading a map entry\n */\nfunction generateMapHook(\n\tmap: AbiMap,\n\tcontractVarName: string,\n\t_address: string,\n\t_contractName: string,\n): string {\n\tconst hookName = `use${capitalize(contractVarName)}${capitalize(toCamelCase(map.name))}`;\n\tconst keyType = clarityTypeToTS(map.key);\n\tconst valueType = clarityTypeToTS(map.value);\n\n\treturn `export function ${hookName}(key: ${keyType}, options?: { enabled?: boolean }) {\n const config = useSecondLayerConfig()\n\n return useQuery<${valueType} | null>({\n queryKey: ['${contractVarName}', '${map.name}', 'map', key, config.network],\n queryFn: async () => {\n return ${contractVarName}.maps.${toCamelCase(map.name)}.get(key, { network: config.network })\n },\n enabled: options?.enabled ?? true\n })\n}`;\n}\n\n/**\n * Generate a hook for reading a data variable\n */\nfunction generateVarHook(\n\tvariable: AbiVariable,\n\tcontractVarName: string,\n\t_address: string,\n\t_contractName: string,\n): string {\n\tconst hookName = `use${capitalize(contractVarName)}${capitalize(toCamelCase(variable.name))}`;\n\tconst valueType = clarityTypeToTS(variable.type);\n\n\treturn `export function ${hookName}(options?: { enabled?: boolean }) {\n const config = useSecondLayerConfig()\n\n return useQuery<${valueType}>({\n queryKey: ['${contractVarName}', '${variable.name}', 'var', config.network],\n queryFn: async () => {\n return ${contractVarName}.vars.${toCamelCase(variable.name)}.get({ network: config.network })\n },\n enabled: options?.enabled ?? true\n })\n}`;\n}\n\n/**\n * Generate a hook for reading a constant\n */\nfunction generateConstantHook(\n\tconstant: AbiVariable,\n\tcontractVarName: string,\n\t_address: string,\n\t_contractName: string,\n): string {\n\tconst hookName = `use${capitalize(contractVarName)}${capitalize(toCamelCase(constant.name))}`;\n\tconst valueType = clarityTypeToTS(constant.type);\n\n\treturn `export function ${hookName}(options?: { enabled?: boolean }) {\n const config = useSecondLayerConfig()\n\n return useQuery<${valueType}>({\n queryKey: ['${contractVarName}', '${constant.name}', 'constant', config.network],\n queryFn: async () => {\n return ${contractVarName}.constants.${toCamelCase(constant.name)}.get({ network: config.network })\n },\n enabled: options?.enabled ?? true,\n staleTime: Infinity // Constants never change\n })\n}`;\n}\n",
19
19
  "import { toCamelCase } from \"@secondlayer/stacks/clarity\";\n\nexport { toCamelCase };\n\nexport function capitalize(str: string): string {\n\treturn str.charAt(0).toUpperCase() + str.slice(1);\n}\n\nexport function toPascalCase(str: string): string {\n\treturn capitalize(toCamelCase(str));\n}\n",
20
20
  "/**\n * Utility functions for React hook generation\n */\n\nimport type { FunctionArg } from \"@secondlayer/stacks/clarity\";\nimport { capitalize, toCamelCase } from \"../../../utils/case-conversion\";\nimport { clarityTypeToTS } from \"../../../utils/type-mapping\";\n\n// Re-export for use in other files\nexport { toCamelCase, clarityTypeToTS, capitalize };\n\nexport function generateHookArgsSignature(\n\targs: ReadonlyArray<FunctionArg>,\n): string {\n\tif (args.length === 0) return \"\";\n\n\tconst argsList = args\n\t\t.map((arg) => `${toCamelCase(arg.name)}: ${clarityTypeToTS(arg.type)}`)\n\t\t.join(\", \");\n\treturn `${argsList}`;\n}\n\nexport function generateArgsType(args: ReadonlyArray<FunctionArg>): string {\n\tif (args.length === 0) return \"void\";\n\n\tconst argsList = args\n\t\t.map((arg) => `${toCamelCase(arg.name)}: ${clarityTypeToTS(arg.type)}`)\n\t\t.join(\"; \");\n\treturn `{ ${argsList} }`;\n}\n\nexport function generateArgNames(args: ReadonlyArray<FunctionArg>): string {\n\tif (args.length === 0) return \"\";\n\treturn args.map((arg) => toCamelCase(arg.name)).join(\", \");\n}\n\nexport function generateEnabledCondition(\n\targs: ReadonlyArray<FunctionArg>,\n): string {\n\treturn args\n\t\t.map((arg) => {\n\t\t\tconst camelName = toCamelCase(arg.name);\n\t\t\tconst type = clarityTypeToTS(arg.type);\n\t\t\tif (type === \"string\") return `!!${camelName}`;\n\t\t\tif (type === \"bigint\") return `${camelName} !== undefined`;\n\t\t\treturn `${camelName} !== undefined`;\n\t\t})\n\t\t.join(\" && \");\n}\n\nexport function generateObjectArgs(args: ReadonlyArray<FunctionArg>): string {\n\tif (args.length === 0) return \"\";\n\treturn args.map((arg) => `${arg.name}: ${toCamelCase(arg.name)}`).join(\", \");\n}\n",
@@ -23,9 +23,9 @@
23
23
  "/**\n * Provider generator for React plugin\n */\n\nimport { formatCode } from \"../../../utils/format\";\n\n/**\n * Generate the provider file content for user projects\n */\nexport async function generateProvider(): Promise<string> {\n\tconst code = `/**\n * Generated SecondLayer React Provider\n * DO NOT EDIT MANUALLY\n */\n\nimport React, { createContext, useContext } from 'react'\n\n/**\n * SecondLayer configuration interface\n */\nexport interface SecondLayerReactConfig {\n /**\n * Network to use for API calls\n */\n network: 'mainnet' | 'testnet' | 'devnet'\n\n /**\n * API key for Stacks API (optional)\n */\n apiKey?: string\n\n /**\n * Base URL for Stacks API (optional override)\n */\n apiUrl?: string\n\n /**\n * Default sender address for read-only calls\n */\n senderAddress?: string\n}\n\n/**\n * Provider component props\n */\nexport interface SecondLayerProviderProps {\n children: React.ReactNode\n config: SecondLayerReactConfig\n}\n\n/**\n * React context for SecondLayer configuration\n */\nconst SecondLayerContext = createContext<SecondLayerReactConfig | undefined>(undefined)\nSecondLayerContext.displayName = 'SecondLayerContext'\n\n/**\n * Create a SecondLayer React configuration with defaults\n */\nexport function createSecondLayerConfig(config: SecondLayerReactConfig): SecondLayerReactConfig {\n return {\n network: config.network,\n apiKey: config.apiKey,\n apiUrl: config.apiUrl,\n senderAddress: config.senderAddress || 'SP000000000000000000002Q6VF78'\n }\n}\n\n/**\n * Provider component that makes SecondLayer configuration available to hooks\n */\nexport function SecondLayerProvider({ children, config }: SecondLayerProviderProps) {\n const resolvedConfig = createSecondLayerConfig(config)\n\n return (\n <SecondLayerContext.Provider value={resolvedConfig}>\n {children}\n </SecondLayerContext.Provider>\n )\n}\n\n/**\n * Hook to access the SecondLayer configuration\n */\nexport function useSecondLayerConfig(): SecondLayerReactConfig {\n const context = useContext(SecondLayerContext)\n\n if (context === undefined) {\n throw new Error(\n 'useSecondLayerConfig must be used within a SecondLayerProvider. ' +\n 'Make sure to wrap your app with <SecondLayerProvider config={{...}}>'\n )\n }\n\n return context\n}`;\n\n\treturn formatCode(code);\n}\n",
24
24
  "/**\n * React Plugin for @secondlayer/cli\n * Generates React hooks for contract interfaces and generic Stacks functionality\n */\n\nimport type { GenerateContext, PluginFactory } from \"../../types/plugin\";\nimport { generateContractHooks } from \"./generators/contract\";\nimport { generateGenericHooks } from \"./generators/generic\";\nimport { generateProvider } from \"./provider/index\";\nimport type { ReactPluginOptions } from \"./types\";\n\n/**\n * React plugin factory\n */\nexport const react: PluginFactory<ReactPluginOptions> = (options = {}) => {\n\tconst excludeList = options.exclude || [];\n\n\treturn {\n\t\tname: \"@secondlayer/cli/plugin-react\",\n\t\tversion: \"1.0.0\",\n\n\t\tasync generate(context: GenerateContext): Promise<void> {\n\t\t\tif (options.debug) {\n\t\t\t\tcontext.logger.debug(\n\t\t\t\t\t`React plugin generating hooks (excluding: ${excludeList.join(\", \") || \"none\"})`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\t// Generate provider (always generated)\n\t\t\tconst provider = await generateProvider();\n\t\t\tcontext.addOutput(\"provider\", {\n\t\t\t\tpath: \"./src/generated/provider.tsx\",\n\t\t\t\tcontent: provider,\n\t\t\t\ttype: \"config\",\n\t\t\t});\n\n\t\t\t// Generate generic hooks (all by default, minus excludes)\n\t\t\tconst genericHooks = await generateGenericHooks(excludeList);\n\t\t\tcontext.addOutput(\"generic-hooks\", {\n\t\t\t\tpath: \"./src/generated/hooks.ts\",\n\t\t\t\tcontent: genericHooks,\n\t\t\t\ttype: \"hooks\",\n\t\t\t});\n\n\t\t\t// Generate contract hooks (all contracts, minus excludes)\n\t\t\tif (context.contracts.length > 0) {\n\t\t\t\tconst contractHooks = await generateContractHooks(\n\t\t\t\t\tcontext.contracts,\n\t\t\t\t\texcludeList,\n\t\t\t\t);\n\n\t\t\t\t// Only add output if there are hooks to generate\n\t\t\t\tif (contractHooks.trim()) {\n\t\t\t\t\tcontext.addOutput(\"contract-hooks\", {\n\t\t\t\t\t\tpath: \"./src/generated/contract-hooks.ts\",\n\t\t\t\t\t\tcontent: contractHooks,\n\t\t\t\t\t\ttype: \"hooks\",\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (options.debug) {\n\t\t\t\tcontext.logger.success(\n\t\t\t\t\t`React plugin generated ${context.contracts.length} contract hook sets`,\n\t\t\t\t);\n\t\t\t}\n\t\t},\n\t};\n};\n\n// Re-export types for convenience\nexport type { ReactPluginOptions } from \"./types\";\n",
25
25
  "/**\n * Code generators for the testing plugin\n * Generates type-safe helpers for Clarinet SDK unit tests\n */\n\nimport {\n\ttype AbiFunction,\n\ttype AbiMap,\n\ttype AbiType,\n\ttype AbiVariable,\n\tisAbiTuple,\n} from \"@secondlayer/stacks/clarity\";\nimport type { ProcessedContract } from \"../../types/plugin\";\nimport { toCamelCase, toPascalCase } from \"../../utils/case-conversion\";\nimport {\n\tgenerateArgsSignature,\n\tgenerateClarityArgs,\n\tgenerateMapKeyConversion,\n} from \"../../utils/generator-helpers\";\nimport { getTypeForArg } from \"../../utils/type-mapping\";\nimport type { TestingPluginOptions } from \"./index\";\n\n/**\n * Generate a public function helper\n */\nfunction generatePublicFunction(func: AbiFunction, contractId: string): string {\n\tconst methodName = toCamelCase(func.name);\n\tconst argsSignature = generateArgsSignature(func.args);\n\tconst clarityArgs = generateClarityArgs(func.args);\n\n\treturn `${methodName}: (${argsSignature}caller: string) => {\n const callerAddr = accounts.get(caller) ?? caller;\n return simnet.callPublicFn(\n '${contractId}',\n '${func.name}',\n [${clarityArgs}],\n callerAddr\n );\n }`;\n}\n\n/**\n * Generate a read-only function helper\n */\nfunction generateReadOnlyFunction(\n\tfunc: AbiFunction,\n\tcontractId: string,\n): string {\n\tconst methodName = toCamelCase(func.name);\n\tconst argsSignature = generateArgsSignature(func.args);\n\tconst clarityArgs = generateClarityArgs(func.args);\n\n\t// Read-only functions don't need a caller, use deployer as default\n\tconst hasArgs = func.args.length > 0;\n\tconst argsParam = hasArgs ? argsSignature : \"\";\n\n\treturn `${methodName}: (${argsParam}) => {\n return simnet.callReadOnlyFn(\n '${contractId}',\n '${func.name}',\n [${clarityArgs}],\n accounts.get('deployer')!\n );\n }`;\n}\n\n/**\n * Generate a private function helper (for testing only)\n */\nfunction generatePrivateFunction(\n\tfunc: AbiFunction,\n\tcontractId: string,\n): string {\n\tconst methodName = toCamelCase(func.name);\n\tconst argsSignature = generateArgsSignature(func.args);\n\tconst clarityArgs = generateClarityArgs(func.args);\n\n\treturn `${methodName}: (${argsSignature}caller: string) => {\n const callerAddr = accounts.get(caller) ?? caller;\n return simnet.callPrivateFn(\n '${contractId}',\n '${func.name}',\n [${clarityArgs}],\n callerAddr\n );\n }`;\n}\n\n/**\n * Generate a data variable accessor helper\n */\nfunction generateDataVarHelper(\n\tvariable: AbiVariable,\n\tcontractId: string,\n): string {\n\tconst methodName = toCamelCase(variable.name);\n\n\treturn `${methodName}: () => {\n return simnet.getDataVar('${contractId}', '${variable.name}');\n }`;\n}\n\n/**\n * Generate TypeScript type for map key based on its structure\n */\nfunction getMapKeyType(keyType: AbiType): string {\n\t// Map keys are typically tuples\n\tif (isAbiTuple(keyType)) {\n\t\tconst fields = keyType.tuple\n\t\t\t.map(\n\t\t\t\t(field: { name: string; type: AbiType }) =>\n\t\t\t\t\t`${toCamelCase(field.name)}: ${getTypeForArg({ type: field.type })}`,\n\t\t\t)\n\t\t\t.join(\"; \");\n\t\treturn `{ ${fields} }`;\n\t}\n\n\t// Single-value keys (less common but possible)\n\treturn getTypeForArg({ type: keyType });\n}\n\n/**\n * Generate a map entry accessor helper\n */\nfunction generateMapEntryHelper(map: AbiMap, contractId: string): string {\n\tconst methodName = toCamelCase(map.name);\n\tconst keyType = getMapKeyType(map.key);\n\tconst keyConversion = generateMapKeyConversion(map.key);\n\n\treturn `${methodName}: (key: ${keyType}) => {\n return simnet.getMapEntry(\n '${contractId}',\n '${map.name}',\n ${keyConversion}\n );\n }`;\n}\n\n/**\n * Generate the vars object containing all data variable accessors\n */\nfunction generateVarsObject(\n\tvariables: readonly AbiVariable[],\n\tcontractId: string,\n): string {\n\t// Filter to only include mutable variables (not constants)\n\tconst dataVars = variables.filter((v) => v.access === \"variable\");\n\n\tif (dataVars.length === 0) {\n\t\treturn \"\";\n\t}\n\n\tconst varHelpers = dataVars.map((v) => generateDataVarHelper(v, contractId));\n\n\treturn `vars: {\n ${varHelpers.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate the maps object containing all map entry accessors\n */\nfunction generateMapsObject(\n\tmaps: readonly AbiMap[],\n\tcontractId: string,\n): string {\n\tif (maps.length === 0) {\n\t\treturn \"\";\n\t}\n\n\tconst mapHelpers = maps.map((m) => generateMapEntryHelper(m, contractId));\n\n\treturn `maps: {\n ${mapHelpers.join(\",\\n\\n \")}\n }`;\n}\n\n/**\n * Generate a contract helper factory function\n */\nfunction generateContractHelper(\n\tcontract: ProcessedContract,\n\toptions: TestingPluginOptions,\n): string {\n\tconst { abi, name, address } = contract;\n\tconst functions = abi.functions || [];\n\tconst variables = abi.variables || [];\n\tconst maps = abi.maps || [];\n\tconst pascalName = toPascalCase(name);\n\n\t// Filter functions by access type\n\tconst publicFns = functions.filter((f: AbiFunction) => f.access === \"public\");\n\tconst readOnlyFns = functions.filter(\n\t\t(f: AbiFunction) => f.access === \"read-only\",\n\t);\n\tconst privateFns = options.includePrivate\n\t\t? functions.filter((f: AbiFunction) => f.access === \"private\")\n\t\t: [];\n\n\t// Generate function helpers\n\tconst publicHelpers = publicFns.map((f: AbiFunction) =>\n\t\tgeneratePublicFunction(f, address),\n\t);\n\tconst readOnlyHelpers = readOnlyFns.map((f: AbiFunction) =>\n\t\tgenerateReadOnlyFunction(f, address),\n\t);\n\tconst privateHelpers = privateFns.map((f: AbiFunction) =>\n\t\tgeneratePrivateFunction(f, address),\n\t);\n\n\t// Generate data variable and map accessors\n\tconst varsObject = generateVarsObject(variables, address);\n\tconst mapsObject = generateMapsObject(maps, address);\n\n\tconst allHelpers = [...publicHelpers, ...readOnlyHelpers, ...privateHelpers];\n\n\t// Include vars and maps objects if they have content\n\tif (varsObject) {\n\t\tallHelpers.push(varsObject);\n\t}\n\tif (mapsObject) {\n\t\tallHelpers.push(mapsObject);\n\t}\n\n\tif (allHelpers.length === 0) {\n\t\treturn \"\";\n\t}\n\n\treturn `export function get${pascalName}(simnet: Simnet) {\n const accounts = simnet.getAccounts();\n\n return {\n ${allHelpers.join(\",\\n\\n \")}\n };\n}`;\n}\n\n/**\n * Generate the getContracts convenience wrapper\n */\nfunction generateGetContracts(contracts: ProcessedContract[]): string {\n\tconst contractEntries = contracts\n\t\t.map((contract) => {\n\t\t\tconst camelName = toCamelCase(contract.name);\n\t\t\tconst pascalName = toPascalCase(contract.name);\n\t\t\treturn `${camelName}: get${pascalName}(simnet)`;\n\t\t})\n\t\t.join(\",\\n \");\n\n\treturn `export function getContracts(simnet: Simnet) {\n const accounts = simnet.getAccounts();\n\n return {\n accounts,\n ${contractEntries}\n };\n}`;\n}\n\n/**\n * Generate type exports for consumer convenience\n */\nfunction generateTypeExports(contracts: ProcessedContract[]): string {\n\tconst typeExports = contracts\n\t\t.map((contract) => {\n\t\t\tconst pascalName = toPascalCase(contract.name);\n\t\t\treturn `export type ${pascalName}Helpers = ReturnType<typeof get${pascalName}>;`;\n\t\t})\n\t\t.join(\"\\n\");\n\n\treturn `${typeExports}\nexport type Contracts = ReturnType<typeof getContracts>;`;\n}\n\n/**\n * Main entry point - generates the full testing helpers file\n */\nexport async function generateTestingHelpers(\n\tcontracts: ProcessedContract[],\n\toptions: TestingPluginOptions,\n): Promise<string> {\n\tconst contractHelpers = contracts\n\t\t.map((contract) => generateContractHelper(contract, options))\n\t\t.filter(Boolean);\n\n\tif (contractHelpers.length === 0) {\n\t\treturn `// No contracts with functions to generate helpers for\nexport {};`;\n\t}\n\n\tconst getContractsCode = generateGetContracts(contracts);\n\tconst typeExports = generateTypeExports(contracts);\n\n\treturn `/**\n * Generated by @secondlayer/cli testing plugin\n * Type-safe helpers for Clarinet SDK unit tests\n */\n\nimport { type Simnet, Cl } from '@hirosystems/clarinet-sdk';\n\n// ============================================\n// Per-contract factory functions\n// ============================================\n\n${contractHelpers.join(\"\\n\\n\")}\n\n// ============================================\n// Convenience: all contracts at once\n// ============================================\n\n${getContractsCode}\n\n// ============================================\n// Type exports\n// ============================================\n\n${typeExports}\n`;\n}\n",
26
- "/**\n * Testing plugin for @secondlayer/cli\n * Generates type-safe helpers for Clarinet SDK unit tests\n */\n\nimport type { GenerateContext, PluginFactory } from \"../../types/plugin\";\nimport { generateTestingHelpers } from \"./generators\";\n\nexport interface TestingPluginOptions {\n\t/** Include only specific contracts */\n\tinclude?: string[];\n\n\t/** Exclude specific contracts */\n\texclude?: string[];\n\n\t/** Output path for generated testing helpers (default: ./src/generated/testing.ts) */\n\tout?: string;\n\n\t/** Include private function helpers (default: false) */\n\tincludePrivate?: boolean;\n\n\t/** Enable debug output */\n\tdebug?: boolean;\n}\n\nexport const testing: PluginFactory<TestingPluginOptions> = (options = {}) => {\n\treturn {\n\t\tname: \"@secondlayer/cli/plugin-testing\",\n\t\tversion: \"1.0.0\",\n\n\t\tasync generate(context: GenerateContext): Promise<void> {\n\t\t\tconst { contracts } = context;\n\n\t\t\t// Filter contracts based on options\n\t\t\tconst filteredContracts = contracts.filter((contract) => {\n\t\t\t\tif (options.include && !options.include.includes(contract.name)) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\tif (options.exclude && options.exclude.includes(contract.name)) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\treturn true;\n\t\t\t});\n\n\t\t\tif (filteredContracts.length === 0) {\n\t\t\t\tif (options.debug) {\n\t\t\t\t\tcontext.logger.debug(\"Testing plugin: No contracts to process\");\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (options.debug) {\n\t\t\t\tcontext.logger.debug(\n\t\t\t\t\t`Testing plugin: Generating helpers for ${filteredContracts.length} contracts`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\t// Generate testing helpers\n\t\t\tconst testingCode = await generateTestingHelpers(\n\t\t\t\tfilteredContracts,\n\t\t\t\toptions,\n\t\t\t);\n\n\t\t\tconst outputPath = options.out || \"./src/generated/testing.ts\";\n\n\t\t\tcontext.addOutput(\"testing\", {\n\t\t\t\tpath: outputPath,\n\t\t\t\tcontent: testingCode,\n\t\t\t\ttype: \"utils\",\n\t\t\t});\n\n\t\t\tif (options.debug) {\n\t\t\t\tcontext.logger.debug(\n\t\t\t\t\t`Testing plugin: Generated helpers for ${filteredContracts.length} contracts`,\n\t\t\t\t);\n\t\t\t}\n\t\t},\n\t};\n};\n"
26
+ "/**\n * Testing plugin for @secondlayer/cli\n * Generates type-safe helpers for Clarinet SDK unit tests\n */\n\nimport type { GenerateContext, PluginFactory } from \"../../types/plugin\";\nimport { generateTestingHelpers } from \"./generators\";\n\nexport interface TestingPluginOptions {\n\t/** Include only specific contracts */\n\tinclude?: string[];\n\n\t/** Exclude specific contracts */\n\texclude?: string[];\n\n\t/** Output path for generated testing helpers (default: ./src/generated/testing.ts) */\n\tout?: string;\n\n\t/** Include private function helpers (default: false) */\n\tincludePrivate?: boolean;\n\n\t/** Enable debug output */\n\tdebug?: boolean;\n}\n\nexport const testing: PluginFactory<TestingPluginOptions> = (options = {}) => {\n\treturn {\n\t\tname: \"@secondlayer/cli/plugin-testing\",\n\t\tversion: \"1.0.0\",\n\n\t\tasync generate(context: GenerateContext): Promise<void> {\n\t\t\tconst { contracts } = context;\n\n\t\t\t// Filter contracts based on options\n\t\t\tconst filteredContracts = contracts.filter((contract) => {\n\t\t\t\tif (options.include && !options.include.includes(contract.name)) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\tif (options.exclude?.includes(contract.name)) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\treturn true;\n\t\t\t});\n\n\t\t\tif (filteredContracts.length === 0) {\n\t\t\t\tif (options.debug) {\n\t\t\t\t\tcontext.logger.debug(\"Testing plugin: No contracts to process\");\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif (options.debug) {\n\t\t\t\tcontext.logger.debug(\n\t\t\t\t\t`Testing plugin: Generating helpers for ${filteredContracts.length} contracts`,\n\t\t\t\t);\n\t\t\t}\n\n\t\t\t// Generate testing helpers\n\t\t\tconst testingCode = await generateTestingHelpers(\n\t\t\t\tfilteredContracts,\n\t\t\t\toptions,\n\t\t\t);\n\n\t\t\tconst outputPath = options.out || \"./src/generated/testing.ts\";\n\n\t\t\tcontext.addOutput(\"testing\", {\n\t\t\t\tpath: outputPath,\n\t\t\t\tcontent: testingCode,\n\t\t\t\ttype: \"utils\",\n\t\t\t});\n\n\t\t\tif (options.debug) {\n\t\t\t\tcontext.logger.debug(\n\t\t\t\t\t`Testing plugin: Generated helpers for ${filteredContracts.length} contracts`,\n\t\t\t\t);\n\t\t\t}\n\t\t},\n\t};\n};\n"
27
27
  ],
28
- "mappings": "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A;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAmEH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAsCH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAsCH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SA2BH;AAAA,MACJ,OAAO;AAAA,SAEH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SA6CH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAcH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAcH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAcH;AAAA,MACJ,OAA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",
29
- "debugId": "CF062C27A0D1420964756E2164756E21",
28
+ "mappings": "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AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAmEH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAsCH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAsCH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SA2BH;AAAA,MACJ,OAAO;AAAA,SAEH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SA6CH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAcH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAcH;AAAA,MACJ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAcH;AAAA,MACJ,OAAO;AAAA;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",
29
+ "debugId": "63411A134FE3EE3564756E2164756E21",
30
30
  "names": []
31
31
  }