@gabrielhicks/solv 5.6.41 → 5.6.43

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- var FT=Object.defineProperty;var E=(_,e)=>FT(_,"name",{value:e,configurable:!0}),IT=(_=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(_,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):_)(function(_){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+_+'" is not supported')});import"dotenv/config";import{Command as Od}from"commander";var Po="5.6.41";var Ao={name:"@gabrielhicks/solv",version:Po,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","dist/cli/monitoring/scripts","dist/cli/chrony"],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"},overrides:{chalk:"5.3.0","strip-ansi":"7.1.0","color-convert":"2.0.1","color-name":"1.1.4","is-core-module":"2.13.1","error-ex":"1.3.2","has-ansi":"5.0.1"}};var dt=Ao.version;var Ge="https://validators.solutions";var lt="solv4.config.json";var $_="identity.json",q_="unstaked-identity.json",Uo="relayer-keypair.json",DT="mainnet-validator-keypair.json",PT="mainnet-vote-account-keypair.json",AT="mainnet-authority-keypair.json",UT="testnet-validator-keypair.json",uT="testnet-vote-account-keypair.json",pT="testnet-authority-keypair.json",b="/home/solv",p=`${b}/${$_}`,md=`${b}/${q_}`,x=`${b}/${DT}`,se=`${b}/${PT}`,Md=`${b}/${AT}`,G=`${b}/${UT}`,y_=`${b}/${uT}`,Ld=`${b}/${pT}`,w=`${b}/solana-validator.log`,N_=b+"/start-validator.sh",u="/mnt/ledger",K_="/mnt/accounts",O_="/mnt/snapshots",uo="solana-validator",po="agave-validator",mo="ELLB9W7ZCwRCV3FzWcCWoyKP6NjZJKArLyGtkqefnHcG";var Nt=3;var Mo="https://api.mainnet-beta.solana.com",Lo="https://verify.validators.solutions/solv-migrate",ho="https://jup.validators.solutions/v1/jup",BE;(function(_){_.SOL="SOL",_.USDC="USDC",_.elSOL="elSOL",_.JitoSOL="JitoSOL",_.mSOL="mSOL",_.bSOL="bSOL",_.EPCT="EPCT",_.JUP="JUP",_.BONK="BONK",_.JTO="JTO"})(BE||(BE={}));var go=Object.values(BE),Ot="So11111111111111111111111111111111111111112",Ft="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",yE="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC";var Bo="SOLV420",yo={So11111111111111111111111111111111111111112:"4Vwkpk3DTVrTGnUQTazsgQ1wxtU9QwZTmAXDaQRHg9Ra",EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v:"J8sqx9ZEoPRqboFAXK3c1R38zm41tRNJgUn2FzyeYQDj",J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn:"HPj87TFMPZfm5nk1HmTH9a382RXn7h9oWftiFr3Xs12a",mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So:"8CX5tE9KvJ59HcoXwWf6tCZoRuz2JFSmunnbKC1ryaK9",bSo13r4TkiE4KumL71LsHTPpL2euBYLFx6h9HP3piy1:"782MdvLby3VfvKdfDYn9tX3DfNAtg7TcytNNFuepcoMH",CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP:"BhR2L6J5q3xF1TxReXyHjaUh4MF6qV99tMsipzPAKeB",JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN:"212yg3Ev7khq4p1mESFGenF4nWefmkbC8f7mHM68j4vg",DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263:"61Ndjv9392jPRVGALdYgjjxGYa6TT6Gn2WLDSsmugE6U",jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL:"2c9qVh8RQ6j2E2VdAEcCrRXMrd6g1vvPNZvAR6sbaGWo"},re=["adreoi6W1MGA7eegERNcQTwQH3UuJaAnWjVZEq2cxcF","naterTR45j7aWs16S3qx8V29CfM314dzfvtCSitiAYi","th734sEwvZZ5XfemLcvo6TXepPfawWBjz3HMYeQdhPi","BAPExw4zFmwSUjyPfQorenucofeafHLUetcoWTB4Gwnt","bay3c7G89NTxSULyM45gqJx3JoWtBBeXHvifCywwiwZ","BeRTyZTveVQsekrF63WhFvfGiABThym95x8uZaicDPgo","EF8o3aQnu853EEPJKUfqAgoa8szkVs28sv64xtBrRPSV","chrtyETASKQhsndRM9pr6qC3gAHG5MuRwCgXSNVqnJL","GsVJ62qt2nbRLT4f67LAo6Ve8eGhChJquYaK3wT1iG2v","ctz4yB16kvGiMrA4vdtKXEMYgkkfJLo6hMwDk9DZ3Vf","PARaNF4kcQW3BmaeMD3ELLAqUV7MDS8bMudaCEZ72NM","dedxpgLN1VXLHpekKra1JKkMGrw7tW1uuYz7Ec28iLK","DegEnNCbn6PrsvHvsErneRNv7KFTwnjW3uFVjf43e28v","Dcky7CK3aEHzdV9EF5YR1NaTJ9QfSyzW5cACbqEFKZNv","dksYs1gzQ7FzqyadN5XtcaeVbqKSN7X2SpfN3fcUW7G","dstCt4sDCQx1QFFJekmM5RjyFLsDRkaEjTgXd5gbpDB","eyeYaqg9e2L6xw7YwsSLm27eWJfhLNAm6ETQm8TXNoK","ExCHpAsqeaDJGfUj41bhU2BuZK4fhRnJKvhG486rfKg","farmoWMKdJBxLxhMZpgU1uVjvjVJnQqrGhwAyDmcn8R","G1EaM8gLQU7DifPnCTQKP2PLvFf63tHvaXBAR8QFLg5Z","goJirTtcRjP6Wqkw7cHNvzjEva5rpvPDtj2ZnEmPAr6","wetfCN7bhjhBT8GTSAnah8ftoRoHB8H8Q87KkxDdRgK","8H6qQ2FKUjY8wmggSKHUENY38Nr9sQxDUbEZB6fiCHSX","hy1oTqvrknqoNmPWq2JtQMdDDnWkEGH2ab7N4r4rnJJ","jntrbAHjcxhP2eRUgCSACb6cMVhYm3jEQ3eQDZKicmz","akicJSdNFWszP2Le38t1NtVeywXtvoxdiGciaELwZHz","1i1yarXXz55VdvVL4v2HXcjMJPAv4fWJhY8x43bmwfL","LoV31z7KC5CZ8sdGovmRSDGB6csP1fJip1hiM7xDozw","magiCagux3C7nMKo2jKSbX6yWzYWMGKJ6ABRnw1zQ8U","JAfBCSxx2fZwdM5wTiLRAfJm3MpqXz3KnxjPhCQixGVh","mythT638QB6T8rqcGS4aKZ5a5z31xakTsRC6CL9KGEe","phz4F5mHZcZGC21GRUT6j3AqJxTUGDVAiCKiyucnyy1","pineBbb5K6SdV6KG1xibsR5DM1XsWuajtXSy3YYGY4N","prt1stdbFCFXpEcx9rxwJK63zhYo43V5JCXzGWXkPGn","rad1u8GKZoyVWxVAKy1cjL84dqhS9mp57uAezPt4iQg","rapTWQhZD2dPjJ91BXW4UnVKBt6NvX2aZxWSSYg66Y4","royLQKzrsSs9VbMZMDjZkMM8j3buBnwx7oH3wdifAk4","CitYBuKSE5W6CXEBAgY1B9fEMUdHXYSmZbXbAWd31Cr","axyaGn2eZM1dnDCagpd9aYa92gKWTrtEYb8vwc21ddr","sTeV1NswjBBo15qosoyQj1aYrgvoxomAduN1zFV6gCf","txtXxyX13G7h899vnZwNJsVRAMfWcwYZNT3jucRqqiW","hxTzWqz2WMdLhbMgYfsWiWYdtx8pY582FKwQpfGL59M","te1emnh77qnpsdjcCi9FsyX8t4gf4HYWC4kTVHuH4MQ","tstidz7tN8armqvZ7ia2ck62mY9RD2BrwMtW2w8hcwk","vnd1sXYmA8YY9xHQBkKKurZeq7iCe6EQ9bGYNZJwh1c","YE11vEiXKKx95onU1EpjgwrHovgXamRTQvY52Mvde8i","5D1fNXzvv5NjV1ysLjirC4WY92RNsVH18vjmcszZd8on"],F_=["adre1Xia7ekGsEqNgHeFc7MYwkfzTQNeJgQmZ2agAKZ","nateKhsYkrVc992UuTfAhEEFQqr2zQfpGg9RafNkxdC","BeRtYZnaaZLFwYQRPaZcxuuHBmyFBSGP32C8Ls5xnrZP","b1ueZK9bWTywN2587zsScyLTaH18wfRfN5W15XnkiqF","chrtyhyeugoiCD3M2kjVmJigLwX7YtNP3YK9HZ1N3F1","chdvWr6T14nqGRFD37KY36dsvhkCtDaufW5rpu3AfHe","CtzN7ysR5rX69qd168Aosbuc83mPozhi81bEHbG7ecNP","parayLyZvwnGjDT2pGqrVn8UDxmNcdNQCE8uPRWMeRz","dmMwc4RazLHkvDZYrWAfbHQ6cViAvNa5szCJKaiun8S","DEgenZMznWXvg5YHaZM75arVTauV453SeXX1UrxcGNup","dst2u7mXMyDvb14cSErRNA1mxH1d5VXbSXgZ3DKE9xH","eyeY8HangkSYirSBtopAfThXzhHL855wPnddz8WnemV","ExCHWgfeJyKRzpfryiQn4W6aYaWhbSAEnsoUnBGNqjWD","G1eAmANVWf6ZeoxG4aMbS1APauyEDHqLxHFytzk5hZqN","wetkjRRRDrSPAzHqfVHtFDbhNnejKm5UPfkHeccFCpo","hnhCMmnrmod4rcyc3QRKkLEC9XnPTvYJ2gBvjgFiV4o","hy1oMaD3ViyJ8i6w1xjP79zAWBBaRd1zWdTW8zYXnwu","jntr1vkzvSujfckGR6ANmFmirVoPBMNr5XJGKP5uDQA","NATsUSZGohWw8xtLdxG4yus21UCkaes4FLfM2eqKbRk","1i1yPyh843bTfi5qPgqozTbDcEX65rUNEFcUT2KAs2i","Love31pnbDJNVzZZVbtV4h2ftvTPVcBpXW11BSTCa6s","MagiCBYNPD9iTBXqiFybAFCREQzG6MSM4LmFLXQZxuV","D8xKNftHzFcCekENuTEcFC1eoL9y8wNHEg4Q5z57KK4e","mythxvB89eT3C1TKwwhsvdHfYq2aoCt2es8vLoDFYyk","phz1CRbEsCtFCh2Ro5tjyu588VU1WPMwW9BJS9yFNn2","pineXRUnbaLNFMxaM3zBmFfTiKgQMGqT9jYHXZWq2Fw","prt1st4RSxAt32ams4zsXCe1kavzmKeoR7eh1sdYRXW","radM7PKUpZwJ9bYPAJ7V8FXHeUmH1zim6iaXUKkftP9","rapXHroUoGG3KvZ3qwjvGMdA7siWXwXpiNC1bYarvSC","RoYLttggWwa2st3KAGEjnPhsq4NPD5QwaNVyyR8pTz4","ciTyjzN9iyobidMycjyqRRM7vXAHXkFzH3m8vEr6cQj","axy3tCRL3wmFMVG4c69rYurcf4fXhBo2RcuBj9ADnJ4","sTEVErNNwF2qPnV6DuNPkWpEyCt4UU6k2Y3Hyn7WUFu","TxtxXzLTDQ9W4ya3xgwyaqVa6Tky6Yqhi5BLpPCc9tZ","hxMhrsuGPDmkLJ4mTxEjyeMST3VGhTiwJvS9XgHwePj","te1ee9rGf369wxYQkuxkvuvMuTJ9cksgZySmNUF8rNY","UNrgBLmc8JT6A3dxXY9DWeHvDezt2DZQbhg1KPQfqEL","vnd1Ps8w3fsi54qUMJxBhUWARES34Qw7JQXDZxvbysd","YE11a5nVJtUNqsojkphYuWc7StqBzbCeFH6BjhAAUEV","Certusm1sa411sMpV9FPqU5dXAYhmmhygvxJ23S6hJ24","7Np41oeYqPefeNQEHSv1UDhYrehxin3NStELsSKCT4K2","GdnSyH3YtwcxFvQrVVJMm1JhTS4QVX7MFsX56uJLUfiZ","CakcnaRDHka2gXyfbEd2d3xsvkJkqsLw2akB3zsN1D2S"];import{spawnSync as LT}from"child_process";import{spawnSync as I_}from"node:child_process";var mT=E(_=>{I_(`mkdir /tmp/${_}-agave`,{shell:!0,stdio:"inherit"}),I_(`cd /tmp/${_}-agave`,{shell:!0,stdio:"inherit"}),I_(`git -C /tmp/${_}-agave clone https://github.com/anza-xyz/agave.git --recurse-submodules .`,{shell:!0,stdio:"inherit"}),I_(`git -C /tmp/${_}-agave checkout ${_}`,{shell:!0,stdio:"inherit"}),I_(`git -C /tmp/${_}-agave submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),I_(`CI_COMMIT=$(git -C /tmp/${_}-agave rev-parse HEAD) /tmp/${_}-agave/scripts/cargo-install-all.sh /home/solv/.local/share/solana/install/releases/${_}-agave`,{shell:!0,stdio:"inherit"}),I_("sudo rm -rf /home/solv/.local/share/solana/install/active_release",{shell:!0,stdio:"inherit"}),I_(`sudo ln -sfn /home/solv/.local/share/solana/install/releases/${_}-agave /home/solv/.local/share/solana/install/active_release`,{shell:!0,stdio:"inherit"}),I_(`sudo rm -rf /tmp/${_}-agave`,{shell:!0,stdio:"inherit"}),I_("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})},"installAgave"),G_=mT;var Ko="agave-validator",MT=E(()=>{try{return Ko}catch(_){return console.error(_),Ko}},"getSolanaCLI"),f_=MT;var c_="3.1.8",e_="3.0.14",ke="",Te="3.1.8",k_="3.0.14",p_="",It="3.1.8",ae="3.0.14",W_="",Go="3.0.14",X_="3.0.14";var ko="20.17.0",Se="0.811.30108",V_="0.808.30014";var Ve="0.8.5",be="0.8.2-1";var ft=E(async _=>{let e=ke,o=`${`v${_}`}${e}`;G_(o)},"updateVersion"),we=E(async(_,e=!1,t=10)=>{let o=f_(),i=`${o} --ledger ${u} exit --max-delinquent-stake ${_} --min-idle-time ${t}`;e&&(i=`${o} --ledger ${u} exit --max-delinquent-stake ${_} --min-idle-time ${t}`),LT(i,{shell:!0,stdio:"inherit"})},"monitorUpdate");import YE from"chalk";var j_;(function(_){_.EN="en",_.JA="ja"})(j_||(j_={}));var Vo;(function(_){_[_.DOUBLE=0]="DOUBLE",_[_.SINGLE=1]="SINGLE",_[_.TRIPLE=2]="TRIPLE"})(Vo||(Vo={}));var bo;(function(_){_.SINGLE="single",_.DOUBLE="double",_.TRIPLE="triple"})(bo||(bo={}));var b_;(function(_){_.MAINNET="mainnet-beta",_.TESTNET="testnet"})(b_||(b_={}));var wo;(function(_){_.VALIDATOR="validator",_.RPC="rpc"})(wo||(wo={}));var vo;(function(_){_.SOLANA="solana",_.JITO="jito",_.AGAVE="agave",_.FIREDANCER="firedancer"})(vo||(vo={}));var Ho;(function(_){_.CO_HOST_RELAYER="co-host-relayer",_.SEPARATED_RELAYER="separated-relayer",_.WITHOUT_RELAYER="without-relayer"})(Ho||(Ho={}));var Yo;(function(_){_.FIREDANCER="firedancer",_.FRANKENDANCER="frankendancer"})(Yo||(Yo={}));var Dt;(function(_){_[_.TESTNET_VALIDATOR=0]="TESTNET_VALIDATOR",_[_.MAINNET_VALIDATOR=1]="MAINNET_VALIDATOR",_[_.RPC_NODE=2]="RPC_NODE"})(Dt||(Dt={}));var Pt;(function(_){_.SOLANA_CLIENT="SolanaClient",_.JITO_MEV="JitoMev",_.FIREDANCER="Firedancer"})(Pt||(Pt={}));var Qo=!1,$o=!1,qo=!1,Wo=!1,Xo=!1,jo=!1,t_={ID:"solv",LANG:j_.EN,USERNAME:"solv",TESTNET_SOLANA_VERSION:"3.1.8",MAINNET_SOLANA_VERSION:"3.0.14",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,XDP:!1,ZERO_COPY:!1,JAG_SNAPSHOTS:!1,JAG_REGION:"",MEV_COMMISSION:1e3},v={ROOT:"/home/solv",AUTHORIZED_KEYS:"/home/solv/.ssh/authorized_keys"},m={ROOT:"/mnt",ACCOUNTS:"/mnt/accounts",LEDGER:"/mnt/ledger",SNAPSHOTS:"/mnt/snapshots"},D_={LOG:"solana-validator.log",STARTUP_SCRIPT:"start-validator.sh",CONFIG:"solv.config.json",JITO_CONFIG:"jito.config.json"},L={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"},h={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"},g=E((_=v.ROOT)=>{let e=_===v.ROOT?v.ROOT:_,t=`${e}/${h.MAINNET_VALIDATOR_KEY}`,o=`${e}/${h.MAINNET_VALIDATOR_VOTE_KEY}`,i=`${e}/${h.MAINNET_VALITATOR_AUTHORITY_KEY}`,n=`${e}/${h.TESTNET_VALIDATOR_KEY}`,s=`${e}/${h.TESTNET_VALIDATOR_VOTE_KEY}`,r=`${e}/${h.TESTNET_VALITATOR_AUTHORITY_KEY}`;return{mainnetValidatorKey:t,mainnetValidatorVoteKey:o,mainnetValidatorAuthorityKey:i,testnetValidatorKey:n,testnetValidatorVoteKey:s,testnetValidatorAuthorityKey:r}},"getAllKeyPaths"),w_=E((_=!0)=>{let e=_?`${v.ROOT}/${h.TESTNET_VALIDATOR_KEY}`:`${v.ROOT}/${h.MAINNET_VALIDATOR_KEY}`,t=_?`${v.ROOT}/${h.TESTNET_VALIDATOR_VOTE_KEY}`:`${v.ROOT}/${h.MAINNET_VALIDATOR_VOTE_KEY}`,o=`${v.ROOT}/${D_.LOG}`,i=m.ACCOUNTS,n=m.LEDGER,s=m.SNAPSHOTS,r=`${v.ROOT}/${D_.STARTUP_SCRIPT}`;return{identity:e,voteAccount:t,log:o,accounts:i,ledger:n,scriptPath:r,snapshots:s}},"startupScriptPaths");var R_="So1vW4Bm6ZURzJJHZy1JpsjoVY68z4cDgF4tTLwYMa5",KE="7tAfLKgRVd9eywSQPuMbVNd51KGkaveZQuTjapL74Fwv",zo="EiwSTx1Z2uJATDut682U7xzzquFR4UpQJUij3wSxVoSV",Zo=9,P_="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC",_i="So11111111111111111111111111111111111111112",ei="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",ti="CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP",Jo;(function(_){_[_.ELSOL=P_]="ELSOL",_[_.SOL=_i]="SOL",_[_.USDC=ei]="USDC",_[_.EPCT=ti]="EPCT"})(Jo||(Jo={}));var xo;(function(_){_.V6_BASE_URL="https://quote-api.jup.ag/v6",_.V6_QUOTE_URL="https://quote-api.jup.ag/v6/quote",_.V6_SWAP_URL="https://quote-api.jup.ag/v6/swap"})(xo||(xo={}));var $d={[_i]:9,[P_]:9,[ei]:6,[ti]:6},At="/home/solv/currentEpoch.json";var Ut="https://api.testnet.solana.com";import{spawnSync as GE}from"child_process";var Ei=E(()=>{GE("pnpm add -g pnpm",{shell:!0,stdio:"inherit"});let _=t_.NODE_VERSION;GE(`pnpm env use ${_} --global`,{shell:!0,stdio:"inherit"}),GE("pnpm add -g @gabrielhicks/solv",{shell:!0,stdio:"inherit"})},"updateSolv");import{spawnSync as E_}from"child_process";var ut=E((_,e=!1,t=!1,o=!1)=>{t?e?E_(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-solana/${_}/installer)"`,{shell:!0,stdio:"inherit"}):(E_(`mkdir /tmp/${_}`,{shell:!0,stdio:"inherit"}),E_(`cd /tmp/${_}`,{shell:!0,stdio:"inherit"}),E_(`git clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules /tmp/${_}`,{shell:!0,stdio:"inherit"}),E_(`git -C /tmp/${_} checkout ${_}`,{shell:!0,stdio:"inherit"}),E_(`git -C /tmp/${_} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),E_(`CI_COMMIT=$(git -C /tmp/${_} rev-parse HEAD) /tmp/${_}/scripts/cargo-install-all.sh /home/solv/.local/share/solana/install/releases/${_}`,{shell:!0,stdio:"inherit"}),E_("sudo rm -rf /home/solv/.local/share/solana/install/active_release",{shell:!0,stdio:"inherit"}),E_(`sudo ln -sfn /home/solv/.local/share/solana/install/releases/${_} /home/solv/.local/share/solana/install/active_release`,{shell:!0,stdio:"inherit"}),o&&E_("sudo setcap cap_net_raw,cap_net_admin,cap_bpf,cap_perfmon=p /home/solv/.local/share/solana/install/active_release/bin/agave-validator",{shell:!0,stdio:"inherit"}),E_(`sudo rm -rf /tmp/${_}`,{shell:!0,stdio:"inherit"})):e?E_(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-solana/${_}/installer)"`,{shell:!0,stdio:"inherit"}):E_(`sh -c "$(curl --netrc-optional -sSfL https://release.jito.wtf/${_}/install)"`,{shell:!0,stdio:"inherit"})},"jitoUpdate");import{readFile as hT,writeFile as gT}from"fs/promises";import{homedir as BT}from"os";var m_=E(async _=>{let t=`${BT()}/${D_.JITO_CONFIG}`,i={...JSON.parse(await hT(t,"utf8")),..._},n=JSON.stringify(i,null,2);await gT(t,n),console.log(`Updated ${t} with new values.`)},"updateJitoSolvConfig");import{spawnSync as oi}from"child_process";import yT from"inquirer";var ii=E((_,e=!0)=>{let t=e?"/home/solv/testnet-validator-keypair.json":"/home/solv/mainnet-validator-keypair.json",o=e?"/home/solv/testnet-vote-account-keypair.json":"/home/solv/mainnet-vote-account-keypair.json";oi(`solana config set --url ${e?"testnet":"mainnet-beta"} --keypair ${t}`,{shell:!0,stdio:"inherit"});let n=`solana vote-update-commission ${o} ${_} ${t} --keypair ${t}`;oi(n,{shell:!0,stdio:"inherit"})},"updateCommission"),ni=E(async()=>await yT.prompt([{type:"number",name:"commission",message:"Enter new commission",default:7}]),"updateCommissionAsk");import{execAsync as ve}from"@skeet-framework/utils";import KT from"chalk";import GT from"inquirer";var si=E(async()=>{let _=await GT.prompt([{name:"ip",type:"input",message:"Enter your IP address to allow access to RPC NODE:",default:"1.2.3.4"}]);await ve("sudo ufw delete allow 8899/udp"),await ve("sudo ufw delete allow 8899/tcp"),await ve(`sudo ufw allow from ${_.ip} to any port 8899 proto tcp`),await ve(`sudo ufw allow from ${_.ip} to any port 8899 proto udp`),await ve("sudo ufw reload"),console.log(KT.white("\u2714\uFE0F Firewall updated!"))},"updateFirewall");var kT=E(()=>Po,"getSolvVersion"),ce=kT;import{readFile as vT,writeFile as HT}from"fs/promises";import{existsAsync as YT}from"@skeet-framework/utils";var kE;(function(_){_.EN="en",_.JA="ja"})(kE||(kE={}));var Fl=Object.values(kE),l;(function(_){_.MAINNET="mainnet-beta",_.TESTNET="testnet"})(l||(l={}));var ri=Object.values(l),A;(function(_){_.RPC="rpc",_.VALIDATOR="validator"})(A||(A={}));var Ti=Object.values(A),F;(function(_){_.SOLANA="solana",_.AGAVE="agave",_.JITO="jito",_.FRANKENDANCER="frankendancer",_.BAM="bam",_.NONE="none"})(F||(F={}));var Il=Object.values(F).filter(_=>_!=="none"),Q;(function(_){_.AGAVE="agave",_.JITO="jito",_.NONE="none"})(Q||(Q={}));var ai=Object.values(Q).filter(_=>_!=="none"),o_;(function(_){_.SINGLE="single",_.DOUBLE="double",_.TRIPLE="triple"})(o_||(o_={}));var wT={NETWORK:l.TESTNET,NODE_TYPE:A.RPC,VALIDATOR_TYPE:F.NONE,RPC_TYPE:Q.AGAVE,MNT_DISK_TYPE:o_.TRIPLE,TESTNET_SOLANA_VERSION:c_,MAINNET_SOLANA_VERSION:e_,NODE_VERSION:ko,TESTNET_DELINQUENT_STAKE:10,MAINNET_DELINQUENT_STAKE:5,COMMISSION:5,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:mo,STAKE_ACCOUNTS:[],HARVEST_ACCOUNT:"",IS_MEV_MODE:!1,RPC_URL:Mo,KEYPAIR_PATH:"",DISCORD_WEBHOOK_URL:"",AUTO_UPDATE:!1,AUTO_RESTART:!1,IS_DUMMY:!1,API_KEY:"",LEDGER_PATH:u,ACCOUNTS_PATH:K_,SNAPSHOTS_PATH:O_,MOD:!1,XDP:!1,ZERO_COPY:!1,JAG_SNAPSHOTS:!1,JAG_REGION:"",CHRONY_LOCATION:"",MEV_COMMISSION:1e3},M_=wT;import{homedir as JT}from"os";var xT=E(async()=>{let e=`${JT()}/${lt}`;return await YT(e)?JSON.parse(await vT(e,"utf-8")):(console.log("Creating default config file at",e),await HT(e,JSON.stringify(M_,null,2)),M_)},"readConfig"),Y=xT;import QT from"node-fetch";var A_=E(async _=>{try{let e=await Y();if(e.DISCORD_WEBHOOK_URL==="")throw new Error(`DISCORD_WEBHOOK_URL is empty
2
+ var FT=Object.defineProperty;var E=(_,e)=>FT(_,"name",{value:e,configurable:!0}),IT=(_=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(_,{get:(e,t)=>(typeof require<"u"?require:e)[t]}):_)(function(_){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+_+'" is not supported')});import"dotenv/config";import{Command as Od}from"commander";var Po="5.6.43";var Ao={name:"@gabrielhicks/solv",version:Po,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","dist/cli/monitoring/scripts","dist/cli/chrony"],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"},overrides:{chalk:"5.3.0","strip-ansi":"7.1.0","color-convert":"2.0.1","color-name":"1.1.4","is-core-module":"2.13.1","error-ex":"1.3.2","has-ansi":"5.0.1"}};var dt=Ao.version;var Ge="https://validators.solutions";var lt="solv4.config.json";var $_="identity.json",q_="unstaked-identity.json",Uo="relayer-keypair.json",DT="mainnet-validator-keypair.json",PT="mainnet-vote-account-keypair.json",AT="mainnet-authority-keypair.json",UT="testnet-validator-keypair.json",uT="testnet-vote-account-keypair.json",pT="testnet-authority-keypair.json",b="/home/solv",p=`${b}/${$_}`,md=`${b}/${q_}`,x=`${b}/${DT}`,se=`${b}/${PT}`,Md=`${b}/${AT}`,G=`${b}/${UT}`,y_=`${b}/${uT}`,Ld=`${b}/${pT}`,w=`${b}/solana-validator.log`,N_=b+"/start-validator.sh",u="/mnt/ledger",K_="/mnt/accounts",O_="/mnt/snapshots",uo="solana-validator",po="agave-validator",mo="ELLB9W7ZCwRCV3FzWcCWoyKP6NjZJKArLyGtkqefnHcG";var Nt=3;var Mo="https://api.mainnet-beta.solana.com",Lo="https://verify.validators.solutions/solv-migrate",ho="https://jup.validators.solutions/v1/jup",BE;(function(_){_.SOL="SOL",_.USDC="USDC",_.elSOL="elSOL",_.JitoSOL="JitoSOL",_.mSOL="mSOL",_.bSOL="bSOL",_.EPCT="EPCT",_.JUP="JUP",_.BONK="BONK",_.JTO="JTO"})(BE||(BE={}));var go=Object.values(BE),Ot="So11111111111111111111111111111111111111112",Ft="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",yE="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC";var Bo="SOLV420",yo={So11111111111111111111111111111111111111112:"4Vwkpk3DTVrTGnUQTazsgQ1wxtU9QwZTmAXDaQRHg9Ra",EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v:"J8sqx9ZEoPRqboFAXK3c1R38zm41tRNJgUn2FzyeYQDj",J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn:"HPj87TFMPZfm5nk1HmTH9a382RXn7h9oWftiFr3Xs12a",mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So:"8CX5tE9KvJ59HcoXwWf6tCZoRuz2JFSmunnbKC1ryaK9",bSo13r4TkiE4KumL71LsHTPpL2euBYLFx6h9HP3piy1:"782MdvLby3VfvKdfDYn9tX3DfNAtg7TcytNNFuepcoMH",CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP:"BhR2L6J5q3xF1TxReXyHjaUh4MF6qV99tMsipzPAKeB",JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN:"212yg3Ev7khq4p1mESFGenF4nWefmkbC8f7mHM68j4vg",DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263:"61Ndjv9392jPRVGALdYgjjxGYa6TT6Gn2WLDSsmugE6U",jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL:"2c9qVh8RQ6j2E2VdAEcCrRXMrd6g1vvPNZvAR6sbaGWo"},re=["adreoi6W1MGA7eegERNcQTwQH3UuJaAnWjVZEq2cxcF","naterTR45j7aWs16S3qx8V29CfM314dzfvtCSitiAYi","th734sEwvZZ5XfemLcvo6TXepPfawWBjz3HMYeQdhPi","BAPExw4zFmwSUjyPfQorenucofeafHLUetcoWTB4Gwnt","bay3c7G89NTxSULyM45gqJx3JoWtBBeXHvifCywwiwZ","BeRTyZTveVQsekrF63WhFvfGiABThym95x8uZaicDPgo","EF8o3aQnu853EEPJKUfqAgoa8szkVs28sv64xtBrRPSV","chrtyETASKQhsndRM9pr6qC3gAHG5MuRwCgXSNVqnJL","GsVJ62qt2nbRLT4f67LAo6Ve8eGhChJquYaK3wT1iG2v","ctz4yB16kvGiMrA4vdtKXEMYgkkfJLo6hMwDk9DZ3Vf","PARaNF4kcQW3BmaeMD3ELLAqUV7MDS8bMudaCEZ72NM","dedxpgLN1VXLHpekKra1JKkMGrw7tW1uuYz7Ec28iLK","DegEnNCbn6PrsvHvsErneRNv7KFTwnjW3uFVjf43e28v","Dcky7CK3aEHzdV9EF5YR1NaTJ9QfSyzW5cACbqEFKZNv","dksYs1gzQ7FzqyadN5XtcaeVbqKSN7X2SpfN3fcUW7G","dstCt4sDCQx1QFFJekmM5RjyFLsDRkaEjTgXd5gbpDB","eyeYaqg9e2L6xw7YwsSLm27eWJfhLNAm6ETQm8TXNoK","ExCHpAsqeaDJGfUj41bhU2BuZK4fhRnJKvhG486rfKg","farmoWMKdJBxLxhMZpgU1uVjvjVJnQqrGhwAyDmcn8R","G1EaM8gLQU7DifPnCTQKP2PLvFf63tHvaXBAR8QFLg5Z","goJirTtcRjP6Wqkw7cHNvzjEva5rpvPDtj2ZnEmPAr6","wetfCN7bhjhBT8GTSAnah8ftoRoHB8H8Q87KkxDdRgK","8H6qQ2FKUjY8wmggSKHUENY38Nr9sQxDUbEZB6fiCHSX","hy1oTqvrknqoNmPWq2JtQMdDDnWkEGH2ab7N4r4rnJJ","jntrbAHjcxhP2eRUgCSACb6cMVhYm3jEQ3eQDZKicmz","akicJSdNFWszP2Le38t1NtVeywXtvoxdiGciaELwZHz","1i1yarXXz55VdvVL4v2HXcjMJPAv4fWJhY8x43bmwfL","LoV31z7KC5CZ8sdGovmRSDGB6csP1fJip1hiM7xDozw","magiCagux3C7nMKo2jKSbX6yWzYWMGKJ6ABRnw1zQ8U","JAfBCSxx2fZwdM5wTiLRAfJm3MpqXz3KnxjPhCQixGVh","mythT638QB6T8rqcGS4aKZ5a5z31xakTsRC6CL9KGEe","phz4F5mHZcZGC21GRUT6j3AqJxTUGDVAiCKiyucnyy1","pineBbb5K6SdV6KG1xibsR5DM1XsWuajtXSy3YYGY4N","prt1stdbFCFXpEcx9rxwJK63zhYo43V5JCXzGWXkPGn","rad1u8GKZoyVWxVAKy1cjL84dqhS9mp57uAezPt4iQg","rapTWQhZD2dPjJ91BXW4UnVKBt6NvX2aZxWSSYg66Y4","royLQKzrsSs9VbMZMDjZkMM8j3buBnwx7oH3wdifAk4","CitYBuKSE5W6CXEBAgY1B9fEMUdHXYSmZbXbAWd31Cr","axyaGn2eZM1dnDCagpd9aYa92gKWTrtEYb8vwc21ddr","sTeV1NswjBBo15qosoyQj1aYrgvoxomAduN1zFV6gCf","txtXxyX13G7h899vnZwNJsVRAMfWcwYZNT3jucRqqiW","hxTzWqz2WMdLhbMgYfsWiWYdtx8pY582FKwQpfGL59M","te1emnh77qnpsdjcCi9FsyX8t4gf4HYWC4kTVHuH4MQ","tstidz7tN8armqvZ7ia2ck62mY9RD2BrwMtW2w8hcwk","vnd1sXYmA8YY9xHQBkKKurZeq7iCe6EQ9bGYNZJwh1c","YE11vEiXKKx95onU1EpjgwrHovgXamRTQvY52Mvde8i","5D1fNXzvv5NjV1ysLjirC4WY92RNsVH18vjmcszZd8on"],F_=["adre1Xia7ekGsEqNgHeFc7MYwkfzTQNeJgQmZ2agAKZ","nateKhsYkrVc992UuTfAhEEFQqr2zQfpGg9RafNkxdC","BeRtYZnaaZLFwYQRPaZcxuuHBmyFBSGP32C8Ls5xnrZP","b1ueZK9bWTywN2587zsScyLTaH18wfRfN5W15XnkiqF","chrtyhyeugoiCD3M2kjVmJigLwX7YtNP3YK9HZ1N3F1","chdvWr6T14nqGRFD37KY36dsvhkCtDaufW5rpu3AfHe","CtzN7ysR5rX69qd168Aosbuc83mPozhi81bEHbG7ecNP","parayLyZvwnGjDT2pGqrVn8UDxmNcdNQCE8uPRWMeRz","dmMwc4RazLHkvDZYrWAfbHQ6cViAvNa5szCJKaiun8S","DEgenZMznWXvg5YHaZM75arVTauV453SeXX1UrxcGNup","dst2u7mXMyDvb14cSErRNA1mxH1d5VXbSXgZ3DKE9xH","eyeY8HangkSYirSBtopAfThXzhHL855wPnddz8WnemV","ExCHWgfeJyKRzpfryiQn4W6aYaWhbSAEnsoUnBGNqjWD","G1eAmANVWf6ZeoxG4aMbS1APauyEDHqLxHFytzk5hZqN","wetkjRRRDrSPAzHqfVHtFDbhNnejKm5UPfkHeccFCpo","hnhCMmnrmod4rcyc3QRKkLEC9XnPTvYJ2gBvjgFiV4o","hy1oMaD3ViyJ8i6w1xjP79zAWBBaRd1zWdTW8zYXnwu","jntr1vkzvSujfckGR6ANmFmirVoPBMNr5XJGKP5uDQA","NATsUSZGohWw8xtLdxG4yus21UCkaes4FLfM2eqKbRk","1i1yPyh843bTfi5qPgqozTbDcEX65rUNEFcUT2KAs2i","Love31pnbDJNVzZZVbtV4h2ftvTPVcBpXW11BSTCa6s","MagiCBYNPD9iTBXqiFybAFCREQzG6MSM4LmFLXQZxuV","D8xKNftHzFcCekENuTEcFC1eoL9y8wNHEg4Q5z57KK4e","mythxvB89eT3C1TKwwhsvdHfYq2aoCt2es8vLoDFYyk","phz1CRbEsCtFCh2Ro5tjyu588VU1WPMwW9BJS9yFNn2","pineXRUnbaLNFMxaM3zBmFfTiKgQMGqT9jYHXZWq2Fw","prt1st4RSxAt32ams4zsXCe1kavzmKeoR7eh1sdYRXW","radM7PKUpZwJ9bYPAJ7V8FXHeUmH1zim6iaXUKkftP9","rapXHroUoGG3KvZ3qwjvGMdA7siWXwXpiNC1bYarvSC","RoYLttggWwa2st3KAGEjnPhsq4NPD5QwaNVyyR8pTz4","ciTyjzN9iyobidMycjyqRRM7vXAHXkFzH3m8vEr6cQj","axy3tCRL3wmFMVG4c69rYurcf4fXhBo2RcuBj9ADnJ4","sTEVErNNwF2qPnV6DuNPkWpEyCt4UU6k2Y3Hyn7WUFu","TxtxXzLTDQ9W4ya3xgwyaqVa6Tky6Yqhi5BLpPCc9tZ","hxMhrsuGPDmkLJ4mTxEjyeMST3VGhTiwJvS9XgHwePj","te1ee9rGf369wxYQkuxkvuvMuTJ9cksgZySmNUF8rNY","UNrgBLmc8JT6A3dxXY9DWeHvDezt2DZQbhg1KPQfqEL","vnd1Ps8w3fsi54qUMJxBhUWARES34Qw7JQXDZxvbysd","YE11a5nVJtUNqsojkphYuWc7StqBzbCeFH6BjhAAUEV","Certusm1sa411sMpV9FPqU5dXAYhmmhygvxJ23S6hJ24","7Np41oeYqPefeNQEHSv1UDhYrehxin3NStELsSKCT4K2","GdnSyH3YtwcxFvQrVVJMm1JhTS4QVX7MFsX56uJLUfiZ","CakcnaRDHka2gXyfbEd2d3xsvkJkqsLw2akB3zsN1D2S"];import{spawnSync as LT}from"child_process";import{spawnSync as I_}from"node:child_process";var mT=E(_=>{I_(`mkdir /tmp/${_}-agave`,{shell:!0,stdio:"inherit"}),I_(`cd /tmp/${_}-agave`,{shell:!0,stdio:"inherit"}),I_(`git -C /tmp/${_}-agave clone https://github.com/anza-xyz/agave.git --recurse-submodules .`,{shell:!0,stdio:"inherit"}),I_(`git -C /tmp/${_}-agave checkout ${_}`,{shell:!0,stdio:"inherit"}),I_(`git -C /tmp/${_}-agave submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),I_(`CI_COMMIT=$(git -C /tmp/${_}-agave rev-parse HEAD) /tmp/${_}-agave/scripts/cargo-install-all.sh /home/solv/.local/share/solana/install/releases/${_}-agave`,{shell:!0,stdio:"inherit"}),I_("sudo rm -rf /home/solv/.local/share/solana/install/active_release",{shell:!0,stdio:"inherit"}),I_(`sudo ln -sfn /home/solv/.local/share/solana/install/releases/${_}-agave /home/solv/.local/share/solana/install/active_release`,{shell:!0,stdio:"inherit"}),I_(`sudo rm -rf /tmp/${_}-agave`,{shell:!0,stdio:"inherit"}),I_("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})},"installAgave"),G_=mT;var Ko="agave-validator",MT=E(()=>{try{return Ko}catch(_){return console.error(_),Ko}},"getSolanaCLI"),f_=MT;var c_="3.1.8",t_="3.1.8",ke="",Te="3.1.8",k_="3.1.8",p_="",It="3.1.8",ae="3.1.8",W_="",Go="3.1.8",X_="3.1.8";var ko="20.17.0",Se="0.811.30108",V_="0.811.30108";var Ve="0.8.5-1",be="0.8.2-1";var ft=E(async _=>{let e=ke,o=`${`v${_}`}${e}`;G_(o)},"updateVersion"),we=E(async(_,e=!1,t=10)=>{let o=f_(),i=`${o} --ledger ${u} exit --max-delinquent-stake ${_} --min-idle-time ${t}`;e&&(i=`${o} --ledger ${u} exit --max-delinquent-stake ${_} --min-idle-time ${t}`),LT(i,{shell:!0,stdio:"inherit"})},"monitorUpdate");import YE from"chalk";var j_;(function(_){_.EN="en",_.JA="ja"})(j_||(j_={}));var Vo;(function(_){_[_.DOUBLE=0]="DOUBLE",_[_.SINGLE=1]="SINGLE",_[_.TRIPLE=2]="TRIPLE"})(Vo||(Vo={}));var bo;(function(_){_.SINGLE="single",_.DOUBLE="double",_.TRIPLE="triple"})(bo||(bo={}));var b_;(function(_){_.MAINNET="mainnet-beta",_.TESTNET="testnet"})(b_||(b_={}));var wo;(function(_){_.VALIDATOR="validator",_.RPC="rpc"})(wo||(wo={}));var vo;(function(_){_.SOLANA="solana",_.JITO="jito",_.AGAVE="agave",_.FIREDANCER="firedancer"})(vo||(vo={}));var Ho;(function(_){_.CO_HOST_RELAYER="co-host-relayer",_.SEPARATED_RELAYER="separated-relayer",_.WITHOUT_RELAYER="without-relayer"})(Ho||(Ho={}));var Yo;(function(_){_.FIREDANCER="firedancer",_.FRANKENDANCER="frankendancer"})(Yo||(Yo={}));var Dt;(function(_){_[_.TESTNET_VALIDATOR=0]="TESTNET_VALIDATOR",_[_.MAINNET_VALIDATOR=1]="MAINNET_VALIDATOR",_[_.RPC_NODE=2]="RPC_NODE"})(Dt||(Dt={}));var Pt;(function(_){_.SOLANA_CLIENT="SolanaClient",_.JITO_MEV="JitoMev",_.FIREDANCER="Firedancer"})(Pt||(Pt={}));var Qo=!1,$o=!1,qo=!1,Wo=!1,Xo=!1,jo=!1,E_={ID:"solv",LANG:j_.EN,USERNAME:"solv",TESTNET_SOLANA_VERSION:"3.1.8",MAINNET_SOLANA_VERSION:"3.0.14",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,XDP:!1,ZERO_COPY:!1,JAG_SNAPSHOTS:!1,JAG_REGION:"",MEV_COMMISSION:1e3},v={ROOT:"/home/solv",AUTHORIZED_KEYS:"/home/solv/.ssh/authorized_keys"},m={ROOT:"/mnt",ACCOUNTS:"/mnt/accounts",LEDGER:"/mnt/ledger",SNAPSHOTS:"/mnt/snapshots"},D_={LOG:"solana-validator.log",STARTUP_SCRIPT:"start-validator.sh",CONFIG:"solv.config.json",JITO_CONFIG:"jito.config.json"},L={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"},h={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"},g=E((_=v.ROOT)=>{let e=_===v.ROOT?v.ROOT:_,t=`${e}/${h.MAINNET_VALIDATOR_KEY}`,o=`${e}/${h.MAINNET_VALIDATOR_VOTE_KEY}`,i=`${e}/${h.MAINNET_VALITATOR_AUTHORITY_KEY}`,n=`${e}/${h.TESTNET_VALIDATOR_KEY}`,s=`${e}/${h.TESTNET_VALIDATOR_VOTE_KEY}`,r=`${e}/${h.TESTNET_VALITATOR_AUTHORITY_KEY}`;return{mainnetValidatorKey:t,mainnetValidatorVoteKey:o,mainnetValidatorAuthorityKey:i,testnetValidatorKey:n,testnetValidatorVoteKey:s,testnetValidatorAuthorityKey:r}},"getAllKeyPaths"),w_=E((_=!0)=>{let e=_?`${v.ROOT}/${h.TESTNET_VALIDATOR_KEY}`:`${v.ROOT}/${h.MAINNET_VALIDATOR_KEY}`,t=_?`${v.ROOT}/${h.TESTNET_VALIDATOR_VOTE_KEY}`:`${v.ROOT}/${h.MAINNET_VALIDATOR_VOTE_KEY}`,o=`${v.ROOT}/${D_.LOG}`,i=m.ACCOUNTS,n=m.LEDGER,s=m.SNAPSHOTS,r=`${v.ROOT}/${D_.STARTUP_SCRIPT}`;return{identity:e,voteAccount:t,log:o,accounts:i,ledger:n,scriptPath:r,snapshots:s}},"startupScriptPaths");var R_="So1vW4Bm6ZURzJJHZy1JpsjoVY68z4cDgF4tTLwYMa5",KE="7tAfLKgRVd9eywSQPuMbVNd51KGkaveZQuTjapL74Fwv",zo="EiwSTx1Z2uJATDut682U7xzzquFR4UpQJUij3wSxVoSV",Zo=9,P_="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC",_i="So11111111111111111111111111111111111111112",ei="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",ti="CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP",Jo;(function(_){_[_.ELSOL=P_]="ELSOL",_[_.SOL=_i]="SOL",_[_.USDC=ei]="USDC",_[_.EPCT=ti]="EPCT"})(Jo||(Jo={}));var xo;(function(_){_.V6_BASE_URL="https://quote-api.jup.ag/v6",_.V6_QUOTE_URL="https://quote-api.jup.ag/v6/quote",_.V6_SWAP_URL="https://quote-api.jup.ag/v6/swap"})(xo||(xo={}));var $d={[_i]:9,[P_]:9,[ei]:6,[ti]:6},At="/home/solv/currentEpoch.json";var Ut="https://api.testnet.solana.com";import{spawnSync as GE}from"child_process";var Ei=E(()=>{GE("pnpm add -g pnpm",{shell:!0,stdio:"inherit"});let _=E_.NODE_VERSION;GE(`pnpm env use ${_} --global`,{shell:!0,stdio:"inherit"}),GE("pnpm add -g @gabrielhicks/solv",{shell:!0,stdio:"inherit"})},"updateSolv");import{spawnSync as o_}from"child_process";var ut=E((_,e=!1,t=!1,o=!1)=>{t?e?o_(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-solana/${_}/installer)"`,{shell:!0,stdio:"inherit"}):(o_(`mkdir /tmp/${_}`,{shell:!0,stdio:"inherit"}),o_(`cd /tmp/${_}`,{shell:!0,stdio:"inherit"}),o_(`git clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules /tmp/${_}`,{shell:!0,stdio:"inherit"}),o_(`git -C /tmp/${_} checkout ${_}`,{shell:!0,stdio:"inherit"}),o_(`git -C /tmp/${_} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),o_(`CI_COMMIT=$(git -C /tmp/${_} rev-parse HEAD) /tmp/${_}/scripts/cargo-install-all.sh /home/solv/.local/share/solana/install/releases/${_}`,{shell:!0,stdio:"inherit"}),o_("sudo rm -rf /home/solv/.local/share/solana/install/active_release",{shell:!0,stdio:"inherit"}),o_(`sudo ln -sfn /home/solv/.local/share/solana/install/releases/${_} /home/solv/.local/share/solana/install/active_release`,{shell:!0,stdio:"inherit"}),o&&o_("sudo setcap cap_net_raw,cap_net_admin,cap_bpf,cap_perfmon=p /home/solv/.local/share/solana/install/active_release/bin/agave-validator",{shell:!0,stdio:"inherit"}),o_(`sudo rm -rf /tmp/${_}`,{shell:!0,stdio:"inherit"})):e?o_(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-solana/${_}/installer)"`,{shell:!0,stdio:"inherit"}):o_(`sh -c "$(curl --netrc-optional -sSfL https://release.jito.wtf/${_}/install)"`,{shell:!0,stdio:"inherit"})},"jitoUpdate");import{readFile as hT,writeFile as gT}from"fs/promises";import{homedir as BT}from"os";var m_=E(async _=>{let t=`${BT()}/${D_.JITO_CONFIG}`,i={...JSON.parse(await hT(t,"utf8")),..._},n=JSON.stringify(i,null,2);await gT(t,n),console.log(`Updated ${t} with new values.`)},"updateJitoSolvConfig");import{spawnSync as oi}from"child_process";import yT from"inquirer";var ii=E((_,e=!0)=>{let t=e?"/home/solv/testnet-validator-keypair.json":"/home/solv/mainnet-validator-keypair.json",o=e?"/home/solv/testnet-vote-account-keypair.json":"/home/solv/mainnet-vote-account-keypair.json";oi(`solana config set --url ${e?"testnet":"mainnet-beta"} --keypair ${t}`,{shell:!0,stdio:"inherit"});let n=`solana vote-update-commission ${o} ${_} ${t} --keypair ${t}`;oi(n,{shell:!0,stdio:"inherit"})},"updateCommission"),ni=E(async()=>await yT.prompt([{type:"number",name:"commission",message:"Enter new commission",default:7}]),"updateCommissionAsk");import{execAsync as ve}from"@skeet-framework/utils";import KT from"chalk";import GT from"inquirer";var si=E(async()=>{let _=await GT.prompt([{name:"ip",type:"input",message:"Enter your IP address to allow access to RPC NODE:",default:"1.2.3.4"}]);await ve("sudo ufw delete allow 8899/udp"),await ve("sudo ufw delete allow 8899/tcp"),await ve(`sudo ufw allow from ${_.ip} to any port 8899 proto tcp`),await ve(`sudo ufw allow from ${_.ip} to any port 8899 proto udp`),await ve("sudo ufw reload"),console.log(KT.white("\u2714\uFE0F Firewall updated!"))},"updateFirewall");var kT=E(()=>Po,"getSolvVersion"),ce=kT;import{readFile as vT,writeFile as HT}from"fs/promises";import{existsAsync as YT}from"@skeet-framework/utils";var kE;(function(_){_.EN="en",_.JA="ja"})(kE||(kE={}));var Fl=Object.values(kE),l;(function(_){_.MAINNET="mainnet-beta",_.TESTNET="testnet"})(l||(l={}));var ri=Object.values(l),A;(function(_){_.RPC="rpc",_.VALIDATOR="validator"})(A||(A={}));var Ti=Object.values(A),F;(function(_){_.SOLANA="solana",_.AGAVE="agave",_.JITO="jito",_.FRANKENDANCER="frankendancer",_.BAM="bam",_.NONE="none"})(F||(F={}));var Il=Object.values(F).filter(_=>_!=="none"),Q;(function(_){_.AGAVE="agave",_.JITO="jito",_.NONE="none"})(Q||(Q={}));var ai=Object.values(Q).filter(_=>_!=="none"),i_;(function(_){_.SINGLE="single",_.DOUBLE="double",_.TRIPLE="triple"})(i_||(i_={}));var wT={NETWORK:l.TESTNET,NODE_TYPE:A.RPC,VALIDATOR_TYPE:F.NONE,RPC_TYPE:Q.AGAVE,MNT_DISK_TYPE:i_.TRIPLE,TESTNET_SOLANA_VERSION:c_,MAINNET_SOLANA_VERSION:t_,NODE_VERSION:ko,TESTNET_DELINQUENT_STAKE:10,MAINNET_DELINQUENT_STAKE:5,COMMISSION:5,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:mo,STAKE_ACCOUNTS:[],HARVEST_ACCOUNT:"",IS_MEV_MODE:!1,RPC_URL:Mo,KEYPAIR_PATH:"",DISCORD_WEBHOOK_URL:"",AUTO_UPDATE:!1,AUTO_RESTART:!1,IS_DUMMY:!1,API_KEY:"",LEDGER_PATH:u,ACCOUNTS_PATH:K_,SNAPSHOTS_PATH:O_,MOD:!1,XDP:!1,ZERO_COPY:!1,JAG_SNAPSHOTS:!1,JAG_REGION:"",CHRONY_LOCATION:"",MEV_COMMISSION:1e3},M_=wT;import{homedir as JT}from"os";var xT=E(async()=>{let e=`${JT()}/${lt}`;return await YT(e)?JSON.parse(await vT(e,"utf-8")):(console.log("Creating default config file at",e),await HT(e,JSON.stringify(M_,null,2)),M_)},"readConfig"),Y=xT;import QT from"node-fetch";var A_=E(async _=>{try{let e=await Y();if(e.DISCORD_WEBHOOK_URL==="")throw new Error(`DISCORD_WEBHOOK_URL is empty
3
3
  Please set DISCORD_WEBHOOK_URL in .env`);let t={content:_,username:"\u{1FA84} Solv Notifier"};return(await QT(e.DISCORD_WEBHOOK_URL,{method:"POST",body:JSON.stringify(t),headers:{"Content-Type":"application/json"}})).status===204}catch{return console.log({error:`Skeet sendDiscord Error - ${_}`}),!1}},"sendDiscord");import{spawnSync as jT}from"child_process";import{Connection as Si}from"@solana/web3.js";var He=E(async(_,e,t=!1,o=200)=>{let i={pubkey:e,isActive:!1,reason:""};try{let n=t?new Si("https://api.testnet.solana.com"):new Si(_,"confirmed"),s=await n.getVoteAccounts(),r=s.current.find(R=>R.votePubkey===e);if(!r)return s.delinquent.find(C=>C.votePubkey===e)?(i.isActive=!1,i.reason="Validator is delinquent.",i):(i.isActive=!1,i.reason="Validator is not found in both current and delinquent lists.",i);if(s=await n.getVoteAccounts(),r=s.current.find(R=>R.votePubkey===e),!r)return i.isActive=!1,i.reason="Validator is not found in the current list.",i;let T=r.lastVote,c=await n.getSlot()-T;return c>o?(i.isActive=!1,i.reason=`Validator has not voted for ${c} slots.`,i):(i.isActive=!0,i.reason="Validator is active and voting.",i)}catch(n){return console.error(n),i.isActive=!1,i.reason="Failed to check validator status.",i}},"isValidatorActive");import{spawnSync as $T}from"child_process";var k=E(_=>{let e=`solana address --keypair ${_}`,{stdout:t}=$T(e,{shell:!0,stdio:"pipe"});return t.toString().trim()},"getSolanaAddress");var qT=E(_=>new Promise(e=>setTimeout(e,_)),"sleep"),$=qT;import{sendDiscord as WT}from"@skeet-framework/utils";var ci=30,XT=E(async _=>{try{let e=_.NETWORK===l.TESTNET,{mainnetValidatorVoteKey:t,testnetValidatorVoteKey:o}=g(),n=k(e?o:t),s=await He(_.RPC_URL,n,e),r=0;for(;!s.isActive;){if(r>=ci){console.log("Max retries reached, exiting...");let T=`\u26A0\uFE0F Validator is not active for ${ci} minutes!
4
4
  Account: ${s.pubkey}
5
5
  Reason: ${s.reason}
@@ -10,7 +10,7 @@ at: <t:${R}> (${R})
10
10
  _ _`;await A_(C),await $(180*1e3);let O=await Ri(_);if(O){let S=Math.floor(Date.now()/1e3)-R,d=Math.floor(S/60),P=S%60,f=d>0?`${d}m ${P}s`:`${P}s`,D=`**${T}** has caught up!
11
11
  at: <t:${R}> (${R})
12
12
  **${T}** took **${f}** to catch up after restart!
13
- _ _`;await A_(D)}else{let N=`**${T}** failed to catch up after update`;await A_(N)}return O}return!0},"autoUpdate"),Ci=zT;import{homedir as ZT}from"os";import{readFile as _a,writeFile as di}from"fs/promises";import{existsAsync as ea}from"@skeet-framework/utils";var B=E(async _=>{let t=`${ZT()}/${lt}`;await ea(t)||(console.log("Creating default config file at",t),await di(t,JSON.stringify(M_,null,2)));let i={...JSON.parse(await _a(t,"utf8")),..._},n=JSON.stringify(i,null,2);await di(t,n)},"updateDefaultConfig");var ta={description:"\u{1F48E} Solana Validator All-in-One CLI \u{1F48E}",version:"Output the current version",help:"Display help for solv commands",subcmdHelp:"Display help for subcommands",server:"Open solv Dashboard",start:"Start Solana Validator",stop:"Stop Solana Validator",status:"Show Solana Validator Status",restart:"Restart Solana Validator",update:"Update Solana Validator Version",get:"Get Solana Validator Info Commands",log:"Tail Solana Validator Log",catchup:"Catchup Solana Validator",monitor:"Monitor Solana Validator",config:"Show Solana Validator Config",install:"Install/Update Solana Version",stake:"Solana Delegate Stake",check:"Check Solana Validator",scp:"Download/Upload Solana Validator Keypairs",cron:"Run Schedule Tasks",setup:"Setup Solana Validator",epoch:"Show Current Epoch",slot:"Show Current Slot",solv:"Endroll Solv AA",installer:"Please select an option:",unstake:"UnStake"},pt=ta;var Ea={description:"\u{1F48E} \u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u30AA\u30FC\u30EB\u30A4\u30F3\u30EF\u30F3 CLI \u30C4\u30FC\u30EB \u{1F48E}",version:"\u73FE\u5728\u306E\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u51FA\u529B",help:"solv \u30B3\u30DE\u30F3\u30C9\u306E\u30AA\u30D7\u30B7\u30E7\u30F3\u8A73\u7D30\u3092\u8868\u793A",subcmdHelp:"\u30B5\u30D6\u30B3\u30DE\u30F3\u30C9\u306E\u30D8\u30EB\u30D7\u3092\u8868\u793A",server:"solv \u30C0\u30C3\u30B7\u30E5\u30DC\u30FC\u30C9\u3092\u958B\u304F",start:"\u30CE\u30FC\u30C9\u3092\u8D77\u52D5",stop:"\u30CE\u30FC\u30C9\u3092\u505C\u6B62",status:"\u30CE\u30FC\u30C9\u306E\u30B9\u30C6\u30FC\u30BF\u30B9\u3092\u8868\u793A",restart:"\u30CE\u30FC\u30C9\u3092\u518D\u8D77\u52D5",update:"\u30CE\u30FC\u30C9\u306E\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u66F4\u65B0",get:"\u30CE\u30FC\u30C9\u306E\u8A2D\u5B9A\u60C5\u5831\u3092\u53D6\u5F97 \u30B5\u30D6\u30B3\u30DE\u30F3\u30C9",log:"\u30CE\u30FC\u30C9\u306E\u30ED\u30B0\u3092\u8868\u793A",catchup:"\u30CE\u30FC\u30C9\u3092\u30AD\u30E3\u30C3\u30C1\u30A2\u30C3\u30D7",monitor:"\u30CE\u30FC\u30C9\u3092\u76E3\u8996",config:"\u30CE\u30FC\u30C9\u306E\u8A2D\u5B9A\u3092\u8868\u793A",install:"\u30BD\u30E9\u30CA\u306E\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u66F4\u65B0/\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB",stake:"\u30BD\u30E9\u30CA\u306E\u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",unstake:"\u30BD\u30E9\u30CA\u306E\u30A2\u30F3\u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",check:"\u30CE\u30FC\u30C9\u306E\u72B6\u614B\u3092\u30C1\u30A7\u30C3\u30AF",scp:"scp \u30B5\u30D6\u30B3\u30DE\u30F3\u30C9",cron:"\u30B9\u30B1\u30B8\u30E5\u30FC\u30EB\u30BF\u30B9\u30AF \u30B5\u30D6\u30B3\u30DE\u30F3\u30C9",setup:"\u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u3092\u30BB\u30C3\u30C8\u30A2\u30C3\u30D7",epoch:"\u73FE\u5728\u306E\u30A8\u30DD\u30C3\u30AF\u3092\u8868\u793A",slot:"\u73FE\u5728\u306E\u30B9\u30ED\u30C3\u30C8\u3092\u8868\u793A",solv:"Solv\u30A8\u30F3\u30C9\u30ED\u30FC\u30EB AA \u3092\u8868\u793A",installer:"\u4EE5\u4E0B\u304B\u3089\u30AA\u30D7\u30B7\u30E7\u30F3\u3092\u9078\u629E\u3057\u3066\u304F\u3060\u3055\u3044:"},li=Ea;var oa={success:{created:"Created"},error:{failed:"Failed"},installer:{welcomeMsg:"\u{1F525} Welcome to the solv installer \u{1F525}",description:"solv is born and ready for running Solana Validator Nodes \u{1F680}"}},mt=oa;var ia={success:{created:"\u4F5C\u6210\u3055\u308C\u307E\u3057\u305F"},error:{failed:"\u5931\u6557\u3057\u307E\u3057\u305F"},installer:{welcomeMsg:"\u{1F525} \u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u30C4\u30FC\u30EB solv \u3078\u3088\u3046\u3053\u305D \u{1F525}",description:"\u3042\u306A\u305F\u306F\u3082\u3046\u3001\u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306B\u306A\u308B\u6E96\u5099\u304C\u3067\u304D\u3066\u3044\u307E\u3059\u3002"}},Ni=ia;var Mt=[") Upgrade - Update/Downgrade Solana Version",") Check Validator Logs/Status or Start/Stop",") Get Validator Config Info",") Backup Validator Keyfiles",") Staking",") Uninstall",") Exit"],Lt=[[],[") Check Validator Status",") Show Validator Logs",") Start Validator",") Stop Validator",") Restart Validator (no fetch snapshot)",") Restart Validator (fetch snapshot)",") Return to Main Menu"],[") Show Validator Config",") Register Validator Info",") Show Validator Keys Path/Address/Balance",") Get Current Epoch/Slot",") Get Solana Validator Catchup Info",") Get Solana Validator Monitor Info",") Return to Main Menu"],[") Backup Validator Keyfiles",") Set Validator Keyfile/Network",") Return to Main Menu"],[") Stake",") Unstake",") Return to Main Menu"],[],[]];var Oi=[") \u30A2\u30C3\u30D7\u30B0\u30EC\u30FC\u30C9 - Solana\u30D0\u30FC\u30B8\u30E7\u30F3\u306E\u30A2\u30C3\u30D7\u30C7\u30FC\u30C8/\u30C0\u30A6\u30F3\u30B0\u30EC\u30FC\u30C9",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u72B6\u614B/\u30ED\u30B0\u3092\u78BA\u8A8D\u30FB\u307E\u305F\u306F\u958B\u59CB/\u505C\u6B62",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u8A2D\u5B9A\u60C5\u5831",") \u9375\u306E\u8A2D\u5B9A",") \u30B9\u30C6\u30FC\u30AD\u30F3\u30B0",") \u30A2\u30F3\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB",") \u7D42\u4E86"],Fi=[[],[") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u72B6\u614B\u3092\u78BA\u8A8D",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u30ED\u30B0\u3092\u8868\u793A",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u958B\u59CB",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u505C\u6B62",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u518D\u8D77\u52D5 (fetch snapshot \u306A\u3057)",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u518D\u8D77\u52D5 (fetch snapshot \u3042\u308A)",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u8A2D\u5B9A\u3092\u898B\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u60C5\u5831\u3092\u767B\u9332\u3059\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u9375\u306E \u30D1\u30B9/\u30A2\u30C9\u30EC\u30B9/\u6B8B\u9AD8 \u3092\u898B\u308B",") \u73FE\u5728\u306E \u30A8\u30DD\u30C3\u30AF/\u30B9\u30ED\u30C3\u30C8 \u3092\u898B\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E Catchup \u60C5\u5831\u3092\u898B\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u30E2\u30CB\u30BF\u30FC\u60C5\u5831\u3092\u898B\u308B",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u30D0\u30C3\u30AF\u30A2\u30C3\u30D7",") \u9375/\u30CD\u30C3\u30C8\u30EF\u30FC\u30AF\u3092\u8A2D\u5B9A\u3059\u308B",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[") \u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",") \u30A2\u30F3\u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[],[]];var na={server:{description:"Open solv Dashboard"},start:{description:"Start Solana Validator"},stop:{description:"Stop Solana Validator"},status:{description:"Show Solana Validator Status"},restart:{description:"Restart Solana Validator"},update:{description:"Update Solana Validator Version"},get:{description:"Get Solana Validator Info"},log:{description:"Tail Solana Validator Log"},catchup:{description:"Catchup Solana Validator"},monitor:{description:"Monitor Solana Validator"},config:{description:"Show Solana Validator Config"},install:{description:"Install/Update Solana Version"},stake:{description:"Solana Delegate Stake"},unstake:{description:"UnStake"},check:{description:"Check Solana Validator"},scp:{description:"Download/Upload Solana Validator Keypairs"},cron:{description:"Run Schedule Tasks"},setup:{description:"Setup Solana Validator"},epoch:{description:"Show Current Epoch"},slot:{description:"Show Current Slot"},solv:{description:"Endroll Solv AA"}},ht=na;var sa={server:{description:"Open solv Dashboard"},start:{description:"Start Solana Validator"},stop:{description:"Stop Solana Validator"},status:{description:"Show Solana Validator Status"},restart:{description:"Restart Solana Validator"},update:{description:"Update Solana Validator Version"},get:{description:"Get Solana Validator Info"},log:{description:"Tail Solana Validator Log"},catchup:{description:"Catchup Solana Validator"},monitor:{description:"Monitor Solana Validator"},config:{description:"Show Solana Validator Config"},install:{description:"Install/Update Solana Version"},stake:{description:"Solana Delegate Stake"},unstake:{description:"UnStake"},check:{description:"Check Solana Validator"},scp:{description:"Download/Upload Solana Validator Keypairs"},cron:{description:"Run Schedule Tasks"},setup:{description:"Setup Solana Validator"},epoch:{description:"Show Current Epoch"},slot:{description:"Show Current Slot"},solv:{description:"Endroll Solv AA"}},Ii=sa;var gt=[") Check Validator Status",") Download Validator Keyfiles",") Generate Validator Keyfiles",") Upload Validator Keyfiles",") Set Validator Keyfile/Network",") Uninstall",") Exit"];var fi=[") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u72B6\u614B\u3092\u78BA\u8A8D",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u30C0\u30A6\u30F3\u30ED\u30FC\u30C9",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u4F5C\u6210",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u30A2\u30C3\u30D7\u30ED\u30FC\u30C9",") \u9375/\u30CD\u30C3\u30C8\u30EF\u30FC\u30AF\u3092\u8A2D\u5B9A\u3059\u308B",") \u30A2\u30F3\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB",") \u7D42\u4E86"];var ra=E(_=>{let e={cmds:pt,subCmds:ht,logs:mt,installer:Mt,installerSub:Lt,clientCmds:gt};switch(_){case j_.EN:e={cmds:pt,subCmds:ht,logs:mt,installer:Mt,installerSub:Lt,clientCmds:gt};break;case j_.JA:e={cmds:li,subCmds:Ii,logs:Ni,installer:Oi,installerSub:Fi,clientCmds:fi};break;default:e={cmds:pt,subCmds:ht,logs:mt,installer:Mt,installerSub:Lt,clientCmds:gt}}return e},"readLocale"),Di=ra;import{existsSync as ca,readFileSync as Ra,writeFileSync as Pi}from"fs";import{readFileSync as Ta,writeFileSync as aa}from"fs";import{homedir as Sa}from"os";var Re=E(_=>{let t=`${Sa()}/${D_.CONFIG}`,i={...JSON.parse(Ta(t,"utf8")),..._},n=JSON.stringify(i,null,2);aa(t,n)},"updateSolvConfig");import{homedir as Ca}from"os";var Ai=E(()=>{let e=`${Ca()}/${D_.CONFIG}`;ca(e)||(Pi(e,JSON.stringify(t_,null,2)),console.log(`Created default config file at ${e}`));let t;try{t=JSON.parse(Ra(e,"utf-8"))}catch{console.log("Error parsing config file. Renewing config file."),Pi(e,JSON.stringify(t_,null,2)),t=t_}let o=Di(t.LANG);return t.RPC_URL||(t.RPC_URL=t_.RPC_URL,Re({RPC_URL:t_.RPC_URL})),t.IS_MEV_MODE===void 0&&(t.IS_MEV_MODE=!1,Re({IS_MEV_MODE:!1})),t.DISCORD_WEBHOOK_URL||(t.DISCORD_WEBHOOK_URL="",Re({DISCORD_WEBHOOK_URL:""})),{config:t,locale:o}},"readOrCreateDefaultConfig");import{spawnSync as H}from"child_process";import{promises as Ui}from"fs";import la from"path";var da=E(()=>{let _="/home/solv/firedancer/mod.diff",e=String.raw`diff --git a/book/api/metrics-generated.md b/book/api/metrics-generated.md
13
+ _ _`;await A_(D)}else{let N=`**${T}** failed to catch up after update`;await A_(N)}return O}return!0},"autoUpdate"),Ci=zT;import{homedir as ZT}from"os";import{readFile as _a,writeFile as di}from"fs/promises";import{existsAsync as ea}from"@skeet-framework/utils";var B=E(async _=>{let t=`${ZT()}/${lt}`;await ea(t)||(console.log("Creating default config file at",t),await di(t,JSON.stringify(M_,null,2)));let i={...JSON.parse(await _a(t,"utf8")),..._},n=JSON.stringify(i,null,2);await di(t,n)},"updateDefaultConfig");var ta={description:"\u{1F48E} Solana Validator All-in-One CLI \u{1F48E}",version:"Output the current version",help:"Display help for solv commands",subcmdHelp:"Display help for subcommands",server:"Open solv Dashboard",start:"Start Solana Validator",stop:"Stop Solana Validator",status:"Show Solana Validator Status",restart:"Restart Solana Validator",update:"Update Solana Validator Version",get:"Get Solana Validator Info Commands",log:"Tail Solana Validator Log",catchup:"Catchup Solana Validator",monitor:"Monitor Solana Validator",config:"Show Solana Validator Config",install:"Install/Update Solana Version",stake:"Solana Delegate Stake",check:"Check Solana Validator",scp:"Download/Upload Solana Validator Keypairs",cron:"Run Schedule Tasks",setup:"Setup Solana Validator",epoch:"Show Current Epoch",slot:"Show Current Slot",solv:"Endroll Solv AA",installer:"Please select an option:",unstake:"UnStake"},pt=ta;var Ea={description:"\u{1F48E} \u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u30AA\u30FC\u30EB\u30A4\u30F3\u30EF\u30F3 CLI \u30C4\u30FC\u30EB \u{1F48E}",version:"\u73FE\u5728\u306E\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u51FA\u529B",help:"solv \u30B3\u30DE\u30F3\u30C9\u306E\u30AA\u30D7\u30B7\u30E7\u30F3\u8A73\u7D30\u3092\u8868\u793A",subcmdHelp:"\u30B5\u30D6\u30B3\u30DE\u30F3\u30C9\u306E\u30D8\u30EB\u30D7\u3092\u8868\u793A",server:"solv \u30C0\u30C3\u30B7\u30E5\u30DC\u30FC\u30C9\u3092\u958B\u304F",start:"\u30CE\u30FC\u30C9\u3092\u8D77\u52D5",stop:"\u30CE\u30FC\u30C9\u3092\u505C\u6B62",status:"\u30CE\u30FC\u30C9\u306E\u30B9\u30C6\u30FC\u30BF\u30B9\u3092\u8868\u793A",restart:"\u30CE\u30FC\u30C9\u3092\u518D\u8D77\u52D5",update:"\u30CE\u30FC\u30C9\u306E\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u66F4\u65B0",get:"\u30CE\u30FC\u30C9\u306E\u8A2D\u5B9A\u60C5\u5831\u3092\u53D6\u5F97 \u30B5\u30D6\u30B3\u30DE\u30F3\u30C9",log:"\u30CE\u30FC\u30C9\u306E\u30ED\u30B0\u3092\u8868\u793A",catchup:"\u30CE\u30FC\u30C9\u3092\u30AD\u30E3\u30C3\u30C1\u30A2\u30C3\u30D7",monitor:"\u30CE\u30FC\u30C9\u3092\u76E3\u8996",config:"\u30CE\u30FC\u30C9\u306E\u8A2D\u5B9A\u3092\u8868\u793A",install:"\u30BD\u30E9\u30CA\u306E\u30D0\u30FC\u30B8\u30E7\u30F3\u3092\u66F4\u65B0/\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB",stake:"\u30BD\u30E9\u30CA\u306E\u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",unstake:"\u30BD\u30E9\u30CA\u306E\u30A2\u30F3\u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",check:"\u30CE\u30FC\u30C9\u306E\u72B6\u614B\u3092\u30C1\u30A7\u30C3\u30AF",scp:"scp \u30B5\u30D6\u30B3\u30DE\u30F3\u30C9",cron:"\u30B9\u30B1\u30B8\u30E5\u30FC\u30EB\u30BF\u30B9\u30AF \u30B5\u30D6\u30B3\u30DE\u30F3\u30C9",setup:"\u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u3092\u30BB\u30C3\u30C8\u30A2\u30C3\u30D7",epoch:"\u73FE\u5728\u306E\u30A8\u30DD\u30C3\u30AF\u3092\u8868\u793A",slot:"\u73FE\u5728\u306E\u30B9\u30ED\u30C3\u30C8\u3092\u8868\u793A",solv:"Solv\u30A8\u30F3\u30C9\u30ED\u30FC\u30EB AA \u3092\u8868\u793A",installer:"\u4EE5\u4E0B\u304B\u3089\u30AA\u30D7\u30B7\u30E7\u30F3\u3092\u9078\u629E\u3057\u3066\u304F\u3060\u3055\u3044:"},li=Ea;var oa={success:{created:"Created"},error:{failed:"Failed"},installer:{welcomeMsg:"\u{1F525} Welcome to the solv installer \u{1F525}",description:"solv is born and ready for running Solana Validator Nodes \u{1F680}"}},mt=oa;var ia={success:{created:"\u4F5C\u6210\u3055\u308C\u307E\u3057\u305F"},error:{failed:"\u5931\u6557\u3057\u307E\u3057\u305F"},installer:{welcomeMsg:"\u{1F525} \u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u30C4\u30FC\u30EB solv \u3078\u3088\u3046\u3053\u305D \u{1F525}",description:"\u3042\u306A\u305F\u306F\u3082\u3046\u3001\u30BD\u30E9\u30CA\u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306B\u306A\u308B\u6E96\u5099\u304C\u3067\u304D\u3066\u3044\u307E\u3059\u3002"}},Ni=ia;var Mt=[") Upgrade - Update/Downgrade Solana Version",") Check Validator Logs/Status or Start/Stop",") Get Validator Config Info",") Backup Validator Keyfiles",") Staking",") Uninstall",") Exit"],Lt=[[],[") Check Validator Status",") Show Validator Logs",") Start Validator",") Stop Validator",") Restart Validator (no fetch snapshot)",") Restart Validator (fetch snapshot)",") Return to Main Menu"],[") Show Validator Config",") Register Validator Info",") Show Validator Keys Path/Address/Balance",") Get Current Epoch/Slot",") Get Solana Validator Catchup Info",") Get Solana Validator Monitor Info",") Return to Main Menu"],[") Backup Validator Keyfiles",") Set Validator Keyfile/Network",") Return to Main Menu"],[") Stake",") Unstake",") Return to Main Menu"],[],[]];var Oi=[") \u30A2\u30C3\u30D7\u30B0\u30EC\u30FC\u30C9 - Solana\u30D0\u30FC\u30B8\u30E7\u30F3\u306E\u30A2\u30C3\u30D7\u30C7\u30FC\u30C8/\u30C0\u30A6\u30F3\u30B0\u30EC\u30FC\u30C9",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u72B6\u614B/\u30ED\u30B0\u3092\u78BA\u8A8D\u30FB\u307E\u305F\u306F\u958B\u59CB/\u505C\u6B62",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u8A2D\u5B9A\u60C5\u5831",") \u9375\u306E\u8A2D\u5B9A",") \u30B9\u30C6\u30FC\u30AD\u30F3\u30B0",") \u30A2\u30F3\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB",") \u7D42\u4E86"],Fi=[[],[") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u72B6\u614B\u3092\u78BA\u8A8D",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u30ED\u30B0\u3092\u8868\u793A",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u958B\u59CB",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u505C\u6B62",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u518D\u8D77\u52D5 (fetch snapshot \u306A\u3057)",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u3092\u518D\u8D77\u52D5 (fetch snapshot \u3042\u308A)",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u8A2D\u5B9A\u3092\u898B\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u60C5\u5831\u3092\u767B\u9332\u3059\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u9375\u306E \u30D1\u30B9/\u30A2\u30C9\u30EC\u30B9/\u6B8B\u9AD8 \u3092\u898B\u308B",") \u73FE\u5728\u306E \u30A8\u30DD\u30C3\u30AF/\u30B9\u30ED\u30C3\u30C8 \u3092\u898B\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E Catchup \u60C5\u5831\u3092\u898B\u308B",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u30E2\u30CB\u30BF\u30FC\u60C5\u5831\u3092\u898B\u308B",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u30D0\u30C3\u30AF\u30A2\u30C3\u30D7",") \u9375/\u30CD\u30C3\u30C8\u30EF\u30FC\u30AF\u3092\u8A2D\u5B9A\u3059\u308B",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[") \u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",") \u30A2\u30F3\u30B9\u30C6\u30FC\u30AD\u30F3\u30B0\u3092\u884C\u3046",") \u30E1\u30A4\u30F3\u30E1\u30CB\u30E5\u30FC\u306B\u623B\u308B"],[],[]];var na={server:{description:"Open solv Dashboard"},start:{description:"Start Solana Validator"},stop:{description:"Stop Solana Validator"},status:{description:"Show Solana Validator Status"},restart:{description:"Restart Solana Validator"},update:{description:"Update Solana Validator Version"},get:{description:"Get Solana Validator Info"},log:{description:"Tail Solana Validator Log"},catchup:{description:"Catchup Solana Validator"},monitor:{description:"Monitor Solana Validator"},config:{description:"Show Solana Validator Config"},install:{description:"Install/Update Solana Version"},stake:{description:"Solana Delegate Stake"},unstake:{description:"UnStake"},check:{description:"Check Solana Validator"},scp:{description:"Download/Upload Solana Validator Keypairs"},cron:{description:"Run Schedule Tasks"},setup:{description:"Setup Solana Validator"},epoch:{description:"Show Current Epoch"},slot:{description:"Show Current Slot"},solv:{description:"Endroll Solv AA"}},ht=na;var sa={server:{description:"Open solv Dashboard"},start:{description:"Start Solana Validator"},stop:{description:"Stop Solana Validator"},status:{description:"Show Solana Validator Status"},restart:{description:"Restart Solana Validator"},update:{description:"Update Solana Validator Version"},get:{description:"Get Solana Validator Info"},log:{description:"Tail Solana Validator Log"},catchup:{description:"Catchup Solana Validator"},monitor:{description:"Monitor Solana Validator"},config:{description:"Show Solana Validator Config"},install:{description:"Install/Update Solana Version"},stake:{description:"Solana Delegate Stake"},unstake:{description:"UnStake"},check:{description:"Check Solana Validator"},scp:{description:"Download/Upload Solana Validator Keypairs"},cron:{description:"Run Schedule Tasks"},setup:{description:"Setup Solana Validator"},epoch:{description:"Show Current Epoch"},slot:{description:"Show Current Slot"},solv:{description:"Endroll Solv AA"}},Ii=sa;var gt=[") Check Validator Status",") Download Validator Keyfiles",") Generate Validator Keyfiles",") Upload Validator Keyfiles",") Set Validator Keyfile/Network",") Uninstall",") Exit"];var fi=[") \u30D0\u30EA\u30C7\u30FC\u30BF-\u306E\u72B6\u614B\u3092\u78BA\u8A8D",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u30C0\u30A6\u30F3\u30ED\u30FC\u30C9",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u4F5C\u6210",") \u30D0\u30EA\u30C7\u30FC\u30BF\u30FC\u306E\u9375\u3092\u30A2\u30C3\u30D7\u30ED\u30FC\u30C9",") \u9375/\u30CD\u30C3\u30C8\u30EF\u30FC\u30AF\u3092\u8A2D\u5B9A\u3059\u308B",") \u30A2\u30F3\u30A4\u30F3\u30B9\u30C8\u30FC\u30EB",") \u7D42\u4E86"];var ra=E(_=>{let e={cmds:pt,subCmds:ht,logs:mt,installer:Mt,installerSub:Lt,clientCmds:gt};switch(_){case j_.EN:e={cmds:pt,subCmds:ht,logs:mt,installer:Mt,installerSub:Lt,clientCmds:gt};break;case j_.JA:e={cmds:li,subCmds:Ii,logs:Ni,installer:Oi,installerSub:Fi,clientCmds:fi};break;default:e={cmds:pt,subCmds:ht,logs:mt,installer:Mt,installerSub:Lt,clientCmds:gt}}return e},"readLocale"),Di=ra;import{existsSync as ca,readFileSync as Ra,writeFileSync as Pi}from"fs";import{readFileSync as Ta,writeFileSync as aa}from"fs";import{homedir as Sa}from"os";var Re=E(_=>{let t=`${Sa()}/${D_.CONFIG}`,i={...JSON.parse(Ta(t,"utf8")),..._},n=JSON.stringify(i,null,2);aa(t,n)},"updateSolvConfig");import{homedir as Ca}from"os";var Ai=E(()=>{let e=`${Ca()}/${D_.CONFIG}`;ca(e)||(Pi(e,JSON.stringify(E_,null,2)),console.log(`Created default config file at ${e}`));let t;try{t=JSON.parse(Ra(e,"utf-8"))}catch{console.log("Error parsing config file. Renewing config file."),Pi(e,JSON.stringify(E_,null,2)),t=E_}let o=Di(t.LANG);return t.RPC_URL||(t.RPC_URL=E_.RPC_URL,Re({RPC_URL:E_.RPC_URL})),t.IS_MEV_MODE===void 0&&(t.IS_MEV_MODE=!1,Re({IS_MEV_MODE:!1})),t.DISCORD_WEBHOOK_URL||(t.DISCORD_WEBHOOK_URL="",Re({DISCORD_WEBHOOK_URL:""})),{config:t,locale:o}},"readOrCreateDefaultConfig");import{spawnSync as H}from"child_process";import{promises as Ui}from"fs";import la from"path";var da=E(()=>{let _="/home/solv/firedancer/mod.diff",e=String.raw`diff --git a/book/api/metrics-generated.md b/book/api/metrics-generated.md
14
14
  index a0c631ee9f..048b118660 100644
15
15
  --- a/book/api/metrics-generated.md
16
16
  +++ b/book/api/metrics-generated.md
@@ -5795,7 +5795,7 @@ index 479e0f1829..a97f5778d4 100644
5795
5795
 
5796
5796
  /* FD_LOG_NOTICE(( ... printf style arguments ... )) will send a message
5797
5797
  at the NOTICE level to the logger. E.g. for a typical fd_log
5798
- `;return{filePath:_,body:e}},"modDiff"),Bt=da;var yt=E(async(_,e,t=!1)=>{let o=_.NETWORK===l.TESTNET,i=e||(o?Se:V_),n=t||_.MOD,{filePath:s,body:r}=Bt();n?(H("git -C /home/solv/firedancer fetch origin",{shell:!0,stdio:"inherit"}),H(`git -C /home/solv/firedancer checkout v${i}`,{shell:!0,stdio:"inherit"}),H("git -C /home/solv/firedancer submodule update --init --recursive",{shell:!0,stdio:"inherit"}),H('git -C /home/solv/firedancer config --global user.email "you@example.com"',{shell:!0,stdio:"inherit"}),H('git -C /home/solv/firedancer config --global user.name "Your Name"',{shell:!0,stdio:"inherit"}),await Ui.mkdir(la.dirname(s),{recursive:!0}),await Ui.writeFile(s,r,"utf8"),H(`sudo chown solv:solv "${s}"`,{shell:!0,stdio:"inherit"}),H(`git -C /home/solv/firedancer apply ${s}`,{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),H("git -C /home/solv/firedancer add /home/solv/firedancer/src/*",{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),H("git -C /home/solv/firedancer add /home/solv/firedancer/book/*",{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),H('git -C /home/solv/firedancer commit -m "add mods"',{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"})):(H("git -C /home/solv/firedancer fetch origin",{shell:!0,stdio:"inherit"}),H(`git -C /home/solv/firedancer checkout v${i}`,{shell:!0,stdio:"inherit"}),H("git -C /home/solv/firedancer submodule update --init --recursive",{shell:!0,stdio:"inherit"})),H("export FD_AUTO_INSTALL_PACKAGES=1 && ./deps.sh fetch check install",{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),H("make -j fdctl solana",{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),H("sudo systemctl restart port-relay",{shell:!0,stdio:"inherit"}),H("sudo systemctl disable solv.service",{stdio:"inherit",shell:!0}),H("sudo systemctl stop solv.service",{stdio:"inherit",shell:!0})},"frankendancerUpdate");import{spawnSync as i_}from"child_process";var Kt=E((_,e=!1,t=!1,o=!1)=>{t?e?i_(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-bam/${_}/installer)"`,{shell:!0,stdio:"inherit"}):(i_(`mkdir /tmp/${_}-bam`,{shell:!0,stdio:"inherit"}),i_(`cd /tmp/${_}-bam`,{shell:!0,stdio:"inherit"}),i_(`git clone https://github.com/jito-labs/bam-client.git --recurse-submodules /tmp/${_}`,{shell:!0,stdio:"inherit"}),i_(`git -C /tmp/${_} checkout ${_}`,{shell:!0,stdio:"inherit"}),i_(`git -C /tmp/${_} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),i_(`CI_COMMIT=$(git -C /tmp/${_} rev-parse HEAD) /tmp/${_}/scripts/cargo-install-all.sh /home/solv/.local/share/solana/install/releases/${_}`,{shell:!0,stdio:"inherit"}),i_("sudo rm -rf /home/solv/.local/share/solana/install/active_release",{shell:!0,stdio:"inherit"}),i_(`sudo ln -sfn /home/solv/.local/share/solana/install/releases/${_} /home/solv/.local/share/solana/install/active_release`,{shell:!0,stdio:"inherit"}),o&&i_("sudo setcap cap_net_raw,cap_net_admin,cap_bpf,cap_perfmon=p /home/solv/.local/share/solana/install/active_release/bin/agave-validator",{shell:!0,stdio:"inherit"}),i_(`sudo rm -rf /tmp/${_}`,{shell:!0,stdio:"inherit"})):e?i_(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-bam/${_}/installer)"`,{shell:!0,stdio:"inherit"}):i_(`sh -c "$(curl --netrc-optional -sSfL https://release.jito.wtf/${_}/install)"`,{shell:!0,stdio:"inherit"})},"bamUpdate");var ui=E(()=>`#!/bin/bash
5798
+ `;return{filePath:_,body:e}},"modDiff"),Bt=da;var yt=E(async(_,e,t=!1)=>{let o=_.NETWORK===l.TESTNET,i=e||(o?Se:V_),n=t||_.MOD,{filePath:s,body:r}=Bt();n?(H("git -C /home/solv/firedancer fetch origin",{shell:!0,stdio:"inherit"}),H(`git -C /home/solv/firedancer checkout v${i}`,{shell:!0,stdio:"inherit"}),H("git -C /home/solv/firedancer submodule update --init --recursive",{shell:!0,stdio:"inherit"}),H('git -C /home/solv/firedancer config --global user.email "you@example.com"',{shell:!0,stdio:"inherit"}),H('git -C /home/solv/firedancer config --global user.name "Your Name"',{shell:!0,stdio:"inherit"}),await Ui.mkdir(la.dirname(s),{recursive:!0}),await Ui.writeFile(s,r,"utf8"),H(`sudo chown solv:solv "${s}"`,{shell:!0,stdio:"inherit"}),H(`git -C /home/solv/firedancer apply ${s}`,{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),H("git -C /home/solv/firedancer add /home/solv/firedancer/src/*",{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),H("git -C /home/solv/firedancer add /home/solv/firedancer/book/*",{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),H('git -C /home/solv/firedancer commit -m "add mods"',{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"})):(H("git -C /home/solv/firedancer fetch origin",{shell:!0,stdio:"inherit"}),H(`git -C /home/solv/firedancer checkout v${i}`,{shell:!0,stdio:"inherit"}),H("git -C /home/solv/firedancer submodule update --init --recursive",{shell:!0,stdio:"inherit"})),H("export FD_AUTO_INSTALL_PACKAGES=1 && ./deps.sh fetch check install",{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),H("make -j fdctl solana",{shell:!0,stdio:"inherit",cwd:"/home/solv/firedancer"}),H("sudo systemctl restart port-relay",{shell:!0,stdio:"inherit"}),H("sudo systemctl disable solv.service",{stdio:"inherit",shell:!0}),H("sudo systemctl stop solv.service",{stdio:"inherit",shell:!0})},"frankendancerUpdate");import{spawnSync as n_}from"child_process";var Kt=E((_,e=!1,t=!1,o=!1)=>{t?e?n_(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-bam/${_}/installer)"`,{shell:!0,stdio:"inherit"}):(n_(`mkdir /tmp/${_}-bam`,{shell:!0,stdio:"inherit"}),n_(`cd /tmp/${_}-bam`,{shell:!0,stdio:"inherit"}),n_(`git clone https://github.com/jito-labs/bam-client.git --recurse-submodules /tmp/${_}`,{shell:!0,stdio:"inherit"}),n_(`git -C /tmp/${_} checkout ${_}`,{shell:!0,stdio:"inherit"}),n_(`git -C /tmp/${_} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),n_(`CI_COMMIT=$(git -C /tmp/${_} rev-parse HEAD) /tmp/${_}/scripts/cargo-install-all.sh /home/solv/.local/share/solana/install/releases/${_}`,{shell:!0,stdio:"inherit"}),n_("sudo rm -rf /home/solv/.local/share/solana/install/active_release",{shell:!0,stdio:"inherit"}),n_(`sudo ln -sfn /home/solv/.local/share/solana/install/releases/${_} /home/solv/.local/share/solana/install/active_release`,{shell:!0,stdio:"inherit"}),o&&n_("sudo setcap cap_net_raw,cap_net_admin,cap_bpf,cap_perfmon=p /home/solv/.local/share/solana/install/active_release/bin/agave-validator",{shell:!0,stdio:"inherit"}),n_(`sudo rm -rf /tmp/${_}`,{shell:!0,stdio:"inherit"})):e?n_(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-bam/${_}/installer)"`,{shell:!0,stdio:"inherit"}):n_(`sh -c "$(curl --netrc-optional -sSfL https://release.jito.wtf/${_}/install)"`,{shell:!0,stdio:"inherit"})},"bamUpdate");var ui=E(()=>`#!/bin/bash
5799
5799
  exec agave-validator \\
5800
5800
  --identity ${p} \\
5801
5801
  --vote-account ${y_} \\
@@ -5825,7 +5825,7 @@ exec agave-validator \\
5825
5825
  --experimental-retransmit-xdp-zero-copy \\
5826
5826
  --experimental-poh-pinned-cpu-core 6 \\
5827
5827
  `,"startTestnetValidatorScript");import pi from"chalk";import{spawnSync as Na}from"child_process";var mi=E(async _=>{try{let e=`spl-token accounts --owner ${_}`;Na(e,{shell:!0,stdio:"inherit"})}catch{console.log(pi.yellow(`You might need to install the Solana SPL CLI:
5828
- `)),console.log(pi.white("$ cargo install spl-token-cli"))}},"splBalance");import{homedir as Fa}from"os";import{spawnSync as Oa}from"child_process";var v_=E(_=>{let e=`solana balance --keypair ${_}`,{stdout:t}=Oa(e,{shell:!0,stdio:"pipe"});return t.toString().trim()},"getSolBalance");import Ia from"chalk";import{spawnSync as fa}from"node:child_process";var Mi=E(_=>{I.command("balance").alias("bal").alias("b").option("-s, --spl","Show SPL Token Balance",!1).description("Show Keypairs Balance").action(async e=>{if(e.spl){let o=`${Fa()}/mainnet-authority-keypair.json`;await mi(o),process.exit(0)}await Da(_),process.exit(0)})},"balanceCommands"),Da=E(async _=>{let e=n_(_),t=`Validator Key: ${e.validatorKey}
5828
+ `)),console.log(pi.white("$ cargo install spl-token-cli"))}},"splBalance");import{homedir as Fa}from"os";import{spawnSync as Oa}from"child_process";var v_=E(_=>{let e=`solana balance --keypair ${_}`,{stdout:t}=Oa(e,{shell:!0,stdio:"pipe"});return t.toString().trim()},"getSolBalance");import Ia from"chalk";import{spawnSync as fa}from"node:child_process";var Mi=E(_=>{I.command("balance").alias("bal").alias("b").option("-s, --spl","Show SPL Token Balance",!1).description("Show Keypairs Balance").action(async e=>{if(e.spl){let o=`${Fa()}/mainnet-authority-keypair.json`;await mi(o),process.exit(0)}await Da(_),process.exit(0)})},"balanceCommands"),Da=E(async _=>{let e=s_(_),t=`Validator Key: ${e.validatorKey}
5829
5829
  Address: ${e.validatorKeyAddress}
5830
5830
  Balance: ${e.validatorKeyBalance}
5831
5831
  Vote Key: ${e.voteKey}
@@ -5837,7 +5837,7 @@ Balance: ${e.authorityKeyBalance}
5837
5837
  Active Identity:`;_.NODE_TYPE===A.RPC&&(t=`Validator Key: ${e.validatorKey}
5838
5838
  Address: ${e.validatorKeyAddress}
5839
5839
  Balance: ${e.validatorKeyBalance}
5840
- Active Identity:`),console.log(Ia.white(t)),fa(`solana-keygen pubkey ${p}`,{stdio:"inherit",shell:!0})},"showKeypairsInfo"),n_=E(_=>{let e=g(),t=_.NETWORK===l.TESTNET;return _.NODE_TYPE===A.RPC?{validatorKey:e.mainnetValidatorKey,validatorKeyAddress:k(e.mainnetValidatorKey),validatorKeyBalance:v_(e.mainnetValidatorKey)}:t?{validatorKey:e.testnetValidatorKey,validatorKeyAddress:k(e.testnetValidatorKey),validatorKeyBalance:v_(e.testnetValidatorKey),voteKey:e.testnetValidatorVoteKey,voteKeyAddress:k(e.testnetValidatorVoteKey),voteKeyBalance:v_(e.testnetValidatorVoteKey),authorityKey:e.testnetValidatorAuthorityKey,authorityKeyAddress:k(e.testnetValidatorAuthorityKey),authorityKeyBalance:v_(e.testnetValidatorAuthorityKey)}:{validatorKey:e.mainnetValidatorKey,validatorKeyAddress:k(e.mainnetValidatorKey),validatorKeyBalance:v_(e.mainnetValidatorKey),voteKey:e.mainnetValidatorVoteKey,voteKeyAddress:k(e.mainnetValidatorVoteKey),voteKeyBalance:v_(e.mainnetValidatorVoteKey),authorityKey:e.mainnetValidatorAuthorityKey,authorityKeyAddress:k(e.mainnetValidatorAuthorityKey),authorityKeyBalance:v_(e.mainnetValidatorAuthorityKey)}},"getKeypairsInfo");import{execSync as Pa}from"node:child_process";var Ye=E((_,e="agave-validator")=>{let{validatorKeyAddress:t}=n_(_),o=_.XDP,i=_.ZERO_COPY,n=_.JAG_SNAPSHOTS,T=`${Pa("hostname -I | awk '{print $1}'").toString().trim()}:18899`,a=n?[`--public-rpc-address ${T} \\`,"--no-port-check \\"].join(`
5840
+ Active Identity:`),console.log(Ia.white(t)),fa(`solana-keygen pubkey ${p}`,{stdio:"inherit",shell:!0})},"showKeypairsInfo"),s_=E(_=>{let e=g(),t=_.NETWORK===l.TESTNET;return _.NODE_TYPE===A.RPC?{validatorKey:e.mainnetValidatorKey,validatorKeyAddress:k(e.mainnetValidatorKey),validatorKeyBalance:v_(e.mainnetValidatorKey)}:t?{validatorKey:e.testnetValidatorKey,validatorKeyAddress:k(e.testnetValidatorKey),validatorKeyBalance:v_(e.testnetValidatorKey),voteKey:e.testnetValidatorVoteKey,voteKeyAddress:k(e.testnetValidatorVoteKey),voteKeyBalance:v_(e.testnetValidatorVoteKey),authorityKey:e.testnetValidatorAuthorityKey,authorityKeyAddress:k(e.testnetValidatorAuthorityKey),authorityKeyBalance:v_(e.testnetValidatorAuthorityKey)}:{validatorKey:e.mainnetValidatorKey,validatorKeyAddress:k(e.mainnetValidatorKey),validatorKeyBalance:v_(e.mainnetValidatorKey),voteKey:e.mainnetValidatorVoteKey,voteKeyAddress:k(e.mainnetValidatorVoteKey),voteKeyBalance:v_(e.mainnetValidatorVoteKey),authorityKey:e.mainnetValidatorAuthorityKey,authorityKeyAddress:k(e.mainnetValidatorAuthorityKey),authorityKeyBalance:v_(e.mainnetValidatorAuthorityKey)}},"getKeypairsInfo");import{execSync as Pa}from"node:child_process";var Ye=E((_,e="agave-validator")=>{let{validatorKeyAddress:t}=s_(_),o=_.XDP,i=_.ZERO_COPY,n=_.JAG_SNAPSHOTS,T=`${Pa("hostname -I | awk '{print $1}'").toString().trim()}:18899`,a=n?[`--public-rpc-address ${T} \\`,"--no-port-check \\"].join(`
5841
5841
  `):["--full-rpc-api \\","--private-rpc \\"].join(`
5842
5842
  `),c=o?["--experimental-retransmit-xdp-cpu-cores 1 \\","--experimental-poh-pinned-cpu-core 10 \\"].join(`
5843
5843
  `):"",R=i?["--experimental-retransmit-xdp-zero-copy \\"].join(`
@@ -5872,7 +5872,7 @@ ${a}
5872
5872
  --maximum-incremental-snapshots-to-retain 2 \\
5873
5873
  ${c}
5874
5874
  ${R}
5875
- `},"startMainnetValidatorScript");var Je=E(_=>{let{validatorKeyAddress:e}=n_(_),t=_.XDP,o=_.ZERO_COPY,i=t?["--experimental-retransmit-xdp-cpu-cores 1 \\","--experimental-poh-pinned-cpu-core 10 \\"].join(`
5875
+ `},"startMainnetValidatorScript");var Je=E(_=>{let{validatorKeyAddress:e}=s_(_),t=_.XDP,o=_.ZERO_COPY,i=t?["--experimental-retransmit-xdp-cpu-cores 1 \\","--experimental-poh-pinned-cpu-core 10 \\"].join(`
5876
5876
  `):"",n=o?["--experimental-retransmit-xdp-zero-copy \\"].join(`
5877
5877
  `):"",T=re.filter(c=>c!==e).map(c=>`--known-validator ${c} \\`).join(`
5878
5878
  `);return`#!/bin/bash
@@ -5903,7 +5903,7 @@ ${T}
5903
5903
  --maximum-incremental-snapshots-to-retain 2 \\
5904
5904
  ${i}
5905
5905
  ${n}
5906
- `},"startTestnetAgaveValidatorScript");var Gt=E((_=1e4,e,t,o,i,n="agave-validator")=>{let{validatorKeyAddress:s}=n_(i),r=i.XDP,T=i.ZERO_COPY,a=r?["--experimental-retransmit-xdp-cpu-cores 1 \\","--experimental-poh-pinned-cpu-core 10 \\"].join(`
5906
+ `},"startTestnetAgaveValidatorScript");var Gt=E((_=1e4,e,t,o,i,n="agave-validator")=>{let{validatorKeyAddress:s}=s_(i),r=i.XDP,T=i.ZERO_COPY,a=r?["--experimental-retransmit-xdp-cpu-cores 1 \\","--experimental-poh-pinned-cpu-core 10 \\"].join(`
5907
5907
  `):"",c=T?["--experimental-retransmit-xdp-zero-copy \\"].join(`
5908
5908
  `):"",O=re.filter(S=>S!==s).map(S=>`--known-validator ${S} \\`).join(`
5909
5909
  `);return`#!/bin/bash
@@ -5939,7 +5939,7 @@ ${O}
5939
5939
  --expected-genesis-hash 4uhcVJyU9pJkvQyS88uRDiswHXSCkY3zQawwpjk2NsNY \\
5940
5940
  ${a}
5941
5941
  ${c}
5942
- `},"startJitoTestnetScript");var kt=E((_=1e4,e,t,o,i,n,s="agave-validator")=>{let{validatorKeyAddress:r}=n_(n),T=n.XDP,a=n.ZERO_COPY,c=T?["--experimental-retransmit-xdp-cpu-cores 1 \\","--experimental-poh-pinned-cpu-core 10 \\"].join(`
5942
+ `},"startJitoTestnetScript");var kt=E((_=1e4,e,t,o,i,n,s="agave-validator")=>{let{validatorKeyAddress:r}=s_(n),T=n.XDP,a=n.ZERO_COPY,c=T?["--experimental-retransmit-xdp-cpu-cores 1 \\","--experimental-poh-pinned-cpu-core 10 \\"].join(`
5943
5943
  `):"",R=a?["--experimental-retransmit-xdp-zero-copy \\"].join(`
5944
5944
  `):"",N=re.filter(d=>d!==r).map(d=>`--known-validator ${d} \\`).join(`
5945
5945
  `);return`#!/bin/bash
@@ -5976,7 +5976,7 @@ ${N}
5976
5976
  --expected-genesis-hash 4uhcVJyU9pJkvQyS88uRDiswHXSCkY3zQawwpjk2NsNY \\
5977
5977
  ${c}
5978
5978
  ${R}
5979
- `},"startBamTestnetScript");import{writeFile as Xa}from"node:fs/promises";var z_={version:"2.3.10",tag:"v2.3.10",commissionBps:0,relayerUrl:"http://frankfurt.mainnet.relayer.jito.wtf:8100",blockEngineUrl:"https://frankfurt.mainnet.block-engine.jito.wtf",shredReceiverAddr:"64.130.50.14:1002",bamUrl:"http://frankfurt.mainnet.bam.jito.wtf"},xe={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",BAM_URL:"http://dallas.testnet.bam.jito.wtf"},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",BAM_URL:"http://ny.testnet.bam.jito.wtf"},SaltLakeCity:{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",BAM_URL:"http://slc.testnet.bam.jito.wtf"}},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",BAM_URL:"http://amsterdam.mainnet.bam.jito.wtf"},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",BAM_URL:"http://london.mainnet.bam.jito.wtf"},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",BAM_URL:"http://frankfurt.mainnet.bam.jito.wtf"},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",BAM_URL:"http://ny.mainnet.bam.jito.wtf"},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",BAM_URL:"http://tokyo.mainnet.bam.jito.wtf"},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",BAM_URL:"http://slc.mainnet.bam.jito.wtf"},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",BAM_URL:"http://singapore.mainnet.bam.jito.wtf"},Dublin:{BLOCK_ENGINE_URL:"https://dublin.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://dublin.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"64.130.61.8:1002",BAM_URL:""}}};import{existsAsync as Aa}from"@skeet-framework/utils";import{readFile as Ua,writeFile as Li}from"fs/promises";import{homedir as ua}from"os";import pa from"path";var q=E(async()=>{let _=ua(),e=pa.join(_,D_.JITO_CONFIG);await Aa(e)||(await Li(e,JSON.stringify(z_,null,2)),console.log(`Created jito config file at ${e}`));let t;try{t=JSON.parse(await Ua(e,"utf-8"))}catch(o){console.log(`readOrCreateJitoConfig - ${o}`),await Li(e,JSON.stringify(z_,null,2)),t=z_}return t},"readOrCreateJitoConfig");import{execSync as ma}from"node:child_process";var Vt=E((_=0,e,t,o,i,n="agave-validator")=>{let{validatorKeyAddress:s}=n_(i),r=i.XDP,T=i.ZERO_COPY,a=i.JAG_SNAPSHOTS,C=`${ma("hostname -I | awk '{print $1}'").toString().trim()}:18899`,O=a?[`--public-rpc-address ${C} \\`,"--no-port-check \\"].join(`
5979
+ `},"startBamTestnetScript");import{writeFile as Xa}from"node:fs/promises";var z_={version:"2.3.10",tag:"v2.3.10",commissionBps:0,relayerUrl:"http://frankfurt.mainnet.relayer.jito.wtf:8100",blockEngineUrl:"https://frankfurt.mainnet.block-engine.jito.wtf",shredReceiverAddr:"64.130.50.14:1002",bamUrl:"http://frankfurt.mainnet.bam.jito.wtf"},xe={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",BAM_URL:"http://dallas.testnet.bam.jito.wtf"},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",BAM_URL:"http://ny.testnet.bam.jito.wtf"},SaltLakeCity:{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",BAM_URL:"http://slc.testnet.bam.jito.wtf"}},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",BAM_URL:"http://amsterdam.mainnet.bam.jito.wtf"},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",BAM_URL:"http://london.mainnet.bam.jito.wtf"},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",BAM_URL:"http://frankfurt.mainnet.bam.jito.wtf"},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",BAM_URL:"http://ny.mainnet.bam.jito.wtf"},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",BAM_URL:"http://tokyo.mainnet.bam.jito.wtf"},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",BAM_URL:"http://slc.mainnet.bam.jito.wtf"},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",BAM_URL:"http://singapore.mainnet.bam.jito.wtf"},Dublin:{BLOCK_ENGINE_URL:"https://dublin.mainnet.block-engine.jito.wtf",RELAYER_URL:"http://dublin.mainnet.relayer.jito.wtf:8100",SHRED_RECEIVER_ADDR:"64.130.61.8:1002",BAM_URL:""}}};import{existsAsync as Aa}from"@skeet-framework/utils";import{readFile as Ua,writeFile as Li}from"fs/promises";import{homedir as ua}from"os";import pa from"path";var q=E(async()=>{let _=ua(),e=pa.join(_,D_.JITO_CONFIG);await Aa(e)||(await Li(e,JSON.stringify(z_,null,2)),console.log(`Created jito config file at ${e}`));let t;try{t=JSON.parse(await Ua(e,"utf-8"))}catch(o){console.log(`readOrCreateJitoConfig - ${o}`),await Li(e,JSON.stringify(z_,null,2)),t=z_}return t},"readOrCreateJitoConfig");import{execSync as ma}from"node:child_process";var Vt=E((_=0,e,t,o,i,n="agave-validator")=>{let{validatorKeyAddress:s}=s_(i),r=i.XDP,T=i.ZERO_COPY,a=i.JAG_SNAPSHOTS,C=`${ma("hostname -I | awk '{print $1}'").toString().trim()}:18899`,O=a?[`--public-rpc-address ${C} \\`,"--no-port-check \\"].join(`
5980
5980
  `):["--full-rpc-api \\","--private-rpc \\"].join(`
5981
5981
  `),N=r?["--experimental-retransmit-xdp-cpu-cores 1 \\","--experimental-poh-pinned-cpu-core 10 \\"].join(`
5982
5982
  `):"",S=T?["--experimental-retransmit-xdp-zero-copy \\"].join(`
@@ -6016,7 +6016,7 @@ ${O}
6016
6016
  --maximum-incremental-snapshots-to-retain 2 \\
6017
6017
  ${N}
6018
6018
  ${S}
6019
- `},"startJitoMainnetScript");import{execSync as Ma}from"node:child_process";var bt=E((_=0,e,t,o,i,n,s="agave-validator")=>{let{validatorKeyAddress:r}=n_(n),c=`${Ma("hostname -I | awk '{print $1}'").toString().trim()}:18899`,R=n.XDP,C=n.ZERO_COPY,O=n.JAG_SNAPSHOTS,N=R?["--experimental-retransmit-xdp-cpu-cores 1 \\","--experimental-poh-pinned-cpu-core 10 \\"].join(`
6019
+ `},"startJitoMainnetScript");import{execSync as Ma}from"node:child_process";var bt=E((_=0,e,t,o,i,n,s="agave-validator")=>{let{validatorKeyAddress:r}=s_(n),c=`${Ma("hostname -I | awk '{print $1}'").toString().trim()}:18899`,R=n.XDP,C=n.ZERO_COPY,O=n.JAG_SNAPSHOTS,N=R?["--experimental-retransmit-xdp-cpu-cores 1 \\","--experimental-poh-pinned-cpu-core 10 \\"].join(`
6020
6020
  `):"",S=O?[`--public-rpc-address ${c} \\`,"--no-port-check \\"].join(`
6021
6021
  `):["--full-rpc-api \\","--private-rpc \\"].join(`
6022
6022
  `),d=C?["--experimental-retransmit-xdp-zero-copy \\"].join(`
@@ -6057,7 +6057,7 @@ ${S}
6057
6057
  --maximum-incremental-snapshots-to-retain 2 \\
6058
6058
  ${N}
6059
6059
  ${d}
6060
- `},"startBamMainnetScript");import{spawnSync as La}from"node:child_process";var ha=E(()=>{let _=`sudo chmod +x ${N_}`;La(_,{shell:!0,stdio:"inherit"})},"updateStartupScriptPermission"),Z_=ha;import{spawnSync as ya}from"child_process";var wE=E((_=t_.USERNAME,e)=>{let{log:t}=w_(),o=e?"frankendancer":"agave",i=`${t} {
6060
+ `},"startBamMainnetScript");import{spawnSync as La}from"node:child_process";var ha=E(()=>{let _=`sudo chmod +x ${N_}`;La(_,{shell:!0,stdio:"inherit"})},"updateStartupScriptPermission"),Z_=ha;import{spawnSync as ya}from"child_process";var wE=E((_=E_.USERNAME,e)=>{let{log:t}=w_(),o=e?"frankendancer":"agave",i=`${t} {
6061
6061
  su ${_} ${_}
6062
6062
  daily
6063
6063
  rotate 1
@@ -6089,7 +6089,7 @@ ${d}
6089
6089
  compress
6090
6090
  copytruncate
6091
6091
  }
6092
- `),i)},"logRotates");import{existsSync as wt}from"fs";import{execSync as hi}from"child_process";function Ce(_=!1){if(console.log("Creating logrotate configuration for solana"),!_&&wt(L.SOL_LOGROTATE)&&console.log("SOL_LOGROTATE_PATH already exists. Skipping logrotate configuration."),!_&&!wt(L.SOL_LOGROTATE)){let e=wE("solv",_);hi(`echo "${e}" | sudo tee ${L.SOL_LOGROTATE} > /dev/null`),console.log("Logrotate configuration created.")}if(_&&!wt(L.FRANKENDANCER_LOGROTATE)){let e=wE("solv",_);hi(`echo "${e}" | sudo tee ${L.FRANKENDANCER_LOGROTATE} > /dev/null`),console.log("Logrotate configuration created.")}_&&wt(L.FRANKENDANCER_LOGROTATE)&&console.log("FRANKENDANCER_LOGROTATE already exists. Skipping logrotate configuration.")}E(Ce,"setupLogrotate");import{spawnSync as ga}from"child_process";var vt=E(()=>{ga("sudo rm -rf /home/solv/solana-validator.log.*",{shell:!0,stdio:"inherit"})},"rmLogs");import{spawnSync as Ba}from"child_process";var gi=E(()=>{Ba("sudo systemctl restart logrotate",{shell:!0,stdio:"inherit"})},"restartLogrotate");var Qe=E(_=>{vt();let e=`sudo rm -rf ${L.SOL_LOGROTATE} && sudo rm -rf ${L.FRANKENDANCER_LOGROTATE}`;ya(e,{shell:!0,stdio:"inherit"}),Ce(_),gi()},"updateLogrotate");import{spawnSync as Ka}from"child_process";var Bi=E(()=>{Ka("sudo systemctl restart frankendancer",{shell:!0,stdio:"inherit"})},"restartFiredancer");import{execAsync as s_}from"@skeet-framework/utils";import Ga from"chalk";var vE=E(async()=>{await s_('echo "yes" | sudo ufw restart'),await s_('echo "yes" | sudo ufw enable'),await s_("sudo ufw allow ssh"),await s_("sudo ufw allow 53"),await s_("sudo ufw allow 8899/udp"),await s_("sudo ufw allow 8899/tcp"),await s_("sudo ufw allow 8000:8898/udp"),await s_("sudo ufw allow 8000:8898/tcp"),await s_("sudo ufw allow 8900:10000/tcp"),await s_("sudo ufw allow 8900:10000/udp"),await s_("sudo ufw allow 179/tcp"),await s_("sudo ufw allow 9600/tcp"),await s_("sudo ufw reload"),console.log(Ga.white("\u2714\uFE0F Firewall updated!"))},"syncFirewall");import{spawnSync as ka}from"node:child_process";var de=E(()=>{ka("sudo systemctl enable solv",{shell:!0,stdio:"inherit"})},"enableSolv");var Va="SOLANA_METRICS_CONFIG=host=https://metrics.solana.com:8086,db=mainnet-beta,u=mainnet-beta_write,p=password",ba="SOLANA_METRICS_CONFIG=host=https://metrics.solana.com:8086,db=tds,u=testnet_write,p=c4fa841aa918bf8274e3e2a44d77568d9861b3ea",wa=`/home/${t_.USERNAME}/.local/share/solana/install/active_release/bin`,yi=E((_=!0)=>{let{scriptPath:e}=w_(_),t=_?ba:Va,o=wa;return`[Unit]
6092
+ `),i)},"logRotates");import{existsSync as wt}from"fs";import{execSync as hi}from"child_process";function Ce(_=!1){if(console.log("Creating logrotate configuration for solana"),!_&&wt(L.SOL_LOGROTATE)&&console.log("SOL_LOGROTATE_PATH already exists. Skipping logrotate configuration."),!_&&!wt(L.SOL_LOGROTATE)){let e=wE("solv",_);hi(`echo "${e}" | sudo tee ${L.SOL_LOGROTATE} > /dev/null`),console.log("Logrotate configuration created.")}if(_&&!wt(L.FRANKENDANCER_LOGROTATE)){let e=wE("solv",_);hi(`echo "${e}" | sudo tee ${L.FRANKENDANCER_LOGROTATE} > /dev/null`),console.log("Logrotate configuration created.")}_&&wt(L.FRANKENDANCER_LOGROTATE)&&console.log("FRANKENDANCER_LOGROTATE already exists. Skipping logrotate configuration.")}E(Ce,"setupLogrotate");import{spawnSync as ga}from"child_process";var vt=E(()=>{ga("sudo rm -rf /home/solv/solana-validator.log.*",{shell:!0,stdio:"inherit"})},"rmLogs");import{spawnSync as Ba}from"child_process";var gi=E(()=>{Ba("sudo systemctl restart logrotate",{shell:!0,stdio:"inherit"})},"restartLogrotate");var Qe=E(_=>{vt();let e=`sudo rm -rf ${L.SOL_LOGROTATE} && sudo rm -rf ${L.FRANKENDANCER_LOGROTATE}`;ya(e,{shell:!0,stdio:"inherit"}),Ce(_),gi()},"updateLogrotate");import{spawnSync as Ka}from"child_process";var Bi=E(()=>{Ka("sudo systemctl restart frankendancer",{shell:!0,stdio:"inherit"})},"restartFiredancer");import{execAsync as r_}from"@skeet-framework/utils";import Ga from"chalk";var vE=E(async()=>{await r_('echo "yes" | sudo ufw restart'),await r_('echo "yes" | sudo ufw enable'),await r_("sudo ufw allow ssh"),await r_("sudo ufw allow 53"),await r_("sudo ufw allow 8899/udp"),await r_("sudo ufw allow 8899/tcp"),await r_("sudo ufw allow 8000:8898/udp"),await r_("sudo ufw allow 8000:8898/tcp"),await r_("sudo ufw allow 8900:10000/tcp"),await r_("sudo ufw allow 8900:10000/udp"),await r_("sudo ufw allow 179/tcp"),await r_("sudo ufw allow 9600/tcp"),await r_("sudo ufw reload"),console.log(Ga.white("\u2714\uFE0F Firewall updated!"))},"syncFirewall");import{spawnSync as ka}from"node:child_process";var de=E(()=>{ka("sudo systemctl enable solv",{shell:!0,stdio:"inherit"})},"enableSolv");var Va="SOLANA_METRICS_CONFIG=host=https://metrics.solana.com:8086,db=mainnet-beta,u=mainnet-beta_write,p=password",ba="SOLANA_METRICS_CONFIG=host=https://metrics.solana.com:8086,db=tds,u=testnet_write,p=c4fa841aa918bf8274e3e2a44d77568d9861b3ea",wa=`/home/${E_.USERNAME}/.local/share/solana/install/active_release/bin`,yi=E((_=!0)=>{let{scriptPath:e}=w_(_),t=_?ba:Va,o=wa;return`[Unit]
6093
6093
  Description=Solana Validator
6094
6094
  After=network.target
6095
6095
  StartLimitIntervalSec=0
@@ -6104,7 +6104,7 @@ RestartSec=1
6104
6104
  LimitNOFILE=1048576
6105
6105
  LimitMEMLOCK=infinity
6106
6106
  LogRateLimitIntervalSec=0
6107
- User=${t_.USERNAME}
6107
+ User=${E_.USERNAME}
6108
6108
  Environment=PATH=${o}
6109
6109
  WorkingDirectory=${v.ROOT}
6110
6110
  Environment="${t}"
@@ -6128,7 +6128,7 @@ Persistent=true
6128
6128
 
6129
6129
  [Install]
6130
6130
  WantedBy=timers.target
6131
- `}),"jagsnapTimer"),Vi=$a;var qa=E(_=>{let{filePath:e,body:t}=ki(_),{filePath:o,body:i}=Vi(_);bi(`echo "${t}" | sudo tee ${e} > /dev/null`),bi(`echo "${i}" | sudo tee ${o} > /dev/null`),H_("git clone https://github.com/gabrielhicks/jag-snap.git /home/solv/jag-snap",{shell:!0,stdio:"inherit"}),H_("cd /home/solv/jag-snap",{shell:!0,stdio:"inherit"}),H_("sudo apt install ipset iptables -y",{shell:!0,stdio:"inherit"}),H_("sudo iptables -A INPUT -p tcp --dport 18899 -j ACCEPT",{shell:!0,stdio:"inherit"}),H_("sudo iptables -A INPUT -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT",{shell:!0,stdio:"inherit"}),H_("sudo ufw allow 18899/tcp",{shell:!0,stdio:"inherit"}),H_("sudo ufw reload",{shell:!0,stdio:"inherit"}),H_("cd /home/solv/jag-snap && docker build -t jag-snap . && docker run -d --name jag-snap --network host jag-snap",{shell:!0,stdio:"inherit"})},"installJagSnap"),wi=qa;import{spawnSync as T_}from"node:child_process";var Wa=E((_,e)=>{e?(T_("sudo apt update -y",{shell:!0,stdio:"inherit"}),T_(`sudo apt install --upgrade-only doublezero=${_} -y`,{shell:!0,stdio:"inherit"}),T_("sudo apt update -y",{shell:!0,stdio:"inherit"}),T_("sudo apt install doublezero-solana -y",{shell:!0,stdio:"inherit"}),T_("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}),T_("sudo systemctl restart doublezerod",{shell:!0,stdio:"inherit"})):(T_("sudo apt update -y",{shell:!0,stdio:"inherit"}),T_(`sudo apt install --upgrade-only doublezero=${_} -y`,{shell:!0,stdio:"inherit"}),T_("sudo apt update -y",{shell:!0,stdio:"inherit"}),T_("sudo apt install doublezero-solana -y",{shell:!0,stdio:"inherit"}),T_("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}),T_("sudo systemctl restart doublezerod",{shell:!0,stdio:"inherit"}))},"updateDZ"),HE=Wa;var vi=E(_=>{let e=_.NETWORK===l.TESTNET,t=_.NODE_TYPE===A.RPC,o=_.VALIDATOR_TYPE===F.JITO,i=_.VALIDATOR_TYPE===F.BAM,n=_.VALIDATOR_TYPE===F.FRANKENDANCER,s=_.AUTO_RESTART,r=_.MOD,T=_.XDP,a=10;s&&!e&&(a=30);let c=e?c_:e_,R=e?Ve:be;o&&(c=k_,e&&(c=Te)),i&&(c=ae,e&&(c=It)),n&&(c=V_,e&&(c=Se)),t&&(c=X_,o&&(c=Go)),I.command("update").alias("u").description("Update Command").option("-v, --version <version>",`Solana Version e.g ${c}`,c).option("-b, --background","No Monitor Delinquent Stake Update",!1).option("-c, --commission","Update Commission",!1).option("-f, --firewall","Update Firewall",!1).option("--migrate-config","Migrate Solv Config",!1).option("--config","Update Solv Config Default Solana Version",!1).option("--configOnce","Update Solv Config ONCE",!1).option("--auto","Auto Update",!1).option("--mod","Modified Versions",!1).option("--startup","Start up Script",!1).option("--service","SystemD Service",!1).option("-j, --jagsnap","JagSnaps Service",!1).option("-z, --dz","Doublezero Service",!1).action(async C=>{let O=ce(),N=e?_.TESTNET_DELINQUENT_STAKE:_.MAINNET_DELINQUENT_STAKE;if(console.log(YE.white(`Current solv version: ${O}`)),C.auto){await Ci(_);return}if(C.service&&(await vE(),Qe(n),$e(e)),C.migrateConfig){let S=Ai().config,d=o_.TRIPLE;S.DISK_TYPES===0?d=o_.DOUBLE:S.DISK_TYPES===1?d=o_.SINGLE:d=o_.TRIPLE;let P=S.SOLANA_NETWORK===b_.TESTNET,f=S.SOLV_TYPE===Dt.RPC_NODE,D=S.MAINNET_TYPE===Pt.JITO_MEV,U={NETWORK:P?l.TESTNET:l.MAINNET,NODE_TYPE:f?A.RPC:A.VALIDATOR,MNT_DISK_TYPE:d,RPC_TYPE:f?Q.JITO:Q.NONE,VALIDATOR_TYPE:D?F.JITO:P?F.AGAVE:F.SOLANA,TESTNET_SOLANA_VERSION:S.TESTNET_SOLANA_VERSION,MAINNET_SOLANA_VERSION:S.MAINNET_SOLANA_VERSION,NODE_VERSION:S.NODE_VERSION,TESTNET_DELINQUENT_STAKE:S.TESTNET_DELINQUENT_STAKE,MAINNET_DELINQUENT_STAKE:S.MAINNET_DELINQUENT_STAKE,COMMISSION:S.COMMISSION,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:S.DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY,STAKE_ACCOUNTS:S.STAKE_ACCOUNT,HARVEST_ACCOUNT:S.HARVEST_ACCOUNT,IS_MEV_MODE:S.IS_MEV_MODE,RPC_URL:S.RPC_URL,KEYPAIR_PATH:S.KEYPAIR_PATH,DISCORD_WEBHOOK_URL:S.DISCORD_WEBHOOK_URL,AUTO_UPDATE:S.AUTO_UPDATE,AUTO_RESTART:S.AUTO_RESTART,IS_DUMMY:!1,API_KEY:"",LEDGER_PATH:S.LEDGER_PATH,ACCOUNTS_PATH:"/mnt/accounts",SNAPSHOTS_PATH:"/mnt/snapshots",MOD:!1,XDP:!1,ZERO_COPY:!1,JAG_SNAPSHOTS:!1,JAG_REGION:"",CHRONY_LOCATION:"",MEV_COMMISSION:0};await B(U)}if(C.configOnce){if(await B({TESTNET_SOLANA_VERSION:c_,MAINNET_SOLANA_VERSION:e_,MOD:!1,XDP:!1,ZERO_COPY:!1,JAG_SNAPSHOTS:!1,JAG_REGION:"",CHRONY_LOCATION:"",MEV_COMMISSION:0}),o){let S=e?Te:k_;await m_({version:S,tag:`v${S}`,commissionBps:_.MEV_COMMISSION})}if(i){let S=e?It:ae;await m_({version:S,tag:`v${S}`,commissionBps:_.MEV_COMMISSION})}console.log(YE.green("\u2714\uFE0F Updated Solv Config Default Solana Version\n\n You can now run `solv i` to install the latest version"));return}if(C.config){if(await B({TESTNET_SOLANA_VERSION:c_,MAINNET_SOLANA_VERSION:e_}),o){let S=e?Te:k_;await m_({version:S,tag:`v${S}`,commissionBps:_.MEV_COMMISSION})}if(i){let S=e?It:ae;await m_({version:S,tag:`v${S}`,commissionBps:_.MEV_COMMISSION})}console.log(YE.green("\u2714\uFE0F Updated Solv Config Default Solana Version\n\n You can now run `solv i` to install the latest version"));return}if(C.firewall){await si();return}if(C.startup){let S=_.VALIDATOR_TYPE,d="";switch(S){case F.SOLANA:d=e?ui():Ye(_);break;case F.AGAVE:d=e?Je(_):Ye(_);break;case F.JITO:let P=await q();d=e?Gt(P.commissionBps,P.relayerUrl,P.blockEngineUrl,P.shredReceiverAddr,_):Vt(P.commissionBps,P.relayerUrl,P.blockEngineUrl,P.shredReceiverAddr,_);break;case F.BAM:let f=await q();d=e?kt(f.commissionBps,f.relayerUrl,f.blockEngineUrl,f.shredReceiverAddr,f.bamUrl,_):bt(f.commissionBps,f.relayerUrl,f.blockEngineUrl,f.shredReceiverAddr,f.bamUrl,_);break;default:console.log("Unknown Validator Type for Update Script");break}await Xa(N_,d,"utf-8"),Z_();return}if(C.jagsnap){let S=_.JAG_REGION;wi(S)}if(C.background){let S=C.version,d=e?Ve:be,P=!!S.startsWith("3");if(await B({TESTNET_SOLANA_VERSION:c_,MAINNET_SOLANA_VERSION:e_}),e&&await vE(),Qe(n),$e(e),HE(d,e),o){let D=p_,U=`v${S}-jito`,M=`v${S}-mod`,V=C.mod||r?`${M}${D}`:`${U}${D}`;ut(V,C.mod||r,P,T),await m_({version:S,tag:`v${S}`}),await we(N,!0,a),le(),Yt(),de(),Ht();return}if(i){let D=W_,U=`v${S}-bam`,M=`v${S}-mod`,V=C.mod||r?`${M}${D}`:`${U}${D}`;Kt(V,C.mod||r,P,T),await m_({version:S,tag:`v${S}`}),await we(N,!0,a),le(),Yt(),de(),Ht();return}if(n){await yt(_,S,C.mod||r),await we(N,!0,a),Jt(),Gi(),Bi();return}await ft(S),await we(e?10:5,!0,a),le(),Yt(),de(),Ht();return}else if(C.commission){let S=await ni();ii(S.commission,e)}else Ei();C.dz&&HE(R,e)})},"updateCommands");import{spawnSync as ja}from"node:child_process";var Hi=E(_=>{try{let{log:e}=w_(),t=`tail -f ${e}`;_.error?t+=" | grep '\\(WARN\\|ERR\\)'":_.info?t+=" | grep INFO":_.warning&&(t+=" | grep WARN"),console.log(t);let o=ja(t,{shell:!0,stdio:"inherit"});if(o.error)throw o.error;o.signal==="SIGINT"?(console.log("Child process terminated due to receipt of SIGINT signal"),process.exit(0)):o.status!==0&&(console.error(`Child process exited with code ${o.status}`),process.exit(o.status))}catch(e){console.error(`tail Error: ${e}`),process.exit(1)}},"tail");var Yi=E(()=>{I.command("log").description("tail logs").alias("l").description("tail logs").option("-i, --info","Follow INFO output",!1).option("-w, --warning","Follow WARN output",!1).option("-e, --error","Follow ERR/WARN output",!1).option("-a, --all","Follow All output",!1).action(_=>{Hi(_)})},"logCommands");import L_ from"chalk";import{spawnSync as za}from"child_process";import{homedir as Za}from"os";var xt=E(_=>{let e=Za(),t=g(e),o=t.testnetValidatorVoteKey,i=t.testnetValidatorKey,n=t.testnetValidatorAuthorityKey,s=b_.TESTNET,r=_.COMMISSION;_.NETWORK===l.MAINNET&&(o=t.mainnetValidatorVoteKey,i=t.mainnetValidatorKey,n=t.mainnetValidatorAuthorityKey,s=b_.MAINNET),console.log(`\u231B\uFE0F Creating vote account with commission ${r} - ${s}`);let T=_.RPC_URL||s;_.NETWORK===l.TESTNET&&(T=b_.TESTNET);let a=`solana create-vote-account ${o} ${i} ${n} --commission ${r} --url ${T} --keypair ${i}`;za(a,{shell:!0,stdio:"inherit"})},"setupVoteAccount");import{spawnSync as Qt}from"child_process";import{existsSync as Ji,readdirSync as _S,rmSync as eS}from"fs";import{homedir as tS}from"os";import xi from"path";var $t=E(_=>{let e=[],t=0;_.NODE_TYPE===A.RPC&&(e=[h.MAINNET_VALIDATOR_KEY],t=1),_.NETWORK===l.TESTNET?(e=[h.TESTNET_VALIDATOR_KEY,h.TESTNET_VALITATOR_AUTHORITY_KEY,h.TESTNET_VALIDATOR_VOTE_KEY,h.MAINNET_VALIDATOR_KEY,h.MAINNET_VALITATOR_AUTHORITY_KEY,h.MAINNET_VALIDATOR_VOTE_KEY],t=6):(e=[h.MAINNET_VALIDATOR_KEY,h.MAINNET_VALITATOR_AUTHORITY_KEY,h.MAINNET_VALIDATOR_VOTE_KEY],t=3);let o=`solana-keygen grind --starts-and-ends-with E:SV:${t}`;Qt(o,{shell:!0,stdio:"ignore"});let i=_S("./").filter(T=>T.endsWith("SV.json")),n=tS(),s=xi.join(n,"unstaked-identity.json");Ji(s)&&Qt(`mv ${s} ${n}/unstaked-identity.backup.json`,{shell:!0,stdio:"ignore"});let r=0;for(let T of i){let a=xi.join(n,e[r]);if(r++,Ji(a)){console.log(`${a} is already exist!`),eS(T,{recursive:!0});continue}let c=`mv ${T} ${a}`;Qt(c,{shell:!0,stdio:"inherit"})}Qt("solana-keygen new -s --no-bip39-passphrase -o /home/solv/unstaked-identity.json",{shell:!0,stdio:"ignore"}),console.log(`Generated keypairs - ${n}`)},"createSolvKeyPairs");import{spawnSync as $i}from"child_process";var ES=E((_,e,t,o=2001)=>{let i="/etc/systemd/system/jupiter-api.service",n=`[Unit]
6131
+ `}),"jagsnapTimer"),Vi=$a;var qa=E(_=>{let{filePath:e,body:t}=ki(_),{filePath:o,body:i}=Vi(_);bi(`echo "${t}" | sudo tee ${e} > /dev/null`),bi(`echo "${i}" | sudo tee ${o} > /dev/null`),H_("git clone https://github.com/gabrielhicks/jag-snap.git /home/solv/jag-snap",{shell:!0,stdio:"inherit"}),H_("cd /home/solv/jag-snap",{shell:!0,stdio:"inherit"}),H_("sudo apt install ipset iptables -y",{shell:!0,stdio:"inherit"}),H_("sudo iptables -A INPUT -p tcp --dport 18899 -j ACCEPT",{shell:!0,stdio:"inherit"}),H_("sudo iptables -A INPUT -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT",{shell:!0,stdio:"inherit"}),H_("sudo ufw allow 18899/tcp",{shell:!0,stdio:"inherit"}),H_("sudo ufw reload",{shell:!0,stdio:"inherit"}),H_("cd /home/solv/jag-snap && docker build -t jag-snap . && docker run -d --name jag-snap --network host jag-snap",{shell:!0,stdio:"inherit"})},"installJagSnap"),wi=qa;import{spawnSync as W}from"node:child_process";var Wa=E((_,e)=>{e?(W("curl -1sLf https://dl.cloudsmith.io/public/malbeclabs/doublezero-testnet/setup.deb.sh | sudo -E bash",{shell:!0,stdio:"inherit"}),W("sudo apt-get install doublezero",{shell:!0,stdio:"inherit"}),W("sudo apt update -y",{shell:!0,stdio:"inherit"}),W(`sudo apt install doublezero=${_} -y`,{shell:!0,stdio:"inherit"}),W("sudo apt update -y",{shell:!0,stdio:"inherit"}),W("sudo apt install doublezero-solana -y",{shell:!0,stdio:"inherit"}),W("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}),W("sudo systemctl restart doublezerod",{shell:!0,stdio:"inherit"})):(W("sudo apt update -y",{shell:!0,stdio:"inherit"}),W(`sudo apt install --upgrade-only doublezero=${_} -y`,{shell:!0,stdio:"inherit"}),W("sudo apt update -y",{shell:!0,stdio:"inherit"}),W("sudo apt install doublezero-solana -y",{shell:!0,stdio:"inherit"}),W("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}),W("sudo systemctl restart doublezerod",{shell:!0,stdio:"inherit"}))},"updateDZ"),HE=Wa;var vi=E(_=>{let e=_.NETWORK===l.TESTNET,t=_.NODE_TYPE===A.RPC,o=_.VALIDATOR_TYPE===F.JITO,i=_.VALIDATOR_TYPE===F.BAM,n=_.VALIDATOR_TYPE===F.FRANKENDANCER,s=_.AUTO_RESTART,r=_.MOD,T=_.XDP,a=10;s&&!e&&(a=30);let c=e?c_:t_,R=e?Ve:be;o&&(c=k_,e&&(c=Te)),i&&(c=ae,e&&(c=It)),n&&(c=V_,e&&(c=Se)),t&&(c=X_,o&&(c=Go)),I.command("update").alias("u").description("Update Command").option("-v, --version <version>",`Solana Version e.g ${c}`,c).option("-b, --background","No Monitor Delinquent Stake Update",!1).option("-c, --commission","Update Commission",!1).option("-f, --firewall","Update Firewall",!1).option("--migrate-config","Migrate Solv Config",!1).option("--config","Update Solv Config Default Solana Version",!1).option("--configOnce","Update Solv Config ONCE",!1).option("--auto","Auto Update",!1).option("--mod","Modified Versions",!1).option("--startup","Start up Script",!1).option("--service","SystemD Service",!1).option("-j, --jagsnap","JagSnaps Service",!1).option("-z, --dz","Doublezero Service",!1).action(async C=>{let O=ce(),N=e?_.TESTNET_DELINQUENT_STAKE:_.MAINNET_DELINQUENT_STAKE;if(console.log(YE.white(`Current solv version: ${O}`)),C.auto){await Ci(_);return}if(C.service&&(await vE(),Qe(n),$e(e)),C.migrateConfig){let S=Ai().config,d=i_.TRIPLE;S.DISK_TYPES===0?d=i_.DOUBLE:S.DISK_TYPES===1?d=i_.SINGLE:d=i_.TRIPLE;let P=S.SOLANA_NETWORK===b_.TESTNET,f=S.SOLV_TYPE===Dt.RPC_NODE,D=S.MAINNET_TYPE===Pt.JITO_MEV,U={NETWORK:P?l.TESTNET:l.MAINNET,NODE_TYPE:f?A.RPC:A.VALIDATOR,MNT_DISK_TYPE:d,RPC_TYPE:f?Q.JITO:Q.NONE,VALIDATOR_TYPE:D?F.JITO:P?F.AGAVE:F.SOLANA,TESTNET_SOLANA_VERSION:S.TESTNET_SOLANA_VERSION,MAINNET_SOLANA_VERSION:S.MAINNET_SOLANA_VERSION,NODE_VERSION:S.NODE_VERSION,TESTNET_DELINQUENT_STAKE:S.TESTNET_DELINQUENT_STAKE,MAINNET_DELINQUENT_STAKE:S.MAINNET_DELINQUENT_STAKE,COMMISSION:S.COMMISSION,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:S.DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY,STAKE_ACCOUNTS:S.STAKE_ACCOUNT,HARVEST_ACCOUNT:S.HARVEST_ACCOUNT,IS_MEV_MODE:S.IS_MEV_MODE,RPC_URL:S.RPC_URL,KEYPAIR_PATH:S.KEYPAIR_PATH,DISCORD_WEBHOOK_URL:S.DISCORD_WEBHOOK_URL,AUTO_UPDATE:S.AUTO_UPDATE,AUTO_RESTART:S.AUTO_RESTART,IS_DUMMY:!1,API_KEY:"",LEDGER_PATH:S.LEDGER_PATH,ACCOUNTS_PATH:"/mnt/accounts",SNAPSHOTS_PATH:"/mnt/snapshots",MOD:!1,XDP:!1,ZERO_COPY:!1,JAG_SNAPSHOTS:!1,JAG_REGION:"",CHRONY_LOCATION:"",MEV_COMMISSION:0};await B(U)}if(C.configOnce){if(await B({TESTNET_SOLANA_VERSION:c_,MAINNET_SOLANA_VERSION:t_,MOD:!1,XDP:!1,ZERO_COPY:!1,JAG_SNAPSHOTS:!1,JAG_REGION:"",CHRONY_LOCATION:"",MEV_COMMISSION:0}),o){let S=e?Te:k_;await m_({version:S,tag:`v${S}`,commissionBps:_.MEV_COMMISSION})}if(i){let S=e?It:ae;await m_({version:S,tag:`v${S}`,commissionBps:_.MEV_COMMISSION})}console.log(YE.green("\u2714\uFE0F Updated Solv Config Default Solana Version\n\n You can now run `solv i` to install the latest version"));return}if(C.config){if(await B({TESTNET_SOLANA_VERSION:c_,MAINNET_SOLANA_VERSION:t_}),o){let S=e?Te:k_;await m_({version:S,tag:`v${S}`,commissionBps:_.MEV_COMMISSION})}if(i){let S=e?It:ae;await m_({version:S,tag:`v${S}`,commissionBps:_.MEV_COMMISSION})}console.log(YE.green("\u2714\uFE0F Updated Solv Config Default Solana Version\n\n You can now run `solv i` to install the latest version"));return}if(C.firewall){await si();return}if(C.startup){let S=_.VALIDATOR_TYPE,d="";switch(S){case F.SOLANA:d=e?ui():Ye(_);break;case F.AGAVE:d=e?Je(_):Ye(_);break;case F.JITO:let P=await q();d=e?Gt(P.commissionBps,P.relayerUrl,P.blockEngineUrl,P.shredReceiverAddr,_):Vt(P.commissionBps,P.relayerUrl,P.blockEngineUrl,P.shredReceiverAddr,_);break;case F.BAM:let f=await q();d=e?kt(f.commissionBps,f.relayerUrl,f.blockEngineUrl,f.shredReceiverAddr,f.bamUrl,_):bt(f.commissionBps,f.relayerUrl,f.blockEngineUrl,f.shredReceiverAddr,f.bamUrl,_);break;default:console.log("Unknown Validator Type for Update Script");break}await Xa(N_,d,"utf-8"),Z_();return}if(C.jagsnap){let S=_.JAG_REGION;wi(S)}if(C.background){let S=C.version,d=e?Ve:be,P=!!S.startsWith("3");if(await B({TESTNET_SOLANA_VERSION:c_,MAINNET_SOLANA_VERSION:t_}),e&&await vE(),Qe(n),$e(e),HE(d,e),o){let D=p_,U=`v${S}-jito`,M=`v${S}-mod`,V=C.mod||r?`${M}${D}`:`${U}${D}`;ut(V,C.mod||r,P,T),await m_({version:S,tag:`v${S}`}),await we(N,!0,a),le(),Yt(),de(),Ht();return}if(i){let D=W_,U=`v${S}-bam`,M=`v${S}-mod`,V=C.mod||r?`${M}${D}`:`${U}${D}`;Kt(V,C.mod||r,P,T),await m_({version:S,tag:`v${S}`}),await we(N,!0,a),le(),Yt(),de(),Ht();return}if(n){await yt(_,S,C.mod||r),await we(N,!0,a),Jt(),Gi(),Bi();return}await ft(S),await we(e?10:5,!0,a),le(),Yt(),de(),Ht();return}else if(C.commission){let S=await ni();ii(S.commission,e)}else Ei();C.dz&&HE(R,e)})},"updateCommands");import{spawnSync as ja}from"node:child_process";var Hi=E(_=>{try{let{log:e}=w_(),t=`tail -f ${e}`;_.error?t+=" | grep '\\(WARN\\|ERR\\)'":_.info?t+=" | grep INFO":_.warning&&(t+=" | grep WARN"),console.log(t);let o=ja(t,{shell:!0,stdio:"inherit"});if(o.error)throw o.error;o.signal==="SIGINT"?(console.log("Child process terminated due to receipt of SIGINT signal"),process.exit(0)):o.status!==0&&(console.error(`Child process exited with code ${o.status}`),process.exit(o.status))}catch(e){console.error(`tail Error: ${e}`),process.exit(1)}},"tail");var Yi=E(()=>{I.command("log").description("tail logs").alias("l").description("tail logs").option("-i, --info","Follow INFO output",!1).option("-w, --warning","Follow WARN output",!1).option("-e, --error","Follow ERR/WARN output",!1).option("-a, --all","Follow All output",!1).action(_=>{Hi(_)})},"logCommands");import L_ from"chalk";import{spawnSync as za}from"child_process";import{homedir as Za}from"os";var xt=E(_=>{let e=Za(),t=g(e),o=t.testnetValidatorVoteKey,i=t.testnetValidatorKey,n=t.testnetValidatorAuthorityKey,s=b_.TESTNET,r=_.COMMISSION;_.NETWORK===l.MAINNET&&(o=t.mainnetValidatorVoteKey,i=t.mainnetValidatorKey,n=t.mainnetValidatorAuthorityKey,s=b_.MAINNET),console.log(`\u231B\uFE0F Creating vote account with commission ${r} - ${s}`);let T=_.RPC_URL||s;_.NETWORK===l.TESTNET&&(T=b_.TESTNET);let a=`solana create-vote-account ${o} ${i} ${n} --commission ${r} --url ${T} --keypair ${i}`;za(a,{shell:!0,stdio:"inherit"})},"setupVoteAccount");import{spawnSync as Qt}from"child_process";import{existsSync as Ji,readdirSync as _S,rmSync as eS}from"fs";import{homedir as tS}from"os";import xi from"path";var $t=E(_=>{let e=[],t=0;_.NODE_TYPE===A.RPC&&(e=[h.MAINNET_VALIDATOR_KEY],t=1),_.NETWORK===l.TESTNET?(e=[h.TESTNET_VALIDATOR_KEY,h.TESTNET_VALITATOR_AUTHORITY_KEY,h.TESTNET_VALIDATOR_VOTE_KEY,h.MAINNET_VALIDATOR_KEY,h.MAINNET_VALITATOR_AUTHORITY_KEY,h.MAINNET_VALIDATOR_VOTE_KEY],t=6):(e=[h.MAINNET_VALIDATOR_KEY,h.MAINNET_VALITATOR_AUTHORITY_KEY,h.MAINNET_VALIDATOR_VOTE_KEY],t=3);let o=`solana-keygen grind --starts-and-ends-with E:SV:${t}`;Qt(o,{shell:!0,stdio:"ignore"});let i=_S("./").filter(T=>T.endsWith("SV.json")),n=tS(),s=xi.join(n,"unstaked-identity.json");Ji(s)&&Qt(`mv ${s} ${n}/unstaked-identity.backup.json`,{shell:!0,stdio:"ignore"});let r=0;for(let T of i){let a=xi.join(n,e[r]);if(r++,Ji(a)){console.log(`${a} is already exist!`),eS(T,{recursive:!0});continue}let c=`mv ${T} ${a}`;Qt(c,{shell:!0,stdio:"inherit"})}Qt("solana-keygen new -s --no-bip39-passphrase -o /home/solv/unstaked-identity.json",{shell:!0,stdio:"ignore"}),console.log(`Generated keypairs - ${n}`)},"createSolvKeyPairs");import{spawnSync as $i}from"child_process";var ES=E((_,e,t,o=2001)=>{let i="/etc/systemd/system/jupiter-api.service",n=`[Unit]
6132
6132
  Description=Jupiter API Service Instance
6133
6133
  After=network.target
6134
6134
 
@@ -6149,7 +6149,7 @@ unzip jupiter-swap-api-x86_64-unknown-linux-gnu.zip
6149
6149
  chmod +x jupiter-swap-api
6150
6150
  rm jupiter-swap-api-x86_64-unknown-linux-gnu.zip`,{shell:!0,stdio:"inherit"});let{filePath:t,body:o}=Qi(_.rpcUrl,_.grpcUrl,_.grpcToken);$i(`echo '${o}' | sudo tee ${t}`,{shell:!0,stdio:"inherit"}),console.log(iS.white(`\u{1F7E2} Jupiter Swap API Setup Completed
6151
6151
 
6152
- $ solv jupiter --help`))},"jupiterAPISetup"),qi=nS;import{spawnSync as sS}from"child_process";var qe=E(()=>{sS("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})},"daemonReload");import We from"chalk";import Wt from"inquirer";import rS from"inquirer";var Wi=E(async _=>{let t=Object.keys(_?xe.TESTNET:xe.MAINNET),o=_?xe.TESTNET:xe.MAINNET,i=await rS.prompt([{name:"commissionBps",type:"number",message:"Enter commission bps",default:1e3},{name:"region",type:"list",message:"Select region",choices:t}]),n=i.region,s=o[n];return{version:z_.version,tag:z_.tag,commissionBps:i.commissionBps,blockEngineUrl:s.BLOCK_ENGINE_URL,relayerUrl:s.RELAYER_URL,shredReceiverAddr:s.SHRED_RECEIVER_ADDR,bamUrl:s.BAM_URL}},"askJitoSetting");import TS from"inquirer";import{readFileSync as aS}from"fs";import{join as qt}from"path";var SS=["amsterdam","brazil","dublin","frankfurt","london","mexicocity","newyork","saltlakecity","singapore","southafrica","tokyo"],Xi=E(async _=>_?"testnet":(await TS.prompt([{name:"location",type:"list",message:"Select the closest location for chrony NTP configuration",choices:SS.map(t=>({name:t.charAt(0).toUpperCase()+t.slice(1).replace(/([A-Z])/g," $1"),value:t}))}])).location,"askChronyLocation"),cS=E((_,e)=>{let t=__dirname,o;t.includes("dist")?o=qt(t,"..","..",".."):o=qt(t,"..","..","..");let i=_===l.MAINNET?"mainnet":"testnet",n=_===l.MAINNET?`${e}.conf`:"testnet.conf",s=qt(o,"dist","cli","chrony",i,n),r=qt(o,"src","cli","chrony",i,n),T=IT("fs");return T.existsSync(s)?s:T.existsSync(r)?r:s},"getChronyConfigPath"),ji=E((_,e)=>{let t=cS(_,e);try{return aS(t,"utf-8")}catch(o){throw new Error(`Failed to read chrony config file at ${t}: ${o}`)}},"getChronyConfigContent");var RS=E(async()=>{try{let _=F.NONE,e=Q.AGAVE,t=M_.COMMISSION,o=!1,i="",n=await Wt.prompt([{name:"network",type:"list",message:"Choose Network",choices:ri,default:l.MAINNET},{name:"nodeType",type:"list",message:"Choose Node Type",choices:Ti,default:A.RPC}]),s=n.network===l.TESTNET;if(n.nodeType===A.VALIDATOR){let a=n.network===l.MAINNET?[F.AGAVE,F.FRANKENDANCER,F.BAM,F.JITO]:[F.AGAVE,F.FRANKENDANCER,F.BAM,F.JITO];_=await Wt.prompt({name:"validatorType",type:"list",message:"Choose Validator Type",choices:a,default:F.AGAVE}).then(c=>c.validatorType),e=Q.NONE}if(n.nodeType===A.RPC&&(e=await Wt.prompt({name:"rpcType",type:"list",message:"Choose RPC Type",choices:ai,default:Q.AGAVE}).then(a=>a.rpcType)),n.nodeType===A.VALIDATOR){let a=await Wt.prompt([{name:"commission",type:"number",message:`What is your commission rate? You can change it later (default: ${M_.COMMISSION}%)'`,default:M_.COMMISSION},{name:"isDummy",type:"confirm",message:"Do you want to setup as a dummy(Inactive) node?(\u203BFor Migration)",default:!0}]);if(t=a.commission,o=a.isDummy,_===F.JITO||_===F.FRANKENDANCER||_===F.BAM){await q();let c=await Wi(s);await m_(c)}}i=await Xi(s);let{network:r,nodeType:T}=n;return console.log(We.white("Network:",r)),console.log(We.white("Node Type:",T)),console.log(We.white("Validator Type:",_)),console.log(We.white("RPC Type:",e)),T===A.VALIDATOR&&console.log(We.white("Commission:",t)),await B({NETWORK:r,NODE_TYPE:T,VALIDATOR_TYPE:_,RPC_TYPE:e,COMMISSION:t,IS_DUMMY:o,CHRONY_LOCATION:i}),!0}catch(_){throw new Error(_)}},"initialConfigSetup"),zi=RS;import{spawnSync as W}from"child_process";var Xe=E((_=k_,e=!1,t=!1,o=!1)=>{t?e?W(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-solana/${_}/installer)"`,{shell:!0,stdio:"inherit"}):(W(`mkdir /tmp/${_}`,{shell:!0,stdio:"inherit"}),W(`cd /tmp/${_}`,{shell:!0,stdio:"inherit"}),W(`git -C /tmp/${_} clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules .`,{shell:!0,stdio:"inherit"}),W(`git -C /tmp/${_} checkout ${_}`,{shell:!0,stdio:"inherit"}),W(`git -C /tmp/${_} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),W(`CI_COMMIT=$(git -C /tmp/${_} rev-parse HEAD) /tmp/${_}/scripts/cargo-install-all.sh /home/solv/.local/share/solana/install/releases/${_}`,{shell:!0,stdio:"inherit"}),W("sudo rm -rf /home/solv/.local/share/solana/install/active_release",{shell:!0,stdio:"inherit"}),W(`sudo ln -sfn /home/solv/.local/share/solana/install/releases/${_} /home/solv/.local/share/solana/install/active_release`,{shell:!0,stdio:"inherit"}),o&&W("sudo setcap cap_net_raw,cap_net_admin,cap_bpf,cap_perfmon=p /home/solv/.local/share/solana/install/active_release/bin/agave-validator",{shell:!0,stdio:"inherit"}),W(`sudo rm -rf /tmp/${_}`,{shell:!0,stdio:"inherit"}),W("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})):e?W(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-solana/${_}/installer)"`,{shell:!0,stdio:"inherit"}):W(`sh -c "$(curl --netrc-optional -sSfL https://release.jito.wtf/${_}/install)"`,{shell:!0,stdio:"inherit"})},"installJito");var Zi=E(()=>{let t=F_.filter(i=>i!=="").map(i=>`--known-validator ${i} \\`).join(`
6152
+ $ solv jupiter --help`))},"jupiterAPISetup"),qi=nS;import{spawnSync as sS}from"child_process";var qe=E(()=>{sS("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})},"daemonReload");import We from"chalk";import Wt from"inquirer";import rS from"inquirer";var Wi=E(async _=>{let t=Object.keys(_?xe.TESTNET:xe.MAINNET),o=_?xe.TESTNET:xe.MAINNET,i=await rS.prompt([{name:"commissionBps",type:"number",message:"Enter commission bps",default:1e3},{name:"region",type:"list",message:"Select region",choices:t}]),n=i.region,s=o[n];return{version:z_.version,tag:z_.tag,commissionBps:i.commissionBps,blockEngineUrl:s.BLOCK_ENGINE_URL,relayerUrl:s.RELAYER_URL,shredReceiverAddr:s.SHRED_RECEIVER_ADDR,bamUrl:s.BAM_URL}},"askJitoSetting");import TS from"inquirer";import{readFileSync as aS}from"fs";import{join as qt}from"path";var SS=["amsterdam","brazil","dublin","frankfurt","london","mexicocity","newyork","saltlakecity","singapore","southafrica","tokyo"],Xi=E(async _=>_?"testnet":(await TS.prompt([{name:"location",type:"list",message:"Select the closest location for chrony NTP configuration",choices:SS.map(t=>({name:t.charAt(0).toUpperCase()+t.slice(1).replace(/([A-Z])/g," $1"),value:t}))}])).location,"askChronyLocation"),cS=E((_,e)=>{let t=__dirname,o;t.includes("dist")?o=qt(t,"..","..",".."):o=qt(t,"..","..","..");let i=_===l.MAINNET?"mainnet":"testnet",n=_===l.MAINNET?`${e}.conf`:"testnet.conf",s=qt(o,"dist","cli","chrony",i,n),r=qt(o,"src","cli","chrony",i,n),T=IT("fs");return T.existsSync(s)?s:T.existsSync(r)?r:s},"getChronyConfigPath"),ji=E((_,e)=>{let t=cS(_,e);try{return aS(t,"utf-8")}catch(o){throw new Error(`Failed to read chrony config file at ${t}: ${o}`)}},"getChronyConfigContent");var RS=E(async()=>{try{let _=F.NONE,e=Q.AGAVE,t=M_.COMMISSION,o=!1,i="",n=await Wt.prompt([{name:"network",type:"list",message:"Choose Network",choices:ri,default:l.MAINNET},{name:"nodeType",type:"list",message:"Choose Node Type",choices:Ti,default:A.RPC}]),s=n.network===l.TESTNET;if(n.nodeType===A.VALIDATOR){let a=n.network===l.MAINNET?[F.AGAVE,F.FRANKENDANCER,F.BAM,F.JITO]:[F.AGAVE,F.FRANKENDANCER,F.BAM,F.JITO];_=await Wt.prompt({name:"validatorType",type:"list",message:"Choose Validator Type",choices:a,default:F.AGAVE}).then(c=>c.validatorType),e=Q.NONE}if(n.nodeType===A.RPC&&(e=await Wt.prompt({name:"rpcType",type:"list",message:"Choose RPC Type",choices:ai,default:Q.AGAVE}).then(a=>a.rpcType)),n.nodeType===A.VALIDATOR){let a=await Wt.prompt([{name:"commission",type:"number",message:`What is your commission rate? You can change it later (default: ${M_.COMMISSION}%)'`,default:M_.COMMISSION},{name:"isDummy",type:"confirm",message:"Do you want to setup as a dummy(Inactive) node?(\u203BFor Migration)",default:!0}]);if(t=a.commission,o=a.isDummy,_===F.JITO||_===F.FRANKENDANCER||_===F.BAM){await q();let c=await Wi(s);await m_(c)}}i=await Xi(s);let{network:r,nodeType:T}=n;return console.log(We.white("Network:",r)),console.log(We.white("Node Type:",T)),console.log(We.white("Validator Type:",_)),console.log(We.white("RPC Type:",e)),T===A.VALIDATOR&&console.log(We.white("Commission:",t)),await B({NETWORK:r,NODE_TYPE:T,VALIDATOR_TYPE:_,RPC_TYPE:e,COMMISSION:t,IS_DUMMY:o,CHRONY_LOCATION:i}),!0}catch(_){throw new Error(_)}},"initialConfigSetup"),zi=RS;import{spawnSync as X}from"child_process";var Xe=E((_=k_,e=!1,t=!1,o=!1)=>{t?e?X(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-solana/${_}/installer)"`,{shell:!0,stdio:"inherit"}):(X(`mkdir /tmp/${_}`,{shell:!0,stdio:"inherit"}),X(`cd /tmp/${_}`,{shell:!0,stdio:"inherit"}),X(`git -C /tmp/${_} clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules .`,{shell:!0,stdio:"inherit"}),X(`git -C /tmp/${_} checkout ${_}`,{shell:!0,stdio:"inherit"}),X(`git -C /tmp/${_} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),X(`CI_COMMIT=$(git -C /tmp/${_} rev-parse HEAD) /tmp/${_}/scripts/cargo-install-all.sh /home/solv/.local/share/solana/install/releases/${_}`,{shell:!0,stdio:"inherit"}),X("sudo rm -rf /home/solv/.local/share/solana/install/active_release",{shell:!0,stdio:"inherit"}),X(`sudo ln -sfn /home/solv/.local/share/solana/install/releases/${_} /home/solv/.local/share/solana/install/active_release`,{shell:!0,stdio:"inherit"}),o&&X("sudo setcap cap_net_raw,cap_net_admin,cap_bpf,cap_perfmon=p /home/solv/.local/share/solana/install/active_release/bin/agave-validator",{shell:!0,stdio:"inherit"}),X(`sudo rm -rf /tmp/${_}`,{shell:!0,stdio:"inherit"}),X("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})):e?X(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-solana/${_}/installer)"`,{shell:!0,stdio:"inherit"}):X(`sh -c "$(curl --netrc-optional -sSfL https://release.jito.wtf/${_}/install)"`,{shell:!0,stdio:"inherit"})},"installJito");var Zi=E(()=>{let t=F_.filter(i=>i!=="").map(i=>`--known-validator ${i} \\`).join(`
6153
6153
  `);return`#!/bin/bash
6154
6154
  exec agave-validator \\
6155
6155
  --identity ${p} \\
@@ -6218,7 +6218,7 @@ ${t}
6218
6218
  --wal-recovery-mode skip_any_corrupted_record \\
6219
6219
  --use-snapshot-archives-at-startup when-newest \\
6220
6220
  --limit-ledger-size 400000000 \\
6221
- `},"startRPCNodeScript");var lS=E(async _=>{let e=_.RPC_TYPE,t="";switch(e){case Q.AGAVE:console.log("Agave RPC Node Setup"),G_(_.TESTNET_SOLANA_VERSION),t=_n();break;case Q.JITO:console.log("JITO RPC Node Setup");let o=p_,n=`${`v${Te}-jito`}${o}`;Xe(n),t=Zi();break;default:console.log("Unknown RPC Node Setup");break}if(await CS(N_)){console.log("Startup script already exists. Skipping...");return}await dS(N_,t,"utf-8"),Z_()},"setupRpcNode"),en=lS;import{writeFile as sn}from"fs/promises";import{spawnSync as X}from"child_process";var JE=E((_,e=!1,t=!1,o=!1)=>{t?e?X(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-bam/${_}/installer)"`,{shell:!0,stdio:"inherit"}):(X(`mkdir /tmp/${_}`,{shell:!0,stdio:"inherit"}),X(`cd /tmp/${_}`,{shell:!0,stdio:"inherit"}),X(`git -C /tmp/${_} clone https://github.com/jito-labs/bam-client.git --recurse-submodules .`,{shell:!0,stdio:"inherit"}),X(`git -C /tmp/${_} checkout ${_}`,{shell:!0,stdio:"inherit"}),X(`git -C /tmp/${_} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),X(`CI_COMMIT=$(git -C /tmp/${_} rev-parse HEAD) /tmp/${_}/scripts/cargo-install-all.sh /home/solv/.local/share/solana/install/releases/${_}`,{shell:!0,stdio:"inherit"}),X("sudo rm -rf /home/solv/.local/share/solana/install/active_release",{shell:!0,stdio:"inherit"}),X(`sudo ln -sfn /home/solv/.local/share/solana/install/releases/${_} /home/solv/.local/share/solana/install/active_release`,{shell:!0,stdio:"inherit"}),o&&X("sudo setcap cap_net_raw,cap_net_admin,cap_bpf,cap_perfmon=p /home/solv/.local/share/solana/install/active_release/bin/agave-validator",{shell:!0,stdio:"inherit"}),X(`sudo rm -rf /tmp/${_}`,{shell:!0,stdio:"inherit"}),X("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})):e?X(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-bam/${_}/installer)"`,{shell:!0,stdio:"inherit"}):X(`sh -c "$(curl --netrc-optional -sSfL https://release.jito.wtf/${_}/install)"`,{shell:!0,stdio:"inherit"})},"installBam");import{spawnSync as y}from"child_process";import{promises as xE}from"fs";import fS from"path";var NS=E(()=>({filePath:"/home/solv/start-firedancer.sh",body:`#!/usr/bin/env bash
6221
+ `},"startRPCNodeScript");var lS=E(async _=>{let e=_.RPC_TYPE,t="";switch(e){case Q.AGAVE:console.log("Agave RPC Node Setup"),G_(_.TESTNET_SOLANA_VERSION),t=_n();break;case Q.JITO:console.log("JITO RPC Node Setup");let o=p_,n=`${`v${Te}-jito`}${o}`;Xe(n),t=Zi();break;default:console.log("Unknown RPC Node Setup");break}if(await CS(N_)){console.log("Startup script already exists. Skipping...");return}await dS(N_,t,"utf-8"),Z_()},"setupRpcNode"),en=lS;import{writeFile as sn}from"fs/promises";import{spawnSync as j}from"child_process";var JE=E((_,e=!1,t=!1,o=!1)=>{t?e?j(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-bam/${_}/installer)"`,{shell:!0,stdio:"inherit"}):(j(`mkdir /tmp/${_}`,{shell:!0,stdio:"inherit"}),j(`cd /tmp/${_}`,{shell:!0,stdio:"inherit"}),j(`git -C /tmp/${_} clone https://github.com/jito-labs/bam-client.git --recurse-submodules .`,{shell:!0,stdio:"inherit"}),j(`git -C /tmp/${_} checkout ${_}`,{shell:!0,stdio:"inherit"}),j(`git -C /tmp/${_} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),j(`CI_COMMIT=$(git -C /tmp/${_} rev-parse HEAD) /tmp/${_}/scripts/cargo-install-all.sh /home/solv/.local/share/solana/install/releases/${_}`,{shell:!0,stdio:"inherit"}),j("sudo rm -rf /home/solv/.local/share/solana/install/active_release",{shell:!0,stdio:"inherit"}),j(`sudo ln -sfn /home/solv/.local/share/solana/install/releases/${_} /home/solv/.local/share/solana/install/active_release`,{shell:!0,stdio:"inherit"}),o&&j("sudo setcap cap_net_raw,cap_net_admin,cap_bpf,cap_perfmon=p /home/solv/.local/share/solana/install/active_release/bin/agave-validator",{shell:!0,stdio:"inherit"}),j(`sudo rm -rf /tmp/${_}`,{shell:!0,stdio:"inherit"}),j("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})):e?j(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-bam/${_}/installer)"`,{shell:!0,stdio:"inherit"}):j(`sh -c "$(curl --netrc-optional -sSfL https://release.jito.wtf/${_}/install)"`,{shell:!0,stdio:"inherit"})},"installBam");import{spawnSync as y}from"child_process";import{promises as xE}from"fs";import fS from"path";var NS=E(()=>({filePath:"/home/solv/start-firedancer.sh",body:`#!/usr/bin/env bash
6222
6222
  sudo chmod -R 755 /mnt
6223
6223
  sudo fdctl configure init all --config /home/solv/firedancer/config.toml
6224
6224
  sudo chown -R solv:solv /mnt
@@ -6432,7 +6432,7 @@ ${s} ${m.ACCOUNTS} ext4 defaults 0 0
6432
6432
  ${r} ${m.SNAPSHOTS} ext4 defaults 0 0`);let a=[T],R=jt("cat /etc/fstab",{shell:!0,encoding:"utf8"}).stdout,C=[];for(let O of a)R.includes(O)||(console.log(`[INFO] Line to add: ${O}`),C.push(O));if(C.length){console.log(`[INFO] Lines to add all: ${C}`);let O=`echo "${C.join(`
6433
6433
  `)}" | sudo tee -a /etc/fstab`;jt(O,{shell:!0,encoding:"utf8"}),jt("sudo mount --all --verbose",{shell:!0,encoding:"utf8"}),console.log(`Added lines to /etc/fstab:
6434
6434
  ${C.join(`
6435
- `)}`)}else console.log("All lines are already present in /etc/fstab")},"ensureFstabEntries");import{spawnSync as MS}from"child_process";var cn=E(_=>{try{let e=`sudo umount ${_}`,{stderr:t}=MS(e,{shell:!0,stdio:"inherit"});return!t.includes("busy")}catch(e){return console.log(`umount: ${e}`),!1}},"umount");var LS=E(async()=>{let _=ze(),e=_.disks[0].mountpoint;if(_.has850GB&&_.has400GB&&_.disks.length>=3){console.log("Setting up TRIPLE DISK..."),await B({MNT_DISK_TYPE:o_.TRIPLE});let t="/dev/"+_.disks[0].name,o="/dev/"+_.disks[1].name,i="/dev/"+_.disks[2].name,n=Y_(t),s=Y_(o),r=Y_(i),T=n?t:"",a=s?o:"",c=r?i:"";console.log("Waiting for formatting to finish..."),await $(5e3),await Ze(n?T:"",s?a:"",r?c:"",!1,!0)}else if(_.has850GB&&_.has400GB){console.log("Setting up DOUBLE DISK..."),await B({MNT_DISK_TYPE:o_.DOUBLE});let t="/dev/"+_.disks[0].name,o="/dev/"+_.disks[1].name,i=Y_(t),n=Y_(o);await Ze(i?i?t:"":"",n?n?o:"":"","",!0)}else if(console.log("Setting up SINGLE DISK..."),await B({MNT_DISK_TYPE:o_.SINGLE}),e.includes("/mnt")){cn(e);let t="/dev/"+_.disks[0].name;Y_(t),await Ze(t)}else{let t="/dev/"+_.disks[0].name;Y_(t),await Ze(t)}},"mountDirs"),Rn=LS;import{spawnSync as hS}from"child_process";var Cn=E(()=>{let _=[`sudo mkdir -p ${m.ROOT}`,`sudo chown -R solv:solv ${m.ROOT}`,`sudo chmod -R 755 ${m.ROOT}`,`sudo mkdir -p ${m.ACCOUNTS}`,`sudo chown -R solv:solv ${m.ACCOUNTS}`,`sudo chmod -R 755 ${m.ACCOUNTS}`,`sudo mkdir -p ${m.LEDGER}`,`sudo chown -R solv:solv ${m.LEDGER}`,`sudo chmod -R 755 ${m.LEDGER}`,`sudo mkdir -p ${m.SNAPSHOTS}`,`sudo chown -R solv:solv ${m.SNAPSHOTS}`,`sudo chmod -R 755 ${m.SNAPSHOTS}`];for(let e of _)hS(e,{shell:!0,stdio:"ignore"})},"setupPermissions");import{execSync as zt}from"child_process";import{existsSync as gS}from"fs";function dn(){if(!gS(L.SOL_SYSTEM_CONFIG21)){console.log("Creating solana-validator.conf sysctl configuration file");let _=`
6435
+ `)}`)}else console.log("All lines are already present in /etc/fstab")},"ensureFstabEntries");import{spawnSync as MS}from"child_process";var cn=E(_=>{try{let e=`sudo umount ${_}`,{stderr:t}=MS(e,{shell:!0,stdio:"inherit"});return!t.includes("busy")}catch(e){return console.log(`umount: ${e}`),!1}},"umount");var LS=E(async()=>{let _=ze(),e=_.disks[0].mountpoint;if(_.has850GB&&_.has400GB&&_.disks.length>=3){console.log("Setting up TRIPLE DISK..."),await B({MNT_DISK_TYPE:i_.TRIPLE});let t="/dev/"+_.disks[0].name,o="/dev/"+_.disks[1].name,i="/dev/"+_.disks[2].name,n=Y_(t),s=Y_(o),r=Y_(i),T=n?t:"",a=s?o:"",c=r?i:"";console.log("Waiting for formatting to finish..."),await $(5e3),await Ze(n?T:"",s?a:"",r?c:"",!1,!0)}else if(_.has850GB&&_.has400GB){console.log("Setting up DOUBLE DISK..."),await B({MNT_DISK_TYPE:i_.DOUBLE});let t="/dev/"+_.disks[0].name,o="/dev/"+_.disks[1].name,i=Y_(t),n=Y_(o);await Ze(i?i?t:"":"",n?n?o:"":"","",!0)}else if(console.log("Setting up SINGLE DISK..."),await B({MNT_DISK_TYPE:i_.SINGLE}),e.includes("/mnt")){cn(e);let t="/dev/"+_.disks[0].name;Y_(t),await Ze(t)}else{let t="/dev/"+_.disks[0].name;Y_(t),await Ze(t)}},"mountDirs"),Rn=LS;import{spawnSync as hS}from"child_process";var Cn=E(()=>{let _=[`sudo mkdir -p ${m.ROOT}`,`sudo chown -R solv:solv ${m.ROOT}`,`sudo chmod -R 755 ${m.ROOT}`,`sudo mkdir -p ${m.ACCOUNTS}`,`sudo chown -R solv:solv ${m.ACCOUNTS}`,`sudo chmod -R 755 ${m.ACCOUNTS}`,`sudo mkdir -p ${m.LEDGER}`,`sudo chown -R solv:solv ${m.LEDGER}`,`sudo chmod -R 755 ${m.LEDGER}`,`sudo mkdir -p ${m.SNAPSHOTS}`,`sudo chown -R solv:solv ${m.SNAPSHOTS}`,`sudo chmod -R 755 ${m.SNAPSHOTS}`];for(let e of _)hS(e,{shell:!0,stdio:"ignore"})},"setupPermissions");import{execSync as zt}from"child_process";import{existsSync as gS}from"fs";function dn(){if(!gS(L.SOL_SYSTEM_CONFIG21)){console.log("Creating solana-validator.conf sysctl configuration file");let _=`
6436
6436
  # Increase UDP buffer sizes
6437
6437
  net.core.rmem_default = 134217728
6438
6438
  net.core.rmem_max = 134217728
@@ -6447,7 +6447,7 @@ fs.nr_open = 1048576
6447
6447
  `,e=`
6448
6448
  # Increase process file descriptor count limit
6449
6449
  * - nofile 1048576
6450
- `;zt(`echo "${_}" | sudo tee ${L.SOL_SYSTEM_CONFIG21} > /dev/null`),zt(`sudo sysctl -p ${L.SOL_SYSTEM_CONFIG21}`),zt(`echo "DefaultFILE=1048576" | sudo tee -a ${L.SOL_SYSTEM_CONF}`),zt(`echo "${e}" | sudo tee ${L.SOL_NOFILES_CONF} > /dev/null`)}}E(dn,"setupSystemd");import{execSync as BS}from"child_process";function ln(){console.log("Creating solvService configuration for solana");let _=Xt();BS(`echo "${_.body}" | sudo tee ${_.filePath} > /dev/null`),console.log("frankendancer.service configuration created.")}E(ln,"setupFiredancerService");var Nn=E((_,e)=>{Ce(e),$e(_),ln(),dn()},"makeServices");import{spawnSync as qE}from"node:child_process";var On=E(_=>{try{$t(_);let e=_.NETWORK;return e===l.TESTNET?(qE(`solana config set --url ${e} -k ${G}`,{shell:!0,stdio:"inherit"}),qE(`solana airdrop 1 --url ${e} -k ${G}`,{shell:!0,stdio:"inherit"})):qE(`solana config set --url ${e} -k ${x}`,{shell:!0,stdio:"inherit"}),_.NODE_TYPE!==A.RPC&&xt(_),!0}catch(e){throw new Error(`setupKeys Error: ${e}`)}},"setupKeys");import{spawnSync as Fn}from"node:child_process";var _t=E((_=!1,e="45",t=O_,o=e_,i=_?"https://api.testnet.solana.com":"https://api.mainnet-beta.solana.com",n=!1)=>{try{let s=`docker run -it --rm -v ${t}:${t} --user $(id -u):$(id -g) c29r3/solana-snapshot-finder:latest --snapshot_path ${t} --min_download_speed ${e} --version ${o} --rpc ${i}`;if(_&&n){Fn(`wget --trust-server-names https://snapshots.avorio.network/testnet/snapshot.tar.bz2 https://snapshots.avorio.network/testnet/incremental-snapshot.tar.bz2 && for file in snapshot-* incremental-snapshot-*; do mv "$file" "$(echo "$file" | sed 's/\\?.*$//')"; done`,{shell:!0,stdio:"inherit",cwd:t});return}Fn(s,{shell:!0,stdio:"inherit"})}catch(s){throw new Error(`getSnapshot Error: ${s}`)}},"getSnapshot");import{spawnSync as yS}from"node:child_process";var Zt=E(_=>{let t=[`sudo systemctl start ${_.VALIDATOR_TYPE===F.FRANKENDANCER?"frankendancer":"solv"}`];yS(t[0],{shell:!0,stdio:"inherit"})},"startSolana");import{execSync as KS}from"node:child_process";var GS=E(()=>{try{KS('echo "performance" | sudo tee /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor')}catch{}},"setupCpuGovernor"),In=GS;import WE from"fs";import{promisify as Dn}from"util";import{execSync as fn}from"child_process";var kS=Dn(WE.readFile),VS=Dn(WE.access),_E="/etc/sysctl.conf",bS=`# set default and maximum socket buffer sizes to 128MB
6450
+ `;zt(`echo "${_}" | sudo tee ${L.SOL_SYSTEM_CONFIG21} > /dev/null`),zt(`sudo sysctl -p ${L.SOL_SYSTEM_CONFIG21}`),zt(`echo "DefaultFILE=1048576" | sudo tee -a ${L.SOL_SYSTEM_CONF}`),zt(`echo "${e}" | sudo tee ${L.SOL_NOFILES_CONF} > /dev/null`)}}E(dn,"setupSystemd");import{execSync as BS}from"child_process";function ln(){console.log("Creating solvService configuration for solana");let _=Xt();BS(`echo "${_.body}" | sudo tee ${_.filePath} > /dev/null`),console.log("frankendancer.service configuration created.")}E(ln,"setupFiredancerService");var Nn=E((_,e)=>{Ce(e),$e(_),ln(),dn()},"makeServices");import{spawnSync as qE}from"node:child_process";var On=E(_=>{try{$t(_);let e=_.NETWORK;return e===l.TESTNET?(qE(`solana config set --url ${e} -k ${G}`,{shell:!0,stdio:"inherit"}),qE(`solana airdrop 1 --url ${e} -k ${G}`,{shell:!0,stdio:"inherit"})):qE(`solana config set --url ${e} -k ${x}`,{shell:!0,stdio:"inherit"}),_.NODE_TYPE!==A.RPC&&xt(_),!0}catch(e){throw new Error(`setupKeys Error: ${e}`)}},"setupKeys");import{spawnSync as Fn}from"node:child_process";var _t=E((_=!1,e="45",t=O_,o=t_,i=_?"https://api.testnet.solana.com":"https://api.mainnet-beta.solana.com",n=!1)=>{try{let s=`docker run -it --rm -v ${t}:${t} --user $(id -u):$(id -g) c29r3/solana-snapshot-finder:latest --snapshot_path ${t} --min_download_speed ${e} --version ${o} --rpc ${i}`;if(_&&n){Fn(`wget --trust-server-names https://snapshots.avorio.network/testnet/snapshot.tar.bz2 https://snapshots.avorio.network/testnet/incremental-snapshot.tar.bz2 && for file in snapshot-* incremental-snapshot-*; do mv "$file" "$(echo "$file" | sed 's/\\?.*$//')"; done`,{shell:!0,stdio:"inherit",cwd:t});return}Fn(s,{shell:!0,stdio:"inherit"})}catch(s){throw new Error(`getSnapshot Error: ${s}`)}},"getSnapshot");import{spawnSync as yS}from"node:child_process";var Zt=E(_=>{let t=[`sudo systemctl start ${_.VALIDATOR_TYPE===F.FRANKENDANCER?"frankendancer":"solv"}`];yS(t[0],{shell:!0,stdio:"inherit"})},"startSolana");import{execSync as KS}from"node:child_process";var GS=E(()=>{try{KS('echo "performance" | sudo tee /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor')}catch{}},"setupCpuGovernor"),In=GS;import WE from"fs";import{promisify as Dn}from"util";import{execSync as fn}from"child_process";var kS=Dn(WE.readFile),VS=Dn(WE.access),_E="/etc/sysctl.conf",bS=`# set default and maximum socket buffer sizes to 128MB
6451
6451
  net.core.rmem_default=134217728
6452
6452
  net.core.wmem_default=134217728
6453
6453
  net.core.rmem_max=134217728
@@ -6470,7 +6470,7 @@ To get your free API key, simply join us through the link below:
6470
6470
  Validators DAO: ${eE.white("`https://discord.gg/X4BgkBHavp`")}
6471
6471
 
6472
6472
  Unlock fast connections and elevate your experience with your very own API key \u{1F680}
6473
- `;console.log(eE.cyan(e))},"rpcLog"),_e=JS;import{spawnSync as xS}from"node:child_process";var pn=E(()=>{xS("sudo systemctl enable frankendancer",{shell:!0,stdio:"inherit"})},"enableFiredancer");import{spawnSync as j}from"child_process";import a_ from"chalk";import{writeFileSync as QS}from"fs";var mn=E(async(_,e)=>{try{if(console.log(a_.white("\u23F0 Setting up chrony...")),console.log(a_.gray("Stopping systemd-timesyncd...")),j("sudo systemctl stop systemd-timesyncd",{shell:!0,stdio:"inherit"}),j("sudo systemctl disable systemd-timesyncd",{shell:!0,stdio:"inherit"}),console.log(a_.gray("Updating package list...")),j("sudo apt update",{shell:!0,stdio:"inherit"}),console.log(a_.gray("Installing chrony...")),j("sudo apt install chrony -y",{shell:!0,stdio:"inherit"}).status!==0)throw new Error("Failed to install chrony");let o=ji(_,e);console.log(a_.gray("Configuring chrony...")),j("sudo rm -f /etc/chrony/chrony.conf",{shell:!0,stdio:"inherit"});let i="/tmp/chrony.conf";QS(i,o,"utf-8"),j(`sudo mv ${i} /etc/chrony/chrony.conf`,{shell:!0,stdio:"inherit"}),j("sudo chmod 644 /etc/chrony/chrony.conf",{shell:!0,stdio:"inherit"}),console.log(a_.gray("Enabling and starting chrony service...")),j("sudo systemctl enable chrony",{shell:!0,stdio:"inherit"}),j("sudo systemctl restart chrony",{shell:!0,stdio:"inherit"}),console.log(a_.gray("Verifying chrony sources...")),j("chronyc sources -v",{shell:!0,stdio:"inherit"}),console.log(a_.gray("Updating netplan configuration..."));let n="/etc/netplan/50-cloud-init.yaml";j(`test -f ${n}`,{shell:!0}).status===0&&(j(`sudo sed -i 's/^\\(\\s*search:\\)/#\\1/g' ${n}`,{shell:!0,stdio:"inherit"}),j(`sudo sed -i 's/^\\(\\s*.*maas.*\\)/#\\1/g' ${n}`,{shell:!0,stdio:"inherit"}),j("sudo netplan apply",{shell:!0,stdio:"inherit"})),console.log(a_.green("\u2705 Chrony setup completed")),console.log(a_.gray("You can check chrony status with:")),console.log(a_.gray(" chronyc tracking")),console.log(a_.gray(" chronyc sourcestats -v"))}catch(t){throw new Error(`Failed to setup chrony: ${t.message}`)}},"setupChrony");import{spawnSync as tE}from"child_process";import EE from"chalk";var Mn=E(()=>{try{console.log(EE.white("\u{1F512} Disabling auto updates..."));let _="/etc/apt/apt.conf.d/99needrestart";tE(`test -f ${_}`,{shell:!0}).status===0?(tE(`sudo sed -i 's/-m u//g' ${_}`,{shell:!0,stdio:"inherit"}),tE(`sudo sed -i 's/^\\(DPkg::Post-Invoke.*apt-pinvoke.*\\)$/\\/\\/ \\1/' ${_}`,{shell:!0,stdio:"inherit"}),tE(`sudo dpkg-divert --add --rename --divert ${_}.disabled ${_}`,{shell:!0,stdio:"inherit"}),console.log(EE.green("\u2705 Auto updates disabled"))):console.log(EE.gray("\u26A0\uFE0F /etc/apt/apt.conf.d/99needrestart not found, skipping"))}catch(_){console.log(EE.yellow(`\u26A0\uFE0F Warning: Could not disable auto updates: ${_.message}`))}},"disableAutoUpdates");import{spawnSync as Oe}from"child_process";import ee from"chalk";import{writeFileSync as $S}from"fs";var Ln=E(()=>{try{if(console.log(ee.white("\u26A1 Setting up CPU frequency governor with cpufrequtils...")),console.log(ee.gray("Installing cpufrequtils...")),Oe("sudo apt install cpufrequtils -y",{shell:!0,stdio:"inherit"}).status!==0)throw new Error("Failed to install cpufrequtils");console.log(ee.gray("Configuring cpufrequtils..."));let e=`GOVERNOR="performance"
6473
+ `;console.log(eE.cyan(e))},"rpcLog"),_e=JS;import{spawnSync as xS}from"node:child_process";var pn=E(()=>{xS("sudo systemctl enable frankendancer",{shell:!0,stdio:"inherit"})},"enableFiredancer");import{spawnSync as z}from"child_process";import a_ from"chalk";import{writeFileSync as QS}from"fs";var mn=E(async(_,e)=>{try{if(console.log(a_.white("\u23F0 Setting up chrony...")),console.log(a_.gray("Stopping systemd-timesyncd...")),z("sudo systemctl stop systemd-timesyncd",{shell:!0,stdio:"inherit"}),z("sudo systemctl disable systemd-timesyncd",{shell:!0,stdio:"inherit"}),console.log(a_.gray("Updating package list...")),z("sudo apt update",{shell:!0,stdio:"inherit"}),console.log(a_.gray("Installing chrony...")),z("sudo apt install chrony -y",{shell:!0,stdio:"inherit"}).status!==0)throw new Error("Failed to install chrony");let o=ji(_,e);console.log(a_.gray("Configuring chrony...")),z("sudo rm -f /etc/chrony/chrony.conf",{shell:!0,stdio:"inherit"});let i="/tmp/chrony.conf";QS(i,o,"utf-8"),z(`sudo mv ${i} /etc/chrony/chrony.conf`,{shell:!0,stdio:"inherit"}),z("sudo chmod 644 /etc/chrony/chrony.conf",{shell:!0,stdio:"inherit"}),console.log(a_.gray("Enabling and starting chrony service...")),z("sudo systemctl enable chrony",{shell:!0,stdio:"inherit"}),z("sudo systemctl restart chrony",{shell:!0,stdio:"inherit"}),console.log(a_.gray("Verifying chrony sources...")),z("chronyc sources -v",{shell:!0,stdio:"inherit"}),console.log(a_.gray("Updating netplan configuration..."));let n="/etc/netplan/50-cloud-init.yaml";z(`test -f ${n}`,{shell:!0}).status===0&&(z(`sudo sed -i 's/^\\(\\s*search:\\)/#\\1/g' ${n}`,{shell:!0,stdio:"inherit"}),z(`sudo sed -i 's/^\\(\\s*.*maas.*\\)/#\\1/g' ${n}`,{shell:!0,stdio:"inherit"}),z("sudo netplan apply",{shell:!0,stdio:"inherit"})),console.log(a_.green("\u2705 Chrony setup completed")),console.log(a_.gray("You can check chrony status with:")),console.log(a_.gray(" chronyc tracking")),console.log(a_.gray(" chronyc sourcestats -v"))}catch(t){throw new Error(`Failed to setup chrony: ${t.message}`)}},"setupChrony");import{spawnSync as tE}from"child_process";import EE from"chalk";var Mn=E(()=>{try{console.log(EE.white("\u{1F512} Disabling auto updates..."));let _="/etc/apt/apt.conf.d/99needrestart";tE(`test -f ${_}`,{shell:!0}).status===0?(tE(`sudo sed -i 's/-m u//g' ${_}`,{shell:!0,stdio:"inherit"}),tE(`sudo sed -i 's/^\\(DPkg::Post-Invoke.*apt-pinvoke.*\\)$/\\/\\/ \\1/' ${_}`,{shell:!0,stdio:"inherit"}),tE(`sudo dpkg-divert --add --rename --divert ${_}.disabled ${_}`,{shell:!0,stdio:"inherit"}),console.log(EE.green("\u2705 Auto updates disabled"))):console.log(EE.gray("\u26A0\uFE0F /etc/apt/apt.conf.d/99needrestart not found, skipping"))}catch(_){console.log(EE.yellow(`\u26A0\uFE0F Warning: Could not disable auto updates: ${_.message}`))}},"disableAutoUpdates");import{spawnSync as Oe}from"child_process";import ee from"chalk";import{writeFileSync as $S}from"fs";var Ln=E(()=>{try{if(console.log(ee.white("\u26A1 Setting up CPU frequency governor with cpufrequtils...")),console.log(ee.gray("Installing cpufrequtils...")),Oe("sudo apt install cpufrequtils -y",{shell:!0,stdio:"inherit"}).status!==0)throw new Error("Failed to install cpufrequtils");console.log(ee.gray("Configuring cpufrequtils..."));let e=`GOVERNOR="performance"
6474
6474
  `,t="/tmp/cpufrequtils.conf";$S(t,e,"utf-8"),Oe(`sudo mv ${t} /etc/default/cpufrequtils`,{shell:!0,stdio:"inherit"}),Oe("sudo chmod 644 /etc/default/cpufrequtils",{shell:!0,stdio:"inherit"}),console.log(ee.gray("Enabling cpufrequtils service...")),Oe("sudo systemctl restart cpufrequtils",{shell:!0,stdio:"inherit"}),Oe("sudo systemctl enable cpufrequtils",{shell:!0,stdio:"inherit"}),console.log(ee.gray("Verifying CPU governor...")),Oe("cat /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor",{shell:!0,stdio:"inherit"}),console.log(ee.green("\u2705 CPU frequency governor configured"))}catch(_){console.log(ee.yellow(`\u26A0\uFE0F Warning: Could not setup cpufrequtils: ${_.message}`))}},"setupCpuFreqUtils");import{spawnSync as et}from"child_process";import tt from"chalk";import{writeFileSync as qS}from"fs";var hn=E(()=>{try{console.log(tt.white("\u{1F6E1}\uFE0F Setting up fail2ban...")),console.log(tt.gray("Creating fail2ban configuration..."));let _=`[DEFAULT]
6475
6475
  maxretry = 1
6476
6476
  bantime.increment = true
@@ -6533,7 +6533,7 @@ WantedBy=multi-user.target`;return{filePath:e,body:t}},"jitoRelayerSeparateServi
6533
6533
  `);await ZS(_,o),jS(`chmod +x ${_}`,{shell:!0,stdio:"inherit"})},"addConfigToStartupScript"),Vn=_c;import ec from"inquirer";import{writeFile as tc}from"node:fs/promises";var bn=E(async()=>{let e=(await ec.prompt([{type:"input",name:"xToken",message:"Enter the xToken",default:"xToken"}])).xToken,t="git clone https://github.com/rpcpool/yellowstone-grpc.git",o="cargo build -r",i="cargo-fmt && cargo run --bin config-check -- --config yellowstone-grpc-geyser/config.json";jE(t,{shell:!0,stdio:"inherit"}),jE(o,{shell:!0,stdio:"inherit",cwd:"/home/solv/yellowstone-grpc"}),jE(i,{shell:!0,stdio:"inherit",cwd:"/home/solv/yellowstone-grpc"});let{filePath:n,defaultConfig:s}=kn(e),r=JSON.stringify(s,null,2);await tc(n,r,{encoding:"utf8"}),await Vn()},"yellowstoneGeyser");var wn=E(_=>{I.command("setup").description("Setup Solana Validator").option("--vote","Setup Vote Account",!1).option("--key","Setup Validator Keypairs",!1).option("--relayer","Setup Jito Relayer",!1).option("--jupiter","Setup Jupiter Swap API",!1).option("--geyser","Setup Geyser",!1).option("--firedancer","Setup Firedancer",!1).option("--skip-init-config","Skip Initial Config",!1).option("--skip-mount","Skip Mount",!1).option("--pivot","Pivot install",!1).option("--mod","Modified install",!1).option("--jagsnap","Jag Snapshot enabled",!1).action(async e=>{let t=_.MOD||e.mod;try{if(e.vote)console.log(L_.white("\u{1F5F3}\uFE0F Setting up Vote Account ...")),xt(_),process.exit(0);else if(e.key)console.log(L_.white("\u{1F511} Setting up Validator Keypairs ...")),$t(_),process.exit(0);else if(e.relayer){console.log(L_.white("\u{1F6F0}\uFE0F Setting up Jito Relayer ..."));let i=(await q()).blockEngineUrl;await Gn(i,!1),console.log(L_.green(`Jito Relayer Setup Completed
6534
6534
 
6535
6535
  $ solv relayer --help`)),qe(),_e(),process.exit(0)}else if(e.jupiter)console.log(L_.white("\u{1F30F} Setting up Jupiter Swap API ...")),await qi(),qe(),_e(),process.exit(0);else if(e.geyser){console.log(L_.white("\u26A1\uFE0F Setting up Geyser ...")),await bn();return}else if(e.firedancer){console.log(L_.white("\u{1F525} Setting up Firedancer ...")),await je(t);return}await Bn(e.skipInitConfig,e.skipMount,e.pivot,t,e.jagSnap,!0)}catch(o){(o.message.includes("User force closed the prompt")||o.message.includes("initialConfigSetup"))&&(console.error(L_.cyan("Exiting...\u{1F31B}")),process.exit(0)),console.error(L_.red(`Setup Error: ${o.message}`)),process.exit(0)}})},"setupCommands");import{execSync as Ec}from"child_process";var zE=E(()=>{let t=Ec("df -h").toString().split(`
6536
- `).slice(1).filter(i=>i.split(/\s+/)[0]!=="").map(i=>{let n=i.split(/\s+/);return{Filesystem:n[0],Size:n[1],Used:n[2],Avail:n[3],Use:n[4],MountedOn:n[5]}}).sort((i,n)=>te(n.Avail)-te(i.Avail)).slice(0,10),o=t.some(i=>i.MountedOn==="/mnt"&&te(i.Size)>9e11-1);return t.forEach(i=>{i.MountedOn==="/mnt"&&te(i.Size)>9e11-1?console.log(`%c${i.Filesystem} ${i.Size} ${i.MountedOn}`,"color: green"):i.Filesystem.startsWith("/dev/")&&te(i.Size)>9e11-1&&console.log(`%c${i.Filesystem} ${i.Size} ${i.MountedOn}`,"color: red")}),o?console.log("your mount point is correct"):t.filter(n=>n.Filesystem.startsWith("/dev/")&&te(n.Size)>899999999999).map(n=>n.Filesystem).length>0,t},"df");import vn from"chalk";import oc from"cli-table3";var ZE=E(_=>{let e=["Filesystem","Size","Used","Avail","Use","MountedOn"].map(o=>vn.blue(o)),t=new oc({head:e,colWidths:[20,10,10,10,10,20]});_.forEach(o=>{t.push([o.Filesystem,o.Size,o.Used,o.Avail,o.Use,o.MountedOn].map(i=>vn.white(i)))}),console.log(t.toString())},"displayTable");var Hn=E(async()=>{I.command("df").description("Disk Free Command").action(()=>{let _=zE();ZE(_)})},"dfCommands"),te=E(_=>{let e={K:1e3,KB:1e3,M:1e6,MB:1e6,G:1e9,GB:1e9,T:1e12,TB:1e12},t=_.match(/[A-Za-z]+/)?.[0]||"",o=parseFloat(_);return e[t]?o*e[t]:o},"convertToBytes");var Yn=E(_=>{I.command("start").description("Start Solana Validator").action(()=>{Zt(_),process.exit(0)})},"startCommand");import{spawnSync as ic}from"node:child_process";import nc from"chalk";var Jn=E(async _=>{nc.white(console.log("Starting solv stop process..."));let t=[`sudo systemctl stop ${_.VALIDATOR_TYPE===F.FRANKENDANCER?"frankendancer":"solv"}`];ic(t[0],{shell:!0,stdio:"inherit"})},"stopSolana");var xn=E(_=>{I.command("stop").description("Stop Solana Validator").action(()=>{Jn(_),process.exit(0)})},"stopCommand");import{spawnSync as Et}from"node:child_process";import Qn from"chalk";var $n=E(_=>{let e=f_();I.command("restart").description("Restart Solana Validator").option("-r, --rm","Remove Snapshot and Restart Validator",!1).action(async t=>{let o=_.AUTO_RESTART,i=_.NETWORK===l.TESTNET,n=o&&i?10:30;t.rm&&(console.log(Qn.white("\u{1F477}\u200D\u2640\uFE0F Removing Snapshot and Restarting Validator...")),Et("solv stop",{stdio:"inherit",shell:!0}),Et("solv rm:snapshot",{stdio:"inherit",shell:!0}),Et("solv get snapshot",{stdio:"inherit",shell:!0}),Et("solv start",{stdio:"inherit",shell:!0}),console.log(Qn.green("\u2714\uFE0E Successfully Restarted Validator")),process.exit(0));let s=`${e} --ledger ${_.LEDGER_PATH} exit --max-delinquent-stake ${_.MAINNET_DELINQUENT_STAKE} --min-idle-time ${n}`;Et(s,{shell:!0,stdio:"inherit"}),process.exit(0)})},"restartCommand");var qn=E(_=>{let t=_.NETWORK===l.TESTNET?c_:e_;_.NODE_TYPE===A.RPC&&(t=X_),I.command("install").alias("i").description("Install Solana Client").option("-v, --version <version>",`Solana Version e.g. ${t}`,t).option("-m, --mod <version>","Use modified installer",!1).action(async o=>{let i=_.VALIDATOR_TYPE===F.JITO,n=_.VALIDATOR_TYPE===F.BAM,s=_.VALIDATOR_TYPE===F.FRANKENDANCER,r=o.mod||_.MOD,T=_.XDP;if(i){let R=o.version||k_,C=p_,O=`v${R}-jito`,N=`v${R}-mod`,S=r?`${N}${C}`:`${O}${C}`,d=!!R.startsWith("3");ut(S,r,d,T);return}if(n){let R=o.version||ae,C=W_,O=`v${R}-bam`,N=`v${R}-mod`,S=r?`${N}${C}`:`${O}${C}`,d=!!R.startsWith("3");Kt(S,r,d,T);return}if(s){let R=o.version||V_;yt(_,R,r);return}_.NODE_TYPE===A.RPC&&(t=X_);let c=o.version||t;await ft(c)})},"installCommands");import{spawnSync as sc}from"child_process";var Wn=E(()=>{I.command("mtr").description("Mount Reload Command").action(()=>{sc("sudo mount --all --verbose",{shell:!0,stdio:"inherit"})}),I.command("disks").description("Show unmounted disks").action(()=>{let _=ze();console.log(_)})},"mountCommands");import{spawnSync as ac}from"node:child_process";import Xn from"chalk";import{spawnSync as rc}from"child_process";var Tc=E(async()=>{try{let _=rc("crontab",["-l"],{encoding:"utf-8"});if(_.status!==0)return console.log("No crontab for this user."),!1;let e=_.stdout;return console.log(e),e.includes("solv epochTimer")}catch(_){return console.error("Error reading crontab:",_),!1}},"hasEpochTimer"),nE=Tc;var jn=E(()=>{I.command("cron").description("Cron Job Commands").command("epoch").description("Solv Epoch Timer Discord Notification Command").option("-c, --cron <value>","Cron Job","*/5 * * * *").action(async e=>{await nE()&&(console.log(Xn.green("\u26A0\uFE0F Epoch Timer Cron Job already set")),process.exit(1));let o=`(crontab -l 2>/dev/null; echo "${e.cron} . /home/solv/.profile && solv epochTimer >> /home/solv/cron.log 2>&1") | crontab -`;ac(o,{shell:!0,stdio:"inherit"}),console.log(Xn.green("\u2705 Epoch Timer Cron Job Set"))})},"cronCommands");var ot={SOLV_KEYPAIR_DOWNLOAD_PATH:"/solvKeys/download",SOLV_KEYPAIR_UPLOAD_PATH:"/solvKeys/upload",SOLV_KEYPAIR_UPLOAD_PATH_LINUX:"/home/solv",SOLV_KEYPAIR_TRASH_PATH:"/solvKeys/trash",SSH_PUBKEY_PATH:"/.ssh/id_rsa.pub"};import{existsSync as cc,mkdirSync as Rc}from"fs";import Cc from"inquirer";import{homedir as dc}from"os";import{spawnSync as Sc}from"node:child_process";function zn(_,e,t,o){let i=o?`scp -o StrictHostKeyChecking=no solv@${_}:${e} ${t}`:`scp -o StrictHostKeyChecking=no ${e} solv@${_}:${t}`;return Sc(i,{shell:!0,stdio:"inherit"}).status===0}E(zn,"executeSCP");var _o=E(async(_="")=>{let e=_;_===""&&(e=(await Cc.prompt([{type:"input",name:"ip",message:"Enter your Ubuntu Server IP",default(){return"1.1.1.1"}}])).ip);let t=Object.values(g()),o=dc(),i=o.includes("/home/solv")?"/home/solv":o+ot.SOLV_KEYPAIR_DOWNLOAD_PATH;cc(i)||Rc(i,{recursive:!0});let n=!0,s=o+"/"+Uo;t.push(s);for(let r of t){let T=r.split("/"),a=T[T.length-1];a=o.includes("/home/solv")?a:a.replace(".json",`-${e}.json`);let c=`${i}/${a}`;zn(e,r,c,n)&&console.log(`Successfully Exported - ${c} \u{1F389}`)}},"download");import{spawnSync as lc}from"child_process";import{existsSync as Nc}from"fs";import Oc from"inquirer";import Fc from"os";var Zn=E(async(_="")=>{let e=Fc.userInfo().homedir,t=_;_===""&&(t=(await Oc.prompt([{type:"input",name:"ip",message:"Enter your Ubuntu Server IP",default(){return"1.1.1.1"}}])).ip);let o=`${e}${ot.SOLV_KEYPAIR_UPLOAD_PATH}`;e.includes("/home/solv")&&(o=ot.SOLV_KEYPAIR_UPLOAD_PATH_LINUX);let i=Object.values(g(o));for(let n of i){let s=n.split("/"),r=s[s.length-1];if(!r.endsWith("keypair.json"))continue;let T=`${o}/${r}`;if(!Nc(T))continue;let a=`scp -o StrictHostKeyChecking=no ${T} solv@${t}:${n}`;lc(a,{shell:!0,stdio:"inherit"}),console.log(`Successfully Uploaded - ${r} \u{1F389}`)}},"upload");import{spawnSync as Ic}from"child_process";import fc from"inquirer";var _s=E(async()=>{let _=await fc.prompt({type:"input",name:"pubkey",message:"Enter your SSH Public Key",default(){return"xxxxxxxpubkeyxxxxxxxx"}}),e=`mkdir -p ${v.ROOT}/.ssh && echo "${_.pubkey}" >> ${v.AUTHORIZED_KEYS}`;Ic(e,{shell:!0,stdio:"inherit"}),console.log("Successfully Created SSH Login Setting \u{1F389}")},"scpCreate");import sE from"chalk";import{readFileSync as Dc}from"fs";import Pc from"os";var es=E(()=>{try{let e=`${Pc.userInfo().homedir}/.ssh/id_rsa.pub`,t=Dc(e,"utf8");console.log(sE.white(`Your SSH Public Key is:
6536
+ `).slice(1).filter(i=>i.split(/\s+/)[0]!=="").map(i=>{let n=i.split(/\s+/);return{Filesystem:n[0],Size:n[1],Used:n[2],Avail:n[3],Use:n[4],MountedOn:n[5]}}).sort((i,n)=>te(n.Avail)-te(i.Avail)).slice(0,10),o=t.some(i=>i.MountedOn==="/mnt"&&te(i.Size)>9e11-1);return t.forEach(i=>{i.MountedOn==="/mnt"&&te(i.Size)>9e11-1?console.log(`%c${i.Filesystem} ${i.Size} ${i.MountedOn}`,"color: green"):i.Filesystem.startsWith("/dev/")&&te(i.Size)>9e11-1&&console.log(`%c${i.Filesystem} ${i.Size} ${i.MountedOn}`,"color: red")}),o?console.log("your mount point is correct"):t.filter(n=>n.Filesystem.startsWith("/dev/")&&te(n.Size)>899999999999).map(n=>n.Filesystem).length>0,t},"df");import vn from"chalk";import oc from"cli-table3";var ZE=E(_=>{let e=["Filesystem","Size","Used","Avail","Use","MountedOn"].map(o=>vn.blue(o)),t=new oc({head:e,colWidths:[20,10,10,10,10,20]});_.forEach(o=>{t.push([o.Filesystem,o.Size,o.Used,o.Avail,o.Use,o.MountedOn].map(i=>vn.white(i)))}),console.log(t.toString())},"displayTable");var Hn=E(async()=>{I.command("df").description("Disk Free Command").action(()=>{let _=zE();ZE(_)})},"dfCommands"),te=E(_=>{let e={K:1e3,KB:1e3,M:1e6,MB:1e6,G:1e9,GB:1e9,T:1e12,TB:1e12},t=_.match(/[A-Za-z]+/)?.[0]||"",o=parseFloat(_);return e[t]?o*e[t]:o},"convertToBytes");var Yn=E(_=>{I.command("start").description("Start Solana Validator").action(()=>{Zt(_),process.exit(0)})},"startCommand");import{spawnSync as ic}from"node:child_process";import nc from"chalk";var Jn=E(async _=>{nc.white(console.log("Starting solv stop process..."));let t=[`sudo systemctl stop ${_.VALIDATOR_TYPE===F.FRANKENDANCER?"frankendancer":"solv"}`];ic(t[0],{shell:!0,stdio:"inherit"})},"stopSolana");var xn=E(_=>{I.command("stop").description("Stop Solana Validator").action(()=>{Jn(_),process.exit(0)})},"stopCommand");import{spawnSync as Et}from"node:child_process";import Qn from"chalk";var $n=E(_=>{let e=f_();I.command("restart").description("Restart Solana Validator").option("-r, --rm","Remove Snapshot and Restart Validator",!1).action(async t=>{let o=_.AUTO_RESTART,i=_.NETWORK===l.TESTNET,n=o&&i?10:30;t.rm&&(console.log(Qn.white("\u{1F477}\u200D\u2640\uFE0F Removing Snapshot and Restarting Validator...")),Et("solv stop",{stdio:"inherit",shell:!0}),Et("solv rm:snapshot",{stdio:"inherit",shell:!0}),Et("solv get snapshot",{stdio:"inherit",shell:!0}),Et("solv start",{stdio:"inherit",shell:!0}),console.log(Qn.green("\u2714\uFE0E Successfully Restarted Validator")),process.exit(0));let s=`${e} --ledger ${_.LEDGER_PATH} exit --max-delinquent-stake ${_.MAINNET_DELINQUENT_STAKE} --min-idle-time ${n}`;Et(s,{shell:!0,stdio:"inherit"}),process.exit(0)})},"restartCommand");var qn=E(_=>{let t=_.NETWORK===l.TESTNET?c_:t_;_.NODE_TYPE===A.RPC&&(t=X_),I.command("install").alias("i").description("Install Solana Client").option("-v, --version <version>",`Solana Version e.g. ${t}`,t).option("-m, --mod <version>","Use modified installer",!1).action(async o=>{let i=_.VALIDATOR_TYPE===F.JITO,n=_.VALIDATOR_TYPE===F.BAM,s=_.VALIDATOR_TYPE===F.FRANKENDANCER,r=o.mod||_.MOD,T=_.XDP;if(i){let R=o.version||k_,C=p_,O=`v${R}-jito`,N=`v${R}-mod`,S=r?`${N}${C}`:`${O}${C}`,d=!!R.startsWith("3");ut(S,r,d,T);return}if(n){let R=o.version||ae,C=W_,O=`v${R}-bam`,N=`v${R}-mod`,S=r?`${N}${C}`:`${O}${C}`,d=!!R.startsWith("3");Kt(S,r,d,T);return}if(s){let R=o.version||V_;yt(_,R,r);return}_.NODE_TYPE===A.RPC&&(t=X_);let c=o.version||t;await ft(c)})},"installCommands");import{spawnSync as sc}from"child_process";var Wn=E(()=>{I.command("mtr").description("Mount Reload Command").action(()=>{sc("sudo mount --all --verbose",{shell:!0,stdio:"inherit"})}),I.command("disks").description("Show unmounted disks").action(()=>{let _=ze();console.log(_)})},"mountCommands");import{spawnSync as ac}from"node:child_process";import Xn from"chalk";import{spawnSync as rc}from"child_process";var Tc=E(async()=>{try{let _=rc("crontab",["-l"],{encoding:"utf-8"});if(_.status!==0)return console.log("No crontab for this user."),!1;let e=_.stdout;return console.log(e),e.includes("solv epochTimer")}catch(_){return console.error("Error reading crontab:",_),!1}},"hasEpochTimer"),nE=Tc;var jn=E(()=>{I.command("cron").description("Cron Job Commands").command("epoch").description("Solv Epoch Timer Discord Notification Command").option("-c, --cron <value>","Cron Job","*/5 * * * *").action(async e=>{await nE()&&(console.log(Xn.green("\u26A0\uFE0F Epoch Timer Cron Job already set")),process.exit(1));let o=`(crontab -l 2>/dev/null; echo "${e.cron} . /home/solv/.profile && solv epochTimer >> /home/solv/cron.log 2>&1") | crontab -`;ac(o,{shell:!0,stdio:"inherit"}),console.log(Xn.green("\u2705 Epoch Timer Cron Job Set"))})},"cronCommands");var ot={SOLV_KEYPAIR_DOWNLOAD_PATH:"/solvKeys/download",SOLV_KEYPAIR_UPLOAD_PATH:"/solvKeys/upload",SOLV_KEYPAIR_UPLOAD_PATH_LINUX:"/home/solv",SOLV_KEYPAIR_TRASH_PATH:"/solvKeys/trash",SSH_PUBKEY_PATH:"/.ssh/id_rsa.pub"};import{existsSync as cc,mkdirSync as Rc}from"fs";import Cc from"inquirer";import{homedir as dc}from"os";import{spawnSync as Sc}from"node:child_process";function zn(_,e,t,o){let i=o?`scp -o StrictHostKeyChecking=no solv@${_}:${e} ${t}`:`scp -o StrictHostKeyChecking=no ${e} solv@${_}:${t}`;return Sc(i,{shell:!0,stdio:"inherit"}).status===0}E(zn,"executeSCP");var _o=E(async(_="")=>{let e=_;_===""&&(e=(await Cc.prompt([{type:"input",name:"ip",message:"Enter your Ubuntu Server IP",default(){return"1.1.1.1"}}])).ip);let t=Object.values(g()),o=dc(),i=o.includes("/home/solv")?"/home/solv":o+ot.SOLV_KEYPAIR_DOWNLOAD_PATH;cc(i)||Rc(i,{recursive:!0});let n=!0,s=o+"/"+Uo;t.push(s);for(let r of t){let T=r.split("/"),a=T[T.length-1];a=o.includes("/home/solv")?a:a.replace(".json",`-${e}.json`);let c=`${i}/${a}`;zn(e,r,c,n)&&console.log(`Successfully Exported - ${c} \u{1F389}`)}},"download");import{spawnSync as lc}from"child_process";import{existsSync as Nc}from"fs";import Oc from"inquirer";import Fc from"os";var Zn=E(async(_="")=>{let e=Fc.userInfo().homedir,t=_;_===""&&(t=(await Oc.prompt([{type:"input",name:"ip",message:"Enter your Ubuntu Server IP",default(){return"1.1.1.1"}}])).ip);let o=`${e}${ot.SOLV_KEYPAIR_UPLOAD_PATH}`;e.includes("/home/solv")&&(o=ot.SOLV_KEYPAIR_UPLOAD_PATH_LINUX);let i=Object.values(g(o));for(let n of i){let s=n.split("/"),r=s[s.length-1];if(!r.endsWith("keypair.json"))continue;let T=`${o}/${r}`;if(!Nc(T))continue;let a=`scp -o StrictHostKeyChecking=no ${T} solv@${t}:${n}`;lc(a,{shell:!0,stdio:"inherit"}),console.log(`Successfully Uploaded - ${r} \u{1F389}`)}},"upload");import{spawnSync as Ic}from"child_process";import fc from"inquirer";var _s=E(async()=>{let _=await fc.prompt({type:"input",name:"pubkey",message:"Enter your SSH Public Key",default(){return"xxxxxxxpubkeyxxxxxxxx"}}),e=`mkdir -p ${v.ROOT}/.ssh && echo "${_.pubkey}" >> ${v.AUTHORIZED_KEYS}`;Ic(e,{shell:!0,stdio:"inherit"}),console.log("Successfully Created SSH Login Setting \u{1F389}")},"scpCreate");import sE from"chalk";import{readFileSync as Dc}from"fs";import Pc from"os";var es=E(()=>{try{let e=`${Pc.userInfo().homedir}/.ssh/id_rsa.pub`,t=Dc(e,"utf8");console.log(sE.white(`Your SSH Public Key is:
6537
6537
  `)),console.log(sE.white(t))}catch(_){console.error(sE.white(`Error reading SSH Public Key
6538
6538
  `)),console.error(sE.white(_))}},"cat");import{spawnSync as Ac}from"child_process";var ts=E(()=>{Ac("ssh-keygen -t rsa -b 4096",{shell:!0,stdio:"inherit"})},"init");import{spawn as Uc}from"child_process";import{readFileSync as uc}from"fs";import{Readable as pc}from"stream";var Es=E(async _=>new Promise((e,t)=>{try{let o=Uc("find",["/","-name","*.json","-size","-301c"]),i=[];o.stdout.on("data",n=>{i.push(...n.toString().split(`
6539
6539
  `).filter(s=>s)),_.increment()}),o.stderr.on("data",n=>{_.increment()}),o.on("close",n=>{e(i)})}catch(o){t(`search Error: ${o}`)}}),"search"),mc=E(_=>{try{return JSON.parse(uc(_,"utf-8")).length===64}catch{return!1}},"checkIfSolanaKey"),os=E(async(_,e)=>{let t=[],o=pc.from(_);return o.on("data",async i=>{mc(i)&&t.push(i)}),new Promise((i,n)=>{o.on("end",()=>{i(t)}),o.on("error",s=>{n(s)})})},"processPaths");import rE from"chalk";import{Presets as gc,SingleBar as Bc}from"cli-progress";import is from"chalk";import{spawnSync as Mc}from"node:child_process";import Lc from"node-fetch";var hc=E(async()=>{let _=await Lc(Lo,{method:"POST",headers:{"Content-Type":"application/json"}});if(_.status!==200)return console.log(is.yellow(`\u26A0\uFE0F This Node is not Registered as Auto Operation Node.
@@ -6587,7 +6587,7 @@ $ solv mt -p <fileSystem>
6587
6587
  $ solv umt -p <fileSystem>
6588
6588
  `,i=`mount reload
6589
6589
  $ solv mtr
6590
- `;console.log(e),console.log(_.greyHex(t)),console.log(_.greyHex(o)),console.log(_.greyHex(i))}})(Ae||(Ae={}));import C_ from"chalk";import{spawnSync as fR}from"node:child_process";var dE=E(_=>{fR("solana config get",{shell:!0,stdio:"inherit"});let t=w_();console.log(C_.white("start-validator.sh: ")+t.scriptPath),console.log(C_.white("solv.service: ")+L.SOL_SERVICE),console.log(C_.white("logrotate: ")+L.SOL_LOGROTATE),console.log(C_.white("logrotate (fd): ")+L.FRANKENDANCER_LOGROTATE),console.log(C_.white("sysctl.d: ")+L.SOL_SYSTEM_CONFIG21),console.log(C_.white("limits.d: ")+L.SOL_NOFILES_CONF),console.log(C_.white("system.conf: ")+L.SOL_SYSTEM_CONF),console.log(C_.white("ledger: ")+t.ledger),console.log(C_.white("accounts: ")+t.accounts),console.log(C_.white("snapshots: ")+t.snapshots),console.log(C_.white("mount type: ")+_.MNT_DISK_TYPE)},"showConfig");import{spawnSync as Ms}from"node:child_process";import DR from"chalk";var Ls=E(_=>{let e=_.NETWORK===l.TESTNET,t=e?c_:e_;_.NODE_TYPE===A.RPC&&(t=X_);let o=I.command("get").description("Get Solana Validator's Information").argument("<cmd>","Subcommands: epoch, slot, catchup, snapshot, contact, config");o.command("epoch").description("Show Validator's Epoch").action(()=>{let i=ps();console.log({epoch:i})}),o.command("ip").description("Show Validator's IP Address").action(()=>{let i="curl ipinfo.io/ip",{stdout:n}=Ms(i,{shell:!0,stdio:"pipe"});console.log(DR.white(`${n}`))}),o.command("slot").description("Show Current Slot").action(()=>{let i=ms();console.log({slot:i})}),o.command("snapshot").alias("sn").option("-m, --minDownloadSpeed <minDownloadSpeed>","Minimum download speed","100").option("-s, --snapshotPath <snapshotPath>","Snapshot Path",_.SNAPSHOTS_PATH).option("-v, --version <version>","Specific Version Node",t).option("-r, --rpcUrl <rpcUrl>","RPC URL",e?"https://api.testnet.solana.com":"https://api.mainnet-beta.solana.com").option("-a, --avorio <version>","Use Avorio Network (Testnet only)",!1).description("Download the latest snapshot").action(i=>{let n=i.minDownloadSpeed,s=i.snapshotPath,r=i.version,T=i.rpcUrl,a=i.avorio;_t(e,n,s,r,T,a)}),o.command("contact").description("Show Validator Contact Information").action(()=>{let n=`${f_()} --ledger /mnt/ledger/ contact-info`;Ms(n,{shell:!0,stdio:"inherit"})}),o.command("config").description("Show Solv Config").alias("c").action(async()=>{dE(_)}),o.command("aa").description("Show Solv AA").option("-c, --client","Show Solv Client Mode AA",!1).action(i=>{Ae.solvAA(),i.client?Ae.installClientMessage():Ae.installMessage()}),o.addHelpCommand("help [cmd]","Get Solana Validator Information")},"getCommands");import{spawnSync as PR}from"node:child_process";var hs=E(()=>{PR("sudo systemctl status relayer.service",{shell:!0,stdio:"inherit"})},"relayerStatus");import{spawnSync as AR}from"node:child_process";var gs=E(()=>{AR("sudo systemctl start relayer.service",{shell:!0,stdio:"inherit"})},"relayerStart");import{spawnSync as UR}from"node:child_process";var Bs=E(()=>{UR("sudo systemctl stop relayer.service",{shell:!0,stdio:"inherit"})},"relayerStop");import{spawnSync as uR}from"node:child_process";var ys=E(()=>{uR("sudo systemctl restart relayer.service",{shell:!0,stdio:"inherit"})},"relayerRestart");import{spawnSync as pR}from"node:child_process";var Ks=E((_=!1)=>{pR(_?"journalctl -u relayer.service -xef | grep ERROR":"journalctl -u relayer.service -xef",{shell:!0,stdio:"inherit"})},"relayerLog");import eo from"chalk";import{spawnSync as MR}from"child_process";import{spawnSync as mR}from"node:child_process";var Gs=E(()=>{mR("sudo systemctl enable relayer.service",{shell:!0,stdio:"inherit"})},"relayerEnable");var ks=E(()=>{let _=I.command("relayer").description("Jito Relayer Commands");_.command("status").description("Show Relayer Status").action(()=>{hs()}),_.command("start").description("Start Relayer").action(()=>{gs()}),_.command("stop").description("Stop Relayer").action(()=>{Bs()}),_.command("log").option("-e, --error","Show Error Logs",!1).description("Show Relayer Logs").action(e=>{Ks(e.error)}),_.command("restart").description("Restart Relayer").action(()=>{ys()}),_.command("enable").description("Enable Relayer").action(()=>{Gs()}),_.command("set:url").option("-u, --url <url>","Set Relayer URL","").description("Set Relayer URL on Validator").action(e=>{if(e.url===""){console.log(eo.red("Please provide a URL"));return}let t=`${f_()} --ledger ${u} set-relayer-config --relayer-url ${e.url}`;console.log(eo.white("Setting Relayer URL ...")),MR(t,{shell:!0,stdio:"inherit"}),console.log(eo.green("\u{1F7E2} Relayer URL Set"))})},"relayerCommands");var Vs=E(_=>{I.command("logrotate").description("Refresh Logrotate").action(()=>{let e=_.VALIDATOR_TYPE==="frankendancer";Qe(e),process.exit(0)})},"logrotateCommand");import{spawnSync as yR}from"node:child_process";import St from"chalk";import{spawnSync as g_}from"node:child_process";import Ue from"chalk";var bs=E(async()=>{console.log(Ue.white("\u{1F4E6} Installing telegraf..."));let _=g_("which apt",{shell:!0,stdio:"pipe"}),e=g_("which yum",{shell:!0,stdio:"pipe"});if(_.stdout.toString().trim()){if(console.log(Ue.white("Detected apt package manager")),g_("sudo rm -f /etc/apt/trusted.gpg",{shell:!0,stdio:"inherit"}),g_("sudo mkdir -p /etc/apt/keyrings",{shell:!0,stdio:"inherit"}),g_("curl -fsSL https://repos.influxdata.com/influxdata-archive_compat.key | sudo tee /etc/apt/keyrings/influxdata-archive_compat.asc > /dev/null",{shell:!0,stdio:"inherit"}),g_("ls -l /etc/apt/keyrings/influxdata-archive_compat.asc",{shell:!0,stdio:"pipe"}).status!==0)throw new Error("Failed to add influxdata GPG key");if(g_('echo "deb [signed-by=/etc/apt/keyrings/influxdata-archive_compat.asc] https://repos.influxdata.com/ubuntu stable main" | sudo tee /etc/apt/sources.list.d/influxdb.list',{shell:!0,stdio:"inherit"}),console.log(Ue.white("Updating package list...")),g_("sudo apt update",{shell:!0,stdio:"inherit"}),console.log(Ue.white("Installing telegraf...")),g_("sudo apt install telegraf -y",{shell:!0,stdio:"inherit"}).status!==0)throw new Error("Failed to install telegraf");console.log(Ue.green("\u2705 Telegraf installed successfully"))}else throw e.stdout.toString().trim()?(console.log(Ue.white("Detected yum package manager")),new Error("Yum-based installation not yet implemented")):new Error("No supported package manager found (apt or yum required)")},"installTelegraf");import{spawnSync as ue}from"node:child_process";import{existsSync as Tt}from"fs";import pe from"chalk";var ws=E(async(_,e,t)=>{console.log(pe.white("\u{1F511} Setting up validator key symlinks..."));let o=`/home/${_}/.secrets`,i=`${o}/validator-keypair.json`,n=`${o}/vote-account-keypair.json`;if(!Tt(e))throw new Error(`Validator key not found at ${e}. Please verify the path.`);Tt(o)||ue(`sudo mkdir -p ${o}`,{shell:!0,stdio:"inherit"}),Tt(i)&&(console.log(pe.yellow(`Removing existing symlink: ${i}`)),ue(`sudo rm -f ${i}`,{shell:!0,stdio:"inherit"})),ue(`sudo ln -s ${e} ${i}`,{shell:!0,stdio:"inherit"}),Tt(t)?(Tt(n)&&(console.log(pe.yellow(`Removing existing symlink: ${n}`)),ue(`sudo rm -f ${n}`,{shell:!0,stdio:"inherit"})),ue(`sudo ln -s ${t} ${n}`,{shell:!0,stdio:"inherit"}),console.log(pe.green("\u2705 Vote account key symlink created"))):console.log(pe.yellow(`\u26A0\uFE0F Vote account key not found at ${t}, skipping`)),ue(`sudo chown -h ${_}:${_} ${o}/*`,{shell:!0,stdio:"inherit"}),console.log(pe.green("\u2705 Validator key symlinks created successfully"))},"setupValidatorKeys");import{spawnSync as to}from"node:child_process";import{writeFileSync as LR}from"fs";import Hs from"chalk";var vs=E(_=>{let{hostname:e,flushInterval:t,interval:o,mountPoints:i,validatorUser:n}=_,s=i.map(r=>`"${r}"`).join(", ");return`[agent]
6590
+ `;console.log(e),console.log(_.greyHex(t)),console.log(_.greyHex(o)),console.log(_.greyHex(i))}})(Ae||(Ae={}));import C_ from"chalk";import{spawnSync as fR}from"node:child_process";var dE=E(_=>{fR("solana config get",{shell:!0,stdio:"inherit"});let t=w_();console.log(C_.white("start-validator.sh: ")+t.scriptPath),console.log(C_.white("solv.service: ")+L.SOL_SERVICE),console.log(C_.white("logrotate: ")+L.SOL_LOGROTATE),console.log(C_.white("logrotate (fd): ")+L.FRANKENDANCER_LOGROTATE),console.log(C_.white("sysctl.d: ")+L.SOL_SYSTEM_CONFIG21),console.log(C_.white("limits.d: ")+L.SOL_NOFILES_CONF),console.log(C_.white("system.conf: ")+L.SOL_SYSTEM_CONF),console.log(C_.white("ledger: ")+t.ledger),console.log(C_.white("accounts: ")+t.accounts),console.log(C_.white("snapshots: ")+t.snapshots),console.log(C_.white("mount type: ")+_.MNT_DISK_TYPE)},"showConfig");import{spawnSync as Ms}from"node:child_process";import DR from"chalk";var Ls=E(_=>{let e=_.NETWORK===l.TESTNET,t=e?c_:t_;_.NODE_TYPE===A.RPC&&(t=X_);let o=I.command("get").description("Get Solana Validator's Information").argument("<cmd>","Subcommands: epoch, slot, catchup, snapshot, contact, config");o.command("epoch").description("Show Validator's Epoch").action(()=>{let i=ps();console.log({epoch:i})}),o.command("ip").description("Show Validator's IP Address").action(()=>{let i="curl ipinfo.io/ip",{stdout:n}=Ms(i,{shell:!0,stdio:"pipe"});console.log(DR.white(`${n}`))}),o.command("slot").description("Show Current Slot").action(()=>{let i=ms();console.log({slot:i})}),o.command("snapshot").alias("sn").option("-m, --minDownloadSpeed <minDownloadSpeed>","Minimum download speed","100").option("-s, --snapshotPath <snapshotPath>","Snapshot Path",_.SNAPSHOTS_PATH).option("-v, --version <version>","Specific Version Node",t).option("-r, --rpcUrl <rpcUrl>","RPC URL",e?"https://api.testnet.solana.com":"https://api.mainnet-beta.solana.com").option("-a, --avorio <version>","Use Avorio Network (Testnet only)",!1).description("Download the latest snapshot").action(i=>{let n=i.minDownloadSpeed,s=i.snapshotPath,r=i.version,T=i.rpcUrl,a=i.avorio;_t(e,n,s,r,T,a)}),o.command("contact").description("Show Validator Contact Information").action(()=>{let n=`${f_()} --ledger /mnt/ledger/ contact-info`;Ms(n,{shell:!0,stdio:"inherit"})}),o.command("config").description("Show Solv Config").alias("c").action(async()=>{dE(_)}),o.command("aa").description("Show Solv AA").option("-c, --client","Show Solv Client Mode AA",!1).action(i=>{Ae.solvAA(),i.client?Ae.installClientMessage():Ae.installMessage()}),o.addHelpCommand("help [cmd]","Get Solana Validator Information")},"getCommands");import{spawnSync as PR}from"node:child_process";var hs=E(()=>{PR("sudo systemctl status relayer.service",{shell:!0,stdio:"inherit"})},"relayerStatus");import{spawnSync as AR}from"node:child_process";var gs=E(()=>{AR("sudo systemctl start relayer.service",{shell:!0,stdio:"inherit"})},"relayerStart");import{spawnSync as UR}from"node:child_process";var Bs=E(()=>{UR("sudo systemctl stop relayer.service",{shell:!0,stdio:"inherit"})},"relayerStop");import{spawnSync as uR}from"node:child_process";var ys=E(()=>{uR("sudo systemctl restart relayer.service",{shell:!0,stdio:"inherit"})},"relayerRestart");import{spawnSync as pR}from"node:child_process";var Ks=E((_=!1)=>{pR(_?"journalctl -u relayer.service -xef | grep ERROR":"journalctl -u relayer.service -xef",{shell:!0,stdio:"inherit"})},"relayerLog");import eo from"chalk";import{spawnSync as MR}from"child_process";import{spawnSync as mR}from"node:child_process";var Gs=E(()=>{mR("sudo systemctl enable relayer.service",{shell:!0,stdio:"inherit"})},"relayerEnable");var ks=E(()=>{let _=I.command("relayer").description("Jito Relayer Commands");_.command("status").description("Show Relayer Status").action(()=>{hs()}),_.command("start").description("Start Relayer").action(()=>{gs()}),_.command("stop").description("Stop Relayer").action(()=>{Bs()}),_.command("log").option("-e, --error","Show Error Logs",!1).description("Show Relayer Logs").action(e=>{Ks(e.error)}),_.command("restart").description("Restart Relayer").action(()=>{ys()}),_.command("enable").description("Enable Relayer").action(()=>{Gs()}),_.command("set:url").option("-u, --url <url>","Set Relayer URL","").description("Set Relayer URL on Validator").action(e=>{if(e.url===""){console.log(eo.red("Please provide a URL"));return}let t=`${f_()} --ledger ${u} set-relayer-config --relayer-url ${e.url}`;console.log(eo.white("Setting Relayer URL ...")),MR(t,{shell:!0,stdio:"inherit"}),console.log(eo.green("\u{1F7E2} Relayer URL Set"))})},"relayerCommands");var Vs=E(_=>{I.command("logrotate").description("Refresh Logrotate").action(()=>{let e=_.VALIDATOR_TYPE==="frankendancer";Qe(e),process.exit(0)})},"logrotateCommand");import{spawnSync as yR}from"node:child_process";import St from"chalk";import{spawnSync as g_}from"node:child_process";import Ue from"chalk";var bs=E(async()=>{console.log(Ue.white("\u{1F4E6} Installing telegraf..."));let _=g_("which apt",{shell:!0,stdio:"pipe"}),e=g_("which yum",{shell:!0,stdio:"pipe"});if(_.stdout.toString().trim()){if(console.log(Ue.white("Detected apt package manager")),g_("sudo rm -f /etc/apt/trusted.gpg",{shell:!0,stdio:"inherit"}),g_("sudo mkdir -p /etc/apt/keyrings",{shell:!0,stdio:"inherit"}),g_("curl -fsSL https://repos.influxdata.com/influxdata-archive_compat.key | sudo tee /etc/apt/keyrings/influxdata-archive_compat.asc > /dev/null",{shell:!0,stdio:"inherit"}),g_("ls -l /etc/apt/keyrings/influxdata-archive_compat.asc",{shell:!0,stdio:"pipe"}).status!==0)throw new Error("Failed to add influxdata GPG key");if(g_('echo "deb [signed-by=/etc/apt/keyrings/influxdata-archive_compat.asc] https://repos.influxdata.com/ubuntu stable main" | sudo tee /etc/apt/sources.list.d/influxdb.list',{shell:!0,stdio:"inherit"}),console.log(Ue.white("Updating package list...")),g_("sudo apt update",{shell:!0,stdio:"inherit"}),console.log(Ue.white("Installing telegraf...")),g_("sudo apt install telegraf -y",{shell:!0,stdio:"inherit"}).status!==0)throw new Error("Failed to install telegraf");console.log(Ue.green("\u2705 Telegraf installed successfully"))}else throw e.stdout.toString().trim()?(console.log(Ue.white("Detected yum package manager")),new Error("Yum-based installation not yet implemented")):new Error("No supported package manager found (apt or yum required)")},"installTelegraf");import{spawnSync as ue}from"node:child_process";import{existsSync as Tt}from"fs";import pe from"chalk";var ws=E(async(_,e,t)=>{console.log(pe.white("\u{1F511} Setting up validator key symlinks..."));let o=`/home/${_}/.secrets`,i=`${o}/validator-keypair.json`,n=`${o}/vote-account-keypair.json`;if(!Tt(e))throw new Error(`Validator key not found at ${e}. Please verify the path.`);Tt(o)||ue(`sudo mkdir -p ${o}`,{shell:!0,stdio:"inherit"}),Tt(i)&&(console.log(pe.yellow(`Removing existing symlink: ${i}`)),ue(`sudo rm -f ${i}`,{shell:!0,stdio:"inherit"})),ue(`sudo ln -s ${e} ${i}`,{shell:!0,stdio:"inherit"}),Tt(t)?(Tt(n)&&(console.log(pe.yellow(`Removing existing symlink: ${n}`)),ue(`sudo rm -f ${n}`,{shell:!0,stdio:"inherit"})),ue(`sudo ln -s ${t} ${n}`,{shell:!0,stdio:"inherit"}),console.log(pe.green("\u2705 Vote account key symlink created"))):console.log(pe.yellow(`\u26A0\uFE0F Vote account key not found at ${t}, skipping`)),ue(`sudo chown -h ${_}:${_} ${o}/*`,{shell:!0,stdio:"inherit"}),console.log(pe.green("\u2705 Validator key symlinks created successfully"))},"setupValidatorKeys");import{spawnSync as to}from"node:child_process";import{writeFileSync as LR}from"fs";import Hs from"chalk";var vs=E(_=>{let{hostname:e,flushInterval:t,interval:o,mountPoints:i,validatorUser:n}=_,s=i.map(r=>`"${r}"`).join(", ");return`[agent]
6591
6591
  hostname = "${e}"
6592
6592
  flush_interval = "${t}"
6593
6593
  interval = "${o}"
@@ -6793,8 +6793,8 @@ if __name__ == "__main__":
6793
6793
  password = "1b91CP@44b3c"
6794
6794
  [outputs.influxdb.tagpass]
6795
6795
  pipeline = ["doublezero"]
6796
- `;let a="/tmp/telegraf.conf.new";oo(a,o,"utf-8"),B_(`sudo mv ${a} ${_}`,{shell:!0,stdio:"inherit"}),B_(`sudo chown root:root ${_}`,{shell:!0,stdio:"inherit"}),B_(`sudo chmod 644 ${_}`,{shell:!0,stdio:"inherit"}),console.log(me.green("\u2705 Telegraf config updated for doublezero"))},"updateTelegrafForDoublezero");import{spawnSync as xs}from"node:child_process";import Qs from"chalk";var lE=E(async()=>{if(console.log(Qs.white("\u{1F504} Restarting telegraf service...")),xs("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}),xs("sudo systemctl restart telegraf.service",{shell:!0,stdio:"inherit"}).status===0)console.log(Qs.green("\u2705 Telegraf service restarted successfully"));else throw new Error("Failed to restart telegraf service")},"restartMonitoring");import{spawnSync as J}from"node:child_process";import{existsSync as z,writeFileSync as NE,readFileSync as gR}from"fs";import{join as oe,dirname as $s}from"path";import{fileURLToPath as qs}from"url";import d_ from"chalk";var Ws=E(async(_,e,t)=>{console.log(d_.white("\u{1F40D} Setting up monitoring Python scripts..."));let o=`/home/${_}`,i=`${o}/monitoring`,n=`${i}/bin`,s=`${i}/scripts`;if(J("python3 -m venv --help",{shell:!0,stdio:"pipe"}).status!==0)if(console.log(d_.white("Installing python3-venv package...")),J("which apt",{shell:!0,stdio:"pipe"}).stdout.toString().trim()){let M=`python${J("python3 --version",{shell:!0,stdio:"pipe",encoding:"utf-8"}).stdout.toString().match(/Python (\d+\.\d+)/)?.[1]||"3"}-venv`;if(J(`sudo apt install -y ${M}`,{shell:!0,stdio:"inherit"}).status!==0)throw new Error(`Failed to install ${M}. Please install it manually: sudo apt install ${M}`)}else throw new Error("python3-venv is not available. Please install it manually.");if(z(i)&&!z(`${n}/pip`)&&(console.log(d_.yellow("Cleaning up incomplete virtual environment...")),J(`sudo rm -rf ${i}`,{shell:!0,stdio:"inherit"})),z(i)||(J(`sudo mkdir -p ${i}`,{shell:!0,stdio:"inherit"}),J(`sudo chown -R ${_}:${_} ${i}`,{shell:!0,stdio:"inherit"})),z(s)||(J(`sudo mkdir -p ${s}`,{shell:!0,stdio:"inherit"}),J(`sudo chown -R ${_}:${_} ${s}`,{shell:!0,stdio:"inherit"})),(!z(n)||!z(`${n}/pip`))&&(console.log(d_.white("Creating Python virtual environment...")),J(`sudo chown -R ${_}:${_} ${i}`,{shell:!0,stdio:"inherit"}),J(`sudo -u ${_} python3 -m venv ${i}`,{shell:!0,stdio:"inherit"}).status!==0))throw new Error("Failed to create Python virtual environment. Make sure python3-venv is installed.");if(!z(`${n}/pip`))throw new Error("Python virtual environment was not created successfully. The pip binary is missing.");console.log(d_.white("Installing Python dependencies..."));let T=`numpy>=1.21.0
6797
- requests>=2.25.0`,a="/tmp/monitoring_requirements.txt";if(NE(a,T,"utf-8"),J(`sudo -u ${_} ${n}/pip install -q -r ${a}`,{shell:!0,stdio:"inherit"}).status!==0)throw new Error("Failed to install Python dependencies");let R=["common.py","solana_rpc.py","request_utils.py","measurement_validator_info.py","output_validator_measurements.py"],C=null,O=qs(import.meta.url),N=$s(O);for(let D=0;D<15;D++){let U=oe(N,"cli","monitoring","scripts");if(z(U)){C=U;break}let M=oe(N,"src","cli","monitoring","scripts");if(z(M)){C=M;break}let V=oe(N,"scripts");if(z(V)&&z(oe(V,"common.py"))){C=V;break}let l_=$s(N);if(l_===N)break;N=l_}if(!C){let D=oe(process.cwd(),"dist","cli","monitoring","scripts");if(z(D))C=D;else{let U=oe(process.cwd(),"src","cli","monitoring","scripts");z(U)&&(C=U)}}if(!C)throw console.error(d_.red("Could not locate monitoring scripts directory.")),console.error(d_.red(`Searched from: ${qs(import.meta.url)}`)),console.error(d_.red(`Current working directory: ${process.cwd()}`)),new Error("Could not find monitoring scripts directory. Please ensure the package is built correctly and scripts are included in the dist folder.");console.log(d_.white(`Using scripts from: ${C}`));for(let D of R){console.log(d_.white(`Copying ${D}...`));let U=oe(C,D),M=`${s}/${D}`,V=`/tmp/${D}`;if(!z(U))throw new Error(`Local script not found: ${U}`);let l_=gR(U,"utf-8");NE(V,l_,"utf-8"),J(`sudo mv ${V} ${M}`,{shell:!0,stdio:"inherit"}),J(`sudo chown ${_}:${_} ${M}`,{shell:!0,stdio:"inherit"})}let S=`from common import ValidatorConfig
6796
+ `;let a="/tmp/telegraf.conf.new";oo(a,o,"utf-8"),B_(`sudo mv ${a} ${_}`,{shell:!0,stdio:"inherit"}),B_(`sudo chown root:root ${_}`,{shell:!0,stdio:"inherit"}),B_(`sudo chmod 644 ${_}`,{shell:!0,stdio:"inherit"}),console.log(me.green("\u2705 Telegraf config updated for doublezero"))},"updateTelegrafForDoublezero");import{spawnSync as xs}from"node:child_process";import Qs from"chalk";var lE=E(async()=>{if(console.log(Qs.white("\u{1F504} Restarting telegraf service...")),xs("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}),xs("sudo systemctl restart telegraf.service",{shell:!0,stdio:"inherit"}).status===0)console.log(Qs.green("\u2705 Telegraf service restarted successfully"));else throw new Error("Failed to restart telegraf service")},"restartMonitoring");import{spawnSync as J}from"node:child_process";import{existsSync as Z,writeFileSync as NE,readFileSync as gR}from"fs";import{join as oe,dirname as $s}from"path";import{fileURLToPath as qs}from"url";import d_ from"chalk";var Ws=E(async(_,e,t)=>{console.log(d_.white("\u{1F40D} Setting up monitoring Python scripts..."));let o=`/home/${_}`,i=`${o}/monitoring`,n=`${i}/bin`,s=`${i}/scripts`;if(J("python3 -m venv --help",{shell:!0,stdio:"pipe"}).status!==0)if(console.log(d_.white("Installing python3-venv package...")),J("which apt",{shell:!0,stdio:"pipe"}).stdout.toString().trim()){let M=`python${J("python3 --version",{shell:!0,stdio:"pipe",encoding:"utf-8"}).stdout.toString().match(/Python (\d+\.\d+)/)?.[1]||"3"}-venv`;if(J(`sudo apt install -y ${M}`,{shell:!0,stdio:"inherit"}).status!==0)throw new Error(`Failed to install ${M}. Please install it manually: sudo apt install ${M}`)}else throw new Error("python3-venv is not available. Please install it manually.");if(Z(i)&&!Z(`${n}/pip`)&&(console.log(d_.yellow("Cleaning up incomplete virtual environment...")),J(`sudo rm -rf ${i}`,{shell:!0,stdio:"inherit"})),Z(i)||(J(`sudo mkdir -p ${i}`,{shell:!0,stdio:"inherit"}),J(`sudo chown -R ${_}:${_} ${i}`,{shell:!0,stdio:"inherit"})),Z(s)||(J(`sudo mkdir -p ${s}`,{shell:!0,stdio:"inherit"}),J(`sudo chown -R ${_}:${_} ${s}`,{shell:!0,stdio:"inherit"})),(!Z(n)||!Z(`${n}/pip`))&&(console.log(d_.white("Creating Python virtual environment...")),J(`sudo chown -R ${_}:${_} ${i}`,{shell:!0,stdio:"inherit"}),J(`sudo -u ${_} python3 -m venv ${i}`,{shell:!0,stdio:"inherit"}).status!==0))throw new Error("Failed to create Python virtual environment. Make sure python3-venv is installed.");if(!Z(`${n}/pip`))throw new Error("Python virtual environment was not created successfully. The pip binary is missing.");console.log(d_.white("Installing Python dependencies..."));let T=`numpy>=1.21.0
6797
+ requests>=2.25.0`,a="/tmp/monitoring_requirements.txt";if(NE(a,T,"utf-8"),J(`sudo -u ${_} ${n}/pip install -q -r ${a}`,{shell:!0,stdio:"inherit"}).status!==0)throw new Error("Failed to install Python dependencies");let R=["common.py","solana_rpc.py","request_utils.py","measurement_validator_info.py","output_validator_measurements.py"],C=null,O=qs(import.meta.url),N=$s(O);for(let D=0;D<15;D++){let U=oe(N,"cli","monitoring","scripts");if(Z(U)){C=U;break}let M=oe(N,"src","cli","monitoring","scripts");if(Z(M)){C=M;break}let V=oe(N,"scripts");if(Z(V)&&Z(oe(V,"common.py"))){C=V;break}let l_=$s(N);if(l_===N)break;N=l_}if(!C){let D=oe(process.cwd(),"dist","cli","monitoring","scripts");if(Z(D))C=D;else{let U=oe(process.cwd(),"src","cli","monitoring","scripts");Z(U)&&(C=U)}}if(!C)throw console.error(d_.red("Could not locate monitoring scripts directory.")),console.error(d_.red(`Searched from: ${qs(import.meta.url)}`)),console.error(d_.red(`Current working directory: ${process.cwd()}`)),new Error("Could not find monitoring scripts directory. Please ensure the package is built correctly and scripts are included in the dist folder.");console.log(d_.white(`Using scripts from: ${C}`));for(let D of R){console.log(d_.white(`Copying ${D}...`));let U=oe(C,D),M=`${s}/${D}`,V=`/tmp/${D}`;if(!Z(U))throw new Error(`Local script not found: ${U}`);let l_=gR(U,"utf-8");NE(V,l_,"utf-8"),J(`sudo mv ${V} ${M}`,{shell:!0,stdio:"inherit"}),J(`sudo chown ${_}:${_} ${M}`,{shell:!0,stdio:"inherit"})}let S=`from common import ValidatorConfig
6798
6798
 
6799
6799
  config = ValidatorConfig(
6800
6800
  validator_name="${t}",
@@ -6848,7 +6848,7 @@ Network: ${e.NETWORK}
6848
6848
  CurrentEpoch: ${_.epoch}
6849
6849
  Epoch has been updated!
6850
6850
  Until Next Epoch: Approximately 2 days`;return"Epoch has been updated!"},"newEpoch"),Kr=UC;import{existsAsync as uC}from"@skeet-framework/utils";import{readFile as pC,writeFile as mC}from"fs/promises";import MC from"chalk";import{homedir as LC}from"os";var hC=E(async()=>{let e=LC().includes("/home/solv")?At:"./currentEpoch.json";if(await uC(e))return JSON.parse(await pC(e,"utf-8"));let t={epoch:0,isLessThan1Hour:!1,isLessThan8Hours:!1,isLessThan1Day:!1};return await mC(e,JSON.stringify(t,null,2),"utf-8"),console.log(MC.white("\u2714\uFE0F Initial epoch data has been created!")),t},"initOrReadEpochFile"),Gr=hC;async function gC(_="@gabrielhicks/solv"){try{let e=`https://registry.npmjs.org/${_}`,t=await fetch(e);if(!t.ok)throw new Error(`HTTP error! status: ${t.status}`);return(await t.json())["dist-tags"].latest}catch(e){return console.error(`Error fetching latest version for package ${_}:`,e),null}}E(gC,"getNpmLatestVersion");var kr=gC;async function BC(){let _=ce(),e=await kr();if(!e)throw new Error("Failed to get NPM API");return console.log("currentVersion:",_),console.log("latestVersion:",e),_===e}E(BC,"isVersionSame");var Vr=BC;import{spawnSync as GC}from"child_process";import{spawnSync as yC}from"node:child_process";var br=E(_=>{try{let e=`solana epoch-info --url '${_}'`,{stdout:t}=yC(e,{shell:!0,stdio:"pipe"}),i=t.toString().split(`
6851
- `),n=i.find(C=>C.includes("Epoch Completed Time:")),s=i.find(C=>C.includes("Epoch Completed Percent:"))?.replace("Epoch Completed Percent:",""),r=Number(i.find(C=>C.includes("Epoch:"))?.replace("Epoch:",""));if(!n||!s||!r)throw new Error("Epoch Completed Time not found");let a=n.split("(")[1].replace(" remaining)","");console.log("remainingTime:",a);let c=/(?:(\d+)day\s*)?(?:(\d+)h\s*)?(?:(\d+)m\s*)?(?:(\d+)s\s*)?/,R=a.match(c);if(R){let C=R[1]?parseInt(R[1]):0,O=R[2]?parseInt(R[2]):0,N=R[3]?parseInt(R[3]):0,S=R[4]?parseInt(R[4]):0,d=C*24*60+O*60+N+Math.floor(S/60);return{epoch:r,day:C,hour:O,min:N,sec:S,totalMinutes:d,epochRemainingTime:a,epochCompletedPercent:s}}else throw new Error("Time information could not be parsed")}catch(e){throw new Error(`getEpochInfoByRust failed: ${e}`)}},"getEpochInfoByRust");var kC=E(async _=>{let e=_.NETWORK===l.TESTNET,t=e?Ut:_.RPC_URL,o=KC(new Date,"yyyy-MM-dd HH:mm:ss");console.log(`Checking Epoch at ${o}`);let i=await Gr(),n=br(t),{mainnetValidatorVoteKey:s,testnetValidatorVoteKey:r}=g(),a=await He(t,k(e?r:s));if(console.log(`Validator is active: ${a.isActive}`),!await Vr()&&_.AUTO_UPDATE)return console.log("Found new version of solv! Updating..."),GC("solv update && solv update --config && solv update --auto",{stdio:"inherit",shell:!0}),"Node has been restarted!";if(i.epoch<n.epoch)return await Kr(n,_),"Epoch has been updated!";let R=n.totalMinutes,C=[yr,Br,gr];for(let O of C)if(await O(R,i,n,_))break;return"Epoch has not been changed!"},"epochTimer"),wr=kC;var vr=E(_=>{I.command("epochTimer").description("Check Solana Epoch Timer").action(async()=>{await wr(_),process.exit(0)})},"epochTimerCommands");import eT from"inquirer";import{join as xr}from"path";import{spawnSync as he}from"node:child_process";import r_ from"chalk";import{spawnSync as VC}from"node:child_process";var bC=E((_,e,t,o="pipe",i="~/.ssh/id_rsa")=>{let n;try{let s=VC(`ssh -i ${i} -o StrictHostKeyChecking=no solv@${_} -p 22 'cd ~ && source ~/.profile && ${e}'`,{shell:!0,stdio:o});return s.status!==0?(console.log(`\u26A0\uFE0F CMD Failed. Please check your SSH connection.
6851
+ `),n=i.find(C=>C.includes("Epoch Completed Time:")),s=i.find(C=>C.includes("Epoch Completed Percent:"))?.replace("Epoch Completed Percent:",""),r=Number(i.find(C=>C.includes("Epoch:"))?.replace("Epoch:",""));if(!n||!s||!r)throw new Error("Epoch Completed Time not found");let a=n.split("(")[1].replace(" remaining)","");console.log("remainingTime:",a);let c=/(?:(\d+)day\s*)?(?:(\d+)h\s*)?(?:(\d+)m\s*)?(?:(\d+)s\s*)?/,R=a.match(c);if(R){let C=R[1]?parseInt(R[1]):0,O=R[2]?parseInt(R[2]):0,N=R[3]?parseInt(R[3]):0,S=R[4]?parseInt(R[4]):0,d=C*24*60+O*60+N+Math.floor(S/60);return{epoch:r,day:C,hour:O,min:N,sec:S,totalMinutes:d,epochRemainingTime:a,epochCompletedPercent:s}}else throw new Error("Time information could not be parsed")}catch(e){throw new Error(`getEpochInfoByRust failed: ${e}`)}},"getEpochInfoByRust");var kC=E(async _=>{let e=_.NETWORK===l.TESTNET,t=e?Ut:_.RPC_URL,o=KC(new Date,"yyyy-MM-dd HH:mm:ss");console.log(`Checking Epoch at ${o}`);let i=await Gr(),n=br(t),{mainnetValidatorVoteKey:s,testnetValidatorVoteKey:r}=g(),a=await He(t,k(e?r:s));if(console.log(`Validator is active: ${a.isActive}`),!await Vr()&&_.AUTO_UPDATE)return console.log("Found new version of solv! Updating..."),GC("solv update && solv update --config && solv update --auto",{stdio:"inherit",shell:!0}),"Node has been restarted!";if(i.epoch<n.epoch)return await Kr(n,_),"Epoch has been updated!";let R=n.totalMinutes,C=[yr,Br,gr];for(let O of C)if(await O(R,i,n,_))break;return"Epoch has not been changed!"},"epochTimer"),wr=kC;var vr=E(_=>{I.command("epochTimer").description("Check Solana Epoch Timer").action(async()=>{await wr(_),process.exit(0)})},"epochTimerCommands");import eT from"inquirer";import{join as xr}from"path";import{spawnSync as he}from"node:child_process";import T_ from"chalk";import{spawnSync as VC}from"node:child_process";var bC=E((_,e,t,o="pipe",i="~/.ssh/id_rsa")=>{let n;try{let s=VC(`ssh -i ${i} -o StrictHostKeyChecking=no solv@${_} -p 22 'cd ~ && source ~/.profile && ${e}'`,{shell:!0,stdio:o});return s.status!==0?(console.log(`\u26A0\uFE0F CMD Failed. Please check your SSH connection.
6852
6852
  $ ssh solv@${_}
6853
6853
 
6854
6854
  Failed Cmd: ${e}`),n={status:s.status,stdout:String(s.stdout),stderr:s.stderr.toString()},n):(n={status:s.status,stdout:s.stdout.toString(),stderr:s.stderr.toString()},n)}catch(s){return console.log(`scpSSH Error: ${s}`),n={status:null,stdout:"",stderr:String(s)},n}},"scpSSH"),uE=bC;import Hr from"chalk";var wC=E((_,e,t)=>{console.log(Hr.white("\u{1F50D} Checking If Destination Validator Key is the same..."));let o=k(_).trim(),i=uE(e,`solana-keygen pubkey ${_}`,t).stdout.toString().trim();return o!==i?(console.log(Hr.yellow(`\u26A0\uFE0F Destination Identity Key is different.
@@ -6856,37 +6856,37 @@ Please check your Validator
6856
6856
  $ ssh ${t}@${e}
6857
6857
 
6858
6858
  Local Identity Key: ${o}
6859
- Destination Identity Key: ${i}`)),!1):!0},"checkValidatorKey"),Me=wC;var vC="agave-validator -l /mnt/ledger",HC="sudo fdctl",YC="--config /home/solv/firedancer/config.toml ",JC=E(_=>_==="agave"?[vC,""]:[HC,YC],"getSolanaCLIActive"),Le=JC;var Yr="agave-validator -l /mnt/ledger",xC=E(()=>{try{return Yr}catch(_){return console.error(_),Yr}},"getSolanaCLIAgave"),pE=xC;import Fo from"chalk";var mE=E(async(_,e)=>{try{console.log(Fo.white("\u{1F50D} Detecting client type from remote configuration..."));let t=uE(_,"cat /home/solv/solv4.config.json",e,"pipe");if(t.status!==0)return{client:"agave",validatorType:F.AGAVE,success:!1,error:"Could not read remote configuration file"};let i=JSON.parse(t.stdout).VALIDATOR_TYPE,n;switch(i){case F.AGAVE:n="agave";break;case F.FRANKENDANCER:n="frankendancer";break;case F.JITO:n="agave";break;default:n="agave"}return console.log(Fo.green(`\u2705 Detected remote client type: ${n} (${i})`)),{client:n,validatorType:i,success:!0}}catch(t){return console.log(Fo.yellow(`\u26A0\uFE0F Could not auto-detect client type: ${t}`)),{client:"agave",validatorType:F.AGAVE,success:!1,error:String(t)}}},"getRemoteClientType");import{readFile as QC}from"fs/promises";import Io from"chalk";import{existsSync as $C}from"fs";var ME=E(async()=>{try{console.log(Io.white("\u{1F50D} Detecting local client type from configuration..."));let _="/home/solv/solv4.config.json";if(!$C(_))return{client:"agave",validatorType:F.AGAVE,success:!1,error:"Local configuration file not found"};let e=await QC(_,"utf-8"),o=JSON.parse(e).VALIDATOR_TYPE,i;switch(o){case F.AGAVE:i="agave";break;case F.FRANKENDANCER:i="frankendancer";break;case F.JITO:i="agave";break;default:i="agave"}return console.log(Io.green(`\u2705 Detected local client type: ${i} (${o})`)),{client:i,validatorType:o,success:!0}}catch(_){return console.log(Io.yellow(`\u26A0\uFE0F Could not auto-detect local client type: ${_}`)),{client:"agave",validatorType:F.AGAVE,success:!1,error:String(_)}}},"getLocalClientType");var LE=xr(b,q_),Jr=xr(b,$_),Qr=E(async(_,e,t,o,i=!0)=>{let n=t.NETWORK===l.TESTNET,s=t.NODE_TYPE===A.RPC,r=n?G:x;s&&(r=G);let T=await ME(),a=await mE(_,o),c=T.success?T.client:"agave",R=a.success?a.client:"agave";console.log(r_.green(`\u2705 Local client: ${c}, Remote client: ${R}`));let[C,O]=Le(c),[N,S]=Le(R),d=pE();if(!Me(r,_,o))return;if(i){console.log(r_.white("\u{1F7E2} Waiting for restart window..."));let Ke=`ssh -i ~/.ssh/id_rsa -o StrictHostKeyChecking=no ${o}@${_} -p 22 'cd ~ && source ~/.profile && ${d} wait-for-restart-window --min-idle-time 2 --skip-new-snapshot-check'`;if(he(Ke,{shell:!0,stdio:"inherit"}).status!==0){console.log(r_.yellow(`\u26A0\uFE0F wait-for-restart-window Failed. Please check your Validator
6859
+ Destination Identity Key: ${i}`)),!1):!0},"checkValidatorKey"),Me=wC;var vC="agave-validator -l /mnt/ledger",HC="sudo fdctl",YC="--config /home/solv/firedancer/config.toml ",JC=E(_=>_==="agave"?[vC,""]:[HC,YC],"getSolanaCLIActive"),Le=JC;var Yr="agave-validator -l /mnt/ledger",xC=E(()=>{try{return Yr}catch(_){return console.error(_),Yr}},"getSolanaCLIAgave"),pE=xC;import Fo from"chalk";var mE=E(async(_,e)=>{try{console.log(Fo.white("\u{1F50D} Detecting client type from remote configuration..."));let t=uE(_,"cat /home/solv/solv4.config.json",e,"pipe");if(t.status!==0)return{client:"agave",validatorType:F.AGAVE,success:!1,error:"Could not read remote configuration file"};let i=JSON.parse(t.stdout).VALIDATOR_TYPE,n;switch(i){case F.AGAVE:n="agave";break;case F.FRANKENDANCER:n="frankendancer";break;case F.JITO:n="agave";break;default:n="agave"}return console.log(Fo.green(`\u2705 Detected remote client type: ${n} (${i})`)),{client:n,validatorType:i,success:!0}}catch(t){return console.log(Fo.yellow(`\u26A0\uFE0F Could not auto-detect client type: ${t}`)),{client:"agave",validatorType:F.AGAVE,success:!1,error:String(t)}}},"getRemoteClientType");import{readFile as QC}from"fs/promises";import Io from"chalk";import{existsSync as $C}from"fs";var ME=E(async()=>{try{console.log(Io.white("\u{1F50D} Detecting local client type from configuration..."));let _="/home/solv/solv4.config.json";if(!$C(_))return{client:"agave",validatorType:F.AGAVE,success:!1,error:"Local configuration file not found"};let e=await QC(_,"utf-8"),o=JSON.parse(e).VALIDATOR_TYPE,i;switch(o){case F.AGAVE:i="agave";break;case F.FRANKENDANCER:i="frankendancer";break;case F.JITO:i="agave";break;default:i="agave"}return console.log(Io.green(`\u2705 Detected local client type: ${i} (${o})`)),{client:i,validatorType:o,success:!0}}catch(_){return console.log(Io.yellow(`\u26A0\uFE0F Could not auto-detect local client type: ${_}`)),{client:"agave",validatorType:F.AGAVE,success:!1,error:String(_)}}},"getLocalClientType");var LE=xr(b,q_),Jr=xr(b,$_),Qr=E(async(_,e,t,o,i=!0)=>{let n=t.NETWORK===l.TESTNET,s=t.NODE_TYPE===A.RPC,r=n?G:x;s&&(r=G);let T=await ME(),a=await mE(_,o),c=T.success?T.client:"agave",R=a.success?a.client:"agave";console.log(T_.green(`\u2705 Local client: ${c}, Remote client: ${R}`));let[C,O]=Le(c),[N,S]=Le(R),d=pE();if(!Me(r,_,o))return;if(i){console.log(T_.white("\u{1F7E2} Waiting for restart window..."));let Ke=`ssh -i ~/.ssh/id_rsa -o StrictHostKeyChecking=no ${o}@${_} -p 22 'cd ~ && source ~/.profile && ${d} wait-for-restart-window --min-idle-time 2 --skip-new-snapshot-check'`;if(he(Ke,{shell:!0,stdio:"inherit"}).status!==0){console.log(T_.yellow(`\u26A0\uFE0F wait-for-restart-window Failed. Please check your Validator
6860
6860
  $ ssh ${o}@${_}
6861
6861
 
6862
- Failed Cmd: ${d} wait-for-restart-window --min-idle-time 2 --skip-new-snapshot-check`));return}}console.log(r_.white("\u{1F7E2} Setting identity on the remote validator..."));let f=`ssh -i ~/.ssh/id_rsa -o StrictHostKeyChecking=no ${o}@${_} -p 22 'cd ~ && source ~/.profile && ${N} set-identity ${S}${LE}'`;if(he(f,{shell:!0,stdio:"inherit"}).status!==0){console.log(r_.yellow(`\u26A0\uFE0F Set Identity Failed. Please check your Validator
6862
+ Failed Cmd: ${d} wait-for-restart-window --min-idle-time 2 --skip-new-snapshot-check`));return}}console.log(T_.white("\u{1F7E2} Setting identity on the remote validator..."));let f=`ssh -i ~/.ssh/id_rsa -o StrictHostKeyChecking=no ${o}@${_} -p 22 'cd ~ && source ~/.profile && ${N} set-identity ${S}${LE}'`;if(he(f,{shell:!0,stdio:"inherit"}).status!==0){console.log(T_.yellow(`\u26A0\uFE0F Set Identity Failed. Please check your Validator
6863
6863
  $ ssh ${o}@${_}
6864
6864
 
6865
- Failed Cmd: ${N} set-identity ${S}${LE}`));return}if(console.log(r_.white("\u{1F7E2} Changing the Symlink to the new validator keypair...")),he(`ssh -i ~/.ssh/id_rsa -o StrictHostKeyChecking=no ${o}@${_} -p 22 'cd ~ && source ~/.profile && ln -sf ${LE} ${Jr}'`,{shell:!0,stdio:"inherit"}).status!==0){console.log(r_.yellow(`\u26A0\uFE0F Chaning Identity Key Symlink Failed. Please check your Validator
6865
+ Failed Cmd: ${N} set-identity ${S}${LE}`));return}if(console.log(T_.white("\u{1F7E2} Changing the Symlink to the new validator keypair...")),he(`ssh -i ~/.ssh/id_rsa -o StrictHostKeyChecking=no ${o}@${_} -p 22 'cd ~ && source ~/.profile && ln -sf ${LE} ${Jr}'`,{shell:!0,stdio:"inherit"}).status!==0){console.log(T_.yellow(`\u26A0\uFE0F Chaning Identity Key Symlink Failed. Please check your Validator
6866
6866
  $ ssh ${o}@${_}
6867
6867
 
6868
- Failed Cmd: ln -sf ${LE} ${Jr}`));return}if(console.log(r_.white("\u{1F7E2} Uploading the tower file to the new validator...")),he(`scp ${o}@${_}:${u}/tower-1_9-${e}.bin ${u}`,{shell:!0,stdio:"inherit"}).status!==0){console.log(r_.yellow(`\u26A0\uFE0F Upload Tower File Failed. Please check your tower file
6868
+ Failed Cmd: ln -sf ${LE} ${Jr}`));return}if(console.log(T_.white("\u{1F7E2} Uploading the tower file to the new validator...")),he(`scp ${o}@${_}:${u}/tower-1_9-${e}.bin ${u}`,{shell:!0,stdio:"inherit"}).status!==0){console.log(T_.yellow(`\u26A0\uFE0F Upload Tower File Failed. Please check your tower file
6869
6869
  $ ssh ${o}@${_}
6870
6870
 
6871
- Failed Cmd: scp ${o}@${_}:${u}/tower-1_9-${e}.bin ${u}`));return}if(console.log(r_.white("\u{1F7E2} Setting identity on the local validator...")),he(`${C} set-identity ${O}--require-tower ${r}`,{shell:!0,stdio:"inherit"}).status!==0){console.log(r_.yellow(`\u26A0\uFE0F Set Identity Failed. Please check your Validator
6871
+ Failed Cmd: scp ${o}@${_}:${u}/tower-1_9-${e}.bin ${u}`));return}if(console.log(T_.white("\u{1F7E2} Setting identity on the local validator...")),he(`${C} set-identity ${O}--require-tower ${r}`,{shell:!0,stdio:"inherit"}).status!==0){console.log(T_.yellow(`\u26A0\uFE0F Set Identity Failed. Please check your Validator
6872
6872
 
6873
6873
  Failed Cmd: ${C} set-identity ${O}${r}
6874
- ln -sf ${r} ${p}`));return}if(he(`ln -sf ${r} ${p}`,{shell:!0,stdio:"inherit"}).status!==0){console.log(r_.yellow(`\u26A0\uFE0F Chaning Identity Key Symlink Failed. Please check your Validator
6874
+ ln -sf ${r} ${p}`));return}if(he(`ln -sf ${r} ${p}`,{shell:!0,stdio:"inherit"}).status!==0){console.log(T_.yellow(`\u26A0\uFE0F Chaning Identity Key Symlink Failed. Please check your Validator
6875
6875
 
6876
- Failed Cmd: ln -sf ${r} ${p}`));return}console.log(r_.white("\u{1F7E2} Identity changed successfully!")),await B({IS_DUMMY:!1})},"changeIdentityIncoming");import{join as Wr}from"path";import Z from"chalk";import{spawnSync as ge}from"node:child_process";var $r=Wr(b,q_),qC=Wr(b,$_),qr="~/.ssh/id_rsa",Xr=E(async(_,e,t,o,i=!0)=>{let n=t.NETWORK===l.TESTNET,s=t.NODE_TYPE===A.RPC,r=n?G:x;s&&(r=G);let T=await ME(),a=await mE(_,o),c=T.success?T.client:"agave",R=a.success?a.client:"agave";console.log(Z.green(`\u2705 Local client: ${c}, Remote client: ${R}`));let[C,O]=Le(c),[N,S]=Le(R),d=pE();if(!Me(r,_,o))return;let f=`${d} wait-for-restart-window --min-idle-time 2 --skip-new-snapshot-check`,D=`${C} set-identity ${O}${$r}`,U=`ln -sf ${$r} ${qC}`,M=`scp ${u}/tower-1_9-${e}.bin ${o}@${_}:${u}`,V=`${N} set-identity ${S}--require-tower ${r}`,l_=`ln -sf ${r} ${p}`;if(i&&(console.log(Z.white("\u{1F7E2} Waiting for restart window...")),ge(f,{shell:!0,stdio:"inherit"}).status!==0)){console.log(Z.yellow(`\u26A0\uFE0F wait-for-restart-window Failed. Please check your Validator
6876
+ Failed Cmd: ln -sf ${r} ${p}`));return}console.log(T_.white("\u{1F7E2} Identity changed successfully!")),await B({IS_DUMMY:!1})},"changeIdentityIncoming");import{join as Wr}from"path";import __ from"chalk";import{spawnSync as ge}from"node:child_process";var $r=Wr(b,q_),qC=Wr(b,$_),qr="~/.ssh/id_rsa",Xr=E(async(_,e,t,o,i=!0)=>{let n=t.NETWORK===l.TESTNET,s=t.NODE_TYPE===A.RPC,r=n?G:x;s&&(r=G);let T=await ME(),a=await mE(_,o),c=T.success?T.client:"agave",R=a.success?a.client:"agave";console.log(__.green(`\u2705 Local client: ${c}, Remote client: ${R}`));let[C,O]=Le(c),[N,S]=Le(R),d=pE();if(!Me(r,_,o))return;let f=`${d} wait-for-restart-window --min-idle-time 2 --skip-new-snapshot-check`,D=`${C} set-identity ${O}${$r}`,U=`ln -sf ${$r} ${qC}`,M=`scp ${u}/tower-1_9-${e}.bin ${o}@${_}:${u}`,V=`${N} set-identity ${S}--require-tower ${r}`,l_=`ln -sf ${r} ${p}`;if(i&&(console.log(__.white("\u{1F7E2} Waiting for restart window...")),ge(f,{shell:!0,stdio:"inherit"}).status!==0)){console.log(__.yellow(`\u26A0\uFE0F wait-for-restart-window Failed. Please check your Validator
6877
6877
 
6878
- Failed Cmd: ${f}`));return}if(console.log(Z.white("\u{1F7E2} Setting identity on the new validator...")),ge(D,{shell:!0,stdio:"inherit"}).status!==0){console.log(Z.yellow(`\u26A0\uFE0F set-identity Failed. Please check your Validator
6878
+ Failed Cmd: ${f}`));return}if(console.log(__.white("\u{1F7E2} Setting identity on the new validator...")),ge(D,{shell:!0,stdio:"inherit"}).status!==0){console.log(__.yellow(`\u26A0\uFE0F set-identity Failed. Please check your Validator
6879
6879
 
6880
- Failed Cmd: ${D}`));return}if(console.log(Z.white("\u{1F7E2} Changing the Symlink to the new validator keypair...")),ge(U,{shell:!0,stdio:"inherit"}).status!==0){console.log(Z.yellow(`\u26A0\uFE0F Symlink Failed. Please check your Validator
6880
+ Failed Cmd: ${D}`));return}if(console.log(__.white("\u{1F7E2} Changing the Symlink to the new validator keypair...")),ge(U,{shell:!0,stdio:"inherit"}).status!==0){console.log(__.yellow(`\u26A0\uFE0F Symlink Failed. Please check your Validator
6881
6881
 
6882
- Failed Cmd: ${U}`));return}if(console.log(Z.white("\u{1F7E2} Uploading the tower file to the new validator...")),ge(M,{shell:!0,stdio:"inherit"}).status!==0){console.log(Z.yellow(`\u26A0\uFE0F Upload Tower File Failed. Please check your Validator
6882
+ Failed Cmd: ${U}`));return}if(console.log(__.white("\u{1F7E2} Uploading the tower file to the new validator...")),ge(M,{shell:!0,stdio:"inherit"}).status!==0){console.log(__.yellow(`\u26A0\uFE0F Upload Tower File Failed. Please check your Validator
6883
6883
 
6884
- Failed Cmd: ${M}`));return}console.log(Z.white("\u{1F7E2} Setting identity on the new validator..."));let NT=`ssh -i ${qr} -o StrictHostKeyChecking=no ${o}@${_} -p 22 'cd ~ && source ~/.profile && ${V}'`;ge(NT,{shell:!0,stdio:"inherit"}).status!==0&&console.log(Z.yellow(`\u26A0\uFE0F set-identity Failed. Please check your Validator
6884
+ Failed Cmd: ${M}`));return}console.log(__.white("\u{1F7E2} Setting identity on the new validator..."));let NT=`ssh -i ${qr} -o StrictHostKeyChecking=no ${o}@${_} -p 22 'cd ~ && source ~/.profile && ${V}'`;ge(NT,{shell:!0,stdio:"inherit"}).status!==0&&console.log(__.yellow(`\u26A0\uFE0F set-identity Failed. Please check your Validator
6885
6885
  $ ssh ${o}@${_}
6886
6886
 
6887
- Failed Cmd: ${V}`)),console.log(Z.white("\u{1F7E2} Changing the Symlink to the new validator keypair..."));let OT=`ssh -i ${qr} -o StrictHostKeyChecking=no ${o}@${_} -p 22 'cd ~ && source ~/.profile && ${l_}'`;if(ge(OT,{shell:!0,stdio:"inherit"}).status!==0){console.log(Z.yellow(`\u26A0\uFE0F Symlink Failed. Please check your Validator
6887
+ Failed Cmd: ${V}`)),console.log(__.white("\u{1F7E2} Changing the Symlink to the new validator keypair..."));let OT=`ssh -i ${qr} -o StrictHostKeyChecking=no ${o}@${_} -p 22 'cd ~ && source ~/.profile && ${l_}'`;if(ge(OT,{shell:!0,stdio:"inherit"}).status!==0){console.log(__.yellow(`\u26A0\uFE0F Symlink Failed. Please check your Validator
6888
6888
 
6889
- Failed Cmd: ${l_}`));return}console.log(Z.white("\u{1F7E2} Identity changed successfully!")),await B({IS_DUMMY:!0})},"changeIdentityOutgoing");import{spawnSync as WC}from"node:child_process";function jr(_,e){let t=`ssh -o BatchMode=yes -o ConnectTimeout=5 solv@${_} exit`;return WC(t,{shell:!0,stdio:"inherit"}).status===0}E(jr,"checkSSHConnection");import Ct from"chalk";import{join as Zr}from"path";import{spawnSync as Be}from"node:child_process";import S_ from"chalk";var hE=Zr(b,q_),zr=Zr(b,$_),_T=E(async(_,e,t,o,i=!0)=>{let n=t.NETWORK===l.TESTNET,s=t.NODE_TYPE===A.RPC,r=n?G:x;if(s&&(r=G),!Me(r,_,o))return;let a=uo,c=po;if(i){console.log(S_.white("\u{1F7E2} Waiting for restart window..."));let P=`ssh -i ~/.ssh/id_rsa -o StrictHostKeyChecking=no ${o}@${_} -p 22 'cd ~ && source ~/.profile && ${a} -l ${u} wait-for-restart-window --min-idle-time 2 --skip-new-snapshot-check'`;if(Be(P,{shell:!0,stdio:"inherit"}).status!==0){console.log(S_.yellow(`\u26A0\uFE0F wait-for-restart-window Failed. Please check your Validator
6889
+ Failed Cmd: ${l_}`));return}console.log(__.white("\u{1F7E2} Identity changed successfully!")),await B({IS_DUMMY:!0})},"changeIdentityOutgoing");import{spawnSync as WC}from"node:child_process";function jr(_,e){let t=`ssh -o BatchMode=yes -o ConnectTimeout=5 solv@${_} exit`;return WC(t,{shell:!0,stdio:"inherit"}).status===0}E(jr,"checkSSHConnection");import Ct from"chalk";import{join as Zr}from"path";import{spawnSync as Be}from"node:child_process";import S_ from"chalk";var hE=Zr(b,q_),zr=Zr(b,$_),_T=E(async(_,e,t,o,i=!0)=>{let n=t.NETWORK===l.TESTNET,s=t.NODE_TYPE===A.RPC,r=n?G:x;if(s&&(r=G),!Me(r,_,o))return;let a=uo,c=po;if(i){console.log(S_.white("\u{1F7E2} Waiting for restart window..."));let P=`ssh -i ~/.ssh/id_rsa -o StrictHostKeyChecking=no ${o}@${_} -p 22 'cd ~ && source ~/.profile && ${a} -l ${u} wait-for-restart-window --min-idle-time 2 --skip-new-snapshot-check'`;if(Be(P,{shell:!0,stdio:"inherit"}).status!==0){console.log(S_.yellow(`\u26A0\uFE0F wait-for-restart-window Failed. Please check your Validator
6890
6890
  $ ssh ${o}@${_}
6891
6891
 
6892
6892
  Failed Cmd: ${a} -l ${u} wait-for-restart-window --min-idle-time 2 --skip-new-snapshot-check`));return}}console.log(S_.white("\u{1F7E2} Setting identity on the new validator..."));let R=`ssh -i ~/.ssh/id_rsa -o StrictHostKeyChecking=no ${o}@${_} -p 22 'cd ~ && source ~/.profile && ${a} -l ${u} set-identity ${hE}'`;if(Be(R,{shell:!0,stdio:"inherit"}).status!==0){console.log(S_.yellow(`\u26A0\uFE0F Set Identity Failed. Please check your Validator
@@ -6904,14 +6904,14 @@ Failed Cmd: ${c} -l ${u} set-identity ${r}
6904
6904
  ln -sf ${r} ${p}`));return}if(Be(`ln -sf ${r} ${p}`,{shell:!0,stdio:"inherit"}).status!==0){console.log(S_.yellow(`\u26A0\uFE0F Chaning Identity Key Symlink Failed. Please check your Validator
6905
6905
 
6906
6906
  Failed Cmd: ln -sf ${r} ${p}`));return}console.log(S_.white("\u{1F7E2} Identity changed successfully!")),await B({IS_DUMMY:!1})},"changeIdentityIncomingV1toV2");var XC=["Incoming","Outgoing"],tT=E(async(_,e)=>{_.command("switch").option("--ip <ip>","IP Address of the New Validator","").option("--switchType <switchType>","Switch Type","").option("--v2-migrate-incoming","Switch V1 to V2 Incoming",!1).option("--user <user>","SSH User","solv").option("--unsafe","Switch without waiting for a restart window",!1).description("Switch Validator Identity with No Downtime").action(async t=>{try{let o=e.NETWORK===l.TESTNET,i=e.NODE_TYPE===A.RPC,n=t.unsafe===!1,s=o?G:x;i&&(s=G);let r=t.user,T=k(s),a=t.switchType,c=t.ip;if(a===""||c===""||r===""){let C=await eT.prompt([{name:"switchType",type:"list",message:"Which switch type do you want to perform?",choices:["Incoming","Outgoing"]},{name:"ip",type:"input",message:"What is the IP address of the new validator?",default(){return"1.1.1.1"}},{name:"user",type:"list",message:"Which user would you want to SSH as?",choices:["solv"]}]);a=C.switchType,c=C.ip,r=C.user}if(!XC.includes(a)){console.log(Ct.yellow(`\u26A0\uFE0F Invalid Switch Type
6907
- You can choose only Incoming or Outgoing`));return}if(!jr(c,r)){console.log("SSH Connection Failed");return}if(a==="Incoming"){if(t.v2MigrateIncoming){(await eT.prompt([{name:"confirm",type:"confirm",message:"Are you sure you want to migrate V1 to V2 Incoming? This node must be running V2 and the remote node must be running V1."}])).confirm||(console.log(Ct.cyan("Exiting...\u{1F31B}")),process.exit(0)),console.log(Ct.white("\u{1F7E2} Migrating V1 to V2 Incoming...")),await _T(c,T,e,r,n);return}await Qr(c,T,e,r,n)}else await Xr(c,T,e,r,n);process.exit(0)}catch(o){o.message.includes("User force closed the prompt")&&(console.error(Ct.cyan("Exiting...\u{1F31B}")),process.exit(0)),console.error(Ct.red(`Switch Error: ${o.message}`)),process.exit(0)}})},"switchCommand");import{spawnSync as jC}from"node:child_process";var zC=E((_="306450862",e=u,t=O_)=>{try{let o=`agave-ledger-tool --ledger ${e} create-snapshot --incremental --snapshot-archive-path ${t} --hard-fork ${_} -- ${_} ${e}`;console.log("Parameters to createSnapshot:",_,e,t),console.log("Command:",o);let i=jC(o,{shell:!0,stdio:"pipe",cwd:e});if(i.status!==0)throw new Error(`createSnapshot: ${i.error}`)}catch(o){throw new Error(`createSnapshot: ${o}`)}},"createSnapshot"),ET=zC;import ye from"inquirer";import sd from"dotenv";import ne from"chalk";var gE={SOL:{tokenMint:"So11111111111111111111111111111111111111112",associationAccount:"4Vwkpk3DTVrTGnUQTazsgQ1wxtU9QwZTmAXDaQRHg9Ra",decimal:9},USDC:{tokenMint:"EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",associationAccount:"J8sqx9ZEoPRqboFAXK3c1R38zm41tRNJgUn2FzyeYQDj",decimal:6},elSOL:{tokenMint:yE,associationAccount:"",decimal:9},JitoSOL:{tokenMint:"J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn",associationAccount:"HPj87TFMPZfm5nk1HmTH9a382RXn7h9oWftiFr3Xs12a",decimal:9},mSOL:{tokenMint:"mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So",associationAccount:"8CX5tE9KvJ59HcoXwWf6tCZoRuz2JFSmunnbKC1ryaK9",decimal:9},bSOL:{tokenMint:"bSo13r4TkiE4KumL71LsHTPpL2euBYLFx6h9HP3piy1",associationAccount:"782MdvLby3VfvKdfDYn9tX3DfNAtg7TcytNNFuepcoMH",decimal:9},EPCT:{tokenMint:"CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP",associationAccount:"BhR2L6J5q3xF1TxReXyHjaUh4MF6qV99tMsipzPAKeB",decimal:6},JUP:{tokenMint:"JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN",associationAccount:"212yg3Ev7khq4p1mESFGenF4nWefmkbC8f7mHM68j4vg",decimal:6},BONK:{tokenMint:"DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263",associationAccount:"61Ndjv9392jPRVGALdYgjjxGYa6TT6Gn2WLDSsmugE6U",decimal:5},JTO:{tokenMint:"jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL",associationAccount:"2c9qVh8RQ6j2E2VdAEcCrRXMrd6g1vvPNZvAR6sbaGWo",decimal:9}},fo={So11111111111111111111111111111111111111112:{symbol:"SOL",tokenMint:Ot,associationAccount:"4Vwkpk3DTVrTGnUQTazsgQ1wxtU9QwZTmAXDaQRHg9Ra",decimal:9},EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v:{symbol:"USDC",tokenMint:Ft,associationAccount:"J8sqx9ZEoPRqboFAXK3c1R38zm41tRNJgUn2FzyeYQDj",decimal:6},ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC:{symbol:"elSOL",tokenMint:yE,associationAccount:"",decimal:9},J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn:{symbol:"jitoSOL",tokenMint:"J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn",associationAccount:"HPj87TFMPZfm5nk1HmTH9a382RXn7h9oWftiFr3Xs12a",decimal:9},mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So:{symbol:"mSOL",tokenMint:"mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So",associationAccount:"8CX5tE9KvJ59HcoXwWf6tCZoRuz2JFSmunnbKC1ryaK9",decimal:9},bSo13r4TkiE4KumL71LsHTPpL2euBYLFx6h9HP3piy1:{symbol:"bSOL",tokenMint:"bSo13r4TkiE4KumL71LsHTPpL2euBYLFx6h9HP3piy1",associationAccount:"782MdvLby3VfvKdfDYn9tX3DfNAtg7TcytNNFuepcoMH",decimal:9},CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP:{symbol:"EPCT",tokenMint:"CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP",associationAccount:"BhR2L6J5q3xF1TxReXyHjaUh4MF6qV99tMsipzPAKeB",decimal:6},JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN:{symbol:"JUP",tokenMint:"JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN",associationAccount:"212yg3Ev7khq4p1mESFGenF4nWefmkbC8f7mHM68j4vg",decimal:6},DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263:{symbol:"BONK",tokenMint:"DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263",associationAccount:"61Ndjv9392jPRVGALdYgjjxGYa6TT6Gn2WLDSsmugE6U",decimal:5},jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL:{symbol:"JTO",tokenMint:"jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL",associationAccount:"2c9qVh8RQ6j2E2VdAEcCrRXMrd6g1vvPNZvAR6sbaGWo",decimal:9}};import{readFile as ed}from"fs/promises";import{Connection as td,Keypair as Ed,VersionedTransaction as od}from"@solana/web3.js";import __ from"chalk";import id from"inquirer";import nd from"dotenv";var ZC=E(async(_,e,t,o,i)=>{try{let n=`${_}/quote?inputMint=${t}&outputMint=${o}&amount=${i}`,s=await fetch(n,{method:"GET",headers:{"Content-Type":"application/json","x-api-key":e,Authorization:`Bearer ${e}`}});return s.status===429?"Too many requests, please try again later":s.status===401?"Unauthorized, please check your API key":await s.json()}catch(n){throw new Error(`Error getJupiterQuote: ${n}`)}},"getJupiterQuote"),oT=ZC;var _d=E(async(_,e,t,o)=>{try{let i=t.outputMint,n,s=yo[i];s?n={swapRequest:{quoteResponse:t,userPublicKey:o,feeAccount:s,dynamicComputeUnitLimit:!0,prioritizationFeeLamports:"auto",dynamicSlippage:{maxBps:500}}}:n={swapRequest:{quoteResponse:t,userPublicKey:o,dynamicComputeUnitLimit:!0,prioritizationFeeLamports:"auto",dynamicSlippage:{maxBps:500}}};let r=`${_}/swap`,T=await fetch(r,{method:"POST",headers:{"Content-Type":"application/json","x-api-key":e,Authorization:`Bearer ${e}`},body:JSON.stringify(n.swapRequest)});return T.status===429?"Too many requests, please try again later":await T.json()}catch(i){throw new Error(`Error postJupiterSwap: ${i}`)}},"postJupiterSwap"),iT=_d;nd.config();var nT=E(async(_,e,t,o,i,n,s,r=!0)=>{let T=new td(_,"confirmed"),a=await oT(e,t,i,n,s);if(typeof a=="string"){a.includes("Unauthorized")&&(console.error(__.yellow(`\u26A0\uFE0F Invalid API key, please check your API key \u26A0\uFE0F
6908
- `)),console.log(__.white("Get Your API key \u{1F447}")),console.log(__.white(Ge+`
6909
- `)),process.exit(0));let V=`${__.yellow("\u26A0\uFE0F Too many requests, please try again later \u26A0\uFE0F")}
6907
+ You can choose only Incoming or Outgoing`));return}if(!jr(c,r)){console.log("SSH Connection Failed");return}if(a==="Incoming"){if(t.v2MigrateIncoming){(await eT.prompt([{name:"confirm",type:"confirm",message:"Are you sure you want to migrate V1 to V2 Incoming? This node must be running V2 and the remote node must be running V1."}])).confirm||(console.log(Ct.cyan("Exiting...\u{1F31B}")),process.exit(0)),console.log(Ct.white("\u{1F7E2} Migrating V1 to V2 Incoming...")),await _T(c,T,e,r,n);return}await Qr(c,T,e,r,n)}else await Xr(c,T,e,r,n);process.exit(0)}catch(o){o.message.includes("User force closed the prompt")&&(console.error(Ct.cyan("Exiting...\u{1F31B}")),process.exit(0)),console.error(Ct.red(`Switch Error: ${o.message}`)),process.exit(0)}})},"switchCommand");import{spawnSync as jC}from"node:child_process";var zC=E((_="306450862",e=u,t=O_)=>{try{let o=`agave-ledger-tool --ledger ${e} create-snapshot --incremental --snapshot-archive-path ${t} --hard-fork ${_} -- ${_} ${e}`;console.log("Parameters to createSnapshot:",_,e,t),console.log("Command:",o);let i=jC(o,{shell:!0,stdio:"pipe",cwd:e});if(i.status!==0)throw new Error(`createSnapshot: ${i.error}`)}catch(o){throw new Error(`createSnapshot: ${o}`)}},"createSnapshot"),ET=zC;import ye from"inquirer";import sd from"dotenv";import ne from"chalk";var gE={SOL:{tokenMint:"So11111111111111111111111111111111111111112",associationAccount:"4Vwkpk3DTVrTGnUQTazsgQ1wxtU9QwZTmAXDaQRHg9Ra",decimal:9},USDC:{tokenMint:"EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",associationAccount:"J8sqx9ZEoPRqboFAXK3c1R38zm41tRNJgUn2FzyeYQDj",decimal:6},elSOL:{tokenMint:yE,associationAccount:"",decimal:9},JitoSOL:{tokenMint:"J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn",associationAccount:"HPj87TFMPZfm5nk1HmTH9a382RXn7h9oWftiFr3Xs12a",decimal:9},mSOL:{tokenMint:"mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So",associationAccount:"8CX5tE9KvJ59HcoXwWf6tCZoRuz2JFSmunnbKC1ryaK9",decimal:9},bSOL:{tokenMint:"bSo13r4TkiE4KumL71LsHTPpL2euBYLFx6h9HP3piy1",associationAccount:"782MdvLby3VfvKdfDYn9tX3DfNAtg7TcytNNFuepcoMH",decimal:9},EPCT:{tokenMint:"CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP",associationAccount:"BhR2L6J5q3xF1TxReXyHjaUh4MF6qV99tMsipzPAKeB",decimal:6},JUP:{tokenMint:"JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN",associationAccount:"212yg3Ev7khq4p1mESFGenF4nWefmkbC8f7mHM68j4vg",decimal:6},BONK:{tokenMint:"DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263",associationAccount:"61Ndjv9392jPRVGALdYgjjxGYa6TT6Gn2WLDSsmugE6U",decimal:5},JTO:{tokenMint:"jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL",associationAccount:"2c9qVh8RQ6j2E2VdAEcCrRXMrd6g1vvPNZvAR6sbaGWo",decimal:9}},fo={So11111111111111111111111111111111111111112:{symbol:"SOL",tokenMint:Ot,associationAccount:"4Vwkpk3DTVrTGnUQTazsgQ1wxtU9QwZTmAXDaQRHg9Ra",decimal:9},EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v:{symbol:"USDC",tokenMint:Ft,associationAccount:"J8sqx9ZEoPRqboFAXK3c1R38zm41tRNJgUn2FzyeYQDj",decimal:6},ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC:{symbol:"elSOL",tokenMint:yE,associationAccount:"",decimal:9},J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn:{symbol:"jitoSOL",tokenMint:"J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn",associationAccount:"HPj87TFMPZfm5nk1HmTH9a382RXn7h9oWftiFr3Xs12a",decimal:9},mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So:{symbol:"mSOL",tokenMint:"mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So",associationAccount:"8CX5tE9KvJ59HcoXwWf6tCZoRuz2JFSmunnbKC1ryaK9",decimal:9},bSo13r4TkiE4KumL71LsHTPpL2euBYLFx6h9HP3piy1:{symbol:"bSOL",tokenMint:"bSo13r4TkiE4KumL71LsHTPpL2euBYLFx6h9HP3piy1",associationAccount:"782MdvLby3VfvKdfDYn9tX3DfNAtg7TcytNNFuepcoMH",decimal:9},CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP:{symbol:"EPCT",tokenMint:"CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP",associationAccount:"BhR2L6J5q3xF1TxReXyHjaUh4MF6qV99tMsipzPAKeB",decimal:6},JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN:{symbol:"JUP",tokenMint:"JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN",associationAccount:"212yg3Ev7khq4p1mESFGenF4nWefmkbC8f7mHM68j4vg",decimal:6},DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263:{symbol:"BONK",tokenMint:"DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263",associationAccount:"61Ndjv9392jPRVGALdYgjjxGYa6TT6Gn2WLDSsmugE6U",decimal:5},jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL:{symbol:"JTO",tokenMint:"jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL",associationAccount:"2c9qVh8RQ6j2E2VdAEcCrRXMrd6g1vvPNZvAR6sbaGWo",decimal:9}};import{readFile as ed}from"fs/promises";import{Connection as td,Keypair as Ed,VersionedTransaction as od}from"@solana/web3.js";import e_ from"chalk";import id from"inquirer";import nd from"dotenv";var ZC=E(async(_,e,t,o,i)=>{try{let n=`${_}/quote?inputMint=${t}&outputMint=${o}&amount=${i}`,s=await fetch(n,{method:"GET",headers:{"Content-Type":"application/json","x-api-key":e,Authorization:`Bearer ${e}`}});return s.status===429?"Too many requests, please try again later":s.status===401?"Unauthorized, please check your API key":await s.json()}catch(n){throw new Error(`Error getJupiterQuote: ${n}`)}},"getJupiterQuote"),oT=ZC;var _d=E(async(_,e,t,o)=>{try{let i=t.outputMint,n,s=yo[i];s?n={swapRequest:{quoteResponse:t,userPublicKey:o,feeAccount:s,dynamicComputeUnitLimit:!0,prioritizationFeeLamports:"auto",dynamicSlippage:{maxBps:500}}}:n={swapRequest:{quoteResponse:t,userPublicKey:o,dynamicComputeUnitLimit:!0,prioritizationFeeLamports:"auto",dynamicSlippage:{maxBps:500}}};let r=`${_}/swap`,T=await fetch(r,{method:"POST",headers:{"Content-Type":"application/json","x-api-key":e,Authorization:`Bearer ${e}`},body:JSON.stringify(n.swapRequest)});return T.status===429?"Too many requests, please try again later":await T.json()}catch(i){throw new Error(`Error postJupiterSwap: ${i}`)}},"postJupiterSwap"),iT=_d;nd.config();var nT=E(async(_,e,t,o,i,n,s,r=!0)=>{let T=new td(_,"confirmed"),a=await oT(e,t,i,n,s);if(typeof a=="string"){a.includes("Unauthorized")&&(console.error(e_.yellow(`\u26A0\uFE0F Invalid API key, please check your API key \u26A0\uFE0F
6908
+ `)),console.log(e_.white("Get Your API key \u{1F447}")),console.log(e_.white(Ge+`
6909
+ `)),process.exit(0));let V=`${e_.yellow("\u26A0\uFE0F Too many requests, please try again later \u26A0\uFE0F")}
6910
6910
 
6911
6911
  You can upgrade your API key to increase your rate limits.
6912
6912
  Get Your API key \u{1F447}
6913
6913
  Validators Solutions: ${Ge}
6914
- `;console.error(__.white(V)),process.exit(0)}let c=fo[i],R=fo[n],C=`\u{1F504} Swap Quote \u{1F504}
6914
+ `;console.error(e_.white(V)),process.exit(0)}let c=fo[i],R=fo[n],C=`\u{1F504} Swap Quote \u{1F504}
6915
6915
 
6916
6916
  - \u{1F3E6} Input Token: ${c.symbol} (${i})
6917
6917
  - \u{1F4B0} Input Amount: ${s/Math.pow(10,c.decimal)} ${c.symbol}
@@ -6920,16 +6920,16 @@ Validators Solutions: ${Ge}
6920
6920
  - \u{1F4B0} Output Amount: ${Number(a?.outAmount)/Math.pow(10,R.decimal)} ${R.symbol}
6921
6921
 
6922
6922
  \u203B This quote is based on the current market rate and may change before the swap is completed.
6923
- `;console.log(__.white(C)),console.log(__.gray(`You can also swap using the following command:
6923
+ `;console.log(e_.white(C)),console.log(e_.gray(`You can also swap using the following command:
6924
6924
  $ solv swap --input ${i} --output ${n} --amount ${s} --skip-confirm
6925
- `));let O=!1;r?O=(await id.prompt([{type:"confirm",name:"confirm",message:"Do you want to proceed with the swap?",default:!1}])).confirm:(console.log(__.cyan("Skipping confirmation...")),O=!0),O||(console.log(__.yellow("\u26A0\uFE0F Swap cancelled")),process.exit(0)),a||process.exit(0);let N=JSON.parse(await ed(o,"utf8")),S=Ed.fromSecretKey(new Uint8Array(Array.from(N))),d=await iT(e,t,a,S.publicKey.toString());if(typeof d=="string"){d.includes("Unauthorized")&&(console.error(__.yellow(`\u26A0\uFE0F Invalid API key, please check your API key \u26A0\uFE0F
6926
- `)),console.log(__.white("Get Your API key \u{1F447}")),console.log(__.white(Ge+`
6927
- `)),process.exit(0));let V=`${__.yellow("\u26A0\uFE0F Too many requests, please try again later \u26A0\uFE0F")}
6925
+ `));let O=!1;r?O=(await id.prompt([{type:"confirm",name:"confirm",message:"Do you want to proceed with the swap?",default:!1}])).confirm:(console.log(e_.cyan("Skipping confirmation...")),O=!0),O||(console.log(e_.yellow("\u26A0\uFE0F Swap cancelled")),process.exit(0)),a||process.exit(0);let N=JSON.parse(await ed(o,"utf8")),S=Ed.fromSecretKey(new Uint8Array(Array.from(N))),d=await iT(e,t,a,S.publicKey.toString());if(typeof d=="string"){d.includes("Unauthorized")&&(console.error(e_.yellow(`\u26A0\uFE0F Invalid API key, please check your API key \u26A0\uFE0F
6926
+ `)),console.log(e_.white("Get Your API key \u{1F447}")),console.log(e_.white(Ge+`
6927
+ `)),process.exit(0));let V=`${e_.yellow("\u26A0\uFE0F Too many requests, please try again later \u26A0\uFE0F")}
6928
6928
 
6929
6929
  You can upgrade your API key to increase your rate limits.
6930
6930
  Get Your API key \u{1F447}
6931
6931
  Validators Solutions: ${Ge}
6932
- `;console.error(__.white(V)),process.exit(0)}let P=Buffer.from(d.swapTransaction,"base64"),f=od.deserialize(P);f.sign([S]);let D=f.serialize(),U=await T.sendRawTransaction(D,{skipPreflight:!0,maxRetries:2}),M=f.message.recentBlockhash;return console.log(`Swapping...
6932
+ `;console.error(e_.white(V)),process.exit(0)}let P=Buffer.from(d.swapTransaction,"base64"),f=od.deserialize(P);f.sign([S]);let D=f.serialize(),U=await T.sendRawTransaction(D,{skipPreflight:!0,maxRetries:2}),M=f.message.recentBlockhash;return console.log(`Swapping...
6933
6933
  Transaction ID: ${U}`),await T.confirmTransaction({blockhash:M,lastValidBlockHeight:d.lastValidBlockHeight,signature:U},"confirmed"),U},"swap");sd.config();var sT=E(async(_,e)=>{_.command("swap").description("Swap tokens").option("-i, --input <input>","Input token mint","").option("-o, --output <output>","Output token mint","").option("-a, --amount <amount>","Input amount in lamports","0").option("-s, --skip-confirm","Skip confirmation",!1).option("-c, --init-config","Initialize config",!1).action(async t=>{try{await rd(e.RPC_URL,e.KEYPAIR_PATH,e.API_KEY,t.input,t.output,Number(t.amount),!t.skipConfirm,t.initConfig)}catch(o){o.message.includes("User force closed the prompt")&&(console.error(ne.cyan("Exiting...\u{1F31B}")),process.exit(0)),console.error(ne.red(`Swap Error: ${o.message}`)),process.exit(0)}})},"swapCommand"),rd=E(async(_,e,t,o="",i="",n=0,s=!0,r=!1)=>{console.log(ne.white("Solana RPC URL:",_)),console.log(ne.white("KeyfilePath:",e)),(!e||e===""||r)&&await Td();let T=ho,a=[...go,"Other"],c=o,R="",C=i,O=n;if(c===""){let d=await ye.prompt([{type:"list",name:"name",message:"Select input mint",choices:a,default:Ot}]);d.name==="Other"?c=(await ye.prompt([{type:"input",name:"address",message:"Enter input mint address",default:Ft}])).address:(R=d.name,c=gE[R].tokenMint)}if(C===""){a=a.filter(f=>f!==R);let d=await ye.prompt([{type:"list",name:"name",message:"Select output mint",choices:a}]);if(d.name==="Other")C=(await ye.prompt([{type:"input",name:"address",message:"Enter output mint address",default:P_}])).address;else{let f=d.name;C=gE[f].tokenMint}let P=d.name;C=gE[P].tokenMint}if(O===0){let d=await ye.prompt([{type:"input",name:"amount",message:"Enter input amount in LAMPORTS. e.g. 0.01 SOL",default:"10000000"}]);O=Number(d.amount)}let S=await nT(_,T,!t||t===""?Bo:t,e,c,C,O,s);S||process.exit(0),console.log(ne.green("\u2714\uFE0E Sent Tx Successfully!")),console.log(ne.white(`Check Your TX \u{1F449}: https://solscan.io/tx/${S}`))},"swapCmd");var Td=E(async()=>{let _=await ye.prompt([{type:"input",name:"RPC_URL",message:"Enter Solana RPC URL",default:"https://api.mainnet-beta.solana.com"},{type:"input",name:"KEYPAIR_PATH",message:"Enter Keypair Path",default:"/home/solv/mainnet-validator-keypair.json"},{type:"input",name:"API_KEY",message:"Enter Jupiter API Key(Optional)",default:""}]);await B(_),console.log(ne.green(`\u2714\uFE0E Config Updated Successfully!
6934
6934
  `)),_e()},"askForConfig");import{spawnSync as ad}from"node:child_process";var rT=E(()=>{ad("sudo systemctl status jupiter-api.service",{shell:!0,stdio:"inherit"})},"jupiterStatus");import{spawnSync as Sd}from"node:child_process";var TT=E(()=>{Sd("sudo systemctl start jupiter-api.service",{shell:!0,stdio:"inherit"})},"jupiterStart");import{spawnSync as cd}from"node:child_process";var aT=E(()=>{cd("sudo systemctl stop jupiter-api.service",{shell:!0,stdio:"inherit"})},"jupiterStop");import{spawnSync as Rd}from"node:child_process";var ST=E(()=>{Rd("sudo systemctl restart jupiter-api.service",{shell:!0,stdio:"inherit"})},"jupiterRestart");import{spawnSync as Cd}from"node:child_process";var cT=E((_=!1)=>{Cd(_?"journalctl -u jupiter-api.service -xef | grep ERROR":"journalctl -u jupiter-api.service -xef",{shell:!0,stdio:"inherit"})},"jupiterLog");import{spawnSync as dd}from"node:child_process";var RT=E(()=>{dd("sudo systemctl enable jupiter-api.service",{shell:!0,stdio:"inherit"})},"jupiterEnable");var CT=E(()=>{let _=I.command("jupiter").description("Jupiter API Commands");_.command("status").description("Show Jupiter Status").action(()=>{rT()}),_.command("start").description("Start Jupiter").action(()=>{TT()}),_.command("stop").description("Stop Jupiter").action(()=>{aT()}),_.command("log").option("-e, --error","Show Error Logs",!1).description("Show Jupiter Logs").action(e=>{cT(e.error),process.exit(0)}),_.command("restart").description("Restart Jupiter").action(()=>{ST()}),_.command("enable").description("Enable Jupiter").action(()=>{RT()})},"jupiterCommands");import Fd from"chalk";import{spawnSync as ld}from"node:child_process";var Nd=E(()=>{let{stdout:_}=ld("solana --version",{shell:!0});return(_?String(_):"Unknown").trim()},"getSolanaVersion"),dT=Nd;var I=new Od;I.name("solv").description("\u{1FA84} solv - Solana Validator Tool \u2728").helpOption("-h, --help","Display help for command").version(dt,"-V","Display version");async function Id(){try{let _=await Y();Yn(_),$n(_),xn(_),rs(_),vi(_),Yi(),qn(_),us(_),Ls(_),ss(),jn(),wn(_),Mi(_),Wn(),ks(),nr(_),Tr(_),hr(_),Hn(),sT(I,_),vr(_),tT(I,_),CT(),Vs(_),er(_),I.command("rm:log").description("Remove Logs").action(()=>{vt()}),I.command("rm:snapshot").description("Remove Snapshot").action(()=>{tr(_)}),I.command("create:snapshot").description("Create Snapshot").option("-s, --slot <slot>","Slot","306450862").option("-l, --ledger <ledger>","Ledger",_.LEDGER_PATH).option("-n, --snapshots <snapshots>","Snapshots",_.SNAPSHOTS_PATH).action(e=>{console.log(Fd.white("\u{1F4DD} Creating Snapshot...")),ET(e.slot,e.ledger,e.snapshots)}),I.command("monitor").alias("m").description("Monitor Solana Node").action(()=>{Er(_)}),I.command("catchup").description("Check Solana Catchup Status").alias("c").alias("ca").action(()=>{or()}),I.command("config").description("Show Solv Config").action(()=>{dE(_)}),I.command("vv").description("Show Solv Version").action(()=>{let e=dT();console.log("version:",e)}),await I.addHelpCommand("help [cmd]","Display help for command").parseAsync(process.argv),process.exit(0)}catch(_){console.log(_),process.exit(0)}}E(Id,"main");Id();export{I as program};
6935
6935
  //# sourceMappingURL=index.js.map