@gabrielhicks/solv 5.8.2 → 5.8.4
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 +7 -7
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
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.2";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.14.0-1",be="0.13.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"),Q;(function(_){_.AGAVE="agave",_.JITO="jito",_.NONE="none"})(Q||(Q={}));var Ri=Object.values(Q).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:Q.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:1e3,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.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
|
|
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
|
|
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]
|
|
6097
6097
|
Description=Solana Validator
|
|
6098
6098
|
After=network.target
|
|
6099
6099
|
StartLimitIntervalSec=0
|
|
@@ -6132,7 +6132,7 @@ Persistent=true
|
|
|
6132
6132
|
|
|
6133
6133
|
[Install]
|
|
6134
6134
|
WantedBy=timers.target
|
|
6135
|
-
`}),"jagsnapTimer"),vi=Xa;var ja=E(_=>{let{filePath:e,body:t}=wi(_),{filePath:o,body:i}=vi(_);Hi(`echo "${t}" | sudo tee ${e} > /dev/null`),Hi(`echo "${i}" | sudo tee ${o} > /dev/null`),Y_("git clone https://github.com/gabrielhicks/jag-snap.git /home/solv/jag-snap",{shell:!0,stdio:"inherit"}),Y_("cd /home/solv/jag-snap",{shell:!0,stdio:"inherit"}),Y_("sudo apt install ipset iptables -y",{shell:!0,stdio:"inherit"}),Y_("sudo iptables -A INPUT -p tcp --dport 18899 -j ACCEPT",{shell:!0,stdio:"inherit"}),Y_("sudo iptables -A INPUT -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT",{shell:!0,stdio:"inherit"}),Y_("sudo ufw allow 18899/tcp",{shell:!0,stdio:"inherit"}),Y_("sudo ufw reload",{shell:!0,stdio:"inherit"}),Y_("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"),Yi=ja;import{spawnSync as X}from"node:child_process";var za=E((_,e)=>{e?(X("curl -1sLf https://dl.cloudsmith.io/public/malbeclabs/doublezero-testnet/setup.deb.sh | sudo -E bash",{shell:!0,stdio:"inherit"}),X("sudo apt-get install doublezero",{shell:!0,stdio:"inherit"}),X("sudo apt update -y",{shell:!0,stdio:"inherit"}),X(`sudo apt install doublezero=${_} -y`,{shell:!0,stdio:"inherit"}),X("sudo apt update -y",{shell:!0,stdio:"inherit"}),X("sudo apt install doublezero-solana -y",{shell:!0,stdio:"inherit"}),X("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}),X("sudo systemctl restart doublezerod",{shell:!0,stdio:"inherit"})):(X("sudo apt update -y",{shell:!0,stdio:"inherit"}),X(`sudo apt install --upgrade-only doublezero=${_} -y`,{shell:!0,stdio:"inherit"}),X("sudo apt update -y",{shell:!0,stdio:"inherit"}),X("sudo apt install doublezero-solana -y",{shell:!0,stdio:"inherit"}),X("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}),X("sudo systemctl restart doublezerod",{shell:!0,stdio:"inherit"}))},"updateDZ"),JE=za;var Ji=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?S_:e_,R=e?Ve:be;o&&(c=k_,e&&(c=ae)),i&&(c=ce,e&&(c=ft)),n&&(c=b_,e&&(c=Ce)),t&&(c=X_,o&&(c=bo)),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=de(),N=e?_.TESTNET_DELINQUENT_STAKE:_.MAINNET_DELINQUENT_STAKE;if(console.log(xE.white(`Current solv version: ${O}`)),C.auto){await Ni(_);return}if(C.service&&(await YE(),Qe(n),$e(e)),C.migrateConfig){let S=pi().config,d=E_.TRIPLE;S.DISK_TYPES===0?d=E_.DOUBLE:S.DISK_TYPES===1?d=E_.SINGLE:d=E_.TRIPLE;let D=S.SOLANA_NETWORK===w_.TESTNET,f=S.SOLV_TYPE===At.RPC_NODE,P=S.MAINNET_TYPE===Ut.JITO_MEV,U={NETWORK:D?l.TESTNET:l.MAINNET,NODE_TYPE:f?A.RPC:A.VALIDATOR,MNT_DISK_TYPE:d,RPC_TYPE:f
|
|
6135
|
+
`}),"jagsnapTimer"),vi=Xa;var ja=E(_=>{let{filePath:e,body:t}=wi(_),{filePath:o,body:i}=vi(_);Hi(`echo "${t}" | sudo tee ${e} > /dev/null`),Hi(`echo "${i}" | sudo tee ${o} > /dev/null`),Y_("git clone https://github.com/gabrielhicks/jag-snap.git /home/solv/jag-snap",{shell:!0,stdio:"inherit"}),Y_("cd /home/solv/jag-snap",{shell:!0,stdio:"inherit"}),Y_("sudo apt install ipset iptables -y",{shell:!0,stdio:"inherit"}),Y_("sudo iptables -A INPUT -p tcp --dport 18899 -j ACCEPT",{shell:!0,stdio:"inherit"}),Y_("sudo iptables -A INPUT -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT",{shell:!0,stdio:"inherit"}),Y_("sudo ufw allow 18899/tcp",{shell:!0,stdio:"inherit"}),Y_("sudo ufw reload",{shell:!0,stdio:"inherit"}),Y_("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"),Yi=ja;import{spawnSync as X}from"node:child_process";var za=E((_,e)=>{e?(X("curl -1sLf https://dl.cloudsmith.io/public/malbeclabs/doublezero-testnet/setup.deb.sh | sudo -E bash",{shell:!0,stdio:"inherit"}),X("sudo apt-get install doublezero",{shell:!0,stdio:"inherit"}),X("sudo apt update -y",{shell:!0,stdio:"inherit"}),X(`sudo apt install doublezero=${_} -y`,{shell:!0,stdio:"inherit"}),X("sudo apt update -y",{shell:!0,stdio:"inherit"}),X("sudo apt install doublezero-solana -y",{shell:!0,stdio:"inherit"}),X("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}),X("sudo systemctl restart doublezerod",{shell:!0,stdio:"inherit"})):(X("sudo apt update -y",{shell:!0,stdio:"inherit"}),X(`sudo apt install --upgrade-only doublezero=${_} -y`,{shell:!0,stdio:"inherit"}),X("sudo apt update -y",{shell:!0,stdio:"inherit"}),X("sudo apt install doublezero-solana -y",{shell:!0,stdio:"inherit"}),X("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}),X("sudo systemctl restart doublezerod",{shell:!0,stdio:"inherit"}))},"updateDZ"),JE=za;var Ji=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?S_:e_,R=e?Ve:be;o&&(c=k_,e&&(c=ae)),i&&(c=ce,e&&(c=ft)),n&&(c=b_,e&&(c=Ce)),t&&(c=X_,o&&(c=bo)),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=de(),N=e?_.TESTNET_DELINQUENT_STAKE:_.MAINNET_DELINQUENT_STAKE;if(console.log(xE.white(`Current solv version: ${O}`)),C.auto){await Ni(_);return}if(C.service&&(await YE(),Qe(n),$e(e)),C.migrateConfig){let S=pi().config,d=E_.TRIPLE;S.DISK_TYPES===0?d=E_.DOUBLE:S.DISK_TYPES===1?d=E_.SINGLE:d=E_.TRIPLE;let D=S.SOLANA_NETWORK===w_.TESTNET,f=S.SOLV_TYPE===At.RPC_NODE,P=S.MAINNET_TYPE===Ut.JITO_MEV,U={NETWORK:D?l.TESTNET:l.MAINNET,NODE_TYPE:f?A.RPC:A.VALIDATOR,MNT_DISK_TYPE:d,RPC_TYPE:f?$.JITO:$.NONE,VALIDATOR_TYPE:P?F.JITO:D?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,MULTICAST:!1};await y(U)}if(C.configOnce){if(await y({TESTNET_SOLANA_VERSION:S_,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?ae:k_;await M_({version:S,tag:`v${S}`,commissionBps:_.MEV_COMMISSION})}if(i){let S=e?ft:ce;await M_({version:S,tag:`v${S}`,commissionBps:_.MEV_COMMISSION})}console.log(xE.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 y({TESTNET_SOLANA_VERSION:S_,MAINNET_SOLANA_VERSION:e_}),o){let S=e?ae:k_;await M_({version:S,tag:`v${S}`,commissionBps:_.MEV_COMMISSION})}if(i){let S=e?ft:ce;await M_({version:S,tag:`v${S}`,commissionBps:_.MEV_COMMISSION})}console.log(xE.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 ai();return}if(C.startup){let S=_.VALIDATOR_TYPE,d="";switch(S){case F.SOLANA:d=e?Mi():Ye(_);break;case F.AGAVE:d=e?Je(_):Ye(_);break;case F.JITO:let D=await W();d=e?Vt(D.commissionBps,D.relayerUrl,D.blockEngineUrl,D.shredReceiverAddr,_):wt(D.commissionBps,D.relayerUrl,D.blockEngineUrl,D.shredReceiverAddr,_);break;case F.BAM:let f=await W();d=e?bt(f.commissionBps,f.relayerUrl,f.blockEngineUrl,f.shredReceiverAddr,f.bamUrl,_):vt(f.commissionBps,f.relayerUrl,f.blockEngineUrl,f.shredReceiverAddr,f.bamUrl,_);break;default:console.log("Unknown Validator Type for Update Script");break}await Za(N_,d,"utf-8"),Z_();return}if(C.jagsnap){let S=_.JAG_REGION;Yi(S)}if(C.background){let S=C.version,d=e?Ve:be,D=!!S.startsWith("3");if(await y({TESTNET_SOLANA_VERSION:S_,MAINNET_SOLANA_VERSION:e_}),e&&await YE(),Qe(n),$e(e),JE(d,e),o){let P=e?Se:V_,U=`v${S}-jito`,h=`v${S}-mod`,m=C.mod||r?`${h}`:`${U}`;mt(m,C.mod||r,D,T),await M_({version:S,tag:`v${S}`}),await we(N,!0,a),Fe(),xt(),Oe(),Jt();return}if(i){let P=Re,U=`v${S}-jito`,h=`v${S}-mod`,m=C.mod||r?`${h}`:`${U}`;kt(m,C.mod||r,D,T),await M_({version:S,tag:`v${S}`}),await we(N,!0,a),Fe(),xt(),Oe(),Jt();return}if(n){await Gt(_,S,C.mod||r),await we(N,!0,a),Qt(),bi(),Gi();return}await Pt(S),await we(e?10:5,!0,a),Fe(),xt(),Oe(),Jt();return}else if(C.commission){let S=await Ti();ri(S.commission,e)}else ni();C.dz&&JE(R,e)})},"updateCommands");import{spawnSync as _S}from"node:child_process";var xi=E(_=>{try{let{log:e}=v_(),t=`tail -f ${e}`;_.error?t+=" | grep '\\(WARN\\|ERR\\)'":_.info?t+=" | grep INFO":_.warning&&(t+=" | grep WARN"),console.log(t);let o=_S(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 Qi=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(_=>{xi(_)})},"logCommands");import h_ from"chalk";import{spawnSync as eS}from"child_process";import{homedir as tS}from"os";var $t=E(_=>{let e=tS(),t=B(e),o=t.testnetValidatorVoteKey,i=t.testnetValidatorKey,n=t.testnetValidatorAuthorityKey,s=w_.TESTNET,r=_.COMMISSION;_.NETWORK===l.MAINNET&&(o=t.mainnetValidatorVoteKey,i=t.mainnetValidatorKey,n=t.mainnetValidatorAuthorityKey,s=w_.MAINNET),console.log(`\u231B\uFE0F Creating vote account with commission ${r} - ${s}`);let T=_.RPC_URL||s;_.NETWORK===l.TESTNET&&(T=w_.TESTNET);let a=`solana create-vote-account ${o} ${i} ${n} --commission ${r} --url ${T} --keypair ${i}`;eS(a,{shell:!0,stdio:"inherit"})},"setupVoteAccount");import{spawnSync as qt}from"child_process";import{existsSync as $i,readdirSync as ES,rmSync as oS}from"fs";import{homedir as iS}from"os";import qi from"path";var Wt=E(_=>{let e=[],t=0;_.NODE_TYPE===A.RPC&&(e=[g.MAINNET_VALIDATOR_KEY],t=1),_.NETWORK===l.TESTNET?(e=[g.TESTNET_VALIDATOR_KEY,g.TESTNET_VALITATOR_AUTHORITY_KEY,g.TESTNET_VALIDATOR_VOTE_KEY,g.MAINNET_VALIDATOR_KEY,g.MAINNET_VALITATOR_AUTHORITY_KEY,g.MAINNET_VALIDATOR_VOTE_KEY],t=6):(e=[g.MAINNET_VALIDATOR_KEY,g.MAINNET_VALITATOR_AUTHORITY_KEY,g.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=ES("./").filter(T=>T.endsWith("SV.json")),n=iS(),s=qi.join(n,"unstaked-identity.json");$i(s)&&qt(`mv ${s} ${n}/unstaked-identity.backup.json`,{shell:!0,stdio:"ignore"});let r=0;for(let T of i){let a=qi.join(n,e[r]);if(r++,$i(a)){console.log(`${a} is already exist!`),oS(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 Xi}from"child_process";var nS=E((_,e,t,o=2001)=>{let i="/etc/systemd/system/jupiter-api.service",n=`[Unit]
|
|
6136
6136
|
Description=Jupiter API Service Instance
|
|
6137
6137
|
After=network.target
|
|
6138
6138
|
|
|
@@ -6153,7 +6153,7 @@ unzip jupiter-swap-api-x86_64-unknown-linux-gnu.zip
|
|
|
6153
6153
|
chmod +x jupiter-swap-api
|
|
6154
6154
|
rm jupiter-swap-api-x86_64-unknown-linux-gnu.zip`,{shell:!0,stdio:"inherit"});let{filePath:t,body:o}=Wi(_.rpcUrl,_.grpcUrl,_.grpcToken);Xi(`echo '${o}' | sudo tee ${t}`,{shell:!0,stdio:"inherit"}),console.log(rS.white(`\u{1F7E2} Jupiter Swap API Setup Completed
|
|
6155
6155
|
|
|
6156
|
-
$ solv jupiter --help`))},"jupiterAPISetup"),ji=TS;import{spawnSync as aS}from"child_process";var qe=E(()=>{aS("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})},"daemonReload");import We from"chalk";import jt from"inquirer";import SS from"inquirer";var zi=E(async _=>{let t=Object.keys(_?xe.TESTNET:xe.MAINNET),o=_?xe.TESTNET:xe.MAINNET,i=await SS.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 cS from"inquirer";import{readFileSync as RS}from"fs";import{join as Xt}from"path";var CS=["amsterdam","brazil","dublin","frankfurt","london","mexicocity","newyork","saltlakecity","singapore","southafrica","tokyo"],Zi=E(async _=>_?"testnet":(await cS.prompt([{name:"location",type:"list",message:"Select the closest location for chrony NTP configuration",choices:CS.map(t=>({name:t.charAt(0).toUpperCase()+t.slice(1).replace(/([A-Z])/g," $1"),value:t}))}])).location,"askChronyLocation"),dS=E((_,e)=>{let t=__dirname,o;t.includes("dist")?o=Xt(t,"..","..",".."):o=Xt(t,"..","..","..");let i=_===l.MAINNET?"mainnet":"testnet",n=_===l.MAINNET?`${e}.conf`:"testnet.conf",s=Xt(o,"dist","cli","chrony",i,n),r=Xt(o,"src","cli","chrony",i,n),T=PT("fs");return T.existsSync(s)?s:T.existsSync(r)?r:s},"getChronyConfigPath"),_n=E((_,e)=>{let t=dS(_,e);try{return RS(t,"utf-8")}catch(o){throw new Error(`Failed to read chrony config file at ${t}: ${o}`)}},"getChronyConfigContent");var lS=E(async()=>{try{let _=F.NONE,e
|
|
6156
|
+
$ solv jupiter --help`))},"jupiterAPISetup"),ji=TS;import{spawnSync as aS}from"child_process";var qe=E(()=>{aS("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"})},"daemonReload");import We from"chalk";import jt from"inquirer";import SS from"inquirer";var zi=E(async _=>{let t=Object.keys(_?xe.TESTNET:xe.MAINNET),o=_?xe.TESTNET:xe.MAINNET,i=await SS.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 cS from"inquirer";import{readFileSync as RS}from"fs";import{join as Xt}from"path";var CS=["amsterdam","brazil","dublin","frankfurt","london","mexicocity","newyork","saltlakecity","singapore","southafrica","tokyo"],Zi=E(async _=>_?"testnet":(await cS.prompt([{name:"location",type:"list",message:"Select the closest location for chrony NTP configuration",choices:CS.map(t=>({name:t.charAt(0).toUpperCase()+t.slice(1).replace(/([A-Z])/g," $1"),value:t}))}])).location,"askChronyLocation"),dS=E((_,e)=>{let t=__dirname,o;t.includes("dist")?o=Xt(t,"..","..",".."):o=Xt(t,"..","..","..");let i=_===l.MAINNET?"mainnet":"testnet",n=_===l.MAINNET?`${e}.conf`:"testnet.conf",s=Xt(o,"dist","cli","chrony",i,n),r=Xt(o,"src","cli","chrony",i,n),T=PT("fs");return T.existsSync(s)?s:T.existsSync(r)?r:s},"getChronyConfigPath"),_n=E((_,e)=>{let t=dS(_,e);try{return RS(t,"utf-8")}catch(o){throw new Error(`Failed to read chrony config file at ${t}: ${o}`)}},"getChronyConfigContent");var lS=E(async()=>{try{let _=F.NONE,e=$.AGAVE,t=L_.COMMISSION,o=!1,i="",n=await jt.prompt([{name:"network",type:"list",message:"Choose Network",choices:Si,default:l.MAINNET},{name:"nodeType",type:"list",message:"Choose Node Type",choices:ci,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 jt.prompt({name:"validatorType",type:"list",message:"Choose Validator Type",choices:a,default:F.AGAVE}).then(c=>c.validatorType),e=$.NONE}if(n.nodeType===A.RPC&&(e=await jt.prompt({name:"rpcType",type:"list",message:"Choose RPC Type",choices:Ri,default:$.AGAVE}).then(a=>a.rpcType)),n.nodeType===A.VALIDATOR){let a=await jt.prompt([{name:"commission",type:"number",message:`What is your commission rate? You can change it later (default: ${L_.COMMISSION}%)'`,default:L_.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 W();let c=await zi(s);await M_(c)}}i=await Zi(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 y({NETWORK:r,NODE_TYPE:T,VALIDATOR_TYPE:_,RPC_TYPE:e,COMMISSION:t,IS_DUMMY:o,CHRONY_LOCATION:i}),!0}catch(_){throw new Error(_)}},"initialConfigSetup"),en=lS;import{spawnSync as n_}from"child_process";var Xe=E((_=k_,e=!1,t=!1,o=!1)=>{e?n_(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-solana/${_}/installer)"`,{shell:!0,stdio:"inherit"}):(n_(`mkdir /tmp/${_}`,{shell:!0,stdio:"inherit"}),n_(`cd /tmp/${_}`,{shell:!0,stdio:"inherit"}),n_(`git -C /tmp/${_} clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules .`,{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"}),n_("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}))},"installJito");var tn=E(()=>{let t=F_.filter(i=>i!=="").map(i=>`--known-validator ${i} \\`).join(`
|
|
6157
6157
|
`);return`#!/bin/bash
|
|
6158
6158
|
exec agave-validator \\
|
|
6159
6159
|
--identity ${p} \\
|
|
@@ -6222,7 +6222,7 @@ ${t}
|
|
|
6222
6222
|
--wal-recovery-mode skip_any_corrupted_record \\
|
|
6223
6223
|
--use-snapshot-archives-at-startup when-newest \\
|
|
6224
6224
|
--limit-ledger-size 400000000 \\
|
|
6225
|
-
`},"startRPCNodeScript");var FS=E(async _=>{let e=_.RPC_TYPE,t="";switch(e){case
|
|
6225
|
+
`},"startRPCNodeScript");var FS=E(async _=>{let e=_.RPC_TYPE,t="";switch(e){case $.AGAVE:console.log("Agave RPC Node Setup"),G_(_.TESTNET_SOLANA_VERSION),t=En();break;case $.JITO:console.log("JITO RPC Node Setup");let o=V_,n=`${`v${ae}-jito`}`;Xe(n),t=tn();break;default:console.log("Unknown RPC Node Setup");break}if(await NS(N_)){console.log("Startup script already exists. Skipping...");return}await OS(N_,t,"utf-8"),Z_()},"setupRpcNode"),on=FS;import{writeFile as an}from"fs/promises";import{spawnSync as s_}from"child_process";var QE=E((_,e=!1,t=!1,o=!1)=>{e?s_(`sh -c "$(curl --netrc-optional -sSfL https://raw.githubusercontent.com/gabrielhicks/jito-solana/${_}/installer)"`,{shell:!0,stdio:"inherit"}):(s_(`mkdir /tmp/${_}`,{shell:!0,stdio:"inherit"}),s_(`cd /tmp/${_}`,{shell:!0,stdio:"inherit"}),s_(`git -C /tmp/${_} clone https://github.com/jito-foundation/jito-solana.git --recurse-submodules .`,{shell:!0,stdio:"inherit"}),s_(`git -C /tmp/${_} checkout ${_}`,{shell:!0,stdio:"inherit"}),s_(`git -C /tmp/${_} submodule update --init --recursive`,{shell:!0,stdio:"inherit"}),s_(`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"}),s_("sudo rm -rf /home/solv/.local/share/solana/install/active_release",{shell:!0,stdio:"inherit"}),s_(`sudo ln -sfn /home/solv/.local/share/solana/install/releases/${_} /home/solv/.local/share/solana/install/active_release`,{shell:!0,stdio:"inherit"}),o&&s_("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"}),s_(`sudo rm -rf /tmp/${_}`,{shell:!0,stdio:"inherit"}),s_("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}))},"installBam");import{spawnSync as K}from"child_process";import{promises as $E}from"fs";import AS from"path";var IS=E(()=>({filePath:"/home/solv/start-firedancer.sh",body:`#!/usr/bin/env bash
|
|
6226
6226
|
sudo chmod -R 755 /mnt
|
|
6227
6227
|
sudo fdctl configure init all --config /home/solv/firedancer/config.toml
|
|
6228
6228
|
sudo chown -R solv:solv /mnt
|
|
@@ -6683,7 +6683,7 @@ ${_.influxdbDzMetrics?`
|
|
|
6683
6683
|
[outputs.influxdb.tagpass]
|
|
6684
6684
|
pipeline = ["doublezero"]
|
|
6685
6685
|
`:""}
|
|
6686
|
-
`},"generateTelegrafConfig");var Qs=E(async _=>{console.log(xs.white("\u2699\uFE0F Configuring telegraf..."));let e="/etc/telegraf/telegraf.conf",t=Js(_),o="/tmp/telegraf.conf.new";KR(o,t,"utf-8"),oo(`sudo mv ${o} ${e}`,{shell:!0,stdio:"inherit"}),oo(`sudo chown
|
|
6686
|
+
`},"generateTelegrafConfig");var Qs=E(async _=>{console.log(xs.white("\u2699\uFE0F Configuring telegraf..."));let e="/etc/telegraf/telegraf.conf",t=Js(_),o="/tmp/telegraf.conf.new";KR(o,t,"utf-8"),oo(`sudo mv ${o} ${e}`,{shell:!0,stdio:"inherit"}),oo(`sudo chown solv:solv ${e}`,{shell:!0,stdio:"inherit"}),oo(`sudo chmod 664 ${e}`,{shell:!0,stdio:"inherit"}),console.log(xs.green("\u2705 Telegraf configuration written"))},"configureTelegraf");import{spawnSync as B_}from"node:child_process";import{existsSync as io,writeFileSync as no}from"fs";import Le from"chalk";var $s=E(async()=>{console.log(Le.white("\u{1F535} Setting up doublezero monitoring..."));let _="/opt/doublezero";io(_)||B_(`sudo mkdir -p ${_}`,{shell:!0,stdio:"inherit"});let e=`#!/usr/bin/env python3
|
|
6687
6687
|
import os
|
|
6688
6688
|
import re
|
|
6689
6689
|
import urllib.request
|
|
@@ -6797,7 +6797,7 @@ if __name__ == "__main__":
|
|
|
6797
6797
|
password = "1b91CP@44b3c"
|
|
6798
6798
|
[outputs.influxdb.tagpass]
|
|
6799
6799
|
pipeline = ["doublezero"]
|
|
6800
|
-
`;let a="/tmp/telegraf.conf.new";no(a,o,"utf-8"),B_(`sudo mv ${a} ${_}`,{shell:!0,stdio:"inherit"}),B_(`sudo chown
|
|
6800
|
+
`;let a="/tmp/telegraf.conf.new";no(a,o,"utf-8"),B_(`sudo mv ${a} ${_}`,{shell:!0,stdio:"inherit"}),B_(`sudo chown solv:solv ${_}`,{shell:!0,stdio:"inherit"}),B_(`sudo chmod 664 ${_}`,{shell:!0,stdio:"inherit"}),console.log(Le.green("\u2705 Telegraf config updated for doublezero"))},"updateTelegrafForDoublezero");import{spawnSync as qs}from"node:child_process";import Ws from"chalk";var OE=E(async()=>{if(console.log(Ws.white("\u{1F504} Restarting telegraf service...")),qs("sudo systemctl daemon-reload",{shell:!0,stdio:"inherit"}),qs("sudo systemctl restart telegraf.service",{shell:!0,stdio:"inherit"}).status===0)console.log(Ws.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 FE,readFileSync as kR}from"fs";import{join as ie,dirname as Xs}from"path";import{fileURLToPath as js}from"url";import l_ from"chalk";var zs=E(async(_,e,t)=>{console.log(l_.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(l_.white("Installing python3-venv package...")),J("which apt",{shell:!0,stdio:"pipe"}).stdout.toString().trim()){let h=`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 ${h}`,{shell:!0,stdio:"inherit"}).status!==0)throw new Error(`Failed to install ${h}. Please install it manually: sudo apt install ${h}`)}else throw new Error("python3-venv is not available. Please install it manually.");if(z(i)&&!z(`${n}/pip`)&&(console.log(l_.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(l_.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(l_.white("Installing Python dependencies..."));let T=`numpy>=1.21.0
|
|
6801
6801
|
requests>=2.25.0`,a="/tmp/monitoring_requirements.txt";if(FE(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=js(import.meta.url),N=Xs(O);for(let P=0;P<15;P++){let U=ie(N,"cli","monitoring","scripts");if(z(U)){C=U;break}let h=ie(N,"src","cli","monitoring","scripts");if(z(h)){C=h;break}let m=ie(N,"scripts");if(z(m)&&z(ie(m,"common.py"))){C=m;break}let a_=Xs(N);if(a_===N)break;N=a_}if(!C){let P=ie(process.cwd(),"dist","cli","monitoring","scripts");if(z(P))C=P;else{let U=ie(process.cwd(),"src","cli","monitoring","scripts");z(U)&&(C=U)}}if(!C)throw console.error(l_.red("Could not locate monitoring scripts directory.")),console.error(l_.red(`Searched from: ${js(import.meta.url)}`)),console.error(l_.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(l_.white(`Using scripts from: ${C}`));for(let P of R){console.log(l_.white(`Copying ${P}...`));let U=ie(C,P),h=`${s}/${P}`,m=`/tmp/${P}`;if(!z(U))throw new Error(`Local script not found: ${U}`);let a_=kR(U,"utf-8");FE(m,a_,"utf-8"),J(`sudo mv ${m} ${h}`,{shell:!0,stdio:"inherit"}),J(`sudo chown ${_}:${_} ${h}`,{shell:!0,stdio:"inherit"})}let S=`from common import ValidatorConfig
|
|
6802
6802
|
|
|
6803
6803
|
config = ValidatorConfig(
|