@gabrielhicks/solv 5.3.15 → 5.3.17

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,18 +1,18 @@
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 nr="5.3.15";var ir={name:"@gabrielhicks/solv",version:nr,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=ir.version;var te="https://validators.solutions";var we="solv4.config.json";var vt="identity.json",Nt="unstaked-identity.json",ar="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",lr="solana-validator",cr="agave-validator",mr="ELLB9W7ZCwRCV3FzWcCWoyKP6NjZJKArLyGtkqefnHcG";var Ne=3,pr="https://api.testnet.solana.com",dr="https://api.mainnet-beta.solana.com",ur="https://verify.validators.solutions/solv-migrate",hr="https://jup.validators.solutions/v1/jup",Ro;(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"})(Ro||(Ro={}));var fr=Object.values(Ro),Re="So11111111111111111111111111111111111111112",Oe="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",Oo="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC";var yr="SOLV420",Sr={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 nr="5.3.17";var ir={name:"@gabrielhicks/solv",version:nr,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=ir.version;var te="https://validators.solutions";var we="solv4.config.json";var vt="identity.json",Nt="unstaked-identity.json",ar="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",lr="solana-validator",cr="agave-validator",mr="ELLB9W7ZCwRCV3FzWcCWoyKP6NjZJKArLyGtkqefnHcG";var Ne=3,pr="https://api.testnet.solana.com",dr="https://api.mainnet-beta.solana.com",ur="https://verify.validators.solutions/solv-migrate",hr="https://jup.validators.solutions/v1/jup",Ro;(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"})(Ro||(Ro={}));var fr=Object.values(Ro),Re="So11111111111111111111111111111111111111112",Oe="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",Oo="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC";var yr="SOLV420",Sr={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 _}from"node:child_process";var Va=r((t,e=!1)=>{e?(_("sudo apt-get update",{shell:!0,stdio:"inherit"}),_("sudo apt-get install -y libclang-18-dev clang-18 llvm-18-dev",{shell:!0,stdio:"inherit"}),_("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"}),_("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"}),_("source /home/solv/.profile",{shell:!0,stdio:"inherit"}),_(`mkdir /tmp/v${t}-agave-mod`,{shell:!0,stdio:"inherit"}),_(`cd /tmp/v${t}-agave-mod`,{shell:!0,stdio:"inherit"}),_(`git clone https://github.com/gabrielhicks/agave.git --recurse-submodules /tmp/v${t}-agave-mod`,{shell:!0,stdio:"inherit"}),_(`git -C /tmp/v${t}-agave-mod checkout v${t}-mod`,{shell:!0,stdio:"inherit"}),_(`git -C /tmp/v${t}-agave-mod submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),_(`CI_COMMIT=$(git -C /tmp/v${t}-agave-mod rev-parse HEAD) /tmp/v${t}-agave-mod/scripts/cargo-install-all.sh --validator-only /home/solv/.local/share/solana/install/releases/v${t}-agave-mod`,{shell:!0,stdio:"inherit"}),_("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),_(`cp -r /home/solv/.local/share/solana/install/releases/v${t}-agave-mod/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),_(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
3
3
  n
4
4
  /^LimitMEMLOCK=infinity$/!i LimitMEMLOCK=infinity
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$/{
5
+ }' /etc/systemd/system/solv.service`,{shell:!0,stdio:"inherit"}),_("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\\\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),_(`sudo rm -rf /tmp/v${t}-agave-mod`,{shell:!0,stdio:"inherit"}),_("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})):(_("sudo apt-get update",{shell:!0,stdio:"inherit"}),_("sudo apt-get install -y libclang-18-dev clang-18 llvm-18-dev",{shell:!0,stdio:"inherit"}),_("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"}),_("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"}),_("source /home/solv/.profile",{shell:!0,stdio:"inherit"}),_(`mkdir /tmp/v${t}-agave`,{shell:!0,stdio:"inherit"}),_(`cd /tmp/v${t}-agave`,{shell:!0,stdio:"inherit"}),_(`git clone https://github.com/anza-xyz/agave.git --recurse-submodules /tmp/v${t}-agave`,{shell:!0,stdio:"inherit"}),_(`git -C /tmp/v${t}-agave checkout v${t}`,{shell:!0,stdio:"inherit"}),_(`git -C /tmp/v${t}-agave submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),_(`CI_COMMIT=$(git -C /tmp/v${t}-agave rev-parse HEAD) /tmp/v${t}-agave/scripts/cargo-install-all.sh --validator-only /home/solv/.local/share/solana/install/releases/v${t}-agave`,{shell:!0,stdio:"inherit"}),_("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),_(`cp -r /home/solv/.local/share/solana/install/releases/v${t}-agave/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),_(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
6
6
  n
7
7
  /^LimitMEMLOCK=infinity$/!i LimitMEMLOCK=infinity
8
- }' /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}`,{shell:!0,stdio:"inherit"}),w("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}))},"installAgave"),$t=Va;var Tr="agave-validator",ba=r(()=>{try{return Tr}catch(t){return console.error(t),Tr}},"getSolanaCLI"),it=ba;var Ce=r(async(t,e=!1)=>{$t(t,e)},"updateVersion"),ke=r(async(t,e=!1,o=10)=>{let s=it(),n=`${s} --ledger ${N} exit --max-delinquent-stake ${t} --monitor --min-idle-time ${o}`;e&&(n=`${s} --ledger ${N} exit --max-delinquent-stake ${t} --min-idle-time ${o}`),Da(n,{shell:!0,stdio:"inherit"})},"monitorUpdate");import ls from"chalk";var Rt;(function(t){t.EN="en",t.JA="ja"})(Rt||(Rt={}));var gr;(function(t){t[t.DOUBLE=0]="DOUBLE",t[t.SINGLE=1]="SINGLE",t[t.TRIPLE=2]="TRIPLE"})(gr||(gr={}));var Er;(function(t){t.SINGLE="single",t.DOUBLE="double",t.TRIPLE="triple"})(Er||(Er={}));var St;(function(t){t.MAINNET="mainnet-beta",t.TESTNET="testnet"})(St||(St={}));var Ar;(function(t){t.VALIDATOR="validator",t.RPC="rpc"})(Ar||(Ar={}));var wr;(function(t){t.SOLANA="solana",t.JITO="jito",t.AGAVE="agave",t.FIREDANCER="firedancer"})(wr||(wr={}));var _r;(function(t){t.CO_HOST_RELAYER="co-host-relayer",t.SEPARATED_RELAYER="separated-relayer",t.WITHOUT_RELAYER="without-relayer"})(_r||(_r={}));var vr;(function(t){t.FIREDANCER="firedancer",t.FRANKENDANCER="frankendancer"})(vr||(vr={}));var Le;(function(t){t[t.TESTNET_VALIDATOR=0]="TESTNET_VALIDATOR",t[t.MAINNET_VALIDATOR=1]="MAINNET_VALIDATOR",t[t.RPC_NODE=2]="RPC_NODE"})(Le||(Le={}));var Ie;(function(t){t.SOLANA_CLIENT="SolanaClient",t.JITO_MEV="JitoMev",t.FIREDANCER="Firedancer"})(Ie||(Ie={}));var Or=!1,Cr=!0,kr=!1,Lr=!1,J={ID:"solv",LANG:Rt.EN,USERNAME:"solv",TESTNET_SOLANA_VERSION:"3.0.0",MAINNET_SOLANA_VERSION:"2.3.7",NODE_VERSION:"20.17.0",TESTNET_DELINQUENT_STAKE:5,MAINNET_DELINQUENT_STAKE:5,COMMISSION:5,SOLANA_NETWORK:"testnet",SOLV_TYPE:0,DISK_TYPES:1,IS_SETUP:!1,LANG_SETUP:!1,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:"ELLB9W7ZCwRCV3FzWcCWoyKP6NjZJKArLyGtkqefnHcG",IS_CLIENT:!1,VALIDATOR_IPS:[],MAINNET_TYPE:"SolanaClient",LEDGER_PATH:"/mnt/ledger",STAKE_ACCOUNT:[],HARVEST_ACCOUNT:"",IS_MEV_MODE:!1,RPC_URL:"https://mainnet-beta.solana.com",KEYPAIR_PATH:"/home/solv/testnet-validator-keypair.json",DISCORD_WEBHOOK_URL:"",AUTO_UPDATE:!1,AUTO_RESTART:!1,ACCOUNTS_PATH:"/mnt/accounts",SNAPSHOTS_PATH:"/mnt/snapshots",MOD:!1},H={ROOT:"/home/solv",AUTHORIZED_KEYS:"/home/solv/.ssh/authorized_keys"},R={ROOT:"/mnt",ACCOUNTS:"/mnt/accounts",LEDGER:"/mnt/ledger",SNAPSHOTS:"/mnt/snapshots"},at={LOG:"solana-validator.log",STARTUP_SCRIPT:"start-validator.sh",CONFIG:"solv.config.json",JITO_CONFIG:"jito.config.json"},P={SOL_SERVICE:"/etc/systemd/system/solv.service",SOL_LOGROTATE:"/etc/logrotate.d/solana",FRANKENDANCER_LOGROTATE:"/etc/logrotate.d/frankendancer",SOL_SYSTEM_CONFIG21:"/etc/sysctl.d/21-solana-validator.conf",SOL_NOFILES_CONF:"/etc/security/limits.d/90-solana-nofiles.conf",SOL_SYSTEM_CONF:"/etc/systemd/system.conf",SOLANA_PATH:"/home/solv/.local/share/solana/install"},x={MAINNET_VALIDATOR_KEY:"mainnet-validator-keypair.json",MAINNET_VALIDATOR_VOTE_KEY:"mainnet-vote-account-keypair.json",MAINNET_VALITATOR_AUTHORITY_KEY:"mainnet-authority-keypair.json",TESTNET_VALIDATOR_KEY:"testnet-validator-keypair.json",TESTNET_VALIDATOR_VOTE_KEY:"testnet-vote-account-keypair.json",TESTNET_VALITATOR_AUTHORITY_KEY:"testnet-authority-keypair.json"},O=r((t=H.ROOT)=>{let e=t===H.ROOT?H.ROOT:t,o=`${e}/${x.MAINNET_VALIDATOR_KEY}`,s=`${e}/${x.MAINNET_VALIDATOR_VOTE_KEY}`,n=`${e}/${x.MAINNET_VALITATOR_AUTHORITY_KEY}`,i=`${e}/${x.TESTNET_VALIDATOR_KEY}`,a=`${e}/${x.TESTNET_VALIDATOR_VOTE_KEY}`,l=`${e}/${x.TESTNET_VALITATOR_AUTHORITY_KEY}`;return{mainnetValidatorKey:o,mainnetValidatorVoteKey:s,mainnetValidatorAuthorityKey:n,testnetValidatorKey:i,testnetValidatorVoteKey:a,testnetValidatorAuthorityKey:l}},"getAllKeyPaths"),Tt=r((t=!0)=>{let e=t?`${H.ROOT}/${x.TESTNET_VALIDATOR_KEY}`:`${H.ROOT}/${x.MAINNET_VALIDATOR_KEY}`,o=t?`${H.ROOT}/${x.TESTNET_VALIDATOR_VOTE_KEY}`:`${H.ROOT}/${x.MAINNET_VALIDATOR_VOTE_KEY}`,s=`${H.ROOT}/${at.LOG}`,n=R.ACCOUNTS,i=R.LEDGER,a=R.SNAPSHOTS,l=`${H.ROOT}/${at.STARTUP_SCRIPT}`;return{identity:e,voteAccount:o,log:s,accounts:n,ledger:i,scriptPath:l,snapshots:a}},"startupScriptPaths");var et="So1vW4Bm6ZURzJJHZy1JpsjoVY68z4cDgF4tTLwYMa5",Co="7tAfLKgRVd9eywSQPuMbVNd51KGkaveZQuTjapL74Fwv",Ir="EiwSTx1Z2uJATDut682U7xzzquFR4UpQJUij3wSxVoSV",Pr=9,lt="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC",xr="So11111111111111111111111111111111111111112",$r="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",Vr="CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP",Nr;(function(t){t[t.ELSOL=lt]="ELSOL",t[t.SOL=xr]="SOL",t[t.USDC=$r]="USDC",t[t.EPCT=Vr]="EPCT"})(Nr||(Nr={}));var Rr;(function(t){t.V6_BASE_URL="https://quote-api.jup.ag/v6",t.V6_QUOTE_URL="https://quote-api.jup.ag/v6/quote",t.V6_SWAP_URL="https://quote-api.jup.ag/v6/swap"})(Rr||(Rr={}));var Au={[xr]:9,[lt]:9,[$r]:6,[Vr]:6},Pe="/home/solv/currentEpoch.json",ko=.5,xe="https://api.testnet.solana.com";import{spawnSync as Lo}from"child_process";var br=r(()=>{Lo("pnpm add -g pnpm",{shell:!0,stdio:"inherit"});let t=J.NODE_VERSION;Lo(`pnpm env use ${t} --global`,{shell:!0,stdio:"inherit"}),Lo("pnpm add -g @gabrielhicks/solv",{shell:!0,stdio:"inherit"})},"updateSolv");var dt={version:"2.3.6",tag:"v2.3.6",commissionBps:1e3,relayerUrl:"http://frankfurt.mainnet.relayer.jito.wtf:8100",blockEngineUrl:"https://frankfurt.mainnet.block-engine.jito.wtf",shredReceiverAddr:"64.130.50.14:1002"},ee={TESTNET:{Dallas:{BLOCK_ENGINE_URL:"https://dallas.testnet.block-engine.jito.wtf",RELAYER_URL:"http://dallas.testnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"141.98.218.12:1002"},NewYork:{BLOCK_ENGINE_URL:"https://ny.testnet.block-engine.jito.wtf",RELAYER_URL:"http://ny.testnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"64.130.35.224:1002"}},MAINNET:{Amsterdam:{BLOCK_ENGINE_URL:"https://amsterdam.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://amsterdam.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"74.118.140.240:1002"},London:{BLOCK_ENGINE_URL:"https://london.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://london.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"142.91.127.175:1002"},Frankfurt:{BLOCK_ENGINE_URL:"https://frankfurt.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://frankfurt.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"64.130.50.14:1002"},NewYork:{BLOCK_ENGINE_URL:"https://ny.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://ny.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"141.98.216.96:1002"},Tokyo:{BLOCK_ENGINE_URL:"https://tokyo.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://tokyo.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"202.8.9.160:1002"},SaltLakeCity:{BLOCK_ENGINE_URL:"https://slc.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://slc.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"64.130.53.8:1002"},Singapore:{BLOCK_ENGINE_URL:"https://singapore.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://singapore.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"202.8.11.224:1002"}}};import{spawnSync as _}from"child_process";var $e=r((t=dt.tag,e=!1)=>{e?(_("sudo apt-get update",{shell:!0,stdio:"inherit"}),_("sudo apt-get install -y libclang-18-dev clang-18 llvm-18-dev",{shell:!0,stdio:"inherit"}),_("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"}),_("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"}),_("source /home/solv/.profile",{shell:!0,stdio:"inherit"}),_(`mkdir /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),_(`cd /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),_(`git clone https://github.com/gabrielhicks/jito-solana.git --recurse-submodules /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),_(`git -C /tmp/${t}-mod checkout ${t}-mod`,{shell:!0,stdio:"inherit"}),_(`git -C /tmp/${t}-mod submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),_(`CI_COMMIT=$(git -C /tmp/${t}-mod rev-parse HEAD) /tmp/${t}-mod/scripts/cargo-install-all.sh --validator-only /home/solv/.local/share/solana/install/releases/${t}-mod`,{shell:!0,stdio:"inherit"}),_("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),_(`cp -r /home/solv/.local/share/solana/install/releases/${t}-mod/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),_(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
8
+ }' /etc/systemd/system/solv.service`,{shell:!0,stdio:"inherit"}),_("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\\\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),_(`sudo rm -rf /tmp/v${t}-agave`,{shell:!0,stdio:"inherit"}),_("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}))},"installAgave"),$t=Va;var Tr="agave-validator",ba=r(()=>{try{return Tr}catch(t){return console.error(t),Tr}},"getSolanaCLI"),it=ba;var Ce=r(async(t,e=!1)=>{$t(t,e)},"updateVersion"),ke=r(async(t,e=!1,o=10)=>{let s=it(),n=`${s} --ledger ${N} exit --max-delinquent-stake ${t} --monitor --min-idle-time ${o}`;e&&(n=`${s} --ledger ${N} exit --max-delinquent-stake ${t} --min-idle-time ${o}`),Da(n,{shell:!0,stdio:"inherit"})},"monitorUpdate");import ls from"chalk";var Rt;(function(t){t.EN="en",t.JA="ja"})(Rt||(Rt={}));var gr;(function(t){t[t.DOUBLE=0]="DOUBLE",t[t.SINGLE=1]="SINGLE",t[t.TRIPLE=2]="TRIPLE"})(gr||(gr={}));var Er;(function(t){t.SINGLE="single",t.DOUBLE="double",t.TRIPLE="triple"})(Er||(Er={}));var St;(function(t){t.MAINNET="mainnet-beta",t.TESTNET="testnet"})(St||(St={}));var Ar;(function(t){t.VALIDATOR="validator",t.RPC="rpc"})(Ar||(Ar={}));var wr;(function(t){t.SOLANA="solana",t.JITO="jito",t.AGAVE="agave",t.FIREDANCER="firedancer"})(wr||(wr={}));var _r;(function(t){t.CO_HOST_RELAYER="co-host-relayer",t.SEPARATED_RELAYER="separated-relayer",t.WITHOUT_RELAYER="without-relayer"})(_r||(_r={}));var vr;(function(t){t.FIREDANCER="firedancer",t.FRANKENDANCER="frankendancer"})(vr||(vr={}));var Le;(function(t){t[t.TESTNET_VALIDATOR=0]="TESTNET_VALIDATOR",t[t.MAINNET_VALIDATOR=1]="MAINNET_VALIDATOR",t[t.RPC_NODE=2]="RPC_NODE"})(Le||(Le={}));var Ie;(function(t){t.SOLANA_CLIENT="SolanaClient",t.JITO_MEV="JitoMev",t.FIREDANCER="Firedancer"})(Ie||(Ie={}));var Or=!1,Cr=!1,kr=!1,Lr=!1,J={ID:"solv",LANG:Rt.EN,USERNAME:"solv",TESTNET_SOLANA_VERSION:"3.0.0",MAINNET_SOLANA_VERSION:"2.3.7",NODE_VERSION:"20.17.0",TESTNET_DELINQUENT_STAKE:5,MAINNET_DELINQUENT_STAKE:5,COMMISSION:5,SOLANA_NETWORK:"testnet",SOLV_TYPE:0,DISK_TYPES:1,IS_SETUP:!1,LANG_SETUP:!1,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:"ELLB9W7ZCwRCV3FzWcCWoyKP6NjZJKArLyGtkqefnHcG",IS_CLIENT:!1,VALIDATOR_IPS:[],MAINNET_TYPE:"SolanaClient",LEDGER_PATH:"/mnt/ledger",STAKE_ACCOUNT:[],HARVEST_ACCOUNT:"",IS_MEV_MODE:!1,RPC_URL:"https://mainnet-beta.solana.com",KEYPAIR_PATH:"/home/solv/testnet-validator-keypair.json",DISCORD_WEBHOOK_URL:"",AUTO_UPDATE:!1,AUTO_RESTART:!1,ACCOUNTS_PATH:"/mnt/accounts",SNAPSHOTS_PATH:"/mnt/snapshots",MOD:!1},H={ROOT:"/home/solv",AUTHORIZED_KEYS:"/home/solv/.ssh/authorized_keys"},R={ROOT:"/mnt",ACCOUNTS:"/mnt/accounts",LEDGER:"/mnt/ledger",SNAPSHOTS:"/mnt/snapshots"},at={LOG:"solana-validator.log",STARTUP_SCRIPT:"start-validator.sh",CONFIG:"solv.config.json",JITO_CONFIG:"jito.config.json"},P={SOL_SERVICE:"/etc/systemd/system/solv.service",SOL_LOGROTATE:"/etc/logrotate.d/solana",FRANKENDANCER_LOGROTATE:"/etc/logrotate.d/frankendancer",SOL_SYSTEM_CONFIG21:"/etc/sysctl.d/21-solana-validator.conf",SOL_NOFILES_CONF:"/etc/security/limits.d/90-solana-nofiles.conf",SOL_SYSTEM_CONF:"/etc/systemd/system.conf",SOLANA_PATH:"/home/solv/.local/share/solana/install"},x={MAINNET_VALIDATOR_KEY:"mainnet-validator-keypair.json",MAINNET_VALIDATOR_VOTE_KEY:"mainnet-vote-account-keypair.json",MAINNET_VALITATOR_AUTHORITY_KEY:"mainnet-authority-keypair.json",TESTNET_VALIDATOR_KEY:"testnet-validator-keypair.json",TESTNET_VALIDATOR_VOTE_KEY:"testnet-vote-account-keypair.json",TESTNET_VALITATOR_AUTHORITY_KEY:"testnet-authority-keypair.json"},O=r((t=H.ROOT)=>{let e=t===H.ROOT?H.ROOT:t,o=`${e}/${x.MAINNET_VALIDATOR_KEY}`,s=`${e}/${x.MAINNET_VALIDATOR_VOTE_KEY}`,n=`${e}/${x.MAINNET_VALITATOR_AUTHORITY_KEY}`,i=`${e}/${x.TESTNET_VALIDATOR_KEY}`,a=`${e}/${x.TESTNET_VALIDATOR_VOTE_KEY}`,l=`${e}/${x.TESTNET_VALITATOR_AUTHORITY_KEY}`;return{mainnetValidatorKey:o,mainnetValidatorVoteKey:s,mainnetValidatorAuthorityKey:n,testnetValidatorKey:i,testnetValidatorVoteKey:a,testnetValidatorAuthorityKey:l}},"getAllKeyPaths"),Tt=r((t=!0)=>{let e=t?`${H.ROOT}/${x.TESTNET_VALIDATOR_KEY}`:`${H.ROOT}/${x.MAINNET_VALIDATOR_KEY}`,o=t?`${H.ROOT}/${x.TESTNET_VALIDATOR_VOTE_KEY}`:`${H.ROOT}/${x.MAINNET_VALIDATOR_VOTE_KEY}`,s=`${H.ROOT}/${at.LOG}`,n=R.ACCOUNTS,i=R.LEDGER,a=R.SNAPSHOTS,l=`${H.ROOT}/${at.STARTUP_SCRIPT}`;return{identity:e,voteAccount:o,log:s,accounts:n,ledger:i,scriptPath:l,snapshots:a}},"startupScriptPaths");var et="So1vW4Bm6ZURzJJHZy1JpsjoVY68z4cDgF4tTLwYMa5",Co="7tAfLKgRVd9eywSQPuMbVNd51KGkaveZQuTjapL74Fwv",Ir="EiwSTx1Z2uJATDut682U7xzzquFR4UpQJUij3wSxVoSV",Pr=9,lt="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC",xr="So11111111111111111111111111111111111111112",$r="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",Vr="CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP",Nr;(function(t){t[t.ELSOL=lt]="ELSOL",t[t.SOL=xr]="SOL",t[t.USDC=$r]="USDC",t[t.EPCT=Vr]="EPCT"})(Nr||(Nr={}));var Rr;(function(t){t.V6_BASE_URL="https://quote-api.jup.ag/v6",t.V6_QUOTE_URL="https://quote-api.jup.ag/v6/quote",t.V6_SWAP_URL="https://quote-api.jup.ag/v6/swap"})(Rr||(Rr={}));var Au={[xr]:9,[lt]:9,[$r]:6,[Vr]:6},Pe="/home/solv/currentEpoch.json",ko=.5,xe="https://api.testnet.solana.com";import{spawnSync as Lo}from"child_process";var br=r(()=>{Lo("pnpm add -g pnpm",{shell:!0,stdio:"inherit"});let t=J.NODE_VERSION;Lo(`pnpm env use ${t} --global`,{shell:!0,stdio:"inherit"}),Lo("pnpm add -g @gabrielhicks/solv",{shell:!0,stdio:"inherit"})},"updateSolv");var dt={version:"2.3.6",tag:"v2.3.6",commissionBps:1e3,relayerUrl:"http://frankfurt.mainnet.relayer.jito.wtf:8100",blockEngineUrl:"https://frankfurt.mainnet.block-engine.jito.wtf",shredReceiverAddr:"64.130.50.14:1002"},ee={TESTNET:{Dallas:{BLOCK_ENGINE_URL:"https://dallas.testnet.block-engine.jito.wtf",RELAYER_URL:"http://dallas.testnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"141.98.218.12:1002"},NewYork:{BLOCK_ENGINE_URL:"https://ny.testnet.block-engine.jito.wtf",RELAYER_URL:"http://ny.testnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"64.130.35.224:1002"}},MAINNET:{Amsterdam:{BLOCK_ENGINE_URL:"https://amsterdam.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://amsterdam.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"74.118.140.240:1002"},London:{BLOCK_ENGINE_URL:"https://london.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://london.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"142.91.127.175:1002"},Frankfurt:{BLOCK_ENGINE_URL:"https://frankfurt.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://frankfurt.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"64.130.50.14:1002"},NewYork:{BLOCK_ENGINE_URL:"https://ny.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://ny.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"141.98.216.96:1002"},Tokyo:{BLOCK_ENGINE_URL:"https://tokyo.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://tokyo.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"202.8.9.160:1002"},SaltLakeCity:{BLOCK_ENGINE_URL:"https://slc.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://slc.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"64.130.53.8:1002"},Singapore:{BLOCK_ENGINE_URL:"https://singapore.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://singapore.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"202.8.11.224:1002"}}};import{spawnSync as w}from"child_process";var $e=r((t=dt.tag,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}-mod`,{shell:!0,stdio:"inherit"}),w(`cd /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),w(`git clone https://github.com/gabrielhicks/jito-solana.git --recurse-submodules /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),w(`git -C /tmp/${t}-mod checkout ${t}-mod`,{shell:!0,stdio:"inherit"}),w(`git -C /tmp/${t}-mod submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),w(`CI_COMMIT=$(git -C /tmp/${t}-mod rev-parse HEAD) /tmp/${t}-mod/scripts/cargo-install-all.sh --validator-only /home/solv/.local/share/solana/install/releases/${t}-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}-mod/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),w(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
9
9
  n
10
10
  /^LimitMEMLOCK=infinity$/!i LimitMEMLOCK=infinity
11
- }' /etc/systemd/system/solv.service`,{shell:!0,stdio:"inherit"}),_("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\\\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),_(`sudo rm -rf /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),_("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})):(_("sudo apt-get update",{shell:!0,stdio:"inherit"}),_("sudo apt-get install -y libclang-18-dev clang-18 llvm-18-dev",{shell:!0,stdio:"inherit"}),_("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"}),_("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"}),_("source /home/solv/.profile",{shell:!0,stdio:"inherit"}),_(`mkdir /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),_(`cd /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),_(`git clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),_(`git -C /tmp/${t}-jito checkout ${t}-jito`,{shell:!0,stdio:"inherit"}),_(`git -C /tmp/${t}-jito submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),_(`CI_COMMIT=$(git -C /tmp/${t}-jito rev-parse HEAD) /tmp/${t}-jito/scripts/cargo-install-all.sh --validator-only /home/solv/.local/share/solana/install/releases/${t}-jito`,{shell:!0,stdio:"inherit"}),_("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),_(`cp -r /home/solv/.local/share/solana/install/releases/${t}-jito/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),_(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
11
+ }' /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}-mod`,{shell:!0,stdio:"inherit"}),w("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}),w("solv get snapshot",{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}-jito`,{shell:!0,stdio:"inherit"}),w(`cd /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),w(`git clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),w(`git -C /tmp/${t}-jito checkout ${t}-jito`,{shell:!0,stdio:"inherit"}),w(`git -C /tmp/${t}-jito submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),w(`CI_COMMIT=$(git -C /tmp/${t}-jito rev-parse HEAD) /tmp/${t}-jito/scripts/cargo-install-all.sh --validator-only /home/solv/.local/share/solana/install/releases/${t}-jito`,{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}-jito/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),w(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
12
12
  n
13
13
  /^LimitMEMLOCK=infinity$/!i LimitMEMLOCK=infinity
14
- }' /etc/systemd/system/solv.service`,{shell:!0,stdio:"inherit"}),_("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\\\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),_(`sudo rm -rf /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),_("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}))},"jitoUpdate");import{readFile as Ka,writeFile as Ua}from"fs/promises";import{homedir as Ma}from"os";var oe=r(async t=>{let o=`${Ma()}/${at.JITO_CONFIG}`,n={...JSON.parse(await Ka(o,"utf8")),...t},i=JSON.stringify(n,null,2);await Ua(o,i),console.log(`Updated ${o} with new values.`)},"updateJitoSolvConfig");import{spawnSync as Dr}from"child_process";import Ha from"inquirer";var Kr=r((t,e=!0)=>{let o=e?"/home/solv/testnet-validator-keypair.json":"/home/solv/mainnet-validator-keypair.json",s=e?"/home/solv/testnet-vote-account-keypair.json":"/home/solv/mainnet-vote-account-keypair.json";Dr(`solana config set --url ${e?"testnet":"mainnet-beta"} --keypair ${o}`,{shell:!0,stdio:"inherit"});let i=`solana vote-update-commission ${s} ${t} ${o} --keypair ${o}`;Dr(i,{shell:!0,stdio:"inherit"})},"updateCommission"),Ur=r(async()=>await Ha.prompt([{type:"number",name:"commission",message:"Enter new commission",default:7}]),"updateCommissionAsk");import{execAsync as re}from"@skeet-framework/utils";import Fa from"chalk";import ja from"inquirer";var Mr=r(async()=>{let t=await ja.prompt([{name:"ip",type:"input",message:"Enter your IP address to allow access to RPC NODE:",default:"1.2.3.4"}]);await re("sudo ufw delete allow 8899/udp"),await re("sudo ufw delete allow 8899/tcp"),await re(`sudo ufw allow from ${t.ip} to any port 8899 proto tcp`),await re(`sudo ufw allow from ${t.ip} to any port 8899 proto udp`),await re("sudo ufw reload"),console.log(Fa.white("\u2714\uFE0F Firewall updated!"))},"updateFirewall");var Ya=r(()=>nr,"getSolvVersion"),Vt=Ya;import{readFile as Ja,writeFile as za}from"fs/promises";import{existsAsync as Wa}from"@skeet-framework/utils";var Io;(function(t){t.EN="en",t.JA="ja"})(Io||(Io={}));var Wu=Object.values(Io),h;(function(t){t.MAINNET="mainnet-beta",t.TESTNET="testnet"})(h||(h={}));var Hr=Object.values(h),E;(function(t){t.RPC="rpc",t.VALIDATOR="validator"})(E||(E={}));var Fr=Object.values(E),T;(function(t){t.SOLANA="solana",t.AGAVE="agave",t.JITO="jito",t.FRANKENDANCER="frankendancer",t.NONE="none"})(T||(T={}));var qu=Object.values(T).filter(t=>t!=="none"),U;(function(t){t.AGAVE="agave",t.JITO="jito",t.NONE="none"})(U||(U={}));var jr=Object.values(U).filter(t=>t!=="none"),z;(function(t){t.SINGLE="single",t.DOUBLE="double",t.TRIPLE="triple"})(z||(z={}));var W="3.0.0",F="2.3.7",Ot="3.0.0",se="2.3.7",Yr="2.3.7",Ct="2.3.7";var Gr="20.17.0",bt="0.707.20306",Dt="0.707.20306";var Ba={NETWORK:h.TESTNET,NODE_TYPE:E.RPC,VALIDATOR_TYPE:T.NONE,RPC_TYPE:U.AGAVE,MNT_DISK_TYPE:z.TRIPLE,TESTNET_SOLANA_VERSION:W,MAINNET_SOLANA_VERSION:F,NODE_VERSION:Gr,TESTNET_DELINQUENT_STAKE:10,MAINNET_DELINQUENT_STAKE:5,COMMISSION:5,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:mr,STAKE_ACCOUNTS:[],HARVEST_ACCOUNT:"",IS_MEV_MODE:!1,RPC_URL:dr,KEYPAIR_PATH:"",DISCORD_WEBHOOK_URL:"",AUTO_UPDATE:!1,AUTO_RESTART:!1,IS_DUMMY:!1,API_KEY:"",LEDGER_PATH:N,ACCOUNTS_PATH:xt,SNAPSHOTS_PATH:nt,MOD:!1},ut=Ba;import{homedir as qa}from"os";var Qa=r(async()=>{let e=`${qa()}/${we}`;return await Wa(e)?JSON.parse(await Ja(e,"utf-8")):(console.log("Creating default config file at",e),await za(e,JSON.stringify(ut,null,2)),ut)},"readConfig"),D=Qa;import Za from"node-fetch";var Z=r(async t=>{try{let e=await D();if(e.DISCORD_WEBHOOK_URL==="")throw new Error(`DISCORD_WEBHOOK_URL is empty
15
- Please set DISCORD_WEBHOOK_URL in .env`);let o={content:t,username:"\u{1FA84} Solv Notifier"};return(await Za(e.DISCORD_WEBHOOK_URL,{method:"POST",body:JSON.stringify(o),headers:{"Content-Type":"application/json"}})).status===204}catch{return console.log({error:`Skeet sendDiscord Error - ${t}`}),!1}},"sendDiscord");import{spawnSync as rl}from"child_process";import{Connection as Br}from"@solana/web3.js";var ne=r(async(t,e,o=!1,s=200)=>{let n={pubkey:e,isActive:!1,reason:""};try{let i=o?new Br("https://api.testnet.solana.com"):new Br(t,"confirmed"),a=await i.getVoteAccounts(),l=a.current.find(u=>u.votePubkey===e);if(!l)return a.delinquent.find(p=>p.votePubkey===e)?(n.isActive=!1,n.reason="Validator is delinquent.",n):(n.isActive=!1,n.reason="Validator is not found in both current and delinquent lists.",n);if(a=await i.getVoteAccounts(),l=a.current.find(u=>u.votePubkey===e),!l)return n.isActive=!1,n.reason="Validator is not found in the current list.",n;let c=l.lastVote,d=await i.getSlot()-c;return d>s?(n.isActive=!1,n.reason=`Validator has not voted for ${d} slots.`,n):(n.isActive=!0,n.reason="Validator is active and voting.",n)}catch(i){return console.error(i),n.isActive=!1,n.reason="Failed to check validator status.",n}},"isValidatorActive");import{spawnSync as Xa}from"child_process";var C=r(t=>{let e=`solana address --keypair ${t}`,{stdout:o}=Xa(e,{shell:!0,stdio:"pipe"});return o.toString().trim()},"getSolanaAddress");var tl=r(t=>new Promise(e=>setTimeout(e,t)),"sleep"),j=tl;import{sendDiscord as el}from"@skeet-framework/utils";var Jr=60,ol=r(async t=>{try{let e=t.NETWORK===h.TESTNET,{mainnetValidatorVoteKey:o,testnetValidatorVoteKey:s}=O(),i=C(e?s:o),a=await ne(t.RPC_URL,i,e),l=0;for(;!a.isActive;){if(l>=Jr){console.log("Max retries reached, exiting...");let c=`\u26A0\uFE0F Validator is not active for ${Jr} minutes!
14
+ }' /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}-jito`,{shell:!0,stdio:"inherit"}),w("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}),w("solv get snapshot",{shell:!0,stdio:"inherit"}))},"jitoUpdate");import{readFile as Ka,writeFile as Ua}from"fs/promises";import{homedir as Ma}from"os";var oe=r(async t=>{let o=`${Ma()}/${at.JITO_CONFIG}`,n={...JSON.parse(await Ka(o,"utf8")),...t},i=JSON.stringify(n,null,2);await Ua(o,i),console.log(`Updated ${o} with new values.`)},"updateJitoSolvConfig");import{spawnSync as Dr}from"child_process";import Ha from"inquirer";var Kr=r((t,e=!0)=>{let o=e?"/home/solv/testnet-validator-keypair.json":"/home/solv/mainnet-validator-keypair.json",s=e?"/home/solv/testnet-vote-account-keypair.json":"/home/solv/mainnet-vote-account-keypair.json";Dr(`solana config set --url ${e?"testnet":"mainnet-beta"} --keypair ${o}`,{shell:!0,stdio:"inherit"});let i=`solana vote-update-commission ${s} ${t} ${o} --keypair ${o}`;Dr(i,{shell:!0,stdio:"inherit"})},"updateCommission"),Ur=r(async()=>await Ha.prompt([{type:"number",name:"commission",message:"Enter new commission",default:7}]),"updateCommissionAsk");import{execAsync as re}from"@skeet-framework/utils";import Fa from"chalk";import ja from"inquirer";var Mr=r(async()=>{let t=await ja.prompt([{name:"ip",type:"input",message:"Enter your IP address to allow access to RPC NODE:",default:"1.2.3.4"}]);await re("sudo ufw delete allow 8899/udp"),await re("sudo ufw delete allow 8899/tcp"),await re(`sudo ufw allow from ${t.ip} to any port 8899 proto tcp`),await re(`sudo ufw allow from ${t.ip} to any port 8899 proto udp`),await re("sudo ufw reload"),console.log(Fa.white("\u2714\uFE0F Firewall updated!"))},"updateFirewall");var Ya=r(()=>nr,"getSolvVersion"),Vt=Ya;import{readFile as Ja,writeFile as za}from"fs/promises";import{existsAsync as Wa}from"@skeet-framework/utils";var Io;(function(t){t.EN="en",t.JA="ja"})(Io||(Io={}));var Wu=Object.values(Io),h;(function(t){t.MAINNET="mainnet-beta",t.TESTNET="testnet"})(h||(h={}));var Hr=Object.values(h),E;(function(t){t.RPC="rpc",t.VALIDATOR="validator"})(E||(E={}));var Fr=Object.values(E),T;(function(t){t.SOLANA="solana",t.AGAVE="agave",t.JITO="jito",t.FRANKENDANCER="frankendancer",t.NONE="none"})(T||(T={}));var qu=Object.values(T).filter(t=>t!=="none"),U;(function(t){t.AGAVE="agave",t.JITO="jito",t.NONE="none"})(U||(U={}));var jr=Object.values(U).filter(t=>t!=="none"),z;(function(t){t.SINGLE="single",t.DOUBLE="double",t.TRIPLE="triple"})(z||(z={}));var W="3.0.0",F="2.3.7",Ot="3.0.0",se="2.3.7",Yr="2.3.7",Ct="2.3.7";var Gr="20.17.0",bt="0.707.20306",Dt="0.707.20306";var Ba={NETWORK:h.TESTNET,NODE_TYPE:E.RPC,VALIDATOR_TYPE:T.NONE,RPC_TYPE:U.AGAVE,MNT_DISK_TYPE:z.TRIPLE,TESTNET_SOLANA_VERSION:W,MAINNET_SOLANA_VERSION:F,NODE_VERSION:Gr,TESTNET_DELINQUENT_STAKE:10,MAINNET_DELINQUENT_STAKE:5,COMMISSION:5,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:mr,STAKE_ACCOUNTS:[],HARVEST_ACCOUNT:"",IS_MEV_MODE:!1,RPC_URL:dr,KEYPAIR_PATH:"",DISCORD_WEBHOOK_URL:"",AUTO_UPDATE:!1,AUTO_RESTART:!1,IS_DUMMY:!1,API_KEY:"",LEDGER_PATH:N,ACCOUNTS_PATH:xt,SNAPSHOTS_PATH:nt,MOD:!1},ut=Ba;import{homedir as qa}from"os";var Qa=r(async()=>{let e=`${qa()}/${we}`;return await Wa(e)?JSON.parse(await Ja(e,"utf-8")):(console.log("Creating default config file at",e),await za(e,JSON.stringify(ut,null,2)),ut)},"readConfig"),D=Qa;import Za from"node-fetch";var Z=r(async t=>{try{let e=await D();if(e.DISCORD_WEBHOOK_URL==="")throw new Error(`DISCORD_WEBHOOK_URL is empty
15
+ Please set DISCORD_WEBHOOK_URL in .env`);let o={content:t,username:"\u{1FA84} Solv Notifier"};return(await Za(e.DISCORD_WEBHOOK_URL,{method:"POST",body:JSON.stringify(o),headers:{"Content-Type":"application/json"}})).status===204}catch{return console.log({error:`Skeet sendDiscord Error - ${t}`}),!1}},"sendDiscord");import{spawnSync as rl}from"child_process";import{Connection as Br}from"@solana/web3.js";var ne=r(async(t,e,o=!1,s=200)=>{let n={pubkey:e,isActive:!1,reason:""};try{let i=o?new Br("https://api.testnet.solana.com"):new Br(t,"confirmed"),a=await i.getVoteAccounts(),l=a.current.find(u=>u.votePubkey===e);if(!l)return a.delinquent.find(p=>p.votePubkey===e)?(n.isActive=!1,n.reason="Validator is delinquent.",n):(n.isActive=!1,n.reason="Validator is not found in both current and delinquent lists.",n);if(a=await i.getVoteAccounts(),l=a.current.find(u=>u.votePubkey===e),!l)return n.isActive=!1,n.reason="Validator is not found in the current list.",n;let c=l.lastVote,d=await i.getSlot()-c;return d>s?(n.isActive=!1,n.reason=`Validator has not voted for ${d} slots.`,n):(n.isActive=!0,n.reason="Validator is active and voting.",n)}catch(i){return console.error(i),n.isActive=!1,n.reason="Failed to check validator status.",n}},"isValidatorActive");import{spawnSync as Xa}from"child_process";var C=r(t=>{let e=`solana address --keypair ${t}`,{stdout:o}=Xa(e,{shell:!0,stdio:"pipe"});return o.toString().trim()},"getSolanaAddress");var tl=r(t=>new Promise(e=>setTimeout(e,t)),"sleep"),j=tl;import{sendDiscord as el}from"@skeet-framework/utils";var Jr=10,ol=r(async t=>{try{let e=t.NETWORK===h.TESTNET,{mainnetValidatorVoteKey:o,testnetValidatorVoteKey:s}=O(),i=C(e?s:o),a=await ne(t.RPC_URL,i,e),l=0;for(;!a.isActive;){if(l>=Jr){console.log("Max retries reached, exiting...");let c=`\u26A0\uFE0F Validator is not active for ${Jr} minutes!
16
16
  Account: ${a.pubkey}
17
17
  Reason: ${a.reason}
18
18
  Message: Max retries reached, exiting catchup check...