@gabrielhicks/solv 5.8.4 → 5.8.6

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 DT=Object.defineProperty;var E=(_,e)=>DT(_,"name",{value:e,configurable:!0}),PT=(_=>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 Pd}from"commander";var Uo="5.8.4";var uo={name:"@gabrielhicks/solv",version:Uo,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=uo.version;var ke="https://validators.solutions";var lt="solv4.config.json";var q_="identity.json",W_="unstaked-identity.json",po="relayer-keypair.json",UT="mainnet-validator-keypair.json",uT="mainnet-vote-account-keypair.json",pT="mainnet-authority-keypair.json",mT="testnet-validator-keypair.json",MT="testnet-vote-account-keypair.json",LT="testnet-authority-keypair.json",b="/home/solv",p=`${b}/${q_}`,Bd=`${b}/${W_}`,x=`${b}/${UT}`,re=`${b}/${uT}`,yd=`${b}/${pT}`,k=`${b}/${mT}`,y_=`${b}/${MT}`,Kd=`${b}/${LT}`,w=`${b}/solana-validator.log`,N_=b+"/start-validator.sh",u="/mnt/ledger",K_="/mnt/accounts",O_="/mnt/snapshots",mo="solana-validator",Mo="agave-validator",Lo="ELLB9W7ZCwRCV3FzWcCWoyKP6NjZJKArLyGtkqefnHcG";var Nt=3;var ho="https://api.mainnet-beta.solana.com",go="https://verify.validators.solutions/solv-migrate",Bo="https://jup.validators.solutions/v1/jup",KE;(function(_){_.SOL="SOL",_.USDC="USDC",_.elSOL="elSOL",_.JitoSOL="JitoSOL",_.mSOL="mSOL",_.bSOL="bSOL",_.EPCT="EPCT",_.JUP="JUP",_.BONK="BONK",_.JTO="JTO"})(KE||(KE={}));var yo=Object.values(KE),Ot="So11111111111111111111111111111111111111112",Ft="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",GE="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC";var Ko="SOLV420",Go={So11111111111111111111111111111111111111112:"4Vwkpk3DTVrTGnUQTazsgQ1wxtU9QwZTmAXDaQRHg9Ra",EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v:"J8sqx9ZEoPRqboFAXK3c1R38zm41tRNJgUn2FzyeYQDj",J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn:"HPj87TFMPZfm5nk1HmTH9a382RXn7h9oWftiFr3Xs12a",mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So:"8CX5tE9KvJ59HcoXwWf6tCZoRuz2JFSmunnbKC1ryaK9",bSo13r4TkiE4KumL71LsHTPpL2euBYLFx6h9HP3piy1:"782MdvLby3VfvKdfDYn9tX3DfNAtg7TcytNNFuepcoMH",CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP:"BhR2L6J5q3xF1TxReXyHjaUh4MF6qV99tMsipzPAKeB",JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN:"212yg3Ev7khq4p1mESFGenF4nWefmkbC8f7mHM68j4vg",DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263:"61Ndjv9392jPRVGALdYgjjxGYa6TT6Gn2WLDSsmugE6U",jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL:"2c9qVh8RQ6j2E2VdAEcCrRXMrd6g1vvPNZvAR6sbaGWo"},Te=["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 BT}from"child_process";import{spawnSync as I_}from"node:child_process";var hT=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_=hT;var ko="agave-validator",gT=E(()=>{try{return ko}catch(_){return console.error(_),ko}},"getSolanaCLI"),f_=gT;var S_="4.0.0-beta.4",e_="3.1.11",It="",Vo="",ae="4.0.0-beta.4",k_="3.1.11",V_="",Se="",ft="4.0.0-beta.4",ce="3.1.11",Re="",Dt="",bo="3.1.11",X_="3.1.11";var wo="20.17.0",Ce="0.902.40002",b_="0.817.30110";var Ve="0.15.0-1",be="0.15.0-1";var Pt=E(async _=>{let e=It,o=`${`v${_}`}`;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}`),BT(i,{shell:!0,stdio:"inherit"})},"monitorUpdate");import xE 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 Ho;(function(_){_.SINGLE="single",_.DOUBLE="double",_.TRIPLE="triple"})(Ho||(Ho={}));var w_;(function(_){_.MAINNET="mainnet-beta",_.TESTNET="testnet"})(w_||(w_={}));var Yo;(function(_){_.VALIDATOR="validator",_.RPC="rpc"})(Yo||(Yo={}));var Jo;(function(_){_.SOLANA="solana",_.JITO="jito",_.AGAVE="agave",_.FIREDANCER="firedancer"})(Jo||(Jo={}));var xo;(function(_){_.CO_HOST_RELAYER="co-host-relayer",_.SEPARATED_RELAYER="separated-relayer",_.WITHOUT_RELAYER="without-relayer"})(xo||(xo={}));var Qo;(function(_){_.FIREDANCER="firedancer",_.FRANKENDANCER="frankendancer"})(Qo||(Qo={}));var At;(function(_){_[_.TESTNET_VALIDATOR=0]="TESTNET_VALIDATOR",_[_.MAINNET_VALIDATOR=1]="MAINNET_VALIDATOR",_[_.RPC_NODE=2]="RPC_NODE"})(At||(At={}));var Ut;(function(_){_.SOLANA_CLIENT="SolanaClient",_.JITO_MEV="JitoMev",_.FIREDANCER="Firedancer"})(Ut||(Ut={}));var Wo=!1,Xo=!0,jo=!1,zo=!0,Zo=!1,_i=!0,t_={ID:"solv",LANG:j_.EN,USERNAME:"solv",TESTNET_SOLANA_VERSION:"3.1.9",MAINNET_SOLANA_VERSION:"3.1.9",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,MULTICAST:!1},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"},g={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"},B=E((_=v.ROOT)=>{let e=_===v.ROOT?v.ROOT:_,t=`${e}/${g.MAINNET_VALIDATOR_KEY}`,o=`${e}/${g.MAINNET_VALIDATOR_VOTE_KEY}`,i=`${e}/${g.MAINNET_VALITATOR_AUTHORITY_KEY}`,n=`${e}/${g.TESTNET_VALIDATOR_KEY}`,s=`${e}/${g.TESTNET_VALIDATOR_VOTE_KEY}`,r=`${e}/${g.TESTNET_VALITATOR_AUTHORITY_KEY}`;return{mainnetValidatorKey:t,mainnetValidatorVoteKey:o,mainnetValidatorAuthorityKey:i,testnetValidatorKey:n,testnetValidatorVoteKey:s,testnetValidatorAuthorityKey:r}},"getAllKeyPaths"),v_=E((_=!0)=>{let e=_?`${v.ROOT}/${g.TESTNET_VALIDATOR_KEY}`:`${v.ROOT}/${g.MAINNET_VALIDATOR_KEY}`,t=_?`${v.ROOT}/${g.TESTNET_VALIDATOR_VOTE_KEY}`:`${v.ROOT}/${g.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 c_="So1vW4Bm6ZURzJJHZy1JpsjoVY68z4cDgF4tTLwYMa5",kE="7tAfLKgRVd9eywSQPuMbVNd51KGkaveZQuTjapL74Fwv",ei="EiwSTx1Z2uJATDut682U7xzzquFR4UpQJUij3wSxVoSV",ti=9,P_="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC",Ei="So11111111111111111111111111111111111111112",oi="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",ii="CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP",$o;(function(_){_[_.ELSOL=P_]="ELSOL",_[_.SOL=Ei]="SOL",_[_.USDC=oi]="USDC",_[_.EPCT=ii]="EPCT"})($o||($o={}));var qo;(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"})(qo||(qo={}));var zd={[Ei]:9,[P_]:9,[oi]:6,[ii]:6},ut="/home/solv/currentEpoch.json";var pt="https://api.testnet.solana.com";import{spawnSync as VE}from"child_process";var ni=E(()=>{VE("pnpm add -g pnpm",{shell:!0,stdio:"inherit"});let _=t_.NODE_VERSION;VE(`pnpm env use ${_} --global`,{shell:!0,stdio:"inherit"}),VE("pnpm add -g @gabrielhicks/solv",{shell:!0,stdio:"inherit"})},"updateSolv");import{spawnSync as R_}from"child_process";var mt=E((_,e=!1,t=!1,o=!1)=>{e?R_(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-solana/${_}/installer)"`,{shell:!0,stdio:"inherit"}):(R_(`mkdir /tmp/${_}`,{shell:!0,stdio:"inherit"}),R_(`cd /tmp/${_}`,{shell:!0,stdio:"inherit"}),R_(`git clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules /tmp/${_}`,{shell:!0,stdio:"inherit"}),R_(`git -C /tmp/${_} checkout ${_}`,{shell:!0,stdio:"inherit"}),R_(`git -C /tmp/${_} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),R_(`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"}),R_("sudo rm -rf /home/solv/.local/share/solana/install/active_release",{shell:!0,stdio:"inherit"}),R_(`sudo ln -sfn /home/solv/.local/share/solana/install/releases/${_} /home/solv/.local/share/solana/install/active_release`,{shell:!0,stdio:"inherit"}),o&&R_("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"}),R_(`sudo rm -rf /tmp/${_}`,{shell:!0,stdio:"inherit"}))},"jitoUpdate");import{readFile as yT,writeFile as KT}from"fs/promises";import{homedir as GT}from"os";var M_=E(async _=>{let t=`${GT()}/${D_.JITO_CONFIG}`,i={...JSON.parse(await yT(t,"utf8")),..._},n=JSON.stringify(i,null,2);await KT(t,n),console.log(`Updated ${t} with new values.`)},"updateJitoSolvConfig");import{spawnSync as si}from"child_process";import kT from"inquirer";var ri=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";si(`solana config set --url ${e?"testnet":"mainnet-beta"} --keypair ${t}`,{shell:!0,stdio:"inherit"});let n=`solana vote-update-commission ${o} ${_} ${t} --keypair ${t}`;si(n,{shell:!0,stdio:"inherit"})},"updateCommission"),Ti=E(async()=>await kT.prompt([{type:"number",name:"commission",message:"Enter new commission",default:7}]),"updateCommissionAsk");import{execAsync as ve}from"@skeet-framework/utils";import VT from"chalk";import bT from"inquirer";var ai=E(async()=>{let _=await bT.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(VT.white("\u2714\uFE0F Firewall updated!"))},"updateFirewall");var wT=E(()=>Uo,"getSolvVersion"),de=wT;import{readFile as JT,writeFile as xT}from"fs/promises";import{existsAsync as QT}from"@skeet-framework/utils";var bE;(function(_){_.EN="en",_.JA="ja"})(bE||(bE={}));var Al=Object.values(bE),l;(function(_){_.MAINNET="mainnet-beta",_.TESTNET="testnet"})(l||(l={}));var Si=Object.values(l),A;(function(_){_.RPC="rpc",_.VALIDATOR="validator"})(A||(A={}));var ci=Object.values(A),F;(function(_){_.SOLANA="solana",_.AGAVE="agave",_.JITO="jito",_.FRANKENDANCER="frankendancer",_.BAM="bam",_.NONE="none"})(F||(F={}));var Ul=Object.values(F).filter(_=>_!=="none"),$;(function(_){_.AGAVE="agave",_.JITO="jito",_.NONE="none"})($||($={}));var Ri=Object.values($).filter(_=>_!=="none"),E_;(function(_){_.SINGLE="single",_.DOUBLE="double",_.TRIPLE="triple"})(E_||(E_={}));var YT={NETWORK:l.TESTNET,NODE_TYPE:A.RPC,VALIDATOR_TYPE:F.NONE,RPC_TYPE:$.AGAVE,MNT_DISK_TYPE:E_.TRIPLE,TESTNET_SOLANA_VERSION:S_,MAINNET_SOLANA_VERSION:e_,NODE_VERSION:wo,TESTNET_DELINQUENT_STAKE:10,MAINNET_DELINQUENT_STAKE:5,COMMISSION:5,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:Lo,STAKE_ACCOUNTS:[],HARVEST_ACCOUNT:"",IS_MEV_MODE:!1,RPC_URL:ho,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:0,MULTICAST:!1},L_=YT;import{homedir as $T}from"os";var qT=E(async()=>{let e=`${$T()}/${lt}`;return await QT(e)?JSON.parse(await JT(e,"utf-8")):(console.log("Creating default config file at",e),await xT(e,JSON.stringify(L_,null,2)),L_)},"readConfig"),Y=qT;import WT 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 DT=Object.defineProperty;var E=(_,e)=>DT(_,"name",{value:e,configurable:!0}),PT=(_=>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 Pd}from"commander";var Uo="5.8.6";var uo={name:"@gabrielhicks/solv",version:Uo,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=uo.version;var ke="https://validators.solutions";var lt="solv4.config.json";var q_="identity.json",W_="unstaked-identity.json",po="relayer-keypair.json",UT="mainnet-validator-keypair.json",uT="mainnet-vote-account-keypair.json",pT="mainnet-authority-keypair.json",mT="testnet-validator-keypair.json",MT="testnet-vote-account-keypair.json",LT="testnet-authority-keypair.json",b="/home/solv",p=`${b}/${q_}`,Bd=`${b}/${W_}`,x=`${b}/${UT}`,re=`${b}/${uT}`,yd=`${b}/${pT}`,k=`${b}/${mT}`,y_=`${b}/${MT}`,Kd=`${b}/${LT}`,w=`${b}/solana-validator.log`,N_=b+"/start-validator.sh",u="/mnt/ledger",K_="/mnt/accounts",O_="/mnt/snapshots",mo="solana-validator",Mo="agave-validator",Lo="ELLB9W7ZCwRCV3FzWcCWoyKP6NjZJKArLyGtkqefnHcG";var Nt=3;var ho="https://api.mainnet-beta.solana.com",go="https://verify.validators.solutions/solv-migrate",Bo="https://jup.validators.solutions/v1/jup",KE;(function(_){_.SOL="SOL",_.USDC="USDC",_.elSOL="elSOL",_.JitoSOL="JitoSOL",_.mSOL="mSOL",_.bSOL="bSOL",_.EPCT="EPCT",_.JUP="JUP",_.BONK="BONK",_.JTO="JTO"})(KE||(KE={}));var yo=Object.values(KE),Ot="So11111111111111111111111111111111111111112",Ft="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",GE="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC";var Ko="SOLV420",Go={So11111111111111111111111111111111111111112:"4Vwkpk3DTVrTGnUQTazsgQ1wxtU9QwZTmAXDaQRHg9Ra",EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v:"J8sqx9ZEoPRqboFAXK3c1R38zm41tRNJgUn2FzyeYQDj",J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn:"HPj87TFMPZfm5nk1HmTH9a382RXn7h9oWftiFr3Xs12a",mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So:"8CX5tE9KvJ59HcoXwWf6tCZoRuz2JFSmunnbKC1ryaK9",bSo13r4TkiE4KumL71LsHTPpL2euBYLFx6h9HP3piy1:"782MdvLby3VfvKdfDYn9tX3DfNAtg7TcytNNFuepcoMH",CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP:"BhR2L6J5q3xF1TxReXyHjaUh4MF6qV99tMsipzPAKeB",JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN:"212yg3Ev7khq4p1mESFGenF4nWefmkbC8f7mHM68j4vg",DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263:"61Ndjv9392jPRVGALdYgjjxGYa6TT6Gn2WLDSsmugE6U",jtojtomepa8beP8AuQc6eXt5FriJwfFMwQx2v2f9mCL:"2c9qVh8RQ6j2E2VdAEcCrRXMrd6g1vvPNZvAR6sbaGWo"},Te=["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 BT}from"child_process";import{spawnSync as I_}from"node:child_process";var hT=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_=hT;var ko="agave-validator",gT=E(()=>{try{return ko}catch(_){return console.error(_),ko}},"getSolanaCLI"),f_=gT;var S_="4.0.0-beta.4",e_="3.1.11",It="",Vo="",ae="4.0.0-beta.4",k_="3.1.11",V_="",Se="",ft="4.0.0-beta.4",ce="3.1.11",Re="",Dt="",bo="3.1.11",X_="3.1.11";var wo="20.17.0",Ce="0.902.40002",b_="0.817.30110";var Ve="0.15.0-1",be="0.15.0-1";var Pt=E(async _=>{let e=It,o=`${`v${_}`}`;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}`),BT(i,{shell:!0,stdio:"inherit"})},"monitorUpdate");import xE 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 Ho;(function(_){_.SINGLE="single",_.DOUBLE="double",_.TRIPLE="triple"})(Ho||(Ho={}));var w_;(function(_){_.MAINNET="mainnet-beta",_.TESTNET="testnet"})(w_||(w_={}));var Yo;(function(_){_.VALIDATOR="validator",_.RPC="rpc"})(Yo||(Yo={}));var Jo;(function(_){_.SOLANA="solana",_.JITO="jito",_.AGAVE="agave",_.FIREDANCER="firedancer"})(Jo||(Jo={}));var xo;(function(_){_.CO_HOST_RELAYER="co-host-relayer",_.SEPARATED_RELAYER="separated-relayer",_.WITHOUT_RELAYER="without-relayer"})(xo||(xo={}));var Qo;(function(_){_.FIREDANCER="firedancer",_.FRANKENDANCER="frankendancer"})(Qo||(Qo={}));var At;(function(_){_[_.TESTNET_VALIDATOR=0]="TESTNET_VALIDATOR",_[_.MAINNET_VALIDATOR=1]="MAINNET_VALIDATOR",_[_.RPC_NODE=2]="RPC_NODE"})(At||(At={}));var Ut;(function(_){_.SOLANA_CLIENT="SolanaClient",_.JITO_MEV="JitoMev",_.FIREDANCER="Firedancer"})(Ut||(Ut={}));var Wo=!1,Xo=!1,jo=!1,zo=!1,Zo=!1,_i=!1,t_={ID:"solv",LANG:j_.EN,USERNAME:"solv",TESTNET_SOLANA_VERSION:"3.1.9",MAINNET_SOLANA_VERSION:"3.1.9",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,MULTICAST:!1},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"},g={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"},B=E((_=v.ROOT)=>{let e=_===v.ROOT?v.ROOT:_,t=`${e}/${g.MAINNET_VALIDATOR_KEY}`,o=`${e}/${g.MAINNET_VALIDATOR_VOTE_KEY}`,i=`${e}/${g.MAINNET_VALITATOR_AUTHORITY_KEY}`,n=`${e}/${g.TESTNET_VALIDATOR_KEY}`,s=`${e}/${g.TESTNET_VALIDATOR_VOTE_KEY}`,r=`${e}/${g.TESTNET_VALITATOR_AUTHORITY_KEY}`;return{mainnetValidatorKey:t,mainnetValidatorVoteKey:o,mainnetValidatorAuthorityKey:i,testnetValidatorKey:n,testnetValidatorVoteKey:s,testnetValidatorAuthorityKey:r}},"getAllKeyPaths"),v_=E((_=!0)=>{let e=_?`${v.ROOT}/${g.TESTNET_VALIDATOR_KEY}`:`${v.ROOT}/${g.MAINNET_VALIDATOR_KEY}`,t=_?`${v.ROOT}/${g.TESTNET_VALIDATOR_VOTE_KEY}`:`${v.ROOT}/${g.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 c_="So1vW4Bm6ZURzJJHZy1JpsjoVY68z4cDgF4tTLwYMa5",kE="7tAfLKgRVd9eywSQPuMbVNd51KGkaveZQuTjapL74Fwv",ei="EiwSTx1Z2uJATDut682U7xzzquFR4UpQJUij3wSxVoSV",ti=9,P_="ELSoL1owwMWQ9foMsutweCsMKbTPVBD9pFqxQGidTaMC",Ei="So11111111111111111111111111111111111111112",oi="EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",ii="CvB1ztJvpYQPvdPBePtRzjL4aQidjydtUz61NWgcgQtP",$o;(function(_){_[_.ELSOL=P_]="ELSOL",_[_.SOL=Ei]="SOL",_[_.USDC=oi]="USDC",_[_.EPCT=ii]="EPCT"})($o||($o={}));var qo;(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"})(qo||(qo={}));var zd={[Ei]:9,[P_]:9,[oi]:6,[ii]:6},ut="/home/solv/currentEpoch.json";var pt="https://api.testnet.solana.com";import{spawnSync as VE}from"child_process";var ni=E(()=>{VE("pnpm add -g pnpm",{shell:!0,stdio:"inherit"});let _=t_.NODE_VERSION;VE(`pnpm env use ${_} --global`,{shell:!0,stdio:"inherit"}),VE("pnpm add -g @gabrielhicks/solv",{shell:!0,stdio:"inherit"})},"updateSolv");import{spawnSync as R_}from"child_process";var mt=E((_,e=!1,t=!1,o=!1)=>{e?R_(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-solana/${_}/installer)"`,{shell:!0,stdio:"inherit"}):(R_(`mkdir /tmp/${_}`,{shell:!0,stdio:"inherit"}),R_(`cd /tmp/${_}`,{shell:!0,stdio:"inherit"}),R_(`git clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules /tmp/${_}`,{shell:!0,stdio:"inherit"}),R_(`git -C /tmp/${_} checkout ${_}`,{shell:!0,stdio:"inherit"}),R_(`git -C /tmp/${_} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),R_(`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"}),R_("sudo rm -rf /home/solv/.local/share/solana/install/active_release",{shell:!0,stdio:"inherit"}),R_(`sudo ln -sfn /home/solv/.local/share/solana/install/releases/${_} /home/solv/.local/share/solana/install/active_release`,{shell:!0,stdio:"inherit"}),o&&R_("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"}),R_(`sudo rm -rf /tmp/${_}`,{shell:!0,stdio:"inherit"}))},"jitoUpdate");import{readFile as yT,writeFile as KT}from"fs/promises";import{homedir as GT}from"os";var M_=E(async _=>{let t=`${GT()}/${D_.JITO_CONFIG}`,i={...JSON.parse(await yT(t,"utf8")),..._},n=JSON.stringify(i,null,2);await KT(t,n),console.log(`Updated ${t} with new values.`)},"updateJitoSolvConfig");import{spawnSync as si}from"child_process";import kT from"inquirer";var ri=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";si(`solana config set --url ${e?"testnet":"mainnet-beta"} --keypair ${t}`,{shell:!0,stdio:"inherit"});let n=`solana vote-update-commission ${o} ${_} ${t} --keypair ${t}`;si(n,{shell:!0,stdio:"inherit"})},"updateCommission"),Ti=E(async()=>await kT.prompt([{type:"number",name:"commission",message:"Enter new commission",default:7}]),"updateCommissionAsk");import{execAsync as ve}from"@skeet-framework/utils";import VT from"chalk";import bT from"inquirer";var ai=E(async()=>{let _=await bT.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(VT.white("\u2714\uFE0F Firewall updated!"))},"updateFirewall");var wT=E(()=>Uo,"getSolvVersion"),de=wT;import{readFile as JT,writeFile as xT}from"fs/promises";import{existsAsync as QT}from"@skeet-framework/utils";var bE;(function(_){_.EN="en",_.JA="ja"})(bE||(bE={}));var Al=Object.values(bE),l;(function(_){_.MAINNET="mainnet-beta",_.TESTNET="testnet"})(l||(l={}));var Si=Object.values(l),A;(function(_){_.RPC="rpc",_.VALIDATOR="validator"})(A||(A={}));var ci=Object.values(A),F;(function(_){_.SOLANA="solana",_.AGAVE="agave",_.JITO="jito",_.FRANKENDANCER="frankendancer",_.BAM="bam",_.NONE="none"})(F||(F={}));var Ul=Object.values(F).filter(_=>_!=="none"),$;(function(_){_.AGAVE="agave",_.JITO="jito",_.NONE="none"})($||($={}));var Ri=Object.values($).filter(_=>_!=="none"),E_;(function(_){_.SINGLE="single",_.DOUBLE="double",_.TRIPLE="triple"})(E_||(E_={}));var YT={NETWORK:l.TESTNET,NODE_TYPE:A.RPC,VALIDATOR_TYPE:F.NONE,RPC_TYPE:$.AGAVE,MNT_DISK_TYPE:E_.TRIPLE,TESTNET_SOLANA_VERSION:S_,MAINNET_SOLANA_VERSION:e_,NODE_VERSION:wo,TESTNET_DELINQUENT_STAKE:10,MAINNET_DELINQUENT_STAKE:5,COMMISSION:5,DEFAULT_VALIDATOR_VOTE_ACCOUNT_PUBKEY:Lo,STAKE_ACCOUNTS:[],HARVEST_ACCOUNT:"",IS_MEV_MODE:!1,RPC_URL:ho,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:0,MULTICAST:!1},L_=YT;import{homedir as $T}from"os";var qT=E(async()=>{let e=`${$T()}/${lt}`;return await QT(e)?JSON.parse(await JT(e,"utf-8")):(console.log("Creating default config file at",e),await xT(e,JSON.stringify(L_,null,2)),L_)},"readConfig"),Y=qT;import WT 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 WT(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 _a}from"child_process";import{Connection as Ci}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 Ci("https://api.testnet.solana.com"):new Ci(_,"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 XT}from"child_process";var V=E(_=>{let e=`solana address --keypair ${_}`,{stdout:t}=XT(e,{shell:!0,stdio:"pipe"});return t.toString().trim()},"getSolanaAddress");var jT=E(_=>new Promise(e=>setTimeout(e,_)),"sleep"),q=jT;import{sendDiscord as zT}from"@skeet-framework/utils";var di=30,ZT=E(async _=>{try{let e=_.NETWORK===l.TESTNET,{mainnetValidatorVoteKey:t,testnetValidatorVoteKey:o}=B(),n=V(e?o:t),s=await He(_.RPC_URL,n,e),r=0;for(;!s.isActive;){if(r>=di){console.log("Max retries reached, exiting...");let T=`\u26A0\uFE0F Validator is not active for ${di} minutes!
4
4
  Account: ${s.pubkey}
5
5
  Reason: ${s.reason}
@@ -6093,7 +6093,7 @@ ${h}
6093
6093
  compress
6094
6094
  copytruncate
6095
6095
  }
6096
- `),i)},"logRotates");import{existsSync as Ht}from"fs";import{execSync as yi}from"child_process";function Ne(_=!1){if(console.log("Creating logrotate configuration for solana"),!_&&Ht(L.SOL_LOGROTATE)&&console.log("SOL_LOGROTATE_PATH already exists. Skipping logrotate configuration."),!_&&!Ht(L.SOL_LOGROTATE)){let e=HE("solv",_);yi(`echo "${e}" | sudo tee ${L.SOL_LOGROTATE} > /dev/null`),console.log("Logrotate configuration created.")}if(_&&!Ht(L.FRANKENDANCER_LOGROTATE)){let e=HE("solv",_);yi(`echo "${e}" | sudo tee ${L.FRANKENDANCER_LOGROTATE} > /dev/null`),console.log("Logrotate configuration created.")}_&&Ht(L.FRANKENDANCER_LOGROTATE)&&console.log("FRANKENDANCER_LOGROTATE already exists. Skipping logrotate configuration.")}E(Ne,"setupLogrotate");import{spawnSync as Ka}from"child_process";var Yt=E(()=>{Ka("sudo rm -rf /home/solv/solana-validator.log.*",{shell:!0,stdio:"inherit"})},"rmLogs");import{spawnSync as Ga}from"child_process";var Ki=E(()=>{Ga("sudo systemctl restart logrotate",{shell:!0,stdio:"inherit"})},"restartLogrotate");var Qe=E(_=>{Yt();let e=`sudo rm -rf ${L.SOL_LOGROTATE} && sudo rm -rf ${L.FRANKENDANCER_LOGROTATE}`;ka(e,{shell:!0,stdio:"inherit"}),Ne(_),Ki()},"updateLogrotate");import{spawnSync as Va}from"child_process";var Gi=E(()=>{Va("sudo systemctl restart frankendancer",{shell:!0,stdio:"inherit"})},"restartFiredancer");import{execAsync as Q}from"@skeet-framework/utils";import ba from"chalk";var YE=E(async()=>{await Q('echo "yes" | sudo ufw restart'),await Q('echo "yes" | sudo ufw enable'),await Q("sudo ufw allow ssh"),await Q("sudo ufw allow 53"),await Q("sudo ufw allow 8899/udp"),await Q("sudo ufw allow 8899/tcp"),await Q("sudo ufw allow 8000:8898/udp"),await Q("sudo ufw deny proto tcp from any to any port 8000:8025"),await Q("sudo ufw allow 8026:8898/tcp"),await Q("sudo ufw allow 8900:10000/tcp"),await Q("sudo ufw allow 8900:10000/udp"),await Q("sudo ufw allow 179/tcp"),await Q("sudo ufw allow 9600/tcp"),await Q("sudo ufw allow in on doublezero0 to any port 44880 proto udp"),await Q("sudo ufw allow out on doublezero0 to any port 44880 proto udp"),await Q("sudo ufw reload"),console.log(ba.white("\u2714\uFE0F Firewall updated!"))},"syncFirewall");import{spawnSync as wa}from"node:child_process";var Oe=E(()=>{wa("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",Ha="SOLANA_METRICS_CONFIG=host=https://metrics.solana.com:8086,db=tds,u=testnet_write,p=c4fa841aa918bf8274e3e2a44d77568d9861b3ea",Ya=`/home/${t_.USERNAME}/.local/share/solana/install/active_release/bin`,ki=E((_=!0)=>{let{scriptPath:e}=v_(_),t=_?Ha:va,o=Ya;return`[Unit]
6096
+ `),i)},"logRotates");import{existsSync as Ht}from"fs";import{execSync as yi}from"child_process";function Ne(_=!1){if(console.log("Creating logrotate configuration for solana"),!_&&Ht(L.SOL_LOGROTATE)&&console.log("SOL_LOGROTATE_PATH already exists. Skipping logrotate configuration."),!_&&!Ht(L.SOL_LOGROTATE)){let e=HE("solv",_);yi(`echo "${e}" | sudo tee ${L.SOL_LOGROTATE} > /dev/null`),console.log("Logrotate configuration created.")}if(_&&!Ht(L.FRANKENDANCER_LOGROTATE)){let e=HE("solv",_);yi(`echo "${e}" | sudo tee ${L.FRANKENDANCER_LOGROTATE} > /dev/null`),console.log("Logrotate configuration created.")}_&&Ht(L.FRANKENDANCER_LOGROTATE)&&console.log("FRANKENDANCER_LOGROTATE already exists. Skipping logrotate configuration.")}E(Ne,"setupLogrotate");import{spawnSync as Ka}from"child_process";var Yt=E(()=>{Ka("sudo rm -rf /home/solv/solana-validator.log.*",{shell:!0,stdio:"inherit"})},"rmLogs");import{spawnSync as Ga}from"child_process";var Ki=E(()=>{Ga("sudo systemctl restart logrotate",{shell:!0,stdio:"inherit"})},"restartLogrotate");var Qe=E(_=>{Yt();let e=`sudo rm -rf ${L.SOL_LOGROTATE} && sudo rm -rf ${L.FRANKENDANCER_LOGROTATE}`;ka(e,{shell:!0,stdio:"inherit"}),Ne(_),Ki()},"updateLogrotate");import{spawnSync as Va}from"child_process";var Gi=E(()=>{Va("sudo systemctl restart frankendancer",{shell:!0,stdio:"inherit"})},"restartFiredancer");import{execAsync as Q}from"@skeet-framework/utils";import ba from"chalk";var YE=E(async()=>{await Q('echo "yes" | sudo ufw restart'),await Q('echo "yes" | sudo ufw enable'),await Q("sudo ufw allow ssh"),await Q("sudo ufw allow 53"),await Q("sudo ufw allow 8899/udp"),await Q("sudo ufw allow 8899/tcp"),await Q("sudo ufw allow 8000:8898/udp"),await Q("sudo ufw allow 8000:8898/tcp"),await Q("sudo ufw deny proto tcp from any to any port 8000:8025"),await Q("sudo ufw allow 8900:10000/tcp"),await Q("sudo ufw allow 8900:10000/udp"),await Q("sudo ufw allow 179/tcp"),await Q("sudo ufw allow 9600/tcp"),await Q("sudo ufw allow in on doublezero0 to any port 44880 proto udp"),await Q("sudo ufw allow out on doublezero0 to any port 44880 proto udp"),await Q("sudo ufw reload"),console.log(ba.white("\u2714\uFE0F Firewall updated!"))},"syncFirewall");import{spawnSync as wa}from"node:child_process";var Oe=E(()=>{wa("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",Ha="SOLANA_METRICS_CONFIG=host=https://metrics.solana.com:8086,db=tds,u=testnet_write,p=c4fa841aa918bf8274e3e2a44d77568d9861b3ea",Ya=`/home/${t_.USERNAME}/.local/share/solana/install/active_release/bin`,ki=E((_=!0)=>{let{scriptPath:e}=v_(_),t=_?Ha:va,o=Ya;return`[Unit]
6097
6097
  Description=Solana Validator
6098
6098
  After=network.target
6099
6099
  StartLimitIntervalSec=0