@0xobelisk/sui-cli 0.5.24 → 0.5.26
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 +51 -38
- package/dist/dubhe.js.map +1 -1
- package/package.json +2 -2
- package/src/commands/publish.ts +5 -5
- package/src/utils/publishHandler.ts +249 -37
- package/src/utils/upgradeHandler.ts +60 -14
package/dist/dubhe.js
CHANGED
|
@@ -1,35 +1,46 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import
|
|
2
|
+
import bo from"yargs";import{hideBin as _o}from"yargs/helpers";import{Dubhe as De}from"@0xobelisk/sui-client";import{Transaction as Y}from"@mysten/sui/transactions";import{getFullnodeUrl as Re,SuiClient as Fe}from"@mysten/sui/client";import{execSync as Oe}from"child_process";import S from"chalk";import D from"chalk";import{ZodError as ve}from"zod";import{fromZodError as we,ValidationError as Ce}from"zod-validation-error";var H=class extends Error{name="NotInsideProjectError";message="You are not inside a Dubhe project"},_=class extends Error{name="DubheCliError"},O=class extends Error{name="UpgradeError"},A=class extends Error{name="FsIibError"};function E(e){if(e instanceof Ce)console.log(D.redBright(e.message));else if(e instanceof ve){let o=we(e,{prefixSeparator:`
|
|
3
3
|
- `,issueSeparator:`
|
|
4
|
-
- `});console.log(
|
|
5
|
-
\u{1F50D} Checking Local Node Status...`),console.log(" \u251C\u2500 Scanning running processes"),
|
|
6
|
-
\u26A0\uFE0F Warning: Local Node Already Running`)),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=
|
|
8
|
-
\u274C Failed to Start Local Node`)),console.error(
|
|
4
|
+
- `});console.log(D.redBright(o.message))}else e instanceof H?(console.log(D.red(e.message)),console.log(""),console.log(D.blue("To learn more about Dubhe's configuration, please go to https://github.com/0xobelisk"))):e instanceof _?console.log(D.red(e)):console.log(e)}import*as W from"fs/promises";import{mkdirSync as Pe,writeFileSync as $e}from"fs";import{dirname as Ee}from"path";import{SUI_PRIVATE_KEY_PREFIX as Ne}from"@mysten/sui/cryptography";import{execSync as xe,spawn as ke}from"child_process";import f from"chalk";function Se(){try{let e=process.platform==="win32"?'tasklist /FI "IMAGENAME eq sui.exe" /FO CSV /NH':'pgrep -f "sui start"',o=xe(e).toString().trim();return process.platform==="win32"?o.toLowerCase().includes("sui.exe"):o.length>0}catch{return!1}}async function T(e=!1){if(console.log(`
|
|
5
|
+
\u{1F50D} Checking Local Node Status...`),console.log(" \u251C\u2500 Scanning running processes"),Se()){console.log(f.yellow(`
|
|
6
|
+
\u26A0\uFE0F Warning: Local Node Already Running`)),console.log(f.yellow(" \u251C\u2500 Cannot start a new instance")),console.log(f.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=ke("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(f.red(`
|
|
8
|
+
\u274C Failed to Start Local Node`)),console.error(f.red(` \u2514\u2500 Error: ${t.message}`))}),e?(o.unref(),console.log(f.green(`
|
|
9
9
|
\u2705 Local Node Started in Background`)),process.platform==="win32"?(console.log(`
|
|
10
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(
|
|
12
|
-
\u2705 Local Node Stopped`)),console.log(
|
|
13
|
-
\u274C Local Node Crashed`)),console.error(
|
|
14
|
-
\u{1F4E1} Local Node Running`)),console.log(
|
|
15
|
-
\u274C Failed to Start Local Node`)),console.error(
|
|
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=
|
|
17
|
-
`).filter(Boolean).length>0)?(console.log(
|
|
18
|
-
\u2705 Node Status: Running`)),console.log(
|
|
19
|
-
\u{1F4CA} Process Details:`)),console.log(
|
|
20
|
-
\u274C Node Status: Not Running`)),console.log(
|
|
21
|
-
\u{1F4A1} Quick Start:`)),console.log(
|
|
22
|
-
\u274C Node Status: Not Running`)),console.log(
|
|
23
|
-
\u{1F4A1} Quick Start:`)),console.log(
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
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(f.green(`
|
|
12
|
+
\u2705 Local Node Stopped`)),console.log(f.green(" \u2514\u2500 Exit Status: Normal"))):(console.error(f.red(`
|
|
13
|
+
\u274C Local Node Crashed`)),console.error(f.red(` \u2514\u2500 Exit Code: ${t}`)))}),console.log(f.cyan(`
|
|
14
|
+
\u{1F4E1} Local Node Running`)),console.log(f.cyan(" \u2514\u2500 Press Ctrl+C to stop")),await new Promise(()=>{}))}catch(o){console.error(f.red(`
|
|
15
|
+
\u274C Failed to Start Local Node`)),console.error(f.red(` \u2514\u2500 Error: ${o.message}`))}}import{execSync as Ie}from"child_process";import x from"chalk";async function B(){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=Ie(e,{encoding:"utf8"});(process.platform==="win32"?o.toLowerCase().includes("sui.exe"):o.split(`
|
|
17
|
+
`).filter(Boolean).length>0)?(console.log(x.green(`
|
|
18
|
+
\u2705 Node Status: Running`)),console.log(x.gray(`
|
|
19
|
+
\u{1F4CA} Process Details:`)),console.log(x.gray(` \u2514\u2500 ${o.trim()}`))):(console.log(x.red(`
|
|
20
|
+
\u274C Node Status: Not Running`)),console.log(x.yellow(`
|
|
21
|
+
\u{1F4A1} Quick Start:`)),console.log(x.yellow(" \u2514\u2500 Run `dubhe localnode start`")))}catch{console.log(x.red(`
|
|
22
|
+
\u274C Node Status: Not Running`)),console.log(x.yellow(`
|
|
23
|
+
\u{1F4A1} Quick Start:`)),console.log(x.yellow(" \u2514\u2500 Run `dubhe localnode start`"))}}import{execSync as q}from"child_process";async function V(){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 n=o.match(/"sui\.exe",["']?(\d+)/i);t=n?n[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)}}function N(e){if(e.startsWith(Ne))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 R(e,o){try{let t=await W.readFile(`${e}/.history/sui_${o}/latest.json`,"utf8");return JSON.parse(t)}catch{throw new A("Fs read deployment file failed.")}}async function z(e,o){return(await R(e,o)).schemas}async function Q(e,o){return(await R(e,o)).version}async function Z(e,o){return(await R(e,o)).packageId}async function X(e,o){return(await R(e,o)).upgradeCap}async function U(e,o){return(await R(e,o)).schemaHub}function F(e,o,t,n,a,c,i){let u={projectName:e,network:o,packageId:t,schemas:i,upgradeCap:n,schemaHub:a,version:c},s=process.cwd(),l=JSON.stringify(u,null,2);Me(l,`${s}/contracts/${e}/.history/sui_${o}/latest.json`,"Update deploy log")}async function Me(e,o,t){Pe(Ee(o),{recursive:!0}),$e(o,e),t!==void 0&&console.log(`${t}: ${o}`)}import*as I from"fs";import*as ee from"path";async function Ae(e){switch(e){case"localnet":{let o=process.cwd();return await U(`${o}/contracts/dubhe-framework`,e)}case"testnet":return"0x181befc40b3dafe2740b41d5a970e49bed2cca20205506ee6be2cfb73ff2d3e9";default:return"0x181befc40b3dafe2740b41d5a970e49bed2cca20205506ee6be2cfb73ff2d3e9"}}function oe(e,o){if(!I.existsSync(e))return;let t=I.readFileSync(e,"utf-8"),n=new RegExp(`\\[env\\.${o}\\][\\s\\S]*?(?=\\[|$)`,"g"),a=t.replace(n,"");I.writeFileSync(e,a,"utf-8")}var Te={localnet:"dfa7bb83",testnet:"4c78adac",mainnet:"35834a8a"};function te(e,o,t,n){let a=ee.resolve(e),c=I.readFileSync(a,"utf-8"),i=c.split(`
|
|
24
|
+
`),u=i.findIndex(m=>m.trim()===`[env.${o}]`),s={chainId:Te[o]||"",originalPublishedId:"",latestPublishedId:"",publishedVersion:0};if(u===-1)if(t==="publish")s.originalPublishedId=n,s.latestPublishedId=n,s.publishedVersion=1;else throw new Error(`Network type [env.${o}] not found in the file and cannot upgrade.`);else{for(let m=u+1;m<i.length;m++){let w=i[m].trim();if(w.startsWith("["))break;let[h,y]=w.split("=").map(b=>b.trim().replace(/"/g,""));switch(h){case"chain-id":s.chainId=y;break;case"original-published-id":s.originalPublishedId=y;break;case"latest-published-id":s.latestPublishedId=y;break;case"published-version":s.publishedVersion=parseInt(y,10);break}}t==="publish"?(s.originalPublishedId=n,s.latestPublishedId=n,s.publishedVersion=1):t==="upgrade"&&(s.latestPublishedId=n,s.publishedVersion+=1)}let l=`
|
|
25
|
+
[env.${o}]
|
|
26
|
+
chain-id = "${s.chainId}"
|
|
27
|
+
original-published-id = "${s.originalPublishedId}"
|
|
28
|
+
latest-published-id = "${s.latestPublishedId}"
|
|
29
|
+
published-version = "${s.publishedVersion}"
|
|
30
|
+
`,p=u===-1?c+l:i.slice(0,u).join(`
|
|
31
|
+
`)+l;I.writeFileSync(a,p,"utf-8")}function Ve(e){return e.split("_").map((o,t)=>o.charAt(0).toUpperCase()+o.slice(1).toLowerCase()).join("")}function Ue(e){let o=e.split("::");return o.length>0?o[o.length-1]:""}function ne(e){let o,t;try{let n=JSON.parse(Oe(`sui move build --dump-bytecode-as-base64 --path ${e}`,{encoding:"utf-8"}));o=n.modules,t=n.dependencies,console.log(" \u2514\u2500 Build successful")}catch(n){console.error(S.red(" \u2514\u2500 Build failed")),console.error(n.stdout),process.exit(1)}return[o,t]}async function Le(e,o,t,n,a){let c=await Ae(n);console.log("dappsObjectId",c),oe(`${a}/Move.lock`,n),console.log(`
|
|
32
|
+
\u{1F680} Starting Contract Publication...`),console.log(` \u251C\u2500 Project: ${a}`),console.log(` \u251C\u2500 Network: ${n}`),console.log(" \u251C\u2500 Validating Environment...");let i=o.getKeypair();console.log(` \u2514\u2500 Account: ${i.toSuiAddress()}`),console.log(`
|
|
33
|
+
\u{1F4E6} Building Contract...`);let[u,s]=ne(a);console.log(`
|
|
34
|
+
\u{1F504} Publishing Contract...`);let l=new Y,[p]=l.publish({modules:u,dependencies:s});l.transferObjects([p],i.toSuiAddress());let m;try{m=await e.signAndExecuteTransaction({signer:i,transaction:l,options:{showObjectChanges:!0}})}catch(r){console.error(S.red(" \u2514\u2500 Publication failed")),console.error(r.message),process.exit(1)}m.effects?.status.status==="failure"&&(console.log(S.red(" \u2514\u2500 Publication failed")),process.exit(1)),console.log(" \u251C\u2500 Processing publication results...");let w=1,h="",y=[],b="",g="";m.objectChanges.map(r=>{r.type==="published"&&(console.log(` \u251C\u2500 Package ID: ${r.packageId}`),h=r.packageId),r.type==="created"&&r.objectType==="0x2::package::UpgradeCap"&&(console.log(` \u251C\u2500 Upgrade Cap: ${r.objectId}`),b=r.objectId),r.type==="created"&&r.objectType.includes("schema_hub")&&(console.log(` \u251C\u2500 Schema Hub: ${r.objectId}`),g=r.objectId)}),console.log(` \u2514\u2500 Transaction: ${m.digest}`),te(`${a}/Move.lock`,n,"publish",h),console.log(`
|
|
35
|
+
\u26A1 Executing Deploy Hook...`),await new Promise(r=>setTimeout(r,5e3));let d=new Y;d.setGasBudget(2e9);let[k]=d.splitCoins(d.gas,["1000000000"]);d.moveCall({target:`${h}::deploy_hook::run`,arguments:[d.object(g),d.object(c),d.object(b),d.object("0x6"),k]});let v;try{v=await e.signAndExecuteTransaction({signer:i,transaction:d,options:{showEffects:!0,showObjectChanges:!0}})}catch(r){console.error(S.red(" \u2514\u2500 Deploy hook execution failed")),console.error(r.message),process.exit(1)}v.effects?.status.status==="success"?(console.log(" \u251C\u2500 Hook execution successful"),console.log(` \u251C\u2500 Transaction: ${v.digest}`),console.log(`
|
|
36
|
+
\u{1F4CB} Created Schemas:`),v.objectChanges?.map(r=>{if(r.type==="created"&&r.objectType.includes("_schema")&&!r.objectType.includes("dynamic_field")){console.log(` \u251C\u2500 ${r.objectType}`),console.log(` \u2514\u2500 ID: ${r.objectId}`);let P={};for(let C in t.schemas)Ve(C)===Ue(r.objectType)&&(P=t.schemas[C].structure);y.push({name:r.objectType,objectId:r.objectId,structure:P})}}),F(t.name,n,h,b,g,w,y),console.log(`
|
|
31
37
|
\u2705 Contract Publication Complete
|
|
32
|
-
`)):(console.log(
|
|
38
|
+
`)):(console.log(S.yellow(" \u2514\u2500 Deploy hook execution failed")),console.log(S.yellow(" Please republish or manually call deploy_hook::run")))}async function Ke(e,o,t){let a=`${process.cwd()}/contracts/dubhe-framework`;oe(`${a}/Move.lock`,t),console.log(`
|
|
39
|
+
\u{1F680} Starting Contract Publication...`),console.log(` \u251C\u2500 Project: ${a}`),console.log(` \u251C\u2500 Network: ${t}`),console.log(" \u251C\u2500 Validating Environment...");let c=o.getKeypair();console.log(` \u2514\u2500 Account: ${c.toSuiAddress()}`),console.log(`
|
|
40
|
+
\u{1F4E6} Building Contract...`);let[i,u]=ne(a);console.log(`
|
|
41
|
+
\u{1F504} Publishing Contract...`);let s=new Y,[l]=s.publish({modules:i,dependencies:u});s.transferObjects([l],c.toSuiAddress());let p;try{p=await e.signAndExecuteTransaction({signer:c,transaction:s,options:{showObjectChanges:!0}})}catch(g){console.error(S.red(" \u2514\u2500 Publication failed")),console.error(g.message),process.exit(1)}p.effects?.status.status==="failure"&&(console.log(S.red(" \u2514\u2500 Publication failed")),process.exit(1)),console.log(" \u251C\u2500 Processing publication results...");let m=1,w="",h=[],y="",b="";p.objectChanges.map(g=>{g.type==="published"&&(console.log(` \u251C\u2500 Package ID: ${g.packageId}`),w=g.packageId),g.type==="created"&&g.objectType==="0x2::package::UpgradeCap"&&(console.log(` \u251C\u2500 Upgrade Cap: ${g.objectId}`),y=g.objectId),g.type==="created"&&g.objectType.includes("dapps")&&(console.log(` \u251C\u2500 Dapps: ${g.objectId}`),b=g.objectId)}),console.log(` \u2514\u2500 Transaction: ${p.digest}`),te(`${a}/Move.lock`,t,"publish",w),F("dubhe-framework",t,w,y,b,m,h)}async function se(e,o,t){let n=process.env.PRIVATE_KEY;if(!n)throw new _(`Missing PRIVATE_KEY environment variable.
|
|
42
|
+
Run 'echo "PRIVATE_KEY=YOUR_PRIVATE_KEY" > .env'
|
|
43
|
+
in your contracts directory to use the default sui private key.`);let a=N(n);if(a===!1)throw new _("Please check your privateKey.");let c=new De({secretKey:a}),i=c.getKeypair();console.log(` \u2514\u2500 Account: ${i.toSuiAddress()}`);let u=new Fe({url:Re(o)});if(t=="dubhe-framework")await Ke(u,c,o);else{let l=`${process.cwd()}/contracts/${e.name}`;await Le(u,c,e,o,l)}}import je from"chalk";function re(){console.log(je.yellow(`
|
|
33
44
|
Welcome to Dubhe
|
|
34
45
|
--from team@obelisk
|
|
35
46
|
________ ___ ___ ________ ___ ___ _______
|
|
@@ -40,19 +51,21 @@ Welcome to Dubhe
|
|
|
40
51
|
\\ \\_______\\ \\_______\\ \\_______\\ \\__\\ \\__\\ \\_______\\
|
|
41
52
|
\\|_______|\\|_______|\\|_______|\\|__|\\|__|\\|_______|
|
|
42
53
|
|
|
43
|
-
`))}var
|
|
54
|
+
`))}var He={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 T(t);break;case"stop":await V();break;case"status":await B();break;case"restart":await Be(t);break}}catch(n){console.error("Error executing command:",n),process.exit(1)}}};async function Be(e){console.log("Restarting local Sui node..."),await V(),await T(e),console.log("Local node has been restarted")}var ae=He;import{Dubhe as Ye}from"@0xobelisk/sui-client";import{requestSuiFromFaucetV0 as Ge,getFaucetHost as Je}from"@mysten/sui/faucet";import{SuiClient as qe,getFullnodeUrl as We}from"@mysten/sui/client";var ze={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 i=process.env.PRIVATE_KEY;if(!i)throw new _(`Missing PRIVATE_KEY environment variable.
|
|
44
55
|
Run 'echo "PRIVATE_KEY=YOUR_PRIVATE_KEY" > .env'
|
|
45
|
-
in your contracts directory to use the default sui private key.`);let
|
|
46
|
-
\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
|
|
47
|
-
\u{1F4B0} Account Summary`),console.log(` \u251C\u2500 Address: ${t}`),console.log(` \u2514\u2500 Balance: ${(Number(
|
|
56
|
+
in your contracts directory to use the default sui private key.`);let u=N(i);if(u===!1)throw new _("Please check your PRIVATE_KEY.");t=new Ye({secretKey:u}).getKeypair().toSuiAddress()}else t=o;console.log(`
|
|
57
|
+
\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 Ge({host:Je(e),recipient:t}),console.log(" \u2514\u2500 Checking balance...");let n=new qe({url:We(e)}),a={owner:t},c=await n.getBalance(a);console.log(`
|
|
58
|
+
\u{1F4B0} Account Summary`),console.log(` \u251C\u2500 Address: ${t}`),console.log(` \u2514\u2500 Balance: ${(Number(c.totalBalance)/1e9).toFixed(4)} SUI`),console.log(`
|
|
48
59
|
\u2705 Faucet Operation Complete
|
|
49
|
-
`),process.exit(0)}},
|
|
50
|
-
public fun migrate(
|
|
51
|
-
${t.fields.map(
|
|
60
|
+
`),process.exit(0)}},ie=ze;import{schemaGen as Qe,loadConfig as Ze}from"@0xobelisk/sui-common";import Xe from"chalk";var eo={command:"schemagen",describe:"Autogenerate Dubhe schemas based on the config file",builder:{configPath:{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)"},frameworkId:{type:"string",desc:"Framework Package ID"}},async handler({configPath:e,network:o,frameworkId:t}){try{let n=await Ze(e);await Qe(n,void 0,o,t),process.exit(0)}catch(n){console.log(Xe.red("Schemagen failed!")),console.error(n.message)}}},ce=eo;import{loadConfig as oo}from"@0xobelisk/sui-common";var to={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)"},configPath:{type:"string",default:"dubhe.config.ts",desc:"Configuration file path"},contractName:{type:"string",desc:"Optional contract name"}})},async handler({network:e,configPath:o,contractName:t}){try{let n=await oo(o);await se(n,e,t)}catch(n){E(n),process.exit(1)}process.exit(0)}},le=to;import{Dubhe as no}from"@0xobelisk/sui-client";import{Transaction as so,UpgradePolicy as ro}from"@mysten/sui/transactions";import{getFullnodeUrl as ao,SuiClient as io}from"@mysten/sui/client";import{execSync as co}from"child_process";import L from"chalk";import*as M from"fs";import*as de from"path";function lo(e,o){o.forEach(t=>{let n=`${e}/sources/codegen/schemas/${t.schemaName}.move`,a=M.readFileSync(n,"utf-8"),c=new RegExp(`public fun migrate\\(_${t.schemaName}: &mut ${G(t.schemaName)}, _cap: &UpgradeCap\\) {[^}]*}`),i=`
|
|
61
|
+
public fun migrate(${t.schemaName}: &mut ${G(t.schemaName)}, _cap: &UpgradeCap) {
|
|
62
|
+
${t.fields.map(s=>{let l="";return s.type.includes("StorageValue")?l="storage_value::new()":s.type.includes("StorageMap")?l="storage_map::new()":s.type.includes("StorageDoubleMap")&&(l="storage_double_map::new()"),`storage_migrate::add_field<${s.type}>(&mut ${t.schemaName}.id, b"${s.name}", ${l});`}).join("")}
|
|
52
63
|
}
|
|
53
|
-
`,
|
|
64
|
+
`,u=a.replace(c,i);M.writeFileSync(n,u,"utf-8")})}function G(e){return e.split("_").map((o,t)=>o.charAt(0).toUpperCase()+o.slice(1).toLowerCase()).join("")}function uo(e){let o=e.split("::");return o.length>0?o[o.length-1]:""}function K(e,o,t,n){let a=de.resolve(e),i=M.readFileSync(a,"utf-8").split(`
|
|
65
|
+
`),u=i.findIndex(p=>p.trim()===`[env.${o}]`);if(u===-1)return console.log(`Network type [env.${o}] not found in the file.`),"";let s=-1,l="";for(let p=u+1;p<i.length;p++){let m=i[p].trim();if(m.startsWith("["))break;if(m.startsWith(t)){s=p,l=m.split("=")[1].trim().replace(/"/g,"");break}}if(s!==-1){i[s]=`${t} = "${n}"`;let p=i.join(`
|
|
66
|
+
`);M.writeFileSync(a,p,"utf-8"),console.log(`${t} for [env.${o}] replaced successfully.`)}else console.log(`${t} not found for [env.${o}].`);return l}async function ue(e,o,t){let n=process.cwd(),a=`${n}/contracts/${o}`,c=process.env.PRIVATE_KEY;if(!c)throw new _(`Missing PRIVATE_KEY environment variable.
|
|
54
67
|
Run 'echo "PRIVATE_KEY=YOUR_PRIVATE_KEY" > .env'
|
|
55
|
-
in your contracts directory to use the default sui private key.`);let
|
|
56
|
-
\u{1F680} Starting Migration for ${
|
|
57
|
-
\u{1F680} Starting Upgrade Process...`),console.log("\u{1F4CB} OldPackageId:",
|
|
68
|
+
in your contracts directory to use the default sui private key.`);let i=N(c);if(i===!1)throw new _("Please check your privateKey.");let s=new no({secretKey:i}).getKeypair(),l=new io({url:ao(t)}),p=Number(await Q(a,t)),m=await Z(a,t),w=await U(a,t),h=await X(a,t),y=K(`${a}/Move.lock`,t,"original-published-id","0x0000000000000000000000000000000000000000000000000000000000000000"),b=[],g=await z(a,t);for(let d in e.schemas)g.forEach(k=>{if(G(d)==uo(k.name)){let v={schemaName:"",fields:[]},r=[],P=!1;for(let C in e.schemas[d].structure)C in k.structure||(P=!0,r.push({name:C,type:e.schemas[d].structure[C]}),k.structure[C]=e.schemas[d].structure[C]);P&&(v.schemaName=d,v.fields=r,b.push(v))}});b.forEach(d=>{console.log(`
|
|
69
|
+
\u{1F680} Starting Migration for ${d.schemaName}...`),console.log("\u{1F4CB} Migration Fields:",d.fields)}),lo(a,b);try{let d,k,v;try{let{modules:$,dependencies:be,digest:_e}=JSON.parse(co(`sui move build --dump-bytecode-as-base64 --path ${n}/contracts/${o}`,{encoding:"utf-8"}));d=$,k=be,v=_e}catch($){throw new O($.stdout)}console.log(`
|
|
70
|
+
\u{1F680} Starting Upgrade Process...`),console.log("\u{1F4CB} OldPackageId:",m),console.log("\u{1F4CB} UpgradeCap Object Id:",h),console.log("\u{1F4CB} OldVersion:",p);let r=new so,P=r.moveCall({target:"0x2::package::authorize_upgrade",arguments:[r.object(h),r.pure.u8(ro.COMPATIBLE),r.pure.vector("u8",v)]}),C=r.upgrade({modules:d,dependencies:k,package:m,ticket:P});r.moveCall({target:"0x2::package::commit_upgrade",arguments:[r.object(h),C]});let J=await l.signAndExecuteTransaction({signer:s,transaction:r,options:{showObjectChanges:!0}}),j="";J.objectChanges.map($=>{$.type==="published"&&(console.log(L.blue(`${o} PackageId: ${$.packageId}`)),console.log(L.blue(`${o} Version: ${p+1}`)),j=$.packageId)}),K(`${a}/Move.lock`,t,"original-published-id",y),K(`${a}/Move.lock`,t,"latest-published-id",j),K(`${a}/Move.lock`,t,"published-version",p+1+""),console.log(L.green(`Upgrade Transaction Digest: ${J.digest}`)),F(o,t,j,h,w,p+1,g)}catch(d){console.log(L.red("Upgrade failed!")),console.error(d.message)}}import{loadConfig as po}from"@0xobelisk/sui-common";var go={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)"},configPath:{type:"string",default:"dubhe.config.ts",decs:"Path to the config file"}})},async handler({network:e,configPath:o}){try{let t=await po(o);await ue(t,t.name,e)}catch(t){E(t),process.exit(1)}process.exit(0)}},pe=go;import{execSync as mo}from"child_process";import fo from"chalk";var ho={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{mo(`sui move test --path ${e}`,{encoding:"utf-8"})}catch(o){console.error(fo.red("Error executing sui move test:")),console.log(o.stdout),process.exit(0)}}},ge=ho;var yo={command:"hello",describe:"hello, dubhe",builder(e){return e},async handler(){re()}},me=yo;var fe=[le,ae,ie,ce,pe,ge,me];import*as ye from"dotenv";import he from"chalk";ye.config();bo(_o(process.argv)).scriptName("dubhe").command(fe).strict().fail((e,o)=>{console.error(he.red(e)),e.includes("Missing required argument")&&console.log(he.yellow(`Run 'pnpm dubhe ${process.argv[2]} --help' for a list of available and required arguments.`)),console.log(""),E(o),console.log(""),process.exit(1)}).alias({h:"help"}).argv;
|
|
58
71
|
//# 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,\n} from './utils';\nimport { DubheConfig } from '@0xobelisk/sui-common';\n\nasync function getDappsObjectId(\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet'\n) {\n\tswitch (network) {\n\t\tcase 'testnet':\n\t\t\treturn '0x181befc40b3dafe2740b41d5a970e49bed2cca20205506ee6be2cfb73ff2d3e9';\n\t\tdefault:\n\t\t\treturn '0x181befc40b3dafe2740b41d5a970e49bed2cca20205506ee6be2cfb73ff2d3e9';\n\t}\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\nexport async function publishHandler(\n\tdubheConfig: DubheConfig,\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\n\tdappsObjectId?: string\n) {\n\n\n\tconst path = process.cwd();\n\tconst projectPath = `${path}/contracts/${dubheConfig.name}`;\n\tdappsObjectId = dappsObjectId || (await getDappsObjectId(network));\n\n\tconsole.log('\\n🚀 Starting Contract Publication...');\n\tconsole.log(` ├─ Project: ${projectPath}`);\n\tconsole.log(` ├─ Network: ${network}`);\n\tconsole.log(' ├─ Validating Environment...');\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\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 keypair = dubhe.getKeypair();\n\tconsole.log(` └─ Account: ${keypair.toSuiAddress()}`);\n\n\tconst client = new SuiClient({ url: getFullnodeUrl(network) });\n\n\tconsole.log('\\n📦 Building Contract...');\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\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\tconsole.log('\\n⚡ Executing Deploy Hook...');\n\tawait new Promise(resolve => setTimeout(resolve, 5000));\n\n\tconst deployHookTx = new Transaction();\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],\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","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';\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","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\tconfigPath?: string;\n\tnetwork?: 'mainnet' | 'testnet' | 'devnet' | 'localnet';\n\tframeworkId?: 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\tconfigPath: {\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\tframeworkId: {\n\t\t\ttype: 'string',\n\t\t\tdesc: 'Framework Package ID',\n\t\t},\n\t},\n\n\tasync handler({ configPath, network, frameworkId }) {\n\t\ttry {\n\t\t\tconst dubheConfig = (await loadConfig(\n\t\t\t\tconfigPath\n\t\t\t)) 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\tconfigPath: string;\n\tdappsObjectId?: 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\tconfigPath: {\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\tdappsObjectId: {\n\t\t\t\ttype: 'string',\n\t\t\t\tdesc: 'Optional dappsObjectId',\n\t\t\t},\n\t\t});\n\t},\n\n\tasync handler({ network, configPath, dappsObjectId }) {\n\t\ttry {\n\t\t\tconst dubheConfig = (await loadConfig(\n\t\t\t\tconfigPath\n\t\t\t)) as DubheConfig;\n\t\t\tawait publishHandler(dubheConfig, network, dappsObjectId);\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,\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(assets: &mut Assets, _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 assets.id, b\"${field.name}\", ${storage_type});`}).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\nexport async function upgradeHandler(\n\tconfig: DubheConfig,\n\tname: string,\n\tnetwork: 'mainnet' | 'testnet' | 'devnet' | 'localnet',\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\t// let adminCap = await getAdminCap(projectPath, network);\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\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 network: any;\n configPath: string;\n};\n\nconst commandModule: CommandModule<Options, Options> = {\n command: \"upgrade\",\n\n describe: \"Upgrade your move contracts\",\n\n builder(yargs) {\n return yargs.options({\n network: {\n type: \"string\",\n choices: [\"mainnet\", \"testnet\", \"devnet\", \"localnet\"],\n desc: \"Network of the node (mainnet/testnet/devnet/localnet)\",\n },\n configPath: {\n type: \"string\",\n default: \"dubhe.config.ts\",\n decs: \"Path to the config file\",\n },\n });\n },\n\n async handler({ network, configPath }) {\n try {\n const dubheConfig = (await loadConfig(configPath)) as DubheConfig;\n await upgradeHandler(dubheConfig, dubheConfig.name, network);\n } catch (error: any) {\n logError(error);\n process.exit(1);\n }\n process.exit(0);\n },\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","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","getDappsObjectId","network","capitalizeAndRemoveUnderscores","input","word","index","getLastSegment","segments","publishHandler","dubheConfig","dappsObjectId","projectPath","privateKey","DubheCliError","privateKeyFormat","validatePrivateKey","keypair","Dubhe","client","SuiClient","getFullnodeUrl","modules","dependencies","buildResult","execSync","error","chalk","tx","Transaction","upgradeCap","result","version","packageId","schemas","upgradeCapId","schemaHubId","object","resolve","deployHookTx","deployHookResult","structure","schemaKey","saveContractData","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","dappsObjectId","dubheConfig","publishHandler","error","logError","publish_default","Dubhe","Transaction","UpgradePolicy","getFullnodeUrl","SuiClient","execSync","chalk","fs","updateMigrateMethod","projectPath","migrations","migration","filePath","fileContent","migrateMethodRegex","capitalizeAndRemoveUnderscores","newMigrateMethod","field","storage_type","updatedContent","input","word","index","getLastSegment","segments","upgradeHandler","config","name","network","path","privateKey","DubheCliError","privateKeyFormat","validatePrivateKey","keypair","Dubhe","client","SuiClient","getFullnodeUrl","oldVersion","getVersion","oldPackageId","getOldPackageId","schemaHub","getSchemaHub","upgradeCap","getUpgradeCap","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/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,\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 '0x181befc40b3dafe2740b41d5a970e49bed2cca20205506ee6be2cfb73ff2d3e9';\n\t\tdefault:\n\t\t\treturn '0x181befc40b3dafe2740b41d5a970e49bed2cca20205506ee6be2cfb73ff2d3e9';\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', 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: chainIds[networkType] || '',\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 'chain-id':\n\t\t\t\t\tconfig.chainId = value;\n\t\t\t\t\tbreak;\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\n\tconst dappsObjectId = await getDappsObjectId(network);\n\tconsole.log(\"dappsObjectId\", dappsObjectId);\n\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(' ├─ 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', packageId);\n\n\tconsole.log('\\n⚡ Executing Deploy Hook...');\n\tawait new Promise(resolve => setTimeout(resolve, 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\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(' ├─ 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', 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\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 keypair = dubhe.getKeypair();\n\tconsole.log(` └─ Account: ${keypair.toSuiAddress()}`);\n\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\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';\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","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\tconfigPath?: string;\n\tnetwork?: 'mainnet' | 'testnet' | 'devnet' | 'localnet';\n\tframeworkId?: 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\tconfigPath: {\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\tframeworkId: {\n\t\t\ttype: 'string',\n\t\t\tdesc: 'Framework Package ID',\n\t\t},\n\t},\n\n\tasync handler({ configPath, network, frameworkId }) {\n\t\ttry {\n\t\t\tconst dubheConfig = (await loadConfig(\n\t\t\t\tconfigPath\n\t\t\t)) 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\tconfigPath: string;\n\tcontractName?: 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\tconfigPath: {\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\tcontractName: {\n\t\t\t\ttype: 'string',\n\t\t\t\tdesc: 'Optional contract name',\n\t\t\t},\n\t\t});\n\t},\n\n\tasync handler({ network, configPath, contractName }) {\n\t\ttry {\n\t\t\tconst dubheConfig = (await loadConfig(\n\t\t\t\tconfigPath\n\t\t\t)) 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,\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\tconsole.log(`${field} for [env.${networkType}] replaced successfully.`);\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\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 network: any;\n configPath: string;\n};\n\nconst commandModule: CommandModule<Options, Options> = {\n command: \"upgrade\",\n\n describe: \"Upgrade your move contracts\",\n\n builder(yargs) {\n return yargs.options({\n network: {\n type: \"string\",\n choices: [\"mainnet\", \"testnet\", \"devnet\", \"localnet\"],\n desc: \"Network of the node (mainnet/testnet/devnet/localnet)\",\n },\n configPath: {\n type: \"string\",\n default: \"dubhe.config.ts\",\n decs: \"Path to the config file\",\n },\n });\n },\n\n async handler({ network, configPath }) {\n try {\n const dubheConfig = (await loadConfig(configPath)) as DubheConfig;\n await upgradeHandler(dubheConfig, dubheConfig.name, network);\n } catch (error: any) {\n logError(error);\n process.exit(1);\n }\n process.exit(0);\n },\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","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","fs","path","getDappsObjectId","network","getSchemaHub","removeEnvContent","filePath","networkType","content","regex","updatedContent","chainIds","updateEnvFile","operation","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","dappsObjectId","keypair","tx","Transaction","upgradeCap","result","version","packageId","schemas","upgradeCapId","schemaHubId","object","resolve","deployHookTx","txCoin","deployHookResult","structure","schemaKey","saveContractData","publishDubheFramework","publishHandler","contractName","privateKey","DubheCliError","privateKeyFormat","validatePrivateKey","Dubhe","SuiClient","getFullnodeUrl","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","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"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@0xobelisk/sui-cli",
|
|
3
|
-
"version": "0.5.
|
|
3
|
+
"version": "0.5.26",
|
|
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.
|
|
35
|
+
"@0xobelisk/sui-common": "^0.5.22",
|
|
36
36
|
"@mysten/sui": "^1.7.0",
|
|
37
37
|
"chalk": "^5.0.1",
|
|
38
38
|
"child_process": "^1.0.2",
|
package/src/commands/publish.ts
CHANGED
|
@@ -6,7 +6,7 @@ import { loadConfig, DubheConfig } from '@0xobelisk/sui-common';
|
|
|
6
6
|
type Options = {
|
|
7
7
|
network: any;
|
|
8
8
|
configPath: string;
|
|
9
|
-
|
|
9
|
+
contractName?: string;
|
|
10
10
|
};
|
|
11
11
|
|
|
12
12
|
const commandModule: CommandModule<Options, Options> = {
|
|
@@ -26,19 +26,19 @@ const commandModule: CommandModule<Options, Options> = {
|
|
|
26
26
|
default: 'dubhe.config.ts',
|
|
27
27
|
desc: 'Configuration file path',
|
|
28
28
|
},
|
|
29
|
-
|
|
29
|
+
contractName: {
|
|
30
30
|
type: 'string',
|
|
31
|
-
desc: 'Optional
|
|
31
|
+
desc: 'Optional contract name',
|
|
32
32
|
},
|
|
33
33
|
});
|
|
34
34
|
},
|
|
35
35
|
|
|
36
|
-
async handler({ network, configPath,
|
|
36
|
+
async handler({ network, configPath, contractName }) {
|
|
37
37
|
try {
|
|
38
38
|
const dubheConfig = (await loadConfig(
|
|
39
39
|
configPath
|
|
40
40
|
)) as DubheConfig;
|
|
41
|
-
await publishHandler(dubheConfig, network,
|
|
41
|
+
await publishHandler(dubheConfig, network, contractName);
|
|
42
42
|
} catch (error: any) {
|
|
43
43
|
logError(error);
|
|
44
44
|
process.exit(1);
|
|
@@ -12,14 +12,20 @@ import {
|
|
|
12
12
|
updateVersionInFile,
|
|
13
13
|
saveContractData,
|
|
14
14
|
validatePrivateKey,
|
|
15
|
-
schema,
|
|
15
|
+
schema, getSchemaHub,
|
|
16
16
|
} from './utils';
|
|
17
17
|
import { DubheConfig } from '@0xobelisk/sui-common';
|
|
18
|
+
import * as fs from 'fs';
|
|
19
|
+
import * as path from 'path';
|
|
18
20
|
|
|
19
21
|
async function getDappsObjectId(
|
|
20
22
|
network: 'mainnet' | 'testnet' | 'devnet' | 'localnet'
|
|
21
23
|
) {
|
|
22
24
|
switch (network) {
|
|
25
|
+
case "localnet": {
|
|
26
|
+
const path = process.cwd();
|
|
27
|
+
return await getSchemaHub(`${path}/contracts/dubhe-framework`, network)
|
|
28
|
+
}
|
|
23
29
|
case 'testnet':
|
|
24
30
|
return '0x181befc40b3dafe2740b41d5a970e49bed2cca20205506ee6be2cfb73ff2d3e9';
|
|
25
31
|
default:
|
|
@@ -27,6 +33,97 @@ async function getDappsObjectId(
|
|
|
27
33
|
}
|
|
28
34
|
}
|
|
29
35
|
|
|
36
|
+
function removeEnvContent(filePath: string, networkType: 'mainnet' | 'testnet' | 'devnet' | 'localnet'): void {
|
|
37
|
+
if (!fs.existsSync(filePath)) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
const content = fs.readFileSync(filePath, 'utf-8');
|
|
41
|
+
const regex = new RegExp(`\\[env\\.${networkType}\\][\\s\\S]*?(?=\\[|$)`, 'g');
|
|
42
|
+
const updatedContent = content.replace(regex, '');
|
|
43
|
+
fs.writeFileSync(filePath, updatedContent, 'utf-8');
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
interface EnvConfig {
|
|
47
|
+
chainId: string;
|
|
48
|
+
originalPublishedId: string;
|
|
49
|
+
latestPublishedId: string;
|
|
50
|
+
publishedVersion: number;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
const chainIds: { [key: string]: string } = {
|
|
54
|
+
localnet: 'dfa7bb83',
|
|
55
|
+
testnet: '4c78adac',
|
|
56
|
+
mainnet: '35834a8a',
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
function updateEnvFile(filePath: string, networkType: 'mainnet' | 'testnet' | 'devnet' | 'localnet', operation: 'publish' | 'upgrade', publishedId: string): void {
|
|
60
|
+
const envFilePath = path.resolve(filePath);
|
|
61
|
+
const envContent = fs.readFileSync(envFilePath, 'utf-8');
|
|
62
|
+
const envLines = envContent.split('\n');
|
|
63
|
+
|
|
64
|
+
const networkSectionIndex = envLines.findIndex(line => line.trim() === `[env.${networkType}]`);
|
|
65
|
+
const config: EnvConfig = {
|
|
66
|
+
chainId: chainIds[networkType] || '',
|
|
67
|
+
originalPublishedId: '',
|
|
68
|
+
latestPublishedId: '',
|
|
69
|
+
publishedVersion: 0,
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
if (networkSectionIndex === -1) {
|
|
73
|
+
// If network section is not found, add a new section
|
|
74
|
+
if (operation === 'publish') {
|
|
75
|
+
config.originalPublishedId = publishedId;
|
|
76
|
+
config.latestPublishedId = publishedId;
|
|
77
|
+
config.publishedVersion = 1;
|
|
78
|
+
} else {
|
|
79
|
+
throw new Error(`Network type [env.${networkType}] not found in the file and cannot upgrade.`);
|
|
80
|
+
}
|
|
81
|
+
} else {
|
|
82
|
+
for (let i = networkSectionIndex + 1; i < envLines.length; i++) {
|
|
83
|
+
const line = envLines[i].trim();
|
|
84
|
+
if (line.startsWith('[')) break; // End of the current network section
|
|
85
|
+
|
|
86
|
+
const [key, value] = line.split('=').map(part => part.trim().replace(/"/g, ''));
|
|
87
|
+
switch (key) {
|
|
88
|
+
case 'chain-id':
|
|
89
|
+
config.chainId = value;
|
|
90
|
+
break;
|
|
91
|
+
case 'original-published-id':
|
|
92
|
+
config.originalPublishedId = value;
|
|
93
|
+
break;
|
|
94
|
+
case 'latest-published-id':
|
|
95
|
+
config.latestPublishedId = value;
|
|
96
|
+
break;
|
|
97
|
+
case 'published-version':
|
|
98
|
+
config.publishedVersion = parseInt(value, 10);
|
|
99
|
+
break;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
if (operation === 'publish') {
|
|
104
|
+
config.originalPublishedId = publishedId;
|
|
105
|
+
config.latestPublishedId = publishedId;
|
|
106
|
+
config.publishedVersion = 1;
|
|
107
|
+
} else if (operation === 'upgrade') {
|
|
108
|
+
config.latestPublishedId = publishedId;
|
|
109
|
+
config.publishedVersion += 1;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
const updatedSection = `
|
|
114
|
+
[env.${networkType}]
|
|
115
|
+
chain-id = "${config.chainId}"
|
|
116
|
+
original-published-id = "${config.originalPublishedId}"
|
|
117
|
+
latest-published-id = "${config.latestPublishedId}"
|
|
118
|
+
published-version = "${config.publishedVersion}"
|
|
119
|
+
`;
|
|
120
|
+
|
|
121
|
+
const newEnvContent = networkSectionIndex === -1
|
|
122
|
+
? envContent + updatedSection
|
|
123
|
+
: envLines.slice(0, networkSectionIndex).join('\n') + updatedSection;
|
|
124
|
+
|
|
125
|
+
fs.writeFileSync(envFilePath, newEnvContent, 'utf-8');
|
|
126
|
+
}
|
|
30
127
|
function capitalizeAndRemoveUnderscores(input: string): string {
|
|
31
128
|
return input
|
|
32
129
|
.split('_')
|
|
@@ -43,42 +140,7 @@ function getLastSegment(input: string): string {
|
|
|
43
140
|
return segments.length > 0 ? segments[segments.length - 1] : '';
|
|
44
141
|
}
|
|
45
142
|
|
|
46
|
-
|
|
47
|
-
dubheConfig: DubheConfig,
|
|
48
|
-
network: 'mainnet' | 'testnet' | 'devnet' | 'localnet',
|
|
49
|
-
dappsObjectId?: string
|
|
50
|
-
) {
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
const path = process.cwd();
|
|
54
|
-
const projectPath = `${path}/contracts/${dubheConfig.name}`;
|
|
55
|
-
dappsObjectId = dappsObjectId || (await getDappsObjectId(network));
|
|
56
|
-
|
|
57
|
-
console.log('\n🚀 Starting Contract Publication...');
|
|
58
|
-
console.log(` ├─ Project: ${projectPath}`);
|
|
59
|
-
console.log(` ├─ Network: ${network}`);
|
|
60
|
-
console.log(' ├─ Validating Environment...');
|
|
61
|
-
const privateKey = process.env.PRIVATE_KEY;
|
|
62
|
-
if (!privateKey) {
|
|
63
|
-
throw new DubheCliError(
|
|
64
|
-
`Missing PRIVATE_KEY environment variable.
|
|
65
|
-
Run 'echo "PRIVATE_KEY=YOUR_PRIVATE_KEY" > .env'
|
|
66
|
-
in your contracts directory to use the default sui private key.`
|
|
67
|
-
);
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
const privateKeyFormat = validatePrivateKey(privateKey);
|
|
71
|
-
if (privateKeyFormat === false) {
|
|
72
|
-
throw new DubheCliError(`Please check your privateKey.`);
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
const dubhe = new Dubhe({ secretKey: privateKeyFormat });
|
|
76
|
-
const keypair = dubhe.getKeypair();
|
|
77
|
-
console.log(` └─ Account: ${keypair.toSuiAddress()}`);
|
|
78
|
-
|
|
79
|
-
const client = new SuiClient({ url: getFullnodeUrl(network) });
|
|
80
|
-
|
|
81
|
-
console.log('\n📦 Building Contract...');
|
|
143
|
+
function buildContract(projectPath: string): string[][] {
|
|
82
144
|
let modules: any, dependencies: any;
|
|
83
145
|
try {
|
|
84
146
|
const buildResult = JSON.parse(
|
|
@@ -97,6 +159,31 @@ in your contracts directory to use the default sui private key.`
|
|
|
97
159
|
console.error(error.stdout);
|
|
98
160
|
process.exit(1);
|
|
99
161
|
}
|
|
162
|
+
return [modules, dependencies];
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
async function publishContract(
|
|
166
|
+
client: SuiClient,
|
|
167
|
+
dubhe: Dubhe,
|
|
168
|
+
dubheConfig: DubheConfig,
|
|
169
|
+
network: 'mainnet' | 'testnet' | 'devnet' | 'localnet',
|
|
170
|
+
projectPath: string
|
|
171
|
+
) {
|
|
172
|
+
|
|
173
|
+
const dappsObjectId = await getDappsObjectId(network);
|
|
174
|
+
console.log("dappsObjectId", dappsObjectId);
|
|
175
|
+
|
|
176
|
+
removeEnvContent(`${projectPath}/Move.lock`, network);
|
|
177
|
+
console.log('\n🚀 Starting Contract Publication...');
|
|
178
|
+
console.log(` ├─ Project: ${projectPath}`);
|
|
179
|
+
console.log(` ├─ Network: ${network}`);
|
|
180
|
+
console.log(' ├─ Validating Environment...');
|
|
181
|
+
|
|
182
|
+
const keypair = dubhe.getKeypair();
|
|
183
|
+
console.log(` └─ Account: ${keypair.toSuiAddress()}`);
|
|
184
|
+
|
|
185
|
+
console.log('\n📦 Building Contract...');
|
|
186
|
+
const [modules, dependencies] = buildContract(projectPath);
|
|
100
187
|
|
|
101
188
|
console.log('\n🔄 Publishing Contract...');
|
|
102
189
|
const tx = new Transaction();
|
|
@@ -151,10 +238,14 @@ in your contracts directory to use the default sui private key.`
|
|
|
151
238
|
|
|
152
239
|
console.log(` └─ Transaction: ${result.digest}`);
|
|
153
240
|
|
|
241
|
+
updateEnvFile(`${projectPath}/Move.lock`, network, 'publish', packageId);
|
|
242
|
+
|
|
154
243
|
console.log('\n⚡ Executing Deploy Hook...');
|
|
155
244
|
await new Promise(resolve => setTimeout(resolve, 5000));
|
|
156
245
|
|
|
157
246
|
const deployHookTx = new Transaction();
|
|
247
|
+
deployHookTx.setGasBudget(2000000000);
|
|
248
|
+
const [txCoin] = deployHookTx.splitCoins(deployHookTx.gas, ["1000000000"]);
|
|
158
249
|
deployHookTx.moveCall({
|
|
159
250
|
target: `${packageId}::deploy_hook::run`,
|
|
160
251
|
arguments: [
|
|
@@ -162,6 +253,7 @@ in your contracts directory to use the default sui private key.`
|
|
|
162
253
|
deployHookTx.object(dappsObjectId),
|
|
163
254
|
deployHookTx.object(upgradeCapId),
|
|
164
255
|
deployHookTx.object('0x6'),
|
|
256
|
+
txCoin
|
|
165
257
|
],
|
|
166
258
|
});
|
|
167
259
|
|
|
@@ -225,3 +317,123 @@ in your contracts directory to use the default sui private key.`
|
|
|
225
317
|
);
|
|
226
318
|
}
|
|
227
319
|
}
|
|
320
|
+
|
|
321
|
+
async function publishDubheFramework(
|
|
322
|
+
client: SuiClient,
|
|
323
|
+
dubhe: Dubhe,
|
|
324
|
+
network: 'mainnet' | 'testnet' | 'devnet' | 'localnet',
|
|
325
|
+
) {
|
|
326
|
+
const path = process.cwd();
|
|
327
|
+
const projectPath = `${path}/contracts/dubhe-framework`;
|
|
328
|
+
|
|
329
|
+
removeEnvContent(`${projectPath}/Move.lock`, network);
|
|
330
|
+
console.log('\n🚀 Starting Contract Publication...');
|
|
331
|
+
console.log(` ├─ Project: ${projectPath}`);
|
|
332
|
+
console.log(` ├─ Network: ${network}`);
|
|
333
|
+
console.log(' ├─ Validating Environment...');
|
|
334
|
+
|
|
335
|
+
const keypair = dubhe.getKeypair();
|
|
336
|
+
console.log(` └─ Account: ${keypair.toSuiAddress()}`);
|
|
337
|
+
|
|
338
|
+
|
|
339
|
+
console.log('\n📦 Building Contract...');
|
|
340
|
+
const [modules, dependencies] = buildContract(projectPath);
|
|
341
|
+
|
|
342
|
+
console.log('\n🔄 Publishing Contract...');
|
|
343
|
+
const tx = new Transaction();
|
|
344
|
+
const [upgradeCap] = tx.publish({ modules, dependencies });
|
|
345
|
+
tx.transferObjects([upgradeCap], keypair.toSuiAddress());
|
|
346
|
+
|
|
347
|
+
let result: SuiTransactionBlockResponse;
|
|
348
|
+
try {
|
|
349
|
+
result = await client.signAndExecuteTransaction({
|
|
350
|
+
signer: keypair,
|
|
351
|
+
transaction: tx,
|
|
352
|
+
options: { showObjectChanges: true },
|
|
353
|
+
});
|
|
354
|
+
} catch (error: any) {
|
|
355
|
+
console.error(chalk.red(' └─ Publication failed'));
|
|
356
|
+
console.error(error.message);
|
|
357
|
+
process.exit(1);
|
|
358
|
+
}
|
|
359
|
+
|
|
360
|
+
if (result.effects?.status.status === 'failure') {
|
|
361
|
+
console.log(chalk.red(' └─ Publication failed'));
|
|
362
|
+
process.exit(1);
|
|
363
|
+
}
|
|
364
|
+
|
|
365
|
+
console.log(' ├─ Processing publication results...');
|
|
366
|
+
let version = 1;
|
|
367
|
+
let packageId = '';
|
|
368
|
+
let schemas: schema[] = [];
|
|
369
|
+
let upgradeCapId = '';
|
|
370
|
+
let schemaHubId = '';
|
|
371
|
+
|
|
372
|
+
result.objectChanges!.map(object => {
|
|
373
|
+
if (object.type === 'published') {
|
|
374
|
+
console.log(` ├─ Package ID: ${object.packageId}`);
|
|
375
|
+
packageId = object.packageId;
|
|
376
|
+
}
|
|
377
|
+
if (
|
|
378
|
+
object.type === 'created' &&
|
|
379
|
+
object.objectType === '0x2::package::UpgradeCap'
|
|
380
|
+
) {
|
|
381
|
+
console.log(` ├─ Upgrade Cap: ${object.objectId}`);
|
|
382
|
+
upgradeCapId = object.objectId;
|
|
383
|
+
}
|
|
384
|
+
if (
|
|
385
|
+
object.type === 'created' &&
|
|
386
|
+
object.objectType.includes("dapps")
|
|
387
|
+
) {
|
|
388
|
+
console.log(` ├─ Dapps: ${object.objectId}`);
|
|
389
|
+
schemaHubId = object.objectId;
|
|
390
|
+
}
|
|
391
|
+
});
|
|
392
|
+
|
|
393
|
+
console.log(` └─ Transaction: ${result.digest}`);
|
|
394
|
+
|
|
395
|
+
updateEnvFile(`${projectPath}/Move.lock`, network, 'publish', packageId);
|
|
396
|
+
|
|
397
|
+
saveContractData(
|
|
398
|
+
"dubhe-framework",
|
|
399
|
+
network,
|
|
400
|
+
packageId,
|
|
401
|
+
upgradeCapId,
|
|
402
|
+
schemaHubId,
|
|
403
|
+
version,
|
|
404
|
+
schemas,
|
|
405
|
+
);
|
|
406
|
+
}
|
|
407
|
+
|
|
408
|
+
export async function publishHandler(
|
|
409
|
+
dubheConfig: DubheConfig,
|
|
410
|
+
network: 'mainnet' | 'testnet' | 'devnet' | 'localnet',
|
|
411
|
+
contractName?: string,
|
|
412
|
+
) {
|
|
413
|
+
const privateKey = process.env.PRIVATE_KEY;
|
|
414
|
+
if (!privateKey) {
|
|
415
|
+
throw new DubheCliError(
|
|
416
|
+
`Missing PRIVATE_KEY environment variable.
|
|
417
|
+
Run 'echo "PRIVATE_KEY=YOUR_PRIVATE_KEY" > .env'
|
|
418
|
+
in your contracts directory to use the default sui private key.`
|
|
419
|
+
);
|
|
420
|
+
}
|
|
421
|
+
const privateKeyFormat = validatePrivateKey(privateKey);
|
|
422
|
+
if (privateKeyFormat === false) {
|
|
423
|
+
throw new DubheCliError(`Please check your privateKey.`);
|
|
424
|
+
}
|
|
425
|
+
|
|
426
|
+
const dubhe = new Dubhe({ secretKey: privateKeyFormat });
|
|
427
|
+
const keypair = dubhe.getKeypair();
|
|
428
|
+
console.log(` └─ Account: ${keypair.toSuiAddress()}`);
|
|
429
|
+
|
|
430
|
+
const client = new SuiClient({ url: getFullnodeUrl(network) });
|
|
431
|
+
|
|
432
|
+
if (contractName == "dubhe-framework") {
|
|
433
|
+
await publishDubheFramework(client, dubhe, network);
|
|
434
|
+
} else {
|
|
435
|
+
const path = process.cwd();
|
|
436
|
+
const projectPath = `${path}/contracts/${dubheConfig.name}`;
|
|
437
|
+
await publishContract(client, dubhe, dubheConfig, network, projectPath);
|
|
438
|
+
}
|
|
439
|
+
}
|
|
@@ -39,9 +39,9 @@ function updateMigrateMethod(projectPath: string, migrations: Migration[]): void
|
|
|
39
39
|
const fileContent = fs.readFileSync(filePath, 'utf-8');
|
|
40
40
|
const migrateMethodRegex = new RegExp(`public fun migrate\\(_${migration.schemaName}: &mut ${capitalizeAndRemoveUnderscores(migration.schemaName)}, _cap: &UpgradeCap\\) {[^}]*}`);
|
|
41
41
|
const newMigrateMethod = `
|
|
42
|
-
public fun migrate(
|
|
42
|
+
public fun migrate(${migration.schemaName}: &mut ${capitalizeAndRemoveUnderscores(migration.schemaName)}, _cap: &UpgradeCap) {
|
|
43
43
|
${migration.fields.map((field) => {
|
|
44
|
-
let storage_type =
|
|
44
|
+
let storage_type = '';
|
|
45
45
|
if (field.type.includes('StorageValue')) {
|
|
46
46
|
storage_type = `storage_value::new()`;
|
|
47
47
|
} else if (field.type.includes('StorageMap')) {
|
|
@@ -51,13 +51,14 @@ ${migration.fields.map((field) => {
|
|
|
51
51
|
) {
|
|
52
52
|
storage_type = `storage_double_map::new()`;
|
|
53
53
|
}
|
|
54
|
-
return `storage_migrate::add_field<${field.type}>(&mut
|
|
54
|
+
return `storage_migrate::add_field<${field.type}>(&mut ${migration.schemaName}.id, b"${field.name}", ${storage_type});`;
|
|
55
|
+
}).join('')}
|
|
55
56
|
}
|
|
56
57
|
`;
|
|
57
58
|
|
|
58
59
|
const updatedContent = fileContent.replace(migrateMethodRegex, newMigrateMethod);
|
|
59
60
|
fs.writeFileSync(filePath, updatedContent, 'utf-8');
|
|
60
|
-
})
|
|
61
|
+
});
|
|
61
62
|
|
|
62
63
|
|
|
63
64
|
}
|
|
@@ -78,6 +79,46 @@ function getLastSegment(input: string): string {
|
|
|
78
79
|
return segments.length > 0 ? segments[segments.length - 1] : '';
|
|
79
80
|
}
|
|
80
81
|
|
|
82
|
+
function replaceEnvField(
|
|
83
|
+
filePath: string,
|
|
84
|
+
networkType: 'mainnet' | 'testnet' | 'devnet' | 'localnet',
|
|
85
|
+
field: 'original-published-id' | 'latest-published-id' | 'published-version',
|
|
86
|
+
newValue: string
|
|
87
|
+
): string {
|
|
88
|
+
const envFilePath = path.resolve(filePath);
|
|
89
|
+
const envContent = fs.readFileSync(envFilePath, 'utf-8');
|
|
90
|
+
const envLines = envContent.split('\n');
|
|
91
|
+
|
|
92
|
+
const networkSectionIndex = envLines.findIndex(line => line.trim() === `[env.${networkType}]`);
|
|
93
|
+
if (networkSectionIndex === -1) {
|
|
94
|
+
console.log(`Network type [env.${networkType}] not found in the file.`);
|
|
95
|
+
return "";
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
let fieldIndex = -1;
|
|
99
|
+
let previousValue: string = "";
|
|
100
|
+
for (let i = networkSectionIndex + 1; i < envLines.length; i++) {
|
|
101
|
+
const line = envLines[i].trim();
|
|
102
|
+
if (line.startsWith('[')) break; // End of the current network section
|
|
103
|
+
|
|
104
|
+
if (line.startsWith(field)) {
|
|
105
|
+
fieldIndex = i;
|
|
106
|
+
previousValue = line.split('=')[1].trim().replace(/"/g, '');
|
|
107
|
+
break;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
if (fieldIndex !== -1) {
|
|
112
|
+
envLines[fieldIndex] = `${field} = "${newValue}"`;
|
|
113
|
+
const newEnvContent = envLines.join('\n');
|
|
114
|
+
fs.writeFileSync(envFilePath, newEnvContent, 'utf-8');
|
|
115
|
+
console.log(`${field} for [env.${networkType}] replaced successfully.`);
|
|
116
|
+
} else {
|
|
117
|
+
console.log(`${field} not found for [env.${networkType}].`);
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
return previousValue;
|
|
121
|
+
}
|
|
81
122
|
export async function upgradeHandler(
|
|
82
123
|
config: DubheConfig,
|
|
83
124
|
name: string,
|
|
@@ -90,7 +131,7 @@ export async function upgradeHandler(
|
|
|
90
131
|
throw new DubheCliError(
|
|
91
132
|
`Missing PRIVATE_KEY environment variable.
|
|
92
133
|
Run 'echo "PRIVATE_KEY=YOUR_PRIVATE_KEY" > .env'
|
|
93
|
-
in your contracts directory to use the default sui private key
|
|
134
|
+
in your contracts directory to use the default sui private key.`,
|
|
94
135
|
);
|
|
95
136
|
|
|
96
137
|
const privateKeyFormat = validatePrivateKey(privateKey);
|
|
@@ -110,7 +151,8 @@ in your contracts directory to use the default sui private key.`
|
|
|
110
151
|
let oldPackageId = await getOldPackageId(projectPath, network);
|
|
111
152
|
let schemaHub = await getSchemaHub(projectPath, network);
|
|
112
153
|
let upgradeCap = await getUpgradeCap(projectPath, network);
|
|
113
|
-
|
|
154
|
+
|
|
155
|
+
const original_published_id = replaceEnvField(`${projectPath}/Move.lock`, network, 'original-published-id', "0x0000000000000000000000000000000000000000000000000000000000000000");
|
|
114
156
|
|
|
115
157
|
let pendingMigration: Migration[] = [];
|
|
116
158
|
let schemas = await getOnchainSchemas(projectPath, network);
|
|
@@ -126,17 +168,17 @@ in your contracts directory to use the default sui private key.`
|
|
|
126
168
|
fields.push({
|
|
127
169
|
name: key,
|
|
128
170
|
type: config.schemas[schemaKey].structure[key],
|
|
129
|
-
})
|
|
171
|
+
});
|
|
130
172
|
schema.structure[key] = config.schemas[schemaKey].structure[key];
|
|
131
173
|
}
|
|
132
174
|
}
|
|
133
175
|
if (isMigration) {
|
|
134
176
|
migrate.schemaName = schemaKey;
|
|
135
177
|
migrate.fields = fields;
|
|
136
|
-
pendingMigration.push(migrate)
|
|
178
|
+
pendingMigration.push(migrate);
|
|
137
179
|
}
|
|
138
180
|
}
|
|
139
|
-
})
|
|
181
|
+
});
|
|
140
182
|
}
|
|
141
183
|
|
|
142
184
|
|
|
@@ -158,8 +200,8 @@ in your contracts directory to use the default sui private key.`
|
|
|
158
200
|
`sui move build --dump-bytecode-as-base64 --path ${path}/contracts/${name}`,
|
|
159
201
|
{
|
|
160
202
|
encoding: 'utf-8',
|
|
161
|
-
}
|
|
162
|
-
)
|
|
203
|
+
},
|
|
204
|
+
),
|
|
163
205
|
);
|
|
164
206
|
|
|
165
207
|
modules = extractedModules;
|
|
@@ -208,17 +250,21 @@ in your contracts directory to use the default sui private key.`
|
|
|
208
250
|
result.objectChanges!.map(object => {
|
|
209
251
|
if (object.type === 'published') {
|
|
210
252
|
console.log(
|
|
211
|
-
chalk.blue(`${name} PackageId: ${object.packageId}`)
|
|
253
|
+
chalk.blue(`${name} PackageId: ${object.packageId}`),
|
|
212
254
|
);
|
|
213
255
|
console.log(
|
|
214
|
-
chalk.blue(`${name} Version: ${oldVersion + 1}`)
|
|
256
|
+
chalk.blue(`${name} Version: ${oldVersion + 1}`),
|
|
215
257
|
);
|
|
216
258
|
newPackageId = object.packageId;
|
|
217
259
|
}
|
|
218
260
|
});
|
|
219
261
|
|
|
262
|
+
replaceEnvField(`${projectPath}/Move.lock`, network, 'original-published-id', original_published_id);
|
|
263
|
+
replaceEnvField(`${projectPath}/Move.lock`, network, 'latest-published-id', newPackageId);
|
|
264
|
+
replaceEnvField(`${projectPath}/Move.lock`, network, 'published-version', (oldVersion + 1) + "");
|
|
265
|
+
|
|
220
266
|
console.log(
|
|
221
|
-
chalk.green(`Upgrade Transaction Digest: ${result.digest}`)
|
|
267
|
+
chalk.green(`Upgrade Transaction Digest: ${result.digest}`),
|
|
222
268
|
);
|
|
223
269
|
|
|
224
270
|
saveContractData(
|