@northflank/cli 0.10.16 → 0.11.1

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.
@@ -1 +1 @@
1
- const a14C=a14v;function a14c(){const J=['onUpKey','reloadText','length','loadMore','loading','render','1351672plAqrP','selected','\x20Loading\x20more\x20options','nextPageCursor','down','loop','log','push','3227xXpRjg','dir\x20must\x20be\x20up\x20or\x20down','53779nkSnTB','splice','pagOpt','map','5482OfvFtL','9LDmhAV','run','resolve','catch','opt','6368916UTieVl','2154roWNlc','..\x20Load\x20more\x20options\x20..','name','690TAsAGC','36HchNJi','4nEJIWQ','handleDynamicPageLoad','285235gRkdxI','208869CosNgW','choices','onDownKey','italic'];a14c=function(){return J;};return a14c();}(function(c,v){const u=a14v,j=c();while(!![]){try{const n=parseInt(u(0x72))/0x1*(parseInt(u(0x8e))/0x2)+-parseInt(u(0x76))/0x3+parseInt(u(0x73))/0x4*(-parseInt(u(0x75))/0x5)+-parseInt(u(0x95))/0x6*(parseInt(u(0x88))/0x7)+-parseInt(u(0x80))/0x8*(-parseInt(u(0x8f))/0x9)+-parseInt(u(0x98))/0xa*(parseInt(u(0x8a))/0xb)+parseInt(u(0x94))/0xc;if(n===v)break;else j['push'](j['shift']());}catch(g){j['push'](j['shift']());}}}(a14c,0x293a4));import a14j from'inquirer/lib/prompts/list.js';import a14n from'inquirer/lib/objects/choice.js';import a14g from'chalk';function a14v(c,v){const j=a14c();return a14v=function(n,g){n=n-0x72;let r=j[n];return r;},a14v(c,v);}function incrementListIndex(c,v,j){const k=a14v,n=j[k(0x77)]['realLength'],g=k(0x85)in j?Boolean(j['loop']):!![];if(v==='up'){if(c>0x0)return c-0x1;return g?n-0x1:c;}if(v===k(0x84)){if(c<n-0x1)return c+0x1;return g?0x0:c;}throw new Error(k(0x89));}export class DynamicReloadPaginationPrompt extends a14j{['reloadText']=a14g[a14C(0x79)](a14C(0x96));[a14C(0x8c)];[a14C(0x7e)]=![];[a14C(0x83)];constructor(c,v,j){const o=a14C;super(c,v,j),this[o(0x8c)]=this[o(0x93)],this[o(0x83)]=this[o(0x8c)][o(0x83)],this[o(0x83)]!==undefined&&this[o(0x93)][o(0x77)][o(0x87)](new a14n(this['reloadText'],this['reloadText']));}[a14C(0x90)](){const T=a14C;return console[T(0x86)]('Method\x20not\x20implemented'),Promise[T(0x91)]();}[a14C(0x7a)](){const S=a14C;if(this[S(0x7e)])return;this[S(0x81)]=incrementListIndex(this['selected'],'up',this[S(0x93)]),this['render']();}async[a14C(0x78)](){const Y=a14C;if(this[Y(0x7e)])return;this[Y(0x81)]=incrementListIndex(this[Y(0x81)],Y(0x84),this[Y(0x93)]),await this[Y(0x74)](),this['render']();}async[a14C(0x74)](){const e=a14C;if(this[e(0x81)]>=this[e(0x93)][e(0x77)][e(0x7c)]-0x1){if(this[e(0x83)]===undefined)return;this[e(0x7e)]=!![];let c=0x0;const v=setInterval(()=>{const P=e,r=['⠋','⠙','⠹','⠸','⠼','⠴','⠦','⠧','⠇','⠏'],H=a14g[P(0x79)](r[c%r['length']]+P(0x82));this[P(0x93)]['choices']['choices'][this['selected']][P(0x97)]=''+H,c+=0x1,this[P(0x7f)]();},0x50),{elements:j,nextPageCursor:n}=await this[e(0x8c)][e(0x7d)]({'nextPageCursor':this[e(0x83)]})[e(0x92)](()=>({'elements':[],'nextPageCursor':undefined}));this[e(0x83)]=n;const g=j[e(0x8d)](r=>new a14n(r,r));this['opt'][e(0x77)][e(0x77)][e(0x8b)](this[e(0x81)],0x1),this[e(0x93)]['choices']['push'](...g),n!==undefined&&this[e(0x93)]['choices'][e(0x87)](new a14n(this['reloadText'],this[e(0x7b)])),clearInterval(v),this[e(0x7e)]=![];}}}
1
+ const a14M=a14V;(function(e,V){const E=a14V,b=e();while(!![]){try{const G=parseInt(E(0x14b))/0x1*(-parseInt(E(0x13d))/0x2)+-parseInt(E(0x145))/0x3+-parseInt(E(0x139))/0x4*(parseInt(E(0x142))/0x5)+parseInt(E(0x13f))/0x6*(-parseInt(E(0x152))/0x7)+parseInt(E(0x147))/0x8+parseInt(E(0x14d))/0x9+parseInt(E(0x148))/0xa;if(G===V)break;else b['push'](b['shift']());}catch(a){b['push'](b['shift']());}}}(a14e,0xd7acb));function a14V(e,V){const b=a14e();return a14V=function(G,a){G=G-0x139;let m=b[G];return m;},a14V(e,V);}import a14b from'inquirer/lib/prompts/list.js';import a14G from'inquirer/lib/objects/choice.js';function a14e(){const z=['map','realLength','1210424ddxVIu','italic','onUpKey','down','200CIRFfG','name','6wSbZyb','opt','choices','15ztmKjL','dir\x20must\x20be\x20up\x20or\x20down','loading','969498NPEUHb','selected','5750880hJkweq','23570000EGhUGo','catch','nextPageCursor','11710dfGtEX','\x20Loading\x20more\x20options','7966476BPtCmT','render','push','pagOpt','length','4729459exoBLe','reloadText','handleDynamicPageLoad','..\x20Load\x20more\x20options\x20..','loadMore','loop'];a14e=function(){return z;};return a14e();}import a14a from'chalk';function incrementListIndex(e,V,b){const W=a14V,G=b['choices'][W(0x159)],a=W(0x157)in b?Boolean(b['loop']):!![];if(V==='up'){if(e>0x0)return e-0x1;return a?G-0x1:e;}if(V===W(0x13c)){if(e<G-0x1)return e+0x1;return a?0x0:e;}throw new Error(W(0x143));}export class DynamicReloadPaginationPrompt extends a14b{[a14M(0x153)]=a14a[a14M(0x13a)](a14M(0x155));[a14M(0x150)];[a14M(0x144)]=![];[a14M(0x14a)];constructor(e,V,b){const Q=a14M;super(e,V,b),this['pagOpt']=this[Q(0x140)],this[Q(0x14a)]=this['pagOpt'][Q(0x14a)],this[Q(0x14a)]!==undefined&&this[Q(0x140)][Q(0x141)]['push'](new a14G(this[Q(0x153)],this['reloadText']));}[a14M(0x13b)](){const k=a14M;if(this[k(0x144)])return;this['selected']=incrementListIndex(this['selected'],'up',this['opt']),this[k(0x14e)]();}async['onDownKey'](){const r=a14M;if(this[r(0x144)])return;this[r(0x146)]=incrementListIndex(this['selected'],r(0x13c),this[r(0x140)]),await this[r(0x154)](),this[r(0x14e)]();}async['handleDynamicPageLoad'](){const U=a14M;if(this['selected']>=this[U(0x140)][U(0x141)][U(0x151)]-0x1){if(this[U(0x14a)]===undefined)return;this[U(0x144)]=!![];let e=0x0;const V=setInterval(()=>{const S=U,m=['⠋','⠙','⠹','⠸','⠼','⠴','⠦','⠧','⠇','⠏'],O=a14a[S(0x13a)](m[e%m[S(0x151)]]+S(0x14c));this[S(0x140)][S(0x141)][S(0x141)][this['selected']][S(0x13e)]=''+O,e+=0x1,this[S(0x14e)]();},0x50),{elements:b,nextPageCursor:G}=await this['pagOpt'][U(0x156)]({'nextPageCursor':this[U(0x14a)]})[U(0x149)](()=>({'elements':[],'nextPageCursor':undefined}));this[U(0x14a)]=G;const a=b[U(0x158)](m=>new a14G(m,m));this[U(0x140)]['choices']['choices']['splice'](this['selected'],0x1),this[U(0x140)]['choices']['push'](...a),G!==undefined&&this[U(0x140)][U(0x141)][U(0x14f)](new a14G(this['reloadText'],this[U(0x153)])),clearInterval(V),this[U(0x144)]=![];}}}
@@ -1 +1 @@
1
- const a15Z=a15v;(function(c,v){const l=a15v,j=c();while(!![]){try{const n=parseInt(l(0x127))/0x1*(-parseInt(l(0x11b))/0x2)+parseInt(l(0x13e))/0x3+parseInt(l(0x11a))/0x4+-parseInt(l(0x114))/0x5+-parseInt(l(0x132))/0x6*(-parseInt(l(0x124))/0x7)+parseInt(l(0xe3))/0x8+-parseInt(l(0xec))/0x9*(parseInt(l(0xdd))/0xa);if(n===v)break;else j['push'](j['shift']());}catch(g){j['push'](j['shift']());}}}(a15c,0x30d2b));function a15v(c,v){const j=a15c();return a15v=function(n,g){n=n-0xd0;let r=j[n];return r;},a15v(c,v);}import{ApiClient}from'@northflank/js-client';function a15c(){const a=['\x20is\x20running\x20and\x20reachable\x20and\x20that\x20a\x20port\x20is\x20defined\x20on\x20the\x20networking\x20section.','address','Stop\x20forwarding\x20traffic\x20from\x20','bold','--noDefaults','exit','695051gqmRFe','--skipHostnames','join','87867uSFThW','Don\x27t\x20use\x20context\x20default\x20values,\x20explicitly\x20use\x20options\x20or\x20ask.','message','Forwarding\x20','Please\x20ensure\x20the\x20','Project\x20for\x20forwarding','printHostsFileHint','all','error','skipHostnamesText','Running\x20on\x20macOS\x20in\x20','12ESnywo','Error\x20occured\x20while\x20trying\x20to\x20forward\x20','No\x20services\x20and\x20addons\x20to\x20forward\x20found\x20in\x20project\x20','forwardAddon','win32','Port-forwarding\x20for\x20all\x20services\x20and\x20addons\x20in\x20the\x20given\x20project','\x20\x20-\x20port\x20','portFwdCmd','Cleaning\x20up\x20open\x20connections\x20failed:\x20','forwardProject','addon','platform','479262IMlREL','flat','service','tunnel-close','printForwardingInfo','Running\x20in\x20','name','action','stop','C:/Windows/System32/drivers/etc/hosts','forwarding','--instance\x20--instanceId\x20[NAME]','green','--addon\x20--addonId\x20[NAME]','1600MzHRKp','http://','hostnames','Addon\x20to\x20forward','/etc/hosts','getCurrentProjectName','1538800wMufPz','entries','Port-forwarding\x20for\x20Northflank\x20services\x20and\x20addons.','getCurrentServiceName','option','Only\x20expose\x20on\x20IP\x20address,\x20not\x20on\x20hostnames.\x20With\x20this\x20option,\x20no\x20root\x20permissions\x20are\x20required.','skipHostnames','greenBright','\x27:\x20\x22','15669YoIZmF','length','HTTP','\x20addon\x20ports','Forwarding\x20service\x20','--project\x20--projectId\x20[NAME]','Services:','Failed:\x20','project\x20for\x20forwarding','port','\x20to\x20','SIGINT','forward','canExecuteWithHostnames','Service\x20to\x20forward','askForAddon','forwardService','\x20is\x20exposed\x20on\x20','Port-forwarding\x20for\x20the\x20specified\x20addon','askForService','\x20-\x20','protocol','\x20is\x20exposed\x20with\x20multiple\x20','Addons:','apiClient','Connection\x20error\x20occurred\x20when\x20forwarding\x20\x27','askForProject','noDefaultsText','hosts','connection-error','getProxyForwarder','\x20mode.\x20If\x20hostname\x20forwarding\x20is\x20required,\x20remove\x20','flatMap','data.id','data','Forwarding\x20addon\x20','description','--service\x20--serviceId\x20[NAME]','forEach','filter','453975zdGhzF','\x27\x20of\x20','\x20mode:\x20the\x20locally\x20forwarded\x20port\x20differs\x20from\x20the\x20actual\x20port\x20on\x20the\x20forwarded\x20service/addon.','alias','\x20in\x20project\x20','portName','426044PfYzyQ','2aafQQc','addCommand','log'];a15c=function(){return a;};return a15c();}import a15j from'chalk';import{assertContextExisting,customUserAgent,error,getCommand,success,warning}from'../utils.js';import{InquirerHelper}from'../inquirer-helper.js';import*as a15n from'os';import{uniqBy,uniq,repeat,groupBy,capitalize}from'lodash-es';import{EOL}from'os';export class CliPortForward{['portFwdCmd'];[a15Z(0x104)];[a15Z(0x107)]=a15Z(0x128);[a15Z(0x130)]=a15Z(0xe8);constructor(c,v){const F=a15Z;this['apiClient']=new ApiClient(c,{'throwErrorOnHttpErrorCode':!![],'customUserAgent':customUserAgent,'agent':v});const j=new InquirerHelper(this[F(0x104)]);this[F(0x139)]=getCommand()[F(0xd5)](F(0xf8))[F(0x117)]('fwd')['description'](F(0xe5));const n=getCommand(!![])[F(0xd5)](F(0x12e))[F(0x110)](F(0x137))[F(0xe7)](F(0xf1),F(0xf4))[F(0xe7)]('--noDefaults',this[F(0x107)],![])['option'](F(0x125),this[F(0x130)],![])[F(0xd6)](async({noDefaults:H,projectId:u,skipHostnames:k})=>{const w=F;assertContextExisting(this[w(0x104)]);const C=this[w(0x10a)](k),o=H?undefined:c[w(0xe2)](),T=u||o||await j[w(0x106)]();try{const {services:S,addons:Y}=await C[w(0x13b)]({'projectId':T},k);if(S['length']+Y[w(0xed)]<=0x0)warning(w(0x134)+a15j[w(0x121)](T));else{const P=S['filter'](W=>W['length']>0x0)[w(0xed)],J=Y[w(0x113)](W=>W[w(0xed)]>0x0)['length'],s=w(0x118)+a15j[w(0x121)](T);console[w(0x11d)](w(0x12a)+a15j['green']['bold'](P+'\x20service\x20ports')+'\x20and\x20'+a15j[w(0xdb)][w(0x121)](J+w(0xef))+s),console[w(0x11d)](),console[w(0x11d)](a15j['bold'](w(0xf2))),S[w(0x112)](W=>{const x=w;if(W['length']>=0x1&&!W[0x0][x(0x12f)])this[x(0xd3)](W,{'type':x(0xd1),'name':W[0x0]['data']['id']},k);}),console['log'](a15j[w(0x121)](w(0x103))),Y[w(0x112)](W=>{const b=w;if(W[b(0xed)]>=0x1&&!W[0x0]['error'])this[b(0xd3)](W,{'type':b(0x13c),'name':W[0x0][b(0x10e)]['id']},k);}),this[w(0x12d)]([...S[w(0xd0)](),...Y[w(0xd0)]()],k);}}catch(W){error(w(0xf3)+W[w(0x129)]);}}),g=getCommand(!![])['name'](F(0xd1))['description']('Port-forwarding\x20for\x20the\x20specified\x20service')[F(0xe7)](F(0xf1),'Project\x20for\x20forwarding')[F(0xe7)](F(0x111),F(0xfa))[F(0xe7)](F(0xda),'Instance\x20to\x20forward')[F(0xe7)](F(0x122),this[F(0x107)],![])[F(0xe7)](F(0x125),this[F(0x130)],![])['action'](async({noDefaults:H,projectId:u,serviceId:k,instanceId:C,skipHostnames:o})=>{const K=F;assertContextExisting(this[K(0x104)]);const T=this[K(0x10a)](o),S=H?undefined:c[K(0xe2)](),Y=u||S||await j[K(0x106)](),P=H?undefined:c[K(0xe6)](),J=k||P||await j[K(0xff)](Y)();console['log'](K(0xf0)+a15j[K(0x121)](J)+K(0x118)+a15j[K(0x121)](Y));try{const s=await T[K(0xfc)]({'projectId':Y,'serviceId':J,'instanceId':C},o);this[K(0xd3)](s,{'name':J,'type':K(0xd1),'instanceId':C},o),this['printHostsFileHint'](s,o);}catch(W){error(K(0xf3)+W[K(0x129)]);}}),r=getCommand(!![])['name'](F(0x13c))[F(0x110)](F(0xfe))[F(0xe7)](F(0xf1),F(0x12c))[F(0xe7)](F(0xdc),F(0xe0))[F(0xe7)](F(0x125),this[F(0x130)],![])[F(0xd6)](async({noDefaults:H,projectId:u,addonId:k,skipHostnames:C})=>{const G=F;assertContextExisting(this[G(0x104)]);const o=this[G(0x10a)](C),T=H?undefined:c[G(0xe2)](),S=u||T||await j['askForProject'](),Y=k||await j[G(0xfb)](S)();console['log'](G(0x10f)+a15j['bold'](Y)+'\x20in\x20project\x20'+a15j[G(0x121)](S));try{const P={'projectId':S,'addonId':Y},J=await o[G(0x135)](P,C);this[G(0xd3)](J,{'name':Y,'type':G(0x13c)},C),this[G(0x12d)](J,C);}catch(s){error(G(0xf3)+s[G(0x129)]);}});this['portFwdCmd'][F(0x11c)](n),this[F(0x139)]['addCommand'](g),this[F(0x139)][F(0x11c)](r);}[a15Z(0x10a)](c=![]){const D=a15Z,v=this[D(0x104)][D(0xd9)];if(!c){const j=v[D(0xf9)]();if(j[D(0x12f)])throw new Error(j[D(0x129)]);}return v['on'](D(0xd2),(n,g)=>{const I=D,r=a15j[I(0x121)](g['type']+'\x20\x27'+g['id']+'\x27'),H=g[I(0xdf)][I(0xed)]>0x0;warning(I(0x120)+g[I(0x11f)]+':'+g[I(0xf5)]+I(0xf6)+r),c&&H&&warning('\x20\x20If\x20you\x20have\x20added\x20entries\x20to\x20your\x20hosts\x20file,\x20it\x20is\x20recommended\x20to\x20remove\x20them\x20again\x20now.');}),v['on'](D(0x109),(n,g,r)=>{const N=D;warning(N(0x105)+g[N(0x11f)]+':'+g[N(0xf5)]+N(0xeb)+r?.[N(0x129)]+'\x22');}),process['on'](D(0xf7),async()=>{const d=D;try{await v[d(0xd7)]();}catch(n){error(d(0x13a)+n[d(0x129)]);}finally{process[d(0x123)]();}}),v;}[a15Z(0xd3)](c,v,j=![]){const i=a15Z,{type:n,name:g,instanceId:r}=v;if(c[i(0xed)]<=0x0){const C=i(0x12b)+v['type']+i(0x11e);warning('\x20\x20\x20No\x20running\x20container\x20found\x20for\x20'+n+'\x20'+a15j['bold'](g)+'.\x20'+C);return;}const H=groupBy(c,i(0x10d)),u=o=>'\x20('+(o[i(0x119)]?o['portName']+i(0x100):'')+o[i(0x101)]+')';function k(o,T=0x2){const M=i;if(!j){const S=o[M(0x101)]===M(0xee)?M(0xde):'';o[M(0xdf)]['forEach'](Y=>{const L=M;console[L(0x11d)](repeat('\x20',T)+'-\x20'+S+Y+':'+o[L(0xf5)]);});}}Object[i(0xe4)](H)[i(0x112)](([o,T])=>{const p=i,S=r?'>\x20Instance\x20\x27'+a15j[p(0xea)][p(0x121)](r)+p(0x115)+n+'\x20\x27'+a15j[p(0xea)][p(0x121)](o)+'\x27':'>\x20'+capitalize(n)+'\x20\x27'+a15j[p(0xea)][p(0x121)](o)+'\x27';if(n===p(0x13c)){if(T[p(0xed)]===0x1){const Y=T[0x0];if(Y[p(0x12f)]){error(p(0x133)+o+':\x20'+Y['error'][p(0x129)]);return;}const e=Y[p(0x10e)],P=!j?'\x20'+a15j['reset']('with\x20hostname:\x20'+e[p(0xdf)][p(0x126)](',')):'';success(S+p(0xfd)+e[p(0x11f)]+':'+e[p(0xf5)]+u(e)+P);}else{const J=uniqBy(T,s=>s?.[p(0x10e)]?.[p(0xdf)]?.[p(0x126)](','))[p(0xed)]>0x1;success(S+p(0x102)+(J?p(0x108):'ports')+':'),T[p(0x112)](s=>{const O=p;if(s['error']){error('Error\x20occured\x20while\x20trying\x20to\x20forward\x20'+o+':\x20'+s[O(0x12f)][O(0x129)]);return;}const W=s[O(0x10e)],t=!j?',\x20hostname:\x20'+W[O(0xdf)]['join'](','):'';console[O(0x11d)]('\x20\x20-\x20Address:\x20'+W[O(0x11f)]+':'+W['port']+u(W)+t);});}}if(n===p(0xd1)){if(T[p(0xed)]===0x1){const s=T[0x0];if(s[p(0x12f)]){error('Error\x20occured\x20while\x20trying\x20to\x20forward\x20'+o+':\x20'+s[p(0x12f)][p(0x129)]);return;}const W=s[p(0x10e)],t=!j?'\x20with\x20these\x20hostnames:':':',m=W[p(0x11f)]+':'+W['port']+u(W);success(S+p(0xfd)+m+t),k(W);}else success(S+'\x20is\x20exposed\x20on\x20'+T[0x0]?.[p(0x10e)]?.[p(0x11f)]+'\x20with\x20multiple\x20ports:'),T[p(0x112)](V=>{const q=p;if(V[q(0x12f)]){error(q(0x133)+o+':\x20'+V[q(0x12f)][q(0x129)]);return;}const f=V['data'];success(q(0x138)+f[q(0xf5)]+u(f)),k(f,0x4);});}});}[a15Z(0x12d)](c,v=![]){const Q=a15Z;if(v){const j=c[Q(0x10c)](o=>o[Q(0x10e)])[Q(0x113)](o=>o!==undefined),n=process?.[Q(0x13d)]===Q(0x136),g=a15n['platform']()==='darwin',r=n?Q(0xd8):Q(0xe1),H=a15j[Q(0x121)](Q(0xe9)),u=g?EOL+Q(0x131)+H+Q(0x116):undefined;let k=Q(0xd4)+H+Q(0x10b)+Q(0x125)+'\x20flag\x20or\x20manually\x20append\x20following\x20entry\x20to\x20your\x20hosts\x20file\x20('+r+'):';u!==undefined&&warning(u??'');warning(k);const C=j['map'](o=>o[Q(0x11f)]+'\x20\x20\x20\x20\x20\x20\x20\x20\x20'+o[Q(0xdf)]['join']('\x20'));console[Q(0x11d)](uniq(C)['join'](EOL)),console['log']();}}}
1
+ const a15j=a15V;(function(e,V){const Y=a15V,b=e();while(!![]){try{const G=parseInt(Y(0x176))/0x1*(-parseInt(Y(0x185))/0x2)+-parseInt(Y(0x182))/0x3+parseInt(Y(0x17b))/0x4*(parseInt(Y(0x1c1))/0x5)+parseInt(Y(0x183))/0x6+parseInt(Y(0x187))/0x7+-parseInt(Y(0x168))/0x8+parseInt(Y(0x159))/0x9;if(G===V)break;else b['push'](b['shift']());}catch(a){b['push'](b['shift']());}}}(a15e,0x925b5));import{ApiClient}from'@northflank/js-client';function a15e(){const i=['printHostsFileHint','Services:','No\x20services\x20and\x20addons\x20to\x20forward\x20found\x20in\x20project\x20','join','option','Cleaning\x20up\x20open\x20connections\x20failed:\x20','green','16691112vPhTqU','Team\x20for\x20forwarding','Forwarding\x20','getProxyForwarder','entries','\x20is\x20running\x20and\x20reachable\x20and\x20that\x20a\x20port\x20is\x20defined\x20on\x20the\x20networking\x20section.','data.id','portFwdCmd','bold','Forwarding\x20addon\x20','service','askForProjectContext','action',',\x20hostname:\x20','skipHostnamesText','8564096SPAWXc','--service\x20--serviceId\x20[NAME]','hosts','name','\x20with\x20these\x20hostnames:','askForProject','port','\x20with\x20multiple\x20ports:','contextProvider','askForAddon','alias','SIGINT','\x20service\x20ports','\x20\x20-\x20port\x20','101685OLXfvE','askForTeam','error','askForService','--team\x20--teamId\x20[TEAMID]','4hYNnCt','tunnel-close','hostnames','message','Port-forwarding\x20for\x20all\x20services\x20and\x20addons\x20in\x20the\x20given\x20project','Running\x20on\x20macOS\x20in\x20','noDefaultsText','2060058gsiTao','4964376wIFoSa','Running\x20in\x20','14EBSUNR','--skipHostnames','1476111BEOsem','--project\x20--projectId\x20[NAME]','flat','getTokenScope','\x20addon\x20ports','log','ports','forwardProject','reset','/etc/hosts','Failed:\x20','greenBright','data','platform','type','forwardAddon','skipHostnames','with\x20hostname:\x20','http://','addCommand','darwin','>\x20Instance\x20\x27','Error\x20occured\x20while\x20trying\x20to\x20forward\x20','\x27\x20of\x20','Don\x27t\x20use\x20context\x20default\x20values,\x20explicitly\x20use\x20options\x20or\x20ask.','Instance\x20to\x20forward','forwardService','\x20and\x20','Only\x20expose\x20on\x20IP\x20address,\x20not\x20on\x20hostnames.\x20With\x20this\x20option,\x20no\x20root\x20permissions\x20are\x20required.','length','Service\x20to\x20forward','win32','canExecuteWithHostnames','Port-forwarding\x20for\x20Northflank\x20services\x20and\x20addons.','Project\x20for\x20forwarding','HTTP','flatMap','addon','printForwardingInfo','C:/Windows/System32/drivers/etc/hosts','description','forEach','apiClient','forwarding','getCurrentProjectName','Forwarding\x20service\x20','Connection\x20error\x20occurred\x20when\x20forwarding\x20\x27','protocol','org','address','\x20to\x20','filter','\x20\x20\x20No\x20running\x20container\x20found\x20for\x20','Stop\x20forwarding\x20traffic\x20from\x20','\x20is\x20exposed\x20on\x20','\x20\x20\x20\x20\x20\x20\x20\x20\x20','getBaseCommand','Addon\x20to\x20forward','878165YfssBN','\x20\x20-\x20Address:\x20','--instance\x20--instanceId\x20[NAME]'];a15e=function(){return i;};return a15e();}function a15V(e,V){const b=a15e();return a15V=function(G,a){G=G-0x158;let m=b[G];return m;},a15V(e,V);}import a15b from'chalk';import{assertContextExisting,customUserAgent,error,getCommand,success,warning}from'../utils.js';import{InquirerHelper}from'../inquirer-helper.js';import*as a15G from'os';import{uniqBy,uniq,repeat,groupBy,capitalize}from'lodash-es';import{EOL}from'os';export class CliPortForward{[a15j(0x160)];[a15j(0x1b1)];[a15j(0x181)]=a15j(0x19f);[a15j(0x167)]=a15j(0x1a3);constructor(e,V){const d=a15j;this[d(0x1b1)]=new ApiClient(e,{'throwErrorOnHttpErrorCode':!![],'customUserAgent':customUserAgent,'agent':V});const b=new InquirerHelper(this[d(0x1b1)]);this['portFwdCmd']=getCommand()[d(0x16b)]('forward')[d(0x172)]('fwd')[d(0x1af)](d(0x1a8));const G=this[d(0x1bf)]()[d(0x16b)]('all')['description'](d(0x17f))[d(0x1c8)]('--noDefaults',this[d(0x181)],![])['option'](d(0x186),this[d(0x167)],![])['action'](async({noDefaults:O,teamId:E,projectId:W,skipHostnames:M})=>{const B=d;assertContextExisting(this[B(0x1b1)]);const Q=this[B(0x15c)](M),k=O?undefined:e[B(0x1b3)](),{projectId:r,teamId:U}=await this['askForProjectContext'](e,b,E,W,k);try{const {services:S,addons:z}=await Q[B(0x18e)]({'teamId':U,'projectId':r},M);if(S[B(0x1a4)]+z[B(0x1a4)]<=0x0)warning(B(0x1c6)+a15b[B(0x161)](r));else{const x=S[B(0x1ba)](N=>N[B(0x1a4)]>0x0)[B(0x1a4)],o=z[B(0x1ba)](N=>N[B(0x1a4)]>0x0)[B(0x1a4)],K='\x20in\x20project\x20'+a15b['bold'](r);console['log'](B(0x15b)+a15b[B(0x158)][B(0x161)](x+B(0x174))+B(0x1a2)+a15b[B(0x158)][B(0x161)](o+B(0x18b))+K),console['log'](),console['log'](a15b[B(0x161)](B(0x1c5))),S['forEach'](N=>{const I=B;if(N[I(0x1a4)]>=0x1&&!N[0x0][I(0x178)])this['printForwardingInfo'](N,{'type':'service','name':N[0x0][I(0x193)]['id']},M);}),console[B(0x18c)](a15b[B(0x161)]('Addons:')),z[B(0x1b0)](N=>{const R=B;if(N['length']>=0x1&&!N[0x0][R(0x178)])this['printForwardingInfo'](N,{'type':R(0x1ac),'name':N[0x0]['data']['id']},M);}),this['printHostsFileHint']([...S[B(0x189)](),...z['flat']()],M);}}catch(N){error(B(0x191)+N[B(0x17e)]);}}),a=this['getBaseCommand']()[d(0x16b)]('service')['description']('Port-forwarding\x20for\x20the\x20specified\x20service')[d(0x1c8)](d(0x169),d(0x1a5))[d(0x1c8)](d(0x1c3),d(0x1a0))[d(0x1c8)]('--noDefaults',this[d(0x181)],![])['option']('--skipHostnames',this[d(0x167)],![])[d(0x165)](async({noDefaults:O,teamId:E,projectId:W,serviceId:M,instanceId:Q,skipHostnames:k})=>{const c=d;assertContextExisting(this[c(0x1b1)]);const r=this[c(0x15c)](k),U=O?undefined:e[c(0x1b3)](),{projectId:S,teamId:z}=await this[c(0x164)](e,b,W,E,U),x=O?undefined:e['getCurrentServiceName'](),o=M||x||await b[c(0x179)](S,z)();console[c(0x18c)](c(0x1b4)+a15b[c(0x161)](o)+'\x20in\x20project\x20'+a15b[c(0x161)](S));try{const K=await r[c(0x1a1)]({'teamId':z,'projectId':S,'serviceId':o,'instanceId':Q},k);this['printForwardingInfo'](K,{'name':o,'type':c(0x163),'instanceId':Q},k),this['printHostsFileHint'](K,k);}catch(N){error(c(0x191)+N[c(0x17e)]);}}),m=this[d(0x1bf)]()[d(0x16b)](d(0x1ac))[d(0x1af)]('Port-forwarding\x20for\x20the\x20specified\x20addon')[d(0x1c8)]('--addon\x20--addonId\x20[NAME]',d(0x1c0))[d(0x1c8)](d(0x186),this[d(0x167)],![])[d(0x165)](async({noDefaults:O,teamId:E,projectId:W,addonId:M,skipHostnames:Q})=>{const y=d;assertContextExisting(this['apiClient']);const k=this[y(0x15c)](Q),r=O?undefined:e[y(0x1b3)](),{projectId:U,teamId:S}=await this['askForProjectContext'](e,b,W,E,r),z=M||await b[y(0x171)](U,S)();console[y(0x18c)](y(0x162)+a15b[y(0x161)](z)+'\x20in\x20project\x20'+a15b[y(0x161)](U));try{const x={'teamId':S,'projectId':U,'addonId':z},o=await k[y(0x196)](x,Q);this[y(0x1ad)](o,{'name':z,'type':y(0x1ac)},Q),this[y(0x1c4)](o,Q);}catch(K){error('Failed:\x20'+K['message']);}});this[d(0x160)][d(0x19a)](G),this['portFwdCmd'][d(0x19a)](a),this['portFwdCmd'][d(0x19a)](m);}['getBaseCommand']=()=>{const X=a15j,e=getCommand(!![])[X(0x1c8)](X(0x188),X(0x1a9));return this[X(0x1b1)][X(0x170)][X(0x18a)]()===X(0x1b7)&&e[X(0x1c8)](X(0x17a),X(0x15a)),e;};['getProxyForwarder'](e=![]){const Z=a15j,V=this[Z(0x1b1)][Z(0x1b2)];if(!e){const b=V[Z(0x1a7)]();if(b[Z(0x178)])throw new Error(b[Z(0x17e)]);}return V['on'](Z(0x17c),(G,a)=>{const l=Z,m=a15b[l(0x161)](a[l(0x195)]+'\x20\x27'+a['id']+'\x27'),O=a['hostnames']['length']>0x0;warning(l(0x1bc)+a[l(0x1b8)]+':'+a[l(0x16e)]+l(0x1b9)+m),e&&O&&warning('\x20\x20If\x20you\x20have\x20added\x20entries\x20to\x20your\x20hosts\x20file,\x20it\x20is\x20recommended\x20to\x20remove\x20them\x20again\x20now.');}),V['on']('connection-error',(G,a,m)=>{const T=Z;warning(T(0x1b5)+a[T(0x1b8)]+':'+a[T(0x16e)]+'\x27:\x20\x22'+m?.[T(0x17e)]+'\x22');}),process['on'](Z(0x173),async()=>{const g=Z;try{await V['stop']();}catch(G){error(g(0x1c9)+G[g(0x17e)]);}finally{process['exit']();}}),V;}[a15j(0x1ad)](e,V,b=![]){const p=a15j,{type:G,name:a,instanceId:m}=V;if(e[p(0x1a4)]<=0x0){const M='Please\x20ensure\x20the\x20'+V[p(0x195)]+p(0x15e);warning(p(0x1bb)+G+'\x20'+a15b[p(0x161)](a)+'.\x20'+M);return;}const O=groupBy(e,p(0x15f)),E=Q=>'\x20('+(Q['portName']?Q['portName']+'\x20-\x20':'')+Q['protocol']+')';function W(Q,k=0x2){const C=p;if(!b){const r=Q[C(0x1b6)]===C(0x1aa)?C(0x199):'';Q['hostnames'][C(0x1b0)](U=>{const u=C;console['log'](repeat('\x20',k)+'-\x20'+r+U+':'+Q[u(0x16e)]);});}}Object[p(0x15d)](O)[p(0x1b0)](([Q,k])=>{const L=p,r=m?L(0x19c)+a15b[L(0x192)]['bold'](m)+L(0x19e)+G+'\x20\x27'+a15b[L(0x192)]['bold'](Q)+'\x27':'>\x20'+capitalize(G)+'\x20\x27'+a15b[L(0x192)][L(0x161)](Q)+'\x27';if(G===L(0x1ac)){if(k[L(0x1a4)]===0x1){const U=k[0x0];if(U[L(0x178)]){error(L(0x19d)+Q+':\x20'+U[L(0x178)][L(0x17e)]);return;}const S=U['data'],z=!b?'\x20'+a15b[L(0x18f)](L(0x198)+S[L(0x17d)][L(0x1c7)](',')):'';success(r+L(0x1bd)+S['address']+':'+S['port']+E(S)+z);}else{const x=uniqBy(k,o=>o?.['data']?.[L(0x17d)]?.['join'](','))[L(0x1a4)]>0x1;success(r+'\x20is\x20exposed\x20with\x20multiple\x20'+(x?L(0x16a):L(0x18d))+':'),k['forEach'](o=>{const q=L;if(o[q(0x178)]){error('Error\x20occured\x20while\x20trying\x20to\x20forward\x20'+Q+':\x20'+o[q(0x178)][q(0x17e)]);return;}const K=o['data'],N=!b?q(0x166)+K['hostnames']['join'](','):'';console[q(0x18c)](q(0x1c2)+K['address']+':'+K[q(0x16e)]+E(K)+N);});}}if(G===L(0x163)){if(k['length']===0x1){const o=k[0x0];if(o[L(0x178)]){error('Error\x20occured\x20while\x20trying\x20to\x20forward\x20'+Q+':\x20'+o[L(0x178)][L(0x17e)]);return;}const K=o[L(0x193)],N=!b?L(0x16c):':',J=K['address']+':'+K[L(0x16e)]+E(K);success(r+L(0x1bd)+J+N),W(K);}else success(r+L(0x1bd)+k[0x0]?.[L(0x193)]?.[L(0x1b8)]+L(0x16f)),k[L(0x1b0)](f=>{const s=L;if(f[s(0x178)]){error('Error\x20occured\x20while\x20trying\x20to\x20forward\x20'+Q+':\x20'+f[s(0x178)][s(0x17e)]);return;}const D=f[s(0x193)];success(s(0x175)+D[s(0x16e)]+E(D)),W(D,0x4);});}});}[a15j(0x1c4)](e,V=![]){const F=a15j;if(V){const b=e[F(0x1ab)](Q=>Q[F(0x193)])['filter'](Q=>Q!==undefined),G=process?.[F(0x194)]===F(0x1a6),a=a15G['platform']()===F(0x19b),m=G?F(0x1ae):F(0x190),O=a15b[F(0x161)](F(0x197)),E=a?EOL+F(0x180)+O+'\x20mode:\x20the\x20locally\x20forwarded\x20port\x20differs\x20from\x20the\x20actual\x20port\x20on\x20the\x20forwarded\x20service/addon.':undefined;let W=F(0x184)+O+'\x20mode.\x20If\x20hostname\x20forwarding\x20is\x20required,\x20remove\x20'+F(0x186)+'\x20flag\x20or\x20manually\x20append\x20following\x20entry\x20to\x20your\x20hosts\x20file\x20('+m+'):';E!==undefined&&warning(E??'');warning(W);const M=b['map'](Q=>Q[F(0x1b8)]+F(0x1be)+Q[F(0x17d)][F(0x1c7)]('\x20'));console[F(0x18c)](uniq(M)[F(0x1c7)](EOL)),console['log']();}}['askForProjectContext']=async(e,V,b,G,a)=>{const H=a15j,m=e[H(0x18a)]()==='org'?G??await V[H(0x177)]():undefined,O=b||a||await V[H(0x16d)](m)();return{'teamId':m,'projectId':O};};}
package/dist/ssh/index.js CHANGED
@@ -1 +1 @@
1
- const a16D=a16v;function a16v(c,v){const j=a16c();return a16v=function(n,g){n=n-0x1b5;let r=j[n];return r;},a16v(c,v);}(function(c,v){const G=a16v,j=c();while(!![]){try{const n=-parseInt(G(0x1cf))/0x1+parseInt(G(0x1d1))/0x2*(-parseInt(G(0x1eb))/0x3)+parseInt(G(0x202))/0x4*(-parseInt(G(0x205))/0x5)+parseInt(G(0x1f4))/0x6*(parseInt(G(0x1d8))/0x7)+-parseInt(G(0x1be))/0x8+parseInt(G(0x203))/0x9+parseInt(G(0x1d7))/0xa*(parseInt(G(0x1f1))/0xb);if(n===v)break;else j['push'](j['shift']());}catch(g){j['push'](j['shift']());}}}(a16c,0xaf0f5));import{ApiClient}from'@northflank/js-client';import{assertContextExisting,customUserAgent,error,getCommand,success,warning}from'../utils.js';import{InquirerHelper}from'../inquirer-helper.js';import{spawn}from'child_process';import{execFile}from'child_process';import{promisify}from'util';import a16j from'chalk';function a16c(){const Q=['\x20\x20>\x20RSYNC:\x20\x20\x09','execFileAsync','Ctrl+C\x20-\x20SSH\x20session\x20ended','26697210IyDdBt','5831nHuCIh','\x20to\x20ssh\x20into','ssh','blackBright','charAt',',\x20stop\x20with\x20Ctrl+C','uncaughtException','option','toUpperCase','error','askForService','RemoteCommand=su\x20','SIGINT','\x20-l','-tt','Replicate\x20','forwarding','Use\x20specific\x20username\x20for\x20SSH\x20connection','--instance\x20--instanceName\x20[NAME]','6yJcTBL','action','--proxyOnly','SSH\x20session\x20ended.','Project\x20of\x20the\x20','Only\x20startup\x20SSH\x20proxy\x20without\x20opening\x20an\x20SSH\x20terminal\x20session.','11VGxsAH','\x20\x20>\x20SCP:\x20\x20\x09','SSH\x20binary\x20not\x20found.\x20Please\x20install\x20OpenSSH.','678LoXnnp','apiClient','scp\x20-P\x20','SSH\x20exited\x20with\x20code:\x20','inherit','--project\x20--projectId\x20[NAME]','Id\x20[NAME]','--user\x20[USER]','isTTY','trim','sshCmd','withServiceForwarding','name',':/remote/path/','4MiZVce','2803545zcegRR','\x20-p\x20','4457270SzytlW','ssh\x20','--noDefaults','\x20file.txt\x20','Don\x27t\x20use\x20context\x20default\x20values,\x20explicitly\x20use\x20options\x20or\x20ask.','stdin','findSSH','slice','push','log','Establish\x20SSH\x20connectivity\x20to\x20Northflank\x20','.\x20Creates\x20an\x20SSH\x20terminal\x20session\x20by\x20default.','askForProject','addCommand','\x20\x20>\x20SFTP:\x20\x20\x09','288840TIHOWa','root','SSH\x20for\x20Northflank\x20services\x20and\x20jobs.','toString','startSSH','exit','service','rsync\x20-avz\x20-e\x20\x22ssh\x20-p\x20','description','find','--useHostnames','\x20\x20>\x20SSH\x20session:','\x20hostnames\x20on\x20local\x20machine.\x20Requires\x20sudo\x20permissions','data','Instance\x20to\x20exec\x20into\x20(random\x20instance\x20will\x20be\x20chosen\x20if\x20not\x20specified)','StrictHostKeyChecking=no','SSH\x20proxy\x20started\x20on\x20endpoint:\x20','75217RzVrkM','No\x20SSH\x20endpoint\x20found.\x20Ensure\x20your\x20service\x20has\x20SSH\x20enabled','1355534XNtesJ','\x20--','kill'];a16c=function(){return Q;};return a16c();}export class CliSsh{['sshCmd'];[a16D(0x1f5)];constructor(c,v){const I=a16D;this[I(0x1f5)]=new ApiClient(c,{'throwErrorOnHttpErrorCode':!![],'customUserAgent':customUserAgent,'agent':v});const j=new InquirerHelper(this[I(0x1f5)]);this['sshCmd']=getCommand(!![])[I(0x200)](I(0x1da))[I(0x1c6)](I(0x1c0));const n=I(0x1c4),g=getCommand(!![])['name'](n)[I(0x1c6)](I(0x1b9)+n+I(0x1ba))['option'](I(0x1f9),I(0x1ef)+n)[I(0x1df)]('--'+n+I(0x1d2)+n+I(0x1fa),n[I(0x1dc)](0x0)[I(0x1e0)]()+n[I(0x1b6)](0x1)+I(0x1d9))[I(0x1df)](I(0x1ea),I(0x1cc))[I(0x1df)](I(0x1ed),I(0x1f0),![])[I(0x1df)](I(0x1c8),I(0x1e7)+n+I(0x1ca),![])[I(0x1df)](I(0x1fb),I(0x1e9))['option'](I(0x207),I(0x209),![]),r=g[I(0x1ec)](async H=>{const N=I,{noDefaults:u,projectId:k,serviceId:C,instanceName:o,proxyOnly:T,useHostnames:S}=H,{user:user=N(0x1bf),quiet:Y}=H;assertContextExisting(this[N(0x1f5)]);try{const P=u?undefined:c['getCurrentProjectName'](),J=k||P||await j[N(0x1bb)](),s=u?undefined:c['getCurrentServiceName'](),W=C||s||await j[N(0x1e2)](J)(),t=process[N(0x20a)][N(0x1fc)],m=t&&!T,V={'projectId':J,'serviceId':W,'instanceId':o,'portsFilter':[0x16]};await this[N(0x1f5)][N(0x1e8)][N(0x1ff)](V,async f=>{const d=N,l=f[d(0x1c7)](b=>b['data']?.['portName']==='default-ssh');if(l===undefined)throw new Error(d(0x1d0));if(l?.['error']!==undefined||l?.[d(0x1cb)]===undefined)throw new Error('Error\x20trying\x20to\x20forward:\x20'+(l?.['error']?.['message']??'unknown\x20error'));const {address:Z,port:F,hostnames:w}=l['data'],x=S?w[0x0]??Z:Z;m?(!Y&&success('SSH\x20proxy\x20started\x20on\x20endpoint:\x20'+(x+':'+F)+',\x20stop\x20with\x20Ctrl+D'),await this[d(0x1c2)]({'address':x,'port':F,'user':user})):(!Y?(success(d(0x1ce)+(x+':'+F)+d(0x1dd)),console['log']('Use\x20with\x20any\x20SSH\x20compatible\x20client.\x20Example\x20usages:'),console[d(0x1b8)](d(0x1c9)+a16j[d(0x1db)](d(0x206)+user+'@'+x+d(0x204)+F)),console['log'](d(0x1bd)+a16j[d(0x1db)]('sftp\x20-P\x20'+F+'\x20'+user+'@'+x)),console[d(0x1b8)](d(0x1d4)+a16j[d(0x1db)](d(0x1c5)+F+'\x22\x20./data/\x20'+user+'@'+x+':/rsync-test/')),console['log'](d(0x1f2)+a16j[d(0x1db)](d(0x1f6)+F+d(0x208)+user+'@'+x+d(0x201)))):console[d(0x1b8)](user,x,F),await new Promise((b,K)=>{const i=d;process['on'](i(0x1e4),()=>{const M=i;if(!Y)success(M(0x1d6));b();}),process['on'](i(0x1de),K);}));},!S);}catch(f){error(''+f['message']);}finally{process[N(0x1c3)]();}});this[I(0x1fe)][I(0x1bc)](r);}['execFileAsync']=promisify(execFile);async[a16D(0x1b5)](){const L=a16D;try{const {stdout:c}=await this[L(0x1d5)]('which',[L(0x1da)]);return c[L(0x1fd)]();}catch{const v=[L(0x1da),'/usr/bin/ssh','/usr/local/bin/ssh','C:\x5cWindows\x5cSystem32\x5cOpenSSH\x5cssh.exe'];for(const j of v){try{return await this[L(0x1d5)](j,['-V']),j;}catch{}}return null;}}async[a16D(0x1c2)](c){const p=a16D,v=await this['findSSH']();if(!v)throw new Error(p(0x1f3));if(!process[p(0x20a)][p(0x1fc)])throw new Error('Must\x20be\x20run\x20in\x20an\x20interactive\x20terminal\x20(TTY\x20required).');const {address:j,port:port=0x16,user:user=p(0x1bf),args:args=[],trusted:trusted=!![]}=c,n=[];trusted&&n[p(0x1b7)]('-o',p(0x1cd),'-o','UserKnownHostsFile=/dev/null','-o','LogLevel=ERROR');user!=='root'&&n[p(0x1b7)]('-o',p(0x1e3)+user+p(0x1e5),'-o','RequestTTY=yes');const g=spawn(v,[p(0x1e6),'-p',port[p(0x1c1)](),'-l',p(0x1bf),...n,...args,j],{'stdio':p(0x1f8)});await new Promise((r,H)=>{const q=p;g['on']('close',(u,k)=>{const O=a16v;if(k)warning('SSH\x20killed\x20by\x20signal:\x20'+k);else u!==0x0?warning(O(0x1f7)+u):success(O(0x1ee));r(u);}),g['on'](q(0x1e1),u=>{H(new Error('Failed\x20to\x20spawn\x20SSH\x20command:\x20'+u['message']));}),process['on'](q(0x1e4),()=>g[q(0x1d3)]('SIGINT')),process['on']('SIGTERM',()=>g[q(0x1d3)]('SIGTERM'));});}}
1
+ const a16l=a16V;(function(e,V){const Z=a16V,b=e();while(!![]){try{const G=parseInt(Z(0x172))/0x1+parseInt(Z(0x17f))/0x2+-parseInt(Z(0x16f))/0x3+-parseInt(Z(0x177))/0x4*(-parseInt(Z(0x199))/0x5)+-parseInt(Z(0x191))/0x6*(-parseInt(Z(0x171))/0x7)+-parseInt(Z(0x155))/0x8+-parseInt(Z(0x166))/0x9;if(G===V)break;else b['push'](b['shift']());}catch(a){b['push'](b['shift']());}}}(a16e,0x9f95c));function a16e(){const i=['slice','action','message','which','forwarding','RequestTTY=yes','\x20\x20>\x20SSH\x20session:','log','Id\x20[NAME]','\x20file.txt\x20',',\x20stop\x20with\x20Ctrl+C','Ctrl+C\x20received\x20-\x20Terminating\x20SSH\x20proxy...',',\x20stop\x20with\x20Ctrl+D','6054520EWznwx','unknown\x20error','apiClient','Establish\x20SSH\x20connectivity\x20to\x20Northflank\x20','data','ssh','askForProject','org','askForTeam','kill','Use\x20specific\x20username\x20for\x20SSH\x20connection','SSH\x20binary\x20not\x20found.\x20Please\x20install\x20OpenSSH.','findSSH','Unable\x20to\x20initiate\x20SSH\x20tunnel.\x20Ensure\x20your\x20service\x20is\x20running\x20and\x20has\x20SSH\x20enabled','Error\x20trying\x20to\x20forward:\x20','startSSH','/usr/local/bin/ssh','6463458XDqkKa','sftp\x20-P\x20','\x20\x20>\x20RSYNC:\x20\x20\x09','trim','-tt','\x20hostnames\x20on\x20local\x20machine.\x20Requires\x20sudo\x20permissions','Use\x20with\x20any\x20SSH\x20compatible\x20client.\x20Example\x20usages:','inherit','blackBright','1655664Yuynnc','find','504hXDJkM','563486zzJQcX','option','portName','description','\x20\x20>\x20SCP:\x20\x20\x09','291752NimNIh','--proxyOnly','withServiceForwarding','scp\x20-P\x20','charAt','Instance\x20to\x20use\x20for\x20SSH\x20(random\x20instance\x20will\x20be\x20chosen\x20if\x20not\x20specified)','isTTY','error','1155466ICILHn','uncaughtException','stdin','service','Team\x20id','\x20--','Failed\x20to\x20spawn\x20SSH\x20command:\x20','default-ssh','Replicate\x20','askForService','getCurrentServiceName','askForContainer','Don\x27t\x20use\x20context\x20default\x20values,\x20explicitly\x20use\x20options\x20or\x20ask.','C:\x5cWindows\x5cSystem32\x5cOpenSSH\x5cssh.exe','contextProvider','\x20-l','--project\x20--projectId\x20[NAME]','execFileAsync','73572QVfpVa','Must\x20be\x20run\x20in\x20an\x20interactive\x20terminal\x20(TTY\x20required).','getCurrentProjectName','askForProjectContext','root','--user\x20[USER]','ssh\x20','sshCmd','45mMadGa','SIGINT','SSH\x20proxy\x20started\x20on\x20endpoint:\x20','--instance\x20--instanceName\x20[NAME]','--noDefaults','\x20to\x20ssh\x20into','close','rsync\x20-avz\x20-e\x20\x22ssh\x20-p\x20','SIGTERM','name','--team\x20--teamId\x20[TEAMID]','addCommand'];a16e=function(){return i;};return a16e();}function a16V(e,V){const b=a16e();return a16V=function(G,a){G=G-0x141;let m=b[G];return m;},a16V(e,V);}import{ApiClient}from'@northflank/js-client';import{assertContextExisting,customUserAgent,error,getCommand,success,warning}from'../utils.js';import{InquirerHelper}from'../inquirer-helper.js';import{spawn}from'child_process';import{execFile}from'child_process';import{promisify}from'util';import a16b from'chalk';export class CliSsh{['sshCmd'];[a16l(0x157)];constructor(e,V){const T=a16l;this[T(0x157)]=new ApiClient(e,{'throwErrorOnHttpErrorCode':!![],'customUserAgent':customUserAgent,'agent':V});const b=new InquirerHelper(this['apiClient']);this[T(0x198)]=getCommand(!![])[T(0x145)](T(0x15a))[T(0x175)]('SSH\x20for\x20Northflank\x20services\x20and\x20jobs.');const G=T(0x182),a=getCommand(!![])['name'](G)[T(0x175)](T(0x158)+G+'.\x20Creates\x20an\x20SSH\x20terminal\x20session\x20by\x20default.')[T(0x173)](T(0x18f),'Project\x20of\x20the\x20'+G)[T(0x173)]('--'+G+T(0x184)+G+T(0x150),G[T(0x17b)](0x0)['toUpperCase']()+G[T(0x148)](0x1)+T(0x141))[T(0x173)](T(0x19c),T(0x17c))[T(0x173)](T(0x178),'Only\x20startup\x20SSH\x20proxy\x20without\x20opening\x20an\x20SSH\x20terminal\x20session.',![])[T(0x173)]('--useHostnames',T(0x187)+G+T(0x16b),![])[T(0x173)](T(0x196),T(0x15f))[T(0x173)](T(0x19d),T(0x18b),![]);this[T(0x157)][T(0x18d)]['getTokenScope']()===T(0x15c)&&a[T(0x173)](T(0x146),T(0x183));const m=a[T(0x149)](async O=>{const g=T,{noDefaults:E,teamId:W,projectId:M,serviceId:Q,instanceName:k,proxyOnly:r,useHostnames:U}=O,{user:user='root',quiet:S}=O;assertContextExisting(this[g(0x157)]);try{const z=E?undefined:e[g(0x193)](),{projectId:x,teamId:o}=await this[g(0x194)](e,b,M,W,z),K=E?undefined:e[g(0x189)](),N=Q||K||await b[g(0x188)](x,o)(),J=k||await b[g(0x18a)](x,N,undefined,![],o,!![])(),f=process[g(0x181)][g(0x17d)],D=f&&!r,Y={'teamId':o,'projectId':x,'serviceId':N,'instanceId':J,'portsFilter':[0x16]};await this[g(0x157)][g(0x14c)][g(0x179)](Y,async j=>{const p=g,d=j[p(0x170)](y=>y[p(0x159)]?.[p(0x174)]===p(0x186));if(d===undefined)throw new Error(p(0x162));if(d?.[p(0x17e)]!==undefined||d?.[p(0x159)]===undefined)throw new Error(p(0x163)+(d?.[p(0x17e)]?.[p(0x14a)]??p(0x156)));const {address:B,port:I,hostnames:R}=d[p(0x159)],c=U?R[0x0]??B:B;D?(!S&&success(p(0x19b)+(c+':'+I)+p(0x154)),await this['startSSH']({'address':c,'port':I,'user':user})):(!S?(success('SSH\x20proxy\x20started\x20on\x20endpoint:\x20'+(c+':'+I)+p(0x152)),console[p(0x14f)](p(0x16c)),console[p(0x14f)](p(0x14e)+a16b['blackBright'](p(0x197)+user+'@'+c+'\x20-p\x20'+I)),console['log']('\x20\x20>\x20SFTP:\x20\x20\x09'+a16b[p(0x16e)](p(0x167)+I+'\x20'+user+'@'+c)),console[p(0x14f)](p(0x168)+a16b[p(0x16e)](p(0x143)+I+'\x22\x20./data/\x20'+user+'@'+c+':/rsync-test/')),console['log'](p(0x176)+a16b[p(0x16e)](p(0x17a)+I+p(0x151)+user+'@'+c+':/remote/path/'))):console[p(0x14f)](user,c,I),await new Promise((y,X)=>{const u=p;process['on']('SIGINT',()=>{const C=a16V;if(!S)success(C(0x153));y();}),process['on'](u(0x180),X);}));},!U);}catch(j){error(''+j['message']);}finally{process['exit']();}});this[T(0x198)][T(0x147)](m);}[a16l(0x190)]=promisify(execFile);async[a16l(0x161)](){const L=a16l;try{const {stdout:e}=await this[L(0x190)](L(0x14b),[L(0x15a)]);return e[L(0x169)]();}catch{const V=[L(0x15a),'/usr/bin/ssh',L(0x165),L(0x18c)];for(const b of V){try{return await this[L(0x190)](b,['-V']),b;}catch{}}return null;}}async[a16l(0x164)](e){const q=a16l,V=await this[q(0x161)]();if(!V)throw new Error(q(0x160));if(!process[q(0x181)][q(0x17d)])throw new Error(q(0x192));const {address:b,port:port=0x16,user:user=q(0x195),args:args=[],trusted:trusted=!![]}=e,G=[];trusted&&G['push']('-o','StrictHostKeyChecking=no','-o','UserKnownHostsFile=/dev/null','-o','LogLevel=ERROR');user!=='root'&&G['push']('-o','RemoteCommand=su\x20'+user+q(0x18e),'-o',q(0x14d));const a=spawn(V,[q(0x16a),'-p',port['toString'](),'-l',q(0x195),...G,...args,b],{'stdio':q(0x16d)});await new Promise((m,O)=>{const s=q;a['on'](s(0x142),(E,W)=>{if(W)warning('SSH\x20killed\x20by\x20signal:\x20'+W);else E!==0x0?warning('SSH\x20exited\x20with\x20code:\x20'+E):success('SSH\x20session\x20ended.');m(E);}),a['on'](s(0x17e),E=>{const F=s;O(new Error(F(0x185)+E[F(0x14a)]));}),process['on'](s(0x19a),()=>a[s(0x15e)]('SIGINT')),process['on'](s(0x144),()=>a[s(0x15e)]('SIGTERM'));});}['askForProjectContext']=async(e,V,b,G,a)=>{const H=a16l,m=e['getTokenScope']()===H(0x15c)?G??await V[H(0x15d)]():undefined,O=b||a||await V[H(0x15b)](m)();return{'teamId':m,'projectId':O};};}
package/dist/utils.js CHANGED
@@ -1 +1 @@
1
- const a17C=a17v;(function(c,v){const k=a17v,j=c();while(!![]){try{const n=-parseInt(k(0x190))/0x1*(parseInt(k(0x19f))/0x2)+-parseInt(k(0x164))/0x3+parseInt(k(0x16b))/0x4+-parseInt(k(0x18f))/0x5+parseInt(k(0x166))/0x6+-parseInt(k(0x172))/0x7+-parseInt(k(0x162))/0x8*(-parseInt(k(0x17c))/0x9);if(n===v)break;else j['push'](j['shift']());}catch(g){j['push'](j['shift']());}}}(a17c,0x538c4));import a17j from'chalk';import{Command}from'commander';import{ProxyAgent}from'proxy-agent';import a17n from'node-fetch';import{readFileSync}from'fs';import{fileURLToPath}from'url';import{dirname,join}from'path';const __filename=fileURLToPath(import.meta[a17C(0x17f)]),__dirname=dirname(__filename),pgk=JSON[a17C(0x17a)](readFileSync(join(__dirname,a17C(0x185)),a17C(0x189)));export const customUserAgent=a17C(0x165)+pgk?.[a17C(0x170)];export const agent=new ProxyAgent();export const proxyEnvsSet=process['env']['HTTP_PROXY']!==undefined||process[a17C(0x163)]['HTTPS_PROXY']!==undefined;export const decodeJwtPayload=c=>{const T=a17C;try{const v=g=>{const o=a17v,r=g['replace'](/-/g,'+')[o(0x19b)](/_/g,'/')[o(0x17b)](g[o(0x19d)]+(0x4-g[o(0x19d)]%0x4)%0x4,'=');return JSON[o(0x17a)](Buffer['from'](r,o(0x161))[o(0x179)]());},[j,n]=c[T(0x198)]('.');return v(n);}catch(g){return{};}};export async function checkUpdate(c){const Y=a17C;function v(j,n){const S=a17v,g=new Date(Number(j));return g[S(0x19c)](g[S(0x187)]()+n),g;}try{if(v(c[Y(0x177)](),0x1)>new Date())return;const j=pgk[Y(0x170)],{name:n}=pgk;if(!j)return;const g=Y(0x169)+n+Y(0x182),r=await a17n(g,{'agent':agent,'method':Y(0x168),'signal':AbortSignal[Y(0x171)](0x1388)}),H=(await r[Y(0x193)]())[Y(0x170)];needsUpdate(j,H)&&warning('**\x20You\x27re\x20running\x20on\x20version\x20'+j+Y(0x174)+H+'.'+(Y(0x181)+n+Y(0x17d)+n+Y(0x19a))),await c[Y(0x16e)](new Date());}catch(u){}}function needsUpdate(c,v){const e=a17C,j=/(\.0+)+$/,n=c[e(0x19b)](j,'')[e(0x198)]('.'),g=v['replace'](j,'')[e(0x198)]('.');for(let r=0x0;r<Math['min'](n['length'],g[e(0x19d)]);r+=0x1){const H=parseInt(g[r],0xa)-parseInt(n[r],0xa);if(H>0x0)return!![];if(H<0x0)return![];}return g[e(0x19d)]>n[e(0x19d)];}export function error(c){const P=a17C;console[P(0x18a)](a17j[P(0x18e)](P(0x173)+c));}export function warning(c){const J=a17C;console[J(0x18a)](a17j['yellow'](''+c));}export function success(c){const s=a17C;console[s(0x18b)](a17j[s(0x16f)](''+c));}function a17v(c,v){const j=a17c();return a17v=function(n,g){n=n-0x160;let r=j[n];return r;},a17v(c,v);}function a17c(){const l=['getCurrentBaseUrl','enablePositionalOptions','json','then','push','--quiet','--verbose','split','getCurrentToken','\x27\x20**','replace','setDate','length','Do\x20not\x20validate\x20input\x20fields\x20on\x20client\x20side','602356rRYubi','No\x20token\x20in\x20CLI\x20context.\x20Add\x20token\x20with\x20\x27northflank\x20set-token\x27','getTime','base64','79976aFQnOS','env','1187901SXwbgZ','northflank-cli/','601194TDlXDO','resolve','GET','https://registry.npmjs.org/','reduce','2103808IIMSUi',',\x20expected\x20valid\x20date\x20string\x20(example:\x202020-02-02T02:02:02Z)\x20or\x20unix\x20timestamp\x20(example\x201580608922)','Verbose\x20output','setLastUpdateCheck','green','version','timeout','3514406IXNjSW','Failed:\x20',',\x20the\x20latest\x20version\x20of\x20the\x20cli\x20is\x20','helpOption','setUTCSeconds','getLastUpdateCheck','Display\x20help\x20for\x20command','toString','parse','padEnd','1107KDAWGz','\x20-g\x27\x20or\x20\x27yarn\x20global\x20add\x20','allowUnknownOption','url','example:\x202020-02-02T02:02:02Z\x20(date\x20string)\x20or\x201580608922\x20(unix\x20ts)','\x20Consider\x20updating\x20using\x20\x27npm\x20i\x20','/latest','allowExcessArguments','contextProvider','../package.json','addHelpCommand','getDate','No\x20CLI\x20context\x20present.\x20Create\x20context\x20with\x20\x27northflank\x20login\x27','utf-8','error','log','--skipValidation','option','redBright','1571835WriUnb','1zvbjik'];a17c=function(){return l;};return a17c();}export function getCommand(c=![]){const W=a17C,v=new Command();return v[W(0x175)](undefined,W(0x178)),v[W(0x186)](![]),v['storeOptionsAsProperties'](![]),v[W(0x17e)](![]),v[W(0x183)](![]),v[W(0x192)](!![]),c&&(v[W(0x18d)](W(0x197),W(0x16d),![]),v[W(0x18d)](W(0x196),'No\x20console\x20output',![]),v[W(0x18d)](W(0x18c),W(0x19e),![])),v;}export const retry=(c,v=0x32)=>j=>{let n=c;const g=async()=>{try{return await j();}catch(r){if(n<=0x0)throw r;return n-=0x1,await new Promise(H=>setTimeout(()=>H(),v)),g();}};return g();};export const asyncSequential=async(c,v)=>{const t=a17C,j=Promise[t(0x167)]([]);return c[t(0x16a)]((n,g)=>n[t(0x194)](r=>v(g)['then'](H=>{const m=t;return r[m(0x195)](H),r;})),j);};export function isValidJSON(c){try{return JSON['parse'](c);}catch(v){return![];}}export function assertContextExisting(c){const V=a17C;if(c[V(0x184)]['getCurrentContext']()===undefined)throw new Error(V(0x188));if(c[V(0x184)][V(0x191)]()===undefined)throw new Error('No\x20API\x20URL\x20present\x20in\x20context.\x20Create\x20new\x20context\x20with\x20\x27northflank\x20login\x27');if(c[V(0x184)][V(0x199)]()===undefined)throw new Error(V(0x1a0));}export const parseDateInput=c=>{const f=a17C;try{let j=new Date(c);if(isNaN(j[f(0x160)]())){const n=c['length']===0xd?c/0x3e8:c,g=new Date(0x0);g[f(0x176)](n);if(isNaN(g['getTime']()))throw new Error();return g;}return j;}catch(r){throw new Error('Invalid\x20date\x20received:\x20'+c+f(0x16c));}};export const tsHint=a17C(0x180);
1
+ const a17Q=a17V;(function(e,V){const M=a17V,b=e();while(!![]){try{const G=-parseInt(M(0x120))/0x1*(-parseInt(M(0x14a))/0x2)+parseInt(M(0x136))/0x3+parseInt(M(0x132))/0x4+parseInt(M(0x150))/0x5*(parseInt(M(0x12a))/0x6)+parseInt(M(0x12e))/0x7*(-parseInt(M(0x152))/0x8)+parseInt(M(0x158))/0x9+-parseInt(M(0x141))/0xa*(parseInt(M(0x13a))/0xb);if(G===V)break;else b['push'](b['shift']());}catch(a){b['push'](b['shift']());}}}(a17e,0x7e5e3));function a17V(e,V){const b=a17e();return a17V=function(G,a){G=G-0x11a;let m=b[G];return m;},a17V(e,V);}import a17b from'chalk';import{Command}from'commander';import{ProxyAgent}from'proxy-agent';import a17G from'node-fetch';import{readFileSync}from'fs';import{fileURLToPath}from'url';import{dirname,join}from'path';const __filename=fileURLToPath(import.meta['url']),__dirname=dirname(__filename),pgk=JSON[a17Q(0x13c)](readFileSync(join(__dirname,'../package.json'),a17Q(0x153)));export const customUserAgent='northflank-cli/'+pgk?.[a17Q(0x144)];export const agent=new ProxyAgent();export const proxyEnvsSet=process[a17Q(0x151)][a17Q(0x156)]!==undefined||process[a17Q(0x151)]['HTTPS_PROXY']!==undefined;export const decodeJwtPayload=V=>{const r=a17Q;try{const b=m=>{const k=a17V,O=m[k(0x142)](/-/g,'+')[k(0x142)](/_/g,'/')[k(0x155)](m['length']+(0x4-m[k(0x146)]%0x4)%0x4,'=');return JSON[k(0x13c)](Buffer[k(0x123)](O,k(0x128))[k(0x13b)]());},[G,a]=V[r(0x130)]('.');return b(a);}catch(m){return{};}};export async function checkUpdate(V){const S=a17Q;function b(G,a){const U=a17V,m=new Date(Number(G));return m[U(0x137)](m[U(0x154)]()+a),m;}try{if(b(V[S(0x148)](),0x1)>new Date())return;const G=pgk[S(0x144)],{name:a}=pgk;if(!G)return;const m='https://registry.npmjs.org/'+a+'/latest',O=await a17G(m,{'agent':agent,'method':S(0x157),'signal':AbortSignal[S(0x14d)](0x1388)}),E=(await O[S(0x131)]())[S(0x144)];needsUpdate(G,E)&&warning(S(0x14b)+G+S(0x126)+E+'.'+(S(0x140)+a+S(0x13e)+a+S(0x145))),await V[S(0x135)](new Date());}catch(W){}}function needsUpdate(e,V){const z=a17Q,b=/(\.0+)+$/,G=e['replace'](b,'')['split']('.'),a=V['replace'](b,'')['split']('.');for(let m=0x0;m<Math[z(0x121)](G[z(0x146)],a[z(0x146)]);m+=0x1){const O=parseInt(a[m],0xa)-parseInt(G[m],0xa);if(O>0x0)return!![];if(O<0x0)return![];}return a['length']>G[z(0x146)];}export function error(e){const x=a17Q;console[x(0x13d)](a17b[x(0x14e)]('Failed:\x20'+e));}export function warning(e){const o=a17Q;console[o(0x13d)](a17b[o(0x122)](''+e));}export function success(e){const K=a17Q;console[K(0x143)](a17b[K(0x11b)](''+e));}export function getCommand(e=![]){const N=a17Q,V=new Command();return V[N(0x139)](undefined,N(0x129)),V[N(0x127)](![]),V[N(0x11d)](![]),V[N(0x149)](![]),V[N(0x11f)](![]),V[N(0x125)](!![]),e&&(V['option']('--verbose',N(0x159),![]),V['option'](N(0x11a),N(0x12b),![]),V['option'](N(0x12c),'Do\x20not\x20validate\x20input\x20fields\x20on\x20client\x20side',![])),V;}export const retry=(e,V=0x32)=>b=>{let G=e;const a=async()=>{try{return await b();}catch(m){if(G<=0x0)throw m;return G-=0x1,await new Promise(O=>setTimeout(()=>O(),V)),a();}};return a();};export const asyncSequential=async(e,V)=>{const J=a17Q,b=Promise[J(0x134)]([]);return e[J(0x133)]((G,a)=>G[J(0x147)](m=>V(a)[J(0x147)](O=>{const f=J;return m[f(0x14f)](O),m;})),b);};export function isValidJSON(V){const D=a17Q;try{return JSON[D(0x13c)](V);}catch(b){return![];}}export function assertContextExisting(e){const Y=a17Q;if(e[Y(0x13f)][Y(0x124)]()===undefined)throw new Error(Y(0x11c));if(e['contextProvider']['getCurrentBaseUrl']()===undefined)throw new Error(Y(0x12d));if(e[Y(0x13f)]['getCurrentToken']()===undefined)throw new Error('No\x20token\x20in\x20CLI\x20context.\x20Add\x20token\x20with\x20\x27northflank\x20set-token\x27');}export const parseDateInput=V=>{const j=a17Q;try{let b=new Date(V);if(isNaN(b['getTime']())){const G=V[j(0x146)]===0xd?V/0x3e8:V,a=new Date(0x0);a[j(0x12f)](G);if(isNaN(a[j(0x138)]()))throw new Error();return a;}return b;}catch(m){throw new Error(j(0x11e)+V+j(0x14c));}};export const tsHint='example:\x202020-02-02T02:02:02Z\x20(date\x20string)\x20or\x201580608922\x20(unix\x20ts)';function a17e(){const d=['green','No\x20CLI\x20context\x20present.\x20Create\x20context\x20with\x20\x27northflank\x20login\x27','storeOptionsAsProperties','Invalid\x20date\x20received:\x20','allowExcessArguments','879lGBEST','min','yellow','from','getCurrentContext','enablePositionalOptions',',\x20the\x20latest\x20version\x20of\x20the\x20cli\x20is\x20','addHelpCommand','base64','Display\x20help\x20for\x20command','2736174XzfIuB','No\x20console\x20output','--skipValidation','No\x20API\x20URL\x20present\x20in\x20context.\x20Create\x20new\x20context\x20with\x20\x27northflank\x20login\x27','2036391FwhsyQ','setUTCSeconds','split','json','2798852YbKufE','reduce','resolve','setLastUpdateCheck','1202931kOSAiH','setDate','getTime','helpOption','7806293RyFLCx','toString','parse','error','\x20-g\x27\x20or\x20\x27yarn\x20global\x20add\x20','contextProvider','\x20Consider\x20updating\x20using\x20\x27npm\x20i\x20','20yUtzef','replace','log','version','\x27\x20**','length','then','getLastUpdateCheck','allowUnknownOption','932VyUSBf','**\x20You\x27re\x20running\x20on\x20version\x20',',\x20expected\x20valid\x20date\x20string\x20(example:\x202020-02-02T02:02:02Z)\x20or\x20unix\x20timestamp\x20(example\x201580608922)','timeout','redBright','push','10NacpRq','env','24pvSFiM','utf-8','getDate','padEnd','HTTP_PROXY','GET','3485754sfIkWR','Verbose\x20output','--quiet'];a17e=function(){return d;};return a17e();}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@northflank/cli",
3
- "version": "0.10.16",
3
+ "version": "0.11.1",
4
4
  "author": "Marco Suter",
5
5
  "description": "Provides a command-line interface to the Northflank platform.",
6
6
  "homepage": "https://www.northflank.com",
@@ -27,7 +27,7 @@
27
27
  "LICENSE"
28
28
  ],
29
29
  "dependencies": {
30
- "@northflank/js-client": "0.8.13",
30
+ "@northflank/js-client": "0.9.1",
31
31
  "bufferutil": "^4.0.9",
32
32
  "chalk": "~5.6.2",
33
33
  "columnify": "^1.6.0",