wative 1.1.16 → 1.1.18
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/lib/account.d.ts +14 -0
- package/lib/account.d.ts.map +1 -0
- package/lib/assets.d.ts +11 -0
- package/lib/assets.d.ts.map +1 -0
- package/lib/chain.d.ts +6 -0
- package/lib/chain.d.ts.map +1 -0
- package/lib/config.d.ts +23 -0
- package/lib/config.d.ts.map +1 -0
- package/lib/daemon-watcher.js +181 -0
- package/lib/home_page.d.ts +4 -0
- package/lib/home_page.d.ts.map +1 -0
- package/lib/index.d.ts +12 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.esm.js +1 -1
- package/lib/index.umd.js +1 -1
- package/lib/network.d.ts +28 -0
- package/lib/network.d.ts.map +1 -0
- package/lib/ssh/client.d.ts +120 -0
- package/lib/ssh/client.d.ts.map +1 -0
- package/lib/ssh/client_example.d.ts +19 -0
- package/lib/ssh/client_example.d.ts.map +1 -0
- package/lib/ssh/client_test.d.ts +27 -0
- package/lib/ssh/client_test.d.ts.map +1 -0
- package/lib/ssh/config_manager.d.ts +55 -0
- package/lib/ssh/config_manager.d.ts.map +1 -0
- package/lib/ssh/config_template.d.ts +52 -0
- package/lib/ssh/config_template.d.ts.map +1 -0
- package/lib/ssh/index.d.ts +8 -0
- package/lib/ssh/index.d.ts.map +1 -0
- package/lib/ssh/remote_server_example.d.ts +16 -0
- package/lib/ssh/remote_server_example.d.ts.map +1 -0
- package/lib/ssh/service_manager.d.ts +119 -0
- package/lib/ssh/service_manager.d.ts.map +1 -0
- package/lib/ssh/types.d.ts +45 -0
- package/lib/ssh/types.d.ts.map +1 -0
- package/lib/ssh/utils.d.ts +11 -0
- package/lib/ssh/utils.d.ts.map +1 -0
- package/lib/ssh/wative_server.d.ts +26 -0
- package/lib/ssh/wative_server.d.ts.map +1 -0
- package/lib/tools.d.ts +6 -0
- package/lib/tools.d.ts.map +1 -0
- package/lib/tx_gas_utils.d.ts +18 -0
- package/lib/tx_gas_utils.d.ts.map +1 -0
- package/lib/utils.d.ts +49 -0
- package/lib/utils.d.ts.map +1 -0
- package/lib/wative.d.ts +4 -0
- package/lib/wative.d.ts.map +1 -0
- package/lib/wative.esm.js +1 -1
- package/lib/wative.umd.js +1 -1
- package/lib/web3.d.ts +59 -0
- package/lib/web3.d.ts.map +1 -0
- package/package.json +10 -6
- package/src/daemon-watcher.js +181 -0
- package/src/index.ts +22 -6
- package/src/ssh/client.rs +221 -0
- package/src/ssh/client.ts +389 -0
- package/src/ssh/config_manager.ts +317 -0
- package/src/ssh/index.ts +50 -36
- package/src/ssh/service_manager.ts +684 -0
- package/src/ssh/types.ts +35 -1
- package/src/ssh/wative_server.ts +1 -2
- package/src/wative.ts +566 -122
- package/bin/wative-ssh.sh +0 -44
- package/lib/wative-ssh.esm.js +0 -1
- package/lib/wative-ssh.umd.js +0 -1
package/lib/index.esm.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import*as e from"fs";import*as t from"path";import*as n from"figlet";import r from"inquirer";import a from"web3";import{Connection as s,PublicKey as o,Transaction as c,ComputeBudgetProgram as i,SystemProgram as u}from"@solana/web3.js";import{getAssociatedTokenAddressSync as l,getMint as d,createTransferInstruction as p,createAssociatedTokenAccountInstruction as h}from"@solana/spl-token";import{Metaplex as f}from"@metaplex-foundation/js";import{BigNumber as m}from"bignumber.js";function v(e,t,n,r){return new(n||(n=Promise))(function(a,s){function o(e){try{i(r.next(e))}catch(e){s(e)}}function c(e){try{i(r.throw(e))}catch(e){s(e)}}function i(e){var t;e.done?a(e.value):(t=e.value,t instanceof n?t:new n(function(e){e(t)})).then(o,c)}i((r=r.apply(e,t||[])).next())})}function g(e,t){var n,r,a,s={label:0,sent:function(){if(1&a[0])throw a[1];return a[1]},trys:[],ops:[]},o=Object.create(("function"==typeof Iterator?Iterator:Object).prototype);return o.next=c(0),o.throw=c(1),o.return=c(2),"function"==typeof Symbol&&(o[Symbol.iterator]=function(){return this}),o;function c(c){return function(i){return function(c){if(n)throw new TypeError("Generator is already executing.");for(;o&&(o=0,c[0]&&(s=0)),s;)try{if(n=1,r&&(a=2&c[0]?r.return:c[0]?r.throw||((a=r.return)&&a.call(r),0):r.next)&&!(a=a.call(r,c[1])).done)return a;switch(r=0,a&&(c=[2&c[0],a.value]),c[0]){case 0:case 1:a=c;break;case 4:return s.label++,{value:c[1],done:!1};case 5:s.label++,r=c[1],c=[0];continue;case 7:c=s.ops.pop(),s.trys.pop();continue;default:if(!(a=s.trys,(a=a.length>0&&a[a.length-1])||6!==c[0]&&2!==c[0])){s=0;continue}if(3===c[0]&&(!a||c[1]>a[0]&&c[1]<a[3])){s.label=c[1];break}if(6===c[0]&&s.label<a[1]){s.label=a[1],a=c;break}if(a&&s.label<a[2]){s.label=a[2],s.ops.push(c);break}a[2]&&s.ops.pop(),s.trys.pop();continue}c=t.call(e,s)}catch(e){c=[6,e],r=0}finally{n=a=0}if(5&c[0])throw c[1];return{value:c[0]?c[1]:void 0,done:!0}}([c,i])}}}"function"==typeof SuppressedError&&SuppressedError;var w={},b=function(e){return v(void 0,void 0,void 0,function(){var t;return g(this,function(n){switch(n.label){case 0:return t=new a(e),[4,jt(t.eth.getChainId,[])];case 1:return[2,n.sent()]}})})},y=function(e,t){return v(void 0,void 0,void 0,function(){var n;return g(this,function(r){switch(r.label){case 0:return n=new a(t),[4,jt(n.eth.getBalance,[e])];case 1:return[2,r.sent()]}})})},k=function(e,t){return v(void 0,void 0,void 0,function(){var n;return g(this,function(r){switch(r.label){case 0:return n=new s(t),[4,jt(n.getBalance.bind(n),[new o(e)])];case 1:return[2,r.sent()]}})})},S=function(e,t){return v(void 0,void 0,void 0,function(){var n,r,s,o,c;return g(this,function(i){switch(i.label){case 0:return n=new a(t),r=new n.eth.Contract([{constant:!0,inputs:[],name:"symbol",outputs:[{name:"",type:"string"}],payable:!1,stateMutability:"view",type:"function"},{constant:!0,inputs:[],name:"name",outputs:[{name:"",type:"string"}],payable:!1,stateMutability:"view",type:"function"},{constant:!0,inputs:[],name:"decimals",outputs:[{name:"",type:"uint256"}],payable:!1,stateMutability:"view",type:"function"}],e),[4,jt(r.methods.symbol().call.bind(r),[])];case 1:return s=i.sent(),[4,jt(r.methods.name().call.bind(r),[])];case 2:return o=i.sent(),[4,jt(r.methods.decimals().call.bind(r),[])];case 3:return c=i.sent(),s.status&&o.status&&c.status?[2,{status:!0,output:{symbol:s.output,name:o.output,decimals:c.output}}]:[2,{status:!1,output:"Failed to get token info"}]}})})},x=function(e,t){return v(void 0,void 0,void 0,function(){var n,r,a,c,i,u,l;return g(this,function(p){switch(p.label){case 0:return n=new s(t),r=f.make(n),a=new o(e),[4,jt(d,[n,a])];case 1:if(c=p.sent(),i={status:!0,output:{symbol:"",name:"",decimals:""}},!c.status)return[2,{status:!1,output:"Failed to get token decimals"}];i.output.decimals=c.output.decimals,p.label=2;case 2:return p.trys.push([2,6,,7]),u=r.nfts().pdas().metadata({mint:a}),[4,n.getAccountInfo(u)];case 3:return p.sent()?[4,r.nfts().findByMint({mintAddress:a})]:[3,5];case 4:l=p.sent(),i.output.name=l.name,i.output.symbol=l.symbol,p.label=5;case 5:return[3,7];case 6:return p.sent(),[2,{status:!1,output:"Failed to get token name"}];case 7:return[2,i]}})})},N=function(e,t,n){return v(void 0,void 0,void 0,function(){var r,s,o;return g(this,function(c){switch(c.label){case 0:return r=new a(n),s=new r.eth.Contract([{constant:!0,inputs:[{name:"who",type:"address"}],name:"balanceOf",outputs:[{name:"",type:"uint256"}],payable:!1,stateMutability:"view",type:"function"}],t),[4,jt(s.methods.balanceOf(e).call.bind(s),[])];case 1:return(o=c.sent()).status?[2,{status:!0,output:o.output}]:[2,{status:!1,output:"Failed to get token balance"}]}})})},O=function(e,t,n){return v(void 0,void 0,void 0,function(){var r,a,c;return g(this,function(i){switch(i.label){case 0:return r=new s(n),a=l(new o(t),new o(e)),[4,jt(r.getTokenAccountBalance.bind(r),[a])];case 1:return(c=i.sent()).status?[2,{status:!0,output:c.output.value.amount}]:c.output.includes("could not find account")?[2,{status:!0,output:"0"}]:[2,{status:!1,output:"Failed to get token balance"}]}})})},F=function(e){return v(void 0,void 0,void 0,function(){var t,n,r,a;return g(this,function(o){switch(o.label){case 0:return t=new s(e),[4,jt(t.getRecentPrioritizationFees.bind(t),[])];case 1:return(n=o.sent()).status?(r=n.output,a=r.map(function(e){return e.prioritizationFee}).sort(),[2,{status:!0,output:a.length>0?Math.ceil(a.reduce(function(e,t){return e+t})/a.length):1e3}]):[2,{status:!1,output:"Failed to get recent prioritization fees"}]}})})},P=function(e,t){return v(void 0,void 0,void 0,function(){var n,r;return g(this,function(a){switch(a.label){case 0:return n=new s(t),[4,jt(n.getAccountInfo.bind(n),[new o(e.toString())])];case 1:return(r=a.sent()).status?[2,{status:!0,output:r.output}]:[2,{status:!1,output:"Failed to get account info"}]}})})},A=function(e,t,n,r,a){return v(void 0,void 0,void 0,function(){var s,o,c,i,u;return g(this,function(l){switch(l.label){case 0:n in w?s=w[n][t]||{}:(w[n]={},s={}),o=0,c=e,l.label=1;case 1:return o<c.length?(i=c[o])?i in s?[3,12]:(u=void 0,"0"!==t?[3,6]:a?[4,y(i,r)]:[3,3]):[3,12]:[3,13];case 2:return u=l.sent(),[3,5];case 3:return[4,k(i,r)];case 4:u=l.sent(),l.label=5;case 5:return[3,10];case 6:return a?[4,N(i,t,r)]:[3,8];case 7:return u=l.sent(),[3,10];case 8:return[4,O(i,t,r)];case 9:u=l.sent(),l.label=10;case 10:return u.status&&(s[i]=u.output),[4,Jt(200)];case 11:l.sent(),l.label=12;case 12:return o++,[3,1];case 13:return w[n][t]=s,[2,w]}})})},_=function(e,t,n){for(var r=0;r<t.length;r++)for(var a=t[r],s=0;s<n.length;s++){var o=n[s];try{delete w[e][o][a]}catch(e){}}},T=["abandon","ability","able","about","above","absent","absorb","abstract","absurd","abuse","access","accident","account","accuse","achieve","acid","acoustic","acquire","across","act","action","actor","actress","actual","adapt","add","addict","address","adjust","admit","adult","advance","advice","aerobic","affair","afford","afraid","again","age","agent","agree","ahead","aim","air","airport","aisle","alarm","album","alcohol","alert","alien","all","alley","allow","almost","alone","alpha","already","also","alter","always","amateur","amazing","among","amount","amused","analyst","anchor","ancient","anger","angle","angry","animal","ankle","announce","annual","another","answer","antenna","antique","anxiety","any","apart","apology","appear","apple","approve","april","arch","arctic","area","arena","argue","arm","armed","armor","army","around","arrange","arrest","arrive","arrow","art","artefact","artist","artwork","ask","aspect","assault","asset","assist","assume","asthma","athlete","atom","attack","attend","attitude","attract","auction","audit","august","aunt","author","auto","autumn","average","avocado","avoid","awake","aware","away","awesome","awful","awkward","axis","baby","bachelor","bacon","badge","bag","balance","balcony","ball","bamboo","banana","banner","bar","barely","bargain","barrel","base","basic","basket","battle","beach","bean","beauty","because","become","beef","before","begin","behave","behind","believe","below","belt","bench","benefit","best","betray","better","between","beyond","bicycle","bid","bike","bind","biology","bird","birth","bitter","black","blade","blame","blanket","blast","bleak","bless","blind","blood","blossom","blouse","blue","blur","blush","board","boat","body","boil","bomb","bone","bonus","book","boost","border","boring","borrow","boss","bottom","bounce","box","boy","bracket","brain","brand","brass","brave","bread","breeze","brick","bridge","brief","bright","bring","brisk","broccoli","broken","bronze","broom","brother","brown","brush","bubble","buddy","budget","buffalo","build","bulb","bulk","bullet","bundle","bunker","burden","burger","burst","bus","business","busy","butter","buyer","buzz","cabbage","cabin","cable","cactus","cage","cake","call","calm","camera","camp","can","canal","cancel","candy","cannon","canoe","canvas","canyon","capable","capital","captain","car","carbon","card","cargo","carpet","carry","cart","case","cash","casino","castle","casual","cat","catalog","catch","category","cattle","caught","cause","caution","cave","ceiling","celery","cement","census","century","cereal","certain","chair","chalk","champion","change","chaos","chapter","charge","chase","chat","cheap","check","cheese","chef","cherry","chest","chicken","chief","child","chimney","choice","choose","chronic","chuckle","chunk","churn","cigar","cinnamon","circle","citizen","city","civil","claim","clap","clarify","claw","clay","clean","clerk","clever","click","client","cliff","climb","clinic","clip","clock","clog","close","cloth","cloud","clown","club","clump","cluster","clutch","coach","coast","coconut","code","coffee","coil","coin","collect","color","column","combine","come","comfort","comic","common","company","concert","conduct","confirm","congress","connect","consider","control","convince","cook","cool","copper","copy","coral","core","corn","correct","cost","cotton","couch","country","couple","course","cousin","cover","coyote","crack","cradle","craft","cram","crane","crash","crater","crawl","crazy","cream","credit","creek","crew","cricket","crime","crisp","critic","crop","cross","crouch","crowd","crucial","cruel","cruise","crumble","crunch","crush","cry","crystal","cube","culture","cup","cupboard","curious","current","curtain","curve","cushion","custom","cute","cycle","dad","damage","damp","dance","danger","daring","dash","daughter","dawn","day","deal","debate","debris","decade","december","decide","decline","decorate","decrease","deer","defense","define","defy","degree","delay","deliver","demand","demise","denial","dentist","deny","depart","depend","deposit","depth","deputy","derive","describe","desert","design","desk","despair","destroy","detail","detect","develop","device","devote","diagram","dial","diamond","diary","dice","diesel","diet","differ","digital","dignity","dilemma","dinner","dinosaur","direct","dirt","disagree","discover","disease","dish","dismiss","disorder","display","distance","divert","divide","divorce","dizzy","doctor","document","dog","doll","dolphin","domain","donate","donkey","donor","door","dose","double","dove","draft","dragon","drama","drastic","draw","dream","dress","drift","drill","drink","drip","drive","drop","drum","dry","duck","dumb","dune","during","dust","dutch","duty","dwarf","dynamic","eager","eagle","early","earn","earth","easily","east","easy","echo","ecology","economy","edge","edit","educate","effort","egg","eight","either","elbow","elder","electric","elegant","element","elephant","elevator","elite","else","embark","embody","embrace","emerge","emotion","employ","empower","empty","enable","enact","end","endless","endorse","enemy","energy","enforce","engage","engine","enhance","enjoy","enlist","enough","enrich","enroll","ensure","enter","entire","entry","envelope","episode","equal","equip","era","erase","erode","erosion","error","erupt","escape","essay","essence","estate","eternal","ethics","evidence","evil","evoke","evolve","exact","example","excess","exchange","excite","exclude","excuse","execute","exercise","exhaust","exhibit","exile","exist","exit","exotic","expand","expect","expire","explain","expose","express","extend","extra","eye","eyebrow","fabric","face","faculty","fade","faint","faith","fall","false","fame","family","famous","fan","fancy","fantasy","farm","fashion","fat","fatal","father","fatigue","fault","favorite","feature","february","federal","fee","feed","feel","female","fence","festival","fetch","fever","few","fiber","fiction","field","figure","file","film","filter","final","find","fine","finger","finish","fire","firm","first","fiscal","fish","fit","fitness","fix","flag","flame","flash","flat","flavor","flee","flight","flip","float","flock","floor","flower","fluid","flush","fly","foam","focus","fog","foil","fold","follow","food","foot","force","forest","forget","fork","fortune","forum","forward","fossil","foster","found","fox","fragile","frame","frequent","fresh","friend","fringe","frog","front","frost","frown","frozen","fruit","fuel","fun","funny","furnace","fury","future","gadget","gain","galaxy","gallery","game","gap","garage","garbage","garden","garlic","garment","gas","gasp","gate","gather","gauge","gaze","general","genius","genre","gentle","genuine","gesture","ghost","giant","gift","giggle","ginger","giraffe","girl","give","glad","glance","glare","glass","glide","glimpse","globe","gloom","glory","glove","glow","glue","goat","goddess","gold","good","goose","gorilla","gospel","gossip","govern","gown","grab","grace","grain","grant","grape","grass","gravity","great","green","grid","grief","grit","grocery","group","grow","grunt","guard","guess","guide","guilt","guitar","gun","gym","habit","hair","half","hammer","hamster","hand","happy","harbor","hard","harsh","harvest","hat","have","hawk","hazard","head","health","heart","heavy","hedgehog","height","hello","helmet","help","hen","hero","hidden","high","hill","hint","hip","hire","history","hobby","hockey","hold","hole","holiday","hollow","home","honey","hood","hope","horn","horror","horse","hospital","host","hotel","hour","hover","hub","huge","human","humble","humor","hundred","hungry","hunt","hurdle","hurry","hurt","husband","hybrid","ice","icon","idea","identify","idle","ignore","ill","illegal","illness","image","imitate","immense","immune","impact","impose","improve","impulse","inch","include","income","increase","index","indicate","indoor","industry","infant","inflict","inform","inhale","inherit","initial","inject","injury","inmate","inner","innocent","input","inquiry","insane","insect","inside","inspire","install","intact","interest","into","invest","invite","involve","iron","island","isolate","issue","item","ivory","jacket","jaguar","jar","jazz","jealous","jeans","jelly","jewel","job","join","joke","journey","joy","judge","juice","jump","jungle","junior","junk","just","kangaroo","keen","keep","ketchup","key","kick","kid","kidney","kind","kingdom","kiss","kit","kitchen","kite","kitten","kiwi","knee","knife","knock","know","lab","label","labor","ladder","lady","lake","lamp","language","laptop","large","later","latin","laugh","laundry","lava","law","lawn","lawsuit","layer","lazy","leader","leaf","learn","leave","lecture","left","leg","legal","legend","leisure","lemon","lend","length","lens","leopard","lesson","letter","level","liar","liberty","library","license","life","lift","light","like","limb","limit","link","lion","liquid","list","little","live","lizard","load","loan","lobster","local","lock","logic","lonely","long","loop","lottery","loud","lounge","love","loyal","lucky","luggage","lumber","lunar","lunch","luxury","lyrics","machine","mad","magic","magnet","maid","mail","main","major","make","mammal","man","manage","mandate","mango","mansion","manual","maple","marble","march","margin","marine","market","marriage","mask","mass","master","match","material","math","matrix","matter","maximum","maze","meadow","mean","measure","meat","mechanic","medal","media","melody","melt","member","memory","mention","menu","mercy","merge","merit","merry","mesh","message","metal","method","middle","midnight","milk","million","mimic","mind","minimum","minor","minute","miracle","mirror","misery","miss","mistake","mix","mixed","mixture","mobile","model","modify","mom","moment","monitor","monkey","monster","month","moon","moral","more","morning","mosquito","mother","motion","motor","mountain","mouse","move","movie","much","muffin","mule","multiply","muscle","museum","mushroom","music","must","mutual","myself","mystery","myth","naive","name","napkin","narrow","nasty","nation","nature","near","neck","need","negative","neglect","neither","nephew","nerve","nest","net","network","neutral","never","news","next","nice","night","noble","noise","nominee","noodle","normal","north","nose","notable","note","nothing","notice","novel","now","nuclear","number","nurse","nut","oak","obey","object","oblige","obscure","observe","obtain","obvious","occur","ocean","october","odor","off","offer","office","often","oil","okay","old","olive","olympic","omit","once","one","onion","online","only","open","opera","opinion","oppose","option","orange","orbit","orchard","order","ordinary","organ","orient","original","orphan","ostrich","other","outdoor","outer","output","outside","oval","oven","over","own","owner","oxygen","oyster","ozone","pact","paddle","page","pair","palace","palm","panda","panel","panic","panther","paper","parade","parent","park","parrot","party","pass","patch","path","patient","patrol","pattern","pause","pave","payment","peace","peanut","pear","peasant","pelican","pen","penalty","pencil","people","pepper","perfect","permit","person","pet","phone","photo","phrase","physical","piano","picnic","picture","piece","pig","pigeon","pill","pilot","pink","pioneer","pipe","pistol","pitch","pizza","place","planet","plastic","plate","play","please","pledge","pluck","plug","plunge","poem","poet","point","polar","pole","police","pond","pony","pool","popular","portion","position","possible","post","potato","pottery","poverty","powder","power","practice","praise","predict","prefer","prepare","present","pretty","prevent","price","pride","primary","print","priority","prison","private","prize","problem","process","produce","profit","program","project","promote","proof","property","prosper","protect","proud","provide","public","pudding","pull","pulp","pulse","pumpkin","punch","pupil","puppy","purchase","purity","purpose","purse","push","put","puzzle","pyramid","quality","quantum","quarter","question","quick","quit","quiz","quote","rabbit","raccoon","race","rack","radar","radio","rail","rain","raise","rally","ramp","ranch","random","range","rapid","rare","rate","rather","raven","raw","razor","ready","real","reason","rebel","rebuild","recall","receive","recipe","record","recycle","reduce","reflect","reform","refuse","region","regret","regular","reject","relax","release","relief","rely","remain","remember","remind","remove","render","renew","rent","reopen","repair","repeat","replace","report","require","rescue","resemble","resist","resource","response","result","retire","retreat","return","reunion","reveal","review","reward","rhythm","rib","ribbon","rice","rich","ride","ridge","rifle","right","rigid","ring","riot","ripple","risk","ritual","rival","river","road","roast","robot","robust","rocket","romance","roof","rookie","room","rose","rotate","rough","round","route","royal","rubber","rude","rug","rule","run","runway","rural","sad","saddle","sadness","safe","sail","salad","salmon","salon","salt","salute","same","sample","sand","satisfy","satoshi","sauce","sausage","save","say","scale","scan","scare","scatter","scene","scheme","school","science","scissors","scorpion","scout","scrap","screen","script","scrub","sea","search","season","seat","second","secret","section","security","seed","seek","segment","select","sell","seminar","senior","sense","sentence","series","service","session","settle","setup","seven","shadow","shaft","shallow","share","shed","shell","sheriff","shield","shift","shine","ship","shiver","shock","shoe","shoot","shop","short","shoulder","shove","shrimp","shrug","shuffle","shy","sibling","sick","side","siege","sight","sign","silent","silk","silly","silver","similar","simple","since","sing","siren","sister","situate","six","size","skate","sketch","ski","skill","skin","skirt","skull","slab","slam","sleep","slender","slice","slide","slight","slim","slogan","slot","slow","slush","small","smart","smile","smoke","smooth","snack","snake","snap","sniff","snow","soap","soccer","social","sock","soda","soft","solar","soldier","solid","solution","solve","someone","song","soon","sorry","sort","soul","sound","soup","source","south","space","spare","spatial","spawn","speak","special","speed","spell","spend","sphere","spice","spider","spike","spin","spirit","split","spoil","sponsor","spoon","sport","spot","spray","spread","spring","spy","square","squeeze","squirrel","stable","stadium","staff","stage","stairs","stamp","stand","start","state","stay","steak","steel","stem","step","stereo","stick","still","sting","stock","stomach","stone","stool","story","stove","strategy","street","strike","strong","struggle","student","stuff","stumble","style","subject","submit","subway","success","such","sudden","suffer","sugar","suggest","suit","summer","sun","sunny","sunset","super","supply","supreme","sure","surface","surge","surprise","surround","survey","suspect","sustain","swallow","swamp","swap","swarm","swear","sweet","swift","swim","swing","switch","sword","symbol","symptom","syrup","system","table","tackle","tag","tail","talent","talk","tank","tape","target","task","taste","tattoo","taxi","teach","team","tell","ten","tenant","tennis","tent","term","test","text","thank","that","theme","then","theory","there","they","thing","this","thought","three","thrive","throw","thumb","thunder","ticket","tide","tiger","tilt","timber","time","tiny","tip","tired","tissue","title","toast","tobacco","today","toddler","toe","together","toilet","token","tomato","tomorrow","tone","tongue","tonight","tool","tooth","top","topic","topple","torch","tornado","tortoise","toss","total","tourist","toward","tower","town","toy","track","trade","traffic","tragic","train","transfer","trap","trash","travel","tray","treat","tree","trend","trial","tribe","trick","trigger","trim","trip","trophy","trouble","truck","true","truly","trumpet","trust","truth","try","tube","tuition","tumble","tuna","tunnel","turkey","turn","turtle","twelve","twenty","twice","twin","twist","two","type","typical","ugly","umbrella","unable","unaware","uncle","uncover","under","undo","unfair","unfold","unhappy","uniform","unique","unit","universe","unknown","unlock","until","unusual","unveil","update","upgrade","uphold","upon","upper","upset","urban","urge","usage","use","used","useful","useless","usual","utility","vacant","vacuum","vague","valid","valley","valve","van","vanish","vapor","various","vast","vault","vehicle","velvet","vendor","venture","venue","verb","verify","version","very","vessel","veteran","viable","vibrant","vicious","victory","video","view","village","vintage","violin","virtual","virus","visa","visit","visual","vital","vivid","vocal","voice","void","volcano","volume","vote","voyage","wage","wagon","wait","walk","wall","walnut","want","warfare","warm","warrior","wash","wasp","waste","water","wave","way","wealth","weapon","wear","weasel","weather","web","wedding","weekend","weird","welcome","west","wet","whale","what","wheat","wheel","when","where","whip","whisper","wide","width","wife","wild","will","win","window","wine","wing","wink","winner","winter","wire","wisdom","wise","wish","witness","wolf","woman","wonder","wood","wool","word","work","world","worry","worth","wrap","wreck","wrestle","wrist","write","wrong","yard","year","yellow","you","young","youth","zebra","zero","zone","zoo"],C=[{name:"Ethereum Mainnet",chainId:1,rpcUrl:"https://eth.llamarpc.com",nativeCurrency:{name:"ETH",symbol:"ETH",decimals:18},multicallAddress:"0xeefBa1e63905eF1D7ACbA5a8513c70307C1cE441"},{name:"Solana Mainnet",chainId:901,rpcUrl:"https://api.mainnet-beta.solana.com",nativeCurrency:{name:"SOL",symbol:"SOL",decimals:9}}],I=["901","902","903"],L=function(e){return I.includes(e)?9:18},B=function(e){return I.includes(e)?"solana":"evm"},j=require("bn.js").BN,R=require("ethereumjs-util").stripHexPrefix,z=require("bignumber.js").BigNumber;function J(e){return new j(R(e.toString("hex")),16)}var U=function(e){return e.match(/^-?0x/u)?e:e.match(/^-?0X/u)?e.replace("0X","0x"):e.startsWith("-")?e.replace("-","-0x"):"0x".concat(e)};function q(e){return U(e.toString(16))}var E=function(){function e(e){this.query=new a(a.givenProvider||e).eth}return e.prototype.analyzeGasUsage=function(e){return v(this,void 0,void 0,function(){var t,n,r,a,s,o;return g(this,function(c){switch(c.label){case 0:return[4,this.query.getBlock("latest",!1)];case 1:t=c.sent(),n=J(t.gasLimit),i=n,u=20,l=new j(19),d=new j(u),r=i.mul(l).div(d),a=q(r),c.label=2;case 2:return c.trys.push([2,4,,5]),[4,this.estimateTxGas(e)];case 3:return a=c.sent(),[3,5];case 4:return o=c.sent(),s={reason:o.message,errorKey:o.errorKey,debug:{blockNumber:t.number,blockGasLimit:t.gasLimit}},[3,5];case 5:return[2,{blockGasLimit:t.gasLimit,estimatedGasHex:a,simulationFails:s}]}var i,u,l,d})})},e.prototype.estimateTxGas=function(e){return v(this,void 0,void 0,function(){var t;return g(this,function(n){switch(n.label){case 0:return[4,this.query.estimateGas(e)];case 1:return t=n.sent(),[2,t=new z(t.toString()).multipliedBy(1.3).toFixed(0)]}})})},e.prototype.addGasBuffer=function(e,t,n){void 0===n&&(n=1.3);var r=J(e),a=J(t).muln(.9),s=r.muln(n);return r.gt(a)?q(r):s.lt(a)?q(s):q(a)},e.prototype.getBufferedGasLimit=function(e,t){return v(this,void 0,void 0,function(){var n,r,a,s;return g(this,function(o){switch(o.label){case 0:return[4,this.analyzeGasUsage(e)];case 1:return n=o.sent(),r=n.blockGasLimit,a=n.estimatedGasHex,s=n.simulationFails,[2,{gasLimit:this.addGasBuffer(U(a),r,t),simulationFails:s}]}})})},e.prototype.getGasPrice=function(){return v(this,void 0,void 0,function(){return g(this,function(e){switch(e.label){case 0:return[4,this.query.getGasPrice()];case 1:return[2,e.sent()]}})})},e.prototype.getTransactionCount=function(e){return v(this,void 0,void 0,function(){return g(this,function(t){switch(t.label){case 0:return[4,this.query.getTransactionCount(e)];case 1:return[2,t.sent()]}})})},e}(),M=require("chalk");require("wative-core").WativeCore;var D=function(e){return v(void 0,void 0,void 0,function(){var t,n,a,s,o,c,i,u,l,d;return g(this,function(p){switch(p.label){case 0:return t=[new r.Separator("————Tx Detail—————-"),"from: ".concat(e.from),"to: ".concat(e.to),"nonce: ".concat(e.nonce),"gasPrice: ".concat(e.gasPrice),"data: ".concat(e.data),"value: ".concat(e.value),"gas: ".concat(e.gas),new r.Separator("——————————————-"),"Send it now","Back"],[4,gt(t)];case 1:return n=p.sent(),1!==(a=t.indexOf(n))?[3,3]:(s=e,[4,at("from",vt)]);case 2:s.from=p.sent(),p.label=3;case 3:return 2!==a?[3,5]:(o=e,[4,at("to",vt)]);case 4:o.to=p.sent(),p.label=5;case 5:return 3!==a?[3,7]:(c=e,[4,at("nonce")]);case 6:c.nonce=p.sent(),p.label=7;case 7:return 4!==a?[3,9]:(i=e,[4,at("gasPrice")]);case 8:i.gasPrice=p.sent(),p.label=9;case 9:return 5!==a?[3,11]:(u=e,[4,Lt("data")]);case 10:u.data=p.sent(),p.label=11;case 11:return 6!==a?[3,13]:(l=e,[4,at("value")]);case 12:l.value=p.sent(),p.label=13;case 13:return 7!==a?[3,15]:(d=e,[4,at("gas")]);case 14:d.gas=p.sent(),p.label=15;case 15:return 9===a?[2,e]:10===a?[2,null]:[4,D(e)];case 16:return[2,p.sent()]}})})},G=function(e,t,n,r,s){return v(void 0,void 0,void 0,function(){var o,c,i,u,l,d,p,h,f,w,b,k,S,x,N,O,F,P,A,T,C,I,L,B,j;return g(this,function(R){switch(R.label){case 0:return[4,at("to",vt)];case 1:return o=R.sent(),[4,(c=new E(t)).getGasPrice()];case 2:return i=R.sent(),u=new m(i.toString()).dividedBy(1e9),l=u.toFixed(4,m.ROUND_FLOOR),[4,at("Gas price (".concat(l,"), agree or enter"),dt)];case 3:return d=R.sent(),p=new m(p=d||l).multipliedBy(1e9).toFixed(0),[4,(z=o,J=t,v(void 0,void 0,void 0,function(){var e,t;return g(this,function(n){switch(n.label){case 0:return e=new a(J),[4,jt(e.eth.getCode.bind(e),[z])];case 1:return(t=n.sent()).status?[2,{status:!0,output:t.output}]:[2,{status:!1,output:"Failed to get code"}]}})}))];case 4:return(h=R.sent()).status?(f="42161"===e||"421614"===e?"1700000":"21000","0x"!==h.output?[3,7]:(w="0x",[4,y(r,t)])):(console.log(M.red(h.output)),[2]);case 5:return(k=R.sent()).status?(S=new m(k.output),x=new m(p),N=S.minus(x.multipliedBy(Number(f))).toFixed(0,m.ROUND_FLOOR),O=new m(N).dividedBy(1e18).toFixed(4,m.ROUND_FLOOR),new m(O)<new m(0)?(console.log(M.red("Not enough balance")),[2]):[4,W(O,N,n,18)]):(console.log(M.red(k.output)),[2]);case 6:return b=R.sent(),[3,10];case 7:return[4,Lt("data",Bt)];case 8:return w=R.sent(),[4,at("value",lt)];case 9:b=R.sent(),R.label=10;case 10:return[4,c.getTransactionCount(r)];case 11:return F=R.sent(),[4,at("Nonce (".concat(F,"), agree or enter"))];case 12:return P=R.sent(),A=P||F.toString(),T={from:r,to:o,nonce:A,gasPrice:p,data:w,value:b},"0x"!==w?[3,13]:(T.gas=f,[3,18]);case 13:C=T.gasPrice,delete T.gasPrice,R.label=14;case 14:return R.trys.push([14,16,,17]),I=T,L="gas",[4,c.estimateTxGas(T)];case 15:return I[L]=R.sent().toString(),[3,17];case 16:return B=R.sent(),console.log(M.red("Error: "+B)),[2];case 17:T.gasPrice=C,R.label=18;case 18:return[4,D(T)];case 19:return(T=R.sent())?[4,s.account.signTransaction(r,T,t)]:[2];case 20:return(j=R.sent()).status?(console.log(M.green("Transaction hash: ".concat(j.output.transactionHash))),s.account.sendSignedTransaction(r,j.output.rawTransaction,t),_(e,[r,o],["0"]),[2]):(console.log(M.red(j.output)),[2])}var z,J})})},K=function(e,t,n,r,a){return v(void 0,void 0,void 0,function(){var l,d,p,h,f,w,b,y,S,x,N,O,P,A,T,C,I;return g(this,function(L){switch(L.label){case 0:return[4,at("to",vt)];case 1:return l=L.sent(),(d=(new c).add(u.transfer({fromPubkey:new o(r),toPubkey:new o(l),lamports:1e6}))).add(i.setComputeUnitLimit({units:2e5})),d.add(i.setComputeUnitPrice({microLamports:1e3})),d.feePayer=new o(r),[4,(B=t,v(void 0,void 0,void 0,function(){var e,t;return g(this,function(n){switch(n.label){case 0:return e=new s(B),[4,jt(e.getLatestBlockhash.bind(e),[{commitment:"finalized"}])];case 1:return(t=n.sent()).status?[2,{status:!0,output:t.output}]:[2,{status:!1,output:"Failed to get latest blockhash"}]}})}))];case 2:return(p=L.sent()).status?(d.recentBlockhash=p.output.blockhash,[4,a.account.simulateTransaction(r,t,d)]):(console.log(M.red(p.output)),[2]);case 3:return(h=L.sent()).status?h.output&&h.output.value&&0!==h.output.value.unitsConsumed&&!h.output.value.err?(f=new m(h.output.value.unitsConsumed.toString()).multipliedBy(1.2).toFixed(0,m.ROUND_CEIL),w=new m(f),[4,F(t)]):(console.log(M.red("Simulate error")),console.log("==================reason====================="),console.log(JSON.stringify(h.output,null,4)),console.log("=============================================="),[2]):(console.log(M.red(h.output)),[2]);case 4:return(b=L.sent()).status?(y=new m(b.output.toString()),S=w.multipliedBy(y).dividedBy(1e6).toFixed(0,m.ROUND_CEIL),[4,k(r,t)]):(console.log(M.red(b.output)),[2]);case 5:return(x=L.sent()).status?(N=new m(x.output),O=N.minus(5e3).minus(S),P=new m(O).dividedBy(1e9).toFixed(4,m.ROUND_FLOOR),new m(P)<new m(0)?(console.log(M.red("Not enough balance")),[2]):[4,W(P,O.toString(),n,9)]):(console.log(M.red(x.output)),[2]);case 6:return A=L.sent(),(T=new c).add(i.setComputeUnitLimit({units:Number(w)})),T.add(i.setComputeUnitPrice({microLamports:Number(y)})),T.add(u.transfer({fromPubkey:new o(r),toPubkey:new o(l),lamports:Number(A)})),T.feePayer=new o(r),T.recentBlockhash=p.output.blockhash,[4,a.account.signTransaction(r,T,t)];case 7:return(C=L.sent()).status?[4,a.account.sendSignedTransaction(r,C.output,t)]:(console.log(M.red(C.output)),[2]);case 8:return(I=L.sent()).status?(_(e,[r,l],["0"]),console.log(M.green("Transaction hash: ".concat(I.output))),[2]):(console.log(M.red(I.output)),[2])}var B})})},W=function(e,t,n,r){return v(void 0,void 0,void 0,function(){var a,s,o,c,i;return g(this,function(u){switch(u.label){case 0:return a=["> Input value","> Total Balance (".concat(e," ").concat(n,")")],[4,gt(a)];case 1:return s=u.sent(),o=a.indexOf(s),c="0",0!==o?[3,3]:[4,at("value",lt)];case 2:return i=u.sent(),c=new m(i).multipliedBy(Math.pow(10,r)).toFixed(0,m.ROUND_FLOOR),[3,4];case 3:1===o&&(c=t),u.label=4;case 4:return new m(c).isLessThanOrEqualTo(new m(t))?[2,c]:(console.log(M.red("Not enough balance")),[2,W(e,t,n,r)])}})})},$=function(e,t,n,r,s){return v(void 0,void 0,void 0,function(){var o,c,i,u,l,d,p,h,f,w,b,y,k,x,O,F,P,A,T,C,I,L,B,j,R,z,J,U,q,G,K,W;return g(this,function($){switch($.label){case 0:return[4,gt(["> Input token ticker","> Input token contract address"])];case 1:switch(o=$.sent(),o){case"> Input token ticker":return[3,2];case"> Input token contract address":return[3,10]}return[3,13];case 2:return[4,at("token ticker")];case 3:return u=$.sent(),[4,He(e,n,u)];case 4:if(0===(l=$.sent()).length)return console.log(M.red("Token not found")),[2];d=[],p=0,$.label=5;case 5:return p<l.length?[4,N(r,l[p].address,t)]:[3,8];case 6:if(!(h=$.sent()).status)return console.log(M.red(h.output)),[2];if(f=new m(h.output),w=f.dividedBy(Math.pow(10,Number(l[p].decimals))).toFixed(4,m.ROUND_FLOOR),1===l.length)return d.push("> 1. ".concat(u," Balance: ").concat(w)),[3,8];d.push("> ".concat(p+1,". ").concat(u," Balance: ").concat(w,"(").concat(l[p].address,")")),d.push(l[p].address),$.label=7;case 7:return p++,[3,5];case 8:return[4,gt(d)];case 9:return b=$.sent(),y=l[d.indexOf(b)],c=y.address,i=Number(y.decimals),[3,13];case 10:return[4,at("token contract address",vt)];case 11:return c=$.sent(),[4,S(c,t)];case 12:return(k=$.sent()).status?(i=Number(k.output.decimals),u=k.output.name,[3,13]):(console.log(M.red(k.output)),[2]);case 13:return[4,at("Receipt",vt)];case 14:return x=$.sent(),[4,N(r,c,t)];case 15:return(O=$.sent()).status?[4,(F=new E(t)).getGasPrice()]:(console.log(M.red(O.output)),[2]);case 16:return P=$.sent(),A=new m(P.toString()).dividedBy(1e9),T=A.toFixed(4,m.ROUND_FLOOR),[4,at("Gas price (".concat(T,"), agree or enter"),dt)];case 17:return C=$.sent(),I=new m(I=C||T).multipliedBy(1e9).toFixed(0),[4,Z(O.output,u,i)];case 18:return L=$.sent(),[4,(H=x,V=L,X=t,v(void 0,void 0,void 0,function(){return g(this,function(e){return[2,new a(X).eth.abi.encodeFunctionCall({constant:!1,inputs:[{name:"_to",type:"address"},{name:"_value",type:"uint256"}],name:"transfer",outputs:[],payable:!1,stateMutability:"nonpayable",type:"function"},[H,V])]})}))];case 19:return B=$.sent(),[4,F.getTransactionCount(r)];case 20:return j=$.sent(),[4,at("Nonce (".concat(j,"), agree or enter"))];case 21:return R=$.sent(),z=R||j.toString(),J={from:r,to:c,nonce:z,gasPrice:I,data:B,value:"0"},"0x"!==B?[3,22]:(J.gas="42161"===n||"421614"===n?"1700000":"21000",[3,27]);case 22:U=J.gasPrice,delete J.gasPrice,$.label=23;case 23:return $.trys.push([23,25,,26]),q=J,G="gas",[4,F.estimateTxGas(J)];case 24:return q[G]=$.sent().toString(),[3,26];case 25:return K=$.sent(),console.log(M.red("Failed to estimate gas, "+K.message)),[2];case 26:J.gasPrice=U,$.label=27;case 27:return[4,D(J)];case 28:return(J=$.sent())?[4,s.account.signTransaction(r,J,t)]:[2];case 29:return(W=$.sent()).status?(console.log(M.green("Transaction hash: ".concat(W.output.transactionHash))),s.account.sendSignedTransaction(r,W.output.rawTransaction,t),_(n,[r,x],["0",c]),[2]):(console.log(M.red(W.output)),[2])}var H,V,X})})},H=function(e,t,n,r,a){return v(void 0,void 0,void 0,function(){var s,u,d,f,v,w,b,y,k,S,N,A,T,C,I,L,B,j,R,z,J,U,q,E,D,G,K,W;return g(this,function(g){switch(g.label){case 0:return[4,gt(["> Input token ticker","> Input token contract address"])];case 1:switch(s=g.sent(),s){case"> Input token ticker":return[3,2];case"> Input token contract address":return[3,10]}return[3,13];case 2:return[4,at("token ticker")];case 3:return f=g.sent(),[4,He(e,n,f)];case 4:if(0===(v=g.sent()).length)return console.log(M.red("Token not found")),[2];w=[],b=0,g.label=5;case 5:return b<v.length?[4,O(r,v[b].address,t)]:[3,8];case 6:if(!(y=g.sent()).status)return console.log(M.red(y.output)),[2];if(k=new m(y.output),S=k.dividedBy(Math.pow(10,Number(v[b].decimals))).toFixed(4,m.ROUND_FLOOR),1===v.length)return w.push("> 1. ".concat(f," Balance: ").concat(S)),[3,8];w.push("> ".concat(b+1,". ").concat(f," Balance: ").concat(S,"(").concat(v[b].address,")")),w.push(v[b].address),g.label=7;case 7:return b++,[3,5];case 8:return[4,gt(w)];case 9:return N=g.sent(),A=v[w.indexOf(N)],u=A.address,d=Number(A.decimals),[3,13];case 10:return[4,at("token contract address",vt)];case 11:return u=g.sent(),[4,x(u,t)];case 12:return(T=g.sent()).status?(d=Number(T.output.decimals),f=T.output.name,[3,13]):(console.log(M.red(T.output)),[2]);case 13:return[4,at("Receipt",vt)];case 14:return C=g.sent(),[4,O(r,u,t)];case 15:return(I=g.sent()).status?[4,Z(I.output,f,d)]:(console.log(M.red(I.output)),[2]);case 16:return L=g.sent(),B=l(new o(u),new o(r),!0),[4,P(B.toString(),t)];case 17:return(j=g.sent()).status?j.output&&j.output.owner.toString()!==o.default?(R=l(new o(u),new o(C),!1),[4,P(R.toString(),t)]):(console.log(M.red("From token account not found")),[2]):(console.log(M.red(j.output)),[2]);case 18:return(z=g.sent()).status?(J=new c,U=new c,z.output&&z.output.owner.toString()!==o.default||(J.add(h(new o(r),new o(R),new o(C),new o(u))),U.add(h(new o(r),new o(R),new o(C),new o(u)))),J.add(p(B,R,new o(r),Number(L))),J.add(i.setComputeUnitLimit({units:2e5})),J.add(i.setComputeUnitPrice({microLamports:1e3})),J.feePayer=new o(r),[4,a.account.simulateTransaction(r,t,J)]):(console.log(M.red(z.output)),[2]);case 19:return(q=g.sent()).status?q.output&&q.output.value&&0!==q.output.value.unitsConsumed&&!q.output.value.err?(E=new m(q.output.value.unitsConsumed.toString()),E=new m(Math.ceil(1.2*Number(E))),[4,F(t)]):(console.log(M.red("Simulate error")),console.log("==================reason====================="),console.log(JSON.stringify(q.output,null,4)),console.log("=============================================="),[2]):(console.log(M.red(q.output)),[2]);case 20:return(D=g.sent()).status?(G=new m(D.output.toString()),U.add(p(B,R,new o(r),Number(L))),U.add(i.setComputeUnitLimit({units:Number(E)})),U.add(i.setComputeUnitPrice({microLamports:Number(G)})),J.feePayer=new o(r),[4,a.account.signTransaction(r,U,t)]):(console.log(M.red(D.output)),[2]);case 21:return(K=g.sent()).status?[4,a.account.sendSignedTransaction(r,K.output,t)]:(console.log(M.red(K.output)),[2]);case 22:return(W=g.sent()).status?(_(n,[r,C],["0",u]),console.log(M.green("Transaction hash: ".concat(W.output))),[2]):(console.log(M.red(W.output)),[2])}})})},Z=function(e,t,n){return v(void 0,void 0,void 0,function(){var r,a,s,o,c,i;return g(this,function(u){switch(u.label){case 0:return r=new m(e).dividedBy(Math.pow(10,n)).toFixed(4,m.ROUND_FLOOR),a=["> Input amount","> Total Balance (".concat(r," ").concat(t,")")],[4,gt(a)];case 1:return s=u.sent(),o=a.indexOf(s),c="0",0!==o?[3,3]:[4,at("amount",lt)];case 2:return i=u.sent(),c=new m(i).multipliedBy(Math.pow(10,n)).toFixed(0,m.ROUND_FLOOR),[3,4];case 3:1===o&&(c=e),u.label=4;case 4:return new m(c).isLessThanOrEqualTo(new m(e))?[2,c]:(console.log(M.red("Not enough balance")),[2,Z(e,t,n)])}})})},V=function(e,t,n,a){return v(void 0,void 0,void 0,function(){var s,o,c,i,u,l,d,p,h;return g(this,function(f){switch(f.label){case 0:return s=De(e,t,n),o=ze(e,s),c=Rt(n),o!==c&&("evm"===c&&(s="Ethereum Mainnet"),"solana"===c&&(s="Solana Mainnet"),o=ze(e,s)),"evm"!==o?[3,3]:[4,It("Network (".concat(s,"), want a change?"),!1)];case 1:return f.sent()?(i=Ge(e),[4,gt(i,"Select a network")]):[3,3];case 2:u=f.sent(),s=u,f.label=3;case 3:return[4,Me(n,e,s)];case 4:return(l=f.sent()).status?(d=Je(e,s),console.log(M.green(" ".concat(d.nativeCurrency.symbol," Balance: ").concat(l.output))),p=["> Send Raw Tx","> Send Token",new r.Separator("----------------------------------"),"> Back"],[4,gt(p)]):(console.log(M.red(l.output)),[2]);case 5:switch(h=f.sent(),h){case"> Send Raw Tx":return[3,6];case"> Send Token":return[3,11];case"> Back":return[3,16]}return[3,17];case 6:return"evm"!==c?[3,8]:[4,G(d.chainId.toString(),d.rpcUrl,d.nativeCurrency.symbol,n,a)];case 7:f.sent(),f.label=8;case 8:return"solana"!==c?[3,10]:[4,K(d.chainId.toString(),d.rpcUrl,d.nativeCurrency.symbol,n,a)];case 9:f.sent(),f.label=10;case 10:return[3,17];case 11:return"evm"!==c?[3,13]:[4,$(e,d.rpcUrl,d.chainId.toString(),n,a)];case 12:f.sent(),f.label=13;case 13:return"solana"!==c?[3,15]:[4,H(e,d.rpcUrl,d.chainId.toString(),n,a)];case 14:f.sent(),f.label=15;case 15:return[3,17];case 16:case 17:return[2]}})})},X=function(e,t,n,a){return v(void 0,void 0,void 0,function(){var s,o,c,i;return g(this,function(u){switch(u.label){case 0:return s=["> SendTx","> SignMessage",new r.Separator("----------------------------------"),"> Back"],[4,gt(s)];case 1:switch(o=u.sent(),o){case"> SendTx":return[3,2];case"> SignMessage":return[3,4];case"> Back":return[3,6]}return[3,7];case 2:return[4,V(e,t,n,a)];case 3:return u.sent(),[3,7];case 4:return[4,Lt("Input the message to sign")];case 5:return c=u.sent(),(i=a.account.signMessage(n,c)).status?(console.log(M.green("Signature: "+i.output)),[3,7]):(console.log(M.red(i.output)),[3,7]);case 6:return[2];case 7:return[4,X(e,t,n,a)];case 8:return u.sent(),[2]}})})},Q=function(e,t){return v(void 0,void 0,void 0,function(){var n,a,s,o,c,i,u;return g(this,function(l){switch(l.label){case 0:return n=["> Send Tx","> Search Accounts",new r.Separator("----------------------------------"),"> Back"],[4,gt(n)];case 1:return"> Back"===(a=l.sent())?[2]:"> Send Tx"!==a?[3,3]:[4,at("Input address to send tx",vt)];case 2:s=l.sent(),l.label=3;case 3:return"> Search Accounts"!==a?[3,5]:[4,at("Input part address to send tx",ut)];case 4:s=l.sent(),l.label=5;case 5:return null!==(o=t.account.getAccountLabel(s))?[3,7]:(console.log(M.red("Account not found")),[4,Q(e,t)]);case 6:return l.sent(),[2];case 7:return c=o.account_label,i=Nt(e,c),s=o.account_address,null!==c?[3,9]:(console.log(M.red("Account not found")),[4,Q(e,t)]);case 8:return l.sent(),[2];case 9:return[4,ot(e,c,s)];case 10:return null!==(u=l.sent())?[3,12]:(console.log(M.red("Account not found")),[4,Q(e,t)]);case 11:return l.sent(),[2];case 12:return console.log(M.green("Address found!\n address: ".concat(s,"\n account name: [").concat(i,"]\n account index: #").concat(u))),[4,de(e,c,t)];case 13:return l.sent().isLoginIn?[3,15]:[4,Q(e,t)];case 14:return l.sent(),[2];case 15:return[4,X(e,c,s,t)];case 16:return l.sent(),[4,Q(e,t)];case 17:return l.sent(),[2]}})})},Y=require("chalk");require("dotenv").config();var ee=require("cli-progress");require("wative-core").WativeCore;var te={keystore_slug:"",default_account_index:0},ne=function(e){return v(void 0,void 0,void 0,function(){var t,n,r,a,s;return g(this,function(o){switch(o.label){case 0:return t=ie(e),n=[],t.accounts&&(n=t.accounts),[4,Pt("Account Name",n)];case 1:return null===(r=o.sent())?[2,null]:[4,Ct("Please set a password for Account [".concat(r,"]"))];case 2:return a=o.sent(),[4,Re(e)];case 3:return s=o.sent(),[2,{account_name:r,password:a,selected_default_network:s}]}})})},re=function(n,r){return v(void 0,void 0,void 0,function(){var a,s,o,c,i,u,l;return g(this,function(d){switch(d.label){case 0:return[4,ne(n)];case 1:return(a=d.sent())?[4,Tt("Please enter a mnemonic [split by space]",pt)]:[2];case 2:return s=(s=d.sent()).replace(/\s+/g," "),o=Ot(a.account_name),(c=r.account.generatePPAccount(o,s,a.password)).status?(i=t.join(n,"accounts/".concat(o,".json")),c.output.default_network=a.selected_default_network,e.writeFileSync(i,JSON.stringify(c.output,null,4)),u=t.resolve(n,"network.json"),(l=JSON.parse(e.readFileSync(u,"utf8"))).accounts.push(a.account_name),e.writeFileSync(u,JSON.stringify(l,null,4)),[2]):(console.log(Y.red(c.output)),[2])}})})},ae=function(n,r){return v(void 0,void 0,void 0,function(){var a,s,o,c,i;return g(this,function(u){switch(u.label){case 0:return[4,ne(n)];case 1:return(a=u.sent())?[4,At("Please enter a private key")]:[2];case 2:return s=u.sent(),o=Ot(a.account_name),[4,oe(n,a.password,o,s,a.selected_default_network,r,!0)];case 3:return u.sent(),c=t.resolve(n,"network.json"),(i=JSON.parse(e.readFileSync(c,"utf8"))).accounts.push(a.account_name),e.writeFileSync(c,JSON.stringify(i,null,4)),[2]}})})},se=function(n,r,a,s){return v(void 0,void 0,void 0,function(){var o,c,i;return g(this,function(u){switch(u.label){case 0:return[4,at("Please enter a private key")];case 1:return o=u.sent(),c=t.join(n,"accounts/".concat(a,".json")),i=JSON.parse(e.readFileSync(c,"utf8")),[4,oe(n,r,a,o,i.default_network,s,!1)];case 2:return u.sent(),[2]}})})},oe=function(n,r,a,s,o,c,i){return v(void 0,void 0,void 0,function(){var u,l,d,p,h;return g(this,function(f){switch(f.label){case 0:return[4,Je(n,o)];case 1:return u=f.sent(),"evm"!==B(u.chainId.toString())||s.startsWith("0x")||(s="0x"+s),[4,c.account.generatePKAccount(a,s,r,u.chainId.toString(),i)];case 2:if(!(l=f.sent()).status)return console.log(Y.red(l.output)),[2];if(d=t.join(n,"accounts/".concat(a,".json")),e.existsSync(d))if("data"in(h=JSON.parse(e.readFileSync(d,"utf8")))){if(h.data.map(function(e){return e.ciphertexts.address}).includes(l.output.ciphertexts.address))return console.log(Y.red("The account has already been imported")),[2];h.data.push({ciphertexts:l.output.ciphertexts}),p=h}else h.data=[{ciphertexts:h.ciphertexts}],delete h.ciphertexts,h.data.push({ciphertexts:l.output.ciphertexts}),p=h;else l.output.data=[{ciphertexts:l.output.ciphertexts}],delete l.output.ciphertexts,l.output.default_network=o,p=l.output;return e.writeFileSync(d,JSON.stringify(p,null,4)),c.account.reloadAccount(),[2]}})})},ce=function(e,t){return v(void 0,void 0,void 0,function(){var n,a;return g(this,function(s){switch(s.label){case 0:return n=["> Import Passphrase","> Import Private Key",new r.Separator("----------------------------------"),"> Back"],[4,gt(n)];case 1:switch(a=s.sent(),a){case"> Import Passphrase":return[3,2];case"> Import Private Key":return[3,4];case"> Back":return[3,6]}return[3,7];case 2:return[4,re(e,t)];case 3:case 5:return s.sent(),[3,7];case 4:return[4,ae(e,t)];case 6:return[2];case 7:return t.account.reloadAccount(),[2]}})})},ie=function(n){var r=t.resolve(n,"network.json");return JSON.parse(e.readFileSync(r,"utf8"))},ue=function(n,r){var a=t.join(n,"accounts/".concat(r,".json"));return JSON.parse(e.readFileSync(a,"utf8"))},le=function(n,r,a){var s=t.join(n,"accounts/".concat(r,".json"));e.writeFileSync(s,JSON.stringify(a,null,4))},de=function(e,t,n){return v(void 0,void 0,void 0,function(){var r,a,s,o,c,i;return g(this,function(u){switch(u.label){case 0:if(n.account.isLogin(t))return[2,{isLoginIn:!0}];r=0,u.label=1;case 1:return r<3?(a=Nt(e,t),s="WATIVE_PASSWD_"+t,o=void 0,process.env[s]&&""!==process.env[s]?(o=process.env[s],[3,5]):[3,2]):[3,9];case 2:return process.env.WativePassword&&""!==process.env.WativePassword?(o=process.env.WativePassword,[3,5]):[3,3];case 3:return[4,_t("Please input the password for Account [".concat(a,"]"))];case 4:o=u.sent(),u.label=5;case 5:return o?[4,n.account.login(t,o)]:(console.log(Y.red("Password can't be empty")),[2,{isLoginIn:!1}]);case 6:return(c=u.sent()).status?[2,{isLoginIn:!0,password:o}]:[4,gt(["> Try Again","> Back"],c.output)];case 7:if("> Back"===(i=u.sent()))return[2,{isLoginIn:!1}];if("> Try Again"===i)return[3,8];u.label=8;case 8:return r++,[3,1];case 9:return[2,{isLoginIn:!1}]}})})},pe=function(e,t){return v(void 0,void 0,void 0,function(){var n,a,s,o,c,i,u,l,d,p,h,f;return g(this,function(m){switch(m.label){case 0:if(n=ie(e),a=n.accounts,s=["> Back",new r.Separator("----------------------------------")],0===(o=a.length))return console.log(Y.red("No address here yet")),[2];for(c=0;c<o;c++)i=a[c],u=Ot(i),"data"in(l=ue(e,u))?s.push("".concat(c+1,") ").concat(i," [").concat(l.account_type,":").concat(l.data.length,"]")):s.push("".concat(c+1,") ").concat(i," [").concat(l.account_type,":1]"));return[4,gt(s,"Select an account")];case 1:return"> Back"===(d=m.sent())?[2]:(p=a[s.indexOf(d)-2],h=Ot(p),console.log(Y.green("Keystore slug: [".concat(h,"]"))),[4,de(e,h,t)]);case 2:return(f=m.sent()).isLoginIn?[4,fe(e,h,t,f.password)]:[3,4];case 3:m.sent(),m.label=4;case 4:return[4,pe(e,t)];case 5:return m.sent(),[2]}})})},he=function(e,t,n){return v(void 0,void 0,void 0,function(){var n,a,s,o,c,i,u,l,d,p,h,f,m,v,w,b,y,k,S,x;return g(this,function(g){switch(g.label){case 0:return[4,ue(e,t)];case 1:return n=g.sent(),a=["> Disabled Slots","> Add Single","> Add Range",new r.Separator("----------------------------------"),"> Back"],[4,gt(a)];case 2:switch(s=g.sent(),s){case"> Back":return[3,3];case"> Disabled Slots":return[3,4];case"> Add Single":return[3,7];case"> Add Range":return[3,9]}return[3,11];case 3:return[2];case 4:if(!(o=n.disabled_slots)||0===o.length)return console.log(Y.red("No disabled slots here yet")),[3,11];for(c=n.data,i=["> Back",new r.Separator("----------------------------------")],u=n.default_network,l=0;l<o.length;l++){if(d=o[l].from,p=o[l].to,h=u,f=u,"default_network"in c[d]&&(h=c[d].default_network),"default_network"in c[p]&&(f=c[p].default_network),m=ze(e,h),v=ze(e,f),"evm"!==m&&"solana"!==m)throw new Error("Invalid network type: ".concat(m));if("evm"!==v&&"solana"!==v)throw new Error("Invalid network type: ".concat(v));w=void 0,b=void 0,w="evm"===m?c[d].ciphertexts.evm.address:c[p].ciphertexts.solana.address,b="evm"===v?c[p].ciphertexts.evm.address:c[p].ciphertexts.solana.address,d===p?i.push("".concat(l+1,". ").concat(w,"[").concat(d,"]")):i.push("".concat(l+1,". ").concat(w,"[").concat(d,"]-").concat(b,"[").concat(p,"]"))}return[4,gt(i)];case 5:return"> Back"===(y=g.sent())?[3,11]:[4,It("Are you sure to delete the ".concat(y,"?"),!0)];case 6:return g.sent()?(k=i.indexOf(y)-2,n.disabled_slots.splice(k,1),le(e,t,n),[3,11]):[3,11];case 7:return[4,ct(n,"Input address or index")];case 8:return null===(S=g.sent())?(console.log(Y.red("Invalid account index")),[3,11]):(n.disabled_slots?n.disabled_slots.push({from:S,to:S}):n.disabled_slots=[{from:S,to:S}],le(e,t,n),[3,11]);case 9:return[4,st(n)];case 10:return(x=g.sent())?(n.disabled_slots?n.disabled_slots.push(x):n.disabled_slots=[x],le(e,t,n),[3,11]):(console.log(Y.red("Invalid account range")),[3,11]);case 11:return[4,he(e,t)];case 12:return g.sent(),[2]}})})},fe=function(e,t,n,a){return v(void 0,void 0,void 0,function(){var s,o,c,i,u,l,d,p;return g(this,function(h){switch(h.label){case 0:return[4,ue(e,t)];case 1:return s=h.sent(),o="PP"===s.account_type?["> Address List","> Expand Address","> Slice Address","> Disable Address","> Reset Account Password","> Switch Networks [".concat(s.default_network,"]"),"> Remove",new r.Separator("----------------------------------"),"> Back"]:["> Address List","> Import Private Key","> Remove Address","> Reset Account Password","> Switch Networks [".concat(s.default_network,"]"),"> Remove",new r.Separator("----------------------------------"),"> Back"],[4,gt(o)];case 2:switch(c=h.sent(),c){case"> Address List":return[3,3];case"> Expand Address":return[3,5];case"> Import Private Key":return[3,8];case"> Slice Address":return[3,10];case"> Remove Address":return[3,13];case"> Disable Address":return[3,15];case"> Reset Account Password":return[3,17];case"> Switch Networks [".concat(s.default_network,"]"):return[3,21];case"> Remove":return[3,23];case"> Back":return[3,25]}return[3,26];case 3:return[4,me(e,t,n)];case 4:case 7:case 9:case 12:case 14:case 16:case 22:return h.sent(),[3,26];case 5:return[4,at("Expand accounts count",ht)];case 6:return i=h.sent(),Number(i)>2e3?(console.log(Y.red("Too many accounts, please input less than 2000")),[3,26]):[4,ge(e,t,Number(i),n)];case 8:return[4,se(e,a,t,n)];case 10:return[4,at("Please input last account number",ft)];case 11:return u=h.sent(),[4,we(e,t,Number(u),n)];case 13:return[4,be(e,t,n)];case 15:return[4,he(e,t)];case 17:return l=Nt(e,t),[4,Ct("Please input new password for Account [".concat(l,"]"))];case 18:return d=h.sent(),[4,Ct("Please confirm new password for Account [".concat(l,"]"))];case 19:return p=h.sent(),d&&p&&d===p?[4,n.account.resetPassword(t,d)]:(console.log(Y.red("Passwords do not match")),[3,26]);case 20:case 24:case 27:return h.sent(),[2];case 21:return[4,Ee(e,t,!0)];case 23:return[4,ye(e,t)];case 25:return[2];case 26:return[4,fe(e,t,n,a)]}})})},me=function(e,t,n){return v(void 0,void 0,void 0,function(){var a,s,o,c,i,u,l,d,p,h,f,m,v,w,b,y,k,S,x,N;return g(this,function(g){switch(g.label){case 0:return[4,ue(e,t)];case 1:for(a=g.sent(),s=["> Back",new r.Separator("----------------------------------")],o=[null,null],c=a.disabled_slots,i=Ke(e),u=a.default_network,l=Je(e,u),d=B(l.chainId.toString()),p=a.data.length.toString().length+1,h=0;h<a.data.length;h++)f=a.data[h].tag?"(".concat(a.data[h].tag,")"):"",m=n.account.checkIsDisableAddress(c,h),v=void 0,v="PP"===a.account_type?"evm"===d?a.data[h].ciphertexts.evm.address:a.data[h].ciphertexts.solana.address:a.data[h].ciphertexts.address,o.push(v),m?s.push(new r.Separator(Y.yellow("#".concat(h.toString().padEnd(p)," ").concat(Ut(v,i.fullAddr)," ").concat(f)))):s.push("#".concat(h.toString().padEnd(p)," ").concat(Ut(v,i.fullAddr)," ").concat(f));return w=te.keystore_slug===t?s[te.account_index]:s[0],b=te.keystore_slug===t&&te.account_index>0,[4,$e(e,l.chainId.toString())];case 2:return y=g.sent(),b&&te.account_index>15?(S=s.slice(0,te.account_index-15),x=s.slice(te.account_index-15),k=x.concat(S)):k=s.slice(0),[4,Dt(k,"evm"===d,e,y,l,i.gasToken,i.extendedToken,b,"Select an account",w)];case 3:return"> Back"===(N=g.sent())?[2]:(te.keystore_slug=t,te.account_index=s.indexOf(N),[4,ve(e,t,s.indexOf(N)-2,n)]);case 4:return g.sent(),[4,me(e,t,n)];case 5:return g.sent(),[2]}})})},ve=function(e,t,n,a){return v(void 0,void 0,void 0,function(){var s,o,c,i,u,l,d,p,h,f,m,v;return g(this,function(g){switch(g.label){case 0:return[4,ue(e,t)];case 1:return s=g.sent(),o=s.default_network,c=Ue(e,t,n),[4,Je(e,o)];case 2:return i=g.sent(),[4,Me(c,e,o)];case 3:return(u=g.sent()).status?console.log(Y.green(" Address No: #".concat(n,"\n Network: ").concat(o,"\n ").concat(i.nativeCurrency.symbol," Balance: ").concat(u.output))):console.log(Y.green(" Address No: #".concat(n,"\n Network: ").concat(o,"\n ").concat(i.nativeCurrency.symbol))),l="> Tag","tag"in s.data[n]&&""!==s.data[n].tag&&(l="> Tag(".concat(s.data[n].tag,")")),d=["> Tools","> Show address","> Assets",l,"> Reload balances","> Dump private key",new r.Separator("----------------------------------"),"> Back"],[4,gt(d)];case 4:switch(p=g.sent(),p){case"> Tools":return[3,5];case"> Show address":return[3,7];case"> Assets":return[3,9];case"> Reload balances":return[3,11];case l:return[3,13];case"> Dump private key":return[3,15];case"> Back":return[3,17]}return[3,18];case 5:return[4,X(e,t,c,a)];case 6:case 8:case 10:case 12:return g.sent(),[3,18];case 7:return[4,qe(e,t,n)];case 9:return[4,Ze(e,o,c)];case 11:return[4,Ve(e,o,c)];case 13:return h="Current tag","tag"in s.data[n]&&""!==s.data[n].tag&&(h="Current tag (".concat(s.data[n].tag,")")),[4,at(h,it)];case 14:return f=g.sent(),s.data[n].tag=f.replace(/\s+/g," ").trim(),le(e,t,s),[3,18];case 15:return m=Ue(e,t,n),[4,a.account.showPrivateKey(m)];case 16:return v=g.sent(),console.log("account: ",m),console.log("private key: ",v),[3,18];case 17:case 18:return[2]}})})},ge=function(e,t,n,r){return v(void 0,void 0,void 0,function(){var a,s,o,c,i;return g(this,function(u){switch(u.label){case 0:return[4,ue(e,t)];case 1:a=u.sent(),s=a.data.length,(o=new ee.SingleBar({},ee.Presets.legacy)).start(n,0),c=s,u.label=2;case 2:return c<s+n?[4,r.account.generateSubAccount(t,c)]:[3,5];case 3:if(!(i=u.sent()).status)return console.log(Y.red(i.output)),[2];a.data.push({ciphertexts:i.output}),o.increment(),u.label=4;case 4:return c++,[3,2];case 5:return o.stop(),le(e,t,a),r.account.reloadAccount(),[2]}})})},we=function(e,t,n,r){return v(void 0,void 0,void 0,function(){var a;return g(this,function(s){switch(s.label){case 0:return[4,ue(e,t)];case 1:return(a=s.sent()).data=a.data.slice(0,n+1),le(e,t,a),r.account.reloadAccount(),[2]}})})},be=function(e,t,n){return v(void 0,void 0,void 0,function(){var r,a;return g(this,function(s){switch(s.label){case 0:return[4,at("Please input the accountIndex to remove this account",lt)];case 1:return"0"===(r=s.sent())?(console.log(Y.red("Can't remove the first account")),[2]):[4,ue(e,t)];case 2:return a=s.sent(),[4,It("Are you sure you want to remove this account(".concat(a.data[r].ciphertexts.address,")"),!0)];case 3:return s.sent()?(a.data.splice(Number(r),1),le(e,t,a),n.account.reloadAccount(),[2]):[2]}})})},ye=function(n,r){return v(void 0,void 0,void 0,function(){var a,s,o,c,i,u;return g(this,function(l){switch(l.label){case 0:return[4,at("Please input the account name to remove this account")];case 1:return a=l.sent(),s=Nt(n,r),a!==s?(console.log(Y.red("Can't remove this account")),[2]):[4,It("Are you sure you want to remove this account(".concat(s,")"),!0)];case 2:return l.sent()?(o=t.join(n,"accounts/".concat(r,".json")),e.rmSync(o),c=t.resolve(n,"network.json"),e.existsSync(c)?(i=JSON.parse(e.readFileSync(c,"utf8")),u=i.accounts.indexOf(s),i.accounts.splice(u,1),e.writeFileSync(c,JSON.stringify(i,null,2)),[2]):[2]):[2]}})})},ke=function(n,a){return v(void 0,void 0,void 0,function(){var s,o,c,i,u;return g(this,function(l){switch(l.label){case 0:return s=t.resolve(n,"accounts"),e.existsSync(s)||e.mkdirSync(s),o=ie(n),c=o.accounts,i=0===c.length?["> Create a new account",new r.Separator("----------------------------------"),"> Back"]:["> Select an account","> Create a new account",new r.Separator("----------------------------------"),"> Back"],[4,gt(i)];case 1:switch(u=l.sent(),u){case"> Select an account":return[3,2];case"> Create a new account":return[3,4];case"> Back":return[3,6]}return[3,7];case 2:return[4,pe(n,a)];case 3:case 5:return l.sent(),[3,7];case 4:return[4,ce(n,a)];case 6:return[2];case 7:return[4,ke(n,a)];case 8:return l.sent(),[2]}})})},Se=require("chalk"),xe=function(n){return v(void 0,void 0,void 0,function(){var r,a;return g(this,function(s){return r=t.resolve(n,"network.json"),e.existsSync(r)||(a={networks:C,currentNetwork:"Ethereum Mainnet",accounts:[]},e.writeFileSync(r,JSON.stringify(a,null,2))),[2]})})},Ne=function(e,t){return v(void 0,void 0,void 0,function(){var n,a;return g(this,function(s){switch(s.label){case 0:return n=["> Edit"],"Ethereum Mainnet"!==t.name&&"Solana Mainnet"!==t.name&&n.push("> Remove"),n.push(new r.Separator("----------------------------------")),n.push("> Back"),[4,gt(n)];case 1:switch(a=s.sent(),a){case"> Edit":return[3,2];case"> Remove":return[3,4];case"> Back":return[3,6]}return[3,7];case 2:return[4,Oe(e,t)];case 3:case 5:return s.sent(),[3,7];case 4:return[4,Fe(e,t)];case 6:return[3,7];case 7:return[2]}})})},Oe=function(n,r){return v(void 0,void 0,void 0,function(){var a,s,o,c,i,u,l,d,p,h,f,m,v;return g(this,function(g){switch(g.label){case 0:for(a=t.resolve(n,"network.json"),s=JSON.parse(e.readFileSync(a,"utf8")),o=[],v=0;v<s.networks.length;v++)c=s.networks[v],o.push(c.name);return i=r.rpcUrl,u=r.chainId.toString(),l=r.nativeCurrency.symbol,d=r.name,p=r.multicallAddress,h=r.color,"Ethereum Mainnet"!==r.name&&"Solana Mainnet"!==r.name?[3,2]:[4,yt(r.chainId.toString(),"Rpc Url (default: ".concat(r.rpcUrl,")"),!0)];case 1:return i=g.sent(),[3,9];case 2:return[4,at("Chain Name (default: ".concat(r.name,")"))];case 3:return(d=g.sent())&&d!==r.name&&o.includes(d)?(console.log(Se.red("Chain Name already exists")),[2]):[4,bt("Chain Id (default: ".concat(r.chainId,")"),!0)];case 4:return u=g.sent(),[4,yt(u||r.chainId,"RPC Url (default: ".concat(r.rpcUrl,")"),!0)];case 5:return i=g.sent(),[4,St("Symbol (default: ".concat(r.nativeCurrency.symbol,")"))];case 6:return l=g.sent(),[4,kt(r.multicallAddress?"Multicall Address (Optional) (default: ".concat(r.multicallAddress,")"):"Multicall Address (Optional)")];case 7:return p=g.sent(),[4,xt(r.color?"Color (Optional): (default: ".concat(r.color,")"):"Color (Optional)")];case 8:h=g.sent(),g.label=9;case 9:for(i=i||r.rpcUrl,u=u||r.chainId.toString(),l=l||r.nativeCurrency.symbol,d=d||r.name,p=p||r.multicallAddress,h=h||r.color,f=L(u.toString()),m={name:d||r.name,chainId:Number(u)||r.chainId,rpcUrl:i||r.rpcUrl,nativeCurrency:{name:l||r.nativeCurrency.symbol,symbol:l||r.nativeCurrency.symbol,decimals:f||r.nativeCurrency.decimals}},(p||r.multicallAddress)&&(m.multicallAddress=p||r.multicallAddress),(h||r.color)&&(m.color=h||r.color),v=0;v<s.networks.length;v++)if(s.networks[v].name===r.name){s.networks[v]=m;break}return e.writeFileSync(a,JSON.stringify(s,null,2)),[2]}})})},Fe=function(n,r){return v(void 0,void 0,void 0,function(){var a,s,o;return g(this,function(c){for(a=t.resolve(n,"network.json"),s=JSON.parse(e.readFileSync(a,"utf8")),o=0;o<s.networks.length;o++)if(s.networks[o].name===r.name){s.networks.splice(o,1);break}return r.name===s.currentNetwork&&(s.currentNetwork="Ethereum Mainnet"),e.writeFileSync(a,JSON.stringify(s,null,2)),[2]})})},Pe=function(n){return v(void 0,void 0,void 0,function(){var r,a,s,o,c,i,u,l,d,p,h,f,m;return g(this,function(v){switch(v.label){case 0:for(r=t.resolve(n,"network.json"),a=JSON.parse(e.readFileSync(r,"utf8")),s=[],o=0;o<a.networks.length;o++)c=a.networks[o],s.push(c.name);return console.log(Se.green("Please input someting about network")),[4,at("Chain Name")];case 1:return i=v.sent(),s.includes(i)?(console.log(Se.red("Chain Name already exists")),[2]):[4,bt("Chain Id")];case 2:return(u=v.sent())?[4,yt(u,"RPC Url")]:[2];case 3:return(l=v.sent())?[4,St("Symbol")]:[2];case 4:return(d=v.sent())?[4,kt("Multicall Address (Optional)")]:[2];case 5:return p=v.sent(),[4,xt("Color (Optional)")];case 6:return h=v.sent(),f=L(u.toString()),m={name:i,chainId:Number(u),rpcUrl:l,nativeCurrency:{name:d,symbol:d,decimals:f}},p&&(m.multicallAddress=p),h&&(m.color=h),a.networks.push(m),e.writeFileSync(r,JSON.stringify(a,null,2)),[2]}})})},Ae=function(n){return v(void 0,void 0,void 0,function(){var a,s,o,c,i,u,l,d,p,h,f,m,v;return g(this,function(g){switch(g.label){case 0:for(a=t.resolve(n,"network.json"),s=JSON.parse(e.readFileSync(a,"utf8")),o=[],c=[],l=0;l<s.networks.length;l++)p=s.networks[l],"solana"===B(p.chainId.toString())?c.push(l):o.push(l);for(i=["> Back","+ Add Network",new r.Separator("----Networks(evm)----")],l=0;l<o.length;l++)u=o[l],p=s.networks[u],h="".concat(l+1,".").concat(p.name),0===l&&(h+=" 🔒"),i.push(h);for(i.push(new r.Separator("----Networks(solana)----")),l=0;l<c.length;l++)d=c[l],p=s.networks[d],h="".concat(l+1,".").concat(p.name),0===l&&(h+=" 🔒"),i.push(h);return[4,gt(i)];case 1:return"> Back"===(f=g.sent())?[2]:"+ Add Network"!==f?[3,3]:[4,Pe(n)];case 2:case 5:return g.sent(),[2];case 3:return m=i.indexOf(f),v=m<o.length+3?s.networks[o[m-3]]:s.networks[c[m-o.length-4]],[4,Ne(n,v)];case 4:return g.sent(),[4,Ae(n)]}})})},_e=function(e){return v(void 0,void 0,void 0,function(){var t,n;return g(this,function(a){switch(a.label){case 0:return t=["> Enhanced Balance Display",new r.Separator("----------------------------------"),"> Back"],[4,gt(t)];case 1:switch(n=a.sent(),n){case"> Enhanced Balance Display":return[3,2];case"> Back":return[3,4]}return[3,5];case 2:return[4,Be(e)];case 3:return a.sent(),[3,5];case 4:return[2];case 5:return[4,_e(e)];case 6:return a.sent(),[2]}})})},Te=function(n){return v(void 0,void 0,void 0,function(){var a,s,o,c,i,u,l;return g(this,function(d){switch(d.label){case 0:return a=t.resolve(n,"network.json"),"status"in(s=JSON.parse(e.readFileSync(a,"utf8")))||(s.status={fullAddr:!1,gasToken:!1,extendedToken:!1}),o=["> Show Full Address [".concat(s.status.fullAddr?"ON":"OFF","]"),"> Show Gas Token [".concat(s.status.gasToken?"ON":"OFF","]"),"> Show Extended Token[".concat(s.status.extendedToken?"ON":"OFF","]"),new r.Separator("----------------------------------"),"> Back"],[4,gt(o)];case 1:return"> Back"===(c=d.sent())?[2]:c.includes("Full Address")?(i=s.status,[4,Ce()]):[3,3];case 2:return i.fullAddr=d.sent(),[3,7];case 3:return c.includes("Gas Token")?(u=s.status,[4,Ce()]):[3,5];case 4:return u.gasToken=d.sent(),[3,7];case 5:return c.includes("Extended Token")?(l=s.status,[4,Ce()]):[3,7];case 6:l.extendedToken=d.sent(),d.label=7;case 7:return e.writeFileSync(a,JSON.stringify(s,null,2)),[2]}})})},Ce=function(){return v(void 0,void 0,void 0,function(){return g(this,function(e){switch(e.label){case 0:return[4,gt(["> On","> Off"])];case 1:switch(e.sent()){case"> On":return[2,!0];case"> Off":return[2,!1]}return[2]}})})},Ie=function(n,r){var a=t.resolve(n,"network.json"),s=JSON.parse(e.readFileSync(a,"utf8")).showTokens;return r in s?s[r]:[]},Le=function(n){return v(void 0,void 0,void 0,function(){var a,s,o,c,i,u,l,d,p,h,f,m,v,w,b,y,k,S,x,N,O;return g(this,function(g){switch(g.label){case 0:for(a=t.resolve(n,"network.json"),s=JSON.parse(e.readFileSync(a,"utf8")),o={},c=0,i=s.networks;c<i.length;c++)u=i[c],o[u.chainId.toString()]=u.name;if(l=t.resolve(n,"assets.json"),!zt(l))return console.log(Se.red("No asset here yet")),[2];for(m in d=JSON.parse(e.readFileSync(l,"utf8")),p=[],h=[],f={},d)for(f[p.length]={name:o[m],address:null},p.push(new r.Separator("----- Networks (".concat(o[m],") -------"))),v=Ie(n,o[m]),w=d[m].length,S=0;S<w;S++)b=d[m][S],v.includes(b.address)&&h.push("".concat(S+1,".").concat(b.symbol.padEnd(6)," CA: ").concat(Se.green("".concat(Ut(b.address).padEnd(45)))," Decimals: ").concat(b.display_decimals?b.display_decimals:"4")),f[p.length]={name:o[m],address:b.address},p.push("".concat(S+1,".").concat(b.symbol.padEnd(6)," CA: ").concat(Se.green("".concat(Ut(b.address).padEnd(45)))," Decimals: ").concat(b.display_decimals?b.display_decimals:"4"));return[4,wt(p,"Choose Tokens",h)];case 1:for(y=g.sent(),k={},S=0;S<y.length;S++)x=y[S],N=p.indexOf(x),(O=f[N]).name in k?k[O.name].push(O.address):k[O.name]=[O.address];return s.showTokens=k,e.writeFileSync(a,JSON.stringify(s,null,2)),[2]}})})},Be=function(e){return v(void 0,void 0,void 0,function(){var t,n;return g(this,function(a){switch(a.label){case 0:return t=["> Status","> Token List","> Add Token",new r.Separator("----------------------------------"),"> Back"],[4,gt(t)];case 1:switch(n=a.sent(),n){case"> Status":return[3,2];case"> Token List":return[3,4];case"> Add Token":return[3,6];case"> Back":return[3,8]}return[3,9];case 2:return[4,Te(e)];case 3:case 5:case 7:return a.sent(),[3,9];case 4:return[4,Le(e)];case 6:return[4,Qe(e)];case 8:return[2];case 9:return[4,Be(e)];case 10:return a.sent(),[2]}})})},je=function(e){return v(void 0,void 0,void 0,function(){var t,n;return g(this,function(a){switch(a.label){case 0:return t=["> Networks","> Dataview",new r.Separator("----------------------------------"),"> Back"],[4,gt(t)];case 1:switch(n=a.sent(),n){case"> Networks":return[3,2];case"> Dataview":return[3,4];case"> Back":return[3,6]}return[3,7];case 2:return[4,Ae(e)];case 3:case 5:return a.sent(),[3,7];case 4:return[4,_e(e)];case 6:return[2];case 7:return[4,je(e)];case 8:return a.sent(),[2]}})})},Re=function(n){return v(void 0,void 0,void 0,function(){var r,a,s;return g(this,function(o){switch(o.label){case 0:return r=t.resolve(n,"network.json"),a=JSON.parse(e.readFileSync(r,"utf8")),s=a.networks.map(function(e){return"> ".concat(e.name)}),[4,gt(s,"Please select a default network")];case 1:return[2,o.sent().slice(2)]}})})},ze=function(n,r){for(var a=t.resolve(n,"network.json"),s=JSON.parse(e.readFileSync(a,"utf8")),o=0;o<s.networks.length;o++){var c=s.networks[o];if(c.name===r)return B(c.chainId.toString())}return"unknown"},Je=function(n,r){for(var a=t.resolve(n,"network.json"),s=JSON.parse(e.readFileSync(a,"utf8")),o=0;o<s.networks.length;o++){var c=s.networks[o];if(c.name===r)return c}return null},Ue=function(e,t,n){var r=ue(e,t);if("PK"===r.account_type)return r.data[n].ciphertexts.address;var a=r.default_network,s=ze(e,a);return"solana"===s?r.data[n].ciphertexts.solana.address:"evm"===s?r.data[n].ciphertexts.evm.address:null},qe=function(n,r,a){return v(void 0,void 0,void 0,function(){var s,o,c,i,u,l,d,p,h,f,m;return g(this,function(v){for(s=t.resolve(n,"network.json"),o=JSON.parse(e.readFileSync(s,"utf8")),c=o.networks,i=c.length,u=ue(n,r),l=u.default_network,d=ze(n,l),p=0;p<i;p++)h=c[p],f=ze(n,h.name),"PK"===u.account_type&&d!==f||(m=void 0,m="PK"===u.account_type?u.data[a].ciphertexts.address:"evm"===f?u.data[a].ciphertexts.evm.address:u.data[a].ciphertexts.solana.address,h.name===l?console.log("● ".concat(m," [").concat(h.name,"]")):console.log("○ ".concat(m," [").concat(h.name,"]")));return[2]})})},Ee=function(n,a,s){return v(void 0,void 0,void 0,function(){var o,c,i,u,l,d,p,h,f,m,v,w,b,y,k,S,x;return g(this,function(g){switch(g.label){case 0:for(o=t.resolve(n,"network.json"),c=JSON.parse(e.readFileSync(o,"utf8")),i=c.networks,u=i.length,l=ue(n,a),d=["> Back",new r.Separator("----------------------------------")],p=l.default_network,h="",s||(h=l.ciphertexts.address),f=[],m=ze(n,p),v=0;v<u;v++)w=i[v],b=ze(n,w.name),"PK"===l.account_type&&m!==b||(w.name===p?s?d.push("● ".concat(w.name)):d.push("● ".concat(h," [").concat(w.name,"]")):s?d.push("○ ".concat(w.name)):d.push("○ ".concat(h," [").concat(w.name,"]")),f.push(w.name));return[4,gt(d)];case 1:return"> Back"===(y=g.sent())||(k=d.indexOf(y),l.default_network=f[k-2],le(n,a,l),s||(S=l.default_network,x=Je(n,S),console.log(Se.green(" Address No: #0\n Network: ".concat(S,"\n ").concat(x.nativeCurrency.symbol," Balance: 0"))))),[2]}})})},Me=function(e,t,n){return v(void 0,void 0,void 0,function(){var r,a,s,o,c;return g(this,function(i){switch(i.label){case 0:return r=Je(t,n),a=r.rpcUrl,s=r.nativeCurrency.decimals,"solana"!==B(r.chainId.toString())?[3,2]:[4,k(e,a)];case 1:return o=i.sent(),[3,4];case 2:return[4,y(e,a)];case 3:o=i.sent(),i.label=4;case 4:return o.status&&(c=new m(o.output.toString()),o.output=c.dividedBy(Math.pow(10,s)).toFixed(4,m.ROUND_FLOOR)),_(r.chainId.toString(),[e],["0"]),[2,o]}})})},De=function(e,t,n){var r=ue(e,t);if("PK"===r.account_type)return r.default_network;for(var a=0;a<r.data.length;a++)if(r.data[a].ciphertexts.solana.address===n||r.data[a].ciphertexts.evm.address===n)return"default_network"in r.data[a]?r.data[a].default_network:r.default_network;return null},Ge=function(n){for(var r=t.resolve(n,"network.json"),a=JSON.parse(e.readFileSync(r,"utf8")).networks,s=a.length,o=[],c=0;c<s;c++)"evm"===B(a[c].chainId.toString())&&o.push(a[c].name);return o},Ke=function(n){var r=t.resolve(n,"network.json");return JSON.parse(e.readFileSync(r,"utf8")).status},We=require("chalk"),$e=function(n,r){return v(void 0,void 0,void 0,function(){var a,s,o;return g(this,function(c){return a=t.join(n,"assets.json"),zt(a)?(s=e.readFileSync(a).toString(),o=JSON.parse(s),r in o?[2,o[r]]:[2,[]]):[2,[]]})})},He=function(e,t,n){return v(void 0,void 0,void 0,function(){var r,a,s;return g(this,function(o){switch(o.label){case 0:return[4,$e(e,t)];case 1:for(r=o.sent(),a=[],s=0;s<r.length;s++)r[s].symbol.toLocaleLowerCase()===n.toLocaleLowerCase()&&a.push(r[s]);return[2,a]}})})},Ze=function(e,t,n){return v(void 0,void 0,void 0,function(){var r,a,s,o,c,i;return g(this,function(u){switch(u.label){case 0:return r=Je(e,t),a=B(r.chainId.toString()),[4,$e(e,r.chainId.toString())];case 1:return(s=u.sent())?[4,Ye(n,s,r.rpcUrl,a,r.chainId.toString())]:(console.log(We.red("No asset found")),[2]);case 2:for(o=u.sent(),c=1,i=0;i<o.length;i++)"0"!==o[i].balance&&"0.0000"!==o[i].balance&&(console.log(We.green("".concat(c,". ").concat(o[i].symbol," Balance: ").concat(o[i].balance))),c+=1);return 1===c&&console.log(We.red("No asset found")),[2]}})})},Ve=function(e,t,n){return v(void 0,void 0,void 0,function(){var r,a,s;return g(this,function(o){switch(o.label){case 0:return r=Je(e,t),[4,$e(e,r.chainId.toString())];case 1:return a=o.sent(),(s=a.map(function(e){return e.address})).push("0"),_(r.chainId.toString(),[n],s),[2]}})})},Xe=function(n,r,a,s,o,c,i){return v(void 0,void 0,void 0,function(){var u,l,d,p;return g(this,function(h){for(u=t.join(n,"assets.json"),l={},zt(u)&&(d=e.readFileSync(u).toString(),l=JSON.parse(d)),void 0===l[r]&&(l[r]=[]),p=0;p<l[r].length;p++)if(l[r][p].address.toLocaleLowerCase()===a.toLocaleLowerCase()||l[r][p].symbol.toLocaleLowerCase()===s.toLocaleLowerCase())return l[r][p]={address:a,symbol:s,name:o,decimals:c,display_decimals:i},e.writeFileSync(u,JSON.stringify(l,null,4)),[2];return l[r].push({address:a,symbol:s,name:o,decimals:c,display_decimals:i}),e.writeFileSync(u,JSON.stringify(l,null,4)),[2]})})},Qe=function(n){return v(void 0,void 0,void 0,function(){var r,a,s,o,c,i,u,l,d,p,h,f,m,v;return g(this,function(g){switch(g.label){case 0:for(r=t.resolve(n,"network.json"),a=JSON.parse(e.readFileSync(r,"utf8")),s=[],o=a.networks,c=0;c<o.length;c++)s.push("".concat(c+1,". ").concat(o[c].name));return[4,gt(s)];case 1:return i=g.sent(),u=i.split(".")[1].trim(),l=ze(n,u),d=Je(n,u),[4,at("Enter contract address",vt)];case 2:return p=g.sent(),"evm"!==l?[3,4]:(w=p).startsWith("0x")&&42===w.length?[4,S(p,d.rpcUrl)]:(console.log(We.red("evm address format error")),[2]);case 3:return h=g.sent(),[3,6];case 4:return function(e){return/^[A-HJ-NP-Za-km-z1-9]*$/.test(e)}(p)?[4,x(p,d.rpcUrl)]:(console.log(We.red("solana address format error")),[2]);case 5:h=g.sent(),g.label=6;case 6:return h.status?h.output.name?[3,8]:(f=h.output,[4,at("Please input token name")]):(console.log(We.red(h.output)),[2]);case 7:f.name=g.sent(),g.label=8;case 8:return h.output.symbol?[3,10]:(m=h.output,[4,at("Please input token symbol")]);case 9:m.symbol=g.sent(),g.label=10;case 10:return console.log(We.green("Token ".concat(h.output.symbol,"(").concat(h.output.name,") loaded successfully."))),[4,at("Enter decimals for display",lt)];case 11:return v=g.sent(),v=parseInt(v),[4,Xe(n,d.chainId.toString(),p,h.output.symbol,h.output.name,h.output.decimals,v)];case 12:return g.sent(),[2]}var w})})},Ye=function(e,t,n,r,a){return v(void 0,void 0,void 0,function(){var s,o,c,i,u,l,d,p,h;return g(this,function(f){switch(f.label){case 0:for(s=t.length,o=[],u=0;u<s;u++)l=t[u],"evm"===r?o.push(N(e,l.address,n)):"solana"===r&&o.push(O(e,l.address,n));return[4,Promise.all(o)];case 1:for(c=f.sent(),i=[],u=0;u<s;u++){if(l=t[u],d=l.decimals,!c[u].status)return console.log(We.red(c[u].output)),[2,null];p=new m(c[u].output),h=p.dividedBy(Math.pow(10,d)).toFixed(4,m.ROUND_FLOOR),i.push({address:l.address,symbol:l.symbol,balance:h}),_(a,[e],[l.address])}return _(a,[e],["0"]),[2,i]}})})},et=function(e,t,n,r,a,s,o){return v(void 0,void 0,void 0,function(){var c,i,u,l,d,p,h,f,v;return g(this,function(g){switch(g.label){case 0:return c=n.length,i=Je(e,a),u=B(i.chainId.toString()),l="evm"===u,s?[4,A(t,"0",i.chainId.toString(),r,l)]:[3,2];case 1:g.sent(),g.label=2;case 2:if(!o)return[3,6];d=Ie(e,a),p=0,g.label=3;case 3:return p<c?(h=n[p],f=h.address,d.includes(f)?[4,A(t,f,i.chainId.toString(),r,l)]:[3,5]):[3,6];case 4:g.sent(),g.label=5;case 5:return p++,[3,3];case 6:return v=function(e,t,n,r){var a={};if(!(e in w))return a;n.unshift({address:"0",name:r.nativeCurrency.name,symbol:r.nativeCurrency.symbol,decimals:r.nativeCurrency.decimals,display_decimals:4});for(var s=t.length,o=0;o<s;o++){var c=t[o];if(c)for(var i=0;i<n.length;i++){var u=n[i],l="0";w[e][u.address]&&(c in w[e][u.address]&&(l=new m(w[e][u.address][c]).dividedBy(Math.pow(10,u.decimals)).toFixed(u.display_decimals||4,m.ROUND_FLOOR)),a[c]||(a[c]={}),a[c][u.symbol]=l)}}return a}(i.chainId.toString(),t,n,i),[2,v]}})})},tt=require("chalk"),nt=process.env.HOME||process.env.USERPROFILE,rt="".concat(nt,"/.wative"),at=function(e,t){return v(void 0,void 0,void 0,function(){var n;return g(this,function(a){switch(a.label){case 0:return n=[{name:"inputText",type:"input",message:"".concat(e,":"),validate:t}],[4,r.prompt(n)];case 1:return[2,a.sent().inputText.trim().toString()]}})})},st=function(e){return v(void 0,void 0,void 0,function(){var t,n,r;return g(this,function(a){switch(a.label){case 0:t=0,a.label=1;case 1:return t<5?[4,ct(e,"Input start address or index")]:[3,5];case 2:return(n=a.sent())?[4,ct(e,"Input end address or index")]:(console.log(tt.red("Invalid start account index")),[2,null]);case 3:return(r=a.sent())?n>r?(console.log(tt.red("Invalid address range")),[3,4]):[2,{from:n,to:r}]:(console.log(tt.red("Invalid end account index")),[2,null]);case 4:return t++,[3,1];case 5:return[2,null]}})})},ot=function(n,r,a){return v(void 0,void 0,void 0,function(){var s,o,c,i,u,l;return g(this,function(d){if(s=t.join(n,"accounts/".concat(r,".json")),!e.existsSync(s))return[2,null];if(o=JSON.parse(e.readFileSync(s,"utf8")),c=o.data,i=o.account_type,0===(u=c.length))return[2,null];for(l=0;l<u;l++){if("PK"===i&&c[l].ciphertexts.address.toLocaleLowerCase()===a.toLocaleLowerCase())return[2,l.toString()];if("PP"===i&&(c[l].ciphertexts.evm.address.toLocaleLowerCase()===a.toLocaleLowerCase()||c[l].ciphertexts.solana.address.toLocaleLowerCase()===a.toLocaleLowerCase()))return[2,l.toString()]}return[2,null]})})},ct=function(e,t){return v(void 0,void 0,void 0,function(){var n,r,a,s,o,c,i,u;return g(this,function(l){switch(l.label){case 0:if(n=e.data,0===(r=n.length))return[2,null];for(a=[],s=[],c=0;c<r;c++)a.push(n[c].ciphertexts.evm.address.toLocaleLowerCase()),s.push(n[c].ciphertexts.solana.address.toLocaleLowerCase());o=r-1,c=0,l.label=1;case 1:return c<5?[4,at(t,mt)]:[3,4];case 2:if(i=l.sent(),"unknown"===(u=Rt(i)))return Number(i)>o?(console.log(tt.red("Invalid account index")),[3,3]):[2,Number(i)];if("evm"===u&&-1!==a.indexOf(i.toLocaleLowerCase()))return[2,a.indexOf(i.toLocaleLowerCase())];if("solana"===u&&-1!==s.indexOf(i.toLocaleLowerCase()))return[2,s.indexOf(i.toLocaleLowerCase())];l.label=3;case 3:return c++,[3,1];case 4:return[2,null]}})})},it=function(e){return""===e||((e=e.replace(/\s+/g," ").trim()).length>40?"Tag length should be less than 10":!1!==/^[0-9a-zA-Z\s]*$/g.test(e)||"Tag should be alphanumeric")},ut=function(e){return!(e.length<6)||"Address length should be greater than 6"},lt=function(e){return!isNaN(Number(e))||"Value should be a number"},dt=function(e){return!(isNaN(Number(e))||Number(e)>1e3)||"Value should be a number"},pt=function(e){var t=(e=e.replace(/\s+/g," ")).split(/\s+/g);if(12!==t.length&&24!==t.length)return"Passphrase should be equal to 12 or 24 words";for(var n=0;n<t.length;n++)if(!1===T.includes(t[n]))return"Passphrase word should be valid";return!0},ht=function(e){var t=Number(e);return isNaN(t)?"Amount should be a number":!(t>2e3)||"Amount should be less than 2000"},ft=function(e){var t=Number(e);return!isNaN(t)||"Last account no should be a number"},mt=function(e){return!1===isNaN(Number(e))||vt(e)},vt=function(e){return"unknown"!=Rt(e)||"Address should be valid"},gt=function(e,t,n){return v(void 0,void 0,void 0,function(){var a;return g(this,function(s){switch(s.label){case 0:return a=[{type:"list",name:"inputText",message:t||"Choose an option",default:n,choices:e,pageSize:30,filter:function(e){return e}}],[4,r.prompt(a)];case 1:return[2,s.sent().inputText.toString()]}})})},wt=function(e,t,n){return v(void 0,void 0,void 0,function(){var a;return g(this,function(s){switch(s.label){case 0:return a=[{type:"checkbox",name:"inputText",message:t||"Choose an option",default:n,choices:e,pageSize:30,filter:function(e){return e}}],[4,r.prompt(a)];case 1:return[2,s.sent().inputText]}})})},bt=function(e,t){return void 0===t&&(t=!1),v(void 0,void 0,void 0,function(){var n,r;return g(this,function(a){switch(a.label){case 0:n=0,a.label=1;case 1:return n<5?[4,at(e)]:[3,4];case 2:if(""===(r=a.sent())&&t)return[2,null];if(/^[0-9]*$/g.test(r))return[2,r];a.label=3;case 3:return n++,[3,1];case 4:return[2,null]}})})},yt=function(e,t,n){return void 0===n&&(n=!1),v(void 0,void 0,void 0,function(){var r,a,s,o;return g(this,function(c){switch(c.label){case 0:r=0,c.label=1;case 1:return r<5?[4,at(t)]:[3,7];case 2:a=c.sent(),c.label=3;case 3:return c.trys.push([3,5,,6]),""===a&&n?[2,null]:"solana"===B(e.toString())?[2,a]:[4,b(a)];case 4:return(s=c.sent()).status?s.output.toString()===e.toString()?[2,a]:(console.log(tt.red("Rpc url not match chain id")),[3,6]):(console.log(tt.red(s.output)),[3,6]);case 5:return o=c.sent(),console.log(tt.red(o.message)),[3,6];case 6:return r++,[3,1];case 7:return[2,null]}})})},kt=function(e){return v(void 0,void 0,void 0,function(){var t,n;return g(this,function(r){switch(r.label){case 0:t=0,r.label=1;case 1:return t<5?[4,at(e)]:[3,4];case 2:if(""===(n=r.sent()))return[2,null];if(""!==n&&42!==n.length)return console.log(tt.red("Multicall address length must be 42")),[3,3];r.label=3;case 3:return t++,[3,1];case 4:return[2,null]}})})},St=function(e){return v(void 0,void 0,void 0,function(){var t,n,r;return g(this,function(a){switch(a.label){case 0:t=/^[A-Za-z][0-9a-zA-Z]*$/g,n=0,a.label=1;case 1:return n<5?[4,at(e)]:[3,4];case 2:if(""===(r=a.sent()))return[2,null];if(t.test(r))return[2,r];a.label=3;case 3:return n++,[3,1];case 4:return[2,null]}})})},xt=function(e){return v(void 0,void 0,void 0,function(){var t,n,r;return g(this,function(a){switch(a.label){case 0:t=/^#[0-9A-Fa-f]{6}$/g,n=0,a.label=1;case 1:return n<5?[4,at(e)]:[3,4];case 2:if(""===(r=a.sent()))return[2,null];if(t.test(r))return[2,r];a.label=3;case 3:return n++,[3,1];case 4:return[2,null]}})})},Nt=function(e,t){var n=ie(e).accounts,r=Ft(n).indexOf(t);return-1!==r?n[r]:t},Ot=function(e){return e=(e=(e=(e=e.trim()).toLocaleLowerCase()).replace(/\s+/g,"-").trim()).replace(/\-+/g,"-").trim()},Ft=function(e){for(var t=[],n=0;n<e.length;n++)t.push(Ot(e[n]));return t},Pt=function(e,t){return v(void 0,void 0,void 0,function(){var n,r,a,s,o;return g(this,function(c){switch(c.label){case 0:n=Ft(t),r=/^(?![-_])[a-zA-Z0-9_-]{4,40}(?<![-_])$/g,a=0,c.label=1;case 1:return a<5?[4,at(e)]:[3,4];case 2:if(s=(s=c.sent()).trim(),o=Ot(s),r.test(o))return n.includes(o)?(console.log(tt.red("Account name already exists")),[3,3]):[2,s];c.label=3;case 3:return a++,[3,1];case 4:return[2,null]}})})},At=function(e,t){return v(void 0,void 0,void 0,function(){var n;return g(this,function(a){switch(a.label){case 0:return n=[{name:"inputText",type:"password",mask:"#",message:"".concat(e,":"),validate:t}],[4,r.prompt(n)];case 1:return[2,a.sent().inputText.trim().toString()]}})})},_t=function(e){return v(void 0,void 0,void 0,function(){var t;return g(this,function(n){switch(n.label){case 0:return t=[{name:"password",type:"password",mask:"#",message:"".concat(e,":")}],[4,r.prompt(t)];case 1:return[2,n.sent().password]}})})},Tt=function(e,t){return v(void 0,void 0,void 0,function(){var n;return g(this,function(a){switch(a.label){case 0:return n=[{name:"inputText",type:"input",message:"".concat(e,":"),validate:t,transformer:function(e){var t=e.split(" ");return t.map(function(e,n){return n<t.length-1?"#".repeat(e.length):e}).join(" ")}}],[4,r.prompt(n)];case 1:return[2,a.sent().inputText.trim().toString()]}})})},Ct=function(e){return v(void 0,void 0,void 0,function(){var t,n,a;return g(this,function(s){switch(s.label){case 0:return t=0,n=[{name:"password",type:"password",mask:"#",message:"".concat(e,":"),validate:function(e){return t>=3||(n=e,r="Password must contain at least: \n",a=!0,s=" ",o=tt.green("✔"),c=tt.red("✖"),n.length>=8?r+=s+o+" 8 characters\n":(r+=s+c+" 8 characters\n",a=!1),/[0-9]/.test(n)?r+=s+o+" One numerical character\n":(r+=s+c+" One numerical character\n",a=!1),/[A-Z]/.test(n)?r+=s+o+" One uppercase letter\n":(r+=s+c+" One uppercase letter\n",a=!1),/[!@#$%]/.test(n)?r+=s+o+" One sepcial character (i.e. !@#$%)\n":(r+=s+c+" One sepcial character (i.e. !@#$%)\n",a=!1),!!a||r);var n,r,a,s,o,c}}],[4,r.prompt(n)];case 1:return a=s.sent().password,t>=3&&(a=null),[2,a]}})})},It=function(e,t){return void 0===t&&(t=!0),v(void 0,void 0,void 0,function(){var n;return g(this,function(a){switch(a.label){case 0:return n=[{name:"confirm",type:"confirm",message:"".concat(e),default:t}],[4,r.prompt(n)];case 1:return[2,a.sent().confirm]}})})},Lt=function(e,t){return v(void 0,void 0,void 0,function(){var n;return g(this,function(a){switch(a.label){case 0:return n=[{name:"editor",type:"editor",message:"".concat(e),validate:t}],[4,r.prompt(n)];case 1:return[2,a.sent().editor.trim().toString()]}})})},Bt=function(e){return!!/^0x[0-9a-fA-F]*$/g.test(e.trim())},jt=function(e,t){return v(void 0,void 0,void 0,function(){var n,r,a;return g(this,function(s){switch(s.label){case 0:return s.trys.push([0,2,,3]),[4,e.apply(void 0,t)];case 1:return r=s.sent(),n={status:!0,output:r},[3,3];case 2:return a=s.sent(),n={status:!1,output:a.toString()},[3,3];case 3:return[2,n]}})})},Rt=function(e){return e.startsWith("0x")&&42===e.length?"evm":/^[A-HJ-NP-Za-km-z1-9]*$/.test(e)&&e.length<=44&&e.length>=32?"solana":"unknown"},zt=function(t){return t=t.trim(),e.existsSync(t)},Jt=function(e){return new Promise(function(t){return setTimeout(t,e)})},Ut=function(e,t){return void 0===t&&(t=!0),t?e:e.startsWith("0x")?e.slice(0,8)+"..."+e.slice(-6):e.slice(0,6)+"..."+e.slice(-6)},qt=function(e,t){if(!e.name)return null;var n=null;if(t)n=(n=/0x[0-9a-fA-f]{40}/.exec(e.name))?n[0]:null;else{var r=/\s+([0-9a-zA-Z]*)/.exec(e.name);"Back"===(n=r?r[1]:null)&&(n=null)}return n},Et=function(e,t,n){var r,a;return e<t/2?n/2<=t?(r=0,a=n/2):(r=0,a=t):n/2<=t?(r=0,a=n/2):(r=e-t/2+1,a=e+t/2+1),{fromIndex:r,toIndex:a}},Mt=function(e,t){for(var n=[],r=0;r<e.length;r++){var a=qt(e[r],t);n.push(a)}return n.concat(n)},Dt=function(e,t,n,a,s,o,c,i,u,l){return v(void 0,void 0,void 0,function(){var d,p,h,f,m,v,b,y,k,S,x,N,O,F,P,A,_,T,C,I,L,B,j,R;return g(this,function(g){switch(g.label){case 0:d=[{type:"list",name:"inputText",message:u||"Choose an option",choices:e,pageSize:30,default:l,loop:!0,filter:function(e){return e}}],p=r.prompt(d),h=0,f=0,g.label=1;case 1:return p.ui.activePrompt.answers[p.ui.activePrompt.opt.name]?[3,5]:i?[3,3]:[4,Jt(1e3)];case 2:g.sent(),g.label=3;case 3:return m===p.ui.activePrompt.selected?[3,1]:(h===p.ui.activePrompt.selected?f+=1:(f=0,h=p.ui.activePrompt.selected),!i||(f=6,i=!1,v=p.ui.activePrompt.opt.pageSize,b=Mt(p.ui.activePrompt.opt.choices.choices,t),y=Et(h,v,b.length),k=y.fromIndex,S=y.toIndex,x=b.slice(k,S),function(e,t){var n=0;if(e in w&&"0"in w[e])for(var r=0;r<t.length;r++)t[r]in w[e][0]&&(n+=1);return 0!==n&&n/t.length>.8}(s.chainId.toString(),x))?f<5?[3,1]:(f=0,N=p.ui.activePrompt.opt.pageSize,O=Mt(p.ui.activePrompt.opt.choices.choices,t),F=Et(h,N,O.length),P=F.fromIndex,A=F.toIndex,_=O.slice(P,A),[4,et(n,_,a,s.rpcUrl,s.name,o,c)]):(f=0,[3,1]));case 4:for(I in T=g.sent(),C={},T)for(L in T[I])B=T[I][L],j=B.length+1,C[L]?C[L]<j&&(C[L]=j):C[L]=j;return R=s.nativeCurrency.symbol,function(e,t,n,r,a,s,o,c,i){for(var u=c;u<i;u++){var l=u>=t.length/2?u-t.length/2:u,d=e[l];if(d.name){var p=d.name,h=t[u],f="";if(h){for(var m in n[h])(s||m!==a)&&(o||m===a)&&(p.includes(m)||(f+="".concat(m,":").concat(n[h][m].padEnd(r[m])," ")));var v=p.split("(");if(v.length>1){var g=v[1];e[l].name=v[0]+" ".concat(f)+"(".concat(g)}else e[l].name=v[0]+" ".concat(f)}}}}(p.ui.activePrompt.opt.choices.choices,O,T,C,R,o,c,P,A),p.ui.activePrompt.screen.render(""),p.ui.activePrompt.render(),m=h,[3,1];case 5:return[2,p.ui.activePrompt.answers[p.ui.activePrompt.opt.name]]}})})};require("wative-core").WativeCore;var Gt=function(e,t){return v(void 0,void 0,void 0,function(){var n;return g(this,function(r){switch(r.label){case 0:return[4,gt(["> System & Settings","> Accounts","> Tools","> Exit"])];case 1:switch(n=r.sent(),n){case"> System & Settings":return[3,2];case"> Accounts":return[3,4];case"> Tools":return[3,6];case"> Exit":return[3,8]}return[3,9];case 2:return[4,je(e)];case 3:case 5:case 7:return r.sent(),[3,9];case 4:return[4,ke(e,t)];case 6:return[4,Q(e,t)];case 8:return[2];case 9:return[4,Gt(e,t)];case 10:return r.sent(),[2]}})})},Kt=require("wative-core").WativeCore,Wt=require("../package.json");require("events").EventEmitter.defaultMaxListeners=0;process.on("unhandledRejection",function(e,t){console.log("Unhandled Rejection at:",t,"reason:",e)}),v(void 0,void 0,void 0,function(){var r,a,s,o,c;return g(this,function(i){switch(i.label){case 0:return console.log("version:",Wt.version),console.log(tt.green(n.textSync("Wative",{font:"ANSI Shadow",horizontalLayout:"default",verticalLayout:"default"}))),[4,v(void 0,void 0,void 0,function(){var t;return g(this,function(n){switch(n.label){case 0:return[4,at("Keystore storage located in (default: ".concat(rt,")"))];case 1:return(t=n.sent())||(t=rt),t=(t=t.trim()).replace("~",nt),e.existsSync(t)||e.mkdirSync(t,{recursive:!0}),[2,t]}})})];case 1:return r=i.sent(),[4,xe(r)];case 2:return i.sent(),function(n){var r=t.resolve(n,"network.json"),a=JSON.parse(e.readFileSync(r,"utf8"));a.status||(a.status={fullAddr:!0,gasToken:!1,extendedToken:!1}),a.showTokens||(a.showTokens={});for(var s=a.accounts.length,o=0;o<s;o++){var c=a.accounts[s-1-o],i=Ot(c),u=t.resolve(n,"accounts/".concat(i,".json"));e.existsSync(u)||a.accounts.splice(s-1-o,1)}e.writeFileSync(r,JSON.stringify(a,null,4));var l=a.accounts,d=Ft(l);for(o=0;o<d.length;o++){u=t.resolve(n,"accounts/".concat(d[o],".json"));var p=JSON.parse(e.readFileSync(u,"utf8"));"PP"!==p.account_type&&("data"in p||(p.data=[{ciphertexts:p.ciphertexts}],delete p.ciphertexts,e.writeFileSync(u,JSON.stringify(p,null,4))))}}(r),a=t.resolve(r,"network.json"),s=JSON.parse(e.readFileSync(a,"utf8")),o=Ft(s.accounts),c=new Kt(r,o,null,!0),[4,Gt(r,c)];case 3:return i.sent(),[2]}})}).then(function(){return process.exit(0)}).catch(function(e){console.log(e.message),process.exit(1)});
|
|
1
|
+
import*as e from"fs";import t,{readFileSync as a}from"fs";import*as r from"path";import n from"path";import*as s from"figlet";import o from"inquirer";import i from"web3";import c,{Connection as l,PublicKey as u,Transaction as d,SystemProgram as p,ComputeBudgetProgram as h}from"@solana/web3.js";import{getAssociatedTokenAddressSync as g,getMint as m,createAssociatedTokenAccountInstruction as f,createTransferInstruction as w}from"@solana/spl-token";import{Metaplex as y}from"@metaplex-foundation/js";import{BigNumber as v}from"bignumber.js";import*as b from"ini";import*as k from"crypto";import{timingSafeEqual as S}from"crypto";import{execSync as x,spawn as _}from"child_process";import{utils as $,Server as P,Client as A}from"ssh2";import*as I from"log4js";import{ethers as C}from"ethers";import j from"tweetnacl";import O from"bs58";import N from"bip39";import T from"@coral-xyz/anchor";import E from"crypto-js";import F from"ethereumjs-wallet";import L from"micro-ed25519-hdkey";import*as B from"net";import{Command as R}from"commander";const q={},z=async e=>{let t=new i(e);return await da(t.eth.getChainId,[])},M=async(e,t)=>{const a=new i(t);return await da(a.eth.getBalance,[e])},D=async(e,t)=>{const a=new l(t);return await da(a.getBalance.bind(a),[new u(e)])},K=async(e,t)=>{const a=new(new i(t).eth.Contract)([{constant:!0,inputs:[],name:"symbol",outputs:[{name:"",type:"string"}],payable:!1,stateMutability:"view",type:"function"},{constant:!0,inputs:[],name:"name",outputs:[{name:"",type:"string"}],payable:!1,stateMutability:"view",type:"function"},{constant:!0,inputs:[],name:"decimals",outputs:[{name:"",type:"uint256"}],payable:!1,stateMutability:"view",type:"function"}],e);let r=await da(a.methods.symbol().call.bind(a),[]),n=await da(a.methods.name().call.bind(a),[]),s=await da(a.methods.decimals().call.bind(a),[]);return r.status&&n.status&&s.status?{status:!0,output:{symbol:r.output,name:n.output,decimals:s.output}}:{status:!1,output:"Failed to get token info"}},U=async(e,t)=>{const a=new l(t),r=y.make(a),n=new u(e),s=await da(m,[a,n]);let o={status:!0,output:{symbol:"",name:"",decimals:""}};if(!s.status)return{status:!1,output:"Failed to get token decimals"};o.output.decimals=s.output.decimals;try{const e=r.nfts().pdas().metadata({mint:n});if(await a.getAccountInfo(e)){const e=await r.nfts().findByMint({mintAddress:n});o.output.name=e.name,o.output.symbol=e.symbol}}catch(e){return{status:!1,output:"Failed to get token name"}}return o},H=async(e,t,a)=>{const r=new(new i(a).eth.Contract)([{constant:!0,inputs:[{name:"who",type:"address"}],name:"balanceOf",outputs:[{name:"",type:"uint256"}],payable:!1,stateMutability:"view",type:"function"}],t);let n=await da(r.methods.balanceOf(e).call.bind(r),[]);return n.status?{status:!0,output:n.output}:{status:!1,output:"Failed to get token balance"}},J=async(e,t,a)=>{const r=new l(a),n=g(new u(t),new u(e));let s=await da(r.getTokenAccountBalance.bind(r),[n]);return s.status?{status:!0,output:s.output.value.amount}:s.output.includes("could not find account")?{status:!0,output:"0"}:{status:!1,output:"Failed to get token balance"}},G=async(e,t)=>{const a=new i(t);let r=await da(a.eth.getCode.bind(a),[e]);return r.status?{status:!0,output:r.output}:{status:!1,output:"Failed to get code"}},W=async(e,t,a)=>new i(a).eth.abi.encodeFunctionCall({constant:!1,inputs:[{name:"_to",type:"address"},{name:"_value",type:"uint256"}],name:"transfer",outputs:[],payable:!1,stateMutability:"nonpayable",type:"function"},[e,t]),V=async e=>{const t=new l(e);let a=await da(t.getRecentPrioritizationFees.bind(t),[]);if(!a.status)return{status:!1,output:"Failed to get recent prioritization fees"};const r=a.output.map(e=>e.prioritizationFee).sort();return{status:!0,output:r.length>0?Math.ceil(r.reduce((e,t)=>e+t)/r.length):1e3}},Z=async e=>{const t=new l(e);let a=await da(t.getLatestBlockhash.bind(t),[{commitment:"finalized"}]);return a.status?{status:!0,output:a.output}:{status:!1,output:"Failed to get latest blockhash"}},X=async(e,t)=>{const a=new l(t);let r=await da(a.getAccountInfo.bind(a),[new u(e.toString())]);return r.status?{status:!0,output:r.output}:{status:!1,output:"Failed to get account info"}},Q=async(e,t,a,r,n)=>{let s;a in q?s=q[a][t]||{}:(q[a]={},s={});for(const a of e)if(a&&!(a in s)){let e;e="0"===t?n?await M(a,r):await D(a,r):n?await H(a,t,r):await J(a,t,r),e.status&&(s[a]=e.output),await ma(200)}return q[a][t]=s,q},Y=(e,t,a,r)=>{let n={};if(!(e in q))return n;a.unshift({address:"0",name:r.nativeCurrency.name,symbol:r.nativeCurrency.symbol,decimals:r.nativeCurrency.decimals,display_decimals:4});let s=t.length;for(let r=0;r<s;r++){let s=t[r];if(s)for(let t=0;t<a.length;t++){let r=a[t],o="0";if(q[e][r.address]){if(s in q[e][r.address]){o=new v(q[e][r.address][s]).dividedBy(10**r.decimals).toFixed(r.display_decimals||4,v.ROUND_FLOOR)}n[s]||(n[s]={}),n[s][r.symbol]=o}}}return n},ee=(e,t,a)=>{for(let r=0;r<t.length;r++){let n=t[r];for(let t=0;t<a.length;t++){let r=a[t];try{delete q[e][r][n]}catch(e){}}}},te=async(e,t,a,r,n)=>{for(let s=0;s<a.length;s++){let o=a[s];await Q([t],o,e,r,n)}},ae=(e,t)=>{let a=0;if(e in q&&"0"in q[e])for(let r=0;r<t.length;r++)t[r]in q[e][0]&&(a+=1);return 0!==a&&a/t.length>.8},re=["abandon","ability","able","about","above","absent","absorb","abstract","absurd","abuse","access","accident","account","accuse","achieve","acid","acoustic","acquire","across","act","action","actor","actress","actual","adapt","add","addict","address","adjust","admit","adult","advance","advice","aerobic","affair","afford","afraid","again","age","agent","agree","ahead","aim","air","airport","aisle","alarm","album","alcohol","alert","alien","all","alley","allow","almost","alone","alpha","already","also","alter","always","amateur","amazing","among","amount","amused","analyst","anchor","ancient","anger","angle","angry","animal","ankle","announce","annual","another","answer","antenna","antique","anxiety","any","apart","apology","appear","apple","approve","april","arch","arctic","area","arena","argue","arm","armed","armor","army","around","arrange","arrest","arrive","arrow","art","artefact","artist","artwork","ask","aspect","assault","asset","assist","assume","asthma","athlete","atom","attack","attend","attitude","attract","auction","audit","august","aunt","author","auto","autumn","average","avocado","avoid","awake","aware","away","awesome","awful","awkward","axis","baby","bachelor","bacon","badge","bag","balance","balcony","ball","bamboo","banana","banner","bar","barely","bargain","barrel","base","basic","basket","battle","beach","bean","beauty","because","become","beef","before","begin","behave","behind","believe","below","belt","bench","benefit","best","betray","better","between","beyond","bicycle","bid","bike","bind","biology","bird","birth","bitter","black","blade","blame","blanket","blast","bleak","bless","blind","blood","blossom","blouse","blue","blur","blush","board","boat","body","boil","bomb","bone","bonus","book","boost","border","boring","borrow","boss","bottom","bounce","box","boy","bracket","brain","brand","brass","brave","bread","breeze","brick","bridge","brief","bright","bring","brisk","broccoli","broken","bronze","broom","brother","brown","brush","bubble","buddy","budget","buffalo","build","bulb","bulk","bullet","bundle","bunker","burden","burger","burst","bus","business","busy","butter","buyer","buzz","cabbage","cabin","cable","cactus","cage","cake","call","calm","camera","camp","can","canal","cancel","candy","cannon","canoe","canvas","canyon","capable","capital","captain","car","carbon","card","cargo","carpet","carry","cart","case","cash","casino","castle","casual","cat","catalog","catch","category","cattle","caught","cause","caution","cave","ceiling","celery","cement","census","century","cereal","certain","chair","chalk","champion","change","chaos","chapter","charge","chase","chat","cheap","check","cheese","chef","cherry","chest","chicken","chief","child","chimney","choice","choose","chronic","chuckle","chunk","churn","cigar","cinnamon","circle","citizen","city","civil","claim","clap","clarify","claw","clay","clean","clerk","clever","click","client","cliff","climb","clinic","clip","clock","clog","close","cloth","cloud","clown","club","clump","cluster","clutch","coach","coast","coconut","code","coffee","coil","coin","collect","color","column","combine","come","comfort","comic","common","company","concert","conduct","confirm","congress","connect","consider","control","convince","cook","cool","copper","copy","coral","core","corn","correct","cost","cotton","couch","country","couple","course","cousin","cover","coyote","crack","cradle","craft","cram","crane","crash","crater","crawl","crazy","cream","credit","creek","crew","cricket","crime","crisp","critic","crop","cross","crouch","crowd","crucial","cruel","cruise","crumble","crunch","crush","cry","crystal","cube","culture","cup","cupboard","curious","current","curtain","curve","cushion","custom","cute","cycle","dad","damage","damp","dance","danger","daring","dash","daughter","dawn","day","deal","debate","debris","decade","december","decide","decline","decorate","decrease","deer","defense","define","defy","degree","delay","deliver","demand","demise","denial","dentist","deny","depart","depend","deposit","depth","deputy","derive","describe","desert","design","desk","despair","destroy","detail","detect","develop","device","devote","diagram","dial","diamond","diary","dice","diesel","diet","differ","digital","dignity","dilemma","dinner","dinosaur","direct","dirt","disagree","discover","disease","dish","dismiss","disorder","display","distance","divert","divide","divorce","dizzy","doctor","document","dog","doll","dolphin","domain","donate","donkey","donor","door","dose","double","dove","draft","dragon","drama","drastic","draw","dream","dress","drift","drill","drink","drip","drive","drop","drum","dry","duck","dumb","dune","during","dust","dutch","duty","dwarf","dynamic","eager","eagle","early","earn","earth","easily","east","easy","echo","ecology","economy","edge","edit","educate","effort","egg","eight","either","elbow","elder","electric","elegant","element","elephant","elevator","elite","else","embark","embody","embrace","emerge","emotion","employ","empower","empty","enable","enact","end","endless","endorse","enemy","energy","enforce","engage","engine","enhance","enjoy","enlist","enough","enrich","enroll","ensure","enter","entire","entry","envelope","episode","equal","equip","era","erase","erode","erosion","error","erupt","escape","essay","essence","estate","eternal","ethics","evidence","evil","evoke","evolve","exact","example","excess","exchange","excite","exclude","excuse","execute","exercise","exhaust","exhibit","exile","exist","exit","exotic","expand","expect","expire","explain","expose","express","extend","extra","eye","eyebrow","fabric","face","faculty","fade","faint","faith","fall","false","fame","family","famous","fan","fancy","fantasy","farm","fashion","fat","fatal","father","fatigue","fault","favorite","feature","february","federal","fee","feed","feel","female","fence","festival","fetch","fever","few","fiber","fiction","field","figure","file","film","filter","final","find","fine","finger","finish","fire","firm","first","fiscal","fish","fit","fitness","fix","flag","flame","flash","flat","flavor","flee","flight","flip","float","flock","floor","flower","fluid","flush","fly","foam","focus","fog","foil","fold","follow","food","foot","force","forest","forget","fork","fortune","forum","forward","fossil","foster","found","fox","fragile","frame","frequent","fresh","friend","fringe","frog","front","frost","frown","frozen","fruit","fuel","fun","funny","furnace","fury","future","gadget","gain","galaxy","gallery","game","gap","garage","garbage","garden","garlic","garment","gas","gasp","gate","gather","gauge","gaze","general","genius","genre","gentle","genuine","gesture","ghost","giant","gift","giggle","ginger","giraffe","girl","give","glad","glance","glare","glass","glide","glimpse","globe","gloom","glory","glove","glow","glue","goat","goddess","gold","good","goose","gorilla","gospel","gossip","govern","gown","grab","grace","grain","grant","grape","grass","gravity","great","green","grid","grief","grit","grocery","group","grow","grunt","guard","guess","guide","guilt","guitar","gun","gym","habit","hair","half","hammer","hamster","hand","happy","harbor","hard","harsh","harvest","hat","have","hawk","hazard","head","health","heart","heavy","hedgehog","height","hello","helmet","help","hen","hero","hidden","high","hill","hint","hip","hire","history","hobby","hockey","hold","hole","holiday","hollow","home","honey","hood","hope","horn","horror","horse","hospital","host","hotel","hour","hover","hub","huge","human","humble","humor","hundred","hungry","hunt","hurdle","hurry","hurt","husband","hybrid","ice","icon","idea","identify","idle","ignore","ill","illegal","illness","image","imitate","immense","immune","impact","impose","improve","impulse","inch","include","income","increase","index","indicate","indoor","industry","infant","inflict","inform","inhale","inherit","initial","inject","injury","inmate","inner","innocent","input","inquiry","insane","insect","inside","inspire","install","intact","interest","into","invest","invite","involve","iron","island","isolate","issue","item","ivory","jacket","jaguar","jar","jazz","jealous","jeans","jelly","jewel","job","join","joke","journey","joy","judge","juice","jump","jungle","junior","junk","just","kangaroo","keen","keep","ketchup","key","kick","kid","kidney","kind","kingdom","kiss","kit","kitchen","kite","kitten","kiwi","knee","knife","knock","know","lab","label","labor","ladder","lady","lake","lamp","language","laptop","large","later","latin","laugh","laundry","lava","law","lawn","lawsuit","layer","lazy","leader","leaf","learn","leave","lecture","left","leg","legal","legend","leisure","lemon","lend","length","lens","leopard","lesson","letter","level","liar","liberty","library","license","life","lift","light","like","limb","limit","link","lion","liquid","list","little","live","lizard","load","loan","lobster","local","lock","logic","lonely","long","loop","lottery","loud","lounge","love","loyal","lucky","luggage","lumber","lunar","lunch","luxury","lyrics","machine","mad","magic","magnet","maid","mail","main","major","make","mammal","man","manage","mandate","mango","mansion","manual","maple","marble","march","margin","marine","market","marriage","mask","mass","master","match","material","math","matrix","matter","maximum","maze","meadow","mean","measure","meat","mechanic","medal","media","melody","melt","member","memory","mention","menu","mercy","merge","merit","merry","mesh","message","metal","method","middle","midnight","milk","million","mimic","mind","minimum","minor","minute","miracle","mirror","misery","miss","mistake","mix","mixed","mixture","mobile","model","modify","mom","moment","monitor","monkey","monster","month","moon","moral","more","morning","mosquito","mother","motion","motor","mountain","mouse","move","movie","much","muffin","mule","multiply","muscle","museum","mushroom","music","must","mutual","myself","mystery","myth","naive","name","napkin","narrow","nasty","nation","nature","near","neck","need","negative","neglect","neither","nephew","nerve","nest","net","network","neutral","never","news","next","nice","night","noble","noise","nominee","noodle","normal","north","nose","notable","note","nothing","notice","novel","now","nuclear","number","nurse","nut","oak","obey","object","oblige","obscure","observe","obtain","obvious","occur","ocean","october","odor","off","offer","office","often","oil","okay","old","olive","olympic","omit","once","one","onion","online","only","open","opera","opinion","oppose","option","orange","orbit","orchard","order","ordinary","organ","orient","original","orphan","ostrich","other","outdoor","outer","output","outside","oval","oven","over","own","owner","oxygen","oyster","ozone","pact","paddle","page","pair","palace","palm","panda","panel","panic","panther","paper","parade","parent","park","parrot","party","pass","patch","path","patient","patrol","pattern","pause","pave","payment","peace","peanut","pear","peasant","pelican","pen","penalty","pencil","people","pepper","perfect","permit","person","pet","phone","photo","phrase","physical","piano","picnic","picture","piece","pig","pigeon","pill","pilot","pink","pioneer","pipe","pistol","pitch","pizza","place","planet","plastic","plate","play","please","pledge","pluck","plug","plunge","poem","poet","point","polar","pole","police","pond","pony","pool","popular","portion","position","possible","post","potato","pottery","poverty","powder","power","practice","praise","predict","prefer","prepare","present","pretty","prevent","price","pride","primary","print","priority","prison","private","prize","problem","process","produce","profit","program","project","promote","proof","property","prosper","protect","proud","provide","public","pudding","pull","pulp","pulse","pumpkin","punch","pupil","puppy","purchase","purity","purpose","purse","push","put","puzzle","pyramid","quality","quantum","quarter","question","quick","quit","quiz","quote","rabbit","raccoon","race","rack","radar","radio","rail","rain","raise","rally","ramp","ranch","random","range","rapid","rare","rate","rather","raven","raw","razor","ready","real","reason","rebel","rebuild","recall","receive","recipe","record","recycle","reduce","reflect","reform","refuse","region","regret","regular","reject","relax","release","relief","rely","remain","remember","remind","remove","render","renew","rent","reopen","repair","repeat","replace","report","require","rescue","resemble","resist","resource","response","result","retire","retreat","return","reunion","reveal","review","reward","rhythm","rib","ribbon","rice","rich","ride","ridge","rifle","right","rigid","ring","riot","ripple","risk","ritual","rival","river","road","roast","robot","robust","rocket","romance","roof","rookie","room","rose","rotate","rough","round","route","royal","rubber","rude","rug","rule","run","runway","rural","sad","saddle","sadness","safe","sail","salad","salmon","salon","salt","salute","same","sample","sand","satisfy","satoshi","sauce","sausage","save","say","scale","scan","scare","scatter","scene","scheme","school","science","scissors","scorpion","scout","scrap","screen","script","scrub","sea","search","season","seat","second","secret","section","security","seed","seek","segment","select","sell","seminar","senior","sense","sentence","series","service","session","settle","setup","seven","shadow","shaft","shallow","share","shed","shell","sheriff","shield","shift","shine","ship","shiver","shock","shoe","shoot","shop","short","shoulder","shove","shrimp","shrug","shuffle","shy","sibling","sick","side","siege","sight","sign","silent","silk","silly","silver","similar","simple","since","sing","siren","sister","situate","six","size","skate","sketch","ski","skill","skin","skirt","skull","slab","slam","sleep","slender","slice","slide","slight","slim","slogan","slot","slow","slush","small","smart","smile","smoke","smooth","snack","snake","snap","sniff","snow","soap","soccer","social","sock","soda","soft","solar","soldier","solid","solution","solve","someone","song","soon","sorry","sort","soul","sound","soup","source","south","space","spare","spatial","spawn","speak","special","speed","spell","spend","sphere","spice","spider","spike","spin","spirit","split","spoil","sponsor","spoon","sport","spot","spray","spread","spring","spy","square","squeeze","squirrel","stable","stadium","staff","stage","stairs","stamp","stand","start","state","stay","steak","steel","stem","step","stereo","stick","still","sting","stock","stomach","stone","stool","story","stove","strategy","street","strike","strong","struggle","student","stuff","stumble","style","subject","submit","subway","success","such","sudden","suffer","sugar","suggest","suit","summer","sun","sunny","sunset","super","supply","supreme","sure","surface","surge","surprise","surround","survey","suspect","sustain","swallow","swamp","swap","swarm","swear","sweet","swift","swim","swing","switch","sword","symbol","symptom","syrup","system","table","tackle","tag","tail","talent","talk","tank","tape","target","task","taste","tattoo","taxi","teach","team","tell","ten","tenant","tennis","tent","term","test","text","thank","that","theme","then","theory","there","they","thing","this","thought","three","thrive","throw","thumb","thunder","ticket","tide","tiger","tilt","timber","time","tiny","tip","tired","tissue","title","toast","tobacco","today","toddler","toe","together","toilet","token","tomato","tomorrow","tone","tongue","tonight","tool","tooth","top","topic","topple","torch","tornado","tortoise","toss","total","tourist","toward","tower","town","toy","track","trade","traffic","tragic","train","transfer","trap","trash","travel","tray","treat","tree","trend","trial","tribe","trick","trigger","trim","trip","trophy","trouble","truck","true","truly","trumpet","trust","truth","try","tube","tuition","tumble","tuna","tunnel","turkey","turn","turtle","twelve","twenty","twice","twin","twist","two","type","typical","ugly","umbrella","unable","unaware","uncle","uncover","under","undo","unfair","unfold","unhappy","uniform","unique","unit","universe","unknown","unlock","until","unusual","unveil","update","upgrade","uphold","upon","upper","upset","urban","urge","usage","use","used","useful","useless","usual","utility","vacant","vacuum","vague","valid","valley","valve","van","vanish","vapor","various","vast","vault","vehicle","velvet","vendor","venture","venue","verb","verify","version","very","vessel","veteran","viable","vibrant","vicious","victory","video","view","village","vintage","violin","virtual","virus","visa","visit","visual","vital","vivid","vocal","voice","void","volcano","volume","vote","voyage","wage","wagon","wait","walk","wall","walnut","want","warfare","warm","warrior","wash","wasp","waste","water","wave","way","wealth","weapon","wear","weasel","weather","web","wedding","weekend","weird","welcome","west","wet","whale","what","wheat","wheel","when","where","whip","whisper","wide","width","wife","wild","will","win","window","wine","wing","wink","winner","winter","wire","wisdom","wise","wish","witness","wolf","woman","wonder","wood","wool","word","work","world","worry","worth","wrap","wreck","wrestle","wrist","write","wrong","yard","year","yellow","you","young","youth","zebra","zero","zone","zoo"],ne=[{name:"Ethereum Mainnet",chainId:1,rpcUrl:"https://eth.llamarpc.com",nativeCurrency:{name:"ETH",symbol:"ETH",decimals:18},multicallAddress:"0xeefBa1e63905eF1D7ACbA5a8513c70307C1cE441"},{name:"Solana Mainnet",chainId:901,rpcUrl:"https://api.mainnet-beta.solana.com",nativeCurrency:{name:"SOL",symbol:"SOL",decimals:9}}],se=["901","902","903"],oe=e=>se.includes(e)?9:18,ie=e=>se.includes(e)?"solana":"evm",ce=e=>/^[A-HJ-NP-Za-km-z1-9]*$/.test(e),le=e=>e.startsWith("0x")&&42===e.length,{BN:ue}=require("bn.js"),{stripHexPrefix:de}=require("ethereumjs-util"),{BigNumber:pe}=require("bignumber.js");function he(e){return new ue(de(e.toString("hex")),16)}const ge=e=>e.match(/^-?0x/u)?e:e.match(/^-?0X/u)?e.replace("0X","0x"):e.startsWith("-")?e.replace("-","-0x"):`0x${e}`;function me(e){return ge(e.toString(16))}class fe{constructor(e){this.query=new i(i.givenProvider||e).eth}async analyzeGasUsage(e){const t=await this.query.getBlock("latest",!1);let a,r=me(function(e,t,a){const r=new ue(t),n=new ue(a);return e.mul(r).div(n)}(he(t.gasLimit),19,20));try{r=await this.estimateTxGas(e)}catch(e){a={reason:e.message,errorKey:e.errorKey,debug:{blockNumber:t.number,blockGasLimit:t.gasLimit}}}return{blockGasLimit:t.gasLimit,estimatedGasHex:r,simulationFails:a}}async estimateTxGas(e){let t=await this.query.estimateGas(e);return t=new pe(t.toString()).multipliedBy(1.3).toFixed(0),t}addGasBuffer(e,t,a=1.3){const r=he(e),n=he(t).muln(.9),s=r.muln(a);return r.gt(n)?me(r):s.lt(n)?me(s):me(n)}async getBufferedGasLimit(e,t){const{blockGasLimit:a,estimatedGasHex:r,simulationFails:n}=await this.analyzeGasUsage(e);return{gasLimit:this.addGasBuffer(ge(r),a,t),simulationFails:n}}async getGasPrice(){return await this.query.getGasPrice()}async getTransactionCount(e){return await this.query.getTransactionCount(e)}}const we=require("chalk");require("wative-core");const ye=async e=>{let t=[new o.Separator("————Tx Detail—————-"),`from: ${e.from}`,`to: ${e.to}`,`nonce: ${e.nonce}`,`gasPrice: ${e.gasPrice}`,`data: ${e.data}`,`value: ${e.value}`,`gas: ${e.gas}`,new o.Separator("——————————————-"),"Send it now","Back"],a=await Ht(t),r=t.indexOf(a);return 1===r&&(e.from=await Nt("from",Ut)),2===r&&(e.to=await Nt("to",Ut)),3===r&&(e.nonce=await Nt("nonce")),4===r&&(e.gasPrice=await Nt("gasPrice")),5===r&&(e.data=await la("data")),6===r&&(e.value=await Nt("value")),7===r&&(e.gas=await Nt("gas")),9===r?e:10===r?null:await ye(e)},ve=async(e,t,a,r,n)=>{const s=await Nt("to",Ut);let o=(new d).add(p.transfer({fromPubkey:new u(r),toPubkey:new u(s),lamports:1e6}));o.add(h.setComputeUnitLimit({units:2e5})),o.add(h.setComputeUnitPrice({microLamports:1e3})),o.feePayer=new u(r);let i=await Z(t);if(!i.status)return void console.log(we.red(i.output));o.recentBlockhash=i.output.blockhash;const c=await n.account.simulateTransaction(r,t,o);if(!c.status)return void console.log(we.red(c.output));if(!c.output||!c.output.value||0===c.output.value.unitsConsumed||c.output.value.err)return console.log(we.red("Simulate error")),console.log("==================reason====================="),console.log(JSON.stringify(c.output,null,4)),void console.log("==============================================");let l=new v(c.output.value.unitsConsumed.toString()).multipliedBy(1.2).toFixed(0,v.ROUND_CEIL),g=new v(l);const m=await V(t);if(!m.status)return void console.log(we.red(m.output));const f=new v(m.output.toString()),w=g.multipliedBy(f).dividedBy(1e6).toFixed(0,v.ROUND_CEIL),y=await D(r,t);if(!y.status)return void console.log(we.red(y.output));const b=new v(y.output).minus(5e3).minus(w);let k=new v(b).dividedBy(1e9).toFixed(4,v.ROUND_FLOOR);if(new v(k)<new v(0))return void console.log(we.red("Not enough balance"));let S=await be(k,b.toString(),a,9),x=new d;x.add(h.setComputeUnitLimit({units:Number(g)})),x.add(h.setComputeUnitPrice({microLamports:Number(f)})),x.add(p.transfer({fromPubkey:new u(r),toPubkey:new u(s),lamports:Number(S)})),x.feePayer=new u(r),x.recentBlockhash=i.output.blockhash;const _=await n.account.signTransaction(r,x,t);if(!_.status)return void console.log(we.red(_.output));let $=await n.account.sendSignedTransaction(r,_.output,t);$.status?(ee(e,[r,s],["0"]),console.log(we.green(`Transaction hash: ${$.output}`))):console.log(we.red($.output))},be=async(e,t,a,r)=>{let n=["> Input value",`> Total Balance (${e} ${a})`],s=await Ht(n),o=n.indexOf(s),i="0";if(0===o){let e=await Nt("value",Rt);i=new v(e).multipliedBy(10**r).toFixed(0,v.ROUND_FLOOR)}else 1===o&&(i=t);return new v(i).isLessThanOrEqualTo(new v(t))?i:(console.log(we.red("Not enough balance")),be(e,t,a,r))},ke=async(e,t,a)=>{let r=["> Input amount",`> Total Balance (${new v(e).dividedBy(10**a).toFixed(4,v.ROUND_FLOOR)} ${t})`],n=await Ht(r),s=r.indexOf(n),o="0";if(0===s){let e=await Nt("amount",Rt);o=new v(e).multipliedBy(10**a).toFixed(0,v.ROUND_FLOOR)}else 1===s&&(o=e);return new v(o).isLessThanOrEqualTo(new v(e))?o:(console.log(we.red("Not enough balance")),ke(e,t,a))},Se=async(e,t,a,r)=>{let n=mt(e,t,a),s=ot(e,n),i=pa(a);if(s!==i&&("evm"===i&&(n="Ethereum Mainnet"),"solana"===i&&(n="Solana Mainnet"),s=ot(e,n)),"evm"===s){if(await ca(`Network (${n}), want a change?`,!1)){const t=ft(e);n=await Ht(t,"Select a network")}}let c=await gt(a,e,n);if(!c.status)return void console.log(we.red(c.output));const l=it(e,n);console.log(we.green(` ${l.nativeCurrency.symbol} Balance: ${c.output}`));const p=["> Send Raw Tx","> Send Token",new o.Separator("----------------------------------"),"> Back"];switch(await Ht(p)){case"> Send Raw Tx":"evm"===i&&await(async(e,t,a,r,n)=>{const s=await Nt("to",Ut),o=new fe(t),i=await o.getGasPrice(),c=new v(i.toString()).dividedBy(1e9).toFixed(4,v.ROUND_FLOOR);let l=await Nt(`Gas price (${c}), agree or enter`,qt)||c;l=new v(l).multipliedBy(1e9).toFixed(0);let u,d,p,h=await G(s,t);if(!h.status)return void console.log(we.red(h.output));if(u="42161"===e||"421614"===e?"1700000":"21000","0x"===h.output){d="0x";let e=await M(r,t);if(!e.status)return void console.log(we.red(e.output));let n=new v(e.output),s=new v(l),o=n.minus(s.multipliedBy(Number(u))).toFixed(0,v.ROUND_FLOOR),i=new v(o).dividedBy(1e18).toFixed(4,v.ROUND_FLOOR);if(new v(i)<new v(0))return void console.log(we.red("Not enough balance"));p=await be(i,o,a,18)}else d=await la("data",ua),p=await Nt("value",Rt);const g=await o.getTransactionCount(r),m=await Nt(`Nonce (${g}), agree or enter`);let f={from:r,to:s,nonce:m||g.toString(),gasPrice:l,data:d,value:p};if("0x"===d)f.gas=u;else{let e=f.gasPrice;delete f.gasPrice;try{f.gas=(await o.estimateTxGas(f)).toString()}catch(e){return void console.log(we.red("Error: "+e))}f.gasPrice=e}if(f=await ye(f),!f)return;const w=await n.account.signTransaction(r,f,t);w.status?(console.log(we.green(`Transaction hash: ${w.output.transactionHash}`)),n.account.sendSignedTransaction(r,w.output.rawTransaction,t),ee(e,[r,s],["0"])):console.log(we.red(w.output))})(l.chainId.toString(),l.rpcUrl,l.nativeCurrency.symbol,a,r),"solana"===i&&await ve(l.chainId.toString(),l.rpcUrl,l.nativeCurrency.symbol,a,r);break;case"> Send Token":"evm"===i&&await(async(e,t,a,r,n)=>{let s,o,i;switch(await Ht(["> Input token ticker","> Input token contract address"]),selected_token_address){case"> Input token ticker":i=await Nt("token ticker");let n=await bt(e,a,i);if(0===n.length)return void console.log(we.red("Token not found"));let c=[];for(let e=0;e<n.length;e++){const a=await H(r,n[e].address,t);if(!a.status)return void console.log(we.red(a.output));let s=new v(a.output).dividedBy(10**Number(n[e].decimals)).toFixed(4,v.ROUND_FLOOR);if(1===n.length){c.push(`> 1. ${i} Balance: ${s}`);break}c.push(`> ${e+1}. ${i} Balance: ${s}(${n[e].address})`),c.push(n[e].address)}let l=await Ht(c);const u=n[c.indexOf(l)];s=u.address,o=Number(u.decimals);break;case"> Input token contract address":s=await Nt("token contract address",Ut);let d=await K(s,t);if(!d.status)return void console.log(we.red(d.output));o=Number(d.output.decimals),i=d.output.name}const c=await Nt("Receipt",Ut),l=await H(r,s,t);if(!l.status)return void console.log(we.red(l.output));const u=new fe(t),d=await u.getGasPrice(),p=new v(d.toString()).dividedBy(1e9).toFixed(4,v.ROUND_FLOOR);let h=await Nt(`Gas price (${p}), agree or enter`,qt)||p;h=new v(h).multipliedBy(1e9).toFixed(0);let g=await ke(l.output,i,o);const m=await W(c,g,t),f=await u.getTransactionCount(r),w=await Nt(`Nonce (${f}), agree or enter`);let y={from:r,to:s,nonce:w||f.toString(),gasPrice:h,data:m,value:"0"};if("0x"===m)y.gas="42161"===a||"421614"===a?"1700000":"21000";else{let e=y.gasPrice;delete y.gasPrice;try{y.gas=(await u.estimateTxGas(y)).toString()}catch(e){return void console.log(we.red("Failed to estimate gas, "+e.message))}y.gasPrice=e}if(y=await ye(y),!y)return;const b=await n.account.signTransaction(r,y,t);b.status?(console.log(we.green(`Transaction hash: ${b.output.transactionHash}`)),n.account.sendSignedTransaction(r,b.output.rawTransaction,t),ee(a,[r,c],["0",s])):console.log(we.red(b.output))})(e,l.rpcUrl,l.chainId.toString(),a,r),"solana"===i&&await(async(e,t,a,r,n)=>{let s,o,i;switch(await Ht(["> Input token ticker","> Input token contract address"]),selected_token_address){case"> Input token ticker":i=await Nt("token ticker");let n=await bt(e,a,i);if(0===n.length)return void console.log(we.red("Token not found"));let c=[];for(let e=0;e<n.length;e++){const a=await J(r,n[e].address,t);if(!a.status)return void console.log(we.red(a.output));let s=new v(a.output).dividedBy(10**Number(n[e].decimals)).toFixed(4,v.ROUND_FLOOR);if(1===n.length){c.push(`> 1. ${i} Balance: ${s}`);break}c.push(`> ${e+1}. ${i} Balance: ${s}(${n[e].address})`),c.push(n[e].address)}let l=await Ht(c);const u=n[c.indexOf(l)];s=u.address,o=Number(u.decimals);break;case"> Input token contract address":s=await Nt("token contract address",Ut);let d=await U(s,t);if(!d.status)return void console.log(we.red(d.output));o=Number(d.output.decimals),i=d.output.name}const c=await Nt("Receipt",Ut),l=await J(r,s,t);if(!l.status)return void console.log(we.red(l.output));let p=await ke(l.output,i,o),m=g(new u(s),new u(r),!0);const y=await X(m.toString(),t);if(!y.status)return void console.log(we.red(y.output));if(!y.output||y.output.owner.toString()===u.default)return void console.log(we.red("From token account not found"));let b=g(new u(s),new u(c),!1);const k=await X(b.toString(),t);if(!k.status)return void console.log(we.red(k.output));let S=new d,x=new d;k.output&&k.output.owner.toString()!==u.default||(S.add(f(new u(r),new u(b),new u(c),new u(s))),x.add(f(new u(r),new u(b),new u(c),new u(s)))),S.add(w(m,b,new u(r),Number(p))),S.add(h.setComputeUnitLimit({units:2e5})),S.add(h.setComputeUnitPrice({microLamports:1e3})),S.feePayer=new u(r);const _=await n.account.simulateTransaction(r,t,S);if(!_.status)return void console.log(we.red(_.output));if(!_.output||!_.output.value||0===_.output.value.unitsConsumed||_.output.value.err)return console.log(we.red("Simulate error")),console.log("==================reason====================="),console.log(JSON.stringify(_.output,null,4)),void console.log("==============================================");let $=new v(_.output.value.unitsConsumed.toString());$=new v(Math.ceil(1.2*Number($)));const P=await V(t);if(!P.status)return void console.log(we.red(P.output));const A=new v(P.output.toString());x.add(w(m,b,new u(r),Number(p))),x.add(h.setComputeUnitLimit({units:Number($)})),x.add(h.setComputeUnitPrice({microLamports:Number(A)})),S.feePayer=new u(r);const I=await n.account.signTransaction(r,x,t);if(!I.status)return void console.log(we.red(I.output));let C=await n.account.sendSignedTransaction(r,I.output,t);C.status?(ee(a,[r,c],["0",s]),console.log(we.green(`Transaction hash: ${C.output}`))):console.log(we.red(C.output))})(e,l.rpcUrl,l.chainId.toString(),a,r);break;case"> Back":return}},xe=async(e,t,a,r)=>{const n=["> SendTx","> SignMessage",new o.Separator("----------------------------------"),"> Back"];switch(await Ht(n)){case"> SendTx":await Se(e,t,a,r);break;case"> SignMessage":{const e=await la("Input the message to sign"),t=r.account.signMessage(a,e);if(!t.status){console.log(we.red(t.output));break}console.log(we.green("Signature: "+t.output));break}case"> Back":return}await xe(e,t,a,r)},_e=async(e,t)=>{let a,r=["> Send Tx","> Search Accounts",new o.Separator("----------------------------------"),"> Back"],n=await Ht(r);if("> Back"===n)return;"> Send Tx"===n&&(a=await Nt("Input address to send tx",Ut)),"> Search Accounts"===n&&(a=await Nt("Input part address to send tx",Bt));let s=t.account.getAccountLabel(a);if(null===s)return console.log(we.red("Account not found")),void await _e(e,t);let i=s.account_label,c=ea(e,i);if(a=s.account_address,null===i)return console.log(we.red("Account not found")),void await _e(e,t);const l=await Et(e,i,a);if(null===l)return console.log(we.red("Account not found")),void await _e(e,t);console.log(we.green(`Address found!\n address: ${a}\n account name: [${c}]\n account index: #${l}`)),(await Ee(e,i,t)).isLoginIn?(await xe(e,i,a,t),await _e(e,t)):await _e(e,t)},$e=require("chalk");require("dotenv").config();const Pe=require("cli-progress");require("wative-core");const Ae={keystore_slug:"",default_account_index:0},Ie=async e=>{const t=Oe(e);let a=[];t.accounts&&(a=t.accounts);let r=await ra("Account Name",a);return null===r?null:{account_name:r,password:await ia(`Please set a password for Account [${r}]`),selected_default_network:await st(e)}},Ce=async(t,a,n,s,o,i,c)=>{let l=await it(t,o);"evm"!==ie(l.chainId.toString())||s.startsWith("0x")||(s="0x"+s);let u=await i.account.generatePKAccount(n,s,a,l.chainId.toString(),c);if(!u.status)return void console.log($e.red(u.output));let d,p=r.join(t,`accounts/${n}.json`);if(e.existsSync(p)){let t=JSON.parse(e.readFileSync(p,"utf8"));if("data"in t){if(t.data.map(e=>e.ciphertexts.address).includes(u.output.ciphertexts.address))return void console.log($e.red("The account has already been imported"));t.data.push({ciphertexts:u.output.ciphertexts}),d=t}else t.data=[{ciphertexts:t.ciphertexts}],delete t.ciphertexts,t.data.push({ciphertexts:u.output.ciphertexts}),d=t}else u.output.data=[{ciphertexts:u.output.ciphertexts}],delete u.output.ciphertexts,u.output.default_network=o,d=u.output;e.writeFileSync(p,JSON.stringify(d,null,4)),i.account.reloadAccount()},je=async(t,a)=>{const n=["> Import Passphrase","> Import Private Key",new o.Separator("----------------------------------"),"> Back"];switch(await Ht(n)){case"> Import Passphrase":await(async(t,a)=>{let n=await Ie(t);if(!n)return;let s=await oa("Please enter a mnemonic [split by space]",zt);s=s.replace(/\s+/g," ");let o=ta(n.account_name);const i=a.account.generatePPAccount(o,s,n.password);if(!i.status)return void console.log($e.red(i.output));let c=r.join(t,`accounts/${o}.json`);i.output.default_network=n.selected_default_network,e.writeFileSync(c,JSON.stringify(i.output,null,4));const l=r.resolve(t,"network.json"),u=JSON.parse(e.readFileSync(l,"utf8"));u.accounts.push(n.account_name),e.writeFileSync(l,JSON.stringify(u,null,4))})(t,a);break;case"> Import Private Key":await(async(t,a)=>{let n=await Ie(t);if(!n)return;let s=await na("Please enter a private key"),o=ta(n.account_name);await Ce(t,n.password,o,s,n.selected_default_network,a,!0);const i=r.resolve(t,"network.json"),c=JSON.parse(e.readFileSync(i,"utf8"));c.accounts.push(n.account_name),e.writeFileSync(i,JSON.stringify(c,null,4))})(t,a);break;case"> Back":return}a.account.reloadAccount()},Oe=t=>{const a=r.resolve(t,"network.json");return JSON.parse(e.readFileSync(a,"utf8"))},Ne=(t,a)=>{const n=r.join(t,`accounts/${a}.json`);return JSON.parse(e.readFileSync(n,"utf8"))},Te=(t,a,n)=>{const s=r.join(t,`accounts/${a}.json`);e.writeFileSync(s,JSON.stringify(n,null,4))},Ee=async(e,t,a)=>{if(a.account.isLogin(t))return{isLoginIn:!0};for(let r=0;r<3;r++){let r,n=ea(e,t),s="WATIVE_PASSWD_"+t;if(r=process.env[s]&&""!==process.env[s]?process.env[s]:process.env.WativePassword&&""!==process.env.WativePassword?process.env.WativePassword:await sa(`Please input the password for Account [${n}]`),!r)return console.log($e.red("Password can't be empty")),{isLoginIn:!1};const o=await a.account.login(t,r);if(o.status)return{isLoginIn:!0,password:r};const i=["> Try Again","> Back"],c=await Ht(i,o.output);if("> Back"===c)return{isLoginIn:!1}}return{isLoginIn:!1}},Fe=async(e,t)=>{const a=Oe(e).accounts;let r=["> Back",new o.Separator("----------------------------------")];const n=a.length;if(0===n)return void console.log($e.red("No address here yet"));for(let t=0;t<n;t++){const n=a[t],s=ta(n),o=Ne(e,s);"data"in o?r.push(`${t+1}) ${n} [${o.account_type}:${o.data.length}]`):r.push(`${t+1}) ${n} [${o.account_type}:1]`)}const s=await Ht(r,"Select an account");if("> Back"===s)return;const i=a[r.indexOf(s)-2],c=ta(i);console.log($e.green(`Keystore slug: [${c}]`));let l=await Ee(e,c,t);l.isLoginIn&&await Be(e,c,t,l.password),await Fe(e,t)},Le=async(e,t,a)=>{const r=await Ne(e,t);let n=["> Disabled Slots","> Add Single","> Add Range",new o.Separator("----------------------------------"),"> Back"];switch(await Ht(n)){case"> Back":return;case"> Disabled Slots":{let a=r.disabled_slots;if(!a||0===a.length){console.log($e.red("No disabled slots here yet"));break}let n=r.data,s=["> Back",new o.Separator("----------------------------------")],i=r.default_network;for(let t=0;t<a.length;t++){let r=a[t].from,o=a[t].to,c=i,l=i;"default_network"in n[r]&&(c=n[r].default_network),"default_network"in n[o]&&(l=n[o].default_network);let u,d,p=ot(e,c),h=ot(e,l);if("evm"!==p&&"solana"!==p)throw new Error(`Invalid network type: ${p}`);if("evm"!==h&&"solana"!==h)throw new Error(`Invalid network type: ${h}`);u="evm"===p?n[r].ciphertexts.evm.address:n[o].ciphertexts.solana.address,d="evm"===h?n[o].ciphertexts.evm.address:n[o].ciphertexts.solana.address,r===o?s.push(`${t+1}. ${u}[${r}]`):s.push(`${t+1}. ${u}[${r}]-${d}[${o}]`)}let c=await Ht(s);if("> Back"===c)break;if(!await ca(`Are you sure to delete the ${c}?`,!0))break;let l=s.indexOf(c)-2;r.disabled_slots.splice(l,1),Te(e,t,r);break}case"> Add Single":{let a=await Ft(r,"Input address or index");if(null===a){console.log($e.red("Invalid account index"));break}r.disabled_slots?r.disabled_slots.push({from:a,to:a}):r.disabled_slots=[{from:a,to:a}],Te(e,t,r);break}case"> Add Range":{let a=await Tt(r);if(!a){console.log($e.red("Invalid account range"));break}r.disabled_slots?r.disabled_slots.push(a):r.disabled_slots=[a],Te(e,t,r);break}}await Le(e,t)},Be=async(t,a,n,s)=>{let i,c=await Ne(t,a);i="PP"===c.account_type?["> Address List","> Expand Address","> Slice Address","> Disable Address","> Reset Account Password",`> Switch Networks [${c.default_network}]`,"> Remove",new o.Separator("----------------------------------"),"> Back"]:["> Address List","> Import Private Key","> Remove Address","> Reset Account Password",`> Switch Networks [${c.default_network}]`,"> Remove",new o.Separator("----------------------------------"),"> Back"];switch(await Ht(i)){case"> Address List":await Re(t,a,n);break;case"> Expand Address":{const e=await Nt("Expand accounts count",Mt);if(Number(e)>2e3){console.log($e.red("Too many accounts, please input less than 2000"));break}await ze(t,a,Number(e),n);break}case"> Import Private Key":await(async(t,a,n,s)=>{let o=await Nt("Please enter a private key"),i=r.join(t,`accounts/${n}.json`),c=JSON.parse(e.readFileSync(i,"utf8"));await Ce(t,a,n,o,c.default_network,s,!1)})(t,s,a,n);break;case"> Slice Address":{const e=await Nt("Please input last account number",Dt);await Me(t,a,Number(e),n);break}case"> Remove Address":await De(t,a,n);break;case"> Disable Address":await Le(t,a);break;case"> Reset Account Password":{let e=ea(t,a);const r=await ia(`Please input new password for Account [${e}]`),s=await ia(`Please confirm new password for Account [${e}]`);if(!r||!s||r!==s){console.log($e.red("Passwords do not match"));break}return void await n.account.resetPassword(a,r)}case`> Switch Networks [${c.default_network}]`:await pt(t,a,!0);break;case"> Remove":return void await Ke(t,a);case"> Back":return}await Be(t,a,n,s)},Re=async(e,t,a)=>{const r=await Ne(e,t);let n=["> Back",new o.Separator("----------------------------------")],s=r.disabled_slots,i=wt(e),c=r.default_network,l=it(e,c),u=ie(l.chainId.toString()),d=r.data.length.toString().length+1;for(let e=0;e<r.data.length;e++){let t,c=r.data[e].tag?`(${r.data[e].tag})`:"",l=a.account.checkIsDisableAddress(s,e);t="PP"===r.account_type?"evm"===u?r.data[e].ciphertexts.evm.address:r.data[e].ciphertexts.solana.address:r.data[e].ciphertexts.address,l?n.push(new o.Separator($e.yellow(`#${e.toString().padEnd(d)} ${fa(t,i.fullAddr)} ${c}`))):n.push(`#${e.toString().padEnd(d)} ${fa(t,i.fullAddr)} ${c}`)}let p,h=Ae.keystore_slug===t?n[Ae.account_index]:n[0],g=Ae.keystore_slug===t&&Ae.account_index>0,m=await vt(e,l.chainId.toString());if(g&&Ae.account_index>15){let e=n.slice(0,Ae.account_index-15);p=n.slice(Ae.account_index-15).concat(e)}else p=n.slice(0);let f=await ka(p,"evm"===u,e,m,l,i.gasToken,i.extendedToken,g,"Select an account",h);"> Back"!==f&&(Ae.keystore_slug=t,Ae.account_index=n.indexOf(f),await qe(e,t,n.indexOf(f)-2,a),await Re(e,t,a))},qe=async(e,t,a,r)=>{const n=await Ne(e,t);let s=n.default_network,i=ct(e,t,a);const c=await it(e,s),l=await gt(i,e,s);l.status?console.log($e.green(` Address No: #${a}\n Network: ${s}\n ${c.nativeCurrency.symbol} Balance: ${l.output}`)):console.log($e.green(` Address No: #${a}\n Network: ${s}\n ${c.nativeCurrency.symbol}`));let u="> Tag";"tag"in n.data[a]&&""!==n.data[a].tag&&(u=`> Tag(${n.data[a].tag})`);let d=["> Tools","> Show address","> Assets",u,"> Reload balances","> Dump private key",new o.Separator("----------------------------------"),"> Back"];switch(await Ht(d)){case"> Tools":await xe(e,t,i,r);break;case"> Show address":await dt(e,t,a);break;case"> Assets":await kt(e,s,i);break;case"> Reload balances":await St(e,s,i);break;case u:{let r="Current tag";"tag"in n.data[a]&&""!==n.data[a].tag&&(r=`Current tag (${n.data[a].tag})`);let s=await Nt(r,Lt);n.data[a].tag=s.replace(/\s+/g," ").trim(),Te(e,t,n);break}case"> Dump private key":{let n=ct(e,t,a),s=await r.account.showPrivateKey(n);console.log("account: ",n),console.log("private key: ",s);break}case"> Back":return}},ze=async(e,t,a,r)=>{const n=await Ne(e,t),s=n.data.length,o=new Pe.SingleBar({},Pe.Presets.legacy);o.start(a,0);for(let e=s;e<s+a;e++){let a=await r.account.generateSubAccount(t,e);if(!a.status)return void console.log($e.red(a.output));n.data.push({ciphertexts:a.output}),o.increment()}o.stop(),Te(e,t,n),r.account.reloadAccount()},Me=async(e,t,a,r)=>{const n=await Ne(e,t);n.data=n.data.slice(0,a+1),Te(e,t,n),r.account.reloadAccount()},De=async(e,t,a)=>{let r=await Nt("Please input the accountIndex to remove this account",Rt);if("0"===r)return void console.log($e.red("Can't remove the first account"));let n=await Ne(e,t);await ca(`Are you sure you want to remove this account(${n.data[r].ciphertexts.address})`,!0)&&(n.data.splice(Number(r),1),Te(e,t,n),a.account.reloadAccount())},Ke=async(t,a)=>{let n=await Nt("Please input the account name to remove this account"),s=ea(t,a);if(n!==s)return void console.log($e.red("Can't remove this account"));if(!await ca(`Are you sure you want to remove this account(${s})`,!0))return;let o=r.join(t,`accounts/${a}.json`);e.rmSync(o);const i=r.resolve(t,"network.json");if(!e.existsSync(i))return;const c=JSON.parse(e.readFileSync(i,"utf8"));let l=c.accounts.indexOf(s);c.accounts.splice(l,1),e.writeFileSync(i,JSON.stringify(c,null,2))},Ue=async(t,a)=>{const n=r.resolve(t,"accounts");e.existsSync(n)||e.mkdirSync(n);let s;switch(s=0===Oe(t).accounts.length?["> Create a new account",new o.Separator("----------------------------------"),"> Back"]:["> Select an account","> Create a new account",new o.Separator("----------------------------------"),"> Back"],await Ht(s)){case"> Select an account":await Fe(t,a);break;case"> Create a new account":await je(t,a);break;case"> Back":return}await Ue(t,a)},He=require("chalk"),Je=async t=>{const a=r.resolve(t,"network.json");if(e.existsSync(a))return;const n={networks:ne,currentNetwork:"Ethereum Mainnet",accounts:[]};e.writeFileSync(a,JSON.stringify(n,null,2))},Ge=async(e,t)=>{let a=["> Edit"];"Ethereum Mainnet"!==t.name&&"Solana Mainnet"!==t.name&&a.push("> Remove"),a.push(new o.Separator("----------------------------------")),a.push("> Back");switch(await Ht(a)){case"> Edit":await We(e,t);break;case"> Remove":await Ve(e,t)}},We=async(t,a)=>{const n=r.resolve(t,"network.json"),s=JSON.parse(e.readFileSync(n,"utf8"));let o=[];for(let e=0;e<s.networks.length;e++){const t=s.networks[e];o.push(t.name)}let i=a.rpcUrl,c=a.chainId.toString(),l=a.nativeCurrency.symbol,u=a.name,d=a.multicallAddress,p=a.color;if("Ethereum Mainnet"===a.name||"Solana Mainnet"===a.name)i=await Zt(a.chainId.toString(),`Rpc Url (default: ${a.rpcUrl})`,!0);else{if(u=await Nt(`Chain Name (default: ${a.name})`),u&&u!==a.name&&o.includes(u))return void console.log(He.red("Chain Name already exists"));c=await Vt(`Chain Id (default: ${a.chainId})`,!0),i=await Zt(c||a.chainId,`RPC Url (default: ${a.rpcUrl})`,!0),l=await Qt(`Symbol (default: ${a.nativeCurrency.symbol})`),d=await Xt(a.multicallAddress?`Multicall Address (Optional) (default: ${a.multicallAddress})`:"Multicall Address (Optional)"),p=await Yt(a.color?`Color (Optional): (default: ${a.color})`:"Color (Optional)")}i=i||a.rpcUrl,c=c||a.chainId.toString(),l=l||a.nativeCurrency.symbol,u=u||a.name,d=d||a.multicallAddress,p=p||a.color;let h=oe(c.toString()),g={name:u||a.name,chainId:Number(c)||a.chainId,rpcUrl:i||a.rpcUrl,nativeCurrency:{name:l||a.nativeCurrency.symbol,symbol:l||a.nativeCurrency.symbol,decimals:h||a.nativeCurrency.decimals}};(d||a.multicallAddress)&&(g.multicallAddress=d||a.multicallAddress),(p||a.color)&&(g.color=p||a.color);for(let e=0;e<s.networks.length;e++)if(s.networks[e].name===a.name){s.networks[e]=g;break}e.writeFileSync(n,JSON.stringify(s,null,2))},Ve=async(t,a)=>{const n=r.resolve(t,"network.json");let s=JSON.parse(e.readFileSync(n,"utf8"));for(let e=0;e<s.networks.length;e++)if(s.networks[e].name===a.name){s.networks.splice(e,1);break}a.name===s.currentNetwork&&(s.currentNetwork="Ethereum Mainnet"),e.writeFileSync(n,JSON.stringify(s,null,2))},Ze=async t=>{const a=r.resolve(t,"network.json"),n=JSON.parse(e.readFileSync(a,"utf8"));let s=[];for(let e=0;e<n.networks.length;e++){const t=n.networks[e];s.push(t.name)}console.log(He.green("Please input someting about network"));const o=await Nt("Chain Name");if(s.includes(o))return void console.log(He.red("Chain Name already exists"));const i=await Vt("Chain Id");if(!i)return;const c=await Zt(i,"RPC Url");if(!c)return;const l=await Qt("Symbol");if(!l)return;const u=await Xt("Multicall Address (Optional)"),d=await Yt("Color (Optional)");let p=oe(i.toString()),h={name:o,chainId:Number(i),rpcUrl:c,nativeCurrency:{name:l,symbol:l,decimals:p}};u&&(h.multicallAddress=u),d&&(h.color=d),n.networks.push(h),e.writeFileSync(a,JSON.stringify(n,null,2))},Xe=async t=>{const a=r.resolve(t,"network.json"),n=JSON.parse(e.readFileSync(a,"utf8"));let s=[],i=[];for(let e=0;e<n.networks.length;e++){const t=n.networks[e];"solana"===ie(t.chainId.toString())?i.push(e):s.push(e)}let c=["> Back","+ Add Network",new o.Separator("----Networks(evm)----")];for(let e=0;e<s.length;e++){const t=s[e];let a=`${e+1}.${n.networks[t].name}`;0===e&&(a+=" 🔒"),c.push(a)}c.push(new o.Separator("----Networks(solana)----"));for(let e=0;e<i.length;e++){const t=i[e];let a=`${e+1}.${n.networks[t].name}`;0===e&&(a+=" 🔒"),c.push(a)}const l=await Ht(c);if("> Back"===l)return;if("+ Add Network"===l)return void await Ze(t);let u,d=c.indexOf(l);u=d<s.length+3?n.networks[s[d-3]]:n.networks[i[d-s.length-4]],await Ge(t,u),await Xe(t)},Qe=async e=>{let t=["> Enhanced Balance Display",new o.Separator("----------------------------------"),"> Back"];switch(await Ht(t)){case"> Enhanced Balance Display":await rt(e);break;case"> Back":return}await Qe(e)},Ye=async t=>{const a=r.resolve(t,"network.json"),n=JSON.parse(e.readFileSync(a,"utf8"));"status"in n||(n.status={fullAddr:!1,gasToken:!1,extendedToken:!1});let s=[`> Show Full Address [${n.status.fullAddr?"ON":"OFF"}]`,`> Show Gas Token [${n.status.gasToken?"ON":"OFF"}]`,`> Show Extended Token[${n.status.extendedToken?"ON":"OFF"}]`,new o.Separator("----------------------------------"),"> Back"];const i=await Ht(s);"> Back"!==i&&(i.includes("Full Address")?n.status.fullAddr=await et():i.includes("Gas Token")?n.status.gasToken=await et():i.includes("Extended Token")&&(n.status.extendedToken=await et()),e.writeFileSync(a,JSON.stringify(n,null,2)))},et=async()=>{switch(await Ht(["> On","> Off"])){case"> On":return!0;case"> Off":return!1}},tt=(t,a)=>{const n=r.resolve(t,"network.json");let s=JSON.parse(e.readFileSync(n,"utf8")).showTokens;return a in s?s[a]:[]},at=async t=>{const a=r.resolve(t,"network.json"),n=JSON.parse(e.readFileSync(a,"utf8"));let s={};for(let e of n.networks)s[e.chainId.toString()]=e.name;const i=r.resolve(t,"assets.json");if(!ha(i))return void console.log(He.red("No asset here yet"));const c=JSON.parse(e.readFileSync(i,"utf8"));let l=[],u=[],d={};for(let e in c){d[l.length]={name:s[e],address:null},l.push(new o.Separator(`----- Networks (${s[e]}) -------`));let a=tt(t,s[e]),r=c[e].length;for(let t=0;t<r;t++){let r=c[e][t];a.includes(r.address)&&u.push(`${t+1}.${r.symbol.padEnd(6)} CA: ${He.green(`${fa(r.address).padEnd(45)}`)} Decimals: ${r.display_decimals?r.display_decimals:"4"}`),d[l.length]={name:s[e],address:r.address},l.push(`${t+1}.${r.symbol.padEnd(6)} CA: ${He.green(`${fa(r.address).padEnd(45)}`)} Decimals: ${r.display_decimals?r.display_decimals:"4"}`)}}let p=await Jt(l,"Choose Tokens",u),h={};for(let e=0;e<p.length;e++){let t=p[e],a=d[l.indexOf(t)];a.name in h?h[a.name].push(a.address):h[a.name]=[a.address]}n.showTokens=h,e.writeFileSync(a,JSON.stringify(n,null,2))},rt=async e=>{const t=["> Status","> Token List","> Add Token",new o.Separator("----------------------------------"),"> Back"];switch(await Ht(t)){case"> Status":await Ye(e);break;case"> Token List":await at(e);break;case"> Add Token":await _t(e);break;case"> Back":return}await rt(e)},nt=async e=>{let t=["> Networks","> Dataview",new o.Separator("----------------------------------"),"> Back"];switch(await Ht(t)){case"> Networks":await Xe(e);break;case"> Dataview":await Qe(e);break;case"> Back":return}await nt(e)},st=async t=>{const a=r.resolve(t,"network.json"),n=JSON.parse(e.readFileSync(a,"utf8")).networks.map(e=>`> ${e.name}`);return(await Ht(n,"Please select a default network")).slice(2)},ot=(t,a)=>{const n=r.resolve(t,"network.json"),s=JSON.parse(e.readFileSync(n,"utf8"));for(let e=0;e<s.networks.length;e++){const t=s.networks[e];if(t.name===a)return ie(t.chainId.toString())}return"unknown"},it=(t,a)=>{const n=r.resolve(t,"network.json"),s=JSON.parse(e.readFileSync(n,"utf8"));for(let e=0;e<s.networks.length;e++){const t=s.networks[e];if(t.name===a)return t}return null},ct=(e,t,a)=>{const r=Ne(e,t);if("PK"===r.account_type)return r.data[a].ciphertexts.address;let n=r.default_network,s=ot(e,n);return"solana"===s?r.data[a].ciphertexts.solana.address:"evm"===s?r.data[a].ciphertexts.evm.address:null},lt=(e,t)=>Ne(e,t).ciphertexts.address,ut=async(t,a,n)=>{const s=r.resolve(t,"network.json"),i=JSON.parse(e.readFileSync(s,"utf8")).networks,c=i.length;let l=Ne(t,a),u=["> Back",new o.Separator("----------------------------------")],d=l.data[n].default_network;d&&""!==d?u.push("○ Same as the account setting"):u.push("● Same as the account setting");for(let e=0;e<c;e++){const t=i[e];let a;a=ie(t.chainId.toString())?l.data[n].ciphertexts.solana.address:l.data[n].ciphertexts.evm.address,t.name===d?u.push(`● ${a} [${t.name}]`):u.push(`○ ${a} [${t.name}]`)}const p=await Ht(u);if("> Back"===p)return;let h=u.indexOf(p);2===h?delete l.data[n].default_network:l.data[n].default_network=i[h-3].name,Te(t,a,l);let g=l.default_network;"default_network"in l.data[n]&&""!==l.data[n].default_network&&(g=l.data[n].default_network);let m=it(t,g);console.log(He.green(` Address No: #${n}\n Network: ${g}\n ${m.nativeCurrency.symbol} Balance: 0`))},dt=async(t,a,n)=>{const s=r.resolve(t,"network.json"),o=JSON.parse(e.readFileSync(s,"utf8")).networks,i=o.length;let c=Ne(t,a),l=c.default_network;const u=ot(t,l);for(let e=0;e<i;e++){const a=o[e],r=ot(t,a.name);if("PK"===c.account_type&&u!==r)continue;let s;s="PK"===c.account_type?c.data[n].ciphertexts.address:"evm"===r?c.data[n].ciphertexts.evm.address:c.data[n].ciphertexts.solana.address,a.name===l?console.log(`● ${s} [${a.name}]`):console.log(`○ ${s} [${a.name}]`)}},pt=async(t,a,n)=>{const s=r.resolve(t,"network.json"),i=JSON.parse(e.readFileSync(s,"utf8")).networks,c=i.length;let l=Ne(t,a),u=["> Back",new o.Separator("----------------------------------")],d=l.default_network,p="";n||(p=l.ciphertexts.address);let h=[];const g=ot(t,d);for(let e=0;e<c;e++){const a=i[e],r=ot(t,a.name);"PK"===l.account_type&&g!==r||(a.name===d?n?u.push(`● ${a.name}`):u.push(`● ${p} [${a.name}]`):n?u.push(`○ ${a.name}`):u.push(`○ ${p} [${a.name}]`),h.push(a.name))}const m=await Ht(u);if("> Back"===m)return;let f=u.indexOf(m);if(l.default_network=h[f-2],Te(t,a,l),!n){let e=l.default_network,a=it(t,e);console.log(He.green(` Address No: #0\n Network: ${e}\n ${a.nativeCurrency.symbol} Balance: 0`))}},ht=async(e,t,a,r)=>{let n;n="PK"===Ne(a,e).account_type?ct(a,e,t):lt(a,e);const s=await gt(n,a,r);s.status,console.log(He.green(` Address No: #${t}\n Network: ${r}\n ${s.output}`))},gt=async(e,t,a)=>{const r=it(t,a),n=r.rpcUrl,s=r.nativeCurrency.decimals;let o;if(o="solana"===ie(r.chainId.toString())?await D(e,n):await M(e,n),o.status){let e=new v(o.output.toString());o.output=e.dividedBy(Math.pow(10,s)).toFixed(4,v.ROUND_FLOOR)}return ee(r.chainId.toString(),[e],["0"]),o},mt=(e,t,a)=>{const r=Ne(e,t);if("PK"===r.account_type)return r.default_network;for(let e=0;e<r.data.length;e++)if(r.data[e].ciphertexts.solana.address===a||r.data[e].ciphertexts.evm.address===a)return"default_network"in r.data[e]?r.data[e].default_network:r.default_network;return null},ft=t=>{const a=r.resolve(t,"network.json"),n=JSON.parse(e.readFileSync(a,"utf8")).networks,s=n.length;let o=[];for(let e=0;e<s;e++)"evm"===ie(n[e].chainId.toString())&&o.push(n[e].name);return o},wt=t=>{const a=r.resolve(t,"network.json");return JSON.parse(e.readFileSync(a,"utf8")).status},yt=require("chalk"),vt=async(t,a)=>{let n=r.join(t,"assets.json");if(!ha(n))return[];const s=e.readFileSync(n).toString(),o=JSON.parse(s);return a in o?o[a]:[]},bt=async(e,t,a)=>{const r=await vt(e,t);let n=[];for(let e=0;e<r.length;e++)r[e].symbol.toLocaleLowerCase()===a.toLocaleLowerCase()&&n.push(r[e]);return n},kt=async(e,t,a)=>{const r=it(e,t),n=ie(r.chainId.toString()),s=await vt(e,r.chainId.toString());if(!s)return void console.log(yt.red("No asset found"));const o=await At(a,s,r.rpcUrl,n,r.chainId.toString());let i=1;for(let e=0;e<o.length;e++)"0"!==o[e].balance&&"0.0000"!==o[e].balance&&(console.log(yt.green(`${i}. ${o[e].symbol} Balance: ${o[e].balance}`)),i+=1);1===i&&console.log(yt.red("No asset found"))},St=async(e,t,a)=>{const r=it(e,t);let n=(await vt(e,r.chainId.toString())).map(e=>e.address);n.push("0"),ee(r.chainId.toString(),[a],n)},xt=async(t,a,n,s,o,i,c)=>{let l=r.join(t,"assets.json"),u={};if(ha(l)){const t=e.readFileSync(l).toString();u=JSON.parse(t)}void 0===u[a]&&(u[a]=[]);for(let t=0;t<u[a].length;t++)if(u[a][t].address.toLocaleLowerCase()===n.toLocaleLowerCase()||u[a][t].symbol.toLocaleLowerCase()===s.toLocaleLowerCase())return u[a][t]={address:n,symbol:s,name:o,decimals:i,display_decimals:c},void e.writeFileSync(l,JSON.stringify(u,null,4));u[a].push({address:n,symbol:s,name:o,decimals:i,display_decimals:c}),e.writeFileSync(l,JSON.stringify(u,null,4))},_t=async t=>{const a=r.resolve(t,"network.json");let n=[],s=JSON.parse(e.readFileSync(a,"utf8")).networks;for(let e=0;e<s.length;e++)n.push(`${e+1}. ${s[e].name}`);let o=(await Ht(n)).split(".")[1].trim();const i=ot(t,o),c=it(t,o),l=await Nt("Enter contract address",Ut);let u;if("evm"===i){if(!le(l))return void console.log(yt.red("evm address format error"));u=await K(l,c.rpcUrl)}else{if(!ce(l))return void console.log(yt.red("solana address format error"));u=await U(l,c.rpcUrl)}if(!u.status)return void console.log(yt.red(u.output));u.output.name||(u.output.name=await Nt("Please input token name")),u.output.symbol||(u.output.symbol=await Nt("Please input token symbol")),console.log(yt.green(`Token ${u.output.symbol}(${u.output.name}) loaded successfully.`));let d=await Nt("Enter decimals for display",Rt);d=parseInt(d),await xt(t,c.chainId.toString(),l,u.output.symbol,u.output.name,u.output.decimals,d)},$t=async(e,t)=>{const a=ot(e,t),r=it(e,t),n=await Nt("Enter contract address",Ut);let s;if("evm"===a){if(!le(n))return void console.log(yt.red("evm address format error"));s=await K(n,r.rpcUrl)}else{if(!ce(n))return void console.log(yt.red("solana address format error"));s=await U(n,r.rpcUrl)}if(!s.status)return void console.log(yt.red(s.output));s.output.name||(s.output.name=await Nt("Please input token name")),s.output.symbol||(s.output.symbol=await Nt("Please input token symbol")),console.log(yt.green(`Token ${s.output.symbol}(${s.output.name}) loaded successfully.`));let o=await Nt("Enter decimals for display",Rt);o=parseInt(o),await xt(e,r.chainId.toString(),n,s.output.symbol,s.output.name,s.output.decimals,o)},Pt=async(e,t,a)=>{const r=["> Show Assets","> Add Asset",new o.Separator("----------------------------------"),"> Back"];switch(await Ht(r)){case"> Show Assets":await kt(e,a,t);break;case"> Add Asset":await $t(e,a);break;case"> Back":return}await Pt(e,t,a)},At=async(e,t,a,r,n)=>{let s=t.length,o=[];for(let n=0;n<s;n++){let s=t[n];"evm"===r?o.push(H(e,s.address,a)):"solana"===r&&o.push(J(e,s.address,a))}let i=await Promise.all(o),c=[];for(let a=0;a<s;a++){let r=t[a],s=r.decimals;if(!i[a].status)return console.log(yt.red(i[a].output)),null;let o=new v(i[a].output).dividedBy(Math.pow(10,s)).toFixed(4,v.ROUND_FLOOR);c.push({address:r.address,symbol:r.symbol,balance:o}),ee(n,[e],[r.address])}return ee(n,[e],["0"]),c},It=async(e,t,a,r,n,s,o)=>{let i=a.length,c=it(e,n),l="evm"===ie(c.chainId.toString());if(s&&await Q(t,"0",c.chainId.toString(),r,l),o){let s=tt(e,n);for(let e=0;e<i;e++){let n=a[e].address;s.includes(n)&&await Q(t,n,c.chainId.toString(),r,l)}}return Y(c.chainId.toString(),t,a,c)},Ct=require("chalk"),jt=process.env.HOME||process.env.USERPROFILE,Ot=`${jt}/.wative`,Nt=async(e,t)=>{const a=[{name:"inputText",type:"input",message:`${e}:`,validate:t}],{inputText:r}=await o.prompt(a);return r.trim().toString()},Tt=async e=>{for(let t=0;t<5;t++){let t=await Ft(e,"Input start address or index");if(!t)return console.log(Ct.red("Invalid start account index")),null;let a=await Ft(e,"Input end address or index");if(!a)return console.log(Ct.red("Invalid end account index")),null;if(!(t>a))return{from:t,to:a};console.log(Ct.red("Invalid address range"))}return null},Et=async(t,a,n)=>{let s=r.join(t,`accounts/${a}.json`);if(!e.existsSync(s))return null;let o=JSON.parse(e.readFileSync(s,"utf8")),i=o.data,c=o.account_type,l=i.length;if(0===l)return null;for(let e=0;e<l;e++){if("PK"===c&&i[e].ciphertexts.address.toLocaleLowerCase()===n.toLocaleLowerCase())return e.toString();if("PP"===c&&(i[e].ciphertexts.evm.address.toLocaleLowerCase()===n.toLocaleLowerCase()||i[e].ciphertexts.solana.address.toLocaleLowerCase()===n.toLocaleLowerCase()))return e.toString()}return null},Ft=async(e,t)=>{let a=e.data,r=a.length;if(0===r)return null;let n=[],s=[];for(let e=0;e<r;e++)n.push(a[e].ciphertexts.evm.address.toLocaleLowerCase()),s.push(a[e].ciphertexts.solana.address.toLocaleLowerCase());let o=r-1;for(let e=0;e<5;e++){let e=await Nt(t,Kt),a=pa(e);if("unknown"===a){if(Number(e)>o){console.log(Ct.red("Invalid account index"));continue}return Number(e)}if("evm"===a&&-1!==n.indexOf(e.toLocaleLowerCase()))return n.indexOf(e.toLocaleLowerCase());if("solana"===a&&-1!==s.indexOf(e.toLocaleLowerCase()))return s.indexOf(e.toLocaleLowerCase())}return null},Lt=e=>""===e||((e=e.replace(/\s+/g," ").trim()).length>40?"Tag length should be less than 10":!1!==/^[0-9a-zA-Z\s]*$/g.test(e)||"Tag should be alphanumeric"),Bt=e=>!(e.length<6)||"Address length should be greater than 6",Rt=e=>!isNaN(Number(e))||"Value should be a number",qt=e=>!(isNaN(Number(e))||Number(e)>1e3)||"Value should be a number",zt=e=>{const t=(e=e.replace(/\s+/g," ")).split(/\s+/g);if(12!==t.length&&24!==t.length)return"Passphrase should be equal to 12 or 24 words";for(let e=0;e<t.length;e++)if(!1===re.includes(t[e]))return"Passphrase word should be valid";return!0},Mt=e=>{let t=Number(e);return isNaN(t)?"Amount should be a number":!(t>2e3)||"Amount should be less than 2000"},Dt=e=>{let t=Number(e);return!isNaN(t)||"Last account no should be a number"},Kt=e=>!1===isNaN(Number(e))||Ut(e),Ut=e=>"unknown"!=pa(e)||"Address should be valid",Ht=async(e,t,a)=>{const r=[{type:"list",name:"inputText",message:t||"Choose an option",default:a,choices:e,pageSize:30,filter:e=>e}],{inputText:n}=await o.prompt(r);return n.toString()},Jt=async(e,t,a)=>{const r=[{type:"checkbox",name:"inputText",message:t||"Choose an option",default:a,choices:e,pageSize:30,filter:e=>e}],{inputText:n}=await o.prompt(r);return n},Gt=()=>{console.log(Ct.green(s.textSync("Wative",{font:"ANSI Shadow",horizontalLayout:"default",verticalLayout:"default"})))},Wt=async()=>{let t=await Nt(`Keystore storage located in (default: ${Ot})`);return t||(t=Ot),t=t.trim(),t=t.replace("~",jt),e.existsSync(t)||e.mkdirSync(t,{recursive:!0}),t},Vt=async(e,t=!1)=>{for(let a=0;a<5;a++){const a=await Nt(e);if(""===a&&t)return null;if(/^[0-9]*$/g.test(a))return a}return null},Zt=async(e,t,a=!1)=>{for(let r=0;r<5;r++){let r=await Nt(t);try{if(""===r&&a)return null;if("solana"===ie(e.toString()))return r;const t=await z(r);if(!t.status){console.log(Ct.red(t.output));continue}if(t.output.toString()===e.toString())return r;console.log(Ct.red("Rpc url not match chain id"))}catch(e){console.log(Ct.red(e.message))}}return null},Xt=async e=>{for(let t=0;t<5;t++){let t=await Nt(e);if(""===t)return null;""===t||42===t.length||console.log(Ct.red("Multicall address length must be 42"))}return null},Qt=async e=>{let t=/^[A-Za-z][0-9a-zA-Z]*$/g;for(let a=0;a<5;a++){let a=await Nt(e);if(""===a)return null;if(t.test(a))return a}return null},Yt=async e=>{let t=/^#[0-9A-Fa-f]{6}$/g;for(let a=0;a<5;a++){let a=await Nt(e);if(""===a)return null;if(t.test(a))return a}return null},ea=(e,t)=>{const a=Oe(e).accounts,r=aa(a).indexOf(t);return-1!==r?a[r]:t},ta=e=>e=(e=(e=(e=e.trim()).toLocaleLowerCase()).replace(/\s+/g,"-").trim()).replace(/\-+/g,"-").trim(),aa=e=>{let t=[];for(let a=0;a<e.length;a++)t.push(ta(e[a]));return t},ra=async(e,t)=>{let a=aa(t),r=/^(?![-_])[a-zA-Z0-9_-]{4,40}(?<![-_])$/g;for(let t=0;t<5;t++){let t=await Nt(e);t=t.trim();let n=ta(t);if(r.test(n)){if(a.includes(n)){console.log(Ct.red("Account name already exists"));continue}return t}}return null},na=async(e,t)=>{const a=[{name:"inputText",type:"password",mask:"#",message:`${e}:`,validate:t}],{inputText:r}=await o.prompt(a);return r.trim().toString()},sa=async e=>{const t=[{name:"password",type:"password",mask:"#",message:`${e}:`}];let{password:a}=await o.prompt(t);return a},oa=async(e,t)=>{const a=[{name:"inputText",type:"input",message:`${e}:`,validate:t,transformer:e=>{const t=e.split(" "),a=t.map((e,a)=>a<t.length-1?"#".repeat(e.length):e);return a.join(" ")}}],{inputText:r}=await o.prompt(a);return r.trim().toString()},ia=async e=>{const t=[{name:"password",type:"password",mask:"#",message:`${e}:`,validate:e=>function(e){let t,a="Password must contain at least: \n",r=!0,n=" ",s=Ct.green("✔"),o=Ct.red("✖");return e.length>=8?a+=n+s+" 8 characters\n":(a+=n+o+" 8 characters\n",r=!1),t=/[0-9]/,t.test(e)?a+=n+s+" One numerical character\n":(a+=n+o+" One numerical character\n",r=!1),t=/[A-Z]/,t.test(e)?a+=n+s+" One uppercase letter\n":(a+=n+o+" One uppercase letter\n",r=!1),t=/[!@#$%]/,t.test(e)?a+=n+s+" One sepcial character (i.e. !@#$%)\n":(a+=n+o+" One sepcial character (i.e. !@#$%)\n",r=!1),!!r||a}(e)}];let{password:a}=await o.prompt(t);return a},ca=async(e,t=!0)=>{const a=[{name:"confirm",type:"confirm",message:`${e}`,default:t}],{confirm:r}=await o.prompt(a);return r},la=async(e,t)=>{const a=[{name:"editor",type:"editor",message:`${e}`,validate:t}],{editor:r}=await o.prompt(a);return r.trim().toString()},ua=function(e){return!!/^0x[0-9a-fA-F]*$/g.test(e.trim())},da=async(e,t)=>{let a;try{a={status:!0,output:await e(...t)}}catch(e){a={status:!1,output:e.toString()}}return a},pa=e=>e.startsWith("0x")&&42===e.length?"evm":/^[A-HJ-NP-Za-km-z1-9]*$/.test(e)&&e.length<=44&&e.length>=32?"solana":"unknown",ha=t=>(t=t.trim(),e.existsSync(t)),ga=(e,t)=>{let a=[];for(let r=0;r<e.length;r+=t)a.push(e.slice(r,r+t));return a},ma=e=>new Promise(t=>setTimeout(t,e)),fa=(e,t=!0)=>t?e:e.startsWith("0x")?e.slice(0,8)+"..."+e.slice(-6):e.slice(0,6)+"..."+e.slice(-6),wa=(e,t)=>{if(!e.name)return null;let a=null;if(t)a=/0x[0-9a-fA-f]{40}/.exec(e.name),a=a?a[0]:null;else{let t=/\s+([0-9a-zA-Z]*)/.exec(e.name);a=t?t[1]:null,"Back"===a&&(a=null)}return a},ya=(e,t,a)=>{let r,n;return e<t/2?a/2<=t?(r=0,n=a/2):(r=0,n=t):a/2<=t?(r=0,n=a/2):(r=e-t/2+1,n=e+t/2+1),{fromIndex:r,toIndex:n}},va=(e,t)=>{const a=[];for(let r=0;r<e.length;r++){const n=wa(e[r],t);a.push(n)}return a.concat(a)},ba=(e,t,a,r,n,s,o,i,c)=>{for(let l=i;l<c;l++){let i=l>=t.length/2?l-t.length/2:l,c=e[i];if(!c.name)continue;let u=c.name,d=t[l],p="";if(!d)continue;for(let e in a[d])(s||e!==n)&&(o||e===n)&&(u.includes(e)||(p+=`${e}:${a[d][e].padEnd(r[e])} `));let h=u.split("(");if(h.length>1){let t=h[1];e[i].name=h[0]+` ${p}`+`(${t}`}else e[i].name=h[0]+` ${p}`}},ka=async(e,t,a,r,n,s,i,c,l,u)=>{const d=[{type:"list",name:"inputText",message:l||"Choose an option",choices:e,pageSize:30,default:u,loop:!0,filter:e=>e}],p=o.prompt(d);let h,g=0,m=0;for(;!p.ui.activePrompt.answers[p.ui.activePrompt.opt.name];){if(c||await ma(1e3),h===p.ui.activePrompt.selected)continue;if(g===p.ui.activePrompt.selected?m+=1:(m=0,g=p.ui.activePrompt.selected),c){m=6,c=!1;const e=p.ui.activePrompt.opt.pageSize,a=va(p.ui.activePrompt.opt.choices.choices,t),{fromIndex:r,toIndex:s}=ya(g,e,a.length),o=a.slice(r,s);if(!ae(n.chainId.toString(),o)){m=0;continue}}if(m<5)continue;m=0;const e=p.ui.activePrompt.opt.pageSize,o=va(p.ui.activePrompt.opt.choices.choices,t),{fromIndex:l,toIndex:u}=ya(g,e,o.length),d=o.slice(l,u);let f=await It(a,d,r,n.rpcUrl,n.name,s,i),w={};for(let e in f)for(let t in f[e]){let a=f[e][t].length+1;w[t]?w[t]<a&&(w[t]=a):w[t]=a}const y=n.nativeCurrency.symbol;ba(p.ui.activePrompt.opt.choices.choices,o,f,w,y,s,i,l,u),p.ui.activePrompt.screen.render(""),p.ui.activePrompt.render(),h=g}return p.ui.activePrompt.answers[p.ui.activePrompt.opt.name]},Sa=t=>{const a=r.resolve(t,"network.json"),n=JSON.parse(e.readFileSync(a,"utf8"));n.status||(n.status={fullAddr:!0,gasToken:!1,extendedToken:!1}),n.showTokens||(n.showTokens={});let s=n.accounts.length;for(let a=0;a<s;a++){let o=n.accounts[s-1-a],i=ta(o),c=r.resolve(t,`accounts/${i}.json`);e.existsSync(c)||n.accounts.splice(s-1-a,1)}e.writeFileSync(a,JSON.stringify(n,null,4));let o=n.accounts,i=aa(o);for(let a=0;a<i.length;a++){let n=r.resolve(t,`accounts/${i[a]}.json`),s=JSON.parse(e.readFileSync(n,"utf8"));"PP"!==s.account_type&&("data"in s||(s.data=[{ciphertexts:s.ciphertexts}],delete s.ciphertexts,e.writeFileSync(n,JSON.stringify(s,null,4))))}};require("wative-core");const xa=async(e,t)=>{switch(await Ht(["> System & Settings","> Accounts","> Tools","> Exit"])){case"> System & Settings":await nt(e);break;case"> Accounts":await Ue(e,t);break;case"> Tools":await _e(e,t);break;case"> Exit":return}await xa(e,t)};class _a{constructor(t,a){this.configDir=t||r.join(require("os").homedir(),".wative/ssh"),this.keystorePath=a||r.join(require("os").homedir(),".wative"),e.existsSync(this.configDir)||e.mkdirSync(this.configDir,{recursive:!0});const n=r.join(this.configDir,"conf.d");e.existsSync(n)||e.mkdirSync(n,{recursive:!0})}getKeystorePath(){return this.keystorePath}getConfigDir(){return this.configDir}async createServiceConfig(e,t,a,r="default_client",n){if(!this.isValidServiceName(e))throw new Error("Invalid service name. Use only alphanumeric characters, hyphens, and underscores.");if(this.isPortInUse(t))throw new Error(`Port ${t} is already in use by another service.`);const s=await this.generateServiceKeyPair(e),o=await this.generateClientKeyPair(e,r),i={name:e,description:n||`Wative SSH Service - ${e}`,ssh:{listen:"127.0.0.1",port:t,log:{size:10485760,backups:3}},keystore:{path:this.keystorePath,allowed_keystores:a},clients:[{name:r,public_key_path:o.publicKey,allowed_keystores:a}],server_keys:{private_key_path:s.privateKey,passphrase:s.passphrase}};return this.saveServiceConfig(e,i),i}loadServiceConfig(t){const a=this.getServiceConfigPath(t);if(!e.existsSync(a))throw new Error(`Service configuration '${t}' not found.`);const r=b.parse(e.readFileSync(a,"utf-8"));return this.parseConfigData(r)}listServiceConfigs(){const t=r.join(this.configDir,"conf.d");if(!e.existsSync(t))return[];return e.readdirSync(t).filter(a=>{const n=r.join(t,a);return e.statSync(n).isDirectory()&&e.existsSync(r.join(n,"config.ini"))})}removeServiceConfig(t){const a=this.getServiceConfigPath(t);e.existsSync(a)&&e.unlinkSync(a),this.removeServiceKeys(t)}updateServiceConfig(e,t){const a={...this.loadServiceConfig(e),...t};this.saveServiceConfig(e,a)}async validateKeystorePasswords(e,t){const a={},{WativeCore:r}=require("wative-core");for(const n of e)try{const e=t[n];if(!e){a[n]=!1;continue}const s=new r(this.keystorePath,[n],[e]);a[n]=s.account.isLogin(n)}catch(e){a[n]=!1}return a}isValidServiceName(e){return/^[a-zA-Z0-9_-]+$/.test(e)&&e.length>0&&e.length<=50}isPortInUse(e){const t=this.listServiceConfigs();for(const a of t)try{if(this.loadServiceConfig(a).ssh.port===e)return!0}catch(e){}return!1}async generateServiceKeyPair(t){const a=this.generateSecurePassphrase(),n=r.join(this.configDir,"conf.d",t);e.existsSync(n)||e.mkdirSync(n,{recursive:!0});const s=r.join(n,"server_private_key"),o=r.join(n,"server_public_key.pub");return e.existsSync(s)||(console.log(`Generating SSH server key pair for service '${t}'...`),x(`ssh-keygen -t rsa -b 4096 -f ${s} -N '${a}' -C 'wative_${t}_server'`,{stdio:"inherit"})),{privateKey:s,publicKey:o,passphrase:a}}async generateClientKeyPair(t,a){const n=r.join(this.configDir,"conf.d",t);e.existsSync(n)||e.mkdirSync(n,{recursive:!0});return{privateKey:"",publicKey:r.join(n,`${a}.pub`),passphrase:""}}generateSecurePassphrase(){return k.randomBytes(32).toString("hex")}getServiceConfigPath(e){return r.join(this.configDir,"conf.d",e,"config.ini")}saveServiceConfig(t,a){const n=this.getServiceConfigPath(t),s=r.dirname(n);e.existsSync(s)||e.mkdirSync(s,{recursive:!0});const o=b.stringify(a);e.writeFileSync(n,o)}parseConfigData(e){return{name:e.name,description:e.description,ssh:{listen:e.ssh.listen,port:parseInt(e.ssh.port),log:{size:parseInt(e.ssh.log.size),backups:parseInt(e.ssh.log.backups)}},keystore:{path:e.keystore.path,allowed_keystores:Array.isArray(e.keystore.allowed_keystores)?e.keystore.allowed_keystores:e.keystore.allowed_keystores.split(",")},clients:Array.isArray(e.clients)?e.clients:[e.clients],server_keys:{private_key_path:e.server_keys.private_key_path,passphrase:e.server_keys.passphrase}}}removeServiceKeys(t){const a=[`id_rsa_${t}_server`,`id_rsa_${t}_server.pub`,`id_rsa_${t}_*`];for(const t of a){const a=r.join(this.configDir,t);e.existsSync(a)&&e.unlinkSync(a)}}}const $a=t=>{if(t=t.trim(),!e.existsSync(t))throw new Error("File not exists")};const{WativeCore:Pa}=require("wative-core"),{Connection:Aa,PublicKey:Ia,VersionedTransaction:Ca,VersionedMessage:ja}=require("@solana/web3.js"),Oa=require("bs58"),{Keypair:Na,TransactionMessage:Ta,ComputeBudgetInstruction:Ea,TransactionInstruction:Fa,ComputeBudgetProgram:La}=require("@solana/web3.js"),{Wallet:Ba}=require("@coral-xyz/anchor");I.configure({appenders:{file:{type:"file",filename:process.env.HOME+"/.wative/logs/wative.log",maxLogSize:10485760,backups:3,compress:!0,keepFileExt:!0,layout:{type:"pattern",pattern:"%d{yyyy-MM-dd hh:mm:ss.SSS} [%p] %c - %m"},encoding:"utf-8"},console:{type:"console"}},categories:{default:{appenders:["file","console"],level:"info"}}});const Ra=I.getLogger("file");Ra.level="info";class qa{constructor(e,t,r,n,s,o,i,c){if(this._allowedAppIds=[],this._allowedPubKeys=[],this._allowedKeystoreIds=[],this._sessionIdAppIdMap={},$a(e),0===r.length||0===n.length||0===s.length||r.length!==n.length||r.length!==s.length)throw new Error("WativeWielderServer:: constructor: Invaild AllowedApp");for(let e=0;e<s.length;e++)for(let t=0;t<s[e].length;t++){const a=s[e][t];if(!i.includes(a))throw new Error("WativeWielderServer:: constructor: Invaild AllowedKeystoreIds")}for(let e of r)this._allowedAppIds.push(Buffer.from(e));for(let e of n){let t=$.parseKey(a(e));this._allowedPubKeys.push(t)}this.wativeCore=new Pa(o,i,c),this._idRsaPrivatePath=e,this._idRsaPassphrase=t,this._allowedKeystoreIds=s,this._keystoreDirectoryPath=o}listen(e,t){new P({hostKeys:[{key:a(this._idRsaPrivatePath),passphrase:this._idRsaPassphrase}]},e=>{e.on("authentication",t=>{let a=!0;if(this&&(this.checkValue(Buffer.from(t.username),"appId")||(a=!1)),"publickey"!==t.method||!a)return t.reject();{let e=this.getBytesIndex(Buffer.from(t.username),this._allowedAppIds),a=this._allowedPubKeys[e];if(t.key.algo!==a.type||!this.checkValue(t.key.data,"publicKey")||t.signature&&!0!==a.verify(t.blob,t.signature,t.hashAlgo))return t.reject()}if(a){const a=e._protocol._kex.sessionID.toString("hex");this._sessionIdAppIdMap[a]=Buffer.from(t.username),t.accept()}else t.reject()}).on("ready",()=>{e.on("session",(t,a)=>{t().once("exec",async(t,a,r)=>{const n=e._protocol._kex.sessionID.toString("hex"),s=await this.web3Request(n,r.command),o=t();o&&(JSON.stringify(s)?(o.write(JSON.stringify(s)),o.exit(0),o.end()):(o.write("ssh2 connect error"),o.exit(0),o.end()))})})}).on("close",()=>{Ra.info("Client disconnected")}).on("error",e=>{Ra.error("err: ",e.message)})}).listen(t,e,function(){Ra.info("Listening on port "+t)})}async web3Request(e,t){try{const a=this._sessionIdAppIdMap[e],r=this.getBytesIndex(a,this._allowedAppIds);if(r<0)return{status:!1,msg:"app not found"};let n=JSON.parse(t);Ra.info("sign message: ",t);let s=n.method,o=n.keystoreId||n.params.keystoreId,i=n.chainId||n.params.chainId;if(!this._allowedKeystoreIds[r].includes(o))return{status:!1,msg:"keystore not allowed"};let c;if("get_root_account"===s)c=this.getRootAccount(o,i);else if("get_sub_account"===s){let e=n.params;c=this.getSubAccount(o,e.chainId,null==e?void 0:e.startIndex,null==e?void 0:e.endIndex)}else if("sign"===s){let e=n.params;try{c=await this.wativeCore.account.signTransaction(e.txParams.from,e.txParams,e.rpcUrl)}catch(e){return Ra.error("sign error: ",e.message),{status:!1,msg:e.msg}}}else if("sign_and_send"===s){let e=n.params;try{c={transactionHash:await this.wativeCore.account.signAndSendTx(e.txParams,e.rpcUrl)}}catch(e){return{status:!1,msg:e.msg}}}else if("solana_sign"===s)try{let e=n.params;c=await this.signSolanaTransaction(e.txParams.from,e.txParams.data,e.txParams.lookup_tables,e.rpcUrl,e.priority_fee)}catch(e){return Ra.error("sign error: ",e.message),{status:!1,msg:e.msg}}else if("solana_send"===s)try{let e=n.params;c=await this.sendSignedSolanaTransaction(e.txParams.from,e.txParams.signature,e.txParams.data,e.rpcUrl)}catch(e){return Ra.error("sign error: ",e.message),{status:!1,msg:e.msg}}else if("sign_message"===s)try{let e=n.params;Ra.debug("sign message: ",e),c=await this.signMessage(e.account,e.message)}catch(e){return Ra.error("sign error: ",e.message),{status:!1,msg:e.msg}}else{if("sign_typed_data"!==s)return{status:!1,msg:"message method not find"};try{let e=n.params;Ra.debug("sign message: ",e),c=await this.signTypedData(e.account,e.domain,e.types_name,e.types,e.message)}catch(e){return Ra.error("sign error: ",e.message),{status:!1,msg:e.msg}}}return{status:!0,data:c}}catch(e){return Ra.error("sign error: ",e.message),{status:!1,msg:e.msg}}}checkValue(e,t){if("appId"!==t&&"publicKey"!==t)return!1;let a=this._allowedAppIds.length;for(let r=0;r<a;r++){let a;a="appId"===t?this._allowedAppIds[r]:this._allowedPubKeys[r].getPublicSSH();const n=e.length!==a.length;n&&(a=e);const s=S(e,a);if(!n&&s)return!0}}getBytesIndex(e,t){let a=t.length;for(let r=0;r<a;r++)if(e.length===t[r].length&&S(e,t[r]))return r;return-1}getRootAccount(e,t){const n=r.resolve(this._keystoreDirectoryPath,`accounts/${e}.json`);let s,o=a(n);return o=JSON.parse(o.toString()),s="SOLANA"===this.getChainType(t)?o.data[0].ciphertexts.solana.address:o.data[0].ciphertexts.evm.address,[{id:0,address:s,children:o.data.length,type:"M"}]}getChainType(e){return"901"===e||"902"===e||"903"===e?"SOLANA":"EVM"}getSubAccount(e,t,n,s){const o=r.resolve(this._keystoreDirectoryPath,`accounts/${e}.json`);let i=a(o);i=JSON.parse(i.toString());let c=i.data.length-1;s&&s<c&&(c=s);let l=0;if(n&&n>0&&(l=n),l>c)return[];let u=this.getChainType(t),d=[];for(let e=l;e<=c;e++)d.push(i.data[e].ciphertexts[u.toLocaleLowerCase()].address);return d}async signMessage(e,t){let a=await this.wativeCore.account.signMessage(e,t);return console.log(a),a}async signTypedData(e,t,a,r,n){let s=JSON.parse(t),o=JSON.parse(r),i=JSON.parse(n);console.log(s),console.log(o),console.log(i);let c=this.wativeCore.account.showPrivateKey(e),l=new C.Wallet(c),u=await l.signTypedData(s,{[a]:o},i);return console.log(u),{status:!0,output:u}}async signSolanaTransaction(e,t,a,r,n){let s=new Aa(r),o=[];if(a)for(let e of a){let t=(await s.getAddressLookupTable(new Ia(e))).value;o.push(t),await za(1e3)}let i=ja.deserialize(Uint8Array.from(Buffer.from(t,"hex"))),c=Ta.decompile(i);c.instructions.push(La.setComputeUnitLimit({units:2e6})),c.instructions.push(La.setComputeUnitPrice({microLamports:1e3})),i=c.compileToV0Message(o),i.recentBlockhash=(await s.getLatestBlockhash()).blockhash,await za(3e3);let l=new Ca(i),u=this.wativeCore.account.showPrivateKey(e);const d=Na.fromSecretKey(new Uint8Array(Oa.decode(u))),p=new Ba(d);let h=await s.simulateTransaction(l);if(!h||!h.value||0===h.value.unitsConsumed||h.value.err)return{status:!1,output:h.value.err};let g=c.instructions.length,m=Math.trunc(1.2*h.value.unitsConsumed);if(c.instructions[g-2]=La.setComputeUnitLimit({units:m}),!n||"null"==n)try{n=await this.getPrioritizationFee(r)}catch(e){n=2e5}n<1e4&&(n=1e4),n>5e5&&(n=5e5),c.instructions[g-1]=La.setComputeUnitPrice({microLamports:n}),i=c.compileToV0Message(o),await za(1e3),i.recentBlockhash=(await s.getLatestBlockhash()).blockhash,l=new Ca(i),l.feePayer=p.publicKey,await za(3e3);let f=await this.wativeCore.account.signTransaction(e,l,r),w=new Ca(f.output.message,f.output.signatures).message.serialize();return w=Buffer.from(w).toString("hex"),{status:!0,output:{transactionHash:Oa.encode(f.output.signatures[0]),message:w,compute_units:h.value.unitsConsumed.toString()}}}async sendSignedSolanaTransaction(e,t,a,r){let n=[Oa.decode(t)],s=ja.deserialize(Uint8Array.from(Buffer.from(a,"hex"))),o=new Ca(s,n);return await this.wativeCore.account.sendSignedTransaction(e,o,r)}async getPrioritizationFee(e){let t=new Ia("JUP6LkbZbjS1jKKwapdHNy74zcZ3tLUZoi5QNyVTaV4");const a=new Aa(e,"confirmed");let r=await a.getSignaturesForAddress(t,{limit:5});await za(2e3);let n=[];for(let e=0;e<r.length;e++)n.push(r[e].signature);let s=await a.getParsedTransactions(n,{maxSupportedTransactionVersion:0}),o=0;for(let e=0;e<s.length;e++){let t=s[e].transaction.message.instructions;for(let e=0;e<t.length;e++)if("ComputeBudget111111111111111111111111111111"===t[e].programId.toBase58()){let a=t[e].data;try{let e=new Fa({keys:[],programId:new Ia("ComputeBudget111111111111111111111111111111"),data:Buffer.from(Oa.decode(a))}),{microLamports:t}=Ea.decodeSetComputeUnitPrice(e);o+=Number(t);continue}catch(e){}}}return Math.ceil(o/5)}}const za=e=>new Promise(t=>setTimeout(t,e));"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self&&self;var Ma={exports:{}},Da={name:"wative-core",version:"1.0.21",description:"An agile keystore management toolkit",main:"lib/index.umd.js",module:"lib/index.esm.js",types:"lib/index.d.ts",scripts:{test:"jest",compile:"tsc",build:"rollup --config"},repository:{type:"git",url:""},bugs:{url:"https://github.com"},homepage:"https://github.com",keywords:["keystore","wallet"],author:"",license:"ISC",files:["src/","lib/"],dependencies:{"@babel/plugin-transform-modules-commonjs":"7.24.1","@rollup/plugin-commonjs":"21.0.1","@solana/web3.js":"1.91.8","@types/bs58":"4.0.4","crypto-js":"4.2.0","ethereumjs-wallet":"1.0.2",jest:"27.5.1","micro-ed25519-hdkey":"0.1.2",rollup:"2.79.1","rollup-plugin-terser":"7.0.2","rollup-plugin-typescript2":"0.31.2",tslib:"2.6.2",typescript:"4.9.5",web3:"1.7.3","web3-core":"4.3.2","@coral-xyz/anchor":"0.30.1","@types/crypto-js":"4.2.2","nodejs-threadpool":"1.0.1",tweetnacl:"1.0.3","rpc-websockets":"7.10.0"}};!function(e,t,a,r,n,s,o,i,c,l,u,d){function p(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function h(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach(function(a){if("default"!==a){var r=Object.getOwnPropertyDescriptor(e,a);Object.defineProperty(t,a,r.get?r:{enumerable:!0,get:function(){return e[a]}})}}),t.default=e,Object.freeze(t)}var g=h(t),m=h(a),f=p(r),w=h(n),y=h(s),v=h(o),b=h(l),k=function(){return k=Object.assign||function(e){for(var t,a=1,r=arguments.length;a<r;a++)for(var n in t=arguments[a])Object.prototype.hasOwnProperty.call(t,n)&&(e[n]=t[n]);return e},k.apply(this,arguments)};function S(e,t,a,r){return new(a||(a=Promise))(function(n,s){function o(e){try{c(r.next(e))}catch(e){s(e)}}function i(e){try{c(r.throw(e))}catch(e){s(e)}}function c(e){var t;e.done?n(e.value):(t=e.value,t instanceof a?t:new a(function(e){e(t)})).then(o,i)}c((r=r.apply(e,t||[])).next())})}function x(e,t){var a,r,n,s={label:0,sent:function(){if(1&n[0])throw n[1];return n[1]},trys:[],ops:[]},o=Object.create(("function"==typeof Iterator?Iterator:Object).prototype);return o.next=i(0),o.throw=i(1),o.return=i(2),"function"==typeof Symbol&&(o[Symbol.iterator]=function(){return this}),o;function i(i){return function(c){return function(i){if(a)throw new TypeError("Generator is already executing.");for(;o&&(o=0,i[0]&&(s=0)),s;)try{if(a=1,r&&(n=2&i[0]?r.return:i[0]?r.throw||((n=r.return)&&n.call(r),0):r.next)&&!(n=n.call(r,i[1])).done)return n;switch(r=0,n&&(i=[2&i[0],n.value]),i[0]){case 0:case 1:n=i;break;case 4:return s.label++,{value:i[1],done:!1};case 5:s.label++,r=i[1],i=[0];continue;case 7:i=s.ops.pop(),s.trys.pop();continue;default:if(!((n=(n=s.trys).length>0&&n[n.length-1])||6!==i[0]&&2!==i[0])){s=0;continue}if(3===i[0]&&(!n||i[1]>n[0]&&i[1]<n[3])){s.label=i[1];break}if(6===i[0]&&s.label<n[1]){s.label=n[1],n=i;break}if(n&&s.label<n[2]){s.label=n[2],s.ops.push(i);break}n[2]&&s.ops.pop(),s.trys.pop();continue}i=t.call(e,s)}catch(e){i=[6,e],r=0}finally{a=n=0}if(5&i[0])throw i[1];return{value:i[0]?i[1]:void 0,done:!0}}([i,c])}}}"function"==typeof SuppressedError&&SuppressedError;var _=function(e,t){return S(void 0,void 0,void 0,function(){var a,r,n;return x(this,function(s){switch(s.label){case 0:return s.trys.push([0,2,,3]),[4,e.apply(void 0,t)];case 1:return r=s.sent(),a={status:!0,output:r},[3,3];case 2:return n=s.sent(),a={status:!1,output:n.toString()},[3,3];case 3:return[2,a]}})})},$=function(){function e(e){this.web3=new f.default(e)}return e.prototype.getEvmGasPrice=function(){return S(this,void 0,void 0,function(){return x(this,function(e){switch(e.label){case 0:return[4,_(this.web3.eth.getGasPrice,[])];case 1:return[2,e.sent()]}})})},e.prototype.getEvmGasLimit=function(e,t){return S(this,void 0,void 0,function(){return x(this,function(a){switch(a.label){case 0:return[4,_(this.web3.eth.estimateGas,[e,t])];case 1:return[2,a.sent()]}})})},e}(),P=function(e){return e=e.trim(),g.existsSync(e)},A=function(e,t){var a=t.length;if(0===a)return!0;for(var r=0;r<a;r++){var n=m.join(e,"accounts/".concat(t[r],".json"));if(!P(n))return!1}return!0},I=function(e){return(e=(e=(e=e.trim()).toLocaleLowerCase()).replace(/\s+/g,"-").trim()).replace(/\-+/g,"-").trim()},C=function(e,t){var a=[],r=m.join(e,"network.json");if(!P(r))throw new Error("network.json not found");for(var n=function(e){for(var t=[],a=0;a<e.length;a++)t.push(I(e[a]));return t}(j(r).accounts),s=0;s<t.length;s++)n.includes(t[s])&&a.push(t[s]);return a},j=function(e){var t=g.readFileSync(e).toString();return JSON.parse(t)},O=function(e,t){var a=JSON.stringify(e);g.writeFileSync(t,a)},N=function(e,t){return b.AES.encrypt(e,t).toString()},T=function(e,t){return b.AES.decrypt(e,t).toString(b.enc.Utf8)},E=["abandon","ability","able","about","above","absent","absorb","abstract","absurd","abuse","access","accident","account","accuse","achieve","acid","acoustic","acquire","across","act","action","actor","actress","actual","adapt","add","addict","address","adjust","admit","adult","advance","advice","aerobic","affair","afford","afraid","again","age","agent","agree","ahead","aim","air","airport","aisle","alarm","album","alcohol","alert","alien","all","alley","allow","almost","alone","alpha","already","also","alter","always","amateur","amazing","among","amount","amused","analyst","anchor","ancient","anger","angle","angry","animal","ankle","announce","annual","another","answer","antenna","antique","anxiety","any","apart","apology","appear","apple","approve","april","arch","arctic","area","arena","argue","arm","armed","armor","army","around","arrange","arrest","arrive","arrow","art","artefact","artist","artwork","ask","aspect","assault","asset","assist","assume","asthma","athlete","atom","attack","attend","attitude","attract","auction","audit","august","aunt","author","auto","autumn","average","avocado","avoid","awake","aware","away","awesome","awful","awkward","axis","baby","bachelor","bacon","badge","bag","balance","balcony","ball","bamboo","banana","banner","bar","barely","bargain","barrel","base","basic","basket","battle","beach","bean","beauty","because","become","beef","before","begin","behave","behind","believe","below","belt","bench","benefit","best","betray","better","between","beyond","bicycle","bid","bike","bind","biology","bird","birth","bitter","black","blade","blame","blanket","blast","bleak","bless","blind","blood","blossom","blouse","blue","blur","blush","board","boat","body","boil","bomb","bone","bonus","book","boost","border","boring","borrow","boss","bottom","bounce","box","boy","bracket","brain","brand","brass","brave","bread","breeze","brick","bridge","brief","bright","bring","brisk","broccoli","broken","bronze","broom","brother","brown","brush","bubble","buddy","budget","buffalo","build","bulb","bulk","bullet","bundle","bunker","burden","burger","burst","bus","business","busy","butter","buyer","buzz","cabbage","cabin","cable","cactus","cage","cake","call","calm","camera","camp","can","canal","cancel","candy","cannon","canoe","canvas","canyon","capable","capital","captain","car","carbon","card","cargo","carpet","carry","cart","case","cash","casino","castle","casual","cat","catalog","catch","category","cattle","caught","cause","caution","cave","ceiling","celery","cement","census","century","cereal","certain","chair","chalk","champion","change","chaos","chapter","charge","chase","chat","cheap","check","cheese","chef","cherry","chest","chicken","chief","child","chimney","choice","choose","chronic","chuckle","chunk","churn","cigar","cinnamon","circle","citizen","city","civil","claim","clap","clarify","claw","clay","clean","clerk","clever","click","client","cliff","climb","clinic","clip","clock","clog","close","cloth","cloud","clown","club","clump","cluster","clutch","coach","coast","coconut","code","coffee","coil","coin","collect","color","column","combine","come","comfort","comic","common","company","concert","conduct","confirm","congress","connect","consider","control","convince","cook","cool","copper","copy","coral","core","corn","correct","cost","cotton","couch","country","couple","course","cousin","cover","coyote","crack","cradle","craft","cram","crane","crash","crater","crawl","crazy","cream","credit","creek","crew","cricket","crime","crisp","critic","crop","cross","crouch","crowd","crucial","cruel","cruise","crumble","crunch","crush","cry","crystal","cube","culture","cup","cupboard","curious","current","curtain","curve","cushion","custom","cute","cycle","dad","damage","damp","dance","danger","daring","dash","daughter","dawn","day","deal","debate","debris","decade","december","decide","decline","decorate","decrease","deer","defense","define","defy","degree","delay","deliver","demand","demise","denial","dentist","deny","depart","depend","deposit","depth","deputy","derive","describe","desert","design","desk","despair","destroy","detail","detect","develop","device","devote","diagram","dial","diamond","diary","dice","diesel","diet","differ","digital","dignity","dilemma","dinner","dinosaur","direct","dirt","disagree","discover","disease","dish","dismiss","disorder","display","distance","divert","divide","divorce","dizzy","doctor","document","dog","doll","dolphin","domain","donate","donkey","donor","door","dose","double","dove","draft","dragon","drama","drastic","draw","dream","dress","drift","drill","drink","drip","drive","drop","drum","dry","duck","dumb","dune","during","dust","dutch","duty","dwarf","dynamic","eager","eagle","early","earn","earth","easily","east","easy","echo","ecology","economy","edge","edit","educate","effort","egg","eight","either","elbow","elder","electric","elegant","element","elephant","elevator","elite","else","embark","embody","embrace","emerge","emotion","employ","empower","empty","enable","enact","end","endless","endorse","enemy","energy","enforce","engage","engine","enhance","enjoy","enlist","enough","enrich","enroll","ensure","enter","entire","entry","envelope","episode","equal","equip","era","erase","erode","erosion","error","erupt","escape","essay","essence","estate","eternal","ethics","evidence","evil","evoke","evolve","exact","example","excess","exchange","excite","exclude","excuse","execute","exercise","exhaust","exhibit","exile","exist","exit","exotic","expand","expect","expire","explain","expose","express","extend","extra","eye","eyebrow","fabric","face","faculty","fade","faint","faith","fall","false","fame","family","famous","fan","fancy","fantasy","farm","fashion","fat","fatal","father","fatigue","fault","favorite","feature","february","federal","fee","feed","feel","female","fence","festival","fetch","fever","few","fiber","fiction","field","figure","file","film","filter","final","find","fine","finger","finish","fire","firm","first","fiscal","fish","fit","fitness","fix","flag","flame","flash","flat","flavor","flee","flight","flip","float","flock","floor","flower","fluid","flush","fly","foam","focus","fog","foil","fold","follow","food","foot","force","forest","forget","fork","fortune","forum","forward","fossil","foster","found","fox","fragile","frame","frequent","fresh","friend","fringe","frog","front","frost","frown","frozen","fruit","fuel","fun","funny","furnace","fury","future","gadget","gain","galaxy","gallery","game","gap","garage","garbage","garden","garlic","garment","gas","gasp","gate","gather","gauge","gaze","general","genius","genre","gentle","genuine","gesture","ghost","giant","gift","giggle","ginger","giraffe","girl","give","glad","glance","glare","glass","glide","glimpse","globe","gloom","glory","glove","glow","glue","goat","goddess","gold","good","goose","gorilla","gospel","gossip","govern","gown","grab","grace","grain","grant","grape","grass","gravity","great","green","grid","grief","grit","grocery","group","grow","grunt","guard","guess","guide","guilt","guitar","gun","gym","habit","hair","half","hammer","hamster","hand","happy","harbor","hard","harsh","harvest","hat","have","hawk","hazard","head","health","heart","heavy","hedgehog","height","hello","helmet","help","hen","hero","hidden","high","hill","hint","hip","hire","history","hobby","hockey","hold","hole","holiday","hollow","home","honey","hood","hope","horn","horror","horse","hospital","host","hotel","hour","hover","hub","huge","human","humble","humor","hundred","hungry","hunt","hurdle","hurry","hurt","husband","hybrid","ice","icon","idea","identify","idle","ignore","ill","illegal","illness","image","imitate","immense","immune","impact","impose","improve","impulse","inch","include","income","increase","index","indicate","indoor","industry","infant","inflict","inform","inhale","inherit","initial","inject","injury","inmate","inner","innocent","input","inquiry","insane","insect","inside","inspire","install","intact","interest","into","invest","invite","involve","iron","island","isolate","issue","item","ivory","jacket","jaguar","jar","jazz","jealous","jeans","jelly","jewel","job","join","joke","journey","joy","judge","juice","jump","jungle","junior","junk","just","kangaroo","keen","keep","ketchup","key","kick","kid","kidney","kind","kingdom","kiss","kit","kitchen","kite","kitten","kiwi","knee","knife","knock","know","lab","label","labor","ladder","lady","lake","lamp","language","laptop","large","later","latin","laugh","laundry","lava","law","lawn","lawsuit","layer","lazy","leader","leaf","learn","leave","lecture","left","leg","legal","legend","leisure","lemon","lend","length","lens","leopard","lesson","letter","level","liar","liberty","library","license","life","lift","light","like","limb","limit","link","lion","liquid","list","little","live","lizard","load","loan","lobster","local","lock","logic","lonely","long","loop","lottery","loud","lounge","love","loyal","lucky","luggage","lumber","lunar","lunch","luxury","lyrics","machine","mad","magic","magnet","maid","mail","main","major","make","mammal","man","manage","mandate","mango","mansion","manual","maple","marble","march","margin","marine","market","marriage","mask","mass","master","match","material","math","matrix","matter","maximum","maze","meadow","mean","measure","meat","mechanic","medal","media","melody","melt","member","memory","mention","menu","mercy","merge","merit","merry","mesh","message","metal","method","middle","midnight","milk","million","mimic","mind","minimum","minor","minute","miracle","mirror","misery","miss","mistake","mix","mixed","mixture","mobile","model","modify","mom","moment","monitor","monkey","monster","month","moon","moral","more","morning","mosquito","mother","motion","motor","mountain","mouse","move","movie","much","muffin","mule","multiply","muscle","museum","mushroom","music","must","mutual","myself","mystery","myth","naive","name","napkin","narrow","nasty","nation","nature","near","neck","need","negative","neglect","neither","nephew","nerve","nest","net","network","neutral","never","news","next","nice","night","noble","noise","nominee","noodle","normal","north","nose","notable","note","nothing","notice","novel","now","nuclear","number","nurse","nut","oak","obey","object","oblige","obscure","observe","obtain","obvious","occur","ocean","october","odor","off","offer","office","often","oil","okay","old","olive","olympic","omit","once","one","onion","online","only","open","opera","opinion","oppose","option","orange","orbit","orchard","order","ordinary","organ","orient","original","orphan","ostrich","other","outdoor","outer","output","outside","oval","oven","over","own","owner","oxygen","oyster","ozone","pact","paddle","page","pair","palace","palm","panda","panel","panic","panther","paper","parade","parent","park","parrot","party","pass","patch","path","patient","patrol","pattern","pause","pave","payment","peace","peanut","pear","peasant","pelican","pen","penalty","pencil","people","pepper","perfect","permit","person","pet","phone","photo","phrase","physical","piano","picnic","picture","piece","pig","pigeon","pill","pilot","pink","pioneer","pipe","pistol","pitch","pizza","place","planet","plastic","plate","play","please","pledge","pluck","plug","plunge","poem","poet","point","polar","pole","police","pond","pony","pool","popular","portion","position","possible","post","potato","pottery","poverty","powder","power","practice","praise","predict","prefer","prepare","present","pretty","prevent","price","pride","primary","print","priority","prison","private","prize","problem","process","produce","profit","program","project","promote","proof","property","prosper","protect","proud","provide","public","pudding","pull","pulp","pulse","pumpkin","punch","pupil","puppy","purchase","purity","purpose","purse","push","put","puzzle","pyramid","quality","quantum","quarter","question","quick","quit","quiz","quote","rabbit","raccoon","race","rack","radar","radio","rail","rain","raise","rally","ramp","ranch","random","range","rapid","rare","rate","rather","raven","raw","razor","ready","real","reason","rebel","rebuild","recall","receive","recipe","record","recycle","reduce","reflect","reform","refuse","region","regret","regular","reject","relax","release","relief","rely","remain","remember","remind","remove","render","renew","rent","reopen","repair","repeat","replace","report","require","rescue","resemble","resist","resource","response","result","retire","retreat","return","reunion","reveal","review","reward","rhythm","rib","ribbon","rice","rich","ride","ridge","rifle","right","rigid","ring","riot","ripple","risk","ritual","rival","river","road","roast","robot","robust","rocket","romance","roof","rookie","room","rose","rotate","rough","round","route","royal","rubber","rude","rug","rule","run","runway","rural","sad","saddle","sadness","safe","sail","salad","salmon","salon","salt","salute","same","sample","sand","satisfy","satoshi","sauce","sausage","save","say","scale","scan","scare","scatter","scene","scheme","school","science","scissors","scorpion","scout","scrap","screen","script","scrub","sea","search","season","seat","second","secret","section","security","seed","seek","segment","select","sell","seminar","senior","sense","sentence","series","service","session","settle","setup","seven","shadow","shaft","shallow","share","shed","shell","sheriff","shield","shift","shine","ship","shiver","shock","shoe","shoot","shop","short","shoulder","shove","shrimp","shrug","shuffle","shy","sibling","sick","side","siege","sight","sign","silent","silk","silly","silver","similar","simple","since","sing","siren","sister","situate","six","size","skate","sketch","ski","skill","skin","skirt","skull","slab","slam","sleep","slender","slice","slide","slight","slim","slogan","slot","slow","slush","small","smart","smile","smoke","smooth","snack","snake","snap","sniff","snow","soap","soccer","social","sock","soda","soft","solar","soldier","solid","solution","solve","someone","song","soon","sorry","sort","soul","sound","soup","source","south","space","spare","spatial","spawn","speak","special","speed","spell","spend","sphere","spice","spider","spike","spin","spirit","split","spoil","sponsor","spoon","sport","spot","spray","spread","spring","spy","square","squeeze","squirrel","stable","stadium","staff","stage","stairs","stamp","stand","start","state","stay","steak","steel","stem","step","stereo","stick","still","sting","stock","stomach","stone","stool","story","stove","strategy","street","strike","strong","struggle","student","stuff","stumble","style","subject","submit","subway","success","such","sudden","suffer","sugar","suggest","suit","summer","sun","sunny","sunset","super","supply","supreme","sure","surface","surge","surprise","surround","survey","suspect","sustain","swallow","swamp","swap","swarm","swear","sweet","swift","swim","swing","switch","sword","symbol","symptom","syrup","system","table","tackle","tag","tail","talent","talk","tank","tape","target","task","taste","tattoo","taxi","teach","team","tell","ten","tenant","tennis","tent","term","test","text","thank","that","theme","then","theory","there","they","thing","this","thought","three","thrive","throw","thumb","thunder","ticket","tide","tiger","tilt","timber","time","tiny","tip","tired","tissue","title","toast","tobacco","today","toddler","toe","together","toilet","token","tomato","tomorrow","tone","tongue","tonight","tool","tooth","top","topic","topple","torch","tornado","tortoise","toss","total","tourist","toward","tower","town","toy","track","trade","traffic","tragic","train","transfer","trap","trash","travel","tray","treat","tree","trend","trial","tribe","trick","trigger","trim","trip","trophy","trouble","truck","true","truly","trumpet","trust","truth","try","tube","tuition","tumble","tuna","tunnel","turkey","turn","turtle","twelve","twenty","twice","twin","twist","two","type","typical","ugly","umbrella","unable","unaware","uncle","uncover","under","undo","unfair","unfold","unhappy","uniform","unique","unit","universe","unknown","unlock","until","unusual","unveil","update","upgrade","uphold","upon","upper","upset","urban","urge","usage","use","used","useful","useless","usual","utility","vacant","vacuum","vague","valid","valley","valve","van","vanish","vapor","various","vast","vault","vehicle","velvet","vendor","venture","venue","verb","verify","version","very","vessel","veteran","viable","vibrant","vicious","victory","video","view","village","vintage","violin","virtual","virus","visa","visit","visual","vital","vivid","vocal","voice","void","volcano","volume","vote","voyage","wage","wagon","wait","walk","wall","walnut","want","warfare","warm","warrior","wash","wasp","waste","water","wave","way","wealth","weapon","wear","weasel","weather","web","wedding","weekend","weird","welcome","west","wet","whale","what","wheat","wheel","when","where","whip","whisper","wide","width","wife","wild","will","win","window","wine","wing","wink","winner","winter","wire","wisdom","wise","wish","witness","wolf","woman","wonder","wood","wool","word","work","world","worry","worth","wrap","wreck","wrestle","wrist","write","wrong","yard","year","yellow","you","young","youth","zebra","zero","zone","zoo"],F=new f.default(f.default.givenProvider),L=function(){function e(e,t,a,r){if(this.account_passwords={},this.account_ciphertexts={},this.disable_address=!1,this.account_signatures="",this.setting_path=e,this.account_labels=t,0!==t.length){if(a){if(t.length!==a.length)throw new Error("account_labels should have same length for account_passwords");for(var n=0;n<t.length;n++){if(!this.checkPassword(t[n],a[n].trim()))throw new Error("account_passwords is not correct");this.account_passwords[t[n]]=a[n].trim()}}r&&(this.disable_address=r),this.reload()}}return e.prototype.isLogin=function(e){return e in this.account_passwords},e.prototype.reloadAccount=function(){this.reload()},e.prototype.getAccountLabel=function(e){var t=null;for(var a in this.account_ciphertexts)a.toLocaleLowerCase().includes(e.toLocaleLowerCase())&&(t=a);return null===t?null:{account_address:t,account_label:this.account_ciphertexts[t].account_label}},e.prototype.login=function(e,t){return this.checkPassword(e,t)?(this.account_passwords[e]=t,this.account_labels.push(e),this.reload(),{status:!0,output:"Login success"}):{status:!1,output:"Password is not correct"}},e.prototype.getAccounts=function(e){var t=this.getAccountSignature();t!==this.account_signatures&&(this.account_signatures=t,this.reload());for(var a=Object.keys(this.account_ciphertexts),r=[],n=0;n<a.length;n++)this.getAccountChainType(a[n])===e&&r.push(a[n]);return r},e.prototype.checkAccountLabelIsExist=function(e){return A(this.setting_path,[e])},e.prototype.checkAccountIsExist=function(e){return(e=this.getAccountChecksumAddress(e))in this.account_ciphertexts||(this.reload(),e in this.account_ciphertexts)},e.prototype.checkPassword=function(e,t){var a=m.join(this.setting_path,"accounts/".concat(e,".json"));if(!P(a))return!1;var r,n=j(a);r="PK"===n.account_type?k({salt:t},n.data[0].ciphertexts):{slat:t,data:n.pp_ciphertexts};var s=b.SHA256(JSON.stringify(r)).toString();return n.signature===s},e.prototype.showPrivateKey=function(e){if(!this.checkAccountIsExist(e))throw new Error("Account is not exist");e=this.getAccountChecksumAddress(e);var t=this.account_ciphertexts[e],a=this.account_passwords[t.account_label];return T(t.data,a)},e.prototype.getAccountChainType=function(e){return e.startsWith("0x")&&42===e.length?"evm":/^[A-HJ-NP-Za-km-z1-9]*$/.test(e)?"solana":"unknown"},e.prototype.generatePKAccount=function(e,t,a,r,n){if(n&&this.checkAccountLabelIsExist(e))throw new Error("Account labels already exist");if(!n&&!this.account_passwords[e])throw new Error("Password is not correct");n||(a=this.account_passwords[e]);var s,o=N(t,a);try{s=this.getAccountAddressByPrivateKey(t,r)}catch(e){return{status:!1,output:e.message}}var i={address:s,data:o},c=k({salt:a},i),l={signature:b.SHA256(JSON.stringify(c)).toString(),account_type:"PK",tag:"",ciphertexts:i};return n||(this.account_passwords[e]=a,this.account_labels.push(e)),{status:!0,output:l}},e.prototype.generatePPAccount=function(e,t,a){if(this.checkAccountLabelIsExist(e))return{status:!1,output:"Account labels already exist"};var r=N(t,a),n={slat:a,data:r},s=b.SHA256(JSON.stringify(n)).toString(),o=this.getSubAccount("evm",t,0);if(!1===o.status)return{status:!1,output:o.output};var i=this.getSubAccount("solana",t,0);if(!1===i.status)return{status:!1,output:i.output};var c={signature:s,account_type:"PP",pp_ciphertexts:r,tag:"",data:[{ciphertexts:{evm:{address:o.output.address,data:N(o.output.pk,a)},solana:{address:i.output.address,data:N(i.output.pk,a)}}}]};return this.account_passwords[e]=a,this.account_labels.push(e),{status:!0,output:c}},e.prototype.generateSubAccount=function(e,t){if(!this.checkAccountLabelIsExist(e))return{status:!1,output:"Account labels not exist"};var a=m.join(this.setting_path,"accounts/".concat(e,".json")),r=j(a).pp_ciphertexts,n=T(r,this.account_passwords[e]),s=this.getSubAccount("evm",n,t);if(!1===s.status)return{status:!1,output:s.output};var o=this.getSubAccount("solana",n,t);return!1===o.status?{status:!1,output:o.output}:{status:!0,output:{evm:{address:s.output.address,data:N(s.output.pk,this.account_passwords[e])},solana:{address:o.output.address,data:N(o.output.pk,this.account_passwords[e])}}}},e.prototype.resetPassword=function(e,t){if(!this.checkAccountLabelIsExist(e))return{status:!1,output:"Account labels not exist"};if(!this.checkPassword(e,this.account_passwords[e]))return{status:!1,output:"account passwords is not correct"};var a=m.join(this.setting_path,"accounts/".concat(e,".json")),r=j(a);if("PK"===r.account_type){for(var n=r.data,s=0;s<n.length;s++){var o=n[s].ciphertexts.data,i=T(o,this.account_passwords[e]);n[s].ciphertexts.data=N(i,t)}var c=k({salt:t},r.data[0].ciphertexts);return r.signature=b.SHA256(JSON.stringify(c)).toString(),O(r,a),delete this.account_passwords[e],{status:!0,output:"Password reset successfully"}}var l=T(r.pp_ciphertexts,this.account_passwords[e]);r.pp_ciphertexts=N(l,t);var u={slat:t,data:r.pp_ciphertexts};r.signature=b.SHA256(JSON.stringify(u)).toString();var d=r.data;for(s=0;s<d.length;s++){var p=T(d[s].ciphertexts.evm.data,this.account_passwords[e]);d[s].ciphertexts.evm.data=N(p,t);var h=T(d[s].ciphertexts.solana.data,this.account_passwords[e]);d[s].ciphertexts.solana.data=N(h,t)}return O(r,a),delete this.account_passwords[e],{status:!0,output:"Password reset successfully"}},e.prototype.signTransaction=function(e,t,a){return e=this.getAccountChecksumAddress(e),this.checkAccountIsExist(e)?"unknown"===this.getAccountChainType(e)?{status:!1,output:"Chain type unknown"}:"evm"===this.getAccountChainType(e)?this.signEvmTransaction(t,a):this.signSolanaTransaction(e,a,t):{status:!1,output:"Account is not exist"}},e.prototype.sendSignedTransaction=function(e,t,a){return e=this.getAccountChecksumAddress(e),this.checkAccountIsExist(e)?"unknown"===this.getAccountChainType(e)?{status:!1,output:"Chain type unknown"}:"evm"===this.getAccountChainType(e)?this.sendEvmTransaction(t,a):this.sendSolanaTransaction(t,a):{status:!1,output:"Account is not exist"}},e.prototype.signMessage=function(e,t){return e=this.getAccountChecksumAddress(e),this.checkAccountIsExist(e)?"unknown"===this.getAccountChainType(e)?{status:!1,output:"Chain type unknown"}:"evm"===this.getAccountChainType(e)?{status:!0,output:this.signEvmMessage(t,e)}:{status:!0,output:this.signSolanaMessage(t,e)}:{status:!1,output:"Account is not exist"}},e.prototype.simulateTransaction=function(e,t,a){return S(this,void 0,void 0,function(){var r,n,s;return x(this,function(o){switch(o.label){case 0:return r=new i.Connection(t),n=this.showPrivateKey(e),s=i.Keypair.fromSecretKey(y.decode(n)),[4,_(r.simulateTransaction.bind(r),[a,[s]])];case 1:return[2,o.sent()]}})})},e.prototype.signEvmTransaction=function(e,t){return S(this,void 0,void 0,function(){var a,r,n,s;return x(this,function(o){switch(o.label){case 0:return this.account_passwords?(a=e.from,e.gas?[3,2]:[4,new $(t).getEvmGasLimit(e,t)]):[2,{status:!1,output:"Please set password first"}];case 1:if(!(r=o.sent()).status)return[2,r];e.gas=r.output,o.label=2;case 2:return e.gasPrice?[3,4]:[4,new $(t).getEvmGasPrice()];case 3:if(!(r=o.sent()).status)return[2,r];e.gasPrice=r.output,o.label=4;case 4:return n=this.showPrivateKey(a),s=new f.default(t),[4,_(s.eth.accounts.signTransaction.bind(s.eth.accounts),[e,n])];case 5:return[2,o.sent()]}})})},e.prototype.sendEvmTransaction=function(e,t){return S(this,void 0,void 0,function(){var a;return x(this,function(r){switch(r.label){case 0:return a=new f.default(t),[4,_(a.eth.sendSignedTransaction.bind(a.eth),[e])];case 1:return[2,r.sent()]}})})},e.prototype.signSolanaTransaction=function(e,t,a){return S(this,void 0,void 0,function(){var r,n,s,o,l;return x(this,function(u){switch(u.label){case 0:return r=this.showPrivateKey(e),n=i.Keypair.fromSecretKey(y.decode(r)),s=new c.Wallet(n),"recentBlockhash"in a&&a.recentBlockhash?[3,2]:(o=new i.Connection(t),[4,_(o.getLatestBlockhash.bind(o),[])]);case 1:if(!(l=u.sent()).status)return[2,{status:!1,output:"Failed to get latest blockhash"}];a.recentBlockhash=l.output.blockhash,u.label=2;case 2:return a.feePayer=s.publicKey,[4,_(s.signTransaction.bind(s),[a])];case 3:return[2,u.sent()]}})})},e.prototype.sendSolanaTransaction=function(e,t){return S(this,void 0,void 0,function(){var a;return x(this,function(r){switch(r.label){case 0:return a=new i.Connection(t),[4,_(a.sendRawTransaction.bind(a),[e.serialize()])];case 1:return[2,r.sent()]}})})},e.prototype.signEvmMessage=function(e,t){var a=this.showPrivateKey(t);return F.eth.accounts.sign(e,a).signature},e.prototype.signSolanaMessage=function(e,t){var a=this.showPrivateKey(t),r=w.sign.detached(new Uint8Array(e.match(/.{1,2}/g).map(function(e){return parseInt(e,16)})),y.decode(a));return y.encode(r)},e.prototype.checkIsDisableAddress=function(e,t){if(!e||!this.disable_address)return!1;for(var a=e.length,r=0;r<a;r++){var n=e[r].from,s=e[r].to;if(t>=n&&t<=s)return!0}return!1},e.prototype.reload=function(){if(this.account_labels=C(this.setting_path,this.account_labels),!A(this.setting_path,this.account_labels))throw new Error("Account labels not exist");for(var e={},t=this.account_labels.length,a=0;a<t;a++){var r=m.join(this.setting_path,"accounts/".concat(this.account_labels[a],".json"));if(g.existsSync(r)){var n=JSON.parse(g.readFileSync(r,"utf8"));if("PK"!==n.account_type){var s=n.data.length,o=n.disabled_slots;for(l=0;l<s;l++)this.checkIsDisableAddress(o,l)||(e[n.data[l].ciphertexts.evm.address]={account_label:this.account_labels[a],data:n.data[l].ciphertexts.evm.data},e[n.data[l].ciphertexts.solana.address]={account_label:this.account_labels[a],data:n.data[l].ciphertexts.solana.data})}else{var i=n.data;if(!i)continue;for(var c=i.length,l=0;l<c;l++)e[i[l].ciphertexts.address]={account_label:this.account_labels[a],data:i[l].ciphertexts.data}}}}this.account_ciphertexts=e},e.prototype.getAccountChecksumAddress=function(e){return"evm"===this.getAccountChainType(e)&&(e=F.utils.toChecksumAddress(e)),e},e.prototype.getAccountAddressByPrivateKey=function(e,t){return"evm"===this.getNetworkTypeByChainId(t)?F.eth.accounts.privateKeyToAccount(e).address:i.Keypair.fromSecretKey(y.decode(e)).publicKey.toBase58()},e.prototype.getNetworkTypeByChainId=function(e){return"901"===e||"902"===e||"903"===e?"solana":"evm"},e.prototype.getSubAccount=function(e,t,a){if(!function(e){var t=e.split(/\s+/g),a=t.length;if(12!==a&&24!==a)return!1;for(var r=0;r<a;r++)if(!E.includes(t[r]))return!1;return!0}(t))return{status:!1,output:"Please set correct mnemonic"};if("solana"===e){var r=v.mnemonicToSeedSync(t),n=d.HDKey.fromMasterSeed(r),s=i.Keypair.fromSeed(n.derive("m/44'/501'/".concat(a,"'/0'")).privateKey);return{status:!0,output:{address:s.publicKey.toBase58(),pk:y.encode(s.secretKey)}}}if("evm"===e){r=v.mnemonicToSeedSync(t);var o=(n=u.hdkey.fromMasterSeed(r)).derivePath("m/44'/60'/0'/0").deriveChild(a).getWallet();return{status:!0,output:{address:F.utils.toChecksumAddress(o.getAddressString()),pk:o.getPrivateKeyString()}}}return{status:!1,output:"Unknown chain type"}},e.prototype.getAccountSignature=function(){for(var e=this.account_labels.length,t=[],a=0;a<e;a++){var r=m.join(this.setting_path,"accounts/".concat(this.account_labels[a],".json")),n=g.readFileSync(r,"utf8");t.push(n)}return b.MD5(JSON.stringify(t)).toString()},e}(),B=Da,R=function(){function e(e,t,a,r){this.account=new L(e,t,a,r)}return e.version=B.version,e}();e.WativeCore=R,Object.defineProperty(e,"__esModule",{value:!0})}(Ma.exports,t,n,i,j,O,N,c,T,E,F,L);class Ka{constructor(e,t){this.runningServices=new Map,this.configManager=new _a(e,t),this.pidDir=r.join(this.configManager.getKeystorePath(),"ssh","pids"),this.ensurePidDir(),this.setupLogger()}ensurePidDir(){e.existsSync(this.pidDir)||e.mkdirSync(this.pidDir,{recursive:!0})}async isPortInUse(e,t="127.0.0.1"){return new Promise(a=>{const r=B.createServer();r.listen(e,t,()=>{r.once("close",()=>{a(!1)}),r.close()}),r.on("error",e=>{"EADDRINUSE"===e.code?a(!0):a(!1)})})}getPidFilePath(e){return r.join(this.pidDir,`${e}.pid`)}writePidFile(t,a){const r=this.getPidFilePath(t);e.writeFileSync(r,a.toString())}readPidFile(t){const a=this.getPidFilePath(t);if(!e.existsSync(a))return null;try{const t=e.readFileSync(a,"utf8").trim();return parseInt(t,10)}catch(e){return null}}removePidFile(t){const a=this.getPidFilePath(t);e.existsSync(a)&&e.unlinkSync(a)}isProcessRunning(e){try{return process.kill(e,0),!0}catch(e){return!1}}async startService(e,t){if(this.runningServices.has(e))throw new Error(`Service '${e}' is already running.`);const a=this.configManager.loadServiceConfig(e);if(await this.isPortInUse(a.ssh.port,a.ssh.listen)){const t=`Port ${a.ssh.port} on ${a.ssh.listen} is already in use. Cannot start SSH service '${e}'.`;throw this.logger.error(t),console.error(`Error: ${t}`),new Error(t)}this.logger.info(`Port ${a.ssh.port} on ${a.ssh.listen} is available for service '${e}'`);const r=t||await this.promptForPasswords(a.keystore.allowed_keystores),n=await this.configManager.validateKeystorePasswords(a.keystore.allowed_keystores,r),s=Object.entries(n).filter(([e,t])=>!t).map(([e,t])=>e);if(s.length>0)throw new Error(`Invalid passwords for keystores: ${s.join(", ")}`);const o=this.createServerInstance(a,r);o.listen(a.ssh.listen,a.ssh.port),this.writePidFile(e,process.pid),this.logger.info(`SSH service '${e}' started on ${a.ssh.listen}:${a.ssh.port}`),console.log(`SSH service '${e}' is now running in the background on ${a.ssh.listen}:${a.ssh.port}`);const i={config:a,passwords:r,server:o};this.runningServices.set(e,i),this.setupServiceLogger(e)}async stopService(t){const a=this.runningServices.get(t),n=this.readPidFile(t),s=r.join(this.pidDir,`${t}-daemon.pid`),o=r.join(this.pidDir,`${t}-watcher.pid`);let i=null,c=null;if(e.existsSync(s)){const t=e.readFileSync(s,"utf8").trim();t&&(i=parseInt(t))}if(e.existsSync(o)){const t=e.readFileSync(o,"utf8").trim();t&&(c=parseInt(t))}if(a)a.server&&a.server.close&&a.server.close(),this.runningServices.delete(t);else if(c&&this.isProcessRunning(c))try{process.kill(c,"SIGTERM"),setTimeout(()=>{this.isProcessRunning(c)&&process.kill(c,"SIGKILL");try{e.existsSync(o)&&e.unlinkSync(o),e.existsSync(s)&&e.unlinkSync(s)}catch(e){}},5e3)}catch(t){if(i&&this.isProcessRunning(i))try{process.kill(i,"SIGTERM"),setTimeout(()=>{this.isProcessRunning(i)&&process.kill(i,"SIGKILL")},5e3)}catch(e){}try{e.existsSync(o)&&e.unlinkSync(o),e.existsSync(s)&&e.unlinkSync(s)}catch(e){}}else if(i&&this.isProcessRunning(i))try{process.kill(i,"SIGTERM"),setTimeout(()=>{this.isProcessRunning(i)&&process.kill(i,"SIGKILL")},5e3),e.existsSync(s)&&e.unlinkSync(s)}catch(e){}else{if(!n||!this.isProcessRunning(n))throw new Error(`Service '${t}' is not running.`);try{process.kill(n,"SIGTERM"),setTimeout(()=>{this.isProcessRunning(n)&&process.kill(n,"SIGKILL")},5e3)}catch(e){}}this.removePidFile(t),this.logger.info(`SSH service '${t}' stopped.`)}async restartService(e,t){this.runningServices.has(e)&&await this.stopService(e),await this.startService(e,t)}getRunningServices(){return Array.from(this.runningServices.keys())}getServiceConfig(e){return this.configManager.loadServiceConfig(e)}getServiceStatus(t){if(this.runningServices.has(t))return"running";try{this.configManager.loadServiceConfig(t);const a=r.join(this.pidDir,`${t}-daemon.pid`);if(e.existsSync(a)){const t=e.readFileSync(a,"utf8").trim();if(t){const r=parseInt(t);if(this.isProcessRunning(r))return"running";e.unlinkSync(a)}}const n=this.readPidFile(t);return n&&this.isProcessRunning(n)?"running":(n&&this.removePidFile(t),"stopped")}catch(e){return"not_found"}}async stopAllServices(){const e=Array.from(this.runningServices.keys());for(const t of e)await this.stopService(t)}async createService(e,t,a,r,n){return this.configManager.createServiceConfig(e,t,a,r,n)}async removeService(e){this.runningServices.has(e)&&await this.stopService(e),this.configManager.removeServiceConfig(e),this.logger.info(`Service '${e}' removed.`)}listServices(){return this.configManager.listServiceConfigs().map(e=>{const t=this.getServiceStatus(e);let a,r;try{const t=this.configManager.loadServiceConfig(e);a=t.ssh.port,r=t.description}catch(e){}return{name:e,status:t,port:a,description:r}})}updateServiceKeystores(e,t){this.configManager.updateServiceConfig(e,{keystore:{path:this.configManager.loadServiceConfig(e).keystore.path,allowed_keystores:t}})}async promptForPasswords(e){const t={};for(const a of e){let e,r=!1,n=0;const s=3;for(;!r&&n<s;){e=await sa(`Enter password for keystore [${a}]`);try{const o=this.configManager.getKeystorePath();if(r=new Ma.exports.WativeCore(o,[a]).account.checkPassword(a,e),r){t[a]=e;break}if(n++,!(n<s))throw new Error(`Failed to authenticate keystore [${a}] after ${s} attempts.`);console.log(`Invalid password for ${a}`)}catch(e){if(n++,!(n<s))throw new Error(`Failed to authenticate keystore [${a}] after ${s} attempts: ${e.message}`);console.log("Error validating password for keystore")}}}return t}createServerInstance(e,t){const a=e.clients;if(0===a.length)throw new Error("No clients configured for service");if(a.length>1)throw new Error("Only one client is supported for this service");const r=JSON.parse(a[0]),n=[r.name],s=[r.public_key_path],o=[r.allowed_keystores],i=e.keystore.allowed_keystores;if(0===i.length)throw new Error("No keystores configured for service");let c=[];for(const e of i)c.push(t[e]);return new qa(e.server_keys.private_key_path,e.server_keys.passphrase,n,s,o,e.keystore.path,i,c)}async showLogs(t,a=50,n=!1){const s=process.env.HOME+"/.wative/logs";let o;if(o=t?r.join(s,`${t}.log`):r.join(s,"service_manager.log"),!e.existsSync(o))throw new Error(`Log file not found: ${o}`);const i=_("tail",n?["-f",`-n${a}`,o]:[`-n${a}`,o],{stdio:["ignore","inherit","inherit"]});return n?(process.on("SIGINT",()=>{i.kill("SIGTERM"),process.exit(0)}),new Promise((e,t)=>{i.on("close",a=>{0===a?e():t(new Error(`tail process exited with code ${a}`))})})):new Promise((e,t)=>{i.on("close",a=>{0===a?e():t(new Error(`tail process exited with code ${a}`))})})}setupLogger(){const t=process.env.HOME+"/.wative/logs";e.existsSync(t)||e.mkdirSync(t,{recursive:!0}),I.configure({appenders:{file:{type:"file",filename:r.join(t,"service_manager.log"),maxLogSize:10485760,backups:3,compress:!0,keepFileExt:!0,layout:{type:"pattern",pattern:"%d{yyyy-MM-dd hh:mm:ss.SSS} [%p] %c - %m"},encoding:"utf-8"},console:{type:"console"}},categories:{default:{appenders:["file","console"],level:"info"}}}),this.logger=I.getLogger("service_manager"),this.logger.level="info"}setupServiceLogger(t){const a=process.env.HOME+"/.wative/logs";e.existsSync(a)||e.mkdirSync(a,{recursive:!0});const n=r.join(a,`${t}.log`);this.cleanupOldLogs(a),I.configure({appenders:{file:{type:"file",filename:r.join(a,"service_manager.log"),maxLogSize:10485760,backups:3,compress:!0,keepFileExt:!0,layout:{type:"pattern",pattern:"%d{yyyy-MM-dd hh:mm:ss.SSS} [%p] %c - %m"},encoding:"utf-8"},console:{type:"console"},[`${t}_file`]:{type:"file",filename:n,maxLogSize:10485760,backups:3,compress:!0,keepFileExt:!0,layout:{type:"pattern",pattern:"%d{yyyy-MM-dd hh:mm:ss.SSS} [%p] %c - %m"},encoding:"utf-8"}},categories:{default:{appenders:["file","console"],level:"info"},[t]:{appenders:[`${t}_file`],level:"info"}}})}cleanupOldLogs(t){try{const a=e.readdirSync(t),n=new Date;n.setDate(n.getDate()-3),a.forEach(a=>{const s=r.join(t,a);e.statSync(s).mtime<n&&a.endsWith(".log")&&(e.unlinkSync(s),this.logger.info(`Deleted old log file: ${a}`))})}catch(e){this.logger.warn(`Failed to cleanup old logs: ${e}`)}}}class Ua{constructor(e){this.config=e}async executeCommand(e){return this.config.useRemoteServer?this.executeCommandThroughRemoteServer(e):new Promise((t,r)=>{const n=new A;n.on("ready",()=>{n.exec(e,(e,a)=>{if(e)return n.end(),r(e);let s="",o="";a.on("close",(e,a)=>{n.end(),0===e?t(s):r(new Error(`Command failed with code ${e}: ${o||s}`))}).on("data",e=>{s+=e.toString()}).stderr.on("data",e=>{o+=e.toString()})})}).on("error",e=>{r(e)});const s=this.config.clientAuth,o={host:this.config.host,port:this.config.port,username:s.username,privateKey:a(s.privateKeyPath),passphrase:s.passphrase};n.connect(o)})}async executeCommandThroughRemoteServer(e){return new Promise((t,r)=>{const n=new A;n.on("ready",()=>{n.forwardOut("127.0.0.1",0,this.config.host,this.config.port,(s,o)=>{if(s)return n.end(),r(s);const i=new A;i.on("ready",()=>{i.exec(e,(e,a)=>{if(e)return i.end(),n.end(),r(e);let s="",o="";a.on("close",(e,a)=>{i.end(),n.end(),0===e?t(s):r(new Error(`Command failed with code ${e}: ${o||s}`))}).on("data",e=>{s+=e.toString()}).stderr.on("data",e=>{o+=e.toString()})})}).on("error",e=>{n.end(),r(e)});const c=this.config.clientAuth,l={sock:o,username:c.username,privateKey:a(c.privateKeyPath),passphrase:c.passphrase};i.connect(l)})}).on("error",e=>{r(e)});const s={host:this.config.remoteServer.host,port:this.config.remoteServer.port||22,username:this.config.remoteServer.auth.username,privateKey:a(this.config.remoteServer.auth.privateKeyPath),passphrase:this.config.remoteServer.auth.passphrase};n.connect(s)})}async sendRequest(e){try{const t=JSON.stringify(e),a=await this.executeCommand(t),r=JSON.parse(a);if(!r.status)throw new Error(r.msg||"Request failed");return r}catch(e){if(e instanceof Error)throw new Error(`SSH request failed: ${e.message}`);throw e}}async getRootAccount(e,t){const a={method:"get_root_account",keystoreId:e,chainId:t};return(await this.sendRequest(a)).data}async getSubAccount(e,t,a,r){const n={method:"get_sub_account",params:{keystoreId:e,chainId:t,startIndex:a,endIndex:r}};return(await this.sendRequest(n)).data}async signTransaction(e,t){const a={method:"sign",params:{txParams:e,rpcUrl:t}};return(await this.sendRequest(a)).data}async signAndSendTransaction(e,t){const a={method:"sign_and_send",params:{txParams:e,rpcUrl:t}};return(await this.sendRequest(a)).data}async signSolanaTransaction(e,t,a){const r={method:"solana_sign",params:{txParams:e,rpcUrl:t,priority_fee:a}};return(await this.sendRequest(r)).data}async sendSignedSolanaTransaction(e,t){const a={method:"solana_send",params:{txParams:e,rpcUrl:t}};return(await this.sendRequest(a)).data}async signMessage(e,t){const a={method:"sign_message",params:{account:e,message:t}};return(await this.sendRequest(a)).data}async signTypedData(e,t,a,r,n){const s={method:"sign_typed_data",params:{account:e,domain:t,types_name:a,types:r,message:n}};return(await this.sendRequest(s)).data}}require("dotenv").config();const Ha=async e=>{const t=new Ka;try{if(!e)throw new Error("Configuration name is required. Please specify a configuration name.");console.log(`Starting SSH service with configuration: ${e}`),await t.startService(e),console.log("SSH service started successfully."),process.on("SIGINT",async()=>{console.log("\nShutting down SSH services..."),await t.stopAllServices(),process.exit(0)}),process.on("SIGTERM",async()=>{console.log("\nShutting down SSH services..."),await t.stopAllServices(),process.exit(0)})}catch(e){console.error(`Failed to start SSH service: ${e.message}`),process.exit(1)}},Ja=process.argv.slice(2),Ga=Ja.includes("--daemon"),Wa=Ja.indexOf("--config"),Va=-1!==Wa&&Ja[Wa+1]?Ja[Wa+1]:void 0;(Ga||Va)&&Ha(Va).catch(e=>{console.error("Failed to start SSH service:",e),process.exit(1)}),process.on("unhandledRejection",(e,t)=>{console.log("Unhandled Rejection at:",t,"reason:",e)});var Za=Object.freeze({__proto__:null,mainWithConfig:Ha,WativeSSHClient:Ua,createWativeSSHClient:function(e){return new Ua(e)},WativeWielderServer:qa,SSHConfigManager:_a,checkFileExistence:$a,sleep:function(e=0){return new Promise((t,a)=>{setTimeout(()=>{t(!0)},e)})},getAndGenerateConfig:async t=>{const a="/etc/wative";e.existsSync(a)||e.mkdirSync(a),await(async()=>{const t="/etc/wative",a=r.join(t,"id_rsa_server.pub"),n=r.join(t,"id_rsa_server");e.existsSync(a)&&e.existsSync(n)||(console.log("Generating SSH key pair..."),x(`ssh-keygen -t rsa -f ${n} -N 'wative_server'`,{stdio:"inherit"}));const s=r.join(t,"id_rsa_detake.pub"),o=r.join(t,"id_rsa_detake");e.existsSync(s)&&e.existsSync(o)||(console.log("Generating SSH key pair..."),x(`ssh-keygen -t rsa -f ${o} -N 'wative_detake'`,{stdio:"inherit"}))})();const n=r.join(a,"config.ini");if(!e.existsSync(n)){const a=Oe(t).accounts,r={keystore:{path:t,allowed_keystores:aa(a)},ssh:{listen:"127.0.0.1",port:5678,log:{size:10485760,backups:3}}};let s=b.stringify(r);e.writeFileSync(n,s)}return b.parse(e.readFileSync(n,"utf-8"))}});const Xa=new R,Qa=require("../package.json");let Ya;Xa.version(Qa.version).description("Wative CLI Tool"),Xa.command("version").description("Show the version of wative").action(()=>{console.log(`Wative CLI Tool v${Qa.version}`)});const er=()=>{if(!Ya){const e=r.join(process.env.HOME||"",".wative","ssh");Ya=new Ka(e)}return Ya},tr=Xa.command("ssh").description("Manage SSH services");tr.command("start").description("Start SSH service").option("-c, --config <name>","Specify service configuration name").option("-d, --daemon","Run service in daemon mode").action(async t=>{const a=er();try{t.config||(console.error("Error: Configuration name is required. Use -c or --config to specify a service configuration."),process.exit(1));const n=t.config,s=a.getServiceConfig(n),o=require("net"),i=async(e,t="127.0.0.1")=>new Promise(a=>{const r=o.createServer();r.listen(e,t,()=>{r.once("close",()=>{a(!1)}),r.close()}),r.on("error",e=>{"EADDRINUSE"===e.code?a(!0):a(!1)})});if(await i(s.ssh.port,s.ssh.listen)){const e=`Port ${s.ssh.port} on ${s.ssh.listen} is already in use. Cannot start SSH service '${n}'.`;console.error(`Error: ${e}`),process.exit(1)}if(console.log(`Port ${s.ssh.port} on ${s.ssh.listen} is available for service '${n}'`),t.daemon){console.log(`Starting SSH service '${n}' in daemon mode...`);const t=await a.promptForPasswords(s.keystore.allowed_keystores),o=require("crypto"),i=o.randomBytes(32),c=o.randomBytes(16),l=o.createCipheriv("aes-256-cbc",i,c);let u=l.update(JSON.stringify(t),"utf8","hex");u+=l.final("hex");const d=c.toString("hex")+":"+i.toString("hex")+":"+u;return void((t,a)=>{const n=r.join(process.env.HOME||"",".wative","logs"),s=r.join(process.env.HOME||"",".wative","ssh","pids");e.existsSync(n)||e.mkdirSync(n,{recursive:!0}),e.existsSync(s)||e.mkdirSync(s,{recursive:!0});const o=r.join(n,`${t}-daemon.log`),i=r.join(s,`${t}-daemon.pid`),c=r.join(s,`${t}-watcher.pid`),l=_("node",[r.resolve(__dirname,"daemon-watcher.js"),t,o,i,c,r.resolve(__dirname,"..")],{detached:!0,stdio:"ignore",env:{...process.env,WATIVE_ENCRYPTED_PASSWORDS:a}});e.writeFileSync(c,l.pid.toString()),l.unref(),console.log(`SSH service '${t}' daemon watcher started with PID: ${l.pid}`),console.log(`Daemon log file: ${o}`),console.log(`Watcher PID file: ${c}`)})(n,d)}if(process.env.WATIVE_DAEMON_PASSWORDS&&process.env.WATIVE_WORKER_MODE){const e=require("crypto"),t=process.env.WATIVE_DAEMON_PASSWORDS;delete process.env.WATIVE_DAEMON_PASSWORDS,delete process.env.WATIVE_WORKER_MODE;try{const a=t.split(":"),r=Buffer.from(a[0],"hex"),s=Buffer.from(a[1],"hex"),o=a[2],i=e.createDecipheriv("aes-256-cbc",s,r);let c=i.update(o,"hex","utf8");c+=i.final("utf8");const l=JSON.parse(c);console.log(`[${(new Date).toISOString()}] Worker process starting SSH service '${n}'...`);const u=er();await u.startService(n,l);for(const e in l)l[e]=null,delete l[e];console.log(`[${(new Date).toISOString()}] SSH service '${n}' started successfully`);const d=async e=>{console.log(`[${(new Date).toISOString()}] Worker received ${e}, stopping service...`);try{await u.stopService(n),console.log(`[${(new Date).toISOString()}] Service stopped successfully`)}catch(e){console.error(`[${(new Date).toISOString()}] Error stopping service:`,e)}process.exit(0)};process.on("SIGTERM",()=>d("SIGTERM")),process.on("SIGINT",()=>d("SIGINT"));const p=setInterval(async()=>{try{const e=await u.getServiceStatus(n);"running"!==e&&(console.log(`[${(new Date).toISOString()}] Service status changed to: ${e}`),"stopped"===e&&(console.log(`[${(new Date).toISOString()}] Service stopped unexpectedly, exiting worker...`),clearInterval(p),process.exit(1)))}catch(e){console.error(`[${(new Date).toISOString()}] Error checking service status:`,e)}},3e4),h=setInterval(()=>{},6e4),g=()=>{clearInterval(p),clearInterval(h)};process.on("exit",g)}catch(e){console.error(`[${(new Date).toISOString()}] Worker process error:`,e),process.exit(1)}return}{await a.startService(n),console.log(`SSH service '${n}' started successfully`),process.on("SIGINT",async()=>{console.log("\nReceived SIGINT, stopping services..."),await a.stopAllServices(),process.exit(0)}),process.on("SIGTERM",async()=>{console.log("\nReceived SIGTERM, stopping services..."),await a.stopAllServices(),process.exit(0)});const e=setInterval(()=>{"running"!==a.getServiceStatus(n)&&(console.log(`Service ${n} is no longer running, exiting...`),clearInterval(e),process.exit(1))},5e3);process.stdin.resume()}}catch(e){console.error(`Error: ${e instanceof Error?e.message:String(e)}`),process.exit(1)}}),tr.command("stop").description("Stop SSH service").option("-c, --config <name>","Specify service configuration name").action(async e=>{const t=er();try{e.config||(console.error("Error: Configuration name is required. Use -c or --config to specify a service configuration."),process.exit(1)),await t.stopService(e.config),console.log(`SSH service '${e.config}' stopped successfully`)}catch(e){console.error(`Error: ${e instanceof Error?e.message:String(e)}`),process.exit(1)}}),tr.command("restart").description("Restart SSH service").option("-c, --config <name>","Specify service configuration name").action(async e=>{const t=er();try{e.config||(console.error("Error: Configuration name is required. Use -c or --config to specify a service configuration."),process.exit(1)),await t.restartService(e.config),console.log(`SSH service '${e.config}' restarted successfully`)}catch(e){console.error(`Error: ${e instanceof Error?e.message:String(e)}`),process.exit(1)}}),tr.command("create").description("Create new SSH service configuration interactively").action(async()=>{const e=require("readline"),t=require("fs"),a=require("path"),r=e.createInterface({input:process.stdin,output:process.stdout}),n=e=>new Promise(t=>{r.question(e,t)});try{console.log("SSH create command started...");const e=a.join(process.env.HOME||"",".wative/ssh"),r=(await n(`SSH storage located in (default: ${e}): `)).trim()||e,s=a.join(process.env.HOME||"",".wative"),o=(await n(`Keystore storage located in (default: ${s}): `)).trim()||s,i=new _a(r,o);let c,l,u,d;for(;;)if(c=await n("Enter service name: "),c.trim())try{i.loadServiceConfig(c),console.log("Service name already exists, please enter a different name")}catch(e){break}else console.log("Service name cannot be empty");for(;;){const e=await n("Enter port number: ");if(l=parseInt(e),isNaN(l)||l<1024||l>65535){console.log("Port number must be between 1024-65535");continue}const t=i.listServiceConfigs();let a=!1;for(const e of t)try{if(i.loadServiceConfig(e).ssh.port===l){a=!0;break}}catch(e){}if(!a)break;console.log(`Port ${l} is already in use by another service, please enter a different port`)}for(;;){const e=await n("Enter allowed keystore list (comma separated): ");if(!e.trim()){console.log("Keystore list cannot be empty");continue}if(u=e.split(",").map(e=>e.trim()).filter(e=>e),0===u.length){console.log("At least one valid keystore is required");continue}const r=a.join(o,"accounts");let s=!0;for(const e of u){const n=a.join(r,`${e}.json`);if(!t.existsSync(n)){console.log(`Keystore '${e}' does not exist`),s=!1;break}}if(s){console.log("All keystores verified to exist");break}console.log("Please re-enter valid keystore list")}for(;d=await n("Enter remote client name: "),!d.trim();)console.log("Client name cannot be empty");const p=a.join(r,"conf.d",c);t.existsSync(p)||t.mkdirSync(p,{recursive:!0});const h=a.join(p,`${d}.pub`);for(console.log("\nPlease place the remote client's public key file at the following path:"),console.log(`${h}`),console.log("\nPress Enter to continue after placing the file...");;){if(await n(""),t.existsSync(h)){console.log("Client public key file found");break}console.log("Client public key file not found, please confirm the file is correctly placed and press Enter again")}const g=await n("Enter service description (optional): ");console.log("\nCreating SSH service configuration...");const m=await i.createServiceConfig(c,l,u,d,g||void 0);console.log("\nNote: Passwords will be requested when starting the service."),console.log(`\nSSH service configuration '${c}' created successfully!`),console.log(`Port: ${l}`),console.log(`Allowed keystores: ${u.join(", ")}`),console.log(`Client name: ${d}`),console.log(`Server private key: ${m.server_keys.private_key_path}`),console.log(`Client public key: ${h}`)}catch(e){console.error(`Error: ${e instanceof Error?e.message:String(e)}`),process.exit(1)}finally{r.close()}}),tr.command("remove").description("Remove SSH service configuration").option("-c, --config <name>","Service configuration name").action(async e=>{const t=er();try{e.config||(console.error("Error: Configuration name is required for remove command"),process.exit(1)),await t.removeService(e.config),console.log(`SSH service configuration '${e.config}' removed successfully`)}catch(e){console.error(`Error: ${e instanceof Error?e.message:String(e)}`),process.exit(1)}}),tr.command("list").description("List all SSH service configurations").action(async()=>{const e=new _a,t=new Ka,a=e.listServiceConfigs();if(0!==a.length){console.log("SSH Service Configurations:");for(const r of a)try{const a=e.loadServiceConfig(r),n=t.getServiceStatus(r);console.log(` - ${r}: ${a.description||"No description"} (${n})`)}catch(e){const a=t.getServiceStatus(r);console.log(` - ${r}: Configuration error (${a})`)}}else console.log("No SSH service configurations found.")}),tr.command("status").description("Show SSH service status").option("-c, --config <name>","Service configuration name").action(async e=>{const t=er();try{if(e.config){const a=t.getServiceStatus(e.config);console.log(`SSH service '${e.config}' status: ${a}`)}else{const e=t.listServices();if(0===e.length)return void console.log("No SSH service configurations found");console.log("SSH Service Status:"),e.forEach(e=>{const a=t.getServiceStatus(e.name);console.log(` - ${e.name}: ${a}`)})}}catch(e){console.error(`Error: ${e instanceof Error?e.message:String(e)}`),process.exit(1)}}),tr.command("log").description("Show SSH service logs").option("-c, --config <name>","Service configuration name").option("-n, --lines <number>","Number of lines to show (default: 50)","50").option("-f, --follow","Follow log output").action(async e=>{const t=er();try{const a=parseInt(e.lines)||50;await t.showLogs(e.config,a,e.follow)}catch(e){console.error(`Error: ${e instanceof Error?e.message:String(e)}`),process.exit(1)}}),Xa.command("cmd").description("Start wallet-cli shell").action(async()=>{try{x("wallet-cli",{stdio:"inherit"})}catch(e){}}),(require.main===module||process.argv[1]&&process.argv[1].includes("bin/wative.js"))&&Xa.parse(process.argv);const{WativeCore:ar}=require("wative-core"),rr=require("../package.json");require("events").EventEmitter.defaultMaxListeners=0;process.on("unhandledRejection",(e,t)=>{console.log("Unhandled Rejection at:",t,"reason:",e)}),require.main===module&&(async()=>{console.log("version:",rr.version),Gt();const t=await Wt();await Je(t),Sa(t);const a=r.resolve(t,"network.json"),n=JSON.parse(e.readFileSync(a,"utf8"));let s=aa(n.accounts);const o=new ar(t,s,null,!0);await xa(t,o)})().then(()=>process.exit(0)).catch(e=>{console.log(e.message),process.exit(1)});export{ne as DEFAULT_NETWORK,fe as GasUtil,re as MNEMONIC_WORDS,se as SOLANA_CHAIN_IDS,Za as SSH,ht as accountBalanceLog,Kt as accountIndexOrAddressValidator,Ue as accountSetting,$t as addAsset,Ze as addNetwork,_t as addToken,Bt as addrValidator,aa as batchGetKeystoreSlugByAccountName,At as batchGetTokenBalance,ae as batchHasTokenBalance,te as batchUpdateUserTokenBalance,Ut as chainAddressValidator,ha as checkFileExistence,ga as chunkArray,ca as confirmSomething,Je as createNetwork,ee as deleteTokenBalance,la as editorSomething,rt as enhancedBalanceDisplay,da as excutePromiseFunction,Mt as expandAmountValidator,fa as formatAddr,qt as gasValidator,ct as getAccountAddress,gt as getAccountBalance,M as getAccountBalanceInEvm,D as getAccountBalanceInSolana,pa as getAccountChainType,Ft as getAccountIndex,Et as getAccountIndexByKeystoreSlug,Ne as getAccountInfo,X as getAccountInfoInSolana,ra as getAccountName,ea as getAccountNameByKeystoreSlug,Tt as getAccountRange,vt as getAssetList,bt as getAssetListByTokenName,It as getBatchAccountBalance,Vt as getChainId,z as getChainIdByEvm,ie as getChainType,G as getCodeInEvm,Yt as getColor,mt as getDefaultNetworkByAddress,ft as getEvmNetworks,Wt as getKeystorePath,ta as getKeystoreSlugByAccountName,Z as getLatestBlockhash,Xt as getMulticallAddress,oe as getNativeTokenDecimals,Oe as getNetworkInfo,it as getNetworkInfoByName,ot as getNetworkTypeByName,lt as getPKAccountAddress,V as getPrioritizationFee,Zt as getRpcUrl,tt as getShowTokenList,wt as getStatus,Qt as getSymbol,Y as getTokenBalance,H as getTokenBalanceInEvm,J as getTokenBalanceInSolana,K as getTokenInfoInEvm,U as getTokenInfoInSolana,W as getTransferTokenData,ua as hexValidator,oa as importMaskedPassphrase,na as inputMaskedPassword,ia as inputPassword,sa as inputPasswordWithoutValidator,Nt as inputSomething,le as isEvmAddress,ce as isSolanaAddress,Dt as lastAccountNoValidator,ka as listWithLazyBalanceLoading,Ee as loginIn,Rt as numberValidator,zt as passphraseValidator,Xa as program,Ve as removeNetwork,Te as saveAccountInfo,xt as saveAsset,Jt as selectCheckboxSomething,st as selectDefaultNetwork,et as selectFlag,Ge as selectOrEditNetwork,Ht as selectSomething,xe as selectToolsOptions,ve as sendSolanaRawTransaction,dt as showAllAccounts,Pt as showAssets,kt as showAssetsDetail,Xe as showAvailableNetworks,Qe as showDataview,Gt as showIntroduction,nt as showNetwork,at as showTokenList,_e as showTools,ma as sleep,pt as switchNetworkByAccountName,ut as switchPPNetwork,Lt as tagValidator,Q as updateBalance,We as updateNetwork,Ye as updateStatus,Sa as updateStorage,St as updateTokenBalanceOption};
|