@gabrielhicks/solv 5.3.13 → 5.3.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- var Oa=Object.defineProperty;var r=(t,e)=>Oa(t,"name",{value:e,configurable:!0});import"dotenv/config";import{Command as zd}from"commander";var ir="5.3.13";var ar={name:"@gabrielhicks/solv",version:ir,description:"Solana Validator CLI SOLV",main:"dist/index.js",type:"module",repository:"https://github.com/gabrielhicks/solv",keywords:["solana","validator","cli","validator-tool","Node.js","web3"],files:["dist"],author:"ELSOUL LABO B.V.",private:!1,license:"Apache-2.0",bin:{solv:"./dist/index.js"},scripts:{test:"vitest",build:"tsup src/index.ts && npx tsx add-line.ts",dev:"nodemon",start:"node dist/index.js"},dependencies:{"@jup-ag/api":"6.0.27","@metaplex-foundation/mpl-token-metadata":"3.2.1","@metaplex-foundation/umi":"0.9.2","@metaplex-foundation/umi-bundle-defaults":"0.9.2","@skeet-framework/utils":"1.3.11","@solana/spl-stake-pool":"1.1.5","@solana/spl-token":"0.4.8","@solana/web3.js":"1.95.4","bigint-buffer":"1.1.5","bn.js":"5.2.1",bs58:"6.0.0",chalk:"5.3.0","chalk-pipe":"6.1.0","cli-progress":"3.12.0","cli-spinner":"0.2.10","cli-table3":"0.6.5",commander:"12.1.0",dotenv:"16.4.5",inquirer:"10.2.0","node-fetch":"3.3.2",prompt:"1.3.0"},devDependencies:{"@changesets/changelog-github":"0.5.0","@changesets/cli":"2.27.7","@solana-developers/helpers":"^2.5.6","@swc/core":"1.7.21","@types/bn.js":"5.1.5","@types/cli-progress":"3.11.6","@types/cli-spinner":"0.2.3","@types/inquirer":"9.0.7","@types/node":"22.5.1","@types/node-fetch":"2.6.11","@types/prompt":"1.1.8","@typescript-eslint/eslint-plugin":"8.3.0","@typescript-eslint/parser":"8.3.0",eslint:"9.9.1","eslint-config-prettier":"9.1.0",nodemon:"3.1.7",prettier:"3.3.3",tsup:"8.2.4",typescript:"5.5.4",vite:"5.4.2","vite-tsconfig-paths":"5.0.1",vitest:"2.0.5"}};var Ae=ar.version;var te="https://validators.solutions";var we="solv4.config.json";var vt="identity.json",Nt="unstaked-identity.json",lr="relayer-keypair.json",ka="mainnet-validator-keypair.json",La="mainnet-vote-account-keypair.json",Ia="mainnet-authority-keypair.json",Pa="testnet-validator-keypair.json",xa="testnet-vote-account-keypair.json",$a="testnet-authority-keypair.json",V="/home/solv",k=`${V}/${vt}`,su=`${V}/${Nt}`,M=`${V}/${ka}`,_e=`${V}/${La}`,nu=`${V}/${Ia}`,b=`${V}/${Pa}`,ve=`${V}/${xa}`,iu=`${V}/${$a}`,Q=`${V}/solana-validator.log`,st=V+"/start-validator.sh",N="/mnt/ledger",xt="/mnt/accounts",nt="/mnt/snapshots",cr="solana-validator",mr="agave-validator",pr="ELLB9W7ZCwRCV3FzWcCWoyKP6NjZJKArLyGtkqefnHcG";var Ne=3,dr="https://api.testnet.solana.com",ur="https://api.mainnet-beta.solana.com",hr="https://verify.validators.solutions/solv-migrate",fr="https://jup.validators.solutions/v1/jup",Oo;(function(t){t.SOL="SOL",t.USDC="USDC",t.elSOL="elSOL",t.JitoSOL="JitoSOL",t.mSOL="mSOL",t.bSOL="bSOL",t.EPCT="EPCT",t.JUP="JUP",t.BONK="BONK",t.JTO="JTO"})(Oo||(Oo={}));var yr=Object.values(Oo),Re="So11111111111111111111111111111111111111112",Oe="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",Co="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC";var Sr="SOLV420",Tr={So11111111111111111111111111111111111111112:"4Vwkpk3DTVrTGnUQTazsgQ1wxtU9QwZTmAXDaQRHg9Ra",EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v:"J8sqx9ZEoPRqboFAXK3c1R38zm41tRNJgUn2FzyeYQDj",J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn:"HPj87TFMPZfm5nk1HmTH9a382RXn7h9oWftiFr3Xs12a",mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So:"8CX5tE9KvJ59HcoXwWf6tCZoRuz2JFSmunnbKC1ryaK9",bSo13r4TkiE4KumL71LsHTPpL2euBYLFx6h9HP3piy1:"782MdvLby3VfvKdfDYn9tX3DfNAtg7TcytNNFuepcoMH",CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP:"BhR2L6J5q3xF1TxReXyHjaUh4MF6qV99tMsipzPAKeB",JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN:"212yg3Ev7khq4p1mESFGenF4nWefmkbC8f7mHM68j4vg",DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263:"61Ndjv9392jPRVGALdYgjjxGYa6TT6Gn2WLDSsmugE6U",jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL:"2c9qVh8RQ6j2E2VdAEcCrRXMrd6g1vvPNZvAR6sbaGWo"};import{spawnSync as Da}from"child_process";import{spawnSync as w}from"node:child_process";var Va=r((t,e=!1)=>{e?(w("sudo apt-get update",{shell:!0,stdio:"inherit"}),w("sudo apt-get install -y libclang-18-dev clang-18 llvm-18-dev",{shell:!0,stdio:"inherit"}),w("grep -qxF 'export LIBCLANG_PATH=/usr/lib/llvm-18/lib' /home/solv/.profile || echo 'export LIBCLANG_PATH=/usr/lib/llvm-18/lib' >> /home/solv/.profile",{shell:!0,stdio:"inherit"}),w("grep -qxF 'export CLANG_PATH=/usr/bin/clang-18' /home/solv/.profile || echo 'export CLANG_PATH=/usr/bin/clang-18' >> /home/solv/.profile",{shell:!0,stdio:"inherit"}),w("source /home/solv/.profile",{shell:!0,stdio:"inherit"}),w(`mkdir /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),w(`cd /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),w(`git clone https://github.com/gabrielhicks/agave.git --recurse-submodules /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),w(`git -C /tmp/${t}-agave-mod checkout ${t}-mod`,{shell:!0,stdio:"inherit"}),w(`git -C /tmp/${t}-agave-mod submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),w(`CI_COMMIT=$(git -C /tmp/${t}-agave-mod rev-parse HEAD) /tmp/${t}-agave-mod/scripts/cargo-install-all.sh --validator-only /home/solv/.local/share/solana/install/releases/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),w("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),w(`cp -r /home/solv/.local/share/solana/install/releases/${t}-agave-mod/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),w(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
2
+ var Oa=Object.defineProperty;var r=(t,e)=>Oa(t,"name",{value:e,configurable:!0});import"dotenv/config";import{Command as zd}from"commander";var ir="5.3.14";var ar={name:"@gabrielhicks/solv",version:ir,description:"Solana Validator CLI SOLV",main:"dist/index.js",type:"module",repository:"https://github.com/gabrielhicks/solv",keywords:["solana","validator","cli","validator-tool","Node.js","web3"],files:["dist"],author:"ELSOUL LABO B.V.",private:!1,license:"Apache-2.0",bin:{solv:"./dist/index.js"},scripts:{test:"vitest",build:"tsup src/index.ts && npx tsx add-line.ts",dev:"nodemon",start:"node dist/index.js"},dependencies:{"@jup-ag/api":"6.0.27","@metaplex-foundation/mpl-token-metadata":"3.2.1","@metaplex-foundation/umi":"0.9.2","@metaplex-foundation/umi-bundle-defaults":"0.9.2","@skeet-framework/utils":"1.3.11","@solana/spl-stake-pool":"1.1.5","@solana/spl-token":"0.4.8","@solana/web3.js":"1.95.4","bigint-buffer":"1.1.5","bn.js":"5.2.1",bs58:"6.0.0",chalk:"5.3.0","chalk-pipe":"6.1.0","cli-progress":"3.12.0","cli-spinner":"0.2.10","cli-table3":"0.6.5",commander:"12.1.0",dotenv:"16.4.5",inquirer:"10.2.0","node-fetch":"3.3.2",prompt:"1.3.0"},devDependencies:{"@changesets/changelog-github":"0.5.0","@changesets/cli":"2.27.7","@solana-developers/helpers":"^2.5.6","@swc/core":"1.7.21","@types/bn.js":"5.1.5","@types/cli-progress":"3.11.6","@types/cli-spinner":"0.2.3","@types/inquirer":"9.0.7","@types/node":"22.5.1","@types/node-fetch":"2.6.11","@types/prompt":"1.1.8","@typescript-eslint/eslint-plugin":"8.3.0","@typescript-eslint/parser":"8.3.0",eslint:"9.9.1","eslint-config-prettier":"9.1.0",nodemon:"3.1.7",prettier:"3.3.3",tsup:"8.2.4",typescript:"5.5.4",vite:"5.4.2","vite-tsconfig-paths":"5.0.1",vitest:"2.0.5"}};var Ae=ar.version;var te="https://validators.solutions";var we="solv4.config.json";var vt="identity.json",Nt="unstaked-identity.json",lr="relayer-keypair.json",ka="mainnet-validator-keypair.json",La="mainnet-vote-account-keypair.json",Ia="mainnet-authority-keypair.json",Pa="testnet-validator-keypair.json",xa="testnet-vote-account-keypair.json",$a="testnet-authority-keypair.json",V="/home/solv",k=`${V}/${vt}`,su=`${V}/${Nt}`,M=`${V}/${ka}`,_e=`${V}/${La}`,nu=`${V}/${Ia}`,b=`${V}/${Pa}`,ve=`${V}/${xa}`,iu=`${V}/${$a}`,Q=`${V}/solana-validator.log`,st=V+"/start-validator.sh",N="/mnt/ledger",xt="/mnt/accounts",nt="/mnt/snapshots",cr="solana-validator",mr="agave-validator",pr="ELLB9W7ZCwRCV3FzWcCWoyKP6NjZJKArLyGtkqefnHcG";var Ne=3,dr="https://api.testnet.solana.com",ur="https://api.mainnet-beta.solana.com",hr="https://verify.validators.solutions/solv-migrate",fr="https://jup.validators.solutions/v1/jup",Oo;(function(t){t.SOL="SOL",t.USDC="USDC",t.elSOL="elSOL",t.JitoSOL="JitoSOL",t.mSOL="mSOL",t.bSOL="bSOL",t.EPCT="EPCT",t.JUP="JUP",t.BONK="BONK",t.JTO="JTO"})(Oo||(Oo={}));var yr=Object.values(Oo),Re="So11111111111111111111111111111111111111112",Oe="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",Co="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC";var Sr="SOLV420",Tr={So11111111111111111111111111111111111111112:"4Vwkpk3DTVrTGnUQTazsgQ1wxtU9QwZTmAXDaQRHg9Ra",EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v:"J8sqx9ZEoPRqboFAXK3c1R38zm41tRNJgUn2FzyeYQDj",J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn:"HPj87TFMPZfm5nk1HmTH9a382RXn7h9oWftiFr3Xs12a",mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So:"8CX5tE9KvJ59HcoXwWf6tCZoRuz2JFSmunnbKC1ryaK9",bSo13r4TkiE4KumL71LsHTPpL2euBYLFx6h9HP3piy1:"782MdvLby3VfvKdfDYn9tX3DfNAtg7TcytNNFuepcoMH",CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP:"BhR2L6J5q3xF1TxReXyHjaUh4MF6qV99tMsipzPAKeB",JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN:"212yg3Ev7khq4p1mESFGenF4nWefmkbC8f7mHM68j4vg",DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263:"61Ndjv9392jPRVGALdYgjjxGYa6TT6Gn2WLDSsmugE6U",jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL:"2c9qVh8RQ6j2E2VdAEcCrRXMrd6g1vvPNZvAR6sbaGWo"};import{spawnSync as Da}from"child_process";import{spawnSync as w}from"node:child_process";var Va=r((t,e=!1)=>{e?(w("sudo apt-get update",{shell:!0,stdio:"inherit"}),w("sudo apt-get install -y libclang-18-dev clang-18 llvm-18-dev",{shell:!0,stdio:"inherit"}),w("grep -qxF 'export LIBCLANG_PATH=/usr/lib/llvm-18/lib' /home/solv/.profile || echo 'export LIBCLANG_PATH=/usr/lib/llvm-18/lib' >> /home/solv/.profile",{shell:!0,stdio:"inherit"}),w("grep -qxF 'export CLANG_PATH=/usr/bin/clang-18' /home/solv/.profile || echo 'export CLANG_PATH=/usr/bin/clang-18' >> /home/solv/.profile",{shell:!0,stdio:"inherit"}),w("source /home/solv/.profile",{shell:!0,stdio:"inherit"}),w(`mkdir /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),w(`cd /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),w(`git clone https://github.com/gabrielhicks/agave.git --recurse-submodules /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),w(`git -C /tmp/${t}-agave-mod checkout ${t}-mod`,{shell:!0,stdio:"inherit"}),w(`git -C /tmp/${t}-agave-mod submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),w(`CI_COMMIT=$(git -C /tmp/${t}-agave-mod rev-parse HEAD) /tmp/${t}-agave-mod/scripts/cargo-install-all.sh --validator-only /home/solv/.local/share/solana/install/releases/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),w("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),w(`cp -r /home/solv/.local/share/solana/install/releases/${t}-agave-mod/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),w(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
3
3
  n
4
4
  /^LimitMEMLOCK=infinity$/!i LimitMEMLOCK=infinity
5
5
  }' /etc/systemd/system/solv.service`,{shell:!0,stdio:"inherit"}),w("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\\\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),w(`sudo rm -rf /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),w("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})):(w("sudo apt-get update",{shell:!0,stdio:"inherit"}),w("sudo apt-get install -y libclang-18-dev clang-18 llvm-18-dev",{shell:!0,stdio:"inherit"}),w("grep -qxF 'export LIBCLANG_PATH=/usr/lib/llvm-18/lib' /home/solv/.profile || echo 'export LIBCLANG_PATH=/usr/lib/llvm-18/lib' >> /home/solv/.profile",{shell:!0,stdio:"inherit"}),w("grep -qxF 'export CLANG_PATH=/usr/bin/clang-18' /home/solv/.profile || echo 'export CLANG_PATH=/usr/bin/clang-18' >> /home/solv/.profile",{shell:!0,stdio:"inherit"}),w("source /home/solv/.profile",{shell:!0,stdio:"inherit"}),w(`mkdir /tmp/${t}`,{shell:!0,stdio:"inherit"}),w(`cd /tmp/${t}`,{shell:!0,stdio:"inherit"}),w(`git clone https://github.com/anza-xyz/agave.git --recurse-submodules /tmp/${t}`,{shell:!0,stdio:"inherit"}),w(`git -C /tmp/${t} checkout ${t}`,{shell:!0,stdio:"inherit"}),w(`git -C /tmp/${t} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),w(`CI_COMMIT=$(git -C /tmp/${t} rev-parse HEAD) /tmp/${t}/scripts/cargo-install-all.sh --validator-only /home/solv/.local/share/solana/install/releases/${t}`,{shell:!0,stdio:"inherit"}),w("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),w(`cp -r /home/solv/.local/share/solana/install/releases/${t}/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),w(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
@@ -16,7 +16,7 @@ Please set DISCORD_WEBHOOK_URL in .env`);let o={content:t,username:"\u{1FA84} So
16
16
  Account: ${a.pubkey}
17
17
  Reason: ${a.reason}
18
18
  Message: Max retries reached, exiting catchup check...
19
- Please check your validator node \u{1F477}\u200D\u2640\uFE0F`;return await el(c),!1}console.log("Waiting for validator to catch up..."),await j(60*1e3),a=await ne(t.RPC_URL,i,e),l++}return!0}catch(e){return console.log("Error in waitCatchup:",e),!1}},"waitCatchup"),Wr=ol;import{spawnSync as rl}from"node:child_process";var sl=r(()=>{let{stdout:t}=rl("solana --version",{shell:!0});return(t?String(t):"Unknown").trim()},"getSolanaVersion"),Ve=sl;var il=r(async t=>{let e=t.NETWORK===h.MAINNET,o=t.VALIDATOR_TYPE===T.FRANKENDANCER,{mainnetValidatorKey:s,testnetValidatorKey:n}=O(),i=e?s:n,a=Ve(),l=!1;o?l=e?Lr:Ir:l=e?Cr:kr,l=l&&t.AUTO_RESTART;let c=C(i),m=`**${c}** updated solv to **${Vt()}** with Solana version **${a}**`;if(await Z(m),l){let d=`Restarting **${c}**`;await Z(d);try{nl("solv update -b",{stdio:"inherit",shell:!0})}catch(y){let E=`Error restarting **${c}**: ${y?.message||"Unknown error"}`;return await Z(E),!1}let u=`**${c}** has restarted, catching up...`;await Z(u),await j(180*1e3);let p=await Wr(t);if(p){let y=`**${c}** has caught up!`;await Z(y)}else{let y=`**${c}** failed to catch up after update`;await Z(y)}return p}return!0},"autoUpdate"),qr=il;import{homedir as al}from"os";import{readFile as ll,writeFile as Qr}from"fs/promises";import{existsAsync as cl}from"@skeet-framework/utils";var L=r(async t=>{let o=`${al()}/${we}`;await cl(o)||(console.log("Creating default config file at",o),await Qr(o,JSON.stringify(ut,null,2)));let n={...JSON.parse(await ll(o,"utf8")),...t},i=JSON.stringify(n,null,2);await Qr(o,i)},"updateDefaultConfig");var ml={description:"\u{1F48E} Solana Validator All-in-One CLI \u{1F48E}",version:"Output the current version",help:"Display help for solv commands",subcmdHelp:"Display help for subcommands",server:"Open solv Dashboard",start:"Start Solana Validator",stop:"Stop Solana Validator",status:"Show Solana Validator Status",restart:"Restart Solana Validator",update:"Update Solana Validator Version",get:"Get Solana Validator Info Commands",log:"Tail Solana Validator Log",catchup:"Catchup Solana Validator",monitor:"Monitor Solana Validator",config:"Show Solana Validator Config",install:"Install/Update Solana Version",stake:"Solana Delegate Stake",check:"Check Solana Validator",scp:"Download/Upload Solana Validator Keypairs",cron:"Run Schedule Tasks",setup:"Setup Solana Validator",epoch:"Show Current Epoch",slot:"Show Current Slot",solv:"Endroll Solv AA",installer:"Please select an option:",unstake:"UnStake"},be=ml;var pl={description:"\u{1F48E} \u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u30AA\u30FC\u30EB\u30A4\u30F3\u30EF\u30F3 CLI \u30C4\u30FC\u30EB \u{1F48E}",version:"\u73FE\u5728\u306E\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u51FA\u529B",help:"solv \u30B3\u30DE\u30F3\u30C9\u306E\u30AA\u30D7\u30B7\u30E7\u30F3\u8A73\u7D30\u3092\u8868\u793A",subcmdHelp:"\u30B5\u30D6\u30B3\u30DE\u30F3\u30C9\u306E\u30D8\u30EB\u30D7\u3092\u8868\u793A",server:"solv \u30C0\u30C3\u30B7\u30E5\u30DC\u30FC\u30C9\u3092\u958B\u304F",start:"\u30CE\u30FC\u30C9\u3092\u8D77\u52D5",stop:"\u30CE\u30FC\u30C9\u3092\u505C\u6B62",status:"\u30CE\u30FC\u30C9\u306E\u30B9\u30C6\u30FC\u30BF\u30B9\u3092\u8868\u793A",restart:"\u30CE\u30FC\u30C9\u3092\u518D\u8D77\u52D5",update:"\u30CE\u30FC\u30C9\u306E\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u66F4\u65B0",get:"\u30CE\u30FC\u30C9\u306E\u8A2D\u5B9A\u60C5\u5831\u3092\u53D6\u5F97 \u30B5\u30D6\u30B3\u30DE\u30F3\u30C9",log:"\u30CE\u30FC\u30C9\u306E\u30ED\u30B0\u3092\u8868\u793A",catchup:"\u30CE\u30FC\u30C9\u3092\u30AD\u30E3\u30C3\u30C1\u30A2\u30C3\u30D7",monitor:"\u30CE\u30FC\u30C9\u3092\u76E3\u8996",config:"\u30CE\u30FC\u30C9\u306E\u8A2D\u5B9A\u3092\u8868\u793A",install:"\u30BD\u30E9\u30CA\u306E\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u66F4\u65B0/\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB",stake:"\u30BD\u30E9\u30CA\u306E\u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",unstake:"\u30BD\u30E9\u30CA\u306E\u30A2\u30F3\u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",check:"\u30CE\u30FC\u30C9\u306E\u72B6\u614B\u3092\u30C1\u30A7\u30C3\u30AF",scp:"scp \u30B5\u30D6\u30B3\u30DE\u30F3\u30C9",cron:"\u30B9\u30B1\u30B8\u30E5\u30FC\u30EB\u30BF\u30B9\u30AF \u30B5\u30D6\u30B3\u30DE\u30F3\u30C9",setup:"\u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u3092\u30BB\u30C3\u30C8\u30A2\u30C3\u30D7",epoch:"\u73FE\u5728\u306E\u30A8\u30DD\u30C3\u30AF\u3092\u8868\u793A",slot:"\u73FE\u5728\u306E\u30B9\u30ED\u30C3\u30C8\u3092\u8868\u793A",solv:"Solv\u30A8\u30F3\u30C9\u30ED\u30FC\u30EB AA \u3092\u8868\u793A",installer:"\u4EE5\u4E0B\u304B\u3089\u30AA\u30D7\u30B7\u30E7\u30F3\u3092\u9078\u629E\u3057\u3066\u304F\u3060\u3055\u3044:"},Zr=pl;var dl={success:{created:"Created"},error:{failed:"Failed"},installer:{welcomeMsg:"\u{1F525} Welcome to the solv installer \u{1F525}",description:"solv is born and ready for running Solana Validator Nodes \u{1F680}"}},De=dl;var ul={success:{created:"\u4F5C\u6210\u3055\u308C\u307E\u3057\u305F"},error:{failed:"\u5931\u6557\u3057\u307E\u3057\u305F"},installer:{welcomeMsg:"\u{1F525} \u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u30C4\u30FC\u30EB solv \u3078\u3088\u3046\u3053\u305D \u{1F525}",description:"\u3042\u306A\u305F\u306F\u3082\u3046\u3001\u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306B\u306A\u308B\u6E96\u5099\u304C\u3067\u304D\u3066\u3044\u307E\u3059\u3002"}},Xr=ul;var Ke=[") Upgrade - Update/Downgrade Solana Version",") Check Validator Logs/Status or Start/Stop",") Get Validator Config Info",") Backup Validator Keyfiles",") Staking",") Uninstall",") Exit"],Ue=[[],[") Check Validator Status",") Show Validator Logs",") Start Validator",") Stop Validator",") Restart Validator (no fetch snapshot)",") Restart Validator (fetch snapshot)",") Return to Main Menu"],[") Show Validator Config",") Register Validator Info",") Show Validator Keys Path/Address/Balance",") Get Current Epoch/Slot",") Get Solana Validator Catchup Info",") Get Solana Validator Monitor Info",") Return to Main Menu"],[") Backup Validator Keyfiles",") Set Validator Keyfile/Network",") Return to Main Menu"],[") Stake",") Unstake",") Return to Main Menu"],[],[]];var ts=[") \u30A2\u30C3\u30D7\u30B0\u30EC\u30FC\u30C9 - Solana\u30D0\u30FC\u30B8\u30E7\u30F3\u306E\u30A2\u30C3\u30D7\u30C7\u30FC\u30C8/\u30C0\u30A6\u30F3\u30B0\u30EC\u30FC\u30C9",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u72B6\u614B/\u30ED\u30B0\u3092\u78BA\u8A8D\u30FB\u307E\u305F\u306F\u958B\u59CB/\u505C\u6B62",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u8A2D\u5B9A\u60C5\u5831",") \u9375\u306E\u8A2D\u5B9A",") \u30B9\u30C6\u30FC\u30AD\u30F3\u30B0",") \u30A2\u30F3\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB",") \u7D42\u4E86"],es=[[],[") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u72B6\u614B\u3092\u78BA\u8A8D",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u30ED\u30B0\u3092\u8868\u793A",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u958B\u59CB",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u505C\u6B62",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u518D\u8D77\u52D5 (fetch snapshot \u306A\u3057)",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u518D\u8D77\u52D5 (fetch snapshot \u3042\u308A)",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u8A2D\u5B9A\u3092\u898B\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u60C5\u5831\u3092\u767B\u9332\u3059\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u9375\u306E \u30D1\u30B9/\u30A2\u30C9\u30EC\u30B9/\u6B8B\u9AD8 \u3092\u898B\u308B",") \u73FE\u5728\u306E \u30A8\u30DD\u30C3\u30AF/\u30B9\u30ED\u30C3\u30C8 \u3092\u898B\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E Catchup \u60C5\u5831\u3092\u898B\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u30E2\u30CB\u30BF\u30FC\u60C5\u5831\u3092\u898B\u308B",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u30D0\u30C3\u30AF\u30A2\u30C3\u30D7",") \u9375/\u30CD\u30C3\u30C8\u30EF\u30FC\u30AF\u3092\u8A2D\u5B9A\u3059\u308B",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[") \u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",") \u30A2\u30F3\u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[],[]];var hl={server:{description:"Open solv Dashboard"},start:{description:"Start Solana Validator"},stop:{description:"Stop Solana Validator"},status:{description:"Show Solana Validator Status"},restart:{description:"Restart Solana Validator"},update:{description:"Update Solana Validator Version"},get:{description:"Get Solana Validator Info"},log:{description:"Tail Solana Validator Log"},catchup:{description:"Catchup Solana Validator"},monitor:{description:"Monitor Solana Validator"},config:{description:"Show Solana Validator Config"},install:{description:"Install/Update Solana Version"},stake:{description:"Solana Delegate Stake"},unstake:{description:"UnStake"},check:{description:"Check Solana Validator"},scp:{description:"Download/Upload Solana Validator Keypairs"},cron:{description:"Run Schedule Tasks"},setup:{description:"Setup Solana Validator"},epoch:{description:"Show Current Epoch"},slot:{description:"Show Current Slot"},solv:{description:"Endroll Solv AA"}},Me=hl;var fl={server:{description:"Open solv Dashboard"},start:{description:"Start Solana Validator"},stop:{description:"Stop Solana Validator"},status:{description:"Show Solana Validator Status"},restart:{description:"Restart Solana Validator"},update:{description:"Update Solana Validator Version"},get:{description:"Get Solana Validator Info"},log:{description:"Tail Solana Validator Log"},catchup:{description:"Catchup Solana Validator"},monitor:{description:"Monitor Solana Validator"},config:{description:"Show Solana Validator Config"},install:{description:"Install/Update Solana Version"},stake:{description:"Solana Delegate Stake"},unstake:{description:"UnStake"},check:{description:"Check Solana Validator"},scp:{description:"Download/Upload Solana Validator Keypairs"},cron:{description:"Run Schedule Tasks"},setup:{description:"Setup Solana Validator"},epoch:{description:"Show Current Epoch"},slot:{description:"Show Current Slot"},solv:{description:"Endroll Solv AA"}},os=fl;var He=[") Check Validator Status",") Download Validator Keyfiles",") Generate Validator Keyfiles",") Upload Validator Keyfiles",") Set Validator Keyfile/Network",") Uninstall",") Exit"];var rs=[") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u72B6\u614B\u3092\u78BA\u8A8D",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u30C0\u30A6\u30F3\u30ED\u30FC\u30C9",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u4F5C\u6210",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u30A2\u30C3\u30D7\u30ED\u30FC\u30C9",") \u9375/\u30CD\u30C3\u30C8\u30EF\u30FC\u30AF\u3092\u8A2D\u5B9A\u3059\u308B",") \u30A2\u30F3\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB",") \u7D42\u4E86"];var yl=r(t=>{let e={cmds:be,subCmds:Me,logs:De,installer:Ke,installerSub:Ue,clientCmds:He};switch(t){case Rt.EN:e={cmds:be,subCmds:Me,logs:De,installer:Ke,installerSub:Ue,clientCmds:He};break;case Rt.JA:e={cmds:Zr,subCmds:os,logs:Xr,installer:ts,installerSub:es,clientCmds:rs};break;default:e={cmds:be,subCmds:Me,logs:De,installer:Ke,installerSub:Ue,clientCmds:He}}return e},"readLocale"),ss=yl;import{existsSync as El,readFileSync as Al,writeFileSync as ns}from"fs";import{readFileSync as Sl,writeFileSync as Tl}from"fs";import{homedir as gl}from"os";var Kt=r(t=>{let o=`${gl()}/${at.CONFIG}`,n={...JSON.parse(Sl(o,"utf8")),...t},i=JSON.stringify(n,null,2);Tl(o,i)},"updateSolvConfig");import{homedir as wl}from"os";var is=r(()=>{let e=`${wl()}/${at.CONFIG}`;El(e)||(ns(e,JSON.stringify(J,null,2)),console.log(`Created default config file at ${e}`));let o;try{o=JSON.parse(Al(e,"utf-8"))}catch{console.log("Error parsing config file. Renewing config file."),ns(e,JSON.stringify(J,null,2)),o=J}let s=ss(o.LANG);return o.RPC_URL||(o.RPC_URL=J.RPC_URL,Kt({RPC_URL:J.RPC_URL})),o.IS_MEV_MODE===void 0&&(o.IS_MEV_MODE=!1,Kt({IS_MEV_MODE:!1})),o.DISCORD_WEBHOOK_URL||(o.DISCORD_WEBHOOK_URL="",Kt({DISCORD_WEBHOOK_URL:""})),{config:o,locale:s}},"readOrCreateDefaultConfig");import{spawnSync as as}from"node:child_process";var Ut=r((t=!1,e="45",o=nt,s=F,n=t?"https://api.testnet.solana.com":"https://api.mainnet-beta.solana.com",i=!1)=>{try{let a=`docker run -it --rm -v ${o}:${o} --user $(id -u):$(id -g) c29r3/solana-snapshot-finder:latest --snapshot_path ${o} --min_download_speed ${e} --version ${s} --rpc ${n}`;if(t&&i){as(`wget --trust-server-names https://snapshots.avorio.network/testnet/snapshot.tar.bz2 https://snapshots.avorio.network/testnet/incremental-snapshot.tar.bz2 && for file in snapshot-* incremental-snapshot-*; do mv "$file" "$(echo "$file" | sed 's/\\?.*$//')"; done`,{shell:!0,stdio:"inherit",cwd:o});return}as(a,{shell:!0,stdio:"inherit"})}catch(a){throw new Error(`getSnapshot Error: ${a}`)}},"getSnapshot");import{spawnSync as ot}from"child_process";var ls=r(async(t,e,o=!1)=>{let s=t.NETWORK===h.TESTNET,n=e||(s?bt:Dt);o||t.MOD?(ot("git -C /home/solv/firedancer fetch origin",{shell:!0,stdio:"inherit"}),ot(`git -C /home/solv/firedancer checkout v${n}-mod`,{shell:!0,stdio:"inherit"}),ot("git -C /home/solv/firedancer submodule update --init --recursive",{shell:!0,stdio:"inherit"})):(ot("git -C /home/solv/firedancer fetch origin",{shell:!0,stdio:"inherit"}),ot(`git -C /home/solv/firedancer checkout v${n}`,{shell:!0,stdio:"inherit"}),ot("git -C /home/solv/firedancer submodule update --init --recursive",{shell:!0,stdio:"inherit"})),ot("export FD_AUTO_INSTALL_PACKAGES=1 && ./deps.sh fetch check install",{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),ot("make -j fdctl solana",{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),ot("sudo systemctl restart frankendancer",{shell:!0,stdio:"inherit"}),ot("sudo rm -rf /mnt/accounts/snapshot",{shell:!0,stdio:"inherit"}),ot("sudo systemctl restart port-relay",{shell:!0,stdio:"inherit"})},"frankendancerUpdate");import{spawnSync as Vo}from"node:child_process";var Fe=r(t=>{Vo("sudo rm -rf /mnt/ledger/*",{shell:!0,stdio:"inherit"}),t.SNAPSHOTS_PATH!=="/mnt/ledger"&&Vo(`sudo rm -rf ${t.SNAPSHOTS_PATH}/*`,{shell:!0,stdio:"inherit"}),Vo("sudo rm -rf /mnt/accounts/*",{shell:!0,stdio:"inherit"})},"rmSnapshot");var ms=r(t=>{let e=t.NETWORK===h.TESTNET,o=t.NODE_TYPE===A.RPC,s=t.VALIDATOR_TYPE===T.JITO,n=t.VALIDATOR_TYPE===T.FRANKENDANCER,i=t.AUTO_RESTART,a=t.MOD,l=10;i&&!e&&(l=30);let c=e?W:F;s&&(c=se,e&&(c=Ot)),n&&(c=Dt,e&&(c=bt)),o&&(c=Ct,s&&(c=Gr)),f.command("update").alias("u").description("Update Command").option("-v, --version <version>",`Solana Version e.g ${c}`,c).option("-b, --background","No Monitor Delinquent Stake Update",!1).option("-c, --commission","Update Commission",!1).option("-f, --firewall","Update Firewall",!1).option("--migrate-config","Migrate Solv Config",!1).option("--config","Update Solv Config Default Solana Version",!1).option("--auto","Auto Update",!1).option("--mod","Modified Versions",!1).action(async m=>{let d=Vt(),u=e?t.TESTNET_DELINQUENT_STAKE:t.MAINNET_DELINQUENT_STAKE;if(console.log(cs.white(`Current solv version: ${d}`)),m.auto){await qr(t);return}if(m.migrateConfig){let p=is().config,y=z.TRIPLE;p.DISK_TYPES===0?y=z.DOUBLE:p.DISK_TYPES===1?y=z.SINGLE:y=z.TRIPLE;let E=p.SOLANA_NETWORK===St.TESTNET,S=p.SOLV_TYPE===Le.RPC_NODE,g=p.MAINNET_TYPE===Ie.JITO_MEV,K={NETWORK:E?h.TESTNET:h.MAINNET,NODE_TYPE:S?A.RPC:A.VALIDATOR,MNT_DISK_TYPE:y,RPC_TYPE:S?U.JITO:U.NONE,VALIDATOR_TYPE:g?T.JITO:E?T.AGAVE:T.SOLANA,TESTNET_SOLANA_VERSION:p.TESTNET_SOLANA_VERSION,MAINNET_SOLANA_VERSION:p.MAINNET_SOLANA_VERSION,NODE_VERSION:p.NODE_VERSION,TESTNET_DELINQUENT_STAKE:p.TESTNET_DELINQUENT_STAKE,MAINNET_DELINQUENT_STAKE:p.MAINNET_DELINQUENT_STAKE,COMMISSION:p.COMMISSION,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:p.DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY,STAKE_ACCOUNTS:p.STAKE_ACCOUNT,HARVEST_ACCOUNT:p.HARVEST_ACCOUNT,IS_MEV_MODE:p.IS_MEV_MODE,RPC_URL:p.RPC_URL,KEYPAIR_PATH:p.KEYPAIR_PATH,DISCORD_WEBHOOK_URL:p.DISCORD_WEBHOOK_URL,AUTO_UPDATE:p.AUTO_UPDATE,AUTO_RESTART:p.AUTO_RESTART,IS_DUMMY:!1,API_KEY:"",LEDGER_PATH:p.LEDGER_PATH,ACCOUNTS_PATH:"/mnt/accounts",SNAPSHOTS_PATH:"/mnt/snapshots",MOD:!1};await L(K)}if(m.config){if(await L({TESTNET_SOLANA_VERSION:W,MAINNET_SOLANA_VERSION:F}),s){let p=e?Ot:se;await oe({version:p,tag:`v${p}`})}console.log(cs.green("\u2714\uFE0F Updated Solv Config Default Solana Version\n\n You can now run `solv i` to install the latest version"));return}if(m.firewall){await Hr();return}if(m.background){let p=m.version;if(await L({TESTNET_SOLANA_VERSION:W,MAINNET_SOLANA_VERSION:F}),Fe(t),s){$e(`v${p}`,m.mod||a),await oe({version:p,tag:`v${p}`}),await ke(u,!0,l);return}if(e&&Ut(e,"10",t.SNAPSHOTS_PATH,W),n){await ls(t,p,m.mod||a),await ke(u,!0,l);return}await Ce(p,m.mod||a),await ke(e?10:5,!0,l);return}else if(m.commission){let p=await Mr();Ur(p.commission,e)}else Dr()})},"updateCommands");import{spawnSync as _l}from"node:child_process";var ps=r(t=>{try{let{log:e}=Tt(),o=`tail -f ${e}`;t.error?o+=" | grep '\\(WARN\\|ERR\\)'":t.info?o+=" | grep INFO":t.warning&&(o+=" | grep WARN"),console.log(o);let s=_l(o,{shell:!0,stdio:"inherit"});if(s.error)throw s.error;s.signal==="SIGINT"?(console.log("Child process terminated due to receipt of SIGINT signal"),process.exit(0)):s.status!==0&&(console.error(`Child process exited with code ${s.status}`),process.exit(s.status))}catch(e){console.error(`tail Error: ${e}`),process.exit(1)}},"tail");var ds=r(()=>{f.command("log").description("tail logs").alias("l").description("tail logs").option("-i, --info","Follow INFO output",!1).option("-w, --warning","Follow WARN output",!1).option("-e, --error","Follow ERR/WARN output",!1).option("-a, --all","Follow All output",!1).action(t=>{ps(t)})},"logCommands");import ft from"chalk";import{spawnSync as vl}from"child_process";import{homedir as Nl}from"os";var je=r(t=>{let e=Nl(),o=O(e),s=o.testnetValidatorVoteKey,n=o.testnetValidatorKey,i=o.testnetValidatorAuthorityKey,a=St.TESTNET,l=t.COMMISSION;t.NETWORK===h.MAINNET&&(s=o.mainnetValidatorVoteKey,n=o.mainnetValidatorKey,i=o.mainnetValidatorAuthorityKey,a=St.MAINNET),console.log(`\u231B\uFE0F Creating vote account with commission ${l} - ${a}`);let c=t.RPC_URL||a;t.NETWORK===h.TESTNET&&(c=St.TESTNET);let m=`solana create-vote-account ${s} ${n} ${i} --commission ${l} --url ${c} --keypair ${n}`;vl(m,{shell:!0,stdio:"inherit"})},"setupVoteAccount");import{spawnSync as Ye}from"child_process";import{existsSync as us,readdirSync as Rl,rmSync as Ol}from"fs";import{homedir as Cl}from"os";import hs from"path";var Ge=r(t=>{let e=[],o=0;t.NODE_TYPE===A.RPC&&(e=[x.MAINNET_VALIDATOR_KEY],o=1),t.NETWORK===h.TESTNET?(e=[x.TESTNET_VALIDATOR_KEY,x.TESTNET_VALITATOR_AUTHORITY_KEY,x.TESTNET_VALIDATOR_VOTE_KEY,x.MAINNET_VALIDATOR_KEY,x.MAINNET_VALITATOR_AUTHORITY_KEY,x.MAINNET_VALIDATOR_VOTE_KEY],o=6):(e=[x.MAINNET_VALIDATOR_KEY,x.MAINNET_VALITATOR_AUTHORITY_KEY,x.MAINNET_VALIDATOR_VOTE_KEY],o=3);let s=`solana-keygen grind --starts-and-ends-with E:SV:${o}`;Ye(s,{shell:!0,stdio:"ignore"});let n=Rl("./").filter(c=>c.endsWith("SV.json")),i=Cl(),a=hs.join(i,"unstaked-identity.json");us(a)&&Ye(`mv ${a} ${i}/unstaked-identity.backup.json`,{shell:!0,stdio:"ignore"});let l=0;for(let c of n){let m=hs.join(i,e[l]);if(l++,us(m)){console.log(`${m} is already exist!`),Ol(c,{recursive:!0});continue}let d=`mv ${c} ${m}`;Ye(d,{shell:!0,stdio:"inherit"})}Ye("solana-keygen new -s --no-bip39-passphrase -o /home/solv/unstaked-identity.json",{shell:!0,stdio:"ignore"}),console.log(`Generated keypairs - ${i}`)},"createSolvKeyPairs");import{spawnSync as ys}from"child_process";var kl=r((t,e,o,s=2001)=>{let n="/etc/systemd/system/jupiter-api.service",i=`[Unit]
19
+ Please check your validator node \u{1F477}\u200D\u2640\uFE0F`;return await el(c),!1}console.log("Waiting for validator to catch up..."),await j(60*1e3),a=await ne(t.RPC_URL,i,e),l++}return!0}catch(e){return console.log("Error in waitCatchup:",e),!1}},"waitCatchup"),Wr=ol;import{spawnSync as rl}from"node:child_process";var sl=r(()=>{let{stdout:t}=rl("solana --version",{shell:!0});return(t?String(t):"Unknown").trim()},"getSolanaVersion"),Ve=sl;var il=r(async t=>{let e=t.NETWORK===h.MAINNET,o=t.VALIDATOR_TYPE===T.FRANKENDANCER,{mainnetValidatorKey:s,testnetValidatorKey:n}=O(),i=e?s:n,a=Ve(),l=!1;o?l=e?Lr:Ir:l=e?Cr:kr,l=l&&t.AUTO_RESTART;let c=C(i),m=`**${c}** updated solv to **${Vt()}** with Solana version **${a}**`;if(await Z(m),l){let d=`Restarting **${c}**`;await Z(d);try{nl("solv update && solv update ---config solv update -b",{stdio:"inherit",shell:!0})}catch(y){let E=`Error restarting **${c}**: ${y?.message||"Unknown error"}`;return await Z(E),!1}let u=`**${c}** has restarted, catching up...`;await Z(u),await j(180*1e3);let p=await Wr(t);if(p){let y=`**${c}** has caught up!`;await Z(y)}else{let y=`**${c}** failed to catch up after update`;await Z(y)}return p}return!0},"autoUpdate"),qr=il;import{homedir as al}from"os";import{readFile as ll,writeFile as Qr}from"fs/promises";import{existsAsync as cl}from"@skeet-framework/utils";var L=r(async t=>{let o=`${al()}/${we}`;await cl(o)||(console.log("Creating default config file at",o),await Qr(o,JSON.stringify(ut,null,2)));let n={...JSON.parse(await ll(o,"utf8")),...t},i=JSON.stringify(n,null,2);await Qr(o,i)},"updateDefaultConfig");var ml={description:"\u{1F48E} Solana Validator All-in-One CLI \u{1F48E}",version:"Output the current version",help:"Display help for solv commands",subcmdHelp:"Display help for subcommands",server:"Open solv Dashboard",start:"Start Solana Validator",stop:"Stop Solana Validator",status:"Show Solana Validator Status",restart:"Restart Solana Validator",update:"Update Solana Validator Version",get:"Get Solana Validator Info Commands",log:"Tail Solana Validator Log",catchup:"Catchup Solana Validator",monitor:"Monitor Solana Validator",config:"Show Solana Validator Config",install:"Install/Update Solana Version",stake:"Solana Delegate Stake",check:"Check Solana Validator",scp:"Download/Upload Solana Validator Keypairs",cron:"Run Schedule Tasks",setup:"Setup Solana Validator",epoch:"Show Current Epoch",slot:"Show Current Slot",solv:"Endroll Solv AA",installer:"Please select an option:",unstake:"UnStake"},be=ml;var pl={description:"\u{1F48E} \u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u30AA\u30FC\u30EB\u30A4\u30F3\u30EF\u30F3 CLI \u30C4\u30FC\u30EB \u{1F48E}",version:"\u73FE\u5728\u306E\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u51FA\u529B",help:"solv \u30B3\u30DE\u30F3\u30C9\u306E\u30AA\u30D7\u30B7\u30E7\u30F3\u8A73\u7D30\u3092\u8868\u793A",subcmdHelp:"\u30B5\u30D6\u30B3\u30DE\u30F3\u30C9\u306E\u30D8\u30EB\u30D7\u3092\u8868\u793A",server:"solv \u30C0\u30C3\u30B7\u30E5\u30DC\u30FC\u30C9\u3092\u958B\u304F",start:"\u30CE\u30FC\u30C9\u3092\u8D77\u52D5",stop:"\u30CE\u30FC\u30C9\u3092\u505C\u6B62",status:"\u30CE\u30FC\u30C9\u306E\u30B9\u30C6\u30FC\u30BF\u30B9\u3092\u8868\u793A",restart:"\u30CE\u30FC\u30C9\u3092\u518D\u8D77\u52D5",update:"\u30CE\u30FC\u30C9\u306E\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u66F4\u65B0",get:"\u30CE\u30FC\u30C9\u306E\u8A2D\u5B9A\u60C5\u5831\u3092\u53D6\u5F97 \u30B5\u30D6\u30B3\u30DE\u30F3\u30C9",log:"\u30CE\u30FC\u30C9\u306E\u30ED\u30B0\u3092\u8868\u793A",catchup:"\u30CE\u30FC\u30C9\u3092\u30AD\u30E3\u30C3\u30C1\u30A2\u30C3\u30D7",monitor:"\u30CE\u30FC\u30C9\u3092\u76E3\u8996",config:"\u30CE\u30FC\u30C9\u306E\u8A2D\u5B9A\u3092\u8868\u793A",install:"\u30BD\u30E9\u30CA\u306E\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u66F4\u65B0/\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB",stake:"\u30BD\u30E9\u30CA\u306E\u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",unstake:"\u30BD\u30E9\u30CA\u306E\u30A2\u30F3\u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",check:"\u30CE\u30FC\u30C9\u306E\u72B6\u614B\u3092\u30C1\u30A7\u30C3\u30AF",scp:"scp \u30B5\u30D6\u30B3\u30DE\u30F3\u30C9",cron:"\u30B9\u30B1\u30B8\u30E5\u30FC\u30EB\u30BF\u30B9\u30AF \u30B5\u30D6\u30B3\u30DE\u30F3\u30C9",setup:"\u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u3092\u30BB\u30C3\u30C8\u30A2\u30C3\u30D7",epoch:"\u73FE\u5728\u306E\u30A8\u30DD\u30C3\u30AF\u3092\u8868\u793A",slot:"\u73FE\u5728\u306E\u30B9\u30ED\u30C3\u30C8\u3092\u8868\u793A",solv:"Solv\u30A8\u30F3\u30C9\u30ED\u30FC\u30EB AA \u3092\u8868\u793A",installer:"\u4EE5\u4E0B\u304B\u3089\u30AA\u30D7\u30B7\u30E7\u30F3\u3092\u9078\u629E\u3057\u3066\u304F\u3060\u3055\u3044:"},Zr=pl;var dl={success:{created:"Created"},error:{failed:"Failed"},installer:{welcomeMsg:"\u{1F525} Welcome to the solv installer \u{1F525}",description:"solv is born and ready for running Solana Validator Nodes \u{1F680}"}},De=dl;var ul={success:{created:"\u4F5C\u6210\u3055\u308C\u307E\u3057\u305F"},error:{failed:"\u5931\u6557\u3057\u307E\u3057\u305F"},installer:{welcomeMsg:"\u{1F525} \u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u30C4\u30FC\u30EB solv \u3078\u3088\u3046\u3053\u305D \u{1F525}",description:"\u3042\u306A\u305F\u306F\u3082\u3046\u3001\u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306B\u306A\u308B\u6E96\u5099\u304C\u3067\u304D\u3066\u3044\u307E\u3059\u3002"}},Xr=ul;var Ke=[") Upgrade - Update/Downgrade Solana Version",") Check Validator Logs/Status or Start/Stop",") Get Validator Config Info",") Backup Validator Keyfiles",") Staking",") Uninstall",") Exit"],Ue=[[],[") Check Validator Status",") Show Validator Logs",") Start Validator",") Stop Validator",") Restart Validator (no fetch snapshot)",") Restart Validator (fetch snapshot)",") Return to Main Menu"],[") Show Validator Config",") Register Validator Info",") Show Validator Keys Path/Address/Balance",") Get Current Epoch/Slot",") Get Solana Validator Catchup Info",") Get Solana Validator Monitor Info",") Return to Main Menu"],[") Backup Validator Keyfiles",") Set Validator Keyfile/Network",") Return to Main Menu"],[") Stake",") Unstake",") Return to Main Menu"],[],[]];var ts=[") \u30A2\u30C3\u30D7\u30B0\u30EC\u30FC\u30C9 - Solana\u30D0\u30FC\u30B8\u30E7\u30F3\u306E\u30A2\u30C3\u30D7\u30C7\u30FC\u30C8/\u30C0\u30A6\u30F3\u30B0\u30EC\u30FC\u30C9",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u72B6\u614B/\u30ED\u30B0\u3092\u78BA\u8A8D\u30FB\u307E\u305F\u306F\u958B\u59CB/\u505C\u6B62",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u8A2D\u5B9A\u60C5\u5831",") \u9375\u306E\u8A2D\u5B9A",") \u30B9\u30C6\u30FC\u30AD\u30F3\u30B0",") \u30A2\u30F3\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB",") \u7D42\u4E86"],es=[[],[") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u72B6\u614B\u3092\u78BA\u8A8D",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u30ED\u30B0\u3092\u8868\u793A",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u958B\u59CB",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u505C\u6B62",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u518D\u8D77\u52D5 (fetch snapshot \u306A\u3057)",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u518D\u8D77\u52D5 (fetch snapshot \u3042\u308A)",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u8A2D\u5B9A\u3092\u898B\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u60C5\u5831\u3092\u767B\u9332\u3059\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u9375\u306E \u30D1\u30B9/\u30A2\u30C9\u30EC\u30B9/\u6B8B\u9AD8 \u3092\u898B\u308B",") \u73FE\u5728\u306E \u30A8\u30DD\u30C3\u30AF/\u30B9\u30ED\u30C3\u30C8 \u3092\u898B\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E Catchup \u60C5\u5831\u3092\u898B\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u30E2\u30CB\u30BF\u30FC\u60C5\u5831\u3092\u898B\u308B",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u30D0\u30C3\u30AF\u30A2\u30C3\u30D7",") \u9375/\u30CD\u30C3\u30C8\u30EF\u30FC\u30AF\u3092\u8A2D\u5B9A\u3059\u308B",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[") \u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",") \u30A2\u30F3\u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[],[]];var hl={server:{description:"Open solv Dashboard"},start:{description:"Start Solana Validator"},stop:{description:"Stop Solana Validator"},status:{description:"Show Solana Validator Status"},restart:{description:"Restart Solana Validator"},update:{description:"Update Solana Validator Version"},get:{description:"Get Solana Validator Info"},log:{description:"Tail Solana Validator Log"},catchup:{description:"Catchup Solana Validator"},monitor:{description:"Monitor Solana Validator"},config:{description:"Show Solana Validator Config"},install:{description:"Install/Update Solana Version"},stake:{description:"Solana Delegate Stake"},unstake:{description:"UnStake"},check:{description:"Check Solana Validator"},scp:{description:"Download/Upload Solana Validator Keypairs"},cron:{description:"Run Schedule Tasks"},setup:{description:"Setup Solana Validator"},epoch:{description:"Show Current Epoch"},slot:{description:"Show Current Slot"},solv:{description:"Endroll Solv AA"}},Me=hl;var fl={server:{description:"Open solv Dashboard"},start:{description:"Start Solana Validator"},stop:{description:"Stop Solana Validator"},status:{description:"Show Solana Validator Status"},restart:{description:"Restart Solana Validator"},update:{description:"Update Solana Validator Version"},get:{description:"Get Solana Validator Info"},log:{description:"Tail Solana Validator Log"},catchup:{description:"Catchup Solana Validator"},monitor:{description:"Monitor Solana Validator"},config:{description:"Show Solana Validator Config"},install:{description:"Install/Update Solana Version"},stake:{description:"Solana Delegate Stake"},unstake:{description:"UnStake"},check:{description:"Check Solana Validator"},scp:{description:"Download/Upload Solana Validator Keypairs"},cron:{description:"Run Schedule Tasks"},setup:{description:"Setup Solana Validator"},epoch:{description:"Show Current Epoch"},slot:{description:"Show Current Slot"},solv:{description:"Endroll Solv AA"}},os=fl;var He=[") Check Validator Status",") Download Validator Keyfiles",") Generate Validator Keyfiles",") Upload Validator Keyfiles",") Set Validator Keyfile/Network",") Uninstall",") Exit"];var rs=[") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u72B6\u614B\u3092\u78BA\u8A8D",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u30C0\u30A6\u30F3\u30ED\u30FC\u30C9",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u4F5C\u6210",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u30A2\u30C3\u30D7\u30ED\u30FC\u30C9",") \u9375/\u30CD\u30C3\u30C8\u30EF\u30FC\u30AF\u3092\u8A2D\u5B9A\u3059\u308B",") \u30A2\u30F3\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB",") \u7D42\u4E86"];var yl=r(t=>{let e={cmds:be,subCmds:Me,logs:De,installer:Ke,installerSub:Ue,clientCmds:He};switch(t){case Rt.EN:e={cmds:be,subCmds:Me,logs:De,installer:Ke,installerSub:Ue,clientCmds:He};break;case Rt.JA:e={cmds:Zr,subCmds:os,logs:Xr,installer:ts,installerSub:es,clientCmds:rs};break;default:e={cmds:be,subCmds:Me,logs:De,installer:Ke,installerSub:Ue,clientCmds:He}}return e},"readLocale"),ss=yl;import{existsSync as El,readFileSync as Al,writeFileSync as ns}from"fs";import{readFileSync as Sl,writeFileSync as Tl}from"fs";import{homedir as gl}from"os";var Kt=r(t=>{let o=`${gl()}/${at.CONFIG}`,n={...JSON.parse(Sl(o,"utf8")),...t},i=JSON.stringify(n,null,2);Tl(o,i)},"updateSolvConfig");import{homedir as wl}from"os";var is=r(()=>{let e=`${wl()}/${at.CONFIG}`;El(e)||(ns(e,JSON.stringify(J,null,2)),console.log(`Created default config file at ${e}`));let o;try{o=JSON.parse(Al(e,"utf-8"))}catch{console.log("Error parsing config file. Renewing config file."),ns(e,JSON.stringify(J,null,2)),o=J}let s=ss(o.LANG);return o.RPC_URL||(o.RPC_URL=J.RPC_URL,Kt({RPC_URL:J.RPC_URL})),o.IS_MEV_MODE===void 0&&(o.IS_MEV_MODE=!1,Kt({IS_MEV_MODE:!1})),o.DISCORD_WEBHOOK_URL||(o.DISCORD_WEBHOOK_URL="",Kt({DISCORD_WEBHOOK_URL:""})),{config:o,locale:s}},"readOrCreateDefaultConfig");import{spawnSync as as}from"node:child_process";var Ut=r((t=!1,e="45",o=nt,s=F,n=t?"https://api.testnet.solana.com":"https://api.mainnet-beta.solana.com",i=!1)=>{try{let a=`docker run -it --rm -v ${o}:${o} --user $(id -u):$(id -g) c29r3/solana-snapshot-finder:latest --snapshot_path ${o} --min_download_speed ${e} --version ${s} --rpc ${n}`;if(t&&i){as(`wget --trust-server-names https://snapshots.avorio.network/testnet/snapshot.tar.bz2 https://snapshots.avorio.network/testnet/incremental-snapshot.tar.bz2 && for file in snapshot-* incremental-snapshot-*; do mv "$file" "$(echo "$file" | sed 's/\\?.*$//')"; done`,{shell:!0,stdio:"inherit",cwd:o});return}as(a,{shell:!0,stdio:"inherit"})}catch(a){throw new Error(`getSnapshot Error: ${a}`)}},"getSnapshot");import{spawnSync as ot}from"child_process";var ls=r(async(t,e,o=!1)=>{let s=t.NETWORK===h.TESTNET,n=e||(s?bt:Dt);o||t.MOD?(ot("git -C /home/solv/firedancer fetch origin",{shell:!0,stdio:"inherit"}),ot(`git -C /home/solv/firedancer checkout v${n}-mod`,{shell:!0,stdio:"inherit"}),ot("git -C /home/solv/firedancer submodule update --init --recursive",{shell:!0,stdio:"inherit"})):(ot("git -C /home/solv/firedancer fetch origin",{shell:!0,stdio:"inherit"}),ot(`git -C /home/solv/firedancer checkout v${n}`,{shell:!0,stdio:"inherit"}),ot("git -C /home/solv/firedancer submodule update --init --recursive",{shell:!0,stdio:"inherit"})),ot("export FD_AUTO_INSTALL_PACKAGES=1 && ./deps.sh fetch check install",{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),ot("make -j fdctl solana",{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),ot("sudo systemctl restart frankendancer",{shell:!0,stdio:"inherit"}),ot("sudo rm -rf /mnt/accounts/snapshot",{shell:!0,stdio:"inherit"}),ot("sudo systemctl restart port-relay",{shell:!0,stdio:"inherit"})},"frankendancerUpdate");import{spawnSync as Vo}from"node:child_process";var Fe=r(t=>{Vo("sudo rm -rf /mnt/ledger/*",{shell:!0,stdio:"inherit"}),t.SNAPSHOTS_PATH!=="/mnt/ledger"&&Vo(`sudo rm -rf ${t.SNAPSHOTS_PATH}/*`,{shell:!0,stdio:"inherit"}),Vo("sudo rm -rf /mnt/accounts/*",{shell:!0,stdio:"inherit"})},"rmSnapshot");var ms=r(t=>{let e=t.NETWORK===h.TESTNET,o=t.NODE_TYPE===A.RPC,s=t.VALIDATOR_TYPE===T.JITO,n=t.VALIDATOR_TYPE===T.FRANKENDANCER,i=t.AUTO_RESTART,a=t.MOD,l=10;i&&!e&&(l=30);let c=e?W:F;s&&(c=se,e&&(c=Ot)),n&&(c=Dt,e&&(c=bt)),o&&(c=Ct,s&&(c=Gr)),f.command("update").alias("u").description("Update Command").option("-v, --version <version>",`Solana Version e.g ${c}`,c).option("-b, --background","No Monitor Delinquent Stake Update",!1).option("-c, --commission","Update Commission",!1).option("-f, --firewall","Update Firewall",!1).option("--migrate-config","Migrate Solv Config",!1).option("--config","Update Solv Config Default Solana Version",!1).option("--auto","Auto Update",!1).option("--mod","Modified Versions",!1).action(async m=>{let d=Vt(),u=e?t.TESTNET_DELINQUENT_STAKE:t.MAINNET_DELINQUENT_STAKE;if(console.log(cs.white(`Current solv version: ${d}`)),m.auto){await qr(t);return}if(m.migrateConfig){let p=is().config,y=z.TRIPLE;p.DISK_TYPES===0?y=z.DOUBLE:p.DISK_TYPES===1?y=z.SINGLE:y=z.TRIPLE;let E=p.SOLANA_NETWORK===St.TESTNET,S=p.SOLV_TYPE===Le.RPC_NODE,g=p.MAINNET_TYPE===Ie.JITO_MEV,K={NETWORK:E?h.TESTNET:h.MAINNET,NODE_TYPE:S?A.RPC:A.VALIDATOR,MNT_DISK_TYPE:y,RPC_TYPE:S?U.JITO:U.NONE,VALIDATOR_TYPE:g?T.JITO:E?T.AGAVE:T.SOLANA,TESTNET_SOLANA_VERSION:p.TESTNET_SOLANA_VERSION,MAINNET_SOLANA_VERSION:p.MAINNET_SOLANA_VERSION,NODE_VERSION:p.NODE_VERSION,TESTNET_DELINQUENT_STAKE:p.TESTNET_DELINQUENT_STAKE,MAINNET_DELINQUENT_STAKE:p.MAINNET_DELINQUENT_STAKE,COMMISSION:p.COMMISSION,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:p.DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY,STAKE_ACCOUNTS:p.STAKE_ACCOUNT,HARVEST_ACCOUNT:p.HARVEST_ACCOUNT,IS_MEV_MODE:p.IS_MEV_MODE,RPC_URL:p.RPC_URL,KEYPAIR_PATH:p.KEYPAIR_PATH,DISCORD_WEBHOOK_URL:p.DISCORD_WEBHOOK_URL,AUTO_UPDATE:p.AUTO_UPDATE,AUTO_RESTART:p.AUTO_RESTART,IS_DUMMY:!1,API_KEY:"",LEDGER_PATH:p.LEDGER_PATH,ACCOUNTS_PATH:"/mnt/accounts",SNAPSHOTS_PATH:"/mnt/snapshots",MOD:!1};await L(K)}if(m.config){if(await L({TESTNET_SOLANA_VERSION:W,MAINNET_SOLANA_VERSION:F}),s){let p=e?Ot:se;await oe({version:p,tag:`v${p}`})}console.log(cs.green("\u2714\uFE0F Updated Solv Config Default Solana Version\n\n You can now run `solv i` to install the latest version"));return}if(m.firewall){await Hr();return}if(m.background){let p=m.version;if(await L({TESTNET_SOLANA_VERSION:W,MAINNET_SOLANA_VERSION:F}),Fe(t),s){$e(`v${p}`,m.mod||a),await oe({version:p,tag:`v${p}`}),await ke(u,!0,l);return}if(e&&Ut(e,"10",t.SNAPSHOTS_PATH,W),n){await ls(t,p,m.mod||a),await ke(u,!0,l);return}await Ce(p,m.mod||a),await ke(e?10:5,!0,l);return}else if(m.commission){let p=await Mr();Ur(p.commission,e)}else Dr()})},"updateCommands");import{spawnSync as _l}from"node:child_process";var ps=r(t=>{try{let{log:e}=Tt(),o=`tail -f ${e}`;t.error?o+=" | grep '\\(WARN\\|ERR\\)'":t.info?o+=" | grep INFO":t.warning&&(o+=" | grep WARN"),console.log(o);let s=_l(o,{shell:!0,stdio:"inherit"});if(s.error)throw s.error;s.signal==="SIGINT"?(console.log("Child process terminated due to receipt of SIGINT signal"),process.exit(0)):s.status!==0&&(console.error(`Child process exited with code ${s.status}`),process.exit(s.status))}catch(e){console.error(`tail Error: ${e}`),process.exit(1)}},"tail");var ds=r(()=>{f.command("log").description("tail logs").alias("l").description("tail logs").option("-i, --info","Follow INFO output",!1).option("-w, --warning","Follow WARN output",!1).option("-e, --error","Follow ERR/WARN output",!1).option("-a, --all","Follow All output",!1).action(t=>{ps(t)})},"logCommands");import ft from"chalk";import{spawnSync as vl}from"child_process";import{homedir as Nl}from"os";var je=r(t=>{let e=Nl(),o=O(e),s=o.testnetValidatorVoteKey,n=o.testnetValidatorKey,i=o.testnetValidatorAuthorityKey,a=St.TESTNET,l=t.COMMISSION;t.NETWORK===h.MAINNET&&(s=o.mainnetValidatorVoteKey,n=o.mainnetValidatorKey,i=o.mainnetValidatorAuthorityKey,a=St.MAINNET),console.log(`\u231B\uFE0F Creating vote account with commission ${l} - ${a}`);let c=t.RPC_URL||a;t.NETWORK===h.TESTNET&&(c=St.TESTNET);let m=`solana create-vote-account ${s} ${n} ${i} --commission ${l} --url ${c} --keypair ${n}`;vl(m,{shell:!0,stdio:"inherit"})},"setupVoteAccount");import{spawnSync as Ye}from"child_process";import{existsSync as us,readdirSync as Rl,rmSync as Ol}from"fs";import{homedir as Cl}from"os";import hs from"path";var Ge=r(t=>{let e=[],o=0;t.NODE_TYPE===A.RPC&&(e=[x.MAINNET_VALIDATOR_KEY],o=1),t.NETWORK===h.TESTNET?(e=[x.TESTNET_VALIDATOR_KEY,x.TESTNET_VALITATOR_AUTHORITY_KEY,x.TESTNET_VALIDATOR_VOTE_KEY,x.MAINNET_VALIDATOR_KEY,x.MAINNET_VALITATOR_AUTHORITY_KEY,x.MAINNET_VALIDATOR_VOTE_KEY],o=6):(e=[x.MAINNET_VALIDATOR_KEY,x.MAINNET_VALITATOR_AUTHORITY_KEY,x.MAINNET_VALIDATOR_VOTE_KEY],o=3);let s=`solana-keygen grind --starts-and-ends-with E:SV:${o}`;Ye(s,{shell:!0,stdio:"ignore"});let n=Rl("./").filter(c=>c.endsWith("SV.json")),i=Cl(),a=hs.join(i,"unstaked-identity.json");us(a)&&Ye(`mv ${a} ${i}/unstaked-identity.backup.json`,{shell:!0,stdio:"ignore"});let l=0;for(let c of n){let m=hs.join(i,e[l]);if(l++,us(m)){console.log(`${m} is already exist!`),Ol(c,{recursive:!0});continue}let d=`mv ${c} ${m}`;Ye(d,{shell:!0,stdio:"inherit"})}Ye("solana-keygen new -s --no-bip39-passphrase -o /home/solv/unstaked-identity.json",{shell:!0,stdio:"ignore"}),console.log(`Generated keypairs - ${i}`)},"createSolvKeyPairs");import{spawnSync as ys}from"child_process";var kl=r((t,e,o,s=2001)=>{let n="/etc/systemd/system/jupiter-api.service",i=`[Unit]
20
20
  Description=Jupiter API Service Instance
21
21
  After=network.target
22
22
 
@@ -688,7 +688,7 @@ Epoch has been updated!
688
688
  Until Next Epoch: Approximately 2 days`;return"Epoch has been updated!"},"newEpoch"),ji=ed;import{existsAsync as od}from"@skeet-framework/utils";import{readFile as rd,writeFile as sd}from"fs/promises";import nd from"chalk";import{homedir as id}from"os";var ad=r(async()=>{let e=id().includes("/home/solv")?Pe:"./currentEpoch.json";if(await od(e))return JSON.parse(await rd(e,"utf-8"));let o={epoch:0,isLessThan1Hour:!1,isLessThan8Hours:!1,isLessThan1Day:!1};return await sd(e,JSON.stringify(o,null,2),"utf-8"),console.log(nd.white("\u2714\uFE0F Initial epoch data has been created!")),o},"initOrReadEpochFile"),Yi=ad;import ld from"chalk";var cd=r(async t=>{let e=t.RPC_URL,o=t.NETWORK===h.TESTNET;if(o&&(e=dr),await ct(e,X.VALIDATOR,o)<Lo){let{mainnetValidatorKey:n,testnetValidatorKey:i}=O(),a=o?C(i):C(n),l=`\u26A0\uFE0F Validator Account Balance is less than ${Lo} SOL
689
689
  Please top up your Validator Account
690
690
  Address: ${a}`;return await Z(l),!1}return console.log(ld.green("\u2714\uFE0F Validator Account Balance is sufficient")),!0},"checkBalance"),Gi=cd;async function md(t="@gabrielhicks/solv"){try{let e=`https://registry.npmjs.org/${t}`,o=await fetch(e);if(!o.ok)throw new Error(`HTTP error! status: ${o.status}`);return(await o.json())["dist-tags"].latest}catch(e){return console.error(`Error fetching latest version for package ${t}:`,e),null}}r(md,"getNpmLatestVersion");var Bi=md;async function pd(){let t=Vt(),e=await Bi();if(!e)throw new Error("Failed to get NPM API");return console.log("currentVersion:",t),console.log("latestVersion:",e),t===e}r(pd,"isVersionSame");var Ji=pd;import{spawnSync as hd}from"child_process";import{spawnSync as dd}from"node:child_process";var zi=r(t=>{try{let e=`solana epoch-info --url '${t}'`,{stdout:o}=dd(e,{shell:!0,stdio:"pipe"}),n=o.toString().split(`
691
- `),i=n.find(p=>p.includes("Epoch Completed Time:")),a=n.find(p=>p.includes("Epoch Completed Percent:"))?.replace("Epoch Completed Percent:",""),l=Number(n.find(p=>p.includes("Epoch:"))?.replace("Epoch:",""));if(!i||!a||!l)throw new Error("Epoch Completed Time not found");let m=i.split("(")[1].replace(" remaining)","");console.log("remainingTime:",m);let d=/(?:(\d+)day\s*)?(?:(\d+)h\s*)?(?:(\d+)m\s*)?(?:(\d+)s\s*)?/,u=m.match(d);if(u){let p=u[1]?parseInt(u[1]):0,y=u[2]?parseInt(u[2]):0,E=u[3]?parseInt(u[3]):0,S=u[4]?parseInt(u[4]):0,g=p*24*60+y*60+E+Math.floor(S/60);return{epoch:l,day:p,hour:y,min:E,sec:S,totalMinutes:g,epochRemainingTime:m,epochCompletedPercent:a}}else throw new Error("Time information could not be parsed")}catch(e){throw new Error(`getEpochInfoByRust failed: ${e}`)}},"getEpochInfoByRust");var fd=r(async t=>{let e=t.NETWORK===h.TESTNET,o=e?xe:t.RPC_URL,s=ud(new Date,"yyyy-MM-dd HH:mm:ss");console.log(`Checking Epoch at ${s}`);let n=await Yi(),i=zi(o),{mainnetValidatorVoteKey:a,testnetValidatorVoteKey:l}=O(),m=await ne(o,C(e?l:a));if(console.log(`Validator is active: ${m.isActive}`),await Gi(t),!await Ji()&&t.AUTO_UPDATE)return console.log("Found new version of solv! Updating..."),hd("solv update && solv update --auto",{stdio:"inherit",shell:!0}),"Node has been restarted!";if(n.epoch<i.epoch)return await ji(i,t),"Epoch has been updated!";let u=i.totalMinutes,p=[Fi,Hi,Mi];for(let y of p)if(await y(u,n,i,t))break;return"Epoch has not been changed!"},"epochTimer"),Wi=fd;var qi=r(t=>{f.command("epochTimer").description("Check Solana Epoch Timer").action(async()=>{await Wi(t),process.exit(0)})},"epochTimerCommands");import ma from"inquirer";import{join as ta}from"path";import{spawnSync as zt}from"node:child_process";import q from"chalk";import{spawnSync as yd}from"node:child_process";var Sd=r((t,e,o,s="pipe",n="~/.ssh/id_rsa")=>{let i;try{let a=yd(`ssh -i ${n} -o StrictHostKeyChecking=no solv@${t} -p 22 'cd ~ && source ~/.profile && ${e}'`,{shell:!0,stdio:s});return a.status!==0?(console.log(`\u26A0\uFE0F CMD Failed. Please check your SSH connection.
691
+ `),i=n.find(p=>p.includes("Epoch Completed Time:")),a=n.find(p=>p.includes("Epoch Completed Percent:"))?.replace("Epoch Completed Percent:",""),l=Number(n.find(p=>p.includes("Epoch:"))?.replace("Epoch:",""));if(!i||!a||!l)throw new Error("Epoch Completed Time not found");let m=i.split("(")[1].replace(" remaining)","");console.log("remainingTime:",m);let d=/(?:(\d+)day\s*)?(?:(\d+)h\s*)?(?:(\d+)m\s*)?(?:(\d+)s\s*)?/,u=m.match(d);if(u){let p=u[1]?parseInt(u[1]):0,y=u[2]?parseInt(u[2]):0,E=u[3]?parseInt(u[3]):0,S=u[4]?parseInt(u[4]):0,g=p*24*60+y*60+E+Math.floor(S/60);return{epoch:l,day:p,hour:y,min:E,sec:S,totalMinutes:g,epochRemainingTime:m,epochCompletedPercent:a}}else throw new Error("Time information could not be parsed")}catch(e){throw new Error(`getEpochInfoByRust failed: ${e}`)}},"getEpochInfoByRust");var fd=r(async t=>{let e=t.NETWORK===h.TESTNET,o=e?xe:t.RPC_URL,s=ud(new Date,"yyyy-MM-dd HH:mm:ss");console.log(`Checking Epoch at ${s}`);let n=await Yi(),i=zi(o),{mainnetValidatorVoteKey:a,testnetValidatorVoteKey:l}=O(),m=await ne(o,C(e?l:a));if(console.log(`Validator is active: ${m.isActive}`),await Gi(t),!await Ji()&&t.AUTO_UPDATE)return console.log("Found new version of solv! Updating..."),hd("solv update && solv update --config && solv update --auto",{stdio:"inherit",shell:!0}),"Node has been restarted!";if(n.epoch<i.epoch)return await ji(i,t),"Epoch has been updated!";let u=i.totalMinutes,p=[Fi,Hi,Mi];for(let y of p)if(await y(u,n,i,t))break;return"Epoch has not been changed!"},"epochTimer"),Wi=fd;var qi=r(t=>{f.command("epochTimer").description("Check Solana Epoch Timer").action(async()=>{await Wi(t),process.exit(0)})},"epochTimerCommands");import ma from"inquirer";import{join as ta}from"path";import{spawnSync as zt}from"node:child_process";import q from"chalk";import{spawnSync as yd}from"node:child_process";var Sd=r((t,e,o,s="pipe",n="~/.ssh/id_rsa")=>{let i;try{let a=yd(`ssh -i ${n} -o StrictHostKeyChecking=no solv@${t} -p 22 'cd ~ && source ~/.profile && ${e}'`,{shell:!0,stdio:s});return a.status!==0?(console.log(`\u26A0\uFE0F CMD Failed. Please check your SSH connection.
692
692
  $ ssh solv@${t}
693
693
 
694
694
  Failed Cmd: ${e}`),i={status:a.status,stdout:String(a.stdout),stderr:a.stderr.toString()},i):(i={status:a.status,stdout:a.stdout.toString(),stderr:a.stderr.toString()},i)}catch(a){return console.log(`scpSSH Error: ${a}`),i={status:null,stdout:"",stderr:String(a)},i}},"scpSSH"),Eo=Sd;import Qi from"chalk";var Td=r((t,e,o)=>{console.log(Qi.white("\u{1F50D} Checking If Destination Validator Key is the same..."));let s=C(t).trim(),n=Eo(e,`solana-keygen pubkey ${t}`,o).stdout.toString().trim();return s!==n?(console.log(Qi.yellow(`\u26A0\uFE0F Destination Identity Key is different.