@gabrielhicks/solv 5.3.11 → 5.3.12

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,17 +1,17 @@
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.11";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",Ca="mainnet-validator-keypair.json",Ia="mainnet-vote-account-keypair.json",La="mainnet-authority-keypair.json",Pa="testnet-validator-keypair.json",$a="testnet-vote-account-keypair.json",xa="testnet-authority-keypair.json",V="/home/solv",R=`${V}/${vt}`,su=`${V}/${Nt}`,M=`${V}/${Ca}`,_e=`${V}/${Ia}`,nu=`${V}/${La}`,D=`${V}/${Pa}`,ve=`${V}/${$a}`,iu=`${V}/${xa}`,Q=`${V}/solana-validator.log`,st=V+"/start-validator.sh",w="/mnt/ledger",$t="/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",fr="https://verify.validators.solutions/solv-migrate",hr="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",ko="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 ba}from"child_process";import{spawnSync as O}from"node:child_process";var Va=r((t,e=!1)=>{e?(O(`mkdir /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),O(`cd /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),O(`git clone https://github.com/gabrielhicks/agave.git --recurse-submodules /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),O(`git -C /tmp/${t}-agave-mod checkout ${t}-mod`,{shell:!0,stdio:"inherit"}),O(`git -C /tmp/${t}-agave-mod submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),O(`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"}),O("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),O(`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"}),O(`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.12";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",Ca="mainnet-validator-keypair.json",Ia="mainnet-vote-account-keypair.json",La="mainnet-authority-keypair.json",Pa="testnet-validator-keypair.json",$a="testnet-vote-account-keypair.json",xa="testnet-authority-keypair.json",V="/home/solv",R=`${V}/${vt}`,su=`${V}/${Nt}`,M=`${V}/${Ca}`,_e=`${V}/${Ia}`,nu=`${V}/${La}`,D=`${V}/${Pa}`,ve=`${V}/${$a}`,iu=`${V}/${xa}`,Q=`${V}/solana-validator.log`,st=V+"/start-validator.sh",w="/mnt/ledger",$t="/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",fr="https://verify.validators.solutions/solv-migrate",hr="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",ko="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 ba}from"child_process";import{spawnSync as O}from"node:child_process";var Va=r((t,e=!1)=>{e?(O(`mkdir /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),O(`cd /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),O(`git clone https://github.com/gabrielhicks/agave.git --recurse-submodules /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),O(`git -C /tmp/${t}-agave-mod checkout ${t}-mod`,{shell:!0,stdio:"inherit"}),O(`git -C /tmp/${t}-agave-mod submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),O(`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"}),O("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),O(`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"}),O(`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"}),O("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),O(`sudo rm -rf /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),O("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})):(O(`mkdir /tmp/${t}`,{shell:!0,stdio:"inherit"}),O(`cd /tmp/${t}`,{shell:!0,stdio:"inherit"}),O(`git clone https://github.com/anza-xyz/agave.git --recurse-submodules /tmp/${t}`,{shell:!0,stdio:"inherit"}),O(`git -C /tmp/${t} checkout ${t}`,{shell:!0,stdio:"inherit"}),O(`git -C /tmp/${t} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),O(`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"}),O("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),O(`cp -r /home/solv/.local/share/solana/install/releases/${t}/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),O(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
5
+ }' /etc/systemd/system/solv.service`,{shell:!0,stdio:"inherit"}),O("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\\\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),O(`sudo rm -rf /tmp/${t}-agave-mod`,{shell:!0,stdio:"inherit"}),O("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})):(O(`mkdir /tmp/${t}`,{shell:!0,stdio:"inherit"}),O(`cd /tmp/${t}`,{shell:!0,stdio:"inherit"}),O(`git clone https://github.com/anza-xyz/agave.git --recurse-submodules /tmp/${t}`,{shell:!0,stdio:"inherit"}),O(`git -C /tmp/${t} checkout ${t}`,{shell:!0,stdio:"inherit"}),O(`git -C /tmp/${t} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),O(`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"}),O("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),O(`cp -r /home/solv/.local/share/solana/install/releases/${t}/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),O(`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"}),O("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),O(`sudo rm -rf /tmp/${t}`,{shell:!0,stdio:"inherit"}),O("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}))},"installAgave"),xt=Va;var Er="agave-validator",Da=r(()=>{try{return Er}catch(t){return console.error(t),Er}},"getSolanaCLI"),it=Da;var ke=r(async(t,e=!1)=>{xt(t,e)},"updateVersion"),Ce=r(async(t,e=!1,o=10)=>{let s=it(),n=`${s} --ledger ${w} exit --max-delinquent-stake ${t} --monitor --min-idle-time ${o}`;e&&(n=`${s} --ledger ${w} exit --max-delinquent-stake ${t} --min-idle-time ${o}`),ba(n,{shell:!0,stdio:"inherit"})},"monitorUpdate");import cs 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 Ar;(function(t){t.SINGLE="single",t.DOUBLE="double",t.TRIPLE="triple"})(Ar||(Ar={}));var St;(function(t){t.MAINNET="mainnet-beta",t.TESTNET="testnet"})(St||(St={}));var wr;(function(t){t.VALIDATOR="validator",t.RPC="rpc"})(wr||(wr={}));var _r;(function(t){t.SOLANA="solana",t.JITO="jito",t.AGAVE="agave",t.FIREDANCER="firedancer"})(_r||(_r={}));var vr;(function(t){t.CO_HOST_RELAYER="co-host-relayer",t.SEPARATED_RELAYER="separated-relayer",t.WITHOUT_RELAYER="without-relayer"})(vr||(vr={}));var Nr;(function(t){t.FIREDANCER="firedancer",t.FRANKENDANCER="frankendancer"})(Nr||(Nr={}));var Ie;(function(t){t[t.TESTNET_VALIDATOR=0]="TESTNET_VALIDATOR",t[t.MAINNET_VALIDATOR=1]="MAINNET_VALIDATOR",t[t.RPC_NODE=2]="RPC_NODE"})(Ie||(Ie={}));var Le;(function(t){t.SOLANA_CLIENT="SolanaClient",t.JITO_MEV="JitoMev",t.FIREDANCER="Firedancer"})(Le||(Le={}));var kr=!1,Cr=!0,Ir=!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"},_={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"},$={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"},v=r((t=H.ROOT)=>{let e=t===H.ROOT?H.ROOT:t,o=`${e}/${$.MAINNET_VALIDATOR_KEY}`,s=`${e}/${$.MAINNET_VALIDATOR_VOTE_KEY}`,n=`${e}/${$.MAINNET_VALITATOR_AUTHORITY_KEY}`,i=`${e}/${$.TESTNET_VALIDATOR_KEY}`,a=`${e}/${$.TESTNET_VALIDATOR_VOTE_KEY}`,l=`${e}/${$.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}/${$.TESTNET_VALIDATOR_KEY}`:`${H.ROOT}/${$.MAINNET_VALIDATOR_KEY}`,o=t?`${H.ROOT}/${$.TESTNET_VALIDATOR_VOTE_KEY}`:`${H.ROOT}/${$.MAINNET_VALIDATOR_VOTE_KEY}`,s=`${H.ROOT}/${at.LOG}`,n=_.ACCOUNTS,i=_.LEDGER,a=_.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",Pr="EiwSTx1Z2uJATDut682U7xzzquFR4UpQJUij3wSxVoSV",$r=9,lt="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC",xr="So11111111111111111111111111111111111111112",Vr="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",Dr="CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP",Rr;(function(t){t[t.ELSOL=lt]="ELSOL",t[t.SOL=xr]="SOL",t[t.USDC=Vr]="USDC",t[t.EPCT=Dr]="EPCT"})(Rr||(Rr={}));var Or;(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"})(Or||(Or={}));var Au={[xr]:9,[lt]:9,[Vr]:6,[Dr]:6},Pe="/home/solv/currentEpoch.json",Io=.5,$e="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 k}from"child_process";var xe=r((t=dt.tag,e=!1)=>{e?(k(`mkdir /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),k(`cd /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),k(`git clone https://github.com/gabrielhicks/jito-solana.git --recurse-submodules /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),k(`git -C /tmp/${t}-mod checkout ${t}-mod`,{shell:!0,stdio:"inherit"}),k(`git -C /tmp/${t}-mod submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),k(`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"}),k("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),k(`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"}),k(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
8
+ }' /etc/systemd/system/solv.service`,{shell:!0,stdio:"inherit"}),O("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\\\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),O(`sudo rm -rf /tmp/${t}`,{shell:!0,stdio:"inherit"}),O("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}))},"installAgave"),xt=Va;var Er="agave-validator",Da=r(()=>{try{return Er}catch(t){return console.error(t),Er}},"getSolanaCLI"),it=Da;var ke=r(async(t,e=!1)=>{xt(t,e)},"updateVersion"),Ce=r(async(t,e=!1,o=10)=>{let s=it(),n=`${s} --ledger ${w} exit --max-delinquent-stake ${t} --monitor --min-idle-time ${o}`;e&&(n=`${s} --ledger ${w} exit --max-delinquent-stake ${t} --min-idle-time ${o}`),ba(n,{shell:!0,stdio:"inherit"})},"monitorUpdate");import cs 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 Ar;(function(t){t.SINGLE="single",t.DOUBLE="double",t.TRIPLE="triple"})(Ar||(Ar={}));var St;(function(t){t.MAINNET="mainnet-beta",t.TESTNET="testnet"})(St||(St={}));var wr;(function(t){t.VALIDATOR="validator",t.RPC="rpc"})(wr||(wr={}));var _r;(function(t){t.SOLANA="solana",t.JITO="jito",t.AGAVE="agave",t.FIREDANCER="firedancer"})(_r||(_r={}));var vr;(function(t){t.CO_HOST_RELAYER="co-host-relayer",t.SEPARATED_RELAYER="separated-relayer",t.WITHOUT_RELAYER="without-relayer"})(vr||(vr={}));var Nr;(function(t){t.FIREDANCER="firedancer",t.FRANKENDANCER="frankendancer"})(Nr||(Nr={}));var Ie;(function(t){t[t.TESTNET_VALIDATOR=0]="TESTNET_VALIDATOR",t[t.MAINNET_VALIDATOR=1]="MAINNET_VALIDATOR",t[t.RPC_NODE=2]="RPC_NODE"})(Ie||(Ie={}));var Le;(function(t){t.SOLANA_CLIENT="SolanaClient",t.JITO_MEV="JitoMev",t.FIREDANCER="Firedancer"})(Le||(Le={}));var kr=!1,Cr=!0,Ir=!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"},_={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"},$={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"},v=r((t=H.ROOT)=>{let e=t===H.ROOT?H.ROOT:t,o=`${e}/${$.MAINNET_VALIDATOR_KEY}`,s=`${e}/${$.MAINNET_VALIDATOR_VOTE_KEY}`,n=`${e}/${$.MAINNET_VALITATOR_AUTHORITY_KEY}`,i=`${e}/${$.TESTNET_VALIDATOR_KEY}`,a=`${e}/${$.TESTNET_VALIDATOR_VOTE_KEY}`,l=`${e}/${$.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}/${$.TESTNET_VALIDATOR_KEY}`:`${H.ROOT}/${$.MAINNET_VALIDATOR_KEY}`,o=t?`${H.ROOT}/${$.TESTNET_VALIDATOR_VOTE_KEY}`:`${H.ROOT}/${$.MAINNET_VALIDATOR_VOTE_KEY}`,s=`${H.ROOT}/${at.LOG}`,n=_.ACCOUNTS,i=_.LEDGER,a=_.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",Pr="EiwSTx1Z2uJATDut682U7xzzquFR4UpQJUij3wSxVoSV",$r=9,lt="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC",xr="So11111111111111111111111111111111111111112",Vr="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",Dr="CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP",Rr;(function(t){t[t.ELSOL=lt]="ELSOL",t[t.SOL=xr]="SOL",t[t.USDC=Vr]="USDC",t[t.EPCT=Dr]="EPCT"})(Rr||(Rr={}));var Or;(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"})(Or||(Or={}));var Au={[xr]:9,[lt]:9,[Vr]:6,[Dr]:6},Pe="/home/solv/currentEpoch.json",Io=.5,$e="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 k}from"child_process";var xe=r((t=dt.tag,e=!1)=>{e?(k(`mkdir /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),k(`cd /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),k(`git clone https://github.com/gabrielhicks/jito-solana.git --recurse-submodules /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),k(`git -C /tmp/${t}-mod checkout ${t}-mod`,{shell:!0,stdio:"inherit"}),k(`git -C /tmp/${t}-mod submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),k(`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"}),k("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),k(`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"}),k(`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"}),k("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),k(`sudo rm -rf /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),k("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})):(k(`mkdir /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),k(`cd /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),k(`git clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),k(`git -C /tmp/${t}-jito checkout ${t}-jito`,{shell:!0,stdio:"inherit"}),k(`git -C /tmp/${t}-jito submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),k(`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"}),k("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),k(`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"}),k(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
11
+ }' /etc/systemd/system/solv.service`,{shell:!0,stdio:"inherit"}),k("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\\\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),k(`sudo rm -rf /tmp/${t}-mod`,{shell:!0,stdio:"inherit"}),k("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})):(k(`mkdir /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),k(`cd /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),k(`git clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),k(`git -C /tmp/${t}-jito checkout ${t}-jito`,{shell:!0,stdio:"inherit"}),k(`git -C /tmp/${t}-jito submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),k(`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"}),k("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),k(`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"}),k(`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"}),k("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),k(`sudo rm -rf /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),k("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 Kr}from"child_process";import Ha from"inquirer";var Ur=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";Kr(`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}`;Kr(i,{shell:!0,stdio:"inherit"})},"updateCommission"),Mr=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 Hr=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(()=>ir,"getSolvVersion"),Vt=Ya;import{readFile as Ja,writeFile as za}from"fs/promises";import{existsAsync as Wa}from"@skeet-framework/utils";var Po;(function(t){t.EN="en",t.JA="ja"})(Po||(Po={}));var Wu=Object.values(Po),f;(function(t){t.MAINNET="mainnet-beta",t.TESTNET="testnet"})(f||(f={}));var Fr=Object.values(f),A;(function(t){t.RPC="rpc",t.VALIDATOR="validator"})(A||(A={}));var jr=Object.values(A),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 Yr=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",Gr="2.3.7",kt="2.3.7";var Br="20.17.0",Dt="0.707.20306",bt="0.707.20306";var Ba={NETWORK:f.TESTNET,NODE_TYPE:A.RPC,VALIDATOR_TYPE:T.NONE,RPC_TYPE:U.AGAVE,MNT_DISK_TYPE:z.TRIPLE,TESTNET_SOLANA_VERSION:W,MAINNET_SOLANA_VERSION:F,NODE_VERSION:Br,TESTNET_DELINQUENT_STAKE:10,MAINNET_DELINQUENT_STAKE:5,COMMISSION:5,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:pr,STAKE_ACCOUNTS:[],HARVEST_ACCOUNT:"",IS_MEV_MODE:!1,RPC_URL:ur,KEYPAIR_PATH:"",DISCORD_WEBHOOK_URL:"",AUTO_UPDATE:!1,AUTO_RESTART:!1,IS_DUMMY:!1,API_KEY:"",LEDGER_PATH:w,ACCOUNTS_PATH:$t,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"),b=Qa;import Za from"node-fetch";var Z=r(async t=>{try{let e=await b();if(e.DISCORD_WEBHOOK_URL==="")throw new Error(`DISCORD_WEBHOOK_URL is empty
14
+ }' /etc/systemd/system/solv.service`,{shell:!0,stdio:"inherit"}),k("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\\\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),k(`sudo rm -rf /tmp/${t}-jito`,{shell:!0,stdio:"inherit"}),k("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 Kr}from"child_process";import Ha from"inquirer";var Ur=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";Kr(`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}`;Kr(i,{shell:!0,stdio:"inherit"})},"updateCommission"),Mr=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 Hr=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(()=>ir,"getSolvVersion"),Vt=Ya;import{readFile as Ja,writeFile as za}from"fs/promises";import{existsAsync as Wa}from"@skeet-framework/utils";var Po;(function(t){t.EN="en",t.JA="ja"})(Po||(Po={}));var Wu=Object.values(Po),f;(function(t){t.MAINNET="mainnet-beta",t.TESTNET="testnet"})(f||(f={}));var Fr=Object.values(f),A;(function(t){t.RPC="rpc",t.VALIDATOR="validator"})(A||(A={}));var jr=Object.values(A),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 Yr=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",Gr="2.3.7",kt="2.3.7";var Br="20.17.0",Dt="0.707.20306",bt="0.707.20306";var Ba={NETWORK:f.TESTNET,NODE_TYPE:A.RPC,VALIDATOR_TYPE:T.NONE,RPC_TYPE:U.AGAVE,MNT_DISK_TYPE:z.TRIPLE,TESTNET_SOLANA_VERSION:W,MAINNET_SOLANA_VERSION:F,NODE_VERSION:Br,TESTNET_DELINQUENT_STAKE:10,MAINNET_DELINQUENT_STAKE:5,COMMISSION:5,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:pr,STAKE_ACCOUNTS:[],HARVEST_ACCOUNT:"",IS_MEV_MODE:!1,RPC_URL:ur,KEYPAIR_PATH:"",DISCORD_WEBHOOK_URL:"",AUTO_UPDATE:!1,AUTO_RESTART:!1,IS_DUMMY:!1,API_KEY:"",LEDGER_PATH:w,ACCOUNTS_PATH:$t,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"),b=Qa;import Za from"node-fetch";var Z=r(async t=>{try{let e=await b();if(e.DISCORD_WEBHOOK_URL==="")throw new Error(`DISCORD_WEBHOOK_URL is empty
15
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 nl}from"child_process";import{Connection as Jr}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 Jr("https://api.testnet.solana.com"):new Jr(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 N=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 zr=60,ol=r(async t=>{try{let e=t.NETWORK===f.TESTNET,{mainnetValidatorVoteKey:o,testnetValidatorVoteKey:s}=v(),i=N(e?s:o),a=await ne(t.RPC_URL,i,e),l=0;for(;!a.isActive;){if(l>=zr){console.log("Max retries reached, exiting...");let c=`\u26A0\uFE0F Validator is not active for ${zr} minutes!
16
16
  Account: ${a.pubkey}
17
17
  Reason: ${a.reason}
@@ -40,10 +40,10 @@ rm jupiter-swap-api-x86_64-unknown-linux-gnu.zip`,{shell:!0,stdio:"inherit"});le
40
40
  $ solv jupiter --help`))},"jupiterAPISetup"),Ss=Pl;import{existsAsync as $l}from"@skeet-framework/utils";import{readFile as xl,writeFile as Ts}from"fs/promises";import{homedir as Vl}from"os";import Dl from"path";var ft=r(async()=>{let t=Vl(),e=Dl.join(t,at.JITO_CONFIG);await $l(e)||(await Ts(e,JSON.stringify(dt,null,2)),console.log(`Created jito config file at ${e}`));let o;try{o=JSON.parse(await xl(e,"utf-8"))}catch(s){console.log(`readOrCreateJitoConfig - ${s}`),await Ts(e,JSON.stringify(dt,null,2)),o=dt}return o},"readOrCreateJitoConfig");import{spawnSync as bl}from"child_process";var ie=r(()=>{bl("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})},"daemonReload");import ae from"chalk";import Be from"inquirer";import Kl from"inquirer";var Es=r(async t=>{let o=Object.keys(t?ee.TESTNET:ee.MAINNET),s=t?ee.TESTNET:ee.MAINNET,n=await Kl.prompt([{name:"commissionBps",type:"number",message:"Enter commission bps",default:1e3},{name:"region",type:"list",message:"Select region",choices:o}]),i=n.region,a=s[i];return{version:dt.version,tag:dt.tag,commissionBps:n.commissionBps,blockEngineUrl:a.BLOCK_ENGINE_URL,relayerUrl:a.RELAYER_URL,shredReceiverAddr:a.SHRED_RECEIVER_ADDR}},"askJitoSetting");var Ul=r(async()=>{try{let t=T.NONE,e=U.AGAVE,o=ut.COMMISSION,s=!1,n=await Be.prompt([{name:"network",type:"list",message:"Choose Network",choices:Fr,default:f.MAINNET},{name:"nodeType",type:"list",message:"Choose Node Type",choices:jr,default:A.RPC}]),i=n.network===f.TESTNET;if(n.nodeType===A.VALIDATOR){let c=n.network===f.MAINNET?[T.JITO,T.SOLANA]:[T.AGAVE,T.JITO,T.FRANKENDANCER];t=await Be.prompt({name:"validatorType",type:"list",message:"Choose Validator Type",choices:c,default:T.AGAVE}).then(m=>m.validatorType),e=U.NONE}if(n.nodeType===A.RPC&&(e=await Be.prompt({name:"rpcType",type:"list",message:"Choose RPC Type",choices:Yr,default:U.AGAVE}).then(c=>c.rpcType)),n.nodeType===A.VALIDATOR){let c=await Be.prompt([{name:"commission",type:"number",message:`What is your commission rate? You can change it later (default: ${ut.COMMISSION}%)'`,default:ut.COMMISSION},{name:"isDummy",type:"confirm",message:"Do you want to setup as a dummy(Inactive) node?(\u203BFor Migration)",default:!0}]);if(o=c.commission,s=c.isDummy,t===T.JITO||t===T.FRANKENDANCER){await ft();let m=await Es(i);await oe(m)}}let{network:a,nodeType:l}=n;return console.log(ae.white("Network:",a)),console.log(ae.white("Node Type:",l)),console.log(ae.white("Validator Type:",t)),console.log(ae.white("RPC Type:",e)),l===A.VALIDATOR&&console.log(ae.white("Commission:",o)),await I({NETWORK:a,NODE_TYPE:l,VALIDATOR_TYPE:t,RPC_TYPE:e,COMMISSION:o,IS_DUMMY:s}),!0}catch(t){throw new Error(t)}},"initialConfigSetup"),gs=Ul;import{spawnSync as C}from"child_process";var le=r((t=Ot,e=!1)=>{if(e){let o=`v${t}-mod`;C(`mkdir /tmp/${o}`,{shell:!0,stdio:"inherit"}),C(`cd /tmp/${o}`,{shell:!0,stdio:"inherit"}),C(`git -C /tmp/${o} clone https://github.com/gabrielhicks/jito-solana.git --recurse-submodules .`,{shell:!0,stdio:"inherit"}),C(`git -C /tmp/${o} checkout ${o}`,{shell:!0,stdio:"inherit"}),C(`git -C /tmp/${o} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),C(`CI_COMMIT=$(git -C /tmp/${o} rev-parse HEAD) /tmp/${o}/scripts/cargo-install-all.sh --validator-only /home/solv/.local/share/solana/install/releases/${o}`,{shell:!0,stdio:"inherit"}),C("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),C(`cp -r /home/solv/.local/share/solana/install/releases/${o}/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),C(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
41
41
  n
42
42
  /^LimitMEMLOCK=infinity$/!i LimitMEMLOCK=infinity
43
- }' /etc/systemd/system/solv.service`,{shell:!0,stdio:"inherit"}),C("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),C(`sudo rm -rf /tmp/${o}`,{shell:!0,stdio:"inherit"}),C("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})}else{let o=`v${t}-jito`;C(`mkdir /tmp/${o}`,{shell:!0,stdio:"inherit"}),C(`cd /tmp/${o}`,{shell:!0,stdio:"inherit"}),C(`git -C /tmp/${o} clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules .`,{shell:!0,stdio:"inherit"}),C(`git -C /tmp/${o} checkout ${o}`,{shell:!0,stdio:"inherit"}),C(`git -C /tmp/${o} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),C(`CI_COMMIT=$(git -C /tmp/${o} rev-parse HEAD) /tmp/${o}/scripts/cargo-install-all.sh --validator-only /home/solv/.local/share/solana/install/releases/${o}`,{shell:!0,stdio:"inherit"}),C("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),C(`cp -r /home/solv/.local/share/solana/install/releases/${o}/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),C(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
43
+ }' /etc/systemd/system/solv.service`,{shell:!0,stdio:"inherit"}),C("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\\\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),C(`sudo rm -rf /tmp/${o}`,{shell:!0,stdio:"inherit"}),C("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})}else{let o=`v${t}-jito`;C(`mkdir /tmp/${o}`,{shell:!0,stdio:"inherit"}),C(`cd /tmp/${o}`,{shell:!0,stdio:"inherit"}),C(`git -C /tmp/${o} clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules .`,{shell:!0,stdio:"inherit"}),C(`git -C /tmp/${o} checkout ${o}`,{shell:!0,stdio:"inherit"}),C(`git -C /tmp/${o} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),C(`CI_COMMIT=$(git -C /tmp/${o} rev-parse HEAD) /tmp/${o}/scripts/cargo-install-all.sh --validator-only /home/solv/.local/share/solana/install/releases/${o}`,{shell:!0,stdio:"inherit"}),C("sudo rm -rf /home/solv/.local/share/solana/install/active_release/bin/",{shell:!0,stdio:"inherit"}),C(`cp -r /home/solv/.local/share/solana/install/releases/${o}/bin/ /home/solv/.local/share/solana/install/active_release/bin/`,{shell:!0,stdio:"inherit"}),C(`sudo sudo sed -i '/^LimitNOFILE=1000000$/{
44
44
  n
45
45
  /^LimitMEMLOCK=infinity$/!i LimitMEMLOCK=infinity
46
- }' /etc/systemd/system/solv.service`,{shell:!0,stdio:"inherit"}),C("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),C(`sudo rm -rf /tmp/${o}`,{shell:!0,stdio:"inherit"}),C("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})}},"installJito");var As=r(()=>`#!/bin/bash
46
+ }' /etc/systemd/system/solv.service`,{shell:!0,stdio:"inherit"}),C("sudo sed -i 's|^--dynamic-port-range.*$|--dynamic-port-range 8000-8025 \\\\|' /home/solv/start-validator.sh",{shell:!0,stdio:"inherit"}),C(`sudo rm -rf /tmp/${o}`,{shell:!0,stdio:"inherit"}),C("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})}},"installJito");var As=r(()=>`#!/bin/bash
47
47
  exec agave-validator \\
48
48
  --identity ${R} \\
49
49
  --log ${Q} \\