@mercurjs/cli 2.2.0-canary.1 → 2.2.0-canary.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +5 -5
- package/dist/index.js.map +1 -1
- package/package.json +2 -2
package/dist/index.js
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import {Command}from'commander';import*as R from'path';import R__default,{join,basename}from'path';import De from'prompts';import {z}from'zod';import Lt,{promises,existsSync,readFileSync,mkdirSync,writeFileSync,statSync}from'fs';import {cosmiconfig}from'cosmiconfig';import {loadConfig,createMatchPath}from'tsconfig-paths';import A from'fs-extra';import dt from'fast-glob';import {createHash}from'crypto';import mr from'deepmerge';import*as U from'fs/promises';import U__default,{writeFile,rm}from'fs/promises';import {homedir,tmpdir}from'os';import {Project,ScriptKind}from'ts-morph';import F from'kleur';import mi from'ora';import {execa}from'execa';import {detect}from'@antfu/ni';import {diffLines}from'diff';import {spawn,execSync}from'child_process';import hs from'cross-spawn';import {packageDirectory}from'pkg-dir';import fs from'resolve-cwd';import {Readable}from'stream';import {pipeline}from'stream/promises';import $t from'pg';import Ws from'open';import {x as x$1}from'tar';import Vs from'terminal-link';import Ys from'validate-npm-package-name';import qs from'wait-on';import {builtinModules}from'module';import {generatePluginEntryModule}from'@mercurjs/dashboard-sdk';var Ae={version:"2.2.0-canary.
|
|
2
|
+
import {Command}from'commander';import*as R from'path';import R__default,{join,basename}from'path';import De from'prompts';import {z}from'zod';import Lt,{promises,existsSync,readFileSync,mkdirSync,writeFileSync,statSync}from'fs';import {cosmiconfig}from'cosmiconfig';import {loadConfig,createMatchPath}from'tsconfig-paths';import A from'fs-extra';import dt from'fast-glob';import {createHash}from'crypto';import mr from'deepmerge';import*as U from'fs/promises';import U__default,{writeFile,rm}from'fs/promises';import {homedir,tmpdir}from'os';import {Project,ScriptKind}from'ts-morph';import F from'kleur';import mi from'ora';import {execa}from'execa';import {detect}from'@antfu/ni';import {diffLines}from'diff';import {spawn,execSync}from'child_process';import hs from'cross-spawn';import {packageDirectory}from'pkg-dir';import fs from'resolve-cwd';import {Readable}from'stream';import {pipeline}from'stream/promises';import $t from'pg';import Ws from'open';import {x as x$1}from'tar';import Vs from'terminal-link';import Ys from'validate-npm-package-name';import qs from'wait-on';import {builtinModules}from'module';import {generatePluginEntryModule}from'@mercurjs/dashboard-sdk';var Ae={version:"2.2.0-canary.2"};var zt="MISSING_DIR_OR_EMPTY_PROJECT",E="MISSING_CONFIG",B="BUILD_MISSING_REGISTRY_FILE";var Ro=z.enum(["registry:api","registry:vendor","registry:admin"]),Bt=z.object({path:z.string(),content:z.string().optional(),type:Ro,target:z.string().optional()}),Wt=z.object({$schema:z.string().optional(),name:z.string(),title:z.string().optional(),author:z.string().min(2).optional(),description:z.string().optional(),dependencies:z.array(z.string()).optional(),devDependencies:z.array(z.string()).optional(),registryDependencies:z.array(z.string()).optional(),meta:z.record(z.string(),z.any()).optional(),docs:z.string().optional(),categories:z.array(z.string()).optional()}),T=Wt.extend({files:z.array(Bt)}),K=z.object({name:z.string(),homepage:z.string(),items:z.array(T)}),Pn=z.array(Wt),Gt=T.pick({dependencies:true,devDependencies:true,files:true,docs:true}),xo=z.union([z.string(),z.object({url:z.string(),params:z.record(z.string(),z.string()).optional(),headers:z.record(z.string(),z.string()).optional()})]),Vt=z.record(z.string().refine(e=>e.startsWith("@"),{message:"Registry names must start with @ (e.g., @mercurjs)"}),xo);var Le="https://registry.mercurjs.com/registry.json",Yt="https://registry.mercurjs.com/registry-item.json",we=process.env.REGISTRY_URL??"https://raw.githubusercontent.com/mercurjs/mercur/canary/packages/registry/r",I={"@mercurjs":`${we}/{name}.json`};var $={NOT_FOUND:"NOT_FOUND",UNAUTHORIZED:"UNAUTHORIZED",FORBIDDEN:"FORBIDDEN",FETCH_ERROR:"FETCH_ERROR",NOT_CONFIGURED:"NOT_CONFIGURED",INVALID_CONFIG:"INVALID_CONFIG",MISSING_ENV_VARS:"MISSING_ENV_VARS",LOCAL_FILE_ERROR:"LOCAL_FILE_ERROR",PARSE_ERROR:"PARSE_ERROR",VALIDATION_ERROR:"VALIDATION_ERROR",UNKNOWN_ERROR:"UNKNOWN_ERROR"},S=class extends Error{code;statusCode;context;suggestion;timestamp;cause;constructor(t,r={}){super(t),this.name="RegistryError",this.code=r.code||$.UNKNOWN_ERROR,this.statusCode=r.statusCode,this.cause=r.cause,this.context=r.context,this.suggestion=r.suggestion,this.timestamp=new Date,Error.captureStackTrace&&Error.captureStackTrace(this,this.constructor);}},ae=class extends S{constructor(r,o){let i=`The item at ${r} was not found. It may not exist at the registry.`;super(i,{code:$.NOT_FOUND,statusCode:404,cause:o,context:{url:r},suggestion:"Check if the item name is correct and the registry URL is accessible."});this.url=r;this.name="RegistryNotFoundError";}url},Ue=class extends S{constructor(r,o){let i=`You are not authorized to access the item at ${r}. If this is a remote registry, you may need to authenticate.`;super(i,{code:$.UNAUTHORIZED,statusCode:401,cause:o,context:{url:r},suggestion:"Check your authentication credentials and environment variables."});this.url=r;this.name="RegistryUnauthorizedError";}url},ze=class extends S{constructor(r,o){let i=`You are not authorized to access the item at ${r}. If this is a remote registry, you may need to authenticate.`;super(i,{code:$.FORBIDDEN,statusCode:403,cause:o,context:{url:r},suggestion:"Check your authentication credentials and environment variables."});this.url=r;this.name="RegistryForbiddenError";}url},Be=class extends S{constructor(r,o,i,s){let n=o?`Failed to fetch from registry (${o}): ${r}`:`Failed to fetch from registry: ${r}`,m=typeof s=="string"&&s?`${n} - ${s}`:n,p="Check your network connection and try again.";o===404?p="The requested resource was not found. Check the URL or item name.":o===500?p="The registry server encountered an error. Try again later.":o&&o>=400&&o<500&&(p="There was a client error. Check your request parameters.");super(m,{code:$.FETCH_ERROR,statusCode:o,cause:s,context:{url:r,responseBody:i},suggestion:p});this.url=r;this.responseBody=i;this.name="RegistryFetchError";}url;responseBody},Z=class extends S{constructor(r){let o=r?`Unknown registry "${r}". Make sure it is defined in agents.json as follows:
|
|
3
3
|
{
|
|
4
4
|
"registries": {
|
|
5
5
|
"${r}": "[URL_TO_REGISTRY]"
|
|
6
6
|
}
|
|
7
|
-
}`:'Unknown registry. Make sure it is defined in blocks.json under "registries".';super(o,{code:$.NOT_CONFIGURED,context:{registryName:r},suggestion:"Add the registry configuration to your blocks.json file. Consult the registry documentation for the correct format."});this.registryName=r;this.name="RegistryNotConfiguredError";}},Q=class extends S{constructor(r,o){super(`Failed to read local registry file: ${r}`,{code:$.LOCAL_FILE_ERROR,cause:o,context:{filePath:r},suggestion:"Check if the file exists and you have read permissions."});this.filePath=r;this.name="RegistryLocalFileError";}},C=class extends S{constructor(r,o){let i=`Failed to parse registry item: ${r}`;o instanceof z.ZodError&&(i=`Failed to parse registry item: ${r}
|
|
7
|
+
}`:'Unknown registry. Make sure it is defined in blocks.json under "registries".';super(o,{code:$.NOT_CONFIGURED,context:{registryName:r},suggestion:"Add the registry configuration to your blocks.json file. Consult the registry documentation for the correct format."});this.registryName=r;this.name="RegistryNotConfiguredError";}registryName},Q=class extends S{constructor(r,o){super(`Failed to read local registry file: ${r}`,{code:$.LOCAL_FILE_ERROR,cause:o,context:{filePath:r},suggestion:"Check if the file exists and you have read permissions."});this.filePath=r;this.name="RegistryLocalFileError";}filePath},C=class extends S{constructor(r,o){let i=`Failed to parse registry item: ${r}`;o instanceof z.ZodError&&(i=`Failed to parse registry item: ${r}
|
|
8
8
|
${o.issues.map(s=>` - ${s.path.join(".")}: ${s.message}`).join(`
|
|
9
|
-
`)}`);super(i,{code:$.PARSE_ERROR,cause:o,context:{item:r},suggestion:"The registry item may be corrupted or have an invalid format. Please make sure it returns a valid JSON object."});this.item=r;this.parseError=o,this.name="RegistryParseError";}parseError},We=class extends S{constructor(r,o){let i=`Registry "${r}" requires the following environment variables:
|
|
9
|
+
`)}`);super(i,{code:$.PARSE_ERROR,cause:o,context:{item:r},suggestion:"The registry item may be corrupted or have an invalid format. Please make sure it returns a valid JSON object."});this.item=r;this.parseError=o,this.name="RegistryParseError";}item;parseError},We=class extends S{constructor(r,o){let i=`Registry "${r}" requires the following environment variables:
|
|
10
10
|
|
|
11
11
|
`+o.map(s=>` \u2022 ${s}`).join(`
|
|
12
|
-
`);super(i,{code:$.MISSING_ENV_VARS,context:{registryName:r,missingVars:o},suggestion:"Set the required environment variables to your .env or .env.local file."});this.registryName=r;this.missingVars=o;this.name="RegistryMissingEnvironmentVariablesError";}},Ge=class extends S{constructor(r){let o=`Invalid registry namespace: "${r}". Registry names must start with @ (e.g., @mercurjs).`;super(o,{code:$.VALIDATION_ERROR,context:{name:r},suggestion:"Use a valid registry name starting with @ or provide a direct URL to the registry."});this.name=r;this.name="RegistryInvalidNamespaceError";}};var Ve=class extends S{constructor(r,o){let i=`Invalid blocks.json configuration in ${r}.`;o instanceof z.ZodError&&(i=`Invalid blocks.json configuration in ${r}:
|
|
12
|
+
`);super(i,{code:$.MISSING_ENV_VARS,context:{registryName:r,missingVars:o},suggestion:"Set the required environment variables to your .env or .env.local file."});this.registryName=r;this.missingVars=o;this.name="RegistryMissingEnvironmentVariablesError";}registryName;missingVars},Ge=class extends S{constructor(r){let o=`Invalid registry namespace: "${r}". Registry names must start with @ (e.g., @mercurjs).`;super(o,{code:$.VALIDATION_ERROR,context:{name:r},suggestion:"Use a valid registry name starting with @ or provide a direct URL to the registry."});this.name=r;this.name="RegistryInvalidNamespaceError";}name};var Ve=class extends S{constructor(r,o){let i=`Invalid blocks.json configuration in ${r}.`;o instanceof z.ZodError&&(i=`Invalid blocks.json configuration in ${r}:
|
|
13
13
|
${o.issues.map(s=>` - ${s.path.join(".")}: ${s.message}`).join(`
|
|
14
|
-
`)}`);super(i,{code:$.INVALID_CONFIG,cause:o,context:{cwd:r},suggestion:"Check your blocks.json file for syntax errors or invalid configuration. Run '@mercurjs/cli init' to regenerate a valid configuration."});this.cwd=r;this.name="ConfigParseError";}};var W=z.object({$schema:z.string().optional(),aliases:z.object({api:z.string(),vendor:z.string(),admin:z.string()}),registries:Vt.optional()}).strict(),Jt=W.extend({resolvedPaths:z.object({cwd:z.string(),api:z.string(),vendor:z.string(),admin:z.string()})});async function de(e,t){return createMatchPath(t.absoluteBaseUrl,t.paths)(e,void 0,()=>true,[".ts",".tsx"])}var Eo="packages/api/src",Io="apps/vendor/src",Co="apps/admin/src",Po=cosmiconfig("blocks",{searchPlaces:["blocks.json"]});async function b(e){let t=await To(e);return t?await at(e,t):null}async function at(e,t){t.registries={...t.registries||{},...I};let r=await loadConfig(e);if(r.resultType==="failed")throw new Error(`Failed to load tsconfig.json. ${r.message??""}`.trim());return Jt.parse({...t,resolvedPaths:{cwd:e,api:await de(t.aliases.api,r),vendor:await de(t.aliases.vendor,r),admin:await de(t.aliases.admin,r)}})}async function To(e){try{let t=await Po.search(e);if(!t)return null;let r=W.parse(t.config);if(r.registries){for(let o of Object.keys(r.registries))if(o in I)throw new Error(`"${o}" is a built-in registry and cannot be overridden.`)}return r}catch(t){throw t instanceof Error&&t.message.includes("reserved registry")?t:new Ve(e,t)}}function G(e){let t={resolvedPaths:{cwd:process.cwd(),api:"",vendor:"",admin:""},aliases:{api:Eo,vendor:Io,admin:Co},registries:{...I}};return e?{...t,...e,resolvedPaths:{...t.resolvedPaths,...e.resolvedPaths||{}},aliases:{...t.aliases,...e.aliases||{}},registries:{...t.registries,...e.registries||{}}}:t}var mt=["**/node_modules/**","public","dist"];async function _(e){let[t,r,o,i,s,n]=await Promise.all([A.pathExists(R__default.resolve(e,"src")),Do(e),je(e),Fo(e),No(e),Oo(e)]);return {isSrcDir:t,aliasPrefix:r,packageJson:o,medusaConfigFile:i?.file??null,medusaVersion:s,mercurVersion:n}}async function Do(e){let t=loadConfig(e);if(t.resultType==="failed")return null;let r=t.paths||{},o=Object.keys(r);if(o.length===0)return null;let i=o[0];return i?.includes("*")?i.replace("/*",""):i?.replace("/","")??null}function je(e="",t=true){let r=R__default.join(e,"package.json");return A.readJSONSync(r,{throws:t})}async function Fo(e){let t=await dt.glob("medusa-config.*",{cwd:e,deep:3,ignore:mt});if(!t.length)return null;let r=t[0];return {file:r,dir:R__default.resolve(e,R__default.dirname(r))}}async function No(e){let r=je(e,false)?.dependencies?.["@medusajs/framework"];if(r)return r;let o=await dt.glob("**/package.json",{cwd:e,deep:3,ignore:mt});for(let i of o){let n=je(R__default.join(e,R__default.dirname(i)),false)?.dependencies?.["@medusajs/framework"];if(n)return n}return null}async function Oo(e){let r=je(e,false)?.dependencies?.["@mercurjs/cli"];if(r)return r;let o=await dt.glob("**/package.json",{cwd:e,deep:3,ignore:mt});for(let i of o){let n=je(R__default.join(e,R__default.dirname(i)),false)?.dependencies?.["@mercurjs/cli"];if(n)return n}return null}z.object({cwd:z.string(),blocks:z.array(z.string()).optional(),yes:z.boolean(),overwrite:z.boolean(),silent:z.boolean()});async function Kt(e){let t={},r=R__default.resolve(e.cwd);if(!existsSync(r))return t[zt]=true,{errors:t,config:null};let o=await b(r);if(!o)return t[E]=true,{errors:t,config:null};let i=await _(r);return {errors:t,config:o,projectInfo:i}}var Ye={headers:{}};function pt(e){Ye.headers={...Ye.headers,...e};}function Zt(e){return Ye.headers[e]||{}}function x(){Ye.headers={};}function me(e){let t={aliases:{api:"packages/api/src",vendor:"apps/vendor/src",admin:"apps/admin/src"},registries:I};return {...t,...e||{},aliases:{...t.aliases,...e?.aliases||{}},registries:{...e?.registries||{},...I}}}function be(e){return e.replace(/\${(\w+)}/g,(t,r)=>process.env[r]||"")}function Re(e){let t=[],r=/\${(\w+)}/g,o=r.exec(e);for(;o!==null;){let i=o[1];i&&t.push(i),o=r.exec(e);}return t}var Lo=/^(@[a-zA-Z0-9](?:[a-zA-Z0-9-_]*[a-zA-Z0-9])?)\/(.+)$/;function pe(e){if(!e.startsWith("@"))return {registry:null,item:e};let t=e.match(Lo);return t?{registry:t[1],item:t[2]}:{registry:null,item:e}}var Qt=[".tsx",".ts"],Xt=["lib/utils.ts"],Go=[/^(react|react-dom)(\/.*)?$/,/^(node|jsr|npm):.*$/],Vo=new Project({compilerOptions:{}});function Yo(e){if(Go.some(t=>t.test(e)))return null;if(!e.startsWith("@")&&e.includes("/")&&(e=e.split("/")[0]),e.startsWith("@")){let t=e.split("/");t.length>2&&(e=t.slice(0,2).join("/"));}return e}async function ct(e,t,r,o=new Set){let i=R.resolve(t.resolvedPaths.cwd,e),s=R.relative(t.resolvedPaths.cwd,i);if(Xt.includes(s))return {dependencies:[],files:[]};let n=R.extname(e);if(!Qt.includes(n))return {dependencies:[],files:[]};if(o.has(s))return {dependencies:[],files:[]};o.add(s);try{if(!(await U.stat(i)).isFile())return {dependencies:[],files:[]}}catch{return {dependencies:[],files:[]}}let m=await U.readFile(i,"utf-8"),p=await qo(R.basename(i)),d=Vo.createSourceFile(p,m,{scriptKind:ScriptKind.TSX}),u=await loadConfig(t.resolvedPaths.cwd);if(u.resultType==="failed")return {dependencies:[],files:[]};let c=[],f=new Set,y=er(e),h={path:s,type:y,target:"",content:""};c.push(h);let j=d.getImportDeclarations();for(let N of j){let z=N.getModuleSpecifierValue(),Ne=z.startsWith(".");if(!(r.aliasPrefix&&z.startsWith(`${r.aliasPrefix}/`))&&!Ne){let O=Yo(z);O&&f.add(O);continue}let se=await de(z,u);if(Ne&&(se=R.resolve(R.dirname(i),z)),!se)continue;if(!R.extname(se))for(let O of Qt){let Ut=`${se}${O}`;try{await U.access(Ut),se=Ut;break}catch{continue}}let Oe=R.relative(t.resolvedPaths.cwd,se);if(o.has(Oe)||Xt.includes(Oe))continue;let wo=er(z),jo={path:Oe,type:wo,target:"",content:""};c.push(jo);let Me=await ct(Oe,t,r,o);if(Me.files)for(let O of Me.files)o.has(O.path)||(o.add(O.path),c.push(O));Me.dependencies&&Me.dependencies.forEach(O=>f.add(O));}let k=Array.from(new Map(c.map(N=>[N.path,N])).values());return {dependencies:Array.from(f),files:k}}async function qo(e){let t=await U.mkdtemp(R.join(tmpdir(),"mercur-"));return R.join(t,e)}function er(e){return e.includes("/vendor")?"registry:vendor":e.includes("/admin")?"registry:admin":"registry:api"}function q(e){try{return new URL(e),!0}catch{return false}}function ee(e){return e.endsWith(".json")&&!q(e)}function Jo(e){let t=new Set;if(typeof e=="string")for(let r of Re(e))t.add(r);else {for(let r of Re(e.url))t.add(r);if(e.params)for(let r of Object.values(e.params))for(let o of Re(r))t.add(o);if(e.headers)for(let r of Object.values(e.headers))for(let o of Re(r))t.add(o);}return Array.from(t)}function tr(e,t){let o=Jo(t).filter(i=>!process.env[i]);if(o.length>0)throw new We(e,o)}var qe="{name}",Ho=`${qe}.json`,rr=/\${(\w+)}/g,or="?",Ko="&";function Zo(e){return e.includes(qe)}function ir(e){return Zo(e)?e:`${e.endsWith("/")?e:`${e}/`}${Ho}`}function xe(e,t){let{registry:r,item:o}=pe(e);if(!r)return null;let s=(t?.registries||{})[r];if(!s)throw new Z(r);return tr(r,s),{url:Qo(o,s),headers:Xo(s)}}function Qo(e,t,r){if(typeof t=="string"){let n=ir(t).replace(qe,e);return be(n)}let i=ir(t.url).replace(qe,e);return i=be(i),t.params?ei(i,t.params):i}function Xo(e){if(typeof e=="string"||!e.headers)return {};let t={};for(let[r,o]of Object.entries(e.headers)){let i=be(o);ti(o,i)&&(t[r]=i);}return t}function ei(e,t){let r=new URLSearchParams;for(let[s,n]of Object.entries(t)){let m=be(n);m&&r.append(s,m);}let o=r.toString();if(!o)return e;let i=e.includes(or)?Ko:or;return `${e}${i}${o}`}function ti(e,t){let r=t.trim();if(!r)return false;if(e.includes("${")&&e.match(rr)){let i=e.replace(rr,"").trim();return r!==i}return true}function sr(e){return q(e)||ee(e)?e:`${we}/${e}`}var Je=new Map;async function ri(e){let t=e;t.startsWith("file://")&&(t=t.slice(7)),t.startsWith("~/")&&(t=R__default.join(homedir(),t.slice(2)));let r=R__default.resolve(t);try{let o=await promises.readFile(r,"utf8");return JSON.parse(o)}catch(o){throw o instanceof Error&&(o.message.includes("ENOENT")||o.message.includes("no such file"))?new Q(e,o):new Q(e,o)}}async function te(e){return await Promise.all(e.map(async r=>{let o=sr(r);if(Je.has(o))return Je.get(o);if(ee(o)){let s=ri(o);return Je.set(o,s),s}let i=(async()=>{let s=Zt(o),n=await fetch(o,{headers:{...s}});if(!n.ok){let m;if(n.headers.get("content-type")?.includes("application/json")){let p=await n.json(),d=z.object({detail:z.string().optional(),title:z.string().optional(),message:z.string().optional(),error:z.string().optional()}).safeParse(p);d.success&&(m=d.data.detail||d.data.message,d.data.error&&(m=`[${d.data.error}] ${m}`));}throw n.status===401?new Ue(o,m):n.status===404?new ae(o,m):n.status===403?new ze(o,m):new Be(o,n.status,m)}return n.json()})();return Je.set(o,i),i}))}async function dr(e){try{let t=e;e.startsWith("~/")&&(t=R__default.join(homedir(),e.slice(2)));let r=R__default.resolve(t),o=await promises.readFile(r,"utf8"),i=JSON.parse(o);try{return T.parse(i)}catch(s){throw new C(e,s)}}catch(t){throw t instanceof Error&&(t.message.includes("ENOENT")||t.message.includes("no such file"))?new Q(e,t):t instanceof C?t:new Q(e,t)}}T.extend({_source:z.string().optional()});function ut(e,t){let r={},o=[...e];if(!t?.registries)return pt({}),o;for(let i=0;i<o.length;i++){let s=xe(o[i],t);s&&(o[i]=s.url,Object.keys(s.headers).length>0&&(r[s.url]=s.headers));}return pt(r),o}async function Ke(e,t){return await Promise.all(e.map(async o=>{if(ee(o))return dr(o);if(q(o)){let[n]=await te([o]);try{return T.parse(n)}catch(m){throw new C(o,m)}}if(o.startsWith("@")&&t?.registries){let n=ut([o],t),[m]=await te(n);try{return T.parse(m)}catch(p){throw new C(o,p)}}let i=`${we}/${o}.json`,[s]=await te([i]);try{return T.parse(s)}catch(n){throw new C(o,n)}}))}async function lt(e,t){let r=[],o=[],i=Array.from(new Set(e)),s=await Ke(i,t),n=new Map;for(let d=0;d<s.length;d++)s[d]&&n.set(i[d],s[d]);for(let[d,u]of Array.from(n.entries())){let c={...u,_source:d};if(r.push(c),u.registryDependencies){let f=u.registryDependencies;if(t?.registries)f=ut(u.registryDependencies,t);else {let h=u.registryDependencies.filter(j=>j.startsWith("@"));if(h.length>0){let{registry:j}=pe(h[0]);throw new Z(j)}}let{blocks:y}=await cr(f,t,new Set(i));o.push(...y);}}r.push(...o);let m=new Map;for(let d of r){let u=d._source||d.name;m.set(d,u);}return r=ni(r,m),Gt.parse({dependencies:mr.all(r.map(d=>d.dependencies??[])),devDependencies:mr.all(r.map(d=>d.devDependencies??[])),files:ai(r.map(d=>d.files??[])),docs:r.map(d=>d.docs).filter(Boolean).join(`
|
|
14
|
+
`)}`);super(i,{code:$.INVALID_CONFIG,cause:o,context:{cwd:r},suggestion:"Check your blocks.json file for syntax errors or invalid configuration. Run '@mercurjs/cli init' to regenerate a valid configuration."});this.cwd=r;this.name="ConfigParseError";}cwd};var W=z.object({$schema:z.string().optional(),aliases:z.object({api:z.string(),vendor:z.string(),admin:z.string()}),registries:Vt.optional()}).strict(),Jt=W.extend({resolvedPaths:z.object({cwd:z.string(),api:z.string(),vendor:z.string(),admin:z.string()})});async function de(e,t){return createMatchPath(t.absoluteBaseUrl,t.paths)(e,void 0,()=>true,[".ts",".tsx"])}var Eo="packages/api/src",Io="apps/vendor/src",Co="apps/admin/src",Po=cosmiconfig("blocks",{searchPlaces:["blocks.json"]});async function b(e){let t=await To(e);return t?await at(e,t):null}async function at(e,t){t.registries={...t.registries||{},...I};let r=await loadConfig(e);if(r.resultType==="failed")throw new Error(`Failed to load tsconfig.json. ${r.message??""}`.trim());return Jt.parse({...t,resolvedPaths:{cwd:e,api:await de(t.aliases.api,r),vendor:await de(t.aliases.vendor,r),admin:await de(t.aliases.admin,r)}})}async function To(e){try{let t=await Po.search(e);if(!t)return null;let r=W.parse(t.config);if(r.registries){for(let o of Object.keys(r.registries))if(o in I)throw new Error(`"${o}" is a built-in registry and cannot be overridden.`)}return r}catch(t){throw t instanceof Error&&t.message.includes("reserved registry")?t:new Ve(e,t)}}function G(e){let t={resolvedPaths:{cwd:process.cwd(),api:"",vendor:"",admin:""},aliases:{api:Eo,vendor:Io,admin:Co},registries:{...I}};return e?{...t,...e,resolvedPaths:{...t.resolvedPaths,...e.resolvedPaths||{}},aliases:{...t.aliases,...e.aliases||{}},registries:{...t.registries,...e.registries||{}}}:t}var mt=["**/node_modules/**","public","dist"];async function _(e){let[t,r,o,i,s,n]=await Promise.all([A.pathExists(R__default.resolve(e,"src")),Do(e),je(e),Fo(e),No(e),Oo(e)]);return {isSrcDir:t,aliasPrefix:r,packageJson:o,medusaConfigFile:i?.file??null,medusaVersion:s,mercurVersion:n}}async function Do(e){let t=loadConfig(e);if(t.resultType==="failed")return null;let r=t.paths||{},o=Object.keys(r);if(o.length===0)return null;let i=o[0];return i?.includes("*")?i.replace("/*",""):i?.replace("/","")??null}function je(e="",t=true){let r=R__default.join(e,"package.json");return A.readJSONSync(r,{throws:t})}async function Fo(e){let t=await dt.glob("medusa-config.*",{cwd:e,deep:3,ignore:mt});if(!t.length)return null;let r=t[0];return {file:r,dir:R__default.resolve(e,R__default.dirname(r))}}async function No(e){let r=je(e,false)?.dependencies?.["@medusajs/framework"];if(r)return r;let o=await dt.glob("**/package.json",{cwd:e,deep:3,ignore:mt});for(let i of o){let n=je(R__default.join(e,R__default.dirname(i)),false)?.dependencies?.["@medusajs/framework"];if(n)return n}return null}async function Oo(e){let r=je(e,false)?.dependencies?.["@mercurjs/cli"];if(r)return r;let o=await dt.glob("**/package.json",{cwd:e,deep:3,ignore:mt});for(let i of o){let n=je(R__default.join(e,R__default.dirname(i)),false)?.dependencies?.["@mercurjs/cli"];if(n)return n}return null}z.object({cwd:z.string(),blocks:z.array(z.string()).optional(),yes:z.boolean(),overwrite:z.boolean(),silent:z.boolean()});async function Kt(e){let t={},r=R__default.resolve(e.cwd);if(!existsSync(r))return t[zt]=true,{errors:t,config:null};let o=await b(r);if(!o)return t[E]=true,{errors:t,config:null};let i=await _(r);return {errors:t,config:o,projectInfo:i}}var Ye={headers:{}};function pt(e){Ye.headers={...Ye.headers,...e};}function Zt(e){return Ye.headers[e]||{}}function x(){Ye.headers={};}function me(e){let t={aliases:{api:"packages/api/src",vendor:"apps/vendor/src",admin:"apps/admin/src"},registries:I};return {...t,...e||{},aliases:{...t.aliases,...e?.aliases||{}},registries:{...e?.registries||{},...I}}}function be(e){return e.replace(/\${(\w+)}/g,(t,r)=>process.env[r]||"")}function Re(e){let t=[],r=/\${(\w+)}/g,o=r.exec(e);for(;o!==null;){let i=o[1];i&&t.push(i),o=r.exec(e);}return t}var Lo=/^(@[a-zA-Z0-9](?:[a-zA-Z0-9-_]*[a-zA-Z0-9])?)\/(.+)$/;function pe(e){if(!e.startsWith("@"))return {registry:null,item:e};let t=e.match(Lo);return t?{registry:t[1],item:t[2]}:{registry:null,item:e}}var Qt=[".tsx",".ts"],Xt=["lib/utils.ts"],Go=[/^(react|react-dom)(\/.*)?$/,/^(node|jsr|npm):.*$/],Vo=new Project({compilerOptions:{}});function Yo(e){if(Go.some(t=>t.test(e)))return null;if(!e.startsWith("@")&&e.includes("/")&&(e=e.split("/")[0]),e.startsWith("@")){let t=e.split("/");t.length>2&&(e=t.slice(0,2).join("/"));}return e}async function ct(e,t,r,o=new Set){let i=R.resolve(t.resolvedPaths.cwd,e),s=R.relative(t.resolvedPaths.cwd,i);if(Xt.includes(s))return {dependencies:[],files:[]};let n=R.extname(e);if(!Qt.includes(n))return {dependencies:[],files:[]};if(o.has(s))return {dependencies:[],files:[]};o.add(s);try{if(!(await U.stat(i)).isFile())return {dependencies:[],files:[]}}catch{return {dependencies:[],files:[]}}let m=await U.readFile(i,"utf-8"),p=await qo(R.basename(i)),d=Vo.createSourceFile(p,m,{scriptKind:ScriptKind.TSX}),u=await loadConfig(t.resolvedPaths.cwd);if(u.resultType==="failed")return {dependencies:[],files:[]};let c=[],f=new Set,y=er(e),h={path:s,type:y,target:"",content:""};c.push(h);let j=d.getImportDeclarations();for(let N of j){let z=N.getModuleSpecifierValue(),Ne=z.startsWith(".");if(!(r.aliasPrefix&&z.startsWith(`${r.aliasPrefix}/`))&&!Ne){let O=Yo(z);O&&f.add(O);continue}let se=await de(z,u);if(Ne&&(se=R.resolve(R.dirname(i),z)),!se)continue;if(!R.extname(se))for(let O of Qt){let Ut=`${se}${O}`;try{await U.access(Ut),se=Ut;break}catch{continue}}let Oe=R.relative(t.resolvedPaths.cwd,se);if(o.has(Oe)||Xt.includes(Oe))continue;let wo=er(z),jo={path:Oe,type:wo,target:"",content:""};c.push(jo);let Me=await ct(Oe,t,r,o);if(Me.files)for(let O of Me.files)o.has(O.path)||(o.add(O.path),c.push(O));Me.dependencies&&Me.dependencies.forEach(O=>f.add(O));}let k=Array.from(new Map(c.map(N=>[N.path,N])).values());return {dependencies:Array.from(f),files:k}}async function qo(e){let t=await U.mkdtemp(R.join(tmpdir(),"mercur-"));return R.join(t,e)}function er(e){return e.includes("/vendor")?"registry:vendor":e.includes("/admin")?"registry:admin":"registry:api"}function q(e){try{return new URL(e),!0}catch{return false}}function ee(e){return e.endsWith(".json")&&!q(e)}function Jo(e){let t=new Set;if(typeof e=="string")for(let r of Re(e))t.add(r);else {for(let r of Re(e.url))t.add(r);if(e.params)for(let r of Object.values(e.params))for(let o of Re(r))t.add(o);if(e.headers)for(let r of Object.values(e.headers))for(let o of Re(r))t.add(o);}return Array.from(t)}function tr(e,t){let o=Jo(t).filter(i=>!process.env[i]);if(o.length>0)throw new We(e,o)}var qe="{name}",Ho=`${qe}.json`,rr=/\${(\w+)}/g,or="?",Ko="&";function Zo(e){return e.includes(qe)}function ir(e){return Zo(e)?e:`${e.endsWith("/")?e:`${e}/`}${Ho}`}function xe(e,t){let{registry:r,item:o}=pe(e);if(!r)return null;let s=(t?.registries||{})[r];if(!s)throw new Z(r);return tr(r,s),{url:Qo(o,s),headers:Xo(s)}}function Qo(e,t,r){if(typeof t=="string"){let n=ir(t).replace(qe,e);return be(n)}let i=ir(t.url).replace(qe,e);return i=be(i),t.params?ei(i,t.params):i}function Xo(e){if(typeof e=="string"||!e.headers)return {};let t={};for(let[r,o]of Object.entries(e.headers)){let i=be(o);ti(o,i)&&(t[r]=i);}return t}function ei(e,t){let r=new URLSearchParams;for(let[s,n]of Object.entries(t)){let m=be(n);m&&r.append(s,m);}let o=r.toString();if(!o)return e;let i=e.includes(or)?Ko:or;return `${e}${i}${o}`}function ti(e,t){let r=t.trim();if(!r)return false;if(e.includes("${")&&e.match(rr)){let i=e.replace(rr,"").trim();return r!==i}return true}function sr(e){return q(e)||ee(e)?e:`${we}/${e}`}var Je=new Map;async function ri(e){let t=e;t.startsWith("file://")&&(t=t.slice(7)),t.startsWith("~/")&&(t=R__default.join(homedir(),t.slice(2)));let r=R__default.resolve(t);try{let o=await promises.readFile(r,"utf8");return JSON.parse(o)}catch(o){throw o instanceof Error&&(o.message.includes("ENOENT")||o.message.includes("no such file"))?new Q(e,o):new Q(e,o)}}async function te(e){return await Promise.all(e.map(async r=>{let o=sr(r);if(Je.has(o))return Je.get(o);if(ee(o)){let s=ri(o);return Je.set(o,s),s}let i=(async()=>{let s=Zt(o),n=await fetch(o,{headers:{...s}});if(!n.ok){let m;if(n.headers.get("content-type")?.includes("application/json")){let p=await n.json(),d=z.object({detail:z.string().optional(),title:z.string().optional(),message:z.string().optional(),error:z.string().optional()}).safeParse(p);d.success&&(m=d.data.detail||d.data.message,d.data.error&&(m=`[${d.data.error}] ${m}`));}throw n.status===401?new Ue(o,m):n.status===404?new ae(o,m):n.status===403?new ze(o,m):new Be(o,n.status,m)}return n.json()})();return Je.set(o,i),i}))}async function dr(e){try{let t=e;e.startsWith("~/")&&(t=R__default.join(homedir(),e.slice(2)));let r=R__default.resolve(t),o=await promises.readFile(r,"utf8"),i=JSON.parse(o);try{return T.parse(i)}catch(s){throw new C(e,s)}}catch(t){throw t instanceof Error&&(t.message.includes("ENOENT")||t.message.includes("no such file"))?new Q(e,t):t instanceof C?t:new Q(e,t)}}T.extend({_source:z.string().optional()});function ut(e,t){let r={},o=[...e];if(!t?.registries)return pt({}),o;for(let i=0;i<o.length;i++){let s=xe(o[i],t);s&&(o[i]=s.url,Object.keys(s.headers).length>0&&(r[s.url]=s.headers));}return pt(r),o}async function Ke(e,t){return await Promise.all(e.map(async o=>{if(ee(o))return dr(o);if(q(o)){let[n]=await te([o]);try{return T.parse(n)}catch(m){throw new C(o,m)}}if(o.startsWith("@")&&t?.registries){let n=ut([o],t),[m]=await te(n);try{return T.parse(m)}catch(p){throw new C(o,p)}}let i=`${we}/${o}.json`,[s]=await te([i]);try{return T.parse(s)}catch(n){throw new C(o,n)}}))}async function lt(e,t){let r=[],o=[],i=Array.from(new Set(e)),s=await Ke(i,t),n=new Map;for(let d=0;d<s.length;d++)s[d]&&n.set(i[d],s[d]);for(let[d,u]of Array.from(n.entries())){let c={...u,_source:d};if(r.push(c),u.registryDependencies){let f=u.registryDependencies;if(t?.registries)f=ut(u.registryDependencies,t);else {let h=u.registryDependencies.filter(j=>j.startsWith("@"));if(h.length>0){let{registry:j}=pe(h[0]);throw new Z(j)}}let{blocks:y}=await cr(f,t,new Set(i));o.push(...y);}}r.push(...o);let m=new Map;for(let d of r){let u=d._source||d.name;m.set(d,u);}return r=ni(r,m),Gt.parse({dependencies:mr.all(r.map(d=>d.dependencies??[])),devDependencies:mr.all(r.map(d=>d.devDependencies??[])),files:ai(r.map(d=>d.files??[])),docs:r.map(d=>d.docs).filter(Boolean).join(`
|
|
15
15
|
`)})}async function cr(e,t,r=new Set){let o=[];for(let i of e){if(r.has(i))continue;if(r.add(i),i.startsWith("@")&&t?.registries){let{registry:n}=pe(i);if(n&&!(n in t.registries))throw new Z(n)}let[s]=await Ke([i],t);if(s&&(o.push({...s,_source:i}),s.registryDependencies)){let n=t?.registries?ut(s.registryDependencies,t):s.registryDependencies,m=await cr(n,t,r);o.push(...m.blocks);}}return {blocks:o}}function J(e,t){let r=t||e.name,o=createHash("sha256").update(r).digest("hex").substring(0,8);return `${e.name}::${o}`}function si(e){if(q(e)){let o=new URL(e).pathname,i=o.match(/\/([^/]+)\.json$/),s=i?i[1]:R__default.basename(o,".json");return {name:s,hash:J({name:s},e)}}if(ee(e)){let r=e.match(/\/([^/]+)\.json$/),o=r?r[1]:R__default.basename(e,".json");return {name:o,hash:J({name:o},e)}}let{item:t}=pe(e);return {name:t,hash:J({name:t},e)}}function ni(e,t){let r=new Map,o=new Map,i=new Map,s=new Map;for(let d of e){let u=t.get(d)||d.name,c=J(d,u);r.set(c,d),o.set(c,d),i.set(c,0),s.set(c,[]);}let n=new Map;for(let d of e){let u=t.get(d)||d.name,c=J(d,u);n.has(d.name)||n.set(d.name,[]),n.get(d.name).push(c),u!==d.name&&(n.has(u)||n.set(u,[]),n.get(u).push(c));}for(let d of e){let u=t.get(d)||d.name,c=J(d,u);if(d.registryDependencies)for(let f of d.registryDependencies){let y,h=n.get(f)||[];if(h.length===1)y=h[0];else if(h.length>1)y=h[0];else {let{name:j}=si(f),k=n.get(j)||[];k.length>0&&(y=k[0]);}y&&r.has(y)&&(s.get(y).push(c),i.set(c,i.get(c)+1));}}let m=[],p=[];for(let[d,u]of i)u===0&&m.push(d);for(;m.length>0;){let d=m.shift(),u=r.get(d);p.push(u);for(let c of s.get(d)){let f=i.get(c)-1;i.set(c,f),f===0&&m.push(c);}}if(p.length!==e.length){let d=Array.from(r.keys()).filter(u=>!p.some(c=>J(c,t.get(c))===u));console.warn(`Warning: Circular dependencies detected. Some items may not be sorted correctly: ${d.join(", ")}`);for(let[u,c]of r.entries())p.some(f=>J(f,t.get(f))===u)||p.push(c);}return p}function ai(e){let t=new Map,r=[];for(let o of e)if(o)for(let i of o){let s=i.target||i.path;t.has(s)||(t.set(s,i),r.push(i));}return r}var l={error:e=>F.red(e),warn:e=>F.yellow(e),info:e=>F.blue(e),success:e=>F.green(e),dim:e=>F.cyan(e)};var a={error(...e){console.log(l.error(e.join(" ")));},warn(...e){console.log(l.warn(e.join(" ")));},info(...e){console.log(l.info(e.join(" ")));},success(...e){console.log(l.success(e.join(" ")));},log(...e){console.log(e.join(" "));},break(){console.log("");}};function w(e){if(a.break(),a.error("Something went wrong. Please check the error below for more details."),a.error("If the problem persists, please open an issue on GitHub."),a.error(""),typeof e=="string"&&(a.error(e),a.break(),process.exit(1)),e instanceof S&&(e.message&&(a.error(e.cause?"Error:":"Message:"),a.error(e.message)),e.cause&&(a.error(`
|
|
16
16
|
Message:`),a.error(e.cause)),e.suggestion&&(a.error(`
|
|
17
17
|
Suggestion:`),a.error(e.suggestion)),a.break(),process.exit(1)),e instanceof z.ZodError){a.error("Validation failed:");for(let t of e.issues){let r=t.path.join(".")||"root";a.error(`- ${l.info(r)}: ${t.message}`);}a.break(),process.exit(1);}e instanceof Error&&(a.error(e.message),a.break(),process.exit(1)),a.break(),process.exit(1);}function v(e,t){return mi({text:e,isSilent:t?.silent??false})}async function M(e){let t=await detect({programmatic:true,cwd:e});if(t?.startsWith("bun"))return "bun";if(t?.startsWith("yarn"))return "yarn";if(t?.startsWith("pnpm"))return "pnpm";if(t?.startsWith("deno"))return "deno";if(t?.startsWith("npm"))return "npm";let r=process.env.npm_config_user_agent||"";return r.startsWith("bun")?"bun":r.startsWith("yarn")?"yarn":r.startsWith("pnpm")?"pnpm":r.startsWith("deno")?"deno":"npm"}async function ur(e,t,r,o={}){if(e=Array.from(new Set(e||[])),t=Array.from(new Set(t||[])),!e?.length&&!t?.length)return;o={silent:false,...o};let i=v("Installing dependencies.",{silent:o.silent})?.start(),s=await M(r.resolvedPaths.cwd);i?.start(),await ci(s,e,t,r.resolvedPaths.cwd),i?.succeed();}async function ci(e,t,r,o){if(e==="npm")return ui(t,r,o);if(e==="deno")return li(t,r,o);t?.length&&await execa(e,["add",...t],{cwd:o}),r?.length&&await execa(e,["add","-D",...r],{cwd:o});}async function ui(e,t,r){e.length&&await execa("npm",["install",...e],{cwd:r}),t.length&&await execa("npm",["install","-D",...t],{cwd:r});}async function li(e,t,r){e?.length&&await execa("deno",["add",...e.map(o=>`npm:${o}`)],{cwd:r}),t?.length&&await execa("deno",["add","-D",...t.map(o=>`npm:${o}`)],{cwd:r});}function lr(e,t,r={}){let{ignoreImports:o=false}=r,i=e.replace(/\r\n/g,`
|