@0xobelisk/sui-cli 0.5.29 → 0.5.30

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/dubhe.js CHANGED
@@ -1,51 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import ko from"yargs";import{hideBin as So}from"yargs/helpers";import{Dubhe as Ue}from"@0xobelisk/sui-client";import{Transaction as W}from"@mysten/sui/transactions";import{getFullnodeUrl as Le,SuiClient as Ke}from"@mysten/sui/client";import{execSync as je}from"child_process";import $ from"chalk";import R from"chalk";import{ZodError as Se}from"zod";import{fromZodError as Ie,ValidationError as $e}from"zod-validation-error";var J=class extends Error{name="NotInsideProjectError";message="You are not inside a Dubhe project"},w=class extends Error{name="DubheCliError"},T=class extends Error{name="UpgradeError"},V=class extends Error{name="FsIibError"};function D(e){if(e instanceof $e)console.log(R.redBright(e.message));else if(e instanceof Se){let o=Ie(e,{prefixSeparator:`
3
- - `,issueSeparator:`
4
- - `});console.log(R.redBright(o.message))}else e instanceof J?(console.log(R.red(e.message)),console.log(""),console.log(R.blue("To learn more about Dubhe's configuration, please go to https://github.com/0xobelisk"))):e instanceof w?console.log(R.red(e)):console.log(e)}import*as Z from"fs/promises";import{mkdirSync as Ne,writeFileSync as Fe}from"fs";import{dirname as Re}from"path";import{SUI_PRIVATE_KEY_PREFIX as Oe}from"@mysten/sui/cryptography";import{execSync as Ee,spawn as Pe}from"child_process";import y from"chalk";function De(){try{let e=process.platform==="win32"?'tasklist /FI "IMAGENAME eq sui.exe" /FO CSV /NH':'pgrep -f "sui start"',o=Ee(e).toString().trim();return process.platform==="win32"?o.toLowerCase().includes("sui.exe"):o.length>0}catch{return!1}}async function U(e=!1){if(console.log(`
5
- \u{1F50D} Checking Local Node Status...`),console.log(" \u251C\u2500 Scanning running processes"),De()){console.log(y.yellow(`
6
- \u26A0\uFE0F Warning: Local Node Already Running`)),console.log(y.yellow(" \u251C\u2500 Cannot start a new instance")),console.log(y.yellow(" \u2514\u2500 Please stop the existing process first"));return}console.log(`
7
- \u{1F680} Starting Local Node...`),console.log(" \u251C\u2500 Mode: "+(e?"Background":"Foreground")),console.log(" \u251C\u2500 Faucet: Enabled"),console.log(" \u2514\u2500 Force Regenesis: Yes");try{let o=Pe("sui",["start","--with-faucet","--force-regenesis"],{env:{...process.env,RUST_LOG:"off,sui_node=info"},stdio:e?"ignore":"inherit",detached:e});o.on("error",t=>{console.error(y.red(`
8
- \u274C Failed to Start Local Node`)),console.error(y.red(` \u2514\u2500 Error: ${t.message}`))}),e?(o.unref(),console.log(y.green(`
9
- \u2705 Local Node Started in Background`)),process.platform==="win32"?(console.log(`
10
- \u{1F4A1} Helpful Commands:`),console.log(" \u251C\u2500 Check Process: tasklist | findstr sui.exe"),console.log(" \u2514\u2500 Stop Node: taskkill /PID <process_id> /F")):(console.log(`
11
- \u{1F4A1} Helpful Commands:`),console.log(" \u251C\u2500 Check Process: pgrep -f 'sui start'"),console.log(" \u2514\u2500 Stop Node: kill <process_id>"))):(o.on("exit",t=>{t===0?(console.log(y.green(`
12
- \u2705 Local Node Stopped`)),console.log(y.green(" \u2514\u2500 Exit Status: Normal"))):(console.error(y.red(`
13
- \u274C Local Node Crashed`)),console.error(y.red(` \u2514\u2500 Exit Code: ${t}`)))}),console.log(y.cyan(`
14
- \u{1F4E1} Local Node Running`)),console.log(y.cyan(" \u2514\u2500 Press Ctrl+C to stop")),await new Promise(()=>{}))}catch(o){console.error(y.red(`
15
- \u274C Failed to Start Local Node`)),console.error(y.red(` \u2514\u2500 Error: ${o.message}`))}}import{execSync as Me}from"child_process";import k from"chalk";async function q(){console.log(`
16
- \u{1F50D} Checking Local Node Status...`);try{let e=process.platform==="win32"?'tasklist /FI "IMAGENAME eq sui.exe" /FO CSV /NH':"ps aux | grep '[s]ui start --with-faucet --force-regenesis'",o=Me(e,{encoding:"utf8"});(process.platform==="win32"?o.toLowerCase().includes("sui.exe"):o.split(`
17
- `).filter(Boolean).length>0)?(console.log(k.green(`
18
- \u2705 Node Status: Running`)),console.log(k.gray(`
19
- \u{1F4CA} Process Details:`)),console.log(k.gray(` \u2514\u2500 ${o.trim()}`))):(console.log(k.red(`
20
- \u274C Node Status: Not Running`)),console.log(k.yellow(`
21
- \u{1F4A1} Quick Start:`)),console.log(k.yellow(" \u2514\u2500 Run `dubhe localnode start`")))}catch{console.log(k.red(`
22
- \u274C Node Status: Not Running`)),console.log(k.yellow(`
23
- \u{1F4A1} Quick Start:`)),console.log(k.yellow(" \u2514\u2500 Run `dubhe localnode start`"))}}import{execSync as Q}from"child_process";async function L(){console.log("Stopping local node...");try{let e=process.platform==="win32"?'tasklist /FI "IMAGENAME eq sui.exe" /FO CSV /NH':"ps aux | grep '[s]ui start --with-faucet --force-regenesis'",o=Q(e,{encoding:"utf8"});if(!o){console.log("No running local node process found");return}let t;if(process.platform==="win32"){let s=o.match(/"sui\.exe",["']?(\d+)/i);t=s?s[1]:null}else t=o.toString().split(/\s+/)[1];if(!t){console.log("No running local node process found");return}process.platform==="win32"?Q(`taskkill /PID ${t} /F`):process.kill(Number(t)),console.log("\u2705 Local node stopped successfully")}catch(e){e.code==="ESRCH"||e.message.includes("no running tasks")?console.log("No running local node process found"):console.error("\u274C Error stopping local node:",e.message)}}import*as K from"fs";import S from"chalk";import{spawn as Ae}from"child_process";function M(e){if(e.startsWith(Oe))return e.length===70?e:!1;if(e.startsWith("0x")){let o=e.slice(2);return o.length===64?o:!1}else return e.length===64?e:!1}async function O(e,o){try{let t=await Z.readFile(`${e}/.history/sui_${o}/latest.json`,"utf8");return JSON.parse(t)}catch{throw new V("Fs read deployment file failed.")}}async function X(e,o){return(await O(e,o)).schemas}async function ee(e,o){return(await O(e,o)).version}async function oe(e,o){return(await O(e,o)).packageId}async function te(e,o){return(await O(e,o)).upgradeCap}async function j(e,o){return(await O(e,o)).schemaHub}function A(e,o,t,s,n,u,c){let d={projectName:e,network:o,packageId:t,schemas:c,upgradeCap:s,schemaHub:n,version:u},l=process.cwd(),r=JSON.stringify(d,null,2);Te(r,`${l}/contracts/${e}/.history/sui_${o}/latest.json`,"Update deploy log")}async function Te(e,o,t){Ne(Re(o),{recursive:!0}),Fe(o,e),t!==void 0&&console.log(`${t}: ${o}`)}function Ve(e){switch(e){case"localnet":return'Dubhe = { local = "../dubhe-framework" }';case"testnet":return'Dubhe = { git = "https://github.com/0xobelisk/dubhe-framework.git", rev = "dubhe-testnet-v1.0.0" }';case"mainnet":return'Dubhe = { git = "https://github.com/0xobelisk/dubhe-framework.git", rev = "dubhe-mainnet-v1.0.0" }';default:throw new Error(`Unsupported network: ${e}`)}}function ne(e,o){let t=K.readFileSync(e,"utf-8"),s=Ve(o),n=t.replace(/Dubhe = \{.*\}/,s);K.writeFileSync(e,n,"utf-8"),console.log(`Updated Dubhe dependency in ${e} for ${o}.`)}async function H(e){try{return new Promise((o,t)=>{let s=Ae("sui",["client","switch","--env",e],{env:{...process.env},stdio:"pipe"});s.stdout.on("data",n=>{console.log(S.green(`${n.toString()}`))}),s.stderr.on("data",n=>{console.error(S.red(`
24
- \u274C Failed to Switch Env`)),console.error(S.red(` Error: ${n.toString()}`))}),s.on("error",n=>{console.error(S.red(`
25
- \u274C Failed to Switch Env`)),console.error(S.red(` Error: ${n.message}`)),t(n)}),s.on("exit",n=>{n!==0?(console.error(S.red(`
26
- \u274C Process exited with code: ${n}`)),t(new Error(`Process exited with code: ${n}`))):(console.log(S.green(`
27
- \u2705 Environment switched successfully.`)),o())})})}catch(o){console.error(S.red(`
28
- \u274C Failed to Switch Env`)),console.error(S.red(` \u2514\u2500 Error: ${o}`))}}var se=e=>new Promise(o=>setTimeout(o,e));import*as E from"fs";import*as re from"path";async function He(e){switch(e){case"localnet":{let o=process.cwd();return await j(`${o}/contracts/dubhe-framework`,e)}case"testnet":return"0x8dbf8d28ac027ba214c9e0951b09f6842843be6cb87242b7d9a326a2677cd47a";default:return"0x8dbf8d28ac027ba214c9e0951b09f6842843be6cb87242b7d9a326a2677cd47a"}}function ae(e,o){if(!E.existsSync(e))return;let t=E.readFileSync(e,"utf-8"),s=new RegExp(`\\[env\\.${o}\\][\\s\\S]*?(?=\\[|$)`,"g"),n=t.replace(s,"");E.writeFileSync(e,n,"utf-8")}function ie(e,o,t,s,n){let u=re.resolve(e),c=E.readFileSync(u,"utf-8"),d=c.split(`
29
- `),l=d.findIndex(h=>h.trim()===`[env.${o}]`),r={chainId:s,originalPublishedId:"",latestPublishedId:"",publishedVersion:0};if(l===-1)if(t==="publish")r.originalPublishedId=n,r.latestPublishedId=n,r.publishedVersion=1;else throw new Error(`Network type [env.${o}] not found in the file and cannot upgrade.`);else{for(let h=l+1;h<d.length;h++){let b=d[h].trim();if(b.startsWith("["))break;let[C,_]=b.split("=").map(v=>v.trim().replace(/"/g,""));switch(C){case"original-published-id":r.originalPublishedId=_;break;case"latest-published-id":r.latestPublishedId=_;break;case"published-version":r.publishedVersion=parseInt(_,10);break}}t==="publish"?(r.originalPublishedId=n,r.latestPublishedId=n,r.publishedVersion=1):t==="upgrade"&&(r.latestPublishedId=n,r.publishedVersion+=1)}let p=`
30
- [env.${o}]
31
- chain-id = "${r.chainId}"
32
- original-published-id = "${r.originalPublishedId}"
33
- latest-published-id = "${r.latestPublishedId}"
34
- published-version = "${r.publishedVersion}"
35
- `,f=l===-1?c+p:d.slice(0,l).join(`
36
- `)+p;E.writeFileSync(u,f,"utf-8")}function Be(e){return e.split("_").map((o,t)=>o.charAt(0).toUpperCase()+o.slice(1).toLowerCase()).join("")}function Ye(e){let o=e.split("::");return o.length>0?o[o.length-1]:""}function ce(e){let o,t;try{let s=JSON.parse(je(`sui move build --dump-bytecode-as-base64 --path ${e}`,{encoding:"utf-8"}));o=s.modules,t=s.dependencies,console.log(" \u2514\u2500 Build successful")}catch(s){console.error($.red(" \u2514\u2500 Build failed")),console.error(s.stdout),process.exit(1)}return[o,t]}async function Ge(e,o,t,s,n){let u=await He(s);console.log("dappsObjectId",u);let c=await e.getChainIdentifier();ae(`${n}/Move.lock`,s),console.log(`
37
- \u{1F680} Starting Contract Publication...`),console.log(` \u251C\u2500 Project: ${n}`),console.log(` \u251C\u2500 Network: ${s}`),console.log(` \u251C\u2500 ChainId: ${c}`),console.log(" \u251C\u2500 Validating Environment...");let d=o.getKeypair();console.log(` \u2514\u2500 Account: ${d.toSuiAddress()}`),console.log(`
38
- \u{1F4E6} Building Contract...`);let[l,r]=ce(n);console.log(`
39
- \u{1F504} Publishing Contract...`);let p=new W,[f]=p.publish({modules:l,dependencies:r});p.transferObjects([f],d.toSuiAddress());let h;try{h=await e.signAndExecuteTransaction({signer:d,transaction:p,options:{showObjectChanges:!0}})}catch(i){console.error($.red(" \u2514\u2500 Publication failed")),console.error(i.message),process.exit(1)}h.effects?.status.status==="failure"&&(console.log($.red(" \u2514\u2500 Publication failed")),process.exit(1)),console.log(" \u251C\u2500 Processing publication results...");let b=1,C="",_=[],v="",a="";h.objectChanges.map(i=>{i.type==="published"&&(console.log(` \u251C\u2500 Package ID: ${i.packageId}`),C=i.packageId),i.type==="created"&&i.objectType==="0x2::package::UpgradeCap"&&(console.log(` \u251C\u2500 Upgrade Cap: ${i.objectId}`),v=i.objectId),i.type==="created"&&i.objectType.includes("schema_hub")&&(console.log(` \u251C\u2500 Schema Hub: ${i.objectId}`),a=i.objectId)}),console.log(` \u2514\u2500 Transaction: ${h.digest}`),ie(`${n}/Move.lock`,s,"publish",c,C),console.log(`
40
- \u26A1 Executing Deploy Hook...`),await se(5e3);let g=new W;g.setGasBudget(2e9);let[I]=g.splitCoins(g.gas,["1000000000"]);g.moveCall({target:`${C}::deploy_hook::run`,arguments:[g.object(a),g.object(u),g.object(v),g.object("0x6"),I]});let m;try{m=await e.signAndExecuteTransaction({signer:d,transaction:g,options:{showEffects:!0,showObjectChanges:!0}})}catch(i){console.error($.red(" \u2514\u2500 Deploy hook execution failed")),console.error(i.message),process.exit(1)}m.effects?.status.status==="success"?(console.log(" \u251C\u2500 Hook execution successful"),console.log(` \u251C\u2500 Transaction: ${m.digest}`),console.log(`
41
- \u{1F4CB} Created Schemas:`),m.objectChanges?.map(i=>{if(i.type==="created"&&i.objectType.includes("_schema")&&!i.objectType.includes("dynamic_field")){console.log(` \u251C\u2500 ${i.objectType}`),console.log(` \u2514\u2500 ID: ${i.objectId}`);let x={};for(let F in t.schemas)Be(F)===Ye(i.objectType)&&(x=t.schemas[F].structure);_.push({name:i.objectType,objectId:i.objectId,structure:x})}}),A(t.name,s,C,v,a,b,_),console.log(`
42
- \u2705 Contract Publication Complete
43
- `)):(console.log($.yellow(" \u2514\u2500 Deploy hook execution failed")),console.log($.yellow(" Please republish or manually call deploy_hook::run")))}async function Je(e,o,t){let n=`${process.cwd()}/contracts/dubhe-framework`,u=await e.getChainIdentifier();console.log(` \u2514\u2500 Chain ID: ${u}`),ae(`${n}/Move.lock`,t),console.log(`
44
- \u{1F680} Starting Contract Publication...`),console.log(` \u251C\u2500 Project: ${n}`),console.log(` \u251C\u2500 Network: ${t}`),console.log(` \u251C\u2500 ChainId: ${u}`),console.log(" \u251C\u2500 Validating Environment...");let c=o.getKeypair();console.log(` \u2514\u2500 Account: ${c.toSuiAddress()}`),console.log(`
45
- \u{1F4E6} Building Contract...`);let[d,l]=ce(n);console.log(`
46
- \u{1F504} Publishing Contract...`);let r=new W,[p]=r.publish({modules:d,dependencies:l});r.transferObjects([p],c.toSuiAddress());let f;try{f=await e.signAndExecuteTransaction({signer:c,transaction:r,options:{showObjectChanges:!0}})}catch(a){console.error($.red(" \u2514\u2500 Publication failed")),console.error(a.message),process.exit(1)}f.effects?.status.status==="failure"&&(console.log($.red(" \u2514\u2500 Publication failed")),process.exit(1)),console.log(" \u251C\u2500 Processing publication results...");let h=1,b="",C=[],_="",v="";f.objectChanges.map(a=>{a.type==="published"&&(console.log(` \u251C\u2500 Package ID: ${a.packageId}`),b=a.packageId),a.type==="created"&&a.objectType==="0x2::package::UpgradeCap"&&(console.log(` \u251C\u2500 Upgrade Cap: ${a.objectId}`),_=a.objectId),a.type==="created"&&a.objectType.includes("dapps")&&(console.log(` \u251C\u2500 Dapps: ${a.objectId}`),v=a.objectId)}),console.log(` \u2514\u2500 Transaction: ${f.digest}`),ie(`${n}/Move.lock`,t,"publish",u,b),A("dubhe-framework",t,b,_,v,h,C)}async function le(e,o,t){await H(o);let s=process.env.PRIVATE_KEY;if(!s)throw new w(`Missing PRIVATE_KEY environment variable.
47
- Run 'echo "PRIVATE_KEY=YOUR_PRIVATE_KEY" > .env'
48
- in your contracts directory to use the default sui private key.`);let n=M(s);if(n===!1)throw new w("Please check your privateKey.");let u=new Ue({secretKey:n}),c=new Ke({url:Le(o)});if(t=="dubhe-framework")await Je(c,u,o);else{let l=`${process.cwd()}/contracts/${e.name}`;ne(`${l}/Move.toml`,o),await Ge(c,u,e,o,l)}}import qe from"chalk";function de(){console.log(qe.yellow(`
2
+ import Et from"yargs";import{hideBin as St}from"yargs/helpers";import{execSync as ze,spawn as ie}from"child_process";import w from"chalk";import ke from"chalk";function N(){console.log(ke.yellow(`
49
3
  Welcome to Dubhe
50
4
  --from team@obelisk
51
5
  ________ ___ ___ ________ ___ ___ _______
@@ -56,21 +10,51 @@ Welcome to Dubhe
56
10
  \\ \\_______\\ \\_______\\ \\_______\\ \\__\\ \\__\\ \\_______\\
57
11
  \\|_______|\\|_______|\\|_______|\\|__|\\|__|\\|_______|
58
12
 
59
- `))}var We={command:"localnode <action>",describe:"Manage local Sui node",builder(e){return e.positional("action",{describe:"Action to perform",choices:["start","stop","status","restart"],type:"string",demandOption:!0}).option("background",{alias:"b",type:"boolean",description:"Run node in background",default:!1})},async handler(e){let{action:o,background:t}=e;try{switch(o){case"start":await U(t);break;case"stop":await L();break;case"status":await q();break;case"restart":await ze(t);break}}catch(s){console.error("Error executing command:",s),process.exit(1)}}};async function ze(e){console.log("Restarting local Sui node..."),await L(),await U(e),console.log("Local node has been restarted")}var ue=We;import{Dubhe as Qe}from"@0xobelisk/sui-client";import{requestSuiFromFaucetV0 as Ze,getFaucetHost as Xe}from"@mysten/sui/faucet";import{SuiClient as eo,getFullnodeUrl as oo}from"@mysten/sui/client";var to={command:"faucet",describe:"Interact with a Dubhe faucet",builder(e){return e.options({network:{type:"string",desc:"URL of the Dubhe faucet",choices:["testnet","devnet","localnet"],default:"localnet"},recipient:{type:"string",desc:"Sui address to fund"}})},async handler({network:e,recipient:o}){let t="";if(o===void 0){let c=process.env.PRIVATE_KEY;if(!c)throw new w(`Missing PRIVATE_KEY environment variable.
13
+ `))}import{Dubhe as Re}from"@0xobelisk/sui-client";import{Transaction as G}from"@mysten/sui/transactions";import{getFullnodeUrl as Te,SuiClient as Ne}from"@mysten/sui/client";import{execSync as Ue}from"child_process";import E from"chalk";import j from"chalk";import{ZodError as Ie}from"zod";import{fromZodError as Ee,ValidationError as Se}from"zod-validation-error";var Y=class extends Error{name="NotInsideProjectError";message="You are not inside a Dubhe project"},y=class extends Error{name="DubheCliError"},U=class extends Error{name="UpgradeError"},K=class extends Error{name="FsIibError"};function D(e){if(e instanceof Se)console.log(j.redBright(e.message));else if(e instanceof Ie){let t=Ee(e,{prefixSeparator:`
14
+ - `,issueSeparator:`
15
+ - `});console.log(j.redBright(t.message))}else e instanceof Y?(console.log(j.red(e.message)),console.log(""),console.log(j.blue("To learn more about Dubhe's configuration, please go to https://github.com/0xobelisk"))):e instanceof y?console.log(j.red(e)):console.log(e)}import*as Z from"fs/promises";import{mkdirSync as Pe,writeFileSync as De}from"fs";import{dirname as Me}from"path";import{SUI_PRIVATE_KEY_PREFIX as Fe}from"@mysten/sui/cryptography";import*as V from"fs";import k from"chalk";import{spawn as Oe}from"child_process";function I(e){if(e.startsWith(Fe))return e.length===70?e:!1;if(e.startsWith("0x")){let t=e.slice(2);return t.length===64?t:!1}else return e.length===64?e:!1}async function A(e,t){try{let o=await Z.readFile(`${e}/.history/sui_${t}/latest.json`,"utf8");return JSON.parse(o)}catch{throw new K("Fs read deployment file failed.")}}async function X(e,t){return(await A(e,t)).schemas}async function Q(e,t){return(await A(e,t)).version}async function ee(e,t){return(await A(e,t)).packageId}async function te(e,t){return(await A(e,t)).upgradeCap}async function q(e,t){return(await A(e,t)).schemaHub}function R(e,t,o,s,n,c,a){let p={projectName:e,network:t,packageId:o,schemas:a,upgradeCap:s,schemaHub:n,version:c},d=process.cwd(),r=JSON.stringify(p,null,2);je(r,`${d}/contracts/${e}/.history/sui_${t}/latest.json`,"Update deploy log")}async function je(e,t,o){Pe(Me(t),{recursive:!0}),De(t,e),o!==void 0&&console.log(`${o}: ${t}`)}function Ae(e){switch(e){case"localnet":return'Dubhe = { local = "../dubhe-framework" }';case"testnet":return'Dubhe = { git = "https://github.com/0xobelisk/dubhe-framework.git", rev = "dubhe-testnet-v1.0.0" }';case"mainnet":return'Dubhe = { git = "https://github.com/0xobelisk/dubhe-framework.git", rev = "dubhe-mainnet-v1.0.0" }';default:throw new Error(`Unsupported network: ${e}`)}}function L(e,t){let o=V.readFileSync(e,"utf-8"),s=Ae(t),n=o.replace(/Dubhe = \{.*\}/,s);V.writeFileSync(e,n,"utf-8"),console.log(`Updated Dubhe dependency in ${e} for ${t}.`)}async function M(e){try{return new Promise((t,o)=>{let s=Oe("sui",["client","switch","--env",e],{env:{...process.env},stdio:"pipe"});s.stdout.on("data",n=>{console.log(k.green(`${n.toString()}`))}),s.stderr.on("data",n=>{console.error(k.red(`
16
+ \u274C Failed to Switch Env`)),console.error(k.red(` Error: ${n.toString()}`))}),s.on("error",n=>{console.error(k.red(`
17
+ \u274C Failed to Switch Env`)),console.error(k.red(` Error: ${n.message}`)),o(n)}),s.on("exit",n=>{n!==0?(console.error(k.red(`
18
+ \u274C Process exited with code: ${n}`)),o(new Error(`Process exited with code: ${n}`))):t()})})}catch(t){console.error(k.red(`
19
+ \u274C Failed to Switch Env`)),console.error(k.red(` \u2514\u2500 Error: ${t}`))}}var T=e=>new Promise(t=>setTimeout(t,e));import*as S from"fs";import*as oe from"path";async function Ke(e){switch(e){case"localnet":{let t=process.cwd();return await q(`${t}/contracts/dubhe-framework`,e)}case"testnet":return"0x8dbf8d28ac027ba214c9e0951b09f6842843be6cb87242b7d9a326a2677cd47a";default:return"0x8dbf8d28ac027ba214c9e0951b09f6842843be6cb87242b7d9a326a2677cd47a"}}function ne(e,t){if(!S.existsSync(e))return;let o=S.readFileSync(e,"utf-8"),s=new RegExp(`\\[env\\.${t}\\][\\s\\S]*?(?=\\[|$)`,"g"),n=o.replace(s,"");S.writeFileSync(e,n,"utf-8")}function se(e,t,o,s,n){let c=oe.resolve(e),a=S.readFileSync(c,"utf-8"),p=a.split(`
20
+ `),d=p.findIndex(h=>h.trim()===`[env.${t}]`),r={chainId:s,originalPublishedId:"",latestPublishedId:"",publishedVersion:0};if(d===-1)if(o==="publish")r.originalPublishedId=n,r.latestPublishedId=n,r.publishedVersion=1;else throw new Error(`Network type [env.${t}] not found in the file and cannot upgrade.`);else{for(let h=d+1;h<p.length;h++){let b=p[h].trim();if(b.startsWith("["))break;let[x,v]=b.split("=").map(_=>_.trim().replace(/"/g,""));switch(x){case"original-published-id":r.originalPublishedId=v;break;case"latest-published-id":r.latestPublishedId=v;break;case"published-version":r.publishedVersion=parseInt(v,10);break}}o==="publish"?(r.originalPublishedId=n,r.latestPublishedId=n,r.publishedVersion=1):o==="upgrade"&&(r.latestPublishedId=n,r.publishedVersion+=1)}let u=`
21
+ [env.${t}]
22
+ chain-id = "${r.chainId}"
23
+ original-published-id = "${r.originalPublishedId}"
24
+ latest-published-id = "${r.latestPublishedId}"
25
+ published-version = "${r.publishedVersion}"
26
+ `,f=d===-1?a+u:p.slice(0,d).join(`
27
+ `)+u;S.writeFileSync(c,f,"utf-8")}function Ve(e){return e.split("_").map((t,o)=>t.charAt(0).toUpperCase()+t.slice(1).toLowerCase()).join("")}function qe(e){let t=e.split("::");return t.length>0?t[t.length-1]:""}function re(e){let t,o;try{let s=JSON.parse(Ue(`sui move build --dump-bytecode-as-base64 --path ${e}`,{encoding:"utf-8",stdio:"pipe"}));t=s.modules,o=s.dependencies,console.log(" \u2514\u2500 Build successful")}catch(s){console.error(E.red(" \u2514\u2500 Build failed")),console.error(s.stdout),process.exit(1)}return[t,o]}async function Le(e,t,o,s,n){let c=await Ke(s);console.log("dappsObjectId",c);let a=await e.getChainIdentifier();ne(`${n}/Move.lock`,s),console.log(`
28
+ \u{1F680} Starting Contract Publication...`),console.log(` \u251C\u2500 Project: ${n}`),console.log(` \u251C\u2500 Network: ${s}`),console.log(` \u251C\u2500 ChainId: ${a}`),console.log(" \u251C\u2500 Validating Environment...");let p=t.getKeypair();console.log(` \u2514\u2500 Account: ${p.toSuiAddress()}`),console.log(`
29
+ \u{1F4E6} Building Contract...`);let[d,r]=re(n);console.log(`
30
+ \u{1F504} Publishing Contract...`);let u=new G,[f]=u.publish({modules:d,dependencies:r});u.transferObjects([f],p.toSuiAddress());let h;try{h=await e.signAndExecuteTransaction({signer:p,transaction:u,options:{showObjectChanges:!0}})}catch(l){console.error(E.red(" \u2514\u2500 Publication failed")),console.error(l.message),process.exit(1)}h.effects?.status.status==="failure"&&(console.log(E.red(" \u2514\u2500 Publication failed")),process.exit(1)),console.log(" \u251C\u2500 Processing publication results...");let b=1,x="",v=[],_="",i="";h.objectChanges.map(l=>{l.type==="published"&&(console.log(` \u251C\u2500 Package ID: ${l.packageId}`),x=l.packageId),l.type==="created"&&l.objectType==="0x2::package::UpgradeCap"&&(console.log(` \u251C\u2500 Upgrade Cap: ${l.objectId}`),_=l.objectId),l.type==="created"&&l.objectType.includes("schema_hub")&&(console.log(` \u251C\u2500 Schema Hub: ${l.objectId}`),i=l.objectId)}),console.log(` \u2514\u2500 Transaction: ${h.digest}`),se(`${n}/Move.lock`,s,"publish",a,x),console.log(`
31
+ \u26A1 Executing Deploy Hook...`),await T(5e3);let g=new G;g.setGasBudget(2e9);let[$]=g.splitCoins(g.gas,["1000000000"]);g.moveCall({target:`${x}::deploy_hook::run`,arguments:[g.object(i),g.object(c),g.object(_),g.object("0x6"),$]});let m;try{m=await e.signAndExecuteTransaction({signer:p,transaction:g,options:{showEffects:!0,showObjectChanges:!0}})}catch(l){console.error(E.red(" \u2514\u2500 Deploy hook execution failed")),console.error(l.message),process.exit(1)}m.effects?.status.status==="success"?(console.log(" \u251C\u2500 Hook execution successful"),console.log(` \u251C\u2500 Transaction: ${m.digest}`),console.log(`
32
+ \u{1F4CB} Created Schemas:`),m.objectChanges?.map(l=>{if(l.type==="created"&&l.objectType.includes("_schema")&&!l.objectType.includes("dynamic_field")){console.log(` \u251C\u2500 ${l.objectType}`),console.log(` \u2514\u2500 ID: ${l.objectId}`);let C={};for(let O in o.schemas)Ve(O)===qe(l.objectType)&&(C=o.schemas[O].structure);v.push({name:l.objectType,objectId:l.objectId,structure:C})}}),R(o.name,s,x,_,i,b,v),console.log(`
33
+ \u2705 Contract Publication Complete
34
+ `)):(console.log(E.yellow(" \u2514\u2500 Deploy hook execution failed")),console.log(E.yellow(" Please republish or manually call deploy_hook::run")))}async function W(e,t,o){let n=`${process.cwd()}/contracts/dubhe-framework`,c=await e.getChainIdentifier();console.log(` \u2514\u2500 Chain ID: ${c}`),ne(`${n}/Move.lock`,o),console.log(`
35
+ \u{1F680} Starting Contract Publication...`),console.log(` \u251C\u2500 Project: ${n}`),console.log(` \u251C\u2500 Network: ${o}`),console.log(` \u251C\u2500 ChainId: ${c}`),console.log(" \u251C\u2500 Validating Environment...");let a=t.getKeypair();console.log(` \u2514\u2500 Account: ${a.toSuiAddress()}`),console.log(`
36
+ \u{1F4E6} Building Contract...`);let[p,d]=re(n);console.log(`
37
+ \u{1F504} Publishing Contract...`);let r=new G,[u]=r.publish({modules:p,dependencies:d});r.transferObjects([u],a.toSuiAddress());let f;try{f=await e.signAndExecuteTransaction({signer:a,transaction:r,options:{showObjectChanges:!0}})}catch(i){console.error(E.red(" \u2514\u2500 Publication failed")),console.error(i.message),process.exit(1)}f.effects?.status.status==="failure"&&(console.log(E.red(" \u2514\u2500 Publication failed")),process.exit(1)),console.log(" \u251C\u2500 Processing publication results...");let h=1,b="",x=[],v="",_="";f.objectChanges.map(i=>{i.type==="published"&&(console.log(` \u251C\u2500 Package ID: ${i.packageId}`),b=i.packageId),i.type==="created"&&i.objectType==="0x2::package::UpgradeCap"&&(console.log(` \u251C\u2500 Upgrade Cap: ${i.objectId}`),v=i.objectId),i.type==="created"&&i.objectType.includes("dapps")&&(console.log(` \u251C\u2500 Dapps: ${i.objectId}`),_=i.objectId)}),console.log(` \u2514\u2500 Transaction: ${f.digest}`),se(`${n}/Move.lock`,o,"publish",c,b),R("dubhe-framework",o,b,v,_,h,x)}async function ae(e,t,o){await M(t);let s=process.env.PRIVATE_KEY;if(!s)throw new y(`Missing PRIVATE_KEY environment variable.
38
+ Run 'echo "PRIVATE_KEY=YOUR_PRIVATE_KEY" > .env'
39
+ in your contracts directory to use the default sui private key.`);let n=I(s);if(n===!1)throw new y("Please check your privateKey.");let c=new Re({secretKey:n}),a=new Ne({url:Te(t)});if(o=="dubhe-framework")await W(a,c,t);else{let d=`${process.cwd()}/contracts/${e.name}`;L(`${d}/Move.toml`,t),await Le(a,c,e,t,d)}}import{Dubhe as ce}from"@0xobelisk/sui-client";import{getFullnodeUrl as Be,SuiClient as He}from"@mysten/sui/client";function Ye(){try{let e=process.platform==="win32"?'tasklist /FI "IMAGENAME eq sui.exe" /FO CSV /NH':'pgrep -f "sui start"',t=ze(e).toString().trim();return process.platform==="win32"?t.toLowerCase().includes("sui.exe"):t.length>0}catch{return!1}}async function Ge(){let e=["suiprivkey1qq3ez3dje66l8pypgxynr7yymwps6uhn7vyczespj84974j3zya0wdpu76v","suiprivkey1qp6vcyg8r2x88fllmjmxtpzjl95gd9dugqrgz7xxf50w6rqdqzetg7x4d7s","suiprivkey1qpy3a696eh3m55fwa8h38ss063459u4n2dm9t24w2hlxxzjp2x34q8sdsnc","suiprivkey1qzxwp29favhzrjd95f6uj9nskjwal6nh9g509jpun395y6g72d6jqlmps4c","suiprivkey1qzhq4lv38sesah4uzsqkkmeyjx860xqjdz8qgw36tmrdd5tnle3evxpng57","suiprivkey1qzez45sjjsepjgtksqvpq6jw7dzw3zq0dx7a4sulfypd73acaynw5jl9x2c"];console.log("\u{1F4DD}Accounts"),console.log("=========="),e.forEach((t,o)=>{let n=new ce({secretKey:t}).getKeypair();ie("curl",["--location","--request","POST","http://127.0.0.1:9123/gas","--header","Content-Type: application/json","--data-raw",`{"FixedAmountRequest": {"recipient": "${n.toSuiAddress()}"}}`],{env:{...process.env},stdio:"ignore",detached:!0}),console.log(` \u250C\u2500 Account #${o}: ${n.toSuiAddress()}(1000 SUI)`),console.log(` \u2514\u2500 Private Key: ${t}`)}),console.log("=========="),console.log(w.yellow("\u26A0\uFE0FWARNING: These accounts, and their private keys, are publicly known.")),console.log(w.yellow("Any funds sent to them on Mainnet or any other live network WILL BE LOST."))}async function le(){if(Ye()){console.log(w.yellow(`
40
+ \u26A0\uFE0F Warning: Local Node Already Running`)),console.log(w.yellow(" \u251C\u2500 Cannot start a new instance")),console.log(w.yellow(" \u2514\u2500 Please stop the existing process first"));return}N(),console.log("\u{1F680} Starting Local Node...");try{let e=ie("sui",["start","--with-faucet","--force-regenesis"],{env:{...process.env,RUST_LOG:"off,sui_node=info"},stdio:"ignore",detached:!0});e.on("error",c=>{console.error(w.red(`
41
+ \u274C Failed to Start Local Node`)),console.error(w.red(` \u2514\u2500 Error: ${c.message}`))}),await T(5e3),console.log(" \u251C\u2500 Faucet: Enabled"),console.log(" \u2514\u2500 Force Regenesis: Yes"),console.log(" \u2514\u2500 HTTP server: http://127.0.0.1:9000/"),console.log(" \u2514\u2500 Faucet server: http://127.0.0.1:9123/"),await Ge(),await T(2e3);let t=I("suiprivkey1qzez45sjjsepjgtksqvpq6jw7dzw3zq0dx7a4sulfypd73acaynw5jl9x2c");if(t===!1)throw new y("Please check your privateKey.");let o=new ce({secretKey:t}),s=new He({url:Be("localnet")}),n=console.log;console.log=()=>{},await W(s,o,"localnet"),console.log=n,process.on("SIGINT",()=>{console.log(w.yellow(`
42
+ \u{1F514} Stopping Local Node...`)),e&&(e.kill(),console.log(w.green("\u2705 Local Node Stopped"))),process.exit()})}catch(e){console.error(w.red(`
43
+ \u274C Failed to Start Local Node`)),console.error(w.red(` \u2514\u2500 Error: ${e.message}`))}}var We={command:"node",describe:"Manage local Sui node",builder(e){return e},async handler(){try{await le()}catch(e){console.error("Error executing command:",e),process.exit(1)}}},de=We;import{Dubhe as Je}from"@0xobelisk/sui-client";import{requestSuiFromFaucetV0 as Ze,getFaucetHost as Xe}from"@mysten/sui/faucet";import{SuiClient as Qe,getFullnodeUrl as et}from"@mysten/sui/client";var tt={command:"faucet",describe:"Interact with a Dubhe faucet",builder(e){return e.options({network:{type:"string",desc:"URL of the Dubhe faucet",choices:["testnet","devnet","localnet"],default:"localnet"},recipient:{type:"string",desc:"Sui address to fund"}})},async handler({network:e,recipient:t}){let o="";if(t===void 0){let a=process.env.PRIVATE_KEY;if(!a)throw new y(`Missing PRIVATE_KEY environment variable.
60
44
  Run 'echo "PRIVATE_KEY=YOUR_PRIVATE_KEY" > .env'
61
- in your contracts directory to use the default sui private key.`);let d=M(c);if(d===!1)throw new w("Please check your PRIVATE_KEY.");t=new Qe({secretKey:d}).getKeypair().toSuiAddress()}else t=o;console.log(`
62
- \u{1F30A} Starting Faucet Operation...`),console.log(` \u251C\u2500 Network: ${e}`),o===void 0?(console.log(" \u251C\u2500 Using Environment PrivateKey"),console.log(` \u251C\u2500 Generated Address: ${t}`)):console.log(` \u251C\u2500 Using Provided Address: ${t}`),console.log(" \u251C\u2500 Requesting funds from faucet..."),await Ze({host:Xe(e),recipient:t}),console.log(" \u2514\u2500 Checking balance...");let s=new eo({url:oo(e)}),n={owner:t},u=await s.getBalance(n);console.log(`
63
- \u{1F4B0} Account Summary`),console.log(` \u251C\u2500 Address: ${t}`),console.log(` \u2514\u2500 Balance: ${(Number(u.totalBalance)/1e9).toFixed(4)} SUI`),console.log(`
45
+ in your contracts directory to use the default sui private key.`);let p=I(a);if(p===!1)throw new y("Please check your PRIVATE_KEY.");o=new Je({secretKey:p}).getKeypair().toSuiAddress()}else o=t;console.log(`
46
+ \u{1F30A} Starting Faucet Operation...`),console.log(` \u251C\u2500 Network: ${e}`),t===void 0?(console.log(" \u251C\u2500 Using Environment PrivateKey"),console.log(` \u251C\u2500 Generated Address: ${o}`)):console.log(` \u251C\u2500 Using Provided Address: ${o}`),console.log(" \u251C\u2500 Requesting funds from faucet..."),await Ze({host:Xe(e),recipient:o}),console.log(" \u2514\u2500 Checking balance...");let s=new Qe({url:et(e)}),n={owner:o},c=await s.getBalance(n);console.log(`
47
+ \u{1F4B0} Account Summary`),console.log(` \u251C\u2500 Address: ${o}`),console.log(` \u2514\u2500 Balance: ${(Number(c.totalBalance)/1e9).toFixed(4)} SUI`),console.log(`
64
48
  \u2705 Faucet Operation Complete
65
- `),process.exit(0)}},pe=to;import{schemaGen as no,loadConfig as so}from"@0xobelisk/sui-common";import ro from"chalk";var ao={command:"schemagen",describe:"Autogenerate Dubhe schemas based on the config file",builder:{"config-path":{type:"string",default:"dubhe.config.ts",desc:"Path to the config file"},network:{type:"string",choices:["mainnet","testnet","devnet","localnet"],desc:"Node network (mainnet/testnet/devnet/localnet)"},"framework-id":{type:"string",desc:"Framework Package ID"}},async handler({"config-path":e,network:o,"framework-id":t}){try{let s=await so(e);await no(s,void 0,o,t),process.exit(0)}catch(s){console.log(ro.red("Schemagen failed!")),console.error(s.message)}}},ge=ao;import{loadConfig as io}from"@0xobelisk/sui-common";var co={command:"publish",describe:"Publish dubhe move contract",builder(e){return e.options({network:{type:"string",choices:["mainnet","testnet","devnet","localnet"],desc:"Node network (mainnet/testnet/devnet/localnet)"},"config-path":{type:"string",default:"dubhe.config.ts",desc:"Configuration file path"},"contract-name":{type:"string",desc:"Optional contract name in contracts/ directory"}})},async handler({network:e,"config-path":o,"contract-name":t}){try{let s=await io(o);await le(s,e,t)}catch(s){D(s),process.exit(1)}process.exit(0)}},me=co;import{Dubhe as lo}from"@0xobelisk/sui-client";import{Transaction as uo,UpgradePolicy as po}from"@mysten/sui/transactions";import{getFullnodeUrl as go,SuiClient as mo}from"@mysten/sui/client";import{execSync as fo}from"child_process";import B from"chalk";import*as N from"fs";import*as fe from"path";function ho(e,o){o.forEach(t=>{let s=`${e}/sources/codegen/schemas/${t.schemaName}.move`,n=N.readFileSync(s,"utf-8"),u=new RegExp(`public fun migrate\\(_${t.schemaName}: &mut ${z(t.schemaName)}, _cap: &UpgradeCap\\) {[^}]*}`),c=`
66
- public fun migrate(${t.schemaName}: &mut ${z(t.schemaName)}, _cap: &UpgradeCap) {
67
- ${t.fields.map(l=>{let r="";return l.type.includes("StorageValue")?r="storage_value::new()":l.type.includes("StorageMap")?r="storage_map::new()":l.type.includes("StorageDoubleMap")&&(r="storage_double_map::new()"),`storage_migrate::add_field<${l.type}>(&mut ${t.schemaName}.id, b"${l.name}", ${r});`}).join("")}
49
+ `),process.exit(0)}},pe=tt;import{schemaGen as ot,loadConfig as nt}from"@0xobelisk/sui-common";import st from"chalk";var rt={command:"schemagen",describe:"Autogenerate Dubhe schemas based on the config file",builder:{"config-path":{type:"string",default:"dubhe.config.ts",desc:"Path to the config file"},network:{type:"string",choices:["mainnet","testnet","devnet","localnet"],desc:"Node network (mainnet/testnet/devnet/localnet)"},"framework-id":{type:"string",desc:"Framework Package ID"}},async handler({"config-path":e,network:t,"framework-id":o}){try{let s=await nt(e);await ot(s,void 0,t,o),process.exit(0)}catch(s){console.log(st.red("Schemagen failed!")),console.error(s.message)}}},ue=rt;import{loadConfig as at}from"@0xobelisk/sui-common";var it={command:"publish",describe:"Publish dubhe move contract",builder(e){return e.options({network:{type:"string",choices:["mainnet","testnet","devnet","localnet"],desc:"Node network (mainnet/testnet/devnet/localnet)"},"config-path":{type:"string",default:"dubhe.config.ts",desc:"Configuration file path"},"contract-name":{type:"string",desc:"Optional contract name in contracts/ directory"}})},async handler({network:e,"config-path":t,"contract-name":o}){try{let s=await at(t);await ae(s,e,o)}catch(s){D(s),process.exit(1)}process.exit(0)}},ge=it;import{Dubhe as ct}from"@0xobelisk/sui-client";import{Transaction as lt,UpgradePolicy as dt}from"@mysten/sui/transactions";import{getFullnodeUrl as pt,SuiClient as ut}from"@mysten/sui/client";import{execSync as gt}from"child_process";import z from"chalk";import*as F from"fs";import*as me from"path";function mt(e,t){t.forEach(o=>{let s=`${e}/sources/codegen/schemas/${o.schemaName}.move`,n=F.readFileSync(s,"utf-8"),c=new RegExp(`public fun migrate\\(_${o.schemaName}: &mut ${J(o.schemaName)}, _cap: &UpgradeCap\\) {[^}]*}`),a=`
50
+ public fun migrate(${o.schemaName}: &mut ${J(o.schemaName)}, _cap: &UpgradeCap) {
51
+ ${o.fields.map(d=>{let r="";return d.type.includes("StorageValue")?r="storage_value::new()":d.type.includes("StorageMap")?r="storage_map::new()":d.type.includes("StorageDoubleMap")&&(r="storage_double_map::new()"),`storage_migrate::add_field<${d.type}>(&mut ${o.schemaName}.id, b"${d.name}", ${r});`}).join("")}
68
52
  }
69
- `,d=n.replace(u,c);N.writeFileSync(s,d,"utf-8")})}function z(e){return e.split("_").map((o,t)=>o.charAt(0).toUpperCase()+o.slice(1).toLowerCase()).join("")}function yo(e){let o=e.split("::");return o.length>0?o[o.length-1]:""}function Y(e,o,t,s){let n=fe.resolve(e),c=N.readFileSync(n,"utf-8").split(`
70
- `),d=c.findIndex(p=>p.trim()===`[env.${o}]`);if(d===-1)return console.log(`Network type [env.${o}] not found in the file.`),"";let l=-1,r="";for(let p=d+1;p<c.length;p++){let f=c[p].trim();if(f.startsWith("["))break;if(f.startsWith(t)){l=p,r=f.split("=")[1].trim().replace(/"/g,"");break}}if(l!==-1){c[l]=`${t} = "${s}"`;let p=c.join(`
71
- `);N.writeFileSync(n,p,"utf-8")}else console.log(`${t} not found for [env.${o}].`);return r}async function he(e,o,t){await H(t);let s=process.cwd(),n=`${s}/contracts/${o}`,u=process.env.PRIVATE_KEY;if(!u)throw new w(`Missing PRIVATE_KEY environment variable.
53
+ `,p=n.replace(c,a);F.writeFileSync(s,p,"utf-8")})}function J(e){return e.split("_").map((t,o)=>t.charAt(0).toUpperCase()+t.slice(1).toLowerCase()).join("")}function ft(e){let t=e.split("::");return t.length>0?t[t.length-1]:""}function B(e,t,o,s){let n=me.resolve(e),a=F.readFileSync(n,"utf-8").split(`
54
+ `),p=a.findIndex(u=>u.trim()===`[env.${t}]`);if(p===-1)return console.log(`Network type [env.${t}] not found in the file.`),"";let d=-1,r="";for(let u=p+1;u<a.length;u++){let f=a[u].trim();if(f.startsWith("["))break;if(f.startsWith(o)){d=u,r=f.split("=")[1].trim().replace(/"/g,"");break}}if(d!==-1){a[d]=`${o} = "${s}"`;let u=a.join(`
55
+ `);F.writeFileSync(n,u,"utf-8")}else console.log(`${o} not found for [env.${t}].`);return r}async function fe(e,t,o){await M(o);let s=process.cwd(),n=`${s}/contracts/${t}`,c=process.env.PRIVATE_KEY;if(!c)throw new y(`Missing PRIVATE_KEY environment variable.
72
56
  Run 'echo "PRIVATE_KEY=YOUR_PRIVATE_KEY" > .env'
73
- in your contracts directory to use the default sui private key.`);let c=M(u);if(c===!1)throw new w("Please check your privateKey.");let l=new lo({secretKey:c}).getKeypair(),r=new mo({url:go(t)}),p=Number(await ee(n,t)),f=await oe(n,t),h=await j(n,t),b=await te(n,t),C=Y(`${n}/Move.lock`,t,"original-published-id","0x0000000000000000000000000000000000000000000000000000000000000000"),_=[],v=await X(n,t);for(let a in e.schemas)v.forEach(g=>{if(z(a)==yo(g.name)){let I={schemaName:"",fields:[]},m=[],i=!1;for(let x in e.schemas[a].structure)x in g.structure||(i=!0,m.push({name:x,type:e.schemas[a].structure[x]}),g.structure[x]=e.schemas[a].structure[x]);i&&(I.schemaName=a,I.fields=m,_.push(I))}});_.forEach(a=>{console.log(`
74
- \u{1F680} Starting Migration for ${a.schemaName}...`),console.log("\u{1F4CB} Migration Fields:",a.fields)}),ho(n,_);try{let a,g,I;try{let{modules:P,dependencies:xe,digest:ke}=JSON.parse(fo(`sui move build --dump-bytecode-as-base64 --path ${s}/contracts/${o}`,{encoding:"utf-8"}));a=P,g=xe,I=ke}catch(P){throw new T(P.stdout)}console.log(`
75
- \u{1F680} Starting Upgrade Process...`),console.log("\u{1F4CB} OldPackageId:",f),console.log("\u{1F4CB} UpgradeCap Object Id:",b),console.log("\u{1F4CB} OldVersion:",p);let m=new uo,i=m.moveCall({target:"0x2::package::authorize_upgrade",arguments:[m.object(b),m.pure.u8(po.COMPATIBLE),m.pure.vector("u8",I)]}),x=m.upgrade({modules:a,dependencies:g,package:f,ticket:i});m.moveCall({target:"0x2::package::commit_upgrade",arguments:[m.object(b),x]});let F=await r.signAndExecuteTransaction({signer:l,transaction:m,options:{showObjectChanges:!0}}),G="";F.objectChanges.map(P=>{P.type==="published"&&(console.log(B.blue(`${o} PackageId: ${P.packageId}`)),console.log(B.blue(`${o} Version: ${p+1}`)),G=P.packageId)}),Y(`${n}/Move.lock`,t,"original-published-id",C),Y(`${n}/Move.lock`,t,"latest-published-id",G),Y(`${n}/Move.lock`,t,"published-version",p+1+""),console.log(B.green(`Upgrade Transaction Digest: ${F.digest}`)),A(o,t,G,b,h,p+1,v)}catch(a){console.log(B.red("Upgrade failed!")),console.error(a.message)}}import{loadConfig as bo}from"@0xobelisk/sui-common";var _o={command:"upgrade",describe:"Upgrade your move contracts",builder(e){return e.options({network:{type:"string",choices:["mainnet","testnet","devnet","localnet"],desc:"Network of the node (mainnet/testnet/devnet/localnet)"},"config-path":{type:"string",default:"dubhe.config.ts",decs:"Path to the config file"}})},async handler({network:e,"config-path":o}){try{let t=await bo(o);await he(t,t.name,e)}catch(t){D(t),process.exit(1)}process.exit(0)}},ye=_o;import{execSync as wo}from"child_process";import vo from"chalk";var Co={command:"test",describe:"Run tests in Dubhe contracts",builder(e){return e.options({packagePath:{type:"string",default:".",description:"Options to pass to forge test"}})},async handler({packagePath:e}){try{wo(`sui move test --path ${e}`,{encoding:"utf-8"})}catch(o){console.error(vo.red("Error executing sui move test:")),console.log(o.stdout),process.exit(0)}}},be=Co;var xo={command:"hello",describe:"hello, dubhe",builder(e){return e},async handler(){de()}},_e=xo;var we=[me,ue,pe,ge,ye,be,_e];import*as Ce from"dotenv";import ve from"chalk";Ce.config();ko(So(process.argv)).scriptName("dubhe").command(we).strict().fail((e,o)=>{console.error(ve.red(e)),e.includes("Missing required argument")&&console.log(ve.yellow(`Run 'pnpm dubhe ${process.argv[2]} --help' for a list of available and required arguments.`)),console.log(""),D(o),console.log(""),process.exit(1)}).alias({h:"help"}).argv;
57
+ in your contracts directory to use the default sui private key.`);let a=I(c);if(a===!1)throw new y("Please check your privateKey.");let d=new ct({secretKey:a}).getKeypair(),r=new ut({url:pt(o)}),u=Number(await Q(n,o)),f=await ee(n,o),h=await q(n,o),b=await te(n,o),x=B(`${n}/Move.lock`,o,"original-published-id","0x0000000000000000000000000000000000000000000000000000000000000000"),v=[],_=await X(n,o);for(let i in e.schemas)_.forEach(g=>{if(J(i)==ft(g.name)){let $={schemaName:"",fields:[]},m=[],l=!1;for(let C in e.schemas[i].structure)C in g.structure||(l=!0,m.push({name:C,type:e.schemas[i].structure[C]}),g.structure[C]=e.schemas[i].structure[C]);l&&($.schemaName=i,$.fields=m,v.push($))}});v.forEach(i=>{console.log(`
58
+ \u{1F680} Starting Migration for ${i.schemaName}...`),console.log("\u{1F4CB} Migration Fields:",i.fields)}),mt(n,v);try{let i,g,$;try{let{modules:P,dependencies:Ce,digest:$e}=JSON.parse(gt(`sui move build --dump-bytecode-as-base64 --path ${s}/contracts/${t}`,{encoding:"utf-8"}));i=P,g=Ce,$=$e}catch(P){throw new U(P.stdout)}console.log(`
59
+ \u{1F680} Starting Upgrade Process...`),console.log("\u{1F4CB} OldPackageId:",f),console.log("\u{1F4CB} UpgradeCap Object Id:",b),console.log("\u{1F4CB} OldVersion:",u);let m=new lt,l=m.moveCall({target:"0x2::package::authorize_upgrade",arguments:[m.object(b),m.pure.u8(dt.COMPATIBLE),m.pure.vector("u8",$)]}),C=m.upgrade({modules:i,dependencies:g,package:f,ticket:l});m.moveCall({target:"0x2::package::commit_upgrade",arguments:[m.object(b),C]});let O=await r.signAndExecuteTransaction({signer:d,transaction:m,options:{showObjectChanges:!0}}),H="";O.objectChanges.map(P=>{P.type==="published"&&(console.log(z.blue(`${t} PackageId: ${P.packageId}`)),console.log(z.blue(`${t} Version: ${u+1}`)),H=P.packageId)}),B(`${n}/Move.lock`,o,"original-published-id",x),B(`${n}/Move.lock`,o,"latest-published-id",H),B(`${n}/Move.lock`,o,"published-version",u+1+""),console.log(z.green(`Upgrade Transaction Digest: ${O.digest}`)),R(t,o,H,b,h,u+1,_)}catch(i){console.log(z.red("Upgrade failed!")),console.error(i.message)}}import{loadConfig as ht}from"@0xobelisk/sui-common";var yt={command:"upgrade",describe:"Upgrade your move contracts",builder(e){return e.options({network:{type:"string",choices:["mainnet","testnet","devnet","localnet"],desc:"Network of the node (mainnet/testnet/devnet/localnet)"},"config-path":{type:"string",default:"dubhe.config.ts",decs:"Path to the config file"}})},async handler({network:e,"config-path":t}){try{let o=await ht(t);await fe(o,o.name,e)}catch(o){D(o),process.exit(1)}process.exit(0)}},he=yt;import{execSync as bt}from"child_process";import vt from"chalk";import{loadConfig as _t}from"@0xobelisk/sui-common";var wt={command:"test",describe:"Run tests in Dubhe contracts",builder(e){return e.options({"config-path":{type:"string",default:"dubhe.config.ts",description:"Options to pass to forge test"},test:{type:"string",desc:"Run a specific test"}})},async handler({"config-path":e,test:t}){try{console.log("\u{1F680} Running move test");let o=await _t(e),c=`sui move test --path ${`${process.cwd()}/contracts/${o.name}`} ${t?` --test ${t}`:""}`,a=bt(c,{encoding:"utf-8"});console.log(a)}catch(o){console.error(vt.red("Error executing sui move test:")),console.log(o.stdout),process.exit(0)}}},ye=wt;import{execSync as xt}from"child_process";import Ct from"chalk";import{loadConfig as $t}from"@0xobelisk/sui-common";var kt={command:"build",describe:"Run tests in Dubhe contracts",builder(e){return e.options({"config-path":{type:"string",default:"dubhe.config.ts",description:"Options to pass to forge test"},network:{type:"string",choices:["mainnet","testnet","devnet","localnet"],desc:"Node network (mainnet/testnet/devnet/localnet)"},"dump-bytecode-as-base64":{type:"boolean",default:!1,desc:"Dump bytecode as base64"}})},async handler({"config-path":e,network:t,"dump-bytecode-as-base64":o}){try{console.log("\u{1F680} Running move build");let s=await $t(e),c=`${process.cwd()}/contracts/${s.name}`;await M(t),L(c+"/Move.toml",t);let a=`sui move build --path ${c} ${o?" --dump-bytecode-as-base64":""}`,p=xt(a,{encoding:"utf-8"});console.log(p)}catch(s){console.error(Ct.red("Error executing sui move build:")),console.log(s.stdout),process.exit(0)}}},be=kt;var It={command:"hello",describe:"hello, dubhe",builder(e){return e},async handler(){N()}},ve=It;var _e=[ge,de,pe,ue,he,ye,be,ve];import*as xe from"dotenv";import we from"chalk";xe.config();Et(St(process.argv)).scriptName("dubhe").command(_e).strict().fail((e,t)=>{console.error(we.red(e)),e.includes("Missing required argument")&&console.log(we.yellow(`Run 'pnpm dubhe ${process.argv[2]} --help' for a list of available and required arguments.`)),console.log(""),D(t),console.log(""),process.exit(1)}).alias({h:"help"}).argv;
76
60
  //# sourceMappingURL=dubhe.js.map
package/dist/dubhe.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/dubhe.ts","../src/utils/publishHandler.ts","../src/utils/errors.ts","../src/utils/utils.ts","../src/utils/localnode/start.ts","../src/utils/localnode/status.ts","../src/utils/localnode/stop.ts","../src/utils/printDubhe.ts","../src/commands/localnode.ts","../src/commands/faucet.ts","../src/commands/schemagen.ts","../src/commands/publish.ts","../src/utils/upgradeHandler.ts","../src/commands/upgrade.ts","../src/commands/test.ts","../src/commands/hello.ts","../src/commands/index.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport yargs from \"yargs\";\nimport { hideBin } from \"yargs/helpers\";\nimport { commands } from \"./commands\";\nimport { logError } from \"./utils/errors\";\n\n// Load .env file into process.env\nimport * as dotenv from \"dotenv\";\nimport chalk from \"chalk\";\ndotenv.config();\n\nyargs(hideBin(process.argv))\n // Explicit name to display in help (by default it's the entry file, which may not be \"dubhe\" for e.g. ts-node)\n .scriptName(\"dubhe\")\n // Use the commands directory to scaffold\n // eslint-disable-next-line @typescript-eslint/no-explicit-any -- command array overload isn't typed, see https://github.com/yargs/yargs/blob/main/docs/advanced.md#esm-hierarchy\n .command(commands as any)\n // Enable strict mode.\n .strict()\n // Custom error handler\n .fail((msg, err) => {\n console.error(chalk.red(msg));\n if (msg.includes(\"Missing required argument\")) {\n console.log(\n chalk.yellow(`Run 'pnpm dubhe ${process.argv[2]} --help' for a list of available and required arguments.`)\n );\n }\n console.log(\"\");\n logError(err);\n console.log(\"\");\n\n process.exit(1);\n })\n // Useful aliases.\n .alias({ h: \"help\" }).argv;\n","import { Dubhe } from '@0xobelisk/sui-client';\nimport { Transaction } from '@mysten/sui/transactions';\nimport {\n\tgetFullnodeUrl,\n\tSuiClient,\n\tSuiTransactionBlockResponse,\n} from '@mysten/sui/client';\nimport { execSync } from 'child_process';\nimport chalk from 'chalk';\nimport { DubheCliError } from './errors';\nimport {\n\tupdateVersionInFile,\n\tsaveContractData,\n\tvalidatePrivateKey,\n\tschema, getSchemaHub, updateDubheDependency, switchEnv, delay,\n} from './utils';\nimport { DubheConfig } from '@0xobelisk/sui-common';\nimport * as fs from 'fs';\nimport * as path from 'path';\n\nasync function getDappsObjectId(\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet'\n) {\n\tswitch (network) {\n\t\tcase \"localnet\": {\n\t\t\tconst path = process.cwd();\n\t\t\treturn await getSchemaHub(`${path}/contracts/dubhe-framework`, network)\n\t\t}\n\t\tcase 'testnet':\n\t\t\treturn '0x8dbf8d28ac027ba214c9e0951b09f6842843be6cb87242b7d9a326a2677cd47a';\n\t\tdefault:\n\t\t\treturn '0x8dbf8d28ac027ba214c9e0951b09f6842843be6cb87242b7d9a326a2677cd47a';\n\t}\n}\n\nfunction removeEnvContent(filePath: string, networkType: 'mainnet' | 'testnet' | 'devnet' | 'localnet'): void {\n\tif (!fs.existsSync(filePath)) {\n\t\treturn;\n\t}\n\tconst content = fs.readFileSync(filePath, 'utf-8');\n\tconst regex = new RegExp(`\\\\[env\\\\.${networkType}\\\\][\\\\s\\\\S]*?(?=\\\\[|$)`, 'g');\n\tconst updatedContent = content.replace(regex, '');\n\tfs.writeFileSync(filePath, updatedContent, 'utf-8');\n}\n\ninterface EnvConfig {\n\tchainId: string;\n\toriginalPublishedId: string;\n\tlatestPublishedId: string;\n\tpublishedVersion: number;\n}\n\nconst chainIds: { [key: string]: string } = {\n\tlocalnet: 'dfa7bb83',\n\ttestnet: '4c78adac',\n\tmainnet: '35834a8a',\n};\n\nfunction updateEnvFile(filePath: string, networkType: 'mainnet' | 'testnet' | 'devnet' | 'localnet', operation: 'publish' | 'upgrade', chainId: string, publishedId: string): void {\n\tconst envFilePath = path.resolve(filePath);\n\tconst envContent = fs.readFileSync(envFilePath, 'utf-8');\n\tconst envLines = envContent.split('\\n');\n\n\tconst networkSectionIndex = envLines.findIndex(line => line.trim() === `[env.${networkType}]`);\n\tconst config: EnvConfig = {\n\t\tchainId: chainId,\n\t\toriginalPublishedId: '',\n\t\tlatestPublishedId: '',\n\t\tpublishedVersion: 0,\n\t};\n\n\tif (networkSectionIndex === -1) {\n\t\t// If network section is not found, add a new section\n\t\tif (operation === 'publish') {\n\t\t\tconfig.originalPublishedId = publishedId;\n\t\t\tconfig.latestPublishedId = publishedId;\n\t\t\tconfig.publishedVersion = 1;\n\t\t} else {\n\t\t\tthrow new Error(`Network type [env.${networkType}] not found in the file and cannot upgrade.`);\n\t\t}\n\t} else {\n\t\tfor (let i = networkSectionIndex + 1; i < envLines.length; i++) {\n\t\t\tconst line = envLines[i].trim();\n\t\t\tif (line.startsWith('[')) break; // End of the current network section\n\n\t\t\tconst [key, value] = line.split('=').map(part => part.trim().replace(/\"/g, ''));\n\t\t\tswitch (key) {\n\t\t\t\tcase 'original-published-id':\n\t\t\t\t\tconfig.originalPublishedId = value;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'latest-published-id':\n\t\t\t\t\tconfig.latestPublishedId = value;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'published-version':\n\t\t\t\t\tconfig.publishedVersion = parseInt(value, 10);\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tif (operation === 'publish') {\n\t\t\tconfig.originalPublishedId = publishedId;\n\t\t\tconfig.latestPublishedId = publishedId;\n\t\t\tconfig.publishedVersion = 1;\n\t\t} else if (operation === 'upgrade') {\n\t\t\tconfig.latestPublishedId = publishedId;\n\t\t\tconfig.publishedVersion += 1;\n\t\t}\n\t}\n\n\tconst updatedSection = `\n[env.${networkType}]\nchain-id = \"${config.chainId}\"\noriginal-published-id = \"${config.originalPublishedId}\"\nlatest-published-id = \"${config.latestPublishedId}\"\npublished-version = \"${config.publishedVersion}\"\n`;\n\n\tconst newEnvContent = networkSectionIndex === -1\n\t\t? envContent + updatedSection\n\t\t: envLines.slice(0, networkSectionIndex).join('\\n') + updatedSection;\n\n\tfs.writeFileSync(envFilePath, newEnvContent, 'utf-8');\n}\nfunction capitalizeAndRemoveUnderscores(input: string): string {\n\treturn input\n\t\t.split('_')\n\t\t.map((word, index) => {\n\t\t\treturn index === 0\n\t\t\t\t? word.charAt(0).toUpperCase() + word.slice(1).toLowerCase()\n\t\t\t\t: word.charAt(0).toUpperCase() + word.slice(1).toLowerCase();\n\t\t})\n\t\t.join('');\n}\n\nfunction getLastSegment(input: string): string {\n\tconst segments = input.split('::');\n\treturn segments.length > 0 ? segments[segments.length - 1] : '';\n}\n\nfunction buildContract(projectPath: string): string[][] {\n\tlet modules: any, dependencies: any;\n\ttry {\n\t\tconst buildResult = JSON.parse(\n\t\t\texecSync(\n\t\t\t\t`sui move build --dump-bytecode-as-base64 --path ${projectPath}`,\n\t\t\t\t{\n\t\t\t\t\tencoding: 'utf-8',\n\t\t\t\t}\n\t\t\t)\n\t\t);\n\t\tmodules = buildResult.modules;\n\t\tdependencies = buildResult.dependencies;\n\t\tconsole.log(' └─ Build successful');\n\t} catch (error: any) {\n\t\tconsole.error(chalk.red(' └─ Build failed'));\n\t\tconsole.error(error.stdout);\n\t\tprocess.exit(1);\n\t}\n\treturn [modules, dependencies];\n}\n\nasync function publishContract(\n\tclient: SuiClient,\n\tdubhe: Dubhe,\n\tdubheConfig: DubheConfig,\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n\tprojectPath: string\n) {\n\tconst dappsObjectId = await getDappsObjectId(network);\n\tconsole.log(\"dappsObjectId\", dappsObjectId);\n\tconst chainId = await client.getChainIdentifier();\n\tremoveEnvContent(`${projectPath}/Move.lock`, network);\n\tconsole.log('\\nšŸš€ Starting Contract Publication...');\n\tconsole.log(` ā”œā”€ Project: ${projectPath}`);\n\tconsole.log(` ā”œā”€ Network: ${network}`);\n\tconsole.log(` ā”œā”€ ChainId: ${chainId}`);\n\tconsole.log(' ā”œā”€ Validating Environment...');\n\n\tconst keypair = dubhe.getKeypair();\n\tconsole.log(` └─ Account: ${keypair.toSuiAddress()}`);\n\n\tconsole.log('\\nšŸ“¦ Building Contract...');\n\tconst [modules, dependencies] = buildContract(projectPath);\n\n\tconsole.log('\\nšŸ”„ Publishing Contract...');\n\tconst tx = new Transaction();\n\tconst [upgradeCap] = tx.publish({ modules, dependencies });\n\ttx.transferObjects([upgradeCap], keypair.toSuiAddress());\n\n\tlet result: SuiTransactionBlockResponse;\n\ttry {\n\t\tresult = await client.signAndExecuteTransaction({\n\t\t\tsigner: keypair,\n\t\t\ttransaction: tx,\n\t\t\toptions: { showObjectChanges: true },\n\t\t});\n\t} catch (error: any) {\n\t\tconsole.error(chalk.red(' └─ Publication failed'));\n\t\tconsole.error(error.message);\n\t\tprocess.exit(1);\n\t}\n\n\tif (result.effects?.status.status === 'failure') {\n\t\tconsole.log(chalk.red(' └─ Publication failed'));\n\t\tprocess.exit(1);\n\t}\n\n\tconsole.log(' ā”œā”€ Processing publication results...');\n\tlet version = 1;\n\tlet packageId = '';\n\tlet schemas: schema[] = [];\n\tlet upgradeCapId = '';\n\tlet schemaHubId = '';\n\n\tresult.objectChanges!.map(object => {\n\t\tif (object.type === 'published') {\n\t\t\tconsole.log(` ā”œā”€ Package ID: ${object.packageId}`);\n\t\t\tpackageId = object.packageId;\n\t\t}\n\t\tif (\n\t\t\tobject.type === 'created' &&\n\t\t\tobject.objectType === '0x2::package::UpgradeCap'\n\t\t) {\n\t\t\tconsole.log(` ā”œā”€ Upgrade Cap: ${object.objectId}`);\n\t\t\tupgradeCapId = object.objectId;\n\t\t}\n\t\tif (\n\t\t\tobject.type === 'created' &&\n\t\t\tobject.objectType.includes(\"schema_hub\")\n\t\t) {\n\t\t\tconsole.log(` ā”œā”€ Schema Hub: ${object.objectId}`);\n\t\t\tschemaHubId = object.objectId;\n\t\t}\n\t});\n\n\tconsole.log(` └─ Transaction: ${result.digest}`);\n\n\tupdateEnvFile(`${projectPath}/Move.lock`, network, 'publish', chainId, packageId);\n\n\tconsole.log('\\n⚔ Executing Deploy Hook...');\n\tawait delay(5000);\n\n\tconst deployHookTx = new Transaction();\n\tdeployHookTx.setGasBudget(2000000000);\n\tconst [txCoin] = deployHookTx.splitCoins(deployHookTx.gas, [\"1000000000\"]);\n\tdeployHookTx.moveCall({\n\t\ttarget: `${packageId}::deploy_hook::run`,\n\t\targuments: [\n\t\t\tdeployHookTx.object(schemaHubId),\n\t\t\tdeployHookTx.object(dappsObjectId),\n\t\t\tdeployHookTx.object(upgradeCapId),\n\t\t\tdeployHookTx.object('0x6'),\n\t\t\ttxCoin\n\t\t],\n\t});\n\n\tlet deployHookResult: SuiTransactionBlockResponse;\n\ttry {\n\t\tdeployHookResult = await client.signAndExecuteTransaction({\n\t\t\tsigner: keypair,\n\t\t\ttransaction: deployHookTx,\n\t\t\toptions: { showEffects: true, showObjectChanges: true },\n\t\t});\n\t} catch (error: any) {\n\t\tconsole.error(chalk.red(' └─ Deploy hook execution failed'));\n\t\tconsole.error(error.message);\n\t\tprocess.exit(1);\n\t}\n\n\tif (deployHookResult.effects?.status.status === 'success') {\n\t\tconsole.log(' ā”œā”€ Hook execution successful');\n\t\tconsole.log(` ā”œā”€ Transaction: ${deployHookResult.digest}`);\n\n\t\tconsole.log('\\nšŸ“‹ Created Schemas:');\n\t\tdeployHookResult.objectChanges?.map(object => {\n\t\t\tif (\n\t\t\t\tobject.type === 'created' &&\n\t\t\t\tobject.objectType.includes('_schema') && !object.objectType.includes(\"dynamic_field\")\n\t\t\t) {\n\t\t\t\tconsole.log(` ā”œā”€ ${object.objectType}`);\n\t\t\t\tconsole.log(` └─ ID: ${object.objectId}`);\n\n\t\t\t\tlet structure: Record<string, string> = {};\n\t\t\t\tfor (let schemaKey in dubheConfig.schemas) {\n\t\t\t\t\tif (capitalizeAndRemoveUnderscores(schemaKey) === getLastSegment(object.objectType)) {\n\t\t\t\t\t\tstructure = dubheConfig.schemas[schemaKey].structure;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tschemas.push({\n\t\t\t\t\tname: object.objectType,\n\t\t\t\t\tobjectId: object.objectId,\n\t\t\t\t\tstructure,\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\n\t\tsaveContractData(\n\t\t\tdubheConfig.name,\n\t\t\tnetwork,\n\t\t\tpackageId,\n\t\t\tupgradeCapId,\n\t\t\tschemaHubId,\n\t\t\tversion,\n\t\t\tschemas,\n\t\t);\n\t\tconsole.log('\\nāœ… Contract Publication Complete\\n');\n\t} else {\n\t\tconsole.log(chalk.yellow(' └─ Deploy hook execution failed'));\n\t\tconsole.log(\n\t\t\tchalk.yellow(\n\t\t\t\t' Please republish or manually call deploy_hook::run'\n\t\t\t)\n\t\t);\n\t}\n}\n\nasync function publishDubheFramework(\n\tclient: SuiClient,\n\tdubhe: Dubhe,\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n) {\n\tconst path = process.cwd();\n\tconst projectPath = `${path}/contracts/dubhe-framework`;\n\tconst chainId = await client.getChainIdentifier();\n\tconsole.log(` └─ Chain ID: ${chainId}`);\n\tremoveEnvContent(`${projectPath}/Move.lock`, network);\n\tconsole.log('\\nšŸš€ Starting Contract Publication...');\n\tconsole.log(` ā”œā”€ Project: ${projectPath}`);\n\tconsole.log(` ā”œā”€ Network: ${network}`);\n\tconsole.log(` ā”œā”€ ChainId: ${chainId}`);\n\tconsole.log(' ā”œā”€ Validating Environment...');\n\n\tconst keypair = dubhe.getKeypair();\n\tconsole.log(` └─ Account: ${keypair.toSuiAddress()}`);\n\n\n\tconsole.log('\\nšŸ“¦ Building Contract...');\n\tconst [modules, dependencies] = buildContract(projectPath);\n\n\tconsole.log('\\nšŸ”„ Publishing Contract...');\n\tconst tx = new Transaction();\n\tconst [upgradeCap] = tx.publish({ modules, dependencies });\n\ttx.transferObjects([upgradeCap], keypair.toSuiAddress());\n\n\tlet result: SuiTransactionBlockResponse;\n\ttry {\n\t\tresult = await client.signAndExecuteTransaction({\n\t\t\tsigner: keypair,\n\t\t\ttransaction: tx,\n\t\t\toptions: { showObjectChanges: true },\n\t\t});\n\t} catch (error: any) {\n\t\tconsole.error(chalk.red(' └─ Publication failed'));\n\t\tconsole.error(error.message);\n\t\tprocess.exit(1);\n\t}\n\n\tif (result.effects?.status.status === 'failure') {\n\t\tconsole.log(chalk.red(' └─ Publication failed'));\n\t\tprocess.exit(1);\n\t}\n\n\tconsole.log(' ā”œā”€ Processing publication results...');\n\tlet version = 1;\n\tlet packageId = '';\n\tlet schemas: schema[] = [];\n\tlet upgradeCapId = '';\n\tlet schemaHubId = '';\n\n\tresult.objectChanges!.map(object => {\n\t\tif (object.type === 'published') {\n\t\t\tconsole.log(` ā”œā”€ Package ID: ${object.packageId}`);\n\t\t\tpackageId = object.packageId;\n\t\t}\n\t\tif (\n\t\t\tobject.type === 'created' &&\n\t\t\tobject.objectType === '0x2::package::UpgradeCap'\n\t\t) {\n\t\t\tconsole.log(` ā”œā”€ Upgrade Cap: ${object.objectId}`);\n\t\t\tupgradeCapId = object.objectId;\n\t\t}\n\t\tif (\n\t\t\tobject.type === 'created' &&\n\t\t\tobject.objectType.includes(\"dapps\")\n\t\t) {\n\t\t\tconsole.log(` ā”œā”€ Dapps: ${object.objectId}`);\n\t\t\tschemaHubId = object.objectId;\n\t\t}\n\t});\n\n\tconsole.log(` └─ Transaction: ${result.digest}`);\n\n\tupdateEnvFile(`${projectPath}/Move.lock`, network, 'publish', chainId, packageId);\n\n\tsaveContractData(\n\t\t\"dubhe-framework\",\n\t\tnetwork,\n\t\tpackageId,\n\t\tupgradeCapId,\n\t\tschemaHubId,\n\t\tversion,\n\t\tschemas,\n\t);\n}\n\nexport async function publishHandler(\n\tdubheConfig: DubheConfig,\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n\tcontractName?: string,\n) {\n\tawait switchEnv(network);\n\n\tconst privateKey = process.env.PRIVATE_KEY;\n\tif (!privateKey) {\n\t\tthrow new DubheCliError(\n\t\t\t`Missing PRIVATE_KEY environment variable.\nRun 'echo \"PRIVATE_KEY=YOUR_PRIVATE_KEY\" > .env'\nin your contracts directory to use the default sui private key.`\n\t\t);\n\t}\n\tconst privateKeyFormat = validatePrivateKey(privateKey);\n\tif (privateKeyFormat === false) {\n\t\tthrow new DubheCliError(`Please check your privateKey.`);\n\t}\n\n\tconst dubhe = new Dubhe({ secretKey: privateKeyFormat });\n\tconst client = new SuiClient({ url: getFullnodeUrl(network) });\n\n\tif (contractName == \"dubhe-framework\") {\n\t\tawait publishDubheFramework(client, dubhe, network);\n\t} else {\n\t\tconst path = process.cwd();\n\t\tconst projectPath = `${path}/contracts/${dubheConfig.name}`;\n\t\tupdateDubheDependency(`${projectPath}/Move.toml`, network);\n\t\tawait publishContract(client, dubhe, dubheConfig, network, projectPath);\n\t}\n}\n","import chalk from \"chalk\";\nimport { ZodError } from \"zod\";\nimport { fromZodError, ValidationError } from \"zod-validation-error\";\n\nexport class NotInsideProjectError extends Error {\n name = \"NotInsideProjectError\";\n message = \"You are not inside a Dubhe project\";\n}\n\nexport class DubheCliError extends Error {\n name = \"DubheCliError\";\n}\n\nexport class UpgradeError extends Error {\n name = \"UpgradeError\";\n}\n\nexport class FsIibError extends Error {\n name = \"FsIibError\";\n}\n\nexport function logError(error: unknown) {\n if (error instanceof ValidationError) {\n console.log(chalk.redBright(error.message));\n } else if (error instanceof ZodError) {\n // TODO currently this error shouldn't happen, use `fromZodErrorCustom`\n const validationError = fromZodError(error, {\n prefixSeparator: \"\\n- \",\n issueSeparator: \"\\n- \",\n });\n console.log(chalk.redBright(validationError.message));\n } else if (error instanceof NotInsideProjectError) {\n console.log(chalk.red(error.message));\n console.log(\"\");\n // TODO add docs to the website and update the link to the specific page\n console.log(\n chalk.blue(\n `To learn more about Dubhe's configuration, please go to https://github.com/0xobelisk`\n )\n );\n } else if (error instanceof DubheCliError) {\n console.log(chalk.red(error));\n } else {\n console.log(error);\n }\n}\n","import * as fsAsync from 'fs/promises';\nimport { mkdirSync, writeFileSync } from 'fs';\nimport { dirname } from 'path';\nimport { SUI_PRIVATE_KEY_PREFIX } from '@mysten/sui/cryptography';\nimport { FsIibError } from './errors';\nexport * from './localnode';\nimport * as fs from 'fs';\nimport chalk from 'chalk';\nimport { spawn } from 'child_process';\n\nexport type schema = {\n\tname: string;\n\tobjectId: string;\n\tstructure: Record<string, string>\n};\n\nexport type DeploymentJsonType = {\n\tprojectName: string;\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet';\n\tpackageId: string;\n\tupgradeCap: string;\n\tschemaHub: string;\n\tversion: number;\n\tschemas: schema[];\n};\n\nexport function validatePrivateKey(privateKey: string): false | string {\n\tif (privateKey.startsWith(SUI_PRIVATE_KEY_PREFIX)) {\n\t\tif (privateKey.length === 70) {\n\t\t\treturn privateKey;\n\t\t} else {\n\t\t\treturn false;\n\t\t}\n\t} else if (privateKey.startsWith('0x')) {\n\t\tconst strippedPrivateKey = privateKey.slice(2);\n\t\tif (strippedPrivateKey.length === 64) {\n\t\t\treturn strippedPrivateKey;\n\t\t} else {\n\t\t\treturn false;\n\t\t}\n\t} else {\n\t\tif (privateKey.length === 64) {\n\t\t\treturn privateKey;\n\t\t} else {\n\t\t\treturn false;\n\t\t}\n\t}\n}\n\nexport async function updateVersionInFile(\n\tprojectPath: string,\n\tnewVersion: string\n) {\n\ttry {\n\t\tconst filePath = `${projectPath}/sources/script/migrate.move`;\n\t\tconst data = await fsAsync.readFile(filePath, 'utf8');\n\n\t\t// update version data\n\t\tconst updatedData = data.replace(\n\t\t\t/const VERSION: u64 = \\d+;/,\n\t\t\t`const VERSION: u64 = ${newVersion};`\n\t\t);\n\n\t\t// write new version\n\t\twriteOutput(updatedData, filePath, 'Update package version');\n\t} catch {\n\t\tthrow new FsIibError('Fs update version failed.');\n\t}\n}\n\nasync function getDeploymentJson(projectPath: string, network: string) {\n\ttry {\n\t\tconst data = await fsAsync.readFile(\n\t\t\t`${projectPath}/.history/sui_${network}/latest.json`,\n\t\t\t'utf8'\n\t\t);\n\t\treturn JSON.parse(data) as DeploymentJsonType;\n\t} catch {\n\t\tthrow new FsIibError('Fs read deployment file failed.');\n\t}\n}\n\nexport async function getOnchainSchemas(\n\tprojectPath: string,\n\tnetwork: string\n): Promise<schema[]> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.schemas;\n}\n\nexport async function getVersion(\n\tprojectPath: string,\n\tnetwork: string\n): Promise<number> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.version;\n}\n\nexport async function getNetwork(\n\tprojectPath: string,\n\tnetwork: string\n): Promise<'mainnet' | 'testnet' | 'devnet' | 'localnet'> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.network;\n}\n\nexport async function getOldPackageId(\n\tprojectPath: string,\n\tnetwork: string\n): Promise<string> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.packageId;\n}\n\nexport async function getUpgradeCap(\n\tprojectPath: string,\n\tnetwork: string\n): Promise<string> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.upgradeCap;\n}\n\nexport async function getSchemaHub(\n\tprojectPath: string,\n\tnetwork: string\n): Promise<string> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.schemaHub;\n}\n\nexport async function getObjectIdBySchemaName(\n\tprojectPath: string,\n\tnetwork: string,\n\tschemaName: string\n): Promise<string | undefined> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.schemas.find(schema => schema.name.includes(schemaName))\n\t\t?.objectId;\n}\n\nexport function saveContractData(\n\tprojectName: string,\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n\tpackageId: string,\n\tupgradeCap: string,\n\tschemaHub: string,\n\tversion: number,\n schemas: schema[],\n) {\n\tconst DeploymentData: DeploymentJsonType = {\n\t\tprojectName,\n\t\tnetwork,\n\t\tpackageId,\n\t\tschemas,\n\t\tupgradeCap,\n\t\tschemaHub,\n\t\tversion,\n\t};\n\n\tconst path = process.cwd();\n\tconst storeDeploymentData = JSON.stringify(DeploymentData, null, 2);\n\twriteOutput(\n\t\tstoreDeploymentData,\n\t\t`${path}/contracts/${projectName}/.history/sui_${network}/latest.json`,\n\t\t'Update deploy log'\n\t);\n}\n\nexport async function writeOutput(\n\toutput: string,\n\tfullOutputPath: string,\n\tlogPrefix?: string\n): Promise<void> {\n\tmkdirSync(dirname(fullOutputPath), { recursive: true });\n\n\twriteFileSync(fullOutputPath, output);\n\tif (logPrefix !== undefined) {\n\t\tconsole.log(`${logPrefix}: ${fullOutputPath}`);\n\t}\n}\n\nfunction getDubheDependency(network: 'mainnet' | 'testnet' | 'devnet' | 'localnet'): string {\n\tswitch (network) {\n\t\tcase 'localnet':\n\t\t\treturn 'Dubhe = { local = \"../dubhe-framework\" }';\n\t\tcase 'testnet':\n\t\t\treturn 'Dubhe = { git = \"https://github.com/0xobelisk/dubhe-framework.git\", rev = \"dubhe-testnet-v1.0.0\" }';\n\t\tcase 'mainnet':\n\t\t\treturn 'Dubhe = { git = \"https://github.com/0xobelisk/dubhe-framework.git\", rev = \"dubhe-mainnet-v1.0.0\" }';\n\t\tdefault:\n\t\t\tthrow new Error(`Unsupported network: ${network}`);\n\t}\n}\n\nexport function updateDubheDependency(filePath: string, network: 'mainnet' | 'testnet' | 'devnet' | 'localnet') {\n\tconst fileContent = fs.readFileSync(filePath, 'utf-8');\n\tconst newDependency = getDubheDependency(network);\n\tconst updatedContent = fileContent.replace(/Dubhe = \\{.*\\}/, newDependency);\n\tfs.writeFileSync(filePath, updatedContent, 'utf-8');\n\tconsole.log(`Updated Dubhe dependency in ${filePath} for ${network}.`);\n}\nexport async function switchEnv(network: 'mainnet' | 'testnet' | 'devnet' | 'localnet') {\n\ttry {\n\t\treturn new Promise<void>((resolve, reject) => {\n\t\t\tconst suiProcess = spawn(\n\t\t\t\t'sui',\n\t\t\t\t['client', 'switch', '--env', network],\n\t\t\t\t{\n\t\t\t\t\tenv: { ...process.env },\n\t\t\t\t\tstdio: 'pipe'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tsuiProcess.stdout.on('data', data => {\n\t\t\t\tconsole.log(chalk.green(`${data.toString()}`));\n\t\t\t});\n\n\t\t\tsuiProcess.stderr.on('data', data => {\n\t\t\t\tconsole.error(chalk.red('\\nāŒ Failed to Switch Env'));\n\t\t\t\tconsole.error(chalk.red(` Error: ${data.toString()}`));\n\t\t\t});\n\n\t\t\tsuiProcess.on('error', error => {\n\t\t\t\tconsole.error(chalk.red('\\nāŒ Failed to Switch Env'));\n\t\t\t\tconsole.error(chalk.red(` Error: ${error.message}`));\n\t\t\t\treject(error); // Reject promise on error\n\t\t\t});\n\n\t\t\tsuiProcess.on('exit', (code) => {\n\t\t\t\tif (code !== 0) {\n\t\t\t\t\tconsole.error(chalk.red(`\\nāŒ Process exited with code: ${code}`));\n\t\t\t\t\treject(new Error(`Process exited with code: ${code}`));\n\t\t\t\t} else {\n\t\t\t\t\tconsole.log(chalk.green('\\nāœ… Environment switched successfully.'));\n\t\t\t\t\tresolve(); // Resolve promise on successful exit\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t} catch (error) {\n\t\tconsole.error(chalk.red('\\nāŒ Failed to Switch Env'));\n\t\tconsole.error(chalk.red(` └─ Error: ${error}`));\n\t}\n}\n\nexport const delay = (ms: number) =>\n\tnew Promise(resolve => setTimeout(resolve, ms));\n","import { execSync, spawn } from 'child_process';\nimport chalk from 'chalk';\n\nfunction isSuiStartRunning(): boolean {\n\ttry {\n\t\tconst cmd =\n\t\t\tprocess.platform === 'win32'\n\t\t\t\t? `tasklist /FI \"IMAGENAME eq sui.exe\" /FO CSV /NH`\n\t\t\t\t: 'pgrep -f \"sui start\"';\n\n\t\tconst result = execSync(cmd).toString().trim();\n\t\treturn process.platform === 'win32'\n\t\t\t? result.toLowerCase().includes('sui.exe')\n\t\t\t: result.length > 0;\n\t} catch (error) {\n\t\treturn false;\n\t}\n}\n\nexport async function startLocalnode(background: boolean = false) {\n\tconsole.log('\\nšŸ” Checking Local Node Status...');\n\tconsole.log(' ā”œā”€ Scanning running processes');\n\n\tif (isSuiStartRunning()) {\n\t\tconsole.log(chalk.yellow('\\nāš ļø Warning: Local Node Already Running'));\n\t\tconsole.log(chalk.yellow(' ā”œā”€ Cannot start a new instance'));\n\t\tconsole.log(\n\t\t\tchalk.yellow(' └─ Please stop the existing process first')\n\t\t);\n\t\treturn;\n\t}\n\n\tconsole.log('\\nšŸš€ Starting Local Node...');\n\tconsole.log(' ā”œā”€ Mode: ' + (background ? 'Background' : 'Foreground'));\n\tconsole.log(' ā”œā”€ Faucet: Enabled');\n\tconsole.log(' └─ Force Regenesis: Yes');\n\n\ttry {\n\t\tconst suiProcess = spawn(\n\t\t\t'sui',\n\t\t\t['start', '--with-faucet', '--force-regenesis'],\n\t\t\t{\n\t\t\t\tenv: { ...process.env, RUST_LOG: 'off,sui_node=info' },\n\t\t\t\tstdio: background ? 'ignore' : 'inherit',\n\t\t\t\tdetached: background,\n\t\t\t}\n\t\t);\n\n\t\tsuiProcess.on('error', error => {\n\t\t\tconsole.error(chalk.red('\\nāŒ Failed to Start Local Node'));\n\t\t\tconsole.error(chalk.red(` └─ Error: ${error.message}`));\n\t\t});\n\n\t\tif (!background) {\n\t\t\tsuiProcess.on('exit', code => {\n\t\t\t\tif (code === 0) {\n\t\t\t\t\tconsole.log(chalk.green('\\nāœ… Local Node Stopped'));\n\t\t\t\t\tconsole.log(chalk.green(' └─ Exit Status: Normal'));\n\t\t\t\t} else {\n\t\t\t\t\tconsole.error(chalk.red('\\nāŒ Local Node Crashed'));\n\t\t\t\t\tconsole.error(chalk.red(` └─ Exit Code: ${code}`));\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tconsole.log(chalk.cyan('\\nšŸ“” Local Node Running'));\n\t\t\tconsole.log(chalk.cyan(' └─ Press Ctrl+C to stop'));\n\n\t\t\tawait new Promise(() => {});\n\t\t} else {\n\t\t\tsuiProcess.unref();\n\t\t\tconsole.log(chalk.green('\\nāœ… Local Node Started in Background'));\n\n\t\t\tif (process.platform === 'win32') {\n\t\t\t\tconsole.log('\\nšŸ’” Helpful Commands:');\n\t\t\t\tconsole.log(' ā”œā”€ Check Process: tasklist | findstr sui.exe');\n\t\t\t\tconsole.log(' └─ Stop Node: taskkill /PID <process_id> /F');\n\t\t\t} else {\n\t\t\t\tconsole.log('\\nšŸ’” Helpful Commands:');\n\t\t\t\tconsole.log(\" ā”œā”€ Check Process: pgrep -f 'sui start'\");\n\t\t\t\tconsole.log(' └─ Stop Node: kill <process_id>');\n\t\t\t}\n\t\t}\n\t} catch (error: any) {\n\t\tconsole.error(chalk.red('\\nāŒ Failed to Start Local Node'));\n\t\tconsole.error(chalk.red(` └─ Error: ${error.message}`));\n\t}\n}\n","import { execSync } from 'child_process';\nimport chalk from 'chalk';\n\nexport async function checkLocalNodeStatus() {\n\tconsole.log('\\nšŸ” Checking Local Node Status...');\n\n\ttry {\n\t\tconst cmd =\n\t\t\tprocess.platform === 'win32'\n\t\t\t\t? `tasklist /FI \"IMAGENAME eq sui.exe\" /FO CSV /NH`\n\t\t\t\t: \"ps aux | grep '[s]ui start --with-faucet --force-regenesis'\";\n\n\t\tconst output = execSync(cmd, {\n\t\t\tencoding: 'utf8',\n\t\t});\n\n\t\tconst isRunning =\n\t\t\tprocess.platform === 'win32'\n\t\t\t\t? output.toLowerCase().includes('sui.exe')\n\t\t\t\t: output.split('\\n').filter(Boolean).length > 0;\n\n\t\tif (isRunning) {\n\t\t\tconsole.log(chalk.green('\\nāœ… Node Status: Running'));\n\t\t\tconsole.log(chalk.gray('\\nšŸ“Š Process Details:'));\n\t\t\tconsole.log(chalk.gray(` └─ ${output.trim()}`));\n\t\t} else {\n\t\t\tconsole.log(chalk.red('\\nāŒ Node Status: Not Running'));\n\t\t\tconsole.log(chalk.yellow('\\nšŸ’” Quick Start:'));\n\t\t\tconsole.log(chalk.yellow(' └─ Run `dubhe localnode start`'));\n\t\t}\n\t} catch (error) {\n\t\tconsole.log(chalk.red('\\nāŒ Node Status: Not Running'));\n\t\tconsole.log(chalk.yellow('\\nšŸ’” Quick Start:'));\n\t\tconsole.log(chalk.yellow(' └─ Run `dubhe localnode start`'));\n\t}\n}\n\n// checkLocalNodeStatus();\n","import { execSync } from 'child_process';\n\nexport async function stopLocalnode() {\n\tconsole.log('Stopping local node...');\n\n\ttry {\n\t\t// Choose different commands based on the operating system\n\t\tconst cmd =\n\t\t\tprocess.platform === 'win32'\n\t\t\t\t? `tasklist /FI \"IMAGENAME eq sui.exe\" /FO CSV /NH`\n\t\t\t\t: \"ps aux | grep '[s]ui start --with-faucet --force-regenesis'\";\n\n\t\tconst output = execSync(cmd, {\n\t\t\tencoding: 'utf8',\n\t\t});\n\n\t\tif (!output) {\n\t\t\tconsole.log('No running local node process found');\n\t\t\treturn;\n\t\t}\n\n\t\t// Parse process ID based on the operating system\n\t\tlet pid;\n\t\tif (process.platform === 'win32') {\n\t\t\t// Windows output format: \"sui.exe\",\"1234\",... (CSV format)\n\t\t\tconst match = output.match(/\"sui\\.exe\",[\"']?(\\d+)/i);\n\t\t\tpid = match ? match[1] : null;\n\t\t} else {\n\t\t\t// Unix system output format: user pid %cpu ...\n\t\t\tpid = output.toString().split(/\\s+/)[1];\n\t\t}\n\n\t\tif (!pid) {\n\t\t\tconsole.log('No running local node process found');\n\t\t\treturn;\n\t\t}\n\n\t\t// Choose the command to terminate the process based on the operating system\n\t\tif (process.platform === 'win32') {\n\t\t\texecSync(`taskkill /PID ${pid} /F`);\n\t\t} else {\n\t\t\tprocess.kill(Number(pid));\n\t\t}\n\n\t\tconsole.log('āœ… Local node stopped successfully');\n\t} catch (error: any) {\n\t\tif (\n\t\t\terror.code === 'ESRCH' ||\n\t\t\terror.message.includes('no running tasks')\n\t\t) {\n\t\t\tconsole.log('No running local node process found');\n\t\t} else {\n\t\t\tconsole.error('āŒ Error stopping local node:', error.message);\n\t\t}\n\t}\n}\n\n// stopLocalnode();\n","import chalk from \"chalk\";\n\nexport function printDubhe() {\n console.log(\n chalk.yellow(`\nWelcome to Dubhe\n\\t\\t\\t --from team@obelisk\n ________ ___ ___ ________ ___ ___ _______ \n |\\\\ ___ \\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ \\\\|\\\\ \\\\|\\\\ ___ \\\\ \n \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ /\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ __/| \n \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\_|/__ \n \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \n \\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\\n \\\\|_______|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__|\\\\|_______| \n \n`)\n );\n}\n","import type { CommandModule } from 'yargs';\nimport { startLocalnode, stopLocalnode, checkLocalNodeStatus } from '../utils';\n\nconst commandModule: CommandModule = {\n\tcommand: 'localnode <action>',\n\n\tdescribe: 'Manage local Sui node',\n\n\tbuilder(yargs) {\n\t\treturn yargs\n\t\t\t.positional('action', {\n\t\t\t\tdescribe: 'Action to perform',\n\t\t\t\tchoices: ['start', 'stop', 'status', 'restart'],\n\t\t\t\ttype: 'string',\n\t\t\t\tdemandOption: true,\n\t\t\t})\n\t\t\t.option('background', {\n\t\t\t\talias: 'b',\n\t\t\t\ttype: 'boolean',\n\t\t\t\tdescription: 'Run node in background',\n\t\t\t\tdefault: false,\n\t\t\t});\n\t},\n\n\tasync handler(argv) {\n\t\tconst { action, background } = argv;\n\n\t\ttry {\n\t\t\tswitch (action) {\n\t\t\t\tcase 'start':\n\t\t\t\t\tawait startLocalnode(background as boolean);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'stop':\n\t\t\t\t\tawait stopLocalnode();\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'status':\n\t\t\t\t\tawait checkLocalNodeStatus();\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'restart':\n\t\t\t\t\tawait restartNode(background as boolean);\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t} catch (error) {\n\t\t\tconsole.error('Error executing command:', error);\n\t\t\tprocess.exit(1);\n\t\t}\n\t},\n};\n\nasync function restartNode(background: boolean) {\n\tconsole.log('Restarting local Sui node...');\n\tawait stopLocalnode();\n\tawait startLocalnode(background);\n\tconsole.log('Local node has been restarted');\n}\n\nexport default commandModule;\n","import { Dubhe } from '@0xobelisk/sui-client';\nimport type { CommandModule } from 'yargs';\nimport { requestSuiFromFaucetV0, getFaucetHost } from '@mysten/sui/faucet';\nimport {\n\tSuiClient,\n\tgetFullnodeUrl,\n\tGetBalanceParams,\n} from '@mysten/sui/client';\nimport { validatePrivateKey, DubheCliError } from '../utils';\n\ntype Options = {\n\tnetwork: any;\n\trecipient?: string;\n};\n\nconst commandModule: CommandModule<Options, Options> = {\n\tcommand: 'faucet',\n\n\tdescribe: 'Interact with a Dubhe faucet',\n\n\tbuilder(yargs) {\n\t\treturn yargs.options({\n\t\t\tnetwork: {\n\t\t\t\ttype: 'string',\n\t\t\t\tdesc: 'URL of the Dubhe faucet',\n\t\t\t\tchoices: ['testnet', 'devnet', 'localnet'],\n\t\t\t\tdefault: 'localnet',\n\t\t\t},\n\t\t\trecipient: {\n\t\t\t\ttype: 'string',\n\t\t\t\tdesc: 'Sui address to fund',\n\t\t\t},\n\t\t});\n\t},\n\n\tasync handler({ network, recipient }) {\n\t\tlet faucet_address = '';\n\t\tif (recipient === undefined) {\n\t\t\tconst privateKey = process.env.PRIVATE_KEY;\n\t\t\tif (!privateKey)\n\t\t\t\tthrow new DubheCliError(\n\t\t\t\t\t`Missing PRIVATE_KEY environment variable.\n Run 'echo \"PRIVATE_KEY=YOUR_PRIVATE_KEY\" > .env'\n in your contracts directory to use the default sui private key.`\n\t\t\t\t);\n\n\t\t\tconst privateKeyFormat = validatePrivateKey(privateKey);\n\t\t\tif (privateKeyFormat === false) {\n\t\t\t\tthrow new DubheCliError(`Please check your PRIVATE_KEY.`);\n\t\t\t}\n\t\t\tconst dubhe = new Dubhe({\n\t\t\t\tsecretKey: privateKeyFormat,\n\t\t\t});\n\t\t\tconst keypair = dubhe.getKeypair();\n\t\t\tfaucet_address = keypair.toSuiAddress();\n\t\t} else {\n\t\t\tfaucet_address = recipient;\n\t\t}\n\n\t\tconsole.log('\\n🌊 Starting Faucet Operation...');\n\t\tconsole.log(` ā”œā”€ Network: ${network}`);\n\n\t\tif (recipient === undefined) {\n\t\t\tconsole.log(' ā”œā”€ Using Environment PrivateKey');\n\t\t\tconsole.log(` ā”œā”€ Generated Address: ${faucet_address}`);\n\t\t} else {\n\t\t\tconsole.log(` ā”œā”€ Using Provided Address: ${faucet_address}`);\n\t\t}\n\n\t\tconsole.log(' ā”œā”€ Requesting funds from faucet...');\n\t\tawait requestSuiFromFaucetV0({\n\t\t\thost: getFaucetHost(network),\n\t\t\trecipient: faucet_address,\n\t\t});\n\n\t\tconsole.log(' └─ Checking balance...');\n\t\tconst client = new SuiClient({ url: getFullnodeUrl(network) });\n\t\tlet params = {\n\t\t\towner: faucet_address,\n\t\t} as GetBalanceParams;\n\n\t\tconst balance = await client.getBalance(params);\n\n\t\tconsole.log('\\nšŸ’° Account Summary');\n\t\tconsole.log(` ā”œā”€ Address: ${faucet_address}`);\n\t\tconsole.log(\n\t\t\t` └─ Balance: ${(\n\t\t\t\tNumber(balance.totalBalance) / 1_000_000_000\n\t\t\t).toFixed(4)} SUI`\n\t\t);\n\n\t\tconsole.log('\\nāœ… Faucet Operation Complete\\n');\n\t\tprocess.exit(0);\n\t},\n};\n\nexport default commandModule;\n","import type { CommandModule } from 'yargs';\nimport { schemaGen, loadConfig, DubheConfig } from '@0xobelisk/sui-common';\nimport chalk from 'chalk';\n\ntype Options = {\n\t'config-path'?: string;\n\tnetwork?: 'mainnet' | 'testnet' | 'devnet' | 'localnet';\n\t'framework-id'?: string;\n};\n\nconst commandModule: CommandModule<Options, Options> = {\n\tcommand: 'schemagen',\n\n\tdescribe: 'Autogenerate Dubhe schemas based on the config file',\n\n\tbuilder: {\n\t\t'config-path': {\n\t\t\ttype: 'string',\n\t\t\tdefault: 'dubhe.config.ts',\n\t\t\tdesc: 'Path to the config file',\n\t\t},\n\t\tnetwork: {\n\t\t\ttype: 'string',\n\t\t\tchoices: ['mainnet', 'testnet', 'devnet', 'localnet'] as const,\n\t\t\tdesc: 'Node network (mainnet/testnet/devnet/localnet)',\n\t\t},\n\t\t'framework-id': {\n\t\t\ttype: 'string',\n\t\t\tdesc: 'Framework Package ID',\n\t\t},\n\t},\n\n\tasync handler({\n\t\t'config-path': configPath,\n\t\tnetwork,\n\t\t'framework-id': frameworkId,\n\t}) {\n\t\ttry {\n\t\t\tconst dubheConfig = (await loadConfig(configPath)) as DubheConfig;\n\t\t\tawait schemaGen(dubheConfig, undefined, network, frameworkId);\n\t\t\tprocess.exit(0);\n\t\t} catch (error: any) {\n\t\t\tconsole.log(chalk.red('Schemagen failed!'));\n\t\t\tconsole.error(error.message);\n\t\t}\n\t},\n};\n\nexport default commandModule;\n","import type { CommandModule } from 'yargs';\nimport { logError } from '../utils/errors';\nimport { publishHandler } from '../utils';\nimport { loadConfig, DubheConfig } from '@0xobelisk/sui-common';\n\ntype Options = {\n\tnetwork: any;\n\t'config-path': string;\n\t'contract-name'?: string;\n};\n\nconst commandModule: CommandModule<Options, Options> = {\n\tcommand: 'publish',\n\n\tdescribe: 'Publish dubhe move contract',\n\n\tbuilder(yargs) {\n\t\treturn yargs.options({\n\t\t\tnetwork: {\n\t\t\t\ttype: 'string',\n\t\t\t\tchoices: ['mainnet', 'testnet', 'devnet', 'localnet'],\n\t\t\t\tdesc: 'Node network (mainnet/testnet/devnet/localnet)',\n\t\t\t},\n\t\t\t'config-path': {\n\t\t\t\ttype: 'string',\n\t\t\t\tdefault: 'dubhe.config.ts',\n\t\t\t\tdesc: 'Configuration file path',\n\t\t\t},\n\t\t\t'contract-name': {\n\t\t\t\ttype: 'string',\n\t\t\t\tdesc: 'Optional contract name in contracts/ directory',\n\t\t\t},\n\t\t});\n\t},\n\n\tasync handler({\n\t\tnetwork,\n\t\t'config-path': configPath,\n\t\t'contract-name': contractName,\n\t}) {\n\t\ttry {\n\t\t\tconst dubheConfig = (await loadConfig(configPath)) as DubheConfig;\n\t\t\tawait publishHandler(dubheConfig, network, contractName);\n\t\t} catch (error: any) {\n\t\t\tlogError(error);\n\t\t\tprocess.exit(1);\n\t\t}\n\t\tprocess.exit(0);\n\t},\n};\n\nexport default commandModule;\n","import { Dubhe } from '@0xobelisk/sui-client';\nimport { Transaction, UpgradePolicy } from '@mysten/sui/transactions';\nimport { getFullnodeUrl, SuiClient } from '@mysten/sui/client';\nimport { execSync } from 'child_process';\nimport chalk from 'chalk';\nimport { DubheCliError, UpgradeError } from './errors';\nimport {\n\tupdateVersionInFile,\n\tgetOldPackageId,\n\tgetVersion,\n\tgetUpgradeCap,\n\tsaveContractData,\n\tvalidatePrivateKey, getOnchainSchemas, getSchemaHub, switchEnv, delay,\n} from './utils';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { DubheConfig } from '@0xobelisk/sui-common';\n\ntype ObjectContent = {\n\ttype: string;\n\tfields: Record<string, any>;\n\thasPublicTransfer: boolean;\n\tdataType: string;\n};\n\ntype Field = {\n\tname: string;\n\ttype: string;\n}\n\ntype Migration = {\n\tschemaName: string;\n\tfields: Field[];\n};\n\nfunction updateMigrateMethod(projectPath: string, migrations: Migration[]): void {\n\tmigrations.forEach((migration) => {\n\t\tlet filePath = `${projectPath}/sources/codegen/schemas/${migration.schemaName}.move`;\n\t\tconst fileContent = fs.readFileSync(filePath, 'utf-8');\n\t\tconst migrateMethodRegex = new RegExp(`public fun migrate\\\\(_${migration.schemaName}: &mut ${capitalizeAndRemoveUnderscores(migration.schemaName)}, _cap: &UpgradeCap\\\\) {[^}]*}`);\n\t\tconst newMigrateMethod = `\npublic fun migrate(${migration.schemaName}: &mut ${capitalizeAndRemoveUnderscores(migration.schemaName)}, _cap: &UpgradeCap) {\n${migration.fields.map((field) => {\n\t\t\tlet storage_type = '';\n\t\t\tif (field.type.includes('StorageValue')) {\n\t\t\t\tstorage_type = `storage_value::new()`;\n\t\t\t} else if (field.type.includes('StorageMap')) {\n\t\t\t\tstorage_type = `storage_map::new()`;\n\t\t\t} else if (\n\t\t\t\tfield.type.includes('StorageDoubleMap')\n\t\t\t) {\n\t\t\t\tstorage_type = `storage_double_map::new()`;\n\t\t\t}\n\t\t\treturn `storage_migrate::add_field<${field.type}>(&mut ${migration.schemaName}.id, b\"${field.name}\", ${storage_type});`;\n\t\t}).join('')}\n}\n`;\n\n\t\tconst updatedContent = fileContent.replace(migrateMethodRegex, newMigrateMethod);\n\t\tfs.writeFileSync(filePath, updatedContent, 'utf-8');\n\t});\n\n\n}\n\nfunction capitalizeAndRemoveUnderscores(input: string): string {\n\treturn input\n\t\t.split('_')\n\t\t.map((word, index) => {\n\t\t\treturn index === 0\n\t\t\t\t? word.charAt(0).toUpperCase() + word.slice(1).toLowerCase()\n\t\t\t\t: word.charAt(0).toUpperCase() + word.slice(1).toLowerCase();\n\t\t})\n\t\t.join('');\n}\n\nfunction getLastSegment(input: string): string {\n\tconst segments = input.split('::');\n\treturn segments.length > 0 ? segments[segments.length - 1] : '';\n}\n\nfunction replaceEnvField(\n\tfilePath: string,\n\tnetworkType: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n\tfield: 'original-published-id' | 'latest-published-id' | 'published-version',\n\tnewValue: string\n): string {\n\tconst envFilePath = path.resolve(filePath);\n\tconst envContent = fs.readFileSync(envFilePath, 'utf-8');\n\tconst envLines = envContent.split('\\n');\n\n\tconst networkSectionIndex = envLines.findIndex(line => line.trim() === `[env.${networkType}]`);\n\tif (networkSectionIndex === -1) {\n\t\tconsole.log(`Network type [env.${networkType}] not found in the file.`);\n\t\treturn \"\";\n\t}\n\n\tlet fieldIndex = -1;\n\tlet previousValue: string = \"\";\n\tfor (let i = networkSectionIndex + 1; i < envLines.length; i++) {\n\t\tconst line = envLines[i].trim();\n\t\tif (line.startsWith('[')) break; // End of the current network section\n\n\t\tif (line.startsWith(field)) {\n\t\t\tfieldIndex = i;\n\t\t\tpreviousValue = line.split('=')[1].trim().replace(/\"/g, '');\n\t\t\tbreak;\n\t\t}\n\t}\n\n\tif (fieldIndex !== -1) {\n\t\tenvLines[fieldIndex] = `${field} = \"${newValue}\"`;\n\t\tconst newEnvContent = envLines.join('\\n');\n\t\tfs.writeFileSync(envFilePath, newEnvContent, 'utf-8');\n\t} else {\n\t\tconsole.log(`${field} not found for [env.${networkType}].`);\n\t}\n\n\treturn previousValue;\n}\nexport async function upgradeHandler(\n\tconfig: DubheConfig,\n\tname: string,\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n) {\n\tawait switchEnv(network);\n\n\tconst path = process.cwd();\n\tconst projectPath = `${path}/contracts/${name}`;\n\tconst privateKey = process.env.PRIVATE_KEY;\n\tif (!privateKey)\n\t\tthrow new DubheCliError(\n\t\t\t`Missing PRIVATE_KEY environment variable.\nRun 'echo \"PRIVATE_KEY=YOUR_PRIVATE_KEY\" > .env'\nin your contracts directory to use the default sui private key.`,\n\t\t);\n\n\tconst privateKeyFormat = validatePrivateKey(privateKey);\n\tif (privateKeyFormat === false) {\n\t\tthrow new DubheCliError(`Please check your privateKey.`);\n\t}\n\tconst dubhe = new Dubhe({\n\t\tsecretKey: privateKeyFormat,\n\t});\n\tconst keypair = dubhe.getKeypair();\n\n\tconst client = new SuiClient({\n\t\turl: getFullnodeUrl(network),\n\t});\n\n\tlet oldVersion = Number(await getVersion(projectPath, network));\n\tlet oldPackageId = await getOldPackageId(projectPath, network);\n\tlet schemaHub = await getSchemaHub(projectPath, network);\n\tlet upgradeCap = await getUpgradeCap(projectPath, network);\n\n\tconst original_published_id = replaceEnvField(`${projectPath}/Move.lock`, network, 'original-published-id', \"0x0000000000000000000000000000000000000000000000000000000000000000\");\n\n\tlet pendingMigration: Migration[] = [];\n\tlet schemas = await getOnchainSchemas(projectPath, network);\n\tfor (let schemaKey in config.schemas) {\n\t\tschemas.forEach((schema) => {\n\t\t\tif (capitalizeAndRemoveUnderscores(schemaKey) == getLastSegment(schema.name)) {\n\t\t\t\tlet migrate: Migration = { schemaName: '', fields: [] };\n\t\t\t\tlet fields: Field[] = [];\n\t\t\t\tlet isMigration = false;\n\t\t\t\tfor (const key in config.schemas[schemaKey].structure) {\n\t\t\t\t\tif (!(key in schema.structure)) {\n\t\t\t\t\t\tisMigration = true;\n\t\t\t\t\t\tfields.push({\n\t\t\t\t\t\t\tname: key,\n\t\t\t\t\t\t\ttype: config.schemas[schemaKey].structure[key],\n\t\t\t\t\t\t});\n\t\t\t\t\t\tschema.structure[key] = config.schemas[schemaKey].structure[key];\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (isMigration) {\n\t\t\t\t\tmigrate.schemaName = schemaKey;\n\t\t\t\t\tmigrate.fields = fields;\n\t\t\t\t\tpendingMigration.push(migrate);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\n\tpendingMigration.forEach((migration) => {\n\t\tconsole.log(`\\nšŸš€ Starting Migration for ${migration.schemaName}...`);\n\t\tconsole.log('šŸ“‹ Migration Fields:', migration.fields);\n\t});\n\tupdateMigrateMethod(projectPath, pendingMigration);\n\n\ttry {\n\t\tlet modules: any, dependencies: any, digest: any;\n\t\ttry {\n\t\t\tconst {\n\t\t\t\tmodules: extractedModules,\n\t\t\t\tdependencies: extractedDependencies,\n\t\t\t\tdigest: extractedDigest,\n\t\t\t} = JSON.parse(\n\t\t\t\texecSync(\n\t\t\t\t\t`sui move build --dump-bytecode-as-base64 --path ${path}/contracts/${name}`,\n\t\t\t\t\t{\n\t\t\t\t\t\tencoding: 'utf-8',\n\t\t\t\t\t},\n\t\t\t\t),\n\t\t\t);\n\n\t\t\tmodules = extractedModules;\n\t\t\tdependencies = extractedDependencies;\n\t\t\tdigest = extractedDigest;\n\t\t} catch (error: any) {\n\t\t\tthrow new UpgradeError(error.stdout);\n\t\t}\n\n\t\tconsole.log('\\nšŸš€ Starting Upgrade Process...');\n\t\tconsole.log('šŸ“‹ OldPackageId:', oldPackageId);\n\t\tconsole.log('šŸ“‹ UpgradeCap Object Id:', upgradeCap);\n\t\tconsole.log('šŸ“‹ OldVersion:', oldVersion);\n\n\t\tconst tx = new Transaction();\n\t\tconst ticket = tx.moveCall({\n\t\t\ttarget: '0x2::package::authorize_upgrade',\n\t\t\targuments: [\n\t\t\t\ttx.object(upgradeCap),\n\t\t\t\ttx.pure.u8(UpgradePolicy.COMPATIBLE),\n\t\t\t\ttx.pure.vector('u8', digest),\n\t\t\t],\n\t\t});\n\n\t\tconst receipt = tx.upgrade({\n\t\t\tmodules,\n\t\t\tdependencies,\n\t\t\tpackage: oldPackageId,\n\t\t\tticket,\n\t\t});\n\n\t\ttx.moveCall({\n\t\t\ttarget: '0x2::package::commit_upgrade',\n\t\t\targuments: [tx.object(upgradeCap), receipt],\n\t\t});\n\n\t\tconst result = await client.signAndExecuteTransaction({\n\t\t\tsigner: keypair,\n\t\t\ttransaction: tx,\n\t\t\toptions: {\n\t\t\t\tshowObjectChanges: true,\n\t\t\t},\n\t\t});\n\n\t\tlet newPackageId = '';\n\t\tresult.objectChanges!.map(object => {\n\t\t\tif (object.type === 'published') {\n\t\t\t\tconsole.log(\n\t\t\t\t\tchalk.blue(`${name} PackageId: ${object.packageId}`),\n\t\t\t\t);\n\t\t\t\tconsole.log(\n\t\t\t\t\tchalk.blue(`${name} Version: ${oldVersion + 1}`),\n\t\t\t\t);\n\t\t\t\tnewPackageId = object.packageId;\n\t\t\t}\n\t\t});\n\n\t\treplaceEnvField(`${projectPath}/Move.lock`, network, 'original-published-id', original_published_id);\n\t\treplaceEnvField(`${projectPath}/Move.lock`, network, 'latest-published-id', newPackageId);\n\t\treplaceEnvField(`${projectPath}/Move.lock`, network, 'published-version', (oldVersion + 1) + \"\");\n\n\t\tconsole.log(\n\t\t\tchalk.green(`Upgrade Transaction Digest: ${result.digest}`),\n\t\t);\n\n\t\tsaveContractData(\n\t\t\tname,\n\t\t\tnetwork,\n\t\t\tnewPackageId,\n\t\t\tupgradeCap,\n\t\t\tschemaHub,\n\t\t\toldVersion + 1,\n\t\t\tschemas,\n\t\t);\n\n\t} catch (error: any) {\n\t\tconsole.log(chalk.red('Upgrade failed!'));\n\t\tconsole.error(error.message);\n\t}\n}\n","import type { CommandModule } from 'yargs';\nimport { logError } from '../utils/errors';\nimport { upgradeHandler } from '../utils/upgradeHandler';\nimport { DubheConfig, loadConfig } from '@0xobelisk/sui-common';\n\ntype Options = {\n\tnetwork: any;\n\t'config-path': string;\n};\n\nconst commandModule: CommandModule<Options, Options> = {\n\tcommand: 'upgrade',\n\n\tdescribe: 'Upgrade your move contracts',\n\n\tbuilder(yargs) {\n\t\treturn yargs.options({\n\t\t\tnetwork: {\n\t\t\t\ttype: 'string',\n\t\t\t\tchoices: ['mainnet', 'testnet', 'devnet', 'localnet'],\n\t\t\t\tdesc: 'Network of the node (mainnet/testnet/devnet/localnet)',\n\t\t\t},\n\t\t\t'config-path': {\n\t\t\t\ttype: 'string',\n\t\t\t\tdefault: 'dubhe.config.ts',\n\t\t\t\tdecs: 'Path to the config file',\n\t\t\t},\n\t\t});\n\t},\n\n\tasync handler({ network, 'config-path': configPath }) {\n\t\ttry {\n\t\t\tconst dubheConfig = (await loadConfig(configPath)) as DubheConfig;\n\t\t\tawait upgradeHandler(dubheConfig, dubheConfig.name, network);\n\t\t} catch (error: any) {\n\t\t\tlogError(error);\n\t\t\tprocess.exit(1);\n\t\t}\n\t\tprocess.exit(0);\n\t},\n};\n\nexport default commandModule;\n","import type { CommandModule } from \"yargs\";\nimport { execSync } from \"child_process\";\nimport chalk from \"chalk\";\n\ntype Options = {\n packagePath: string;\n};\n\nconst commandModule: CommandModule<Options, Options> = {\n command: \"test\",\n\n describe: \"Run tests in Dubhe contracts\",\n\n builder(yargs) {\n return yargs.options({\n packagePath: {\n type: \"string\",\n default: \".\",\n description: \"Options to pass to forge test\",\n },\n });\n },\n\n async handler({ packagePath }) {\n // Start an internal anvil process if no world address is provided\n try {\n execSync(`sui move test --path ${packagePath}`, {\n encoding: \"utf-8\",\n });\n } catch (error: any) {\n console.error(chalk.red(\"Error executing sui move test:\"));\n console.log(error.stdout);\n process.exit(0);\n }\n },\n};\n\nexport default commandModule;\n","import type { CommandModule } from \"yargs\";\nimport { printDubhe } from \"../utils\";\n\nconst commandModule: CommandModule = {\n command: \"hello\",\n\n describe: \"hello, dubhe\",\n\n builder(yargs) {\n return yargs;\n },\n\n async handler() {\n printDubhe();\n },\n};\n\nexport default commandModule;\n","import { CommandModule } from 'yargs';\n\nimport localnode from './localnode';\nimport faucet from './faucet';\nimport schemagen from './schemagen';\nimport publish from './publish';\nimport upgrade from \"./upgrade\";\nimport test from './test';\nimport hello from './hello';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Each command has different options\nexport const commands: CommandModule<any, any>[] = [\n\tpublish,\n\tlocalnode,\n\tfaucet,\n\tschemagen,\n\tupgrade,\n\ttest,\n\thello,\n];\n"],"mappings":"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","names":["yargs","hideBin","Dubhe","Transaction","getFullnodeUrl","SuiClient","execSync","chalk","chalk","ZodError","fromZodError","ValidationError","NotInsideProjectError","DubheCliError","UpgradeError","FsIibError","logError","error","validationError","fsAsync","mkdirSync","writeFileSync","dirname","SUI_PRIVATE_KEY_PREFIX","execSync","spawn","chalk","isSuiStartRunning","cmd","result","startLocalnode","background","suiProcess","error","code","execSync","chalk","checkLocalNodeStatus","cmd","output","execSync","stopLocalnode","cmd","output","pid","match","error","fs","chalk","spawn","validatePrivateKey","privateKey","SUI_PRIVATE_KEY_PREFIX","strippedPrivateKey","getDeploymentJson","projectPath","network","data","FsIibError","getOnchainSchemas","getVersion","getOldPackageId","projectPath","network","getDeploymentJson","getUpgradeCap","getSchemaHub","saveContractData","projectName","network","packageId","upgradeCap","schemaHub","version","schemas","DeploymentData","path","storeDeploymentData","writeOutput","output","fullOutputPath","logPrefix","mkdirSync","dirname","writeFileSync","getDubheDependency","updateDubheDependency","filePath","fileContent","newDependency","updatedContent","switchEnv","resolve","reject","suiProcess","spawn","data","chalk","error","code","delay","ms","fs","path","getDappsObjectId","network","getSchemaHub","removeEnvContent","filePath","networkType","content","regex","updatedContent","updateEnvFile","filePath","networkType","operation","chainId","publishedId","envFilePath","envContent","envLines","networkSectionIndex","line","config","i","key","value","part","updatedSection","newEnvContent","capitalizeAndRemoveUnderscores","input","word","index","getLastSegment","segments","buildContract","projectPath","modules","dependencies","buildResult","execSync","error","chalk","publishContract","client","dubhe","dubheConfig","network","dappsObjectId","getDappsObjectId","removeEnvContent","keypair","tx","Transaction","upgradeCap","result","version","packageId","schemas","upgradeCapId","schemaHubId","object","delay","deployHookTx","txCoin","deployHookResult","structure","schemaKey","saveContractData","publishDubheFramework","publishHandler","contractName","switchEnv","privateKey","DubheCliError","privateKeyFormat","validatePrivateKey","Dubhe","SuiClient","getFullnodeUrl","updateDubheDependency","chalk","printDubhe","commandModule","yargs","argv","action","background","startLocalnode","stopLocalnode","checkLocalNodeStatus","restartNode","error","localnode_default","Dubhe","requestSuiFromFaucetV0","getFaucetHost","SuiClient","getFullnodeUrl","commandModule","yargs","network","recipient","faucet_address","privateKey","DubheCliError","privateKeyFormat","validatePrivateKey","Dubhe","requestSuiFromFaucetV0","getFaucetHost","client","SuiClient","getFullnodeUrl","params","balance","faucet_default","schemaGen","loadConfig","chalk","commandModule","configPath","network","frameworkId","dubheConfig","error","schemagen_default","loadConfig","commandModule","yargs","network","configPath","contractName","dubheConfig","publishHandler","error","logError","publish_default","Dubhe","Transaction","UpgradePolicy","getFullnodeUrl","SuiClient","execSync","chalk","fs","path","updateMigrateMethod","projectPath","migrations","migration","filePath","fileContent","migrateMethodRegex","capitalizeAndRemoveUnderscores","newMigrateMethod","field","storage_type","updatedContent","input","word","index","getLastSegment","segments","replaceEnvField","networkType","newValue","envFilePath","envLines","networkSectionIndex","line","fieldIndex","previousValue","i","newEnvContent","upgradeHandler","config","name","network","switchEnv","privateKey","DubheCliError","privateKeyFormat","validatePrivateKey","keypair","Dubhe","client","SuiClient","getFullnodeUrl","oldVersion","getVersion","oldPackageId","getOldPackageId","schemaHub","getSchemaHub","upgradeCap","getUpgradeCap","original_published_id","pendingMigration","schemas","getOnchainSchemas","schemaKey","schema","migrate","fields","isMigration","key","modules","dependencies","digest","extractedModules","extractedDependencies","extractedDigest","execSync","error","UpgradeError","tx","Transaction","ticket","UpgradePolicy","receipt","result","newPackageId","object","chalk","saveContractData","loadConfig","commandModule","yargs","network","configPath","dubheConfig","upgradeHandler","error","logError","upgrade_default","execSync","chalk","commandModule","yargs","packagePath","error","test_default","commandModule","yargs","printDubhe","hello_default","commands","publish_default","localnode_default","faucet_default","schemagen_default","upgrade_default","test_default","hello_default","dotenv","chalk","yargs","hideBin","commands","msg","err","logError"]}
1
+ {"version":3,"sources":["../src/dubhe.ts","../src/utils/startNode.ts","../src/utils/printDubhe.ts","../src/utils/publishHandler.ts","../src/utils/errors.ts","../src/utils/utils.ts","../src/commands/localnode.ts","../src/commands/faucet.ts","../src/commands/schemagen.ts","../src/commands/publish.ts","../src/utils/upgradeHandler.ts","../src/commands/upgrade.ts","../src/commands/test.ts","../src/commands/build.ts","../src/commands/hello.ts","../src/commands/index.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport yargs from \"yargs\";\nimport { hideBin } from \"yargs/helpers\";\nimport { commands } from \"./commands\";\nimport { logError } from \"./utils/errors\";\n\n// Load .env file into process.env\nimport * as dotenv from \"dotenv\";\nimport chalk from \"chalk\";\ndotenv.config();\n\nyargs(hideBin(process.argv))\n // Explicit name to display in help (by default it's the entry file, which may not be \"dubhe\" for e.g. ts-node)\n .scriptName(\"dubhe\")\n // Use the commands directory to scaffold\n // eslint-disable-next-line @typescript-eslint/no-explicit-any -- command array overload isn't typed, see https://github.com/yargs/yargs/blob/main/docs/advanced.md#esm-hierarchy\n .command(commands as any)\n // Enable strict mode.\n .strict()\n // Custom error handler\n .fail((msg, err) => {\n console.error(chalk.red(msg));\n if (msg.includes(\"Missing required argument\")) {\n console.log(\n chalk.yellow(`Run 'pnpm dubhe ${process.argv[2]} --help' for a list of available and required arguments.`)\n );\n }\n console.log(\"\");\n logError(err);\n console.log(\"\");\n\n process.exit(1);\n })\n // Useful aliases.\n .alias({ h: \"help\" }).argv;\n","import { execSync, spawn } from 'child_process';\nimport chalk from 'chalk';\nimport { printDubhe } from './printDubhe';\nimport { delay, DubheCliError, publishDubheFramework, validatePrivateKey } from '../utils';\nimport { Dubhe } from '@0xobelisk/sui-client';\nimport { getFullnodeUrl, SuiClient } from '@mysten/sui/client';\n\nfunction isSuiStartRunning(): boolean {\n\ttry {\n\t\tconst cmd =\n\t\t\tprocess.platform === 'win32'\n\t\t\t\t? `tasklist /FI \"IMAGENAME eq sui.exe\" /FO CSV /NH`\n\t\t\t\t: 'pgrep -f \"sui start\"';\n\n\t\tconst result = execSync(cmd).toString().trim();\n\t\treturn process.platform === 'win32'\n\t\t\t? result.toLowerCase().includes('sui.exe')\n\t\t\t: result.length > 0;\n\t} catch (error) {\n\t\treturn false;\n\t}\n}\n\nasync function printAccounts() {\n\t// These private keys are used for testing purposes only, do not use them in production.\n\tconst privateKeys = [\n\t\t\"suiprivkey1qq3ez3dje66l8pypgxynr7yymwps6uhn7vyczespj84974j3zya0wdpu76v\",\n\t\t\"suiprivkey1qp6vcyg8r2x88fllmjmxtpzjl95gd9dugqrgz7xxf50w6rqdqzetg7x4d7s\",\n\t\t\"suiprivkey1qpy3a696eh3m55fwa8h38ss063459u4n2dm9t24w2hlxxzjp2x34q8sdsnc\",\n\t\t\"suiprivkey1qzxwp29favhzrjd95f6uj9nskjwal6nh9g509jpun395y6g72d6jqlmps4c\",\n\t\t\"suiprivkey1qzhq4lv38sesah4uzsqkkmeyjx860xqjdz8qgw36tmrdd5tnle3evxpng57\",\n\t\t\"suiprivkey1qzez45sjjsepjgtksqvpq6jw7dzw3zq0dx7a4sulfypd73acaynw5jl9x2c\",\n\t]\n\tconsole.log(\"šŸ“Accounts\")\n\tconsole.log(\"==========\")\n\tprivateKeys.forEach((privateKey, index) => {\n\t\tconst dubhe = new Dubhe({ secretKey: privateKey });\n\t\tconst keypair = dubhe.getKeypair();\n\t\tspawn(\n\t\t\t'curl',\n\t\t\t['--location', '--request', 'POST', 'http://127.0.0.1:9123/gas', '--header', 'Content-Type: application/json', '--data-raw', `{\"FixedAmountRequest\": {\"recipient\": \"${keypair.toSuiAddress()}\"}}`],\n\t\t\t{\n\t\t\t\tenv: { ...process.env },\n\t\t\t\tstdio: 'ignore',\n\t\t\t\tdetached: true,\n\t\t\t}\n\t\t\t)\n\t\tconsole.log(` ā”Œā”€ Account #${index}: ${keypair.toSuiAddress()}(1000 SUI)`);\n\t\tconsole.log(` └─ Private Key: ${privateKey}`);\n\t});\n\tconsole.log(\"==========\")\n\tconsole.log(chalk.yellow(\"āš ļøWARNING: These accounts, and their private keys, are publicly known.\"));\n\tconsole.log(chalk.yellow(\"Any funds sent to them on Mainnet or any other live network WILL BE LOST.\"));\n}\n\texport async function startLocalNode() {\n\tif (isSuiStartRunning()) {\n\t\tconsole.log(chalk.yellow('\\nāš ļø Warning: Local Node Already Running'));\n\t\tconsole.log(chalk.yellow(' ā”œā”€ Cannot start a new instance'));\n\t\tconsole.log(\n\t\t\tchalk.yellow(' └─ Please stop the existing process first')\n\t\t);\n\t\treturn;\n\t}\n\n\tprintDubhe();\n\tconsole.log('šŸš€ Starting Local Node...');\n\ttry {\n\t\tconst suiProcess = spawn(\n\t\t\t'sui',\n\t\t\t['start', '--with-faucet', '--force-regenesis'],\n\t\t\t{\n\t\t\t\tenv: { ...process.env, RUST_LOG: 'off,sui_node=info' },\n\t\t\t\tstdio: 'ignore',\n\t\t\t\tdetached: true,\n\t\t\t}\n\t\t);\n\n\t\tsuiProcess.on('error', error => {\n\t\t\tconsole.error(chalk.red('\\nāŒ Failed to Start Local Node'));\n\t\t\tconsole.error(chalk.red(` └─ Error: ${error.message}`));\n\t\t});\n\t\tawait delay(5000);\n\t\tconsole.log(' ā”œā”€ Faucet: Enabled');\n\t\tconsole.log(' └─ Force Regenesis: Yes');\n\t\tconsole.log(' └─ HTTP server: http://127.0.0.1:9000/');\n\t\tconsole.log(' └─ Faucet server: http://127.0.0.1:9123/');\n\n\t\tawait printAccounts();\n\n\t\tawait delay(2000);\n\n\t\tconst privateKeyFormat = validatePrivateKey(\"suiprivkey1qzez45sjjsepjgtksqvpq6jw7dzw3zq0dx7a4sulfypd73acaynw5jl9x2c\");\n\t\tif (privateKeyFormat === false) {\n\t\t\tthrow new DubheCliError(`Please check your privateKey.`);\n\t\t}\n\n\t\tconst dubhe = new Dubhe({ secretKey: privateKeyFormat });\n\t\tconst client = new SuiClient({ url: getFullnodeUrl('localnet') });\n\t\tconst originalLog = console.log;\n\n\t\tconsole.log = () => {};\n\t\tawait publishDubheFramework(client, dubhe, 'localnet');\n\t\tconsole.log = originalLog;\n\n\t\tprocess.on('SIGINT', () => {\n\t\t\tconsole.log(chalk.yellow('\\nšŸ”” Stopping Local Node...'));\n\t\t\tif (suiProcess) {\n\t\t\t\tsuiProcess.kill();\n\t\t\t\tconsole.log(chalk.green('āœ… Local Node Stopped'));\n\t\t\t}\n\t\t\tprocess.exit();\n\t\t});\n\t} catch (error: any) {\n\t\tconsole.error(chalk.red('\\nāŒ Failed to Start Local Node'));\n\t\tconsole.error(chalk.red(` └─ Error: ${error.message}`));\n\t}\n}\n","import chalk from \"chalk\";\n\nexport function printDubhe() {\n console.log(\n chalk.yellow(`\nWelcome to Dubhe\n\\t\\t\\t --from team@obelisk\n ________ ___ ___ ________ ___ ___ _______ \n |\\\\ ___ \\\\|\\\\ \\\\|\\\\ \\\\|\\\\ __ \\\\|\\\\ \\\\|\\\\ \\\\|\\\\ ___ \\\\ \n \\\\ \\\\ \\\\_|\\\\ \\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ /\\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ __/| \n \\\\ \\\\ \\\\ \\\\\\\\ \\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ __ \\\\ \\\\ __ \\\\ \\\\ \\\\_|/__ \n \\\\ \\\\ \\\\_\\\\\\\\ \\\\ \\\\ \\\\\\\\\\\\ \\\\ \\\\ \\\\|\\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\ \\\\_|\\\\ \\\\ \n \\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\_______\\\\ \\\\__\\\\ \\\\__\\\\ \\\\_______\\\\\n \\\\|_______|\\\\|_______|\\\\|_______|\\\\|__|\\\\|__|\\\\|_______| \n \n`)\n );\n}\n","import { Dubhe } from '@0xobelisk/sui-client';\nimport { Transaction } from '@mysten/sui/transactions';\nimport {\n\tgetFullnodeUrl,\n\tSuiClient,\n\tSuiTransactionBlockResponse,\n} from '@mysten/sui/client';\nimport { execSync } from 'child_process';\nimport chalk from 'chalk';\nimport { DubheCliError } from './errors';\nimport {\n\tupdateVersionInFile,\n\tsaveContractData,\n\tvalidatePrivateKey,\n\tschema, getSchemaHub, updateDubheDependency, switchEnv, delay,\n} from './utils';\nimport { DubheConfig } from '@0xobelisk/sui-common';\nimport * as fs from 'fs';\nimport * as path from 'path';\n\nasync function getDappsObjectId(\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet'\n) {\n\tswitch (network) {\n\t\tcase \"localnet\": {\n\t\t\tconst path = process.cwd();\n\t\t\treturn await getSchemaHub(`${path}/contracts/dubhe-framework`, network)\n\t\t}\n\t\tcase 'testnet':\n\t\t\treturn '0x8dbf8d28ac027ba214c9e0951b09f6842843be6cb87242b7d9a326a2677cd47a';\n\t\tdefault:\n\t\t\treturn '0x8dbf8d28ac027ba214c9e0951b09f6842843be6cb87242b7d9a326a2677cd47a';\n\t}\n}\n\nfunction removeEnvContent(filePath: string, networkType: 'mainnet' | 'testnet' | 'devnet' | 'localnet'): void {\n\tif (!fs.existsSync(filePath)) {\n\t\treturn;\n\t}\n\tconst content = fs.readFileSync(filePath, 'utf-8');\n\tconst regex = new RegExp(`\\\\[env\\\\.${networkType}\\\\][\\\\s\\\\S]*?(?=\\\\[|$)`, 'g');\n\tconst updatedContent = content.replace(regex, '');\n\tfs.writeFileSync(filePath, updatedContent, 'utf-8');\n}\n\ninterface EnvConfig {\n\tchainId: string;\n\toriginalPublishedId: string;\n\tlatestPublishedId: string;\n\tpublishedVersion: number;\n}\n\nconst chainIds: { [key: string]: string } = {\n\tlocalnet: 'dfa7bb83',\n\ttestnet: '4c78adac',\n\tmainnet: '35834a8a',\n};\n\nfunction updateEnvFile(filePath: string, networkType: 'mainnet' | 'testnet' | 'devnet' | 'localnet', operation: 'publish' | 'upgrade', chainId: string, publishedId: string): void {\n\tconst envFilePath = path.resolve(filePath);\n\tconst envContent = fs.readFileSync(envFilePath, 'utf-8');\n\tconst envLines = envContent.split('\\n');\n\n\tconst networkSectionIndex = envLines.findIndex(line => line.trim() === `[env.${networkType}]`);\n\tconst config: EnvConfig = {\n\t\tchainId: chainId,\n\t\toriginalPublishedId: '',\n\t\tlatestPublishedId: '',\n\t\tpublishedVersion: 0,\n\t};\n\n\tif (networkSectionIndex === -1) {\n\t\t// If network section is not found, add a new section\n\t\tif (operation === 'publish') {\n\t\t\tconfig.originalPublishedId = publishedId;\n\t\t\tconfig.latestPublishedId = publishedId;\n\t\t\tconfig.publishedVersion = 1;\n\t\t} else {\n\t\t\tthrow new Error(`Network type [env.${networkType}] not found in the file and cannot upgrade.`);\n\t\t}\n\t} else {\n\t\tfor (let i = networkSectionIndex + 1; i < envLines.length; i++) {\n\t\t\tconst line = envLines[i].trim();\n\t\t\tif (line.startsWith('[')) break; // End of the current network section\n\n\t\t\tconst [key, value] = line.split('=').map(part => part.trim().replace(/\"/g, ''));\n\t\t\tswitch (key) {\n\t\t\t\tcase 'original-published-id':\n\t\t\t\t\tconfig.originalPublishedId = value;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'latest-published-id':\n\t\t\t\t\tconfig.latestPublishedId = value;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'published-version':\n\t\t\t\t\tconfig.publishedVersion = parseInt(value, 10);\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tif (operation === 'publish') {\n\t\t\tconfig.originalPublishedId = publishedId;\n\t\t\tconfig.latestPublishedId = publishedId;\n\t\t\tconfig.publishedVersion = 1;\n\t\t} else if (operation === 'upgrade') {\n\t\t\tconfig.latestPublishedId = publishedId;\n\t\t\tconfig.publishedVersion += 1;\n\t\t}\n\t}\n\n\tconst updatedSection = `\n[env.${networkType}]\nchain-id = \"${config.chainId}\"\noriginal-published-id = \"${config.originalPublishedId}\"\nlatest-published-id = \"${config.latestPublishedId}\"\npublished-version = \"${config.publishedVersion}\"\n`;\n\n\tconst newEnvContent = networkSectionIndex === -1\n\t\t? envContent + updatedSection\n\t\t: envLines.slice(0, networkSectionIndex).join('\\n') + updatedSection;\n\n\tfs.writeFileSync(envFilePath, newEnvContent, 'utf-8');\n}\nfunction capitalizeAndRemoveUnderscores(input: string): string {\n\treturn input\n\t\t.split('_')\n\t\t.map((word, index) => {\n\t\t\treturn index === 0\n\t\t\t\t? word.charAt(0).toUpperCase() + word.slice(1).toLowerCase()\n\t\t\t\t: word.charAt(0).toUpperCase() + word.slice(1).toLowerCase();\n\t\t})\n\t\t.join('');\n}\n\nfunction getLastSegment(input: string): string {\n\tconst segments = input.split('::');\n\treturn segments.length > 0 ? segments[segments.length - 1] : '';\n}\n\nfunction buildContract(projectPath: string): string[][] {\n\tlet modules: any, dependencies: any;\n\ttry {\n\t\tconst buildResult = JSON.parse(\n\t\t\texecSync(\n\t\t\t\t`sui move build --dump-bytecode-as-base64 --path ${projectPath}`,\n\t\t\t\t{\n\t\t\t\t\tencoding: 'utf-8',\n\t\t\t\t\tstdio: 'pipe',\n\t\t\t\t}\n\t\t\t)\n\t\t);\n\t\tmodules = buildResult.modules;\n\t\tdependencies = buildResult.dependencies;\n\t\tconsole.log(' └─ Build successful');\n\t} catch (error: any) {\n\t\tconsole.error(chalk.red(' └─ Build failed'));\n\t\tconsole.error(error.stdout);\n\t\tprocess.exit(1);\n\t}\n\treturn [modules, dependencies];\n}\n\nasync function publishContract(\n\tclient: SuiClient,\n\tdubhe: Dubhe,\n\tdubheConfig: DubheConfig,\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n\tprojectPath: string\n) {\n\tconst dappsObjectId = await getDappsObjectId(network);\n\tconsole.log(\"dappsObjectId\", dappsObjectId);\n\tconst chainId = await client.getChainIdentifier();\n\tremoveEnvContent(`${projectPath}/Move.lock`, network);\n\tconsole.log('\\nšŸš€ Starting Contract Publication...');\n\tconsole.log(` ā”œā”€ Project: ${projectPath}`);\n\tconsole.log(` ā”œā”€ Network: ${network}`);\n\tconsole.log(` ā”œā”€ ChainId: ${chainId}`);\n\tconsole.log(' ā”œā”€ Validating Environment...');\n\n\tconst keypair = dubhe.getKeypair();\n\tconsole.log(` └─ Account: ${keypair.toSuiAddress()}`);\n\n\tconsole.log('\\nšŸ“¦ Building Contract...');\n\tconst [modules, dependencies] = buildContract(projectPath);\n\n\tconsole.log('\\nšŸ”„ Publishing Contract...');\n\tconst tx = new Transaction();\n\tconst [upgradeCap] = tx.publish({ modules, dependencies });\n\ttx.transferObjects([upgradeCap], keypair.toSuiAddress());\n\n\tlet result: SuiTransactionBlockResponse;\n\ttry {\n\t\tresult = await client.signAndExecuteTransaction({\n\t\t\tsigner: keypair,\n\t\t\ttransaction: tx,\n\t\t\toptions: { showObjectChanges: true },\n\t\t});\n\t} catch (error: any) {\n\t\tconsole.error(chalk.red(' └─ Publication failed'));\n\t\tconsole.error(error.message);\n\t\tprocess.exit(1);\n\t}\n\n\tif (result.effects?.status.status === 'failure') {\n\t\tconsole.log(chalk.red(' └─ Publication failed'));\n\t\tprocess.exit(1);\n\t}\n\n\tconsole.log(' ā”œā”€ Processing publication results...');\n\tlet version = 1;\n\tlet packageId = '';\n\tlet schemas: schema[] = [];\n\tlet upgradeCapId = '';\n\tlet schemaHubId = '';\n\n\tresult.objectChanges!.map(object => {\n\t\tif (object.type === 'published') {\n\t\t\tconsole.log(` ā”œā”€ Package ID: ${object.packageId}`);\n\t\t\tpackageId = object.packageId;\n\t\t}\n\t\tif (\n\t\t\tobject.type === 'created' &&\n\t\t\tobject.objectType === '0x2::package::UpgradeCap'\n\t\t) {\n\t\t\tconsole.log(` ā”œā”€ Upgrade Cap: ${object.objectId}`);\n\t\t\tupgradeCapId = object.objectId;\n\t\t}\n\t\tif (\n\t\t\tobject.type === 'created' &&\n\t\t\tobject.objectType.includes(\"schema_hub\")\n\t\t) {\n\t\t\tconsole.log(` ā”œā”€ Schema Hub: ${object.objectId}`);\n\t\t\tschemaHubId = object.objectId;\n\t\t}\n\t});\n\n\tconsole.log(` └─ Transaction: ${result.digest}`);\n\n\tupdateEnvFile(`${projectPath}/Move.lock`, network, 'publish', chainId, packageId);\n\n\tconsole.log('\\n⚔ Executing Deploy Hook...');\n\tawait delay(5000);\n\n\tconst deployHookTx = new Transaction();\n\tdeployHookTx.setGasBudget(2000000000);\n\tconst [txCoin] = deployHookTx.splitCoins(deployHookTx.gas, [\"1000000000\"]);\n\tdeployHookTx.moveCall({\n\t\ttarget: `${packageId}::deploy_hook::run`,\n\t\targuments: [\n\t\t\tdeployHookTx.object(schemaHubId),\n\t\t\tdeployHookTx.object(dappsObjectId),\n\t\t\tdeployHookTx.object(upgradeCapId),\n\t\t\tdeployHookTx.object('0x6'),\n\t\t\ttxCoin\n\t\t],\n\t});\n\n\tlet deployHookResult: SuiTransactionBlockResponse;\n\ttry {\n\t\tdeployHookResult = await client.signAndExecuteTransaction({\n\t\t\tsigner: keypair,\n\t\t\ttransaction: deployHookTx,\n\t\t\toptions: { showEffects: true, showObjectChanges: true },\n\t\t});\n\t} catch (error: any) {\n\t\tconsole.error(chalk.red(' └─ Deploy hook execution failed'));\n\t\tconsole.error(error.message);\n\t\tprocess.exit(1);\n\t}\n\n\tif (deployHookResult.effects?.status.status === 'success') {\n\t\tconsole.log(' ā”œā”€ Hook execution successful');\n\t\tconsole.log(` ā”œā”€ Transaction: ${deployHookResult.digest}`);\n\n\t\tconsole.log('\\nšŸ“‹ Created Schemas:');\n\t\tdeployHookResult.objectChanges?.map(object => {\n\t\t\tif (\n\t\t\t\tobject.type === 'created' &&\n\t\t\t\tobject.objectType.includes('_schema') && !object.objectType.includes(\"dynamic_field\")\n\t\t\t) {\n\t\t\t\tconsole.log(` ā”œā”€ ${object.objectType}`);\n\t\t\t\tconsole.log(` └─ ID: ${object.objectId}`);\n\n\t\t\t\tlet structure: Record<string, string> = {};\n\t\t\t\tfor (let schemaKey in dubheConfig.schemas) {\n\t\t\t\t\tif (capitalizeAndRemoveUnderscores(schemaKey) === getLastSegment(object.objectType)) {\n\t\t\t\t\t\tstructure = dubheConfig.schemas[schemaKey].structure;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tschemas.push({\n\t\t\t\t\tname: object.objectType,\n\t\t\t\t\tobjectId: object.objectId,\n\t\t\t\t\tstructure,\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\n\t\tsaveContractData(\n\t\t\tdubheConfig.name,\n\t\t\tnetwork,\n\t\t\tpackageId,\n\t\t\tupgradeCapId,\n\t\t\tschemaHubId,\n\t\t\tversion,\n\t\t\tschemas,\n\t\t);\n\t\tconsole.log('\\nāœ… Contract Publication Complete\\n');\n\t} else {\n\t\tconsole.log(chalk.yellow(' └─ Deploy hook execution failed'));\n\t\tconsole.log(\n\t\t\tchalk.yellow(\n\t\t\t\t' Please republish or manually call deploy_hook::run'\n\t\t\t)\n\t\t);\n\t}\n}\n\nexport async function publishDubheFramework(\n\tclient: SuiClient,\n\tdubhe: Dubhe,\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n) {\n\tconst path = process.cwd();\n\tconst projectPath = `${path}/contracts/dubhe-framework`;\n\tconst chainId = await client.getChainIdentifier();\n\tconsole.log(` └─ Chain ID: ${chainId}`);\n\tremoveEnvContent(`${projectPath}/Move.lock`, network);\n\tconsole.log('\\nšŸš€ Starting Contract Publication...');\n\tconsole.log(` ā”œā”€ Project: ${projectPath}`);\n\tconsole.log(` ā”œā”€ Network: ${network}`);\n\tconsole.log(` ā”œā”€ ChainId: ${chainId}`);\n\tconsole.log(' ā”œā”€ Validating Environment...');\n\n\tconst keypair = dubhe.getKeypair();\n\tconsole.log(` └─ Account: ${keypair.toSuiAddress()}`);\n\n\n\tconsole.log('\\nšŸ“¦ Building Contract...');\n\tconst [modules, dependencies] = buildContract(projectPath);\n\n\tconsole.log('\\nšŸ”„ Publishing Contract...');\n\tconst tx = new Transaction();\n\tconst [upgradeCap] = tx.publish({ modules, dependencies });\n\ttx.transferObjects([upgradeCap], keypair.toSuiAddress());\n\n\tlet result: SuiTransactionBlockResponse;\n\ttry {\n\t\tresult = await client.signAndExecuteTransaction({\n\t\t\tsigner: keypair,\n\t\t\ttransaction: tx,\n\t\t\toptions: { showObjectChanges: true },\n\t\t});\n\t} catch (error: any) {\n\t\tconsole.error(chalk.red(' └─ Publication failed'));\n\t\tconsole.error(error.message);\n\t\tprocess.exit(1);\n\t}\n\n\tif (result.effects?.status.status === 'failure') {\n\t\tconsole.log(chalk.red(' └─ Publication failed'));\n\t\tprocess.exit(1);\n\t}\n\n\tconsole.log(' ā”œā”€ Processing publication results...');\n\tlet version = 1;\n\tlet packageId = '';\n\tlet schemas: schema[] = [];\n\tlet upgradeCapId = '';\n\tlet schemaHubId = '';\n\n\tresult.objectChanges!.map(object => {\n\t\tif (object.type === 'published') {\n\t\t\tconsole.log(` ā”œā”€ Package ID: ${object.packageId}`);\n\t\t\tpackageId = object.packageId;\n\t\t}\n\t\tif (\n\t\t\tobject.type === 'created' &&\n\t\t\tobject.objectType === '0x2::package::UpgradeCap'\n\t\t) {\n\t\t\tconsole.log(` ā”œā”€ Upgrade Cap: ${object.objectId}`);\n\t\t\tupgradeCapId = object.objectId;\n\t\t}\n\t\tif (\n\t\t\tobject.type === 'created' &&\n\t\t\tobject.objectType.includes(\"dapps\")\n\t\t) {\n\t\t\tconsole.log(` ā”œā”€ Dapps: ${object.objectId}`);\n\t\t\tschemaHubId = object.objectId;\n\t\t}\n\t});\n\n\tconsole.log(` └─ Transaction: ${result.digest}`);\n\n\tupdateEnvFile(`${projectPath}/Move.lock`, network, 'publish', chainId, packageId);\n\n\tsaveContractData(\n\t\t\"dubhe-framework\",\n\t\tnetwork,\n\t\tpackageId,\n\t\tupgradeCapId,\n\t\tschemaHubId,\n\t\tversion,\n\t\tschemas,\n\t);\n}\n\nexport async function publishHandler(\n\tdubheConfig: DubheConfig,\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n\tcontractName?: string,\n) {\n\tawait switchEnv(network);\n\n\tconst privateKey = process.env.PRIVATE_KEY;\n\tif (!privateKey) {\n\t\tthrow new DubheCliError(\n\t\t\t`Missing PRIVATE_KEY environment variable.\nRun 'echo \"PRIVATE_KEY=YOUR_PRIVATE_KEY\" > .env'\nin your contracts directory to use the default sui private key.`\n\t\t);\n\t}\n\tconst privateKeyFormat = validatePrivateKey(privateKey);\n\tif (privateKeyFormat === false) {\n\t\tthrow new DubheCliError(`Please check your privateKey.`);\n\t}\n\n\tconst dubhe = new Dubhe({ secretKey: privateKeyFormat });\n\tconst client = new SuiClient({ url: getFullnodeUrl(network) });\n\n\tif (contractName == \"dubhe-framework\") {\n\t\tawait publishDubheFramework(client, dubhe, network);\n\t} else {\n\t\tconst path = process.cwd();\n\t\tconst projectPath = `${path}/contracts/${dubheConfig.name}`;\n\t\tupdateDubheDependency(`${projectPath}/Move.toml`, network);\n\t\tawait publishContract(client, dubhe, dubheConfig, network, projectPath);\n\t}\n}\n","import chalk from \"chalk\";\nimport { ZodError } from \"zod\";\nimport { fromZodError, ValidationError } from \"zod-validation-error\";\n\nexport class NotInsideProjectError extends Error {\n name = \"NotInsideProjectError\";\n message = \"You are not inside a Dubhe project\";\n}\n\nexport class DubheCliError extends Error {\n name = \"DubheCliError\";\n}\n\nexport class UpgradeError extends Error {\n name = \"UpgradeError\";\n}\n\nexport class FsIibError extends Error {\n name = \"FsIibError\";\n}\n\nexport function logError(error: unknown) {\n if (error instanceof ValidationError) {\n console.log(chalk.redBright(error.message));\n } else if (error instanceof ZodError) {\n // TODO currently this error shouldn't happen, use `fromZodErrorCustom`\n const validationError = fromZodError(error, {\n prefixSeparator: \"\\n- \",\n issueSeparator: \"\\n- \",\n });\n console.log(chalk.redBright(validationError.message));\n } else if (error instanceof NotInsideProjectError) {\n console.log(chalk.red(error.message));\n console.log(\"\");\n // TODO add docs to the website and update the link to the specific page\n console.log(\n chalk.blue(\n `To learn more about Dubhe's configuration, please go to https://github.com/0xobelisk`\n )\n );\n } else if (error instanceof DubheCliError) {\n console.log(chalk.red(error));\n } else {\n console.log(error);\n }\n}\n","import * as fsAsync from 'fs/promises';\nimport { mkdirSync, writeFileSync } from 'fs';\nimport { dirname } from 'path';\nimport { SUI_PRIVATE_KEY_PREFIX } from '@mysten/sui/cryptography';\nimport { FsIibError } from './errors';\nimport * as fs from 'fs';\nimport chalk from 'chalk';\nimport { spawn } from 'child_process';\n\nexport type schema = {\n\tname: string;\n\tobjectId: string;\n\tstructure: Record<string, string>\n};\n\nexport type DeploymentJsonType = {\n\tprojectName: string;\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet';\n\tpackageId: string;\n\tupgradeCap: string;\n\tschemaHub: string;\n\tversion: number;\n\tschemas: schema[];\n};\n\nexport function validatePrivateKey(privateKey: string): false | string {\n\tif (privateKey.startsWith(SUI_PRIVATE_KEY_PREFIX)) {\n\t\tif (privateKey.length === 70) {\n\t\t\treturn privateKey;\n\t\t} else {\n\t\t\treturn false;\n\t\t}\n\t} else if (privateKey.startsWith('0x')) {\n\t\tconst strippedPrivateKey = privateKey.slice(2);\n\t\tif (strippedPrivateKey.length === 64) {\n\t\t\treturn strippedPrivateKey;\n\t\t} else {\n\t\t\treturn false;\n\t\t}\n\t} else {\n\t\tif (privateKey.length === 64) {\n\t\t\treturn privateKey;\n\t\t} else {\n\t\t\treturn false;\n\t\t}\n\t}\n}\n\nexport async function updateVersionInFile(\n\tprojectPath: string,\n\tnewVersion: string\n) {\n\ttry {\n\t\tconst filePath = `${projectPath}/sources/script/migrate.move`;\n\t\tconst data = await fsAsync.readFile(filePath, 'utf8');\n\n\t\t// update version data\n\t\tconst updatedData = data.replace(\n\t\t\t/const VERSION: u64 = \\d+;/,\n\t\t\t`const VERSION: u64 = ${newVersion};`\n\t\t);\n\n\t\t// write new version\n\t\twriteOutput(updatedData, filePath, 'Update package version');\n\t} catch {\n\t\tthrow new FsIibError('Fs update version failed.');\n\t}\n}\n\nasync function getDeploymentJson(projectPath: string, network: string) {\n\ttry {\n\t\tconst data = await fsAsync.readFile(\n\t\t\t`${projectPath}/.history/sui_${network}/latest.json`,\n\t\t\t'utf8'\n\t\t);\n\t\treturn JSON.parse(data) as DeploymentJsonType;\n\t} catch {\n\t\tthrow new FsIibError('Fs read deployment file failed.');\n\t}\n}\n\nexport async function getOnchainSchemas(\n\tprojectPath: string,\n\tnetwork: string\n): Promise<schema[]> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.schemas;\n}\n\nexport async function getVersion(\n\tprojectPath: string,\n\tnetwork: string\n): Promise<number> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.version;\n}\n\nexport async function getNetwork(\n\tprojectPath: string,\n\tnetwork: string\n): Promise<'mainnet' | 'testnet' | 'devnet' | 'localnet'> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.network;\n}\n\nexport async function getOldPackageId(\n\tprojectPath: string,\n\tnetwork: string\n): Promise<string> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.packageId;\n}\n\nexport async function getUpgradeCap(\n\tprojectPath: string,\n\tnetwork: string\n): Promise<string> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.upgradeCap;\n}\n\nexport async function getSchemaHub(\n\tprojectPath: string,\n\tnetwork: string\n): Promise<string> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.schemaHub;\n}\n\nexport async function getObjectIdBySchemaName(\n\tprojectPath: string,\n\tnetwork: string,\n\tschemaName: string\n): Promise<string | undefined> {\n\tconst deployment = await getDeploymentJson(projectPath, network);\n\treturn deployment.schemas.find(schema => schema.name.includes(schemaName))\n\t\t?.objectId;\n}\n\nexport function saveContractData(\n\tprojectName: string,\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n\tpackageId: string,\n\tupgradeCap: string,\n\tschemaHub: string,\n\tversion: number,\n schemas: schema[],\n) {\n\tconst DeploymentData: DeploymentJsonType = {\n\t\tprojectName,\n\t\tnetwork,\n\t\tpackageId,\n\t\tschemas,\n\t\tupgradeCap,\n\t\tschemaHub,\n\t\tversion,\n\t};\n\n\tconst path = process.cwd();\n\tconst storeDeploymentData = JSON.stringify(DeploymentData, null, 2);\n\twriteOutput(\n\t\tstoreDeploymentData,\n\t\t`${path}/contracts/${projectName}/.history/sui_${network}/latest.json`,\n\t\t'Update deploy log'\n\t);\n}\n\nexport async function writeOutput(\n\toutput: string,\n\tfullOutputPath: string,\n\tlogPrefix?: string\n): Promise<void> {\n\tmkdirSync(dirname(fullOutputPath), { recursive: true });\n\n\twriteFileSync(fullOutputPath, output);\n\tif (logPrefix !== undefined) {\n\t\tconsole.log(`${logPrefix}: ${fullOutputPath}`);\n\t}\n}\n\nfunction getDubheDependency(network: 'mainnet' | 'testnet' | 'devnet' | 'localnet'): string {\n\tswitch (network) {\n\t\tcase 'localnet':\n\t\t\treturn 'Dubhe = { local = \"../dubhe-framework\" }';\n\t\tcase 'testnet':\n\t\t\treturn 'Dubhe = { git = \"https://github.com/0xobelisk/dubhe-framework.git\", rev = \"dubhe-testnet-v1.0.0\" }';\n\t\tcase 'mainnet':\n\t\t\treturn 'Dubhe = { git = \"https://github.com/0xobelisk/dubhe-framework.git\", rev = \"dubhe-mainnet-v1.0.0\" }';\n\t\tdefault:\n\t\t\tthrow new Error(`Unsupported network: ${network}`);\n\t}\n}\n\nexport function updateDubheDependency(filePath: string, network: 'mainnet' | 'testnet' | 'devnet' | 'localnet') {\n\tconst fileContent = fs.readFileSync(filePath, 'utf-8');\n\tconst newDependency = getDubheDependency(network);\n\tconst updatedContent = fileContent.replace(/Dubhe = \\{.*\\}/, newDependency);\n\tfs.writeFileSync(filePath, updatedContent, 'utf-8');\n\tconsole.log(`Updated Dubhe dependency in ${filePath} for ${network}.`);\n}\nexport async function switchEnv(network: 'mainnet' | 'testnet' | 'devnet' | 'localnet') {\n\ttry {\n\t\treturn new Promise<void>((resolve, reject) => {\n\t\t\tconst suiProcess = spawn(\n\t\t\t\t'sui',\n\t\t\t\t['client', 'switch', '--env', network],\n\t\t\t\t{\n\t\t\t\t\tenv: { ...process.env },\n\t\t\t\t\tstdio: 'pipe'\n\t\t\t\t}\n\t\t\t);\n\n\t\t\tsuiProcess.stdout.on('data', data => {\n\t\t\t\tconsole.log(chalk.green(`${data.toString()}`));\n\t\t\t});\n\n\t\t\tsuiProcess.stderr.on('data', data => {\n\t\t\t\tconsole.error(chalk.red('\\nāŒ Failed to Switch Env'));\n\t\t\t\tconsole.error(chalk.red(` Error: ${data.toString()}`));\n\t\t\t});\n\n\t\t\tsuiProcess.on('error', error => {\n\t\t\t\tconsole.error(chalk.red('\\nāŒ Failed to Switch Env'));\n\t\t\t\tconsole.error(chalk.red(` Error: ${error.message}`));\n\t\t\t\treject(error); // Reject promise on error\n\t\t\t});\n\n\t\t\tsuiProcess.on('exit', (code) => {\n\t\t\t\tif (code !== 0) {\n\t\t\t\t\tconsole.error(chalk.red(`\\nāŒ Process exited with code: ${code}`));\n\t\t\t\t\treject(new Error(`Process exited with code: ${code}`));\n\t\t\t\t} else {\n\t\t\t\t\tresolve(); // Resolve promise on successful exit\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t} catch (error) {\n\t\tconsole.error(chalk.red('\\nāŒ Failed to Switch Env'));\n\t\tconsole.error(chalk.red(` └─ Error: ${error}`));\n\t}\n}\n\nexport const delay = (ms: number) =>\n\tnew Promise(resolve => setTimeout(resolve, ms));\n","import type { CommandModule } from 'yargs';\nimport { startLocalNode } from '../utils/startNode';\n\nconst commandModule: CommandModule = {\n\tcommand: 'node',\n\n\tdescribe: 'Manage local Sui node',\n\n\tbuilder(yargs) {\n\t\treturn yargs\n\t},\n\n\tasync handler() {\n\t\ttry {\n\t\t\tawait startLocalNode();\n\t\t} catch (error) {\n\t\t\tconsole.error('Error executing command:', error);\n\t\t\tprocess.exit(1);\n\t\t}\n\t},\n};\n\nexport default commandModule;\n","import { Dubhe } from '@0xobelisk/sui-client';\nimport type { CommandModule } from 'yargs';\nimport { requestSuiFromFaucetV0, getFaucetHost } from '@mysten/sui/faucet';\nimport {\n\tSuiClient,\n\tgetFullnodeUrl,\n\tGetBalanceParams,\n} from '@mysten/sui/client';\nimport { validatePrivateKey, DubheCliError } from '../utils';\n\ntype Options = {\n\tnetwork: any;\n\trecipient?: string;\n};\n\nconst commandModule: CommandModule<Options, Options> = {\n\tcommand: 'faucet',\n\n\tdescribe: 'Interact with a Dubhe faucet',\n\n\tbuilder(yargs) {\n\t\treturn yargs.options({\n\t\t\tnetwork: {\n\t\t\t\ttype: 'string',\n\t\t\t\tdesc: 'URL of the Dubhe faucet',\n\t\t\t\tchoices: ['testnet', 'devnet', 'localnet'],\n\t\t\t\tdefault: 'localnet',\n\t\t\t},\n\t\t\trecipient: {\n\t\t\t\ttype: 'string',\n\t\t\t\tdesc: 'Sui address to fund',\n\t\t\t},\n\t\t});\n\t},\n\n\tasync handler({ network, recipient }) {\n\t\tlet faucet_address = '';\n\t\tif (recipient === undefined) {\n\t\t\tconst privateKey = process.env.PRIVATE_KEY;\n\t\t\tif (!privateKey)\n\t\t\t\tthrow new DubheCliError(\n\t\t\t\t\t`Missing PRIVATE_KEY environment variable.\n Run 'echo \"PRIVATE_KEY=YOUR_PRIVATE_KEY\" > .env'\n in your contracts directory to use the default sui private key.`\n\t\t\t\t);\n\n\t\t\tconst privateKeyFormat = validatePrivateKey(privateKey);\n\t\t\tif (privateKeyFormat === false) {\n\t\t\t\tthrow new DubheCliError(`Please check your PRIVATE_KEY.`);\n\t\t\t}\n\t\t\tconst dubhe = new Dubhe({\n\t\t\t\tsecretKey: privateKeyFormat,\n\t\t\t});\n\t\t\tconst keypair = dubhe.getKeypair();\n\t\t\tfaucet_address = keypair.toSuiAddress();\n\t\t} else {\n\t\t\tfaucet_address = recipient;\n\t\t}\n\n\t\tconsole.log('\\n🌊 Starting Faucet Operation...');\n\t\tconsole.log(` ā”œā”€ Network: ${network}`);\n\n\t\tif (recipient === undefined) {\n\t\t\tconsole.log(' ā”œā”€ Using Environment PrivateKey');\n\t\t\tconsole.log(` ā”œā”€ Generated Address: ${faucet_address}`);\n\t\t} else {\n\t\t\tconsole.log(` ā”œā”€ Using Provided Address: ${faucet_address}`);\n\t\t}\n\n\t\tconsole.log(' ā”œā”€ Requesting funds from faucet...');\n\t\tawait requestSuiFromFaucetV0({\n\t\t\thost: getFaucetHost(network),\n\t\t\trecipient: faucet_address,\n\t\t});\n\n\t\tconsole.log(' └─ Checking balance...');\n\t\tconst client = new SuiClient({ url: getFullnodeUrl(network) });\n\t\tlet params = {\n\t\t\towner: faucet_address,\n\t\t} as GetBalanceParams;\n\n\t\tconst balance = await client.getBalance(params);\n\n\t\tconsole.log('\\nšŸ’° Account Summary');\n\t\tconsole.log(` ā”œā”€ Address: ${faucet_address}`);\n\t\tconsole.log(\n\t\t\t` └─ Balance: ${(\n\t\t\t\tNumber(balance.totalBalance) / 1_000_000_000\n\t\t\t).toFixed(4)} SUI`\n\t\t);\n\n\t\tconsole.log('\\nāœ… Faucet Operation Complete\\n');\n\t\tprocess.exit(0);\n\t},\n};\n\nexport default commandModule;\n","import type { CommandModule } from 'yargs';\nimport { schemaGen, loadConfig, DubheConfig } from '@0xobelisk/sui-common';\nimport chalk from 'chalk';\n\ntype Options = {\n\t'config-path'?: string;\n\tnetwork?: 'mainnet' | 'testnet' | 'devnet' | 'localnet';\n\t'framework-id'?: string;\n};\n\nconst commandModule: CommandModule<Options, Options> = {\n\tcommand: 'schemagen',\n\n\tdescribe: 'Autogenerate Dubhe schemas based on the config file',\n\n\tbuilder: {\n\t\t'config-path': {\n\t\t\ttype: 'string',\n\t\t\tdefault: 'dubhe.config.ts',\n\t\t\tdesc: 'Path to the config file',\n\t\t},\n\t\tnetwork: {\n\t\t\ttype: 'string',\n\t\t\tchoices: ['mainnet', 'testnet', 'devnet', 'localnet'] as const,\n\t\t\tdesc: 'Node network (mainnet/testnet/devnet/localnet)',\n\t\t},\n\t\t'framework-id': {\n\t\t\ttype: 'string',\n\t\t\tdesc: 'Framework Package ID',\n\t\t},\n\t},\n\n\tasync handler({\n\t\t'config-path': configPath,\n\t\tnetwork,\n\t\t'framework-id': frameworkId,\n\t}) {\n\t\ttry {\n\t\t\tconst dubheConfig = (await loadConfig(configPath)) as DubheConfig;\n\t\t\tawait schemaGen(dubheConfig, undefined, network, frameworkId);\n\t\t\tprocess.exit(0);\n\t\t} catch (error: any) {\n\t\t\tconsole.log(chalk.red('Schemagen failed!'));\n\t\t\tconsole.error(error.message);\n\t\t}\n\t},\n};\n\nexport default commandModule;\n","import type { CommandModule } from 'yargs';\nimport { logError } from '../utils/errors';\nimport { publishHandler } from '../utils';\nimport { loadConfig, DubheConfig } from '@0xobelisk/sui-common';\n\ntype Options = {\n\tnetwork: any;\n\t'config-path': string;\n\t'contract-name'?: string;\n};\n\nconst commandModule: CommandModule<Options, Options> = {\n\tcommand: 'publish',\n\n\tdescribe: 'Publish dubhe move contract',\n\n\tbuilder(yargs) {\n\t\treturn yargs.options({\n\t\t\tnetwork: {\n\t\t\t\ttype: 'string',\n\t\t\t\tchoices: ['mainnet', 'testnet', 'devnet', 'localnet'],\n\t\t\t\tdesc: 'Node network (mainnet/testnet/devnet/localnet)',\n\t\t\t},\n\t\t\t'config-path': {\n\t\t\t\ttype: 'string',\n\t\t\t\tdefault: 'dubhe.config.ts',\n\t\t\t\tdesc: 'Configuration file path',\n\t\t\t},\n\t\t\t'contract-name': {\n\t\t\t\ttype: 'string',\n\t\t\t\tdesc: 'Optional contract name in contracts/ directory',\n\t\t\t},\n\t\t});\n\t},\n\n\tasync handler({\n\t\tnetwork,\n\t\t'config-path': configPath,\n\t\t'contract-name': contractName,\n\t}) {\n\t\ttry {\n\t\t\tconst dubheConfig = (await loadConfig(configPath)) as DubheConfig;\n\t\t\tawait publishHandler(dubheConfig, network, contractName);\n\t\t} catch (error: any) {\n\t\t\tlogError(error);\n\t\t\tprocess.exit(1);\n\t\t}\n\t\tprocess.exit(0);\n\t},\n};\n\nexport default commandModule;\n","import { Dubhe } from '@0xobelisk/sui-client';\nimport { Transaction, UpgradePolicy } from '@mysten/sui/transactions';\nimport { getFullnodeUrl, SuiClient } from '@mysten/sui/client';\nimport { execSync } from 'child_process';\nimport chalk from 'chalk';\nimport { DubheCliError, UpgradeError } from './errors';\nimport {\n\tupdateVersionInFile,\n\tgetOldPackageId,\n\tgetVersion,\n\tgetUpgradeCap,\n\tsaveContractData,\n\tvalidatePrivateKey, getOnchainSchemas, getSchemaHub, switchEnv, delay,\n} from './utils';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { DubheConfig } from '@0xobelisk/sui-common';\n\ntype ObjectContent = {\n\ttype: string;\n\tfields: Record<string, any>;\n\thasPublicTransfer: boolean;\n\tdataType: string;\n};\n\ntype Field = {\n\tname: string;\n\ttype: string;\n}\n\ntype Migration = {\n\tschemaName: string;\n\tfields: Field[];\n};\n\nfunction updateMigrateMethod(projectPath: string, migrations: Migration[]): void {\n\tmigrations.forEach((migration) => {\n\t\tlet filePath = `${projectPath}/sources/codegen/schemas/${migration.schemaName}.move`;\n\t\tconst fileContent = fs.readFileSync(filePath, 'utf-8');\n\t\tconst migrateMethodRegex = new RegExp(`public fun migrate\\\\(_${migration.schemaName}: &mut ${capitalizeAndRemoveUnderscores(migration.schemaName)}, _cap: &UpgradeCap\\\\) {[^}]*}`);\n\t\tconst newMigrateMethod = `\npublic fun migrate(${migration.schemaName}: &mut ${capitalizeAndRemoveUnderscores(migration.schemaName)}, _cap: &UpgradeCap) {\n${migration.fields.map((field) => {\n\t\t\tlet storage_type = '';\n\t\t\tif (field.type.includes('StorageValue')) {\n\t\t\t\tstorage_type = `storage_value::new()`;\n\t\t\t} else if (field.type.includes('StorageMap')) {\n\t\t\t\tstorage_type = `storage_map::new()`;\n\t\t\t} else if (\n\t\t\t\tfield.type.includes('StorageDoubleMap')\n\t\t\t) {\n\t\t\t\tstorage_type = `storage_double_map::new()`;\n\t\t\t}\n\t\t\treturn `storage_migrate::add_field<${field.type}>(&mut ${migration.schemaName}.id, b\"${field.name}\", ${storage_type});`;\n\t\t}).join('')}\n}\n`;\n\n\t\tconst updatedContent = fileContent.replace(migrateMethodRegex, newMigrateMethod);\n\t\tfs.writeFileSync(filePath, updatedContent, 'utf-8');\n\t});\n\n\n}\n\nfunction capitalizeAndRemoveUnderscores(input: string): string {\n\treturn input\n\t\t.split('_')\n\t\t.map((word, index) => {\n\t\t\treturn index === 0\n\t\t\t\t? word.charAt(0).toUpperCase() + word.slice(1).toLowerCase()\n\t\t\t\t: word.charAt(0).toUpperCase() + word.slice(1).toLowerCase();\n\t\t})\n\t\t.join('');\n}\n\nfunction getLastSegment(input: string): string {\n\tconst segments = input.split('::');\n\treturn segments.length > 0 ? segments[segments.length - 1] : '';\n}\n\nfunction replaceEnvField(\n\tfilePath: string,\n\tnetworkType: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n\tfield: 'original-published-id' | 'latest-published-id' | 'published-version',\n\tnewValue: string\n): string {\n\tconst envFilePath = path.resolve(filePath);\n\tconst envContent = fs.readFileSync(envFilePath, 'utf-8');\n\tconst envLines = envContent.split('\\n');\n\n\tconst networkSectionIndex = envLines.findIndex(line => line.trim() === `[env.${networkType}]`);\n\tif (networkSectionIndex === -1) {\n\t\tconsole.log(`Network type [env.${networkType}] not found in the file.`);\n\t\treturn \"\";\n\t}\n\n\tlet fieldIndex = -1;\n\tlet previousValue: string = \"\";\n\tfor (let i = networkSectionIndex + 1; i < envLines.length; i++) {\n\t\tconst line = envLines[i].trim();\n\t\tif (line.startsWith('[')) break; // End of the current network section\n\n\t\tif (line.startsWith(field)) {\n\t\t\tfieldIndex = i;\n\t\t\tpreviousValue = line.split('=')[1].trim().replace(/\"/g, '');\n\t\t\tbreak;\n\t\t}\n\t}\n\n\tif (fieldIndex !== -1) {\n\t\tenvLines[fieldIndex] = `${field} = \"${newValue}\"`;\n\t\tconst newEnvContent = envLines.join('\\n');\n\t\tfs.writeFileSync(envFilePath, newEnvContent, 'utf-8');\n\t} else {\n\t\tconsole.log(`${field} not found for [env.${networkType}].`);\n\t}\n\n\treturn previousValue;\n}\nexport async function upgradeHandler(\n\tconfig: DubheConfig,\n\tname: string,\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n) {\n\tawait switchEnv(network);\n\n\tconst path = process.cwd();\n\tconst projectPath = `${path}/contracts/${name}`;\n\tconst privateKey = process.env.PRIVATE_KEY;\n\tif (!privateKey)\n\t\tthrow new DubheCliError(\n\t\t\t`Missing PRIVATE_KEY environment variable.\nRun 'echo \"PRIVATE_KEY=YOUR_PRIVATE_KEY\" > .env'\nin your contracts directory to use the default sui private key.`,\n\t\t);\n\n\tconst privateKeyFormat = validatePrivateKey(privateKey);\n\tif (privateKeyFormat === false) {\n\t\tthrow new DubheCliError(`Please check your privateKey.`);\n\t}\n\tconst dubhe = new Dubhe({\n\t\tsecretKey: privateKeyFormat,\n\t});\n\tconst keypair = dubhe.getKeypair();\n\n\tconst client = new SuiClient({\n\t\turl: getFullnodeUrl(network),\n\t});\n\n\tlet oldVersion = Number(await getVersion(projectPath, network));\n\tlet oldPackageId = await getOldPackageId(projectPath, network);\n\tlet schemaHub = await getSchemaHub(projectPath, network);\n\tlet upgradeCap = await getUpgradeCap(projectPath, network);\n\n\tconst original_published_id = replaceEnvField(`${projectPath}/Move.lock`, network, 'original-published-id', \"0x0000000000000000000000000000000000000000000000000000000000000000\");\n\n\tlet pendingMigration: Migration[] = [];\n\tlet schemas = await getOnchainSchemas(projectPath, network);\n\tfor (let schemaKey in config.schemas) {\n\t\tschemas.forEach((schema) => {\n\t\t\tif (capitalizeAndRemoveUnderscores(schemaKey) == getLastSegment(schema.name)) {\n\t\t\t\tlet migrate: Migration = { schemaName: '', fields: [] };\n\t\t\t\tlet fields: Field[] = [];\n\t\t\t\tlet isMigration = false;\n\t\t\t\tfor (const key in config.schemas[schemaKey].structure) {\n\t\t\t\t\tif (!(key in schema.structure)) {\n\t\t\t\t\t\tisMigration = true;\n\t\t\t\t\t\tfields.push({\n\t\t\t\t\t\t\tname: key,\n\t\t\t\t\t\t\ttype: config.schemas[schemaKey].structure[key],\n\t\t\t\t\t\t});\n\t\t\t\t\t\tschema.structure[key] = config.schemas[schemaKey].structure[key];\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (isMigration) {\n\t\t\t\t\tmigrate.schemaName = schemaKey;\n\t\t\t\t\tmigrate.fields = fields;\n\t\t\t\t\tpendingMigration.push(migrate);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\n\tpendingMigration.forEach((migration) => {\n\t\tconsole.log(`\\nšŸš€ Starting Migration for ${migration.schemaName}...`);\n\t\tconsole.log('šŸ“‹ Migration Fields:', migration.fields);\n\t});\n\tupdateMigrateMethod(projectPath, pendingMigration);\n\n\ttry {\n\t\tlet modules: any, dependencies: any, digest: any;\n\t\ttry {\n\t\t\tconst {\n\t\t\t\tmodules: extractedModules,\n\t\t\t\tdependencies: extractedDependencies,\n\t\t\t\tdigest: extractedDigest,\n\t\t\t} = JSON.parse(\n\t\t\t\texecSync(\n\t\t\t\t\t`sui move build --dump-bytecode-as-base64 --path ${path}/contracts/${name}`,\n\t\t\t\t\t{\n\t\t\t\t\t\tencoding: 'utf-8',\n\t\t\t\t\t},\n\t\t\t\t),\n\t\t\t);\n\n\t\t\tmodules = extractedModules;\n\t\t\tdependencies = extractedDependencies;\n\t\t\tdigest = extractedDigest;\n\t\t} catch (error: any) {\n\t\t\tthrow new UpgradeError(error.stdout);\n\t\t}\n\n\t\tconsole.log('\\nšŸš€ Starting Upgrade Process...');\n\t\tconsole.log('šŸ“‹ OldPackageId:', oldPackageId);\n\t\tconsole.log('šŸ“‹ UpgradeCap Object Id:', upgradeCap);\n\t\tconsole.log('šŸ“‹ OldVersion:', oldVersion);\n\n\t\tconst tx = new Transaction();\n\t\tconst ticket = tx.moveCall({\n\t\t\ttarget: '0x2::package::authorize_upgrade',\n\t\t\targuments: [\n\t\t\t\ttx.object(upgradeCap),\n\t\t\t\ttx.pure.u8(UpgradePolicy.COMPATIBLE),\n\t\t\t\ttx.pure.vector('u8', digest),\n\t\t\t],\n\t\t});\n\n\t\tconst receipt = tx.upgrade({\n\t\t\tmodules,\n\t\t\tdependencies,\n\t\t\tpackage: oldPackageId,\n\t\t\tticket,\n\t\t});\n\n\t\ttx.moveCall({\n\t\t\ttarget: '0x2::package::commit_upgrade',\n\t\t\targuments: [tx.object(upgradeCap), receipt],\n\t\t});\n\n\t\tconst result = await client.signAndExecuteTransaction({\n\t\t\tsigner: keypair,\n\t\t\ttransaction: tx,\n\t\t\toptions: {\n\t\t\t\tshowObjectChanges: true,\n\t\t\t},\n\t\t});\n\n\t\tlet newPackageId = '';\n\t\tresult.objectChanges!.map(object => {\n\t\t\tif (object.type === 'published') {\n\t\t\t\tconsole.log(\n\t\t\t\t\tchalk.blue(`${name} PackageId: ${object.packageId}`),\n\t\t\t\t);\n\t\t\t\tconsole.log(\n\t\t\t\t\tchalk.blue(`${name} Version: ${oldVersion + 1}`),\n\t\t\t\t);\n\t\t\t\tnewPackageId = object.packageId;\n\t\t\t}\n\t\t});\n\n\t\treplaceEnvField(`${projectPath}/Move.lock`, network, 'original-published-id', original_published_id);\n\t\treplaceEnvField(`${projectPath}/Move.lock`, network, 'latest-published-id', newPackageId);\n\t\treplaceEnvField(`${projectPath}/Move.lock`, network, 'published-version', (oldVersion + 1) + \"\");\n\n\t\tconsole.log(\n\t\t\tchalk.green(`Upgrade Transaction Digest: ${result.digest}`),\n\t\t);\n\n\t\tsaveContractData(\n\t\t\tname,\n\t\t\tnetwork,\n\t\t\tnewPackageId,\n\t\t\tupgradeCap,\n\t\t\tschemaHub,\n\t\t\toldVersion + 1,\n\t\t\tschemas,\n\t\t);\n\n\t} catch (error: any) {\n\t\tconsole.log(chalk.red('Upgrade failed!'));\n\t\tconsole.error(error.message);\n\t}\n}\n","import type { CommandModule } from 'yargs';\nimport { logError } from '../utils/errors';\nimport { upgradeHandler } from '../utils/upgradeHandler';\nimport { DubheConfig, loadConfig } from '@0xobelisk/sui-common';\n\ntype Options = {\n\tnetwork: any;\n\t'config-path': string;\n};\n\nconst commandModule: CommandModule<Options, Options> = {\n\tcommand: 'upgrade',\n\n\tdescribe: 'Upgrade your move contracts',\n\n\tbuilder(yargs) {\n\t\treturn yargs.options({\n\t\t\tnetwork: {\n\t\t\t\ttype: 'string',\n\t\t\t\tchoices: ['mainnet', 'testnet', 'devnet', 'localnet'],\n\t\t\t\tdesc: 'Network of the node (mainnet/testnet/devnet/localnet)',\n\t\t\t},\n\t\t\t'config-path': {\n\t\t\t\ttype: 'string',\n\t\t\t\tdefault: 'dubhe.config.ts',\n\t\t\t\tdecs: 'Path to the config file',\n\t\t\t},\n\t\t});\n\t},\n\n\tasync handler({ network, 'config-path': configPath }) {\n\t\ttry {\n\t\t\tconst dubheConfig = (await loadConfig(configPath)) as DubheConfig;\n\t\t\tawait upgradeHandler(dubheConfig, dubheConfig.name, network);\n\t\t} catch (error: any) {\n\t\t\tlogError(error);\n\t\t\tprocess.exit(1);\n\t\t}\n\t\tprocess.exit(0);\n\t},\n};\n\nexport default commandModule;\n","import type { CommandModule } from \"yargs\";\nimport { execSync } from \"child_process\";\nimport chalk from \"chalk\";\nimport { DubheConfig, loadConfig } from '@0xobelisk/sui-common';\n\ntype Options = {\n 'config-path': string;\n 'test'?: string;\n};\n\nconst commandModule: CommandModule<Options, Options> = {\n command: \"test\",\n\n describe: \"Run tests in Dubhe contracts\",\n\n builder(yargs) {\n return yargs.options({\n 'config-path': {\n type: \"string\",\n default: \"dubhe.config.ts\",\n description: \"Options to pass to forge test\",\n },\n test: {\n type: 'string',\n desc: 'Run a specific test',\n },\n });\n },\n\n async handler({ 'config-path': configPath, test }) {\n // Start an internal anvil process if no world address is provided\n try {\n console.log('šŸš€ Running move test');\n const dubheConfig = (await loadConfig(configPath)) as DubheConfig;\n const path = process.cwd();\n const projectPath = `${path}/contracts/${dubheConfig.name}`;\n const command = `sui move test --path ${projectPath} ${test ? ` --test ${test}` : ''}`;\n const output = execSync(command, { encoding: \"utf-8\" });\n console.log(output);\n } catch (error: any) {\n console.error(chalk.red(\"Error executing sui move test:\"));\n console.log(error.stdout);\n process.exit(0);\n }\n },\n};\n\nexport default commandModule;\n","import type { CommandModule } from \"yargs\";\nimport { execSync } from \"child_process\";\nimport chalk from \"chalk\";\nimport { DubheConfig, loadConfig } from '@0xobelisk/sui-common';\nimport { switchEnv, updateDubheDependency } from '../utils';\n\ntype Options = {\n 'config-path': string;\n network: any;\n 'dump-bytecode-as-base64'?: boolean;\n};\n\nconst commandModule: CommandModule<Options, Options> = {\n command: \"build\",\n describe: \"Run tests in Dubhe contracts\",\n builder(yargs) {\n return yargs.options({\n 'config-path': {\n type: \"string\",\n default: \"dubhe.config.ts\",\n description: \"Options to pass to forge test\",\n },\n network: {\n type: 'string',\n choices: ['mainnet', 'testnet', 'devnet', 'localnet'],\n desc: 'Node network (mainnet/testnet/devnet/localnet)',\n },\n 'dump-bytecode-as-base64': {\n type: 'boolean',\n default: false,\n desc: 'Dump bytecode as base64',\n },\n });\n },\n\n async handler({ 'config-path': configPath, network, 'dump-bytecode-as-base64': dumpBytecodeAsBase64 }) {\n // Start an internal anvil process if no world address is provided\n try {\n console.log('šŸš€ Running move build');\n const dubheConfig = (await loadConfig(configPath)) as DubheConfig;\n const path = process.cwd();\n const projectPath = `${path}/contracts/${dubheConfig.name}`;\n await switchEnv(network);\n updateDubheDependency(projectPath+'/Move.toml', network);\n const command = `sui move build --path ${projectPath} ${dumpBytecodeAsBase64 ? ` --dump-bytecode-as-base64` : ''}`;\n const output = execSync(command, { encoding: \"utf-8\" });\n console.log(output);\n } catch (error: any) {\n console.error(chalk.red(\"Error executing sui move build:\"));\n console.log(error.stdout);\n process.exit(0);\n }\n },\n};\n\nexport default commandModule;\n","import type { CommandModule } from \"yargs\";\nimport { printDubhe } from \"../utils\";\n\nconst commandModule: CommandModule = {\n command: \"hello\",\n\n describe: \"hello, dubhe\",\n\n builder(yargs) {\n return yargs;\n },\n\n async handler() {\n printDubhe();\n },\n};\n\nexport default commandModule;\n","import { CommandModule } from 'yargs';\n\nimport localnode from './localnode';\nimport faucet from './faucet';\nimport schemagen from './schemagen';\nimport publish from './publish';\nimport upgrade from \"./upgrade\";\nimport test from './test';\nimport build from './build';\nimport hello from './hello';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Each command has different options\nexport const commands: CommandModule<any, any>[] = [\n\tpublish,\n\tlocalnode,\n\tfaucet,\n\tschemagen,\n\tupgrade,\n\ttest,\n\tbuild,\n\thello,\n];\n"],"mappings":";AAEA,OAAOA,OAAW,QAClB,OAAS,WAAAC,OAAe,gBCHxB,OAAS,YAAAC,GAAU,SAAAC,OAAa,gBAChC,OAAOC,MAAW,QCDlB,OAAOC,OAAW,QAEX,SAASC,GAAa,CAC3B,QAAQ,IACND,GAAM,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,CAWhB,CACC,CACF,CCjBA,OAAS,SAAAE,OAAa,wBACtB,OAAS,eAAAC,MAAmB,2BAC5B,OACC,kBAAAC,GACA,aAAAC,OAEM,qBACP,OAAS,YAAAC,OAAgB,gBACzB,OAAOC,MAAW,QCRlB,OAAOC,MAAW,QAClB,OAAS,YAAAC,OAAgB,MACzB,OAAS,gBAAAC,GAAc,mBAAAC,OAAuB,uBAEvC,IAAMC,EAAN,cAAoC,KAAM,CAC/C,KAAO,wBACP,QAAU,oCACZ,EAEaC,EAAN,cAA4B,KAAM,CACvC,KAAO,eACT,EAEaC,EAAN,cAA2B,KAAM,CACtC,KAAO,cACT,EAEaC,EAAN,cAAyB,KAAM,CACpC,KAAO,YACT,EAEO,SAASC,EAASC,EAAgB,CACvC,GAAIA,aAAiBN,GACnB,QAAQ,IAAIH,EAAM,UAAUS,EAAM,OAAO,CAAC,UACjCA,aAAiBR,GAAU,CAEpC,IAAMS,EAAkBR,GAAaO,EAAO,CAC1C,gBAAiB;AAAA,IACjB,eAAgB;AAAA,GAClB,CAAC,EACD,QAAQ,IAAIT,EAAM,UAAUU,EAAgB,OAAO,CAAC,OAC3CD,aAAiBL,GAC1B,QAAQ,IAAIJ,EAAM,IAAIS,EAAM,OAAO,CAAC,EACpC,QAAQ,IAAI,EAAE,EAEd,QAAQ,IACNT,EAAM,KACJ,sFACF,CACF,GACSS,aAAiBJ,EAC1B,QAAQ,IAAIL,EAAM,IAAIS,CAAK,CAAC,EAE5B,QAAQ,IAAIA,CAAK,CAErB,CC7CA,UAAYE,MAAa,cACzB,OAAS,aAAAC,GAAW,iBAAAC,OAAqB,KACzC,OAAS,WAAAC,OAAe,OACxB,OAAS,0BAAAC,OAA8B,2BAEvC,UAAYC,MAAQ,KACpB,OAAOC,MAAW,QAClB,OAAS,SAAAC,OAAa,gBAkBf,SAASC,EAAmBC,EAAoC,CACtE,GAAIA,EAAW,WAAWC,EAAsB,EAC/C,OAAID,EAAW,SAAW,GAClBA,EAEA,GAEF,GAAIA,EAAW,WAAW,IAAI,EAAG,CACvC,IAAME,EAAqBF,EAAW,MAAM,CAAC,EAC7C,OAAIE,EAAmB,SAAW,GAC1BA,EAEA,OAGR,QAAIF,EAAW,SAAW,GAClBA,EAEA,EAGV,CAuBA,eAAeG,EAAkBC,EAAqBC,EAAiB,CACtE,GAAI,CACH,IAAMC,EAAO,MAAc,WAC1B,GAAGF,kBAA4BC,gBAC/B,MACD,EACA,OAAO,KAAK,MAAMC,CAAI,CACvB,MAAE,CACD,MAAM,IAAIC,EAAW,iCAAiC,CACvD,CACD,CAEA,eAAsBC,EACrBJ,EACAC,EACoB,CAEpB,OADmB,MAAMF,EAAkBC,EAAaC,CAAO,GAC7C,OACnB,CAEA,eAAsBI,EACrBL,EACAC,EACkB,CAElB,OADmB,MAAMF,EAAkBC,EAAaC,CAAO,GAC7C,OACnB,CAUA,eAAsBK,GACrBC,EACAC,EACkB,CAElB,OADmB,MAAMC,EAAkBF,EAAaC,CAAO,GAC7C,SACnB,CAEA,eAAsBE,GACrBH,EACAC,EACkB,CAElB,OADmB,MAAMC,EAAkBF,EAAaC,CAAO,GAC7C,UACnB,CAEA,eAAsBG,EACrBJ,EACAC,EACkB,CAElB,OADmB,MAAMC,EAAkBF,EAAaC,CAAO,GAC7C,SACnB,CAYO,SAASI,EACfC,EACAC,EACAC,EACAC,EACAC,EACAC,EACCC,EACA,CACD,IAAMC,EAAqC,CAC1C,YAAAP,EACA,QAAAC,EACA,UAAAC,EACA,QAAAI,EACA,WAAAH,EACA,UAAAC,EACA,QAAAC,CACD,EAEMG,EAAO,QAAQ,IAAI,EACnBC,EAAsB,KAAK,UAAUF,EAAgB,KAAM,CAAC,EAClEG,GACCD,EACA,GAAGD,eAAkBR,kBAA4BC,gBACjD,mBACD,CACD,CAEA,eAAsBS,GACrBC,EACAC,EACAC,EACgB,CAChBC,GAAUC,GAAQH,CAAc,EAAG,CAAE,UAAW,EAAK,CAAC,EAEtDI,GAAcJ,EAAgBD,CAAM,EAChCE,IAAc,QACjB,QAAQ,IAAI,GAAGA,MAAcD,GAAgB,CAE/C,CAEA,SAASK,GAAmBhB,EAAiE,CAC5F,OAAQA,EAAS,CAChB,IAAK,WACJ,MAAO,2CACR,IAAK,UACJ,MAAO,qGACR,IAAK,UACJ,MAAO,qGACR,QACC,MAAM,IAAI,MAAM,wBAAwBA,GAAS,CACnD,CACD,CAEO,SAASiB,EAAsBC,EAAkBlB,EAAwD,CAC/G,IAAMmB,EAAiB,eAAaD,EAAU,OAAO,EAC/CE,EAAgBJ,GAAmBhB,CAAO,EAC1CqB,EAAiBF,EAAY,QAAQ,iBAAkBC,CAAa,EACvE,gBAAcF,EAAUG,EAAgB,OAAO,EAClD,QAAQ,IAAI,+BAA+BH,SAAgBlB,IAAU,CACtE,CACA,eAAsBsB,EAAUtB,EAAwD,CACvF,GAAI,CACH,OAAO,IAAI,QAAc,CAACuB,EAASC,IAAW,CAC7C,IAAMC,EAAaC,GAClB,MACA,CAAC,SAAU,SAAU,QAAS1B,CAAO,EACrC,CACC,IAAK,CAAE,GAAG,QAAQ,GAAI,EACtB,MAAO,MACR,CACD,EAEAyB,EAAW,OAAO,GAAG,OAAQE,GAAQ,CACpC,QAAQ,IAAIC,EAAM,MAAM,GAAGD,EAAK,SAAS,GAAG,CAAC,CAC9C,CAAC,EAEDF,EAAW,OAAO,GAAG,OAAQE,GAAQ,CACpC,QAAQ,MAAMC,EAAM,IAAI;AAAA,4BAA0B,CAAC,EACnD,QAAQ,MAAMA,EAAM,IAAI,YAAYD,EAAK,SAAS,GAAG,CAAC,CACvD,CAAC,EAEDF,EAAW,GAAG,QAASI,GAAS,CAC/B,QAAQ,MAAMD,EAAM,IAAI;AAAA,4BAA0B,CAAC,EACnD,QAAQ,MAAMA,EAAM,IAAI,YAAYC,EAAM,SAAS,CAAC,EACpDL,EAAOK,CAAK,CACb,CAAC,EAEDJ,EAAW,GAAG,OAASK,GAAS,CAC3BA,IAAS,GACZ,QAAQ,MAAMF,EAAM,IAAI;AAAA,mCAAiCE,GAAM,CAAC,EAChEN,EAAO,IAAI,MAAM,6BAA6BM,GAAM,CAAC,GAErDP,EAAQ,CAEV,CAAC,CACF,CAAC,CACF,OAASM,EAAP,CACD,QAAQ,MAAMD,EAAM,IAAI;AAAA,4BAA0B,CAAC,EACnD,QAAQ,MAAMA,EAAM,IAAI,yBAAeC,GAAO,CAAC,CAChD,CACD,CAEO,IAAME,EAASC,GACrB,IAAI,QAAQT,GAAW,WAAWA,EAASS,CAAE,CAAC,EFlO/C,UAAYC,MAAQ,KACpB,UAAYC,OAAU,OAEtB,eAAeC,GACdC,EACC,CACD,OAAQA,EAAS,CAChB,IAAK,WAAY,CAChB,IAAMF,EAAO,QAAQ,IAAI,EACzB,OAAO,MAAMG,EAAa,GAAGH,8BAAkCE,CAAO,CACvE,CACA,IAAK,UACJ,MAAO,qEACR,QACC,MAAO,oEACT,CACD,CAEA,SAASE,GAAiBC,EAAkBC,EAAkE,CAC7G,GAAI,CAAI,aAAWD,CAAQ,EAC1B,OAED,IAAME,EAAa,eAAaF,EAAU,OAAO,EAC3CG,EAAQ,IAAI,OAAO,YAAYF,0BAAqC,GAAG,EACvEG,EAAiBF,EAAQ,QAAQC,EAAO,EAAE,EAC7C,gBAAcH,EAAUI,EAAgB,OAAO,CACnD,CAeA,SAASC,GAAcC,EAAkBC,EAA4DC,EAAkCC,EAAiBC,EAA2B,CAClL,IAAMC,EAAmB,WAAQL,CAAQ,EACnCM,EAAgB,eAAaD,EAAa,OAAO,EACjDE,EAAWD,EAAW,MAAM;AAAA,CAAI,EAEhCE,EAAsBD,EAAS,UAAUE,GAAQA,EAAK,KAAK,IAAM,QAAQR,IAAc,EACvFS,EAAoB,CACzB,QAASP,EACT,oBAAqB,GACrB,kBAAmB,GACnB,iBAAkB,CACnB,EAEA,GAAIK,IAAwB,GAE3B,GAAIN,IAAc,UACjBQ,EAAO,oBAAsBN,EAC7BM,EAAO,kBAAoBN,EAC3BM,EAAO,iBAAmB,MAE1B,OAAM,IAAI,MAAM,qBAAqBT,8CAAwD,MAExF,CACN,QAASU,EAAIH,EAAsB,EAAGG,EAAIJ,EAAS,OAAQI,IAAK,CAC/D,IAAMF,EAAOF,EAASI,CAAC,EAAE,KAAK,EAC9B,GAAIF,EAAK,WAAW,GAAG,EAAG,MAE1B,GAAM,CAACG,EAAKC,CAAK,EAAIJ,EAAK,MAAM,GAAG,EAAE,IAAIK,GAAQA,EAAK,KAAK,EAAE,QAAQ,KAAM,EAAE,CAAC,EAC9E,OAAQF,EAAK,CACZ,IAAK,wBACJF,EAAO,oBAAsBG,EAC7B,MACD,IAAK,sBACJH,EAAO,kBAAoBG,EAC3B,MACD,IAAK,oBACJH,EAAO,iBAAmB,SAASG,EAAO,EAAE,EAC5C,KACF,EAGGX,IAAc,WACjBQ,EAAO,oBAAsBN,EAC7BM,EAAO,kBAAoBN,EAC3BM,EAAO,iBAAmB,GAChBR,IAAc,YACxBQ,EAAO,kBAAoBN,EAC3BM,EAAO,kBAAoB,GAI7B,IAAMK,EAAiB;AAAA,OACjBd;AAAA,cACOS,EAAO;AAAA,2BACMA,EAAO;AAAA,yBACTA,EAAO;AAAA,uBACTA,EAAO;AAAA,EAGvBM,EAAgBR,IAAwB,GAC3CF,EAAaS,EACbR,EAAS,MAAM,EAAGC,CAAmB,EAAE,KAAK;AAAA,CAAI,EAAIO,EAEpD,gBAAcV,EAAaW,EAAe,OAAO,CACrD,CACA,SAASC,GAA+BC,EAAuB,CAC9D,OAAOA,EACL,MAAM,GAAG,EACT,IAAI,CAACC,EAAMC,IAERD,EAAK,OAAO,CAAC,EAAE,YAAY,EAAIA,EAAK,MAAM,CAAC,EAAE,YAAY,CAE5D,EACA,KAAK,EAAE,CACV,CAEA,SAASE,GAAeH,EAAuB,CAC9C,IAAMI,EAAWJ,EAAM,MAAM,IAAI,EACjC,OAAOI,EAAS,OAAS,EAAIA,EAASA,EAAS,OAAS,CAAC,EAAI,EAC9D,CAEA,SAASC,GAAcC,EAAkC,CACxD,IAAIC,EAAcC,EAClB,GAAI,CACH,IAAMC,EAAc,KAAK,MACxBC,GACC,mDAAmDJ,IACnD,CACC,SAAU,QACV,MAAO,MACR,CACD,CACD,EACAC,EAAUE,EAAY,QACtBD,EAAeC,EAAY,aAC3B,QAAQ,IAAI,iCAAuB,CACpC,OAASE,EAAP,CACD,QAAQ,MAAMC,EAAM,IAAI,6BAAmB,CAAC,EAC5C,QAAQ,MAAMD,EAAM,MAAM,EAC1B,QAAQ,KAAK,CAAC,CACf,CACA,MAAO,CAACJ,EAASC,CAAY,CAC9B,CAEA,eAAeK,GACdC,EACAC,EACAC,EACAC,EACAX,EACC,CACD,IAAMY,EAAgB,MAAMC,GAAiBF,CAAO,EACpD,QAAQ,IAAI,gBAAiBC,CAAa,EAC1C,IAAMjC,EAAU,MAAM6B,EAAO,mBAAmB,EAChDM,GAAiB,GAAGd,cAAyBW,CAAO,EACpD,QAAQ,IAAI;AAAA,2CAAuC,EACnD,QAAQ,IAAI,2BAAiBX,GAAa,EAC1C,QAAQ,IAAI,2BAAiBW,GAAS,EACtC,QAAQ,IAAI,2BAAiBhC,GAAS,EACtC,QAAQ,IAAI,0CAAgC,EAE5C,IAAMoC,EAAUN,EAAM,WAAW,EACjC,QAAQ,IAAI,2BAAiBM,EAAQ,aAAa,GAAG,EAErD,QAAQ,IAAI;AAAA,+BAA2B,EACvC,GAAM,CAACd,EAASC,CAAY,EAAIH,GAAcC,CAAW,EAEzD,QAAQ,IAAI;AAAA,iCAA6B,EACzC,IAAMgB,EAAK,IAAIC,EACT,CAACC,CAAU,EAAIF,EAAG,QAAQ,CAAE,QAAAf,EAAS,aAAAC,CAAa,CAAC,EACzDc,EAAG,gBAAgB,CAACE,CAAU,EAAGH,EAAQ,aAAa,CAAC,EAEvD,IAAII,EACJ,GAAI,CACHA,EAAS,MAAMX,EAAO,0BAA0B,CAC/C,OAAQO,EACR,YAAaC,EACb,QAAS,CAAE,kBAAmB,EAAK,CACpC,CAAC,CACF,OAASX,EAAP,CACD,QAAQ,MAAMC,EAAM,IAAI,mCAAyB,CAAC,EAClD,QAAQ,MAAMD,EAAM,OAAO,EAC3B,QAAQ,KAAK,CAAC,CACf,CAEIc,EAAO,SAAS,OAAO,SAAW,YACrC,QAAQ,IAAIb,EAAM,IAAI,mCAAyB,CAAC,EAChD,QAAQ,KAAK,CAAC,GAGf,QAAQ,IAAI,kDAAwC,EACpD,IAAIc,EAAU,EACVC,EAAY,GACZC,EAAoB,CAAC,EACrBC,EAAe,GACfC,EAAc,GAElBL,EAAO,cAAe,IAAIM,GAAU,CAC/BA,EAAO,OAAS,cACnB,QAAQ,IAAI,8BAAoBA,EAAO,WAAW,EAClDJ,EAAYI,EAAO,WAGnBA,EAAO,OAAS,WAChBA,EAAO,aAAe,6BAEtB,QAAQ,IAAI,+BAAqBA,EAAO,UAAU,EAClDF,EAAeE,EAAO,UAGtBA,EAAO,OAAS,WAChBA,EAAO,WAAW,SAAS,YAAY,IAEvC,QAAQ,IAAI,8BAAoBA,EAAO,UAAU,EACjDD,EAAcC,EAAO,SAEvB,CAAC,EAED,QAAQ,IAAI,+BAAqBN,EAAO,QAAQ,EAEhD5C,GAAc,GAAGyB,cAAyBW,EAAS,UAAWhC,EAAS0C,CAAS,EAEhF,QAAQ,IAAI;AAAA,gCAA8B,EAC1C,MAAMK,EAAM,GAAI,EAEhB,IAAMC,EAAe,IAAIV,EACzBU,EAAa,aAAa,GAAU,EACpC,GAAM,CAACC,CAAM,EAAID,EAAa,WAAWA,EAAa,IAAK,CAAC,YAAY,CAAC,EACzEA,EAAa,SAAS,CACrB,OAAQ,GAAGN,sBACX,UAAW,CACVM,EAAa,OAAOH,CAAW,EAC/BG,EAAa,OAAOf,CAAa,EACjCe,EAAa,OAAOJ,CAAY,EAChCI,EAAa,OAAO,KAAK,EACzBC,CACD,CACD,CAAC,EAED,IAAIC,EACJ,GAAI,CACHA,EAAmB,MAAMrB,EAAO,0BAA0B,CACzD,OAAQO,EACR,YAAaY,EACb,QAAS,CAAE,YAAa,GAAM,kBAAmB,EAAK,CACvD,CAAC,CACF,OAAStB,EAAP,CACD,QAAQ,MAAMC,EAAM,IAAI,6CAAmC,CAAC,EAC5D,QAAQ,MAAMD,EAAM,OAAO,EAC3B,QAAQ,KAAK,CAAC,CACf,CAEIwB,EAAiB,SAAS,OAAO,SAAW,WAC/C,QAAQ,IAAI,0CAAgC,EAC5C,QAAQ,IAAI,+BAAqBA,EAAiB,QAAQ,EAE1D,QAAQ,IAAI;AAAA,2BAAuB,EACnCA,EAAiB,eAAe,IAAIJ,GAAU,CAC7C,GACCA,EAAO,OAAS,WAChBA,EAAO,WAAW,SAAS,SAAS,GAAK,CAACA,EAAO,WAAW,SAAS,eAAe,EACnF,CACD,QAAQ,IAAI,kBAAQA,EAAO,YAAY,EACvC,QAAQ,IAAI,yBAAeA,EAAO,UAAU,EAE5C,IAAIK,EAAoC,CAAC,EACzC,QAASC,KAAarB,EAAY,QAC7BjB,GAA+BsC,CAAS,IAAMlC,GAAe4B,EAAO,UAAU,IACjFK,EAAYpB,EAAY,QAAQqB,CAAS,EAAE,WAI7CT,EAAQ,KAAK,CACZ,KAAMG,EAAO,WACb,SAAUA,EAAO,SACjB,UAAAK,CACD,CAAC,EAEH,CAAC,EAEDE,EACCtB,EAAY,KACZC,EACAU,EACAE,EACAC,EACAJ,EACAE,CACD,EACA,QAAQ,IAAI;AAAA;AAAA,CAAqC,IAEjD,QAAQ,IAAIhB,EAAM,OAAO,6CAAmC,CAAC,EAC7D,QAAQ,IACPA,EAAM,OACL,yDACD,CACD,EAEF,CAEA,eAAsB2B,EACrBzB,EACAC,EACAE,EACC,CAED,IAAMX,EAAc,GADP,QAAQ,IAAI,8BAEnBrB,EAAU,MAAM6B,EAAO,mBAAmB,EAChD,QAAQ,IAAI,4BAAkB7B,GAAS,EACvCmC,GAAiB,GAAGd,cAAyBW,CAAO,EACpD,QAAQ,IAAI;AAAA,2CAAuC,EACnD,QAAQ,IAAI,2BAAiBX,GAAa,EAC1C,QAAQ,IAAI,2BAAiBW,GAAS,EACtC,QAAQ,IAAI,2BAAiBhC,GAAS,EACtC,QAAQ,IAAI,0CAAgC,EAE5C,IAAMoC,EAAUN,EAAM,WAAW,EACjC,QAAQ,IAAI,2BAAiBM,EAAQ,aAAa,GAAG,EAGrD,QAAQ,IAAI;AAAA,+BAA2B,EACvC,GAAM,CAACd,EAASC,CAAY,EAAIH,GAAcC,CAAW,EAEzD,QAAQ,IAAI;AAAA,iCAA6B,EACzC,IAAMgB,EAAK,IAAIC,EACT,CAACC,CAAU,EAAIF,EAAG,QAAQ,CAAE,QAAAf,EAAS,aAAAC,CAAa,CAAC,EACzDc,EAAG,gBAAgB,CAACE,CAAU,EAAGH,EAAQ,aAAa,CAAC,EAEvD,IAAII,EACJ,GAAI,CACHA,EAAS,MAAMX,EAAO,0BAA0B,CAC/C,OAAQO,EACR,YAAaC,EACb,QAAS,CAAE,kBAAmB,EAAK,CACpC,CAAC,CACF,OAASX,EAAP,CACD,QAAQ,MAAMC,EAAM,IAAI,mCAAyB,CAAC,EAClD,QAAQ,MAAMD,EAAM,OAAO,EAC3B,QAAQ,KAAK,CAAC,CACf,CAEIc,EAAO,SAAS,OAAO,SAAW,YACrC,QAAQ,IAAIb,EAAM,IAAI,mCAAyB,CAAC,EAChD,QAAQ,KAAK,CAAC,GAGf,QAAQ,IAAI,kDAAwC,EACpD,IAAIc,EAAU,EACVC,EAAY,GACZC,EAAoB,CAAC,EACrBC,EAAe,GACfC,EAAc,GAElBL,EAAO,cAAe,IAAIM,GAAU,CAC/BA,EAAO,OAAS,cACnB,QAAQ,IAAI,8BAAoBA,EAAO,WAAW,EAClDJ,EAAYI,EAAO,WAGnBA,EAAO,OAAS,WAChBA,EAAO,aAAe,6BAEtB,QAAQ,IAAI,+BAAqBA,EAAO,UAAU,EAClDF,EAAeE,EAAO,UAGtBA,EAAO,OAAS,WAChBA,EAAO,WAAW,SAAS,OAAO,IAElC,QAAQ,IAAI,yBAAeA,EAAO,UAAU,EAC5CD,EAAcC,EAAO,SAEvB,CAAC,EAED,QAAQ,IAAI,+BAAqBN,EAAO,QAAQ,EAEhD5C,GAAc,GAAGyB,cAAyBW,EAAS,UAAWhC,EAAS0C,CAAS,EAEhFW,EACC,kBACArB,EACAU,EACAE,EACAC,EACAJ,EACAE,CACD,CACD,CAEA,eAAsBY,GACrBxB,EACAC,EACAwB,EACC,CACD,MAAMC,EAAUzB,CAAO,EAEvB,IAAM0B,EAAa,QAAQ,IAAI,YAC/B,GAAI,CAACA,EACJ,MAAM,IAAIC,EACT;AAAA;AAAA,gEAGD,EAED,IAAMC,EAAmBC,EAAmBH,CAAU,EACtD,GAAIE,IAAqB,GACxB,MAAM,IAAID,EAAc,+BAA+B,EAGxD,IAAM7B,EAAQ,IAAIgC,GAAM,CAAE,UAAWF,CAAiB,CAAC,EACjD/B,EAAS,IAAIkC,GAAU,CAAE,IAAKC,GAAehC,CAAO,CAAE,CAAC,EAE7D,GAAIwB,GAAgB,kBACnB,MAAMF,EAAsBzB,EAAQC,EAAOE,CAAO,MAC5C,CAEN,IAAMX,EAAc,GADP,QAAQ,IAAI,eACgBU,EAAY,OACrDkC,EAAsB,GAAG5C,cAAyBW,CAAO,EACzD,MAAMJ,GAAgBC,EAAQC,EAAOC,EAAaC,EAASX,CAAW,EAExE,CFlbA,OAAS,SAAA6C,OAAa,wBACtB,OAAS,kBAAAC,GAAgB,aAAAC,OAAiB,qBAE1C,SAASC,IAA6B,CACrC,GAAI,CACH,IAAMC,EACL,QAAQ,WAAa,QAClB,kDACA,uBAEEC,EAASC,GAASF,CAAG,EAAE,SAAS,EAAE,KAAK,EAC7C,OAAO,QAAQ,WAAa,QACzBC,EAAO,YAAY,EAAE,SAAS,SAAS,EACvCA,EAAO,OAAS,CACpB,MAAE,CACD,MAAO,EACR,CACD,CAEA,eAAeE,IAAgB,CAE9B,IAAMC,EAAc,CACnB,yEACA,yEACA,yEACA,yEACA,yEACA,wEACD,EACA,QAAQ,IAAI,mBAAY,EACxB,QAAQ,IAAI,YAAY,EACxBA,EAAY,QAAQ,CAACC,EAAYC,IAAU,CAE1C,IAAMC,EADQ,IAAIX,GAAM,CAAE,UAAWS,CAAW,CAAC,EAC3B,WAAW,EACjCG,GACC,OACA,CAAC,aAAc,YAAa,OAAQ,4BAA6B,WAAY,iCAAkC,aAAc,yCAAyCD,EAAQ,aAAa,MAAM,EACjM,CACC,IAAK,CAAE,GAAG,QAAQ,GAAI,EACtB,MAAO,SACP,SAAU,EACX,CACA,EACD,QAAQ,IAAI,2BAAiBD,MAAUC,EAAQ,aAAa,aAAa,EACzE,QAAQ,IAAI,+BAAqBF,GAAY,CAC9C,CAAC,EACD,QAAQ,IAAI,YAAY,EACxB,QAAQ,IAAII,EAAM,OAAO,kFAAwE,CAAC,EAClG,QAAQ,IAAIA,EAAM,OAAO,2EAA2E,CAAC,CACtG,CACC,eAAsBC,IAAiB,CACvC,GAAIX,GAAkB,EAAG,CACxB,QAAQ,IAAIU,EAAM,OAAO;AAAA,kDAA2C,CAAC,EACrE,QAAQ,IAAIA,EAAM,OAAO,4CAAkC,CAAC,EAC5D,QAAQ,IACPA,EAAM,OAAO,uDAA6C,CAC3D,EACA,OAGDE,EAAW,EACX,QAAQ,IAAI,kCAA2B,EACvC,GAAI,CACH,IAAMC,EAAaJ,GAClB,MACA,CAAC,QAAS,gBAAiB,mBAAmB,EAC9C,CACC,IAAK,CAAE,GAAG,QAAQ,IAAK,SAAU,mBAAoB,EACrD,MAAO,SACP,SAAU,EACX,CACD,EAEAI,EAAW,GAAG,QAASC,GAAS,CAC/B,QAAQ,MAAMJ,EAAM,IAAI;AAAA,kCAAgC,CAAC,EACzD,QAAQ,MAAMA,EAAM,IAAI,yBAAeI,EAAM,SAAS,CAAC,CACxD,CAAC,EACD,MAAMC,EAAM,GAAI,EAChB,QAAQ,IAAI,gCAAsB,EAClC,QAAQ,IAAI,qCAA2B,EACvC,QAAQ,IAAI,oDAA0C,EACtD,QAAQ,IAAI,sDAA4C,EAExD,MAAMX,GAAc,EAEpB,MAAMW,EAAM,GAAI,EAEhB,IAAMC,EAAmBC,EAAmB,wEAAwE,EACpH,GAAID,IAAqB,GACxB,MAAM,IAAIE,EAAc,+BAA+B,EAGxD,IAAMC,EAAQ,IAAItB,GAAM,CAAE,UAAWmB,CAAiB,CAAC,EACjDI,EAAS,IAAIrB,GAAU,CAAE,IAAKD,GAAe,UAAU,CAAE,CAAC,EAC1DuB,EAAc,QAAQ,IAE5B,QAAQ,IAAM,IAAM,CAAC,EACrB,MAAMC,EAAsBF,EAAQD,EAAO,UAAU,EACrD,QAAQ,IAAME,EAEd,QAAQ,GAAG,SAAU,IAAM,CAC1B,QAAQ,IAAIX,EAAM,OAAO;AAAA,iCAA6B,CAAC,EACnDG,IACHA,EAAW,KAAK,EAChB,QAAQ,IAAIH,EAAM,MAAM,2BAAsB,CAAC,GAEhD,QAAQ,KAAK,CACd,CAAC,CACF,OAASI,EAAP,CACD,QAAQ,MAAMJ,EAAM,IAAI;AAAA,kCAAgC,CAAC,EACzD,QAAQ,MAAMA,EAAM,IAAI,yBAAeI,EAAM,SAAS,CAAC,CACxD,CACD,CKjHA,IAAMS,GAA+B,CACpC,QAAS,OAET,SAAU,wBAEV,QAAQC,EAAO,CACd,OAAOA,CACR,EAEA,MAAM,SAAU,CACf,GAAI,CACH,MAAMC,GAAe,CACtB,OAASC,EAAP,CACD,QAAQ,MAAM,2BAA4BA,CAAK,EAC/C,QAAQ,KAAK,CAAC,CACf,CACD,CACD,EAEOC,GAAQJ,GCtBf,OAAS,SAAAK,OAAa,wBAEtB,OAAS,0BAAAC,GAAwB,iBAAAC,OAAqB,qBACtD,OACC,aAAAC,GACA,kBAAAC,OAEM,qBAQP,IAAMC,GAAiD,CACtD,QAAS,SAET,SAAU,+BAEV,QAAQC,EAAO,CACd,OAAOA,EAAM,QAAQ,CACpB,QAAS,CACR,KAAM,SACN,KAAM,0BACN,QAAS,CAAC,UAAW,SAAU,UAAU,EACzC,QAAS,UACV,EACA,UAAW,CACV,KAAM,SACN,KAAM,qBACP,CACD,CAAC,CACF,EAEA,MAAM,QAAQ,CAAE,QAAAC,EAAS,UAAAC,CAAU,EAAG,CACrC,IAAIC,EAAiB,GACrB,GAAID,IAAc,OAAW,CAC5B,IAAME,EAAa,QAAQ,IAAI,YAC/B,GAAI,CAACA,EACJ,MAAM,IAAIC,EACT;AAAA;AAAA,oEAGD,EAED,IAAMC,EAAmBC,EAAmBH,CAAU,EACtD,GAAIE,IAAqB,GACxB,MAAM,IAAID,EAAc,gCAAgC,EAMzDF,EAJc,IAAIK,GAAM,CACvB,UAAWF,CACZ,CAAC,EACqB,WAAW,EACR,aAAa,OAEtCH,EAAiBD,EAGlB,QAAQ,IAAI;AAAA,uCAAmC,EAC/C,QAAQ,IAAI,2BAAiBD,GAAS,EAElCC,IAAc,QACjB,QAAQ,IAAI,6CAAmC,EAC/C,QAAQ,IAAI,qCAA2BC,GAAgB,GAEvD,QAAQ,IAAI,0CAAgCA,GAAgB,EAG7D,QAAQ,IAAI,gDAAsC,EAClD,MAAMM,GAAuB,CAC5B,KAAMC,GAAcT,CAAO,EAC3B,UAAWE,CACZ,CAAC,EAED,QAAQ,IAAI,oCAA0B,EACtC,IAAMQ,EAAS,IAAIC,GAAU,CAAE,IAAKC,GAAeZ,CAAO,CAAE,CAAC,EACzDa,EAAS,CACZ,MAAOX,CACR,EAEMY,EAAU,MAAMJ,EAAO,WAAWG,CAAM,EAE9C,QAAQ,IAAI;AAAA,0BAAsB,EAClC,QAAQ,IAAI,2BAAiBX,GAAgB,EAC7C,QAAQ,IACP,4BACC,OAAOY,EAAQ,YAAY,EAAI,KAC9B,QAAQ,CAAC,OACZ,EAEA,QAAQ,IAAI;AAAA;AAAA,CAAiC,EAC7C,QAAQ,KAAK,CAAC,CACf,CACD,EAEOC,GAAQjB,GC/Ff,OAAS,aAAAkB,GAAW,cAAAC,OAA+B,wBACnD,OAAOC,OAAW,QAQlB,IAAMC,GAAiD,CACtD,QAAS,YAET,SAAU,sDAEV,QAAS,CACR,cAAe,CACd,KAAM,SACN,QAAS,kBACT,KAAM,yBACP,EACA,QAAS,CACR,KAAM,SACN,QAAS,CAAC,UAAW,UAAW,SAAU,UAAU,EACpD,KAAM,gDACP,EACA,eAAgB,CACf,KAAM,SACN,KAAM,sBACP,CACD,EAEA,MAAM,QAAQ,CACb,cAAeC,EACf,QAAAC,EACA,eAAgBC,CACjB,EAAG,CACF,GAAI,CACH,IAAMC,EAAe,MAAMN,GAAWG,CAAU,EAChD,MAAMJ,GAAUO,EAAa,OAAWF,EAASC,CAAW,EAC5D,QAAQ,KAAK,CAAC,CACf,OAASE,EAAP,CACD,QAAQ,IAAIN,GAAM,IAAI,mBAAmB,CAAC,EAC1C,QAAQ,MAAMM,EAAM,OAAO,CAC5B,CACD,CACD,EAEOC,GAAQN,GC7Cf,OAAS,cAAAO,OAA+B,wBAQxC,IAAMC,GAAiD,CACtD,QAAS,UAET,SAAU,8BAEV,QAAQC,EAAO,CACd,OAAOA,EAAM,QAAQ,CACpB,QAAS,CACR,KAAM,SACN,QAAS,CAAC,UAAW,UAAW,SAAU,UAAU,EACpD,KAAM,gDACP,EACA,cAAe,CACd,KAAM,SACN,QAAS,kBACT,KAAM,yBACP,EACA,gBAAiB,CAChB,KAAM,SACN,KAAM,gDACP,CACD,CAAC,CACF,EAEA,MAAM,QAAQ,CACb,QAAAC,EACA,cAAeC,EACf,gBAAiBC,CAClB,EAAG,CACF,GAAI,CACH,IAAMC,EAAe,MAAMN,GAAWI,CAAU,EAChD,MAAMG,GAAeD,EAAaH,EAASE,CAAY,CACxD,OAASG,EAAP,CACDC,EAASD,CAAK,EACd,QAAQ,KAAK,CAAC,CACf,CACA,QAAQ,KAAK,CAAC,CACf,CACD,EAEOE,GAAQT,GCnDf,OAAS,SAAAU,OAAa,wBACtB,OAAS,eAAAC,GAAa,iBAAAC,OAAqB,2BAC3C,OAAS,kBAAAC,GAAgB,aAAAC,OAAiB,qBAC1C,OAAS,YAAAC,OAAgB,gBACzB,OAAOC,MAAW,QAUlB,UAAYC,MAAQ,KACpB,UAAYC,OAAU,OAoBtB,SAASC,GAAoBC,EAAqBC,EAA+B,CAChFA,EAAW,QAASC,GAAc,CACjC,IAAIC,EAAW,GAAGH,6BAAuCE,EAAU,kBAC7DE,EAAiB,eAAaD,EAAU,OAAO,EAC/CE,EAAqB,IAAI,OAAO,yBAAyBH,EAAU,oBAAoBI,EAA+BJ,EAAU,UAAU,iCAAiC,EAC3KK,EAAmB;AAAA,qBACNL,EAAU,oBAAoBI,EAA+BJ,EAAU,UAAU;AAAA,EACpGA,EAAU,OAAO,IAAKM,GAAU,CAC/B,IAAIC,EAAe,GACnB,OAAID,EAAM,KAAK,SAAS,cAAc,EACrCC,EAAe,uBACLD,EAAM,KAAK,SAAS,YAAY,EAC1CC,EAAe,qBAEfD,EAAM,KAAK,SAAS,kBAAkB,IAEtCC,EAAe,6BAET,8BAA8BD,EAAM,cAAcN,EAAU,oBAAoBM,EAAM,UAAUC,KACxG,CAAC,EAAE,KAAK,EAAE;AAAA;AAAA,EAIJC,EAAiBN,EAAY,QAAQC,EAAoBE,CAAgB,EAC5E,gBAAcJ,EAAUO,EAAgB,OAAO,CACnD,CAAC,CAGF,CAEA,SAASJ,EAA+BK,EAAuB,CAC9D,OAAOA,EACL,MAAM,GAAG,EACT,IAAI,CAACC,EAAMC,IAERD,EAAK,OAAO,CAAC,EAAE,YAAY,EAAIA,EAAK,MAAM,CAAC,EAAE,YAAY,CAE5D,EACA,KAAK,EAAE,CACV,CAEA,SAASE,GAAeH,EAAuB,CAC9C,IAAMI,EAAWJ,EAAM,MAAM,IAAI,EACjC,OAAOI,EAAS,OAAS,EAAIA,EAASA,EAAS,OAAS,CAAC,EAAI,EAC9D,CAEA,SAASC,EACRb,EACAc,EACAT,EACAU,EACS,CACT,IAAMC,EAAmB,WAAQhB,CAAQ,EAEnCiB,EADgB,eAAaD,EAAa,OAAO,EAC3B,MAAM;AAAA,CAAI,EAEhCE,EAAsBD,EAAS,UAAUE,GAAQA,EAAK,KAAK,IAAM,QAAQL,IAAc,EAC7F,GAAII,IAAwB,GAC3B,eAAQ,IAAI,qBAAqBJ,2BAAqC,EAC/D,GAGR,IAAIM,EAAa,GACbC,EAAwB,GAC5B,QAASC,EAAIJ,EAAsB,EAAGI,EAAIL,EAAS,OAAQK,IAAK,CAC/D,IAAMH,EAAOF,EAASK,CAAC,EAAE,KAAK,EAC9B,GAAIH,EAAK,WAAW,GAAG,EAAG,MAE1B,GAAIA,EAAK,WAAWd,CAAK,EAAG,CAC3Be,EAAaE,EACbD,EAAgBF,EAAK,MAAM,GAAG,EAAE,CAAC,EAAE,KAAK,EAAE,QAAQ,KAAM,EAAE,EAC1D,OAIF,GAAIC,IAAe,GAAI,CACtBH,EAASG,CAAU,EAAI,GAAGf,QAAYU,KACtC,IAAMQ,EAAgBN,EAAS,KAAK;AAAA,CAAI,EACrC,gBAAcD,EAAaO,EAAe,OAAO,OAEpD,QAAQ,IAAI,GAAGlB,wBAA4BS,KAAe,EAG3D,OAAOO,CACR,CACA,eAAsBG,GACrBC,EACAC,EACAC,EACC,CACD,MAAMC,EAAUD,CAAO,EAEvB,IAAMhC,EAAO,QAAQ,IAAI,EACnBE,EAAc,GAAGF,eAAkB+B,IACnCG,EAAa,QAAQ,IAAI,YAC/B,GAAI,CAACA,EACJ,MAAM,IAAIC,EACT;AAAA;AAAA,gEAGD,EAED,IAAMC,EAAmBC,EAAmBH,CAAU,EACtD,GAAIE,IAAqB,GACxB,MAAM,IAAID,EAAc,+BAA+B,EAKxD,IAAMG,EAHQ,IAAIC,GAAM,CACvB,UAAWH,CACZ,CAAC,EACqB,WAAW,EAE3BI,EAAS,IAAIC,GAAU,CAC5B,IAAKC,GAAeV,CAAO,CAC5B,CAAC,EAEGW,EAAa,OAAO,MAAMC,EAAW1C,EAAa8B,CAAO,CAAC,EAC1Da,EAAe,MAAMC,GAAgB5C,EAAa8B,CAAO,EACzDe,EAAY,MAAMC,EAAa9C,EAAa8B,CAAO,EACnDiB,EAAa,MAAMC,GAAchD,EAAa8B,CAAO,EAEnDmB,EAAyBjC,EAAgB,GAAGhB,cAAyB8B,EAAS,wBAAyB,oEAAoE,EAE7KoB,EAAgC,CAAC,EACjCC,EAAU,MAAMC,EAAkBpD,EAAa8B,CAAO,EAC1D,QAASuB,KAAazB,EAAO,QAC5BuB,EAAQ,QAASG,GAAW,CAC3B,GAAIhD,EAA+B+C,CAAS,GAAKvC,GAAewC,EAAO,IAAI,EAAG,CAC7E,IAAIC,EAAqB,CAAE,WAAY,GAAI,OAAQ,CAAC,CAAE,EAClDC,EAAkB,CAAC,EACnBC,EAAc,GAClB,QAAWC,KAAO9B,EAAO,QAAQyB,CAAS,EAAE,UACrCK,KAAOJ,EAAO,YACnBG,EAAc,GACdD,EAAO,KAAK,CACX,KAAME,EACN,KAAM9B,EAAO,QAAQyB,CAAS,EAAE,UAAUK,CAAG,CAC9C,CAAC,EACDJ,EAAO,UAAUI,CAAG,EAAI9B,EAAO,QAAQyB,CAAS,EAAE,UAAUK,CAAG,GAG7DD,IACHF,EAAQ,WAAaF,EACrBE,EAAQ,OAASC,EACjBN,EAAiB,KAAKK,CAAO,GAGhC,CAAC,EAIFL,EAAiB,QAAShD,GAAc,CACvC,QAAQ,IAAI;AAAA,mCAA+BA,EAAU,eAAe,EACpE,QAAQ,IAAI,8BAAwBA,EAAU,MAAM,CACrD,CAAC,EACDH,GAAoBC,EAAakD,CAAgB,EAEjD,GAAI,CACH,IAAIS,EAAcC,EAAmBC,EACrC,GAAI,CACH,GAAM,CACL,QAASC,EACT,aAAcC,GACd,OAAQC,EACT,EAAI,KAAK,MACRC,GACC,mDAAmDnE,eAAkB+B,IACrE,CACC,SAAU,OACX,CACD,CACD,EAEA8B,EAAUG,EACVF,EAAeG,GACfF,EAASG,EACV,OAASE,EAAP,CACD,MAAM,IAAIC,EAAaD,EAAM,MAAM,CACpC,CAEA,QAAQ,IAAI;AAAA,sCAAkC,EAC9C,QAAQ,IAAI,0BAAoBvB,CAAY,EAC5C,QAAQ,IAAI,kCAA4BI,CAAU,EAClD,QAAQ,IAAI,wBAAkBN,CAAU,EAExC,IAAM2B,EAAK,IAAIC,GACTC,EAASF,EAAG,SAAS,CAC1B,OAAQ,kCACR,UAAW,CACVA,EAAG,OAAOrB,CAAU,EACpBqB,EAAG,KAAK,GAAGG,GAAc,UAAU,EACnCH,EAAG,KAAK,OAAO,KAAMP,CAAM,CAC5B,CACD,CAAC,EAEKW,EAAUJ,EAAG,QAAQ,CAC1B,QAAAT,EACA,aAAAC,EACA,QAASjB,EACT,OAAA2B,CACD,CAAC,EAEDF,EAAG,SAAS,CACX,OAAQ,+BACR,UAAW,CAACA,EAAG,OAAOrB,CAAU,EAAGyB,CAAO,CAC3C,CAAC,EAED,IAAMC,EAAS,MAAMnC,EAAO,0BAA0B,CACrD,OAAQF,EACR,YAAagC,EACb,QAAS,CACR,kBAAmB,EACpB,CACD,CAAC,EAEGM,EAAe,GACnBD,EAAO,cAAe,IAAIE,GAAU,CAC/BA,EAAO,OAAS,cACnB,QAAQ,IACPC,EAAM,KAAK,GAAG/C,gBAAmB8C,EAAO,WAAW,CACpD,EACA,QAAQ,IACPC,EAAM,KAAK,GAAG/C,cAAiBY,EAAa,GAAG,CAChD,EACAiC,EAAeC,EAAO,UAExB,CAAC,EAED3D,EAAgB,GAAGhB,cAAyB8B,EAAS,wBAAyBmB,CAAqB,EACnGjC,EAAgB,GAAGhB,cAAyB8B,EAAS,sBAAuB4C,CAAY,EACxF1D,EAAgB,GAAGhB,cAAyB8B,EAAS,oBAAsBW,EAAa,EAAK,EAAE,EAE/F,QAAQ,IACPmC,EAAM,MAAM,+BAA+BH,EAAO,QAAQ,CAC3D,EAEAI,EACChD,EACAC,EACA4C,EACA3B,EACAF,EACAJ,EAAa,EACbU,CACD,CAED,OAASe,EAAP,CACD,QAAQ,IAAIU,EAAM,IAAI,iBAAiB,CAAC,EACxC,QAAQ,MAAMV,EAAM,OAAO,CAC5B,CACD,CCzRA,OAAsB,cAAAY,OAAkB,wBAOxC,IAAMC,GAAiD,CACtD,QAAS,UAET,SAAU,8BAEV,QAAQC,EAAO,CACd,OAAOA,EAAM,QAAQ,CACpB,QAAS,CACR,KAAM,SACN,QAAS,CAAC,UAAW,UAAW,SAAU,UAAU,EACpD,KAAM,uDACP,EACA,cAAe,CACd,KAAM,SACN,QAAS,kBACT,KAAM,yBACP,CACD,CAAC,CACF,EAEA,MAAM,QAAQ,CAAE,QAAAC,EAAS,cAAeC,CAAW,EAAG,CACrD,GAAI,CACH,IAAMC,EAAe,MAAML,GAAWI,CAAU,EAChD,MAAME,GAAeD,EAAaA,EAAY,KAAMF,CAAO,CAC5D,OAASI,EAAP,CACDC,EAASD,CAAK,EACd,QAAQ,KAAK,CAAC,CACf,CACA,QAAQ,KAAK,CAAC,CACf,CACD,EAEOE,GAAQR,GCzCf,OAAS,YAAAS,OAAgB,gBACzB,OAAOC,OAAW,QAClB,OAAsB,cAAAC,OAAkB,wBAOxC,IAAMC,GAAiD,CACrD,QAAS,OAET,SAAU,+BAEV,QAAQC,EAAO,CACb,OAAOA,EAAM,QAAQ,CACnB,cAAe,CACb,KAAM,SACN,QAAS,kBACT,YAAa,+BACf,EACA,KAAM,CACJ,KAAM,SACN,KAAM,qBACR,CACF,CAAC,CACH,EAEA,MAAM,QAAQ,CAAE,cAAeC,EAAY,KAAAC,CAAK,EAAG,CAEjD,GAAI,CACF,QAAQ,IAAI,6BAAsB,EAClC,IAAMC,EAAe,MAAML,GAAWG,CAAU,EAG1CG,EAAU,wBADI,GADP,QAAQ,IAAI,eACgBD,EAAY,UACED,EAAO,WAAWA,IAAS,KAC5EG,EAAUT,GAASQ,EAAS,CAAE,SAAU,OAAQ,CAAC,EACvD,QAAQ,IAAIC,CAAM,CACpB,OAASC,EAAP,CACA,QAAQ,MAAMT,GAAM,IAAI,gCAAgC,CAAC,EACzD,QAAQ,IAAIS,EAAM,MAAM,EACxB,QAAQ,KAAK,CAAC,CAChB,CACF,CACF,EAEOC,GAAQR,GC9Cf,OAAS,YAAAS,OAAgB,gBACzB,OAAOC,OAAW,QAClB,OAAsB,cAAAC,OAAkB,wBASxC,IAAMC,GAAiD,CACrD,QAAS,QACT,SAAU,+BACV,QAAQC,EAAO,CACb,OAAOA,EAAM,QAAQ,CACnB,cAAe,CACb,KAAM,SACN,QAAS,kBACT,YAAa,+BACf,EACA,QAAS,CACP,KAAM,SACN,QAAS,CAAC,UAAW,UAAW,SAAU,UAAU,EACpD,KAAM,gDACR,EACA,0BAA2B,CACzB,KAAM,UACN,QAAS,GACT,KAAM,yBACR,CACF,CAAC,CACH,EAEA,MAAM,QAAQ,CAAE,cAAeC,EAAY,QAAAC,EAAS,0BAA2BC,CAAqB,EAAG,CAErG,GAAI,CACF,QAAQ,IAAI,8BAAuB,EACnC,IAAMC,EAAe,MAAMC,GAAWJ,CAAU,EAE1CK,EAAc,GADP,QAAQ,IAAI,eACgBF,EAAY,OACrD,MAAMG,EAAUL,CAAO,EACvBM,EAAsBF,EAAY,aAAcJ,CAAO,EACvD,IAAMO,EAAU,yBAAyBH,KAAeH,EAAuB,6BAA+B,KACxGO,EAASC,GAASF,EAAS,CAAE,SAAU,OAAQ,CAAC,EACtD,QAAQ,IAAIC,CAAM,CACpB,OAASE,EAAP,CACA,QAAQ,MAAMC,GAAM,IAAI,iCAAiC,CAAC,EAC1D,QAAQ,IAAID,EAAM,MAAM,EACxB,QAAQ,KAAK,CAAC,CAChB,CACF,CACF,EAEOE,GAAQf,GCpDf,IAAMgB,GAA+B,CACnC,QAAS,QAET,SAAU,eAEV,QAAQC,EAAO,CACb,OAAOA,CACT,EAEA,MAAM,SAAU,CACdC,EAAW,CACb,CACF,EAEOC,GAAQH,GCLR,IAAMI,GAAsC,CAClDC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,GACAC,EACD,EfbA,UAAYC,OAAY,SACxB,OAAOC,OAAW,QACX,UAAO,EAEdC,GAAMC,GAAQ,QAAQ,IAAI,CAAC,EAExB,WAAW,OAAO,EAGlB,QAAQC,EAAe,EAEvB,OAAO,EAEP,KAAK,CAACC,EAAKC,IAAQ,CAClB,QAAQ,MAAML,GAAM,IAAII,CAAG,CAAC,EACxBA,EAAI,SAAS,2BAA2B,GAC1C,QAAQ,IACNJ,GAAM,OAAO,mBAAmB,QAAQ,KAAK,CAAC,2DAA2D,CAC3G,EAEF,QAAQ,IAAI,EAAE,EACdM,EAASD,CAAG,EACZ,QAAQ,IAAI,EAAE,EAEd,QAAQ,KAAK,CAAC,CAChB,CAAC,EAEA,MAAM,CAAE,EAAG,MAAO,CAAC,EAAE","names":["yargs","hideBin","execSync","spawn","chalk","chalk","printDubhe","Dubhe","Transaction","getFullnodeUrl","SuiClient","execSync","chalk","chalk","ZodError","fromZodError","ValidationError","NotInsideProjectError","DubheCliError","UpgradeError","FsIibError","logError","error","validationError","fsAsync","mkdirSync","writeFileSync","dirname","SUI_PRIVATE_KEY_PREFIX","fs","chalk","spawn","validatePrivateKey","privateKey","SUI_PRIVATE_KEY_PREFIX","strippedPrivateKey","getDeploymentJson","projectPath","network","data","FsIibError","getOnchainSchemas","getVersion","getOldPackageId","projectPath","network","getDeploymentJson","getUpgradeCap","getSchemaHub","saveContractData","projectName","network","packageId","upgradeCap","schemaHub","version","schemas","DeploymentData","path","storeDeploymentData","writeOutput","output","fullOutputPath","logPrefix","mkdirSync","dirname","writeFileSync","getDubheDependency","updateDubheDependency","filePath","fileContent","newDependency","updatedContent","switchEnv","resolve","reject","suiProcess","spawn","data","chalk","error","code","delay","ms","fs","path","getDappsObjectId","network","getSchemaHub","removeEnvContent","filePath","networkType","content","regex","updatedContent","updateEnvFile","filePath","networkType","operation","chainId","publishedId","envFilePath","envContent","envLines","networkSectionIndex","line","config","i","key","value","part","updatedSection","newEnvContent","capitalizeAndRemoveUnderscores","input","word","index","getLastSegment","segments","buildContract","projectPath","modules","dependencies","buildResult","execSync","error","chalk","publishContract","client","dubhe","dubheConfig","network","dappsObjectId","getDappsObjectId","removeEnvContent","keypair","tx","Transaction","upgradeCap","result","version","packageId","schemas","upgradeCapId","schemaHubId","object","delay","deployHookTx","txCoin","deployHookResult","structure","schemaKey","saveContractData","publishDubheFramework","publishHandler","contractName","switchEnv","privateKey","DubheCliError","privateKeyFormat","validatePrivateKey","Dubhe","SuiClient","getFullnodeUrl","updateDubheDependency","Dubhe","getFullnodeUrl","SuiClient","isSuiStartRunning","cmd","result","execSync","printAccounts","privateKeys","privateKey","index","keypair","spawn","chalk","startLocalNode","printDubhe","suiProcess","error","delay","privateKeyFormat","validatePrivateKey","DubheCliError","dubhe","client","originalLog","publishDubheFramework","commandModule","yargs","startLocalNode","error","localnode_default","Dubhe","requestSuiFromFaucetV0","getFaucetHost","SuiClient","getFullnodeUrl","commandModule","yargs","network","recipient","faucet_address","privateKey","DubheCliError","privateKeyFormat","validatePrivateKey","Dubhe","requestSuiFromFaucetV0","getFaucetHost","client","SuiClient","getFullnodeUrl","params","balance","faucet_default","schemaGen","loadConfig","chalk","commandModule","configPath","network","frameworkId","dubheConfig","error","schemagen_default","loadConfig","commandModule","yargs","network","configPath","contractName","dubheConfig","publishHandler","error","logError","publish_default","Dubhe","Transaction","UpgradePolicy","getFullnodeUrl","SuiClient","execSync","chalk","fs","path","updateMigrateMethod","projectPath","migrations","migration","filePath","fileContent","migrateMethodRegex","capitalizeAndRemoveUnderscores","newMigrateMethod","field","storage_type","updatedContent","input","word","index","getLastSegment","segments","replaceEnvField","networkType","newValue","envFilePath","envLines","networkSectionIndex","line","fieldIndex","previousValue","i","newEnvContent","upgradeHandler","config","name","network","switchEnv","privateKey","DubheCliError","privateKeyFormat","validatePrivateKey","keypair","Dubhe","client","SuiClient","getFullnodeUrl","oldVersion","getVersion","oldPackageId","getOldPackageId","schemaHub","getSchemaHub","upgradeCap","getUpgradeCap","original_published_id","pendingMigration","schemas","getOnchainSchemas","schemaKey","schema","migrate","fields","isMigration","key","modules","dependencies","digest","extractedModules","extractedDependencies","extractedDigest","execSync","error","UpgradeError","tx","Transaction","ticket","UpgradePolicy","receipt","result","newPackageId","object","chalk","saveContractData","loadConfig","commandModule","yargs","network","configPath","dubheConfig","upgradeHandler","error","logError","upgrade_default","execSync","chalk","loadConfig","commandModule","yargs","configPath","test","dubheConfig","command","output","error","test_default","execSync","chalk","loadConfig","commandModule","yargs","configPath","network","dumpBytecodeAsBase64","dubheConfig","loadConfig","projectPath","switchEnv","updateDubheDependency","command","output","execSync","error","chalk","build_default","commandModule","yargs","printDubhe","hello_default","commands","publish_default","localnode_default","faucet_default","schemagen_default","upgrade_default","test_default","build_default","hello_default","dotenv","chalk","yargs","hideBin","commands","msg","err","logError"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@0xobelisk/sui-cli",
3
- "version": "0.5.29",
3
+ "version": "0.5.30",
4
4
  "description": "Tookit for interacting with move eps framework",
5
5
  "keywords": [
6
6
  "sui",
@@ -32,7 +32,7 @@
32
32
  },
33
33
  "dependencies": {
34
34
  "@0xobelisk/sui-client": "^0.5.28",
35
- "@0xobelisk/sui-common": "^0.5.22",
35
+ "@0xobelisk/sui-common": "^0.5.23",
36
36
  "@mysten/sui": "^1.7.0",
37
37
  "chalk": "^5.0.1",
38
38
  "child_process": "^1.0.2",
@@ -0,0 +1,56 @@
1
+ import type { CommandModule } from "yargs";
2
+ import { execSync } from "child_process";
3
+ import chalk from "chalk";
4
+ import { DubheConfig, loadConfig } from '@0xobelisk/sui-common';
5
+ import { switchEnv, updateDubheDependency } from '../utils';
6
+
7
+ type Options = {
8
+ 'config-path': string;
9
+ network: any;
10
+ 'dump-bytecode-as-base64'?: boolean;
11
+ };
12
+
13
+ const commandModule: CommandModule<Options, Options> = {
14
+ command: "build",
15
+ describe: "Run tests in Dubhe contracts",
16
+ builder(yargs) {
17
+ return yargs.options({
18
+ 'config-path': {
19
+ type: "string",
20
+ default: "dubhe.config.ts",
21
+ description: "Options to pass to forge test",
22
+ },
23
+ network: {
24
+ type: 'string',
25
+ choices: ['mainnet', 'testnet', 'devnet', 'localnet'],
26
+ desc: 'Node network (mainnet/testnet/devnet/localnet)',
27
+ },
28
+ 'dump-bytecode-as-base64': {
29
+ type: 'boolean',
30
+ default: false,
31
+ desc: 'Dump bytecode as base64',
32
+ },
33
+ });
34
+ },
35
+
36
+ async handler({ 'config-path': configPath, network, 'dump-bytecode-as-base64': dumpBytecodeAsBase64 }) {
37
+ // Start an internal anvil process if no world address is provided
38
+ try {
39
+ console.log('šŸš€ Running move build');
40
+ const dubheConfig = (await loadConfig(configPath)) as DubheConfig;
41
+ const path = process.cwd();
42
+ const projectPath = `${path}/contracts/${dubheConfig.name}`;
43
+ await switchEnv(network);
44
+ updateDubheDependency(projectPath+'/Move.toml', network);
45
+ const command = `sui move build --path ${projectPath} ${dumpBytecodeAsBase64 ? ` --dump-bytecode-as-base64` : ''}`;
46
+ const output = execSync(command, { encoding: "utf-8" });
47
+ console.log(output);
48
+ } catch (error: any) {
49
+ console.error(chalk.red("Error executing sui move build:"));
50
+ console.log(error.stdout);
51
+ process.exit(0);
52
+ }
53
+ },
54
+ };
55
+
56
+ export default commandModule;
@@ -6,6 +6,7 @@ import schemagen from './schemagen';
6
6
  import publish from './publish';
7
7
  import upgrade from "./upgrade";
8
8
  import test from './test';
9
+ import build from './build';
9
10
  import hello from './hello';
10
11
 
11
12
  // eslint-disable-next-line @typescript-eslint/no-explicit-any -- Each command has different options
@@ -16,5 +17,6 @@ export const commands: CommandModule<any, any>[] = [
16
17
  schemagen,
17
18
  upgrade,
18
19
  test,
20
+ build,
19
21
  hello,
20
22
  ];
@@ -1,45 +1,18 @@
1
1
  import type { CommandModule } from 'yargs';
2
- import { startLocalnode, stopLocalnode, checkLocalNodeStatus } from '../utils';
2
+ import { startLocalNode } from '../utils/startNode';
3
3
 
4
4
  const commandModule: CommandModule = {
5
- command: 'localnode <action>',
5
+ command: 'node',
6
6
 
7
7
  describe: 'Manage local Sui node',
8
8
 
9
9
  builder(yargs) {
10
10
  return yargs
11
- .positional('action', {
12
- describe: 'Action to perform',
13
- choices: ['start', 'stop', 'status', 'restart'],
14
- type: 'string',
15
- demandOption: true,
16
- })
17
- .option('background', {
18
- alias: 'b',
19
- type: 'boolean',
20
- description: 'Run node in background',
21
- default: false,
22
- });
23
11
  },
24
12
 
25
- async handler(argv) {
26
- const { action, background } = argv;
27
-
13
+ async handler() {
28
14
  try {
29
- switch (action) {
30
- case 'start':
31
- await startLocalnode(background as boolean);
32
- break;
33
- case 'stop':
34
- await stopLocalnode();
35
- break;
36
- case 'status':
37
- await checkLocalNodeStatus();
38
- break;
39
- case 'restart':
40
- await restartNode(background as boolean);
41
- break;
42
- }
15
+ await startLocalNode();
43
16
  } catch (error) {
44
17
  console.error('Error executing command:', error);
45
18
  process.exit(1);
@@ -47,11 +20,4 @@ const commandModule: CommandModule = {
47
20
  },
48
21
  };
49
22
 
50
- async function restartNode(background: boolean) {
51
- console.log('Restarting local Sui node...');
52
- await stopLocalnode();
53
- await startLocalnode(background);
54
- console.log('Local node has been restarted');
55
- }
56
-
57
23
  export default commandModule;
@@ -1,9 +1,11 @@
1
1
  import type { CommandModule } from "yargs";
2
2
  import { execSync } from "child_process";
3
3
  import chalk from "chalk";
4
+ import { DubheConfig, loadConfig } from '@0xobelisk/sui-common';
4
5
 
5
6
  type Options = {
6
- packagePath: string;
7
+ 'config-path': string;
8
+ 'test'?: string;
7
9
  };
8
10
 
9
11
  const commandModule: CommandModule<Options, Options> = {
@@ -13,20 +15,28 @@ const commandModule: CommandModule<Options, Options> = {
13
15
 
14
16
  builder(yargs) {
15
17
  return yargs.options({
16
- packagePath: {
18
+ 'config-path': {
17
19
  type: "string",
18
- default: ".",
20
+ default: "dubhe.config.ts",
19
21
  description: "Options to pass to forge test",
20
22
  },
23
+ test: {
24
+ type: 'string',
25
+ desc: 'Run a specific test',
26
+ },
21
27
  });
22
28
  },
23
29
 
24
- async handler({ packagePath }) {
30
+ async handler({ 'config-path': configPath, test }) {
25
31
  // Start an internal anvil process if no world address is provided
26
32
  try {
27
- execSync(`sui move test --path ${packagePath}`, {
28
- encoding: "utf-8",
29
- });
33
+ console.log('šŸš€ Running move test');
34
+ const dubheConfig = (await loadConfig(configPath)) as DubheConfig;
35
+ const path = process.cwd();
36
+ const projectPath = `${path}/contracts/${dubheConfig.name}`;
37
+ const command = `sui move test --path ${projectPath} ${test ? ` --test ${test}` : ''}`;
38
+ const output = execSync(command, { encoding: "utf-8" });
39
+ console.log(output);
30
40
  } catch (error: any) {
31
41
  console.error(chalk.red("Error executing sui move test:"));
32
42
  console.log(error.stdout);
@@ -145,6 +145,7 @@ function buildContract(projectPath: string): string[][] {
145
145
  `sui move build --dump-bytecode-as-base64 --path ${projectPath}`,
146
146
  {
147
147
  encoding: 'utf-8',
148
+ stdio: 'pipe',
148
149
  }
149
150
  )
150
151
  );
@@ -315,7 +316,7 @@ async function publishContract(
315
316
  }
316
317
  }
317
318
 
318
- async function publishDubheFramework(
319
+ export async function publishDubheFramework(
319
320
  client: SuiClient,
320
321
  dubhe: Dubhe,
321
322
  network: 'mainnet' | 'testnet' | 'devnet' | 'localnet',
@@ -0,0 +1,117 @@
1
+ import { execSync, spawn } from 'child_process';
2
+ import chalk from 'chalk';
3
+ import { printDubhe } from './printDubhe';
4
+ import { delay, DubheCliError, publishDubheFramework, validatePrivateKey } from '../utils';
5
+ import { Dubhe } from '@0xobelisk/sui-client';
6
+ import { getFullnodeUrl, SuiClient } from '@mysten/sui/client';
7
+
8
+ function isSuiStartRunning(): boolean {
9
+ try {
10
+ const cmd =
11
+ process.platform === 'win32'
12
+ ? `tasklist /FI "IMAGENAME eq sui.exe" /FO CSV /NH`
13
+ : 'pgrep -f "sui start"';
14
+
15
+ const result = execSync(cmd).toString().trim();
16
+ return process.platform === 'win32'
17
+ ? result.toLowerCase().includes('sui.exe')
18
+ : result.length > 0;
19
+ } catch (error) {
20
+ return false;
21
+ }
22
+ }
23
+
24
+ async function printAccounts() {
25
+ // These private keys are used for testing purposes only, do not use them in production.
26
+ const privateKeys = [
27
+ "suiprivkey1qq3ez3dje66l8pypgxynr7yymwps6uhn7vyczespj84974j3zya0wdpu76v",
28
+ "suiprivkey1qp6vcyg8r2x88fllmjmxtpzjl95gd9dugqrgz7xxf50w6rqdqzetg7x4d7s",
29
+ "suiprivkey1qpy3a696eh3m55fwa8h38ss063459u4n2dm9t24w2hlxxzjp2x34q8sdsnc",
30
+ "suiprivkey1qzxwp29favhzrjd95f6uj9nskjwal6nh9g509jpun395y6g72d6jqlmps4c",
31
+ "suiprivkey1qzhq4lv38sesah4uzsqkkmeyjx860xqjdz8qgw36tmrdd5tnle3evxpng57",
32
+ "suiprivkey1qzez45sjjsepjgtksqvpq6jw7dzw3zq0dx7a4sulfypd73acaynw5jl9x2c",
33
+ ]
34
+ console.log("šŸ“Accounts")
35
+ console.log("==========")
36
+ privateKeys.forEach((privateKey, index) => {
37
+ const dubhe = new Dubhe({ secretKey: privateKey });
38
+ const keypair = dubhe.getKeypair();
39
+ spawn(
40
+ 'curl',
41
+ ['--location', '--request', 'POST', 'http://127.0.0.1:9123/gas', '--header', 'Content-Type: application/json', '--data-raw', `{"FixedAmountRequest": {"recipient": "${keypair.toSuiAddress()}"}}`],
42
+ {
43
+ env: { ...process.env },
44
+ stdio: 'ignore',
45
+ detached: true,
46
+ }
47
+ )
48
+ console.log(` ā”Œā”€ Account #${index}: ${keypair.toSuiAddress()}(1000 SUI)`);
49
+ console.log(` └─ Private Key: ${privateKey}`);
50
+ });
51
+ console.log("==========")
52
+ console.log(chalk.yellow("āš ļøWARNING: These accounts, and their private keys, are publicly known."));
53
+ console.log(chalk.yellow("Any funds sent to them on Mainnet or any other live network WILL BE LOST."));
54
+ }
55
+ export async function startLocalNode() {
56
+ if (isSuiStartRunning()) {
57
+ console.log(chalk.yellow('\nāš ļø Warning: Local Node Already Running'));
58
+ console.log(chalk.yellow(' ā”œā”€ Cannot start a new instance'));
59
+ console.log(
60
+ chalk.yellow(' └─ Please stop the existing process first')
61
+ );
62
+ return;
63
+ }
64
+
65
+ printDubhe();
66
+ console.log('šŸš€ Starting Local Node...');
67
+ try {
68
+ const suiProcess = spawn(
69
+ 'sui',
70
+ ['start', '--with-faucet', '--force-regenesis'],
71
+ {
72
+ env: { ...process.env, RUST_LOG: 'off,sui_node=info' },
73
+ stdio: 'ignore',
74
+ detached: true,
75
+ }
76
+ );
77
+
78
+ suiProcess.on('error', error => {
79
+ console.error(chalk.red('\nāŒ Failed to Start Local Node'));
80
+ console.error(chalk.red(` └─ Error: ${error.message}`));
81
+ });
82
+ await delay(5000);
83
+ console.log(' ā”œā”€ Faucet: Enabled');
84
+ console.log(' └─ Force Regenesis: Yes');
85
+ console.log(' └─ HTTP server: http://127.0.0.1:9000/');
86
+ console.log(' └─ Faucet server: http://127.0.0.1:9123/');
87
+
88
+ await printAccounts();
89
+
90
+ await delay(2000);
91
+
92
+ const privateKeyFormat = validatePrivateKey("suiprivkey1qzez45sjjsepjgtksqvpq6jw7dzw3zq0dx7a4sulfypd73acaynw5jl9x2c");
93
+ if (privateKeyFormat === false) {
94
+ throw new DubheCliError(`Please check your privateKey.`);
95
+ }
96
+
97
+ const dubhe = new Dubhe({ secretKey: privateKeyFormat });
98
+ const client = new SuiClient({ url: getFullnodeUrl('localnet') });
99
+ const originalLog = console.log;
100
+
101
+ console.log = () => {};
102
+ await publishDubheFramework(client, dubhe, 'localnet');
103
+ console.log = originalLog;
104
+
105
+ process.on('SIGINT', () => {
106
+ console.log(chalk.yellow('\nšŸ”” Stopping Local Node...'));
107
+ if (suiProcess) {
108
+ suiProcess.kill();
109
+ console.log(chalk.green('āœ… Local Node Stopped'));
110
+ }
111
+ process.exit();
112
+ });
113
+ } catch (error: any) {
114
+ console.error(chalk.red('\nāŒ Failed to Start Local Node'));
115
+ console.error(chalk.red(` └─ Error: ${error.message}`));
116
+ }
117
+ }
@@ -3,7 +3,6 @@ import { mkdirSync, writeFileSync } from 'fs';
3
3
  import { dirname } from 'path';
4
4
  import { SUI_PRIVATE_KEY_PREFIX } from '@mysten/sui/cryptography';
5
5
  import { FsIibError } from './errors';
6
- export * from './localnode';
7
6
  import * as fs from 'fs';
8
7
  import chalk from 'chalk';
9
8
  import { spawn } from 'child_process';
@@ -231,7 +230,6 @@ export async function switchEnv(network: 'mainnet' | 'testnet' | 'devnet' | 'loc
231
230
  console.error(chalk.red(`\nāŒ Process exited with code: ${code}`));
232
231
  reject(new Error(`Process exited with code: ${code}`));
233
232
  } else {
234
- console.log(chalk.green('\nāœ… Environment switched successfully.'));
235
233
  resolve(); // Resolve promise on successful exit
236
234
  }
237
235
  });
@@ -1,3 +0,0 @@
1
- export { startLocalnode } from './start';
2
- export { checkLocalNodeStatus } from './status';
3
- export { stopLocalnode } from './stop';
@@ -1,87 +0,0 @@
1
- import { execSync, spawn } from 'child_process';
2
- import chalk from 'chalk';
3
-
4
- function isSuiStartRunning(): boolean {
5
- try {
6
- const cmd =
7
- process.platform === 'win32'
8
- ? `tasklist /FI "IMAGENAME eq sui.exe" /FO CSV /NH`
9
- : 'pgrep -f "sui start"';
10
-
11
- const result = execSync(cmd).toString().trim();
12
- return process.platform === 'win32'
13
- ? result.toLowerCase().includes('sui.exe')
14
- : result.length > 0;
15
- } catch (error) {
16
- return false;
17
- }
18
- }
19
-
20
- export async function startLocalnode(background: boolean = false) {
21
- console.log('\nšŸ” Checking Local Node Status...');
22
- console.log(' ā”œā”€ Scanning running processes');
23
-
24
- if (isSuiStartRunning()) {
25
- console.log(chalk.yellow('\nāš ļø Warning: Local Node Already Running'));
26
- console.log(chalk.yellow(' ā”œā”€ Cannot start a new instance'));
27
- console.log(
28
- chalk.yellow(' └─ Please stop the existing process first')
29
- );
30
- return;
31
- }
32
-
33
- console.log('\nšŸš€ Starting Local Node...');
34
- console.log(' ā”œā”€ Mode: ' + (background ? 'Background' : 'Foreground'));
35
- console.log(' ā”œā”€ Faucet: Enabled');
36
- console.log(' └─ Force Regenesis: Yes');
37
-
38
- try {
39
- const suiProcess = spawn(
40
- 'sui',
41
- ['start', '--with-faucet', '--force-regenesis'],
42
- {
43
- env: { ...process.env, RUST_LOG: 'off,sui_node=info' },
44
- stdio: background ? 'ignore' : 'inherit',
45
- detached: background,
46
- }
47
- );
48
-
49
- suiProcess.on('error', error => {
50
- console.error(chalk.red('\nāŒ Failed to Start Local Node'));
51
- console.error(chalk.red(` └─ Error: ${error.message}`));
52
- });
53
-
54
- if (!background) {
55
- suiProcess.on('exit', code => {
56
- if (code === 0) {
57
- console.log(chalk.green('\nāœ… Local Node Stopped'));
58
- console.log(chalk.green(' └─ Exit Status: Normal'));
59
- } else {
60
- console.error(chalk.red('\nāŒ Local Node Crashed'));
61
- console.error(chalk.red(` └─ Exit Code: ${code}`));
62
- }
63
- });
64
-
65
- console.log(chalk.cyan('\nšŸ“” Local Node Running'));
66
- console.log(chalk.cyan(' └─ Press Ctrl+C to stop'));
67
-
68
- await new Promise(() => {});
69
- } else {
70
- suiProcess.unref();
71
- console.log(chalk.green('\nāœ… Local Node Started in Background'));
72
-
73
- if (process.platform === 'win32') {
74
- console.log('\nšŸ’” Helpful Commands:');
75
- console.log(' ā”œā”€ Check Process: tasklist | findstr sui.exe');
76
- console.log(' └─ Stop Node: taskkill /PID <process_id> /F');
77
- } else {
78
- console.log('\nšŸ’” Helpful Commands:');
79
- console.log(" ā”œā”€ Check Process: pgrep -f 'sui start'");
80
- console.log(' └─ Stop Node: kill <process_id>');
81
- }
82
- }
83
- } catch (error: any) {
84
- console.error(chalk.red('\nāŒ Failed to Start Local Node'));
85
- console.error(chalk.red(` └─ Error: ${error.message}`));
86
- }
87
- }
@@ -1,38 +0,0 @@
1
- import { execSync } from 'child_process';
2
- import chalk from 'chalk';
3
-
4
- export async function checkLocalNodeStatus() {
5
- console.log('\nšŸ” Checking Local Node Status...');
6
-
7
- try {
8
- const cmd =
9
- process.platform === 'win32'
10
- ? `tasklist /FI "IMAGENAME eq sui.exe" /FO CSV /NH`
11
- : "ps aux | grep '[s]ui start --with-faucet --force-regenesis'";
12
-
13
- const output = execSync(cmd, {
14
- encoding: 'utf8',
15
- });
16
-
17
- const isRunning =
18
- process.platform === 'win32'
19
- ? output.toLowerCase().includes('sui.exe')
20
- : output.split('\n').filter(Boolean).length > 0;
21
-
22
- if (isRunning) {
23
- console.log(chalk.green('\nāœ… Node Status: Running'));
24
- console.log(chalk.gray('\nšŸ“Š Process Details:'));
25
- console.log(chalk.gray(` └─ ${output.trim()}`));
26
- } else {
27
- console.log(chalk.red('\nāŒ Node Status: Not Running'));
28
- console.log(chalk.yellow('\nšŸ’” Quick Start:'));
29
- console.log(chalk.yellow(' └─ Run `dubhe localnode start`'));
30
- }
31
- } catch (error) {
32
- console.log(chalk.red('\nāŒ Node Status: Not Running'));
33
- console.log(chalk.yellow('\nšŸ’” Quick Start:'));
34
- console.log(chalk.yellow(' └─ Run `dubhe localnode start`'));
35
- }
36
- }
37
-
38
- // checkLocalNodeStatus();
@@ -1,58 +0,0 @@
1
- import { execSync } from 'child_process';
2
-
3
- export async function stopLocalnode() {
4
- console.log('Stopping local node...');
5
-
6
- try {
7
- // Choose different commands based on the operating system
8
- const cmd =
9
- process.platform === 'win32'
10
- ? `tasklist /FI "IMAGENAME eq sui.exe" /FO CSV /NH`
11
- : "ps aux | grep '[s]ui start --with-faucet --force-regenesis'";
12
-
13
- const output = execSync(cmd, {
14
- encoding: 'utf8',
15
- });
16
-
17
- if (!output) {
18
- console.log('No running local node process found');
19
- return;
20
- }
21
-
22
- // Parse process ID based on the operating system
23
- let pid;
24
- if (process.platform === 'win32') {
25
- // Windows output format: "sui.exe","1234",... (CSV format)
26
- const match = output.match(/"sui\.exe",["']?(\d+)/i);
27
- pid = match ? match[1] : null;
28
- } else {
29
- // Unix system output format: user pid %cpu ...
30
- pid = output.toString().split(/\s+/)[1];
31
- }
32
-
33
- if (!pid) {
34
- console.log('No running local node process found');
35
- return;
36
- }
37
-
38
- // Choose the command to terminate the process based on the operating system
39
- if (process.platform === 'win32') {
40
- execSync(`taskkill /PID ${pid} /F`);
41
- } else {
42
- process.kill(Number(pid));
43
- }
44
-
45
- console.log('āœ… Local node stopped successfully');
46
- } catch (error: any) {
47
- if (
48
- error.code === 'ESRCH' ||
49
- error.message.includes('no running tasks')
50
- ) {
51
- console.log('No running local node process found');
52
- } else {
53
- console.error('āŒ Error stopping local node:', error.message);
54
- }
55
- }
56
- }
57
-
58
- // stopLocalnode();