@northflank/cli 0.11.4 → 0.11.5

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
- function a14l(o,l){const E=a14o();return a14l=function(y,N){y=y-0x12f;let Z=E[y];return Z;},a14l(o,l);}const a14k=a14l;(function(o,l){const X=a14l,E=o();while(!![]){try{const y=-parseInt(X(0x13e))/0x1+-parseInt(X(0x14c))/0x2*(parseInt(X(0x147))/0x3)+-parseInt(X(0x12f))/0x4*(-parseInt(X(0x136))/0x5)+parseInt(X(0x146))/0x6*(parseInt(X(0x13b))/0x7)+-parseInt(X(0x14a))/0x8*(-parseInt(X(0x140))/0x9)+parseInt(X(0x149))/0xa*(-parseInt(X(0x13c))/0xb)+-parseInt(X(0x14b))/0xc;if(y===l)break;else E['push'](E['shift']());}catch(N){E['push'](E['shift']());}}}(a14o,0x477de));import a14E from'inquirer/lib/prompts/list.js';import a14y from'inquirer/lib/objects/choice.js';import a14N from'chalk';function incrementListIndex(o,l,E){const g=a14l,y=E[g(0x139)]['realLength'],N=g(0x142)in E?Boolean(E[g(0x142)]):!![];if(l==='up'){if(o>0x0)return o-0x1;return N?y-0x1:o;}if(l==='down'){if(o<y-0x1)return o+0x1;return N?0x0:o;}throw new Error(g(0x137));}function a14o(){const b=['..\x20Load\x20more\x20options\x20..','1540RLbXgs','1021624fkRasv','2132808OeBWbs','5524mSBTXy','length','44IdbHBh','selected','render','reloadText','nextPageCursor','loading','down','31740QGfMzJ','dir\x20must\x20be\x20up\x20or\x20down','opt','choices','handleDynamicPageLoad','7xVllmX','29150meUSwp','onUpKey','188691czDSaG','pagOpt','36AiYrbi','catch','loop','italic','push','loadMore','3235158yCUSAN','57zAvRSH'];a14o=function(){return b;};return a14o();}export class DynamicReloadPaginationPrompt extends a14E{[a14k(0x132)]=a14N[a14k(0x143)](a14k(0x148));[a14k(0x13f)];['loading']=![];['nextPageCursor'];constructor(o,l,E){const I=a14k;super(o,l,E),this[I(0x13f)]=this[I(0x138)],this['nextPageCursor']=this[I(0x13f)][I(0x133)],this[I(0x133)]!==undefined&&this[I(0x138)]['choices'][I(0x144)](new a14y(this[I(0x132)],this[I(0x132)]));}[a14k(0x13d)](){const J=a14k;if(this[J(0x134)])return;this[J(0x130)]=incrementListIndex(this['selected'],'up',this[J(0x138)]),this['render']();}async['onDownKey'](){const m=a14k;if(this['loading'])return;this['selected']=incrementListIndex(this[m(0x130)],m(0x135),this['opt']),await this[m(0x13a)](),this['render']();}async[a14k(0x13a)](){const L=a14k;if(this[L(0x130)]>=this[L(0x138)][L(0x139)][L(0x14d)]-0x1){if(this[L(0x133)]===undefined)return;this[L(0x134)]=!![];let o=0x0;const l=setInterval(()=>{const F=L,Z=['⠋','⠙','⠹','⠸','⠼','⠴','⠦','⠧','⠇','⠏'],A=a14N[F(0x143)](Z[o%Z[F(0x14d)]]+'\x20Loading\x20more\x20options');this[F(0x138)][F(0x139)]['choices'][this[F(0x130)]]['name']=''+A,o+=0x1,this[F(0x131)]();},0x50),{elements:E,nextPageCursor:y}=await this['pagOpt'][L(0x145)]({'nextPageCursor':this[L(0x133)]})[L(0x141)](()=>({'elements':[],'nextPageCursor':undefined}));this[L(0x133)]=y;const N=E['map'](Z=>new a14y(Z,Z));this[L(0x138)][L(0x139)][L(0x139)]['splice'](this['selected'],0x1),this[L(0x138)]['choices']['push'](...N),y!==undefined&&this['opt'][L(0x139)][L(0x144)](new a14y(this[L(0x132)],this[L(0x132)])),clearInterval(l),this[L(0x134)]=![];}}}
1
+ const a14B=a14h;(function(Z,h){const d=a14h,T=Z();while(!![]){try{const P=parseInt(d(0x110))/0x1*(-parseInt(d(0x129))/0x2)+-parseInt(d(0x112))/0x3+parseInt(d(0x10e))/0x4+-parseInt(d(0x12a))/0x5*(-parseInt(d(0x125))/0x6)+parseInt(d(0x115))/0x7+parseInt(d(0x11f))/0x8+-parseInt(d(0x11d))/0x9;if(P===h)break;else T['push'](T['shift']());}catch(f){T['push'](T['shift']());}}}(a14Z,0x5f621));import a14T from'inquirer/lib/prompts/list.js';import a14P from'inquirer/lib/objects/choice.js';import a14f from'chalk';function incrementListIndex(Z,h,T){const U=a14h,P=T['choices'][U(0x111)],f=U(0x126)in T?Boolean(T[U(0x126)]):!![];if(h==='up'){if(Z>0x0)return Z-0x1;return f?P-0x1:Z;}if(h===U(0x11a)){if(Z<P-0x1)return Z+0x1;return f?0x0:Z;}throw new Error(U(0x113));}function a14h(Z,h){const T=a14Z();return a14h=function(P,f){P=P-0x10b;let V=T[P];return V;},a14h(Z,h);}export class DynamicReloadPaginationPrompt extends a14T{[a14B(0x11e)]=a14f[a14B(0x11c)](a14B(0x11b));['pagOpt'];[a14B(0x10b)]=![];['nextPageCursor'];constructor(Z,h,T){const q=a14B;super(Z,h,T),this['pagOpt']=this[q(0x10d)],this[q(0x123)]=this[q(0x116)]['nextPageCursor'],this[q(0x123)]!==undefined&&this[q(0x10d)][q(0x127)][q(0x120)](new a14P(this['reloadText'],this[q(0x11e)]));}[a14B(0x10f)](){const w=a14B;if(this['loading'])return;this[w(0x128)]=incrementListIndex(this[w(0x128)],'up',this['opt']),this[w(0x10c)]();}async['onDownKey'](){const M=a14B;if(this[M(0x10b)])return;this[M(0x128)]=incrementListIndex(this[M(0x128)],'down',this[M(0x10d)]),await this['handleDynamicPageLoad'](),this[M(0x10c)]();}async['handleDynamicPageLoad'](){const S=a14B;if(this['selected']>=this[S(0x10d)][S(0x127)][S(0x124)]-0x1){if(this[S(0x123)]===undefined)return;this[S(0x10b)]=!![];let Z=0x0;const h=setInterval(()=>{const z=S,V=['⠋','⠙','⠹','⠸','⠼','⠴','⠦','⠧','⠇','⠏'],x=a14f['italic'](V[Z%V[z(0x124)]]+z(0x118));this['opt'][z(0x127)][z(0x127)][this[z(0x128)]][z(0x117)]=''+x,Z+=0x1,this['render']();},0x50),{elements:T,nextPageCursor:P}=await this[S(0x116)][S(0x119)]({'nextPageCursor':this[S(0x123)]})[S(0x121)](()=>({'elements':[],'nextPageCursor':undefined}));this[S(0x123)]=P;const f=T[S(0x122)](V=>new a14P(V,V));this[S(0x10d)][S(0x127)][S(0x127)][S(0x114)](this[S(0x128)],0x1),this['opt'][S(0x127)][S(0x120)](...f),P!==undefined&&this[S(0x10d)]['choices'][S(0x120)](new a14P(this[S(0x11e)],this[S(0x11e)])),clearInterval(h),this[S(0x10b)]=![];}}}function a14Z(){const H=['7670376KVwQtA','reloadText','3327480lsXBjx','push','catch','map','nextPageCursor','length','3810756MKPTjY','loop','choices','selected','118aqBUQs','5gJsmkz','loading','render','opt','2286644lkMNyY','onUpKey','6067qwaeER','realLength','1888014LwVYnN','dir\x20must\x20be\x20up\x20or\x20down','splice','4252654nNBVRv','pagOpt','name','\x20Loading\x20more\x20options','loadMore','down','..\x20Load\x20more\x20options\x20..','italic'];a14Z=function(){return H;};return a14Z();}
@@ -1 +1 @@
1
- const a15M=a15l;(function(o,l){const T=a15l,E=o();while(!![]){try{const y=parseInt(T(0xa7))/0x1+-parseInt(T(0xaf))/0x2*(-parseInt(T(0x107))/0x3)+-parseInt(T(0xda))/0x4*(parseInt(T(0xaa))/0x5)+parseInt(T(0xf8))/0x6*(parseInt(T(0xd5))/0x7)+-parseInt(T(0xe2))/0x8+-parseInt(T(0xeb))/0x9+-parseInt(T(0x103))/0xa*(-parseInt(T(0xe4))/0xb);if(y===l)break;else E['push'](E['shift']());}catch(N){E['push'](E['shift']());}}}(a15o,0x89bbe));import{ApiClient}from'@northflank/js-client';function a15l(o,l){const E=a15o();return a15l=function(y,N){y=y-0xa3;let Z=E[y];return Z;},a15l(o,l);}import a15E from'chalk';import{assertContextExisting,customUserAgent,error,getCommand,success,warning}from'../utils.js';import{InquirerHelper}from'../inquirer-helper.js';import*as a15y from'os';import{uniqBy,uniq,repeat,groupBy,capitalize}from'lodash-es';function a15o(){const H=['forwardAddon','forwarding','Project\x20for\x20forwarding','Don\x27t\x20use\x20context\x20default\x20values,\x20explicitly\x20use\x20options\x20or\x20ask.','Port-forwarding\x20for\x20all\x20services\x20and\x20addons\x20in\x20the\x20given\x20project','forwardProject','flat','10MoNrnM','skipHostnames','http://','askForService','186CNQHvg','entries','reset','action','type','stop','Connection\x20error\x20occurred\x20when\x20forwarding\x20\x27','C:/Windows/System32/drivers/etc/hosts','green','--skipHostnames','\x20to\x20','forEach','join','protocol','\x20flag\x20or\x20manually\x20append\x20following\x20entry\x20to\x20your\x20hosts\x20file\x20(','data','filter','\x20service\x20ports','contextProvider','ports','\x27\x20of\x20','485983HvAWAl','message','HTTP','155mZOpsh','Forwarding\x20addon\x20','data.id','Stop\x20forwarding\x20traffic\x20from\x20','portFwdCmd','8444lKJvLs','\x20\x20\x20\x20\x20\x20\x20\x20\x20','printForwardingInfo','hostnames','Team\x20for\x20forwarding','\x20with\x20these\x20hostnames:','addCommand','Running\x20on\x20macOS\x20in\x20','\x20\x20-\x20Address:\x20','platform','getBaseCommand','org','Running\x20in\x20','hosts','Port-forwarding\x20for\x20the\x20specified\x20addon','Service\x20to\x20forward','darwin','log','noDefaultsText','greenBright','Port-forwarding\x20for\x20the\x20specified\x20service','\x20and\x20','askForProject','--addon\x20--addonId\x20[NAME]','Error\x20occured\x20while\x20trying\x20to\x20forward\x20','Cleaning\x20up\x20open\x20connections\x20failed:\x20','Forwarding\x20','apiClient','\x20with\x20multiple\x20ports:','getTokenScope','\x20-\x20','--noDefaults','error','forwardService','\x27:\x20\x22','Addon\x20to\x20forward','Services:','--project\x20--projectId\x20[NAME]','441EPCMED','\x20in\x20project\x20','askForProjectContext','getProxyForwarder','bold','135448BvLqNW','description','\x20mode:\x20the\x20locally\x20forwarded\x20port\x20differs\x20from\x20the\x20actual\x20port\x20on\x20the\x20forwarded\x20service/addon.','address','SIGINT','--service\x20--serviceId\x20[NAME]','printHostsFileHint','name','2478208RTQYJI','--team\x20--teamId\x20[TEAMID]','21425118RtnFeP','Forwarding\x20service\x20','service',',\x20hostname:\x20','\x20is\x20running\x20and\x20reachable\x20and\x20that\x20a\x20port\x20is\x20defined\x20on\x20the\x20networking\x20section.','win32','Addons:','8927559flRAou','--instance\x20--instanceId\x20[NAME]','port','\x20\x20If\x20you\x20have\x20added\x20entries\x20to\x20your\x20hosts\x20file,\x20it\x20is\x20recommended\x20to\x20remove\x20them\x20again\x20now.','tunnel-close','\x20addon\x20ports','alias','option','getCurrentProjectName','Port-forwarding\x20for\x20Northflank\x20services\x20and\x20addons.','\x20is\x20exposed\x20on\x20','skipHostnamesText','\x20\x20-\x20port\x20','20964qMPfAz','Failed:\x20','length','addon'];a15o=function(){return H;};return a15o();}import{EOL}from'os';export class CliPortForward{['portFwdCmd'];['apiClient'];[a15M(0xc1)]=a15M(0xff);[a15M(0xf6)]='Only\x20expose\x20on\x20IP\x20address,\x20not\x20on\x20hostnames.\x20With\x20this\x20option,\x20no\x20root\x20permissions\x20are\x20required.';constructor(o,l){const B=a15M;this[B(0xca)]=new ApiClient(o,{'throwErrorOnHttpErrorCode':!![],'customUserAgent':customUserAgent,'agent':l});const E=new InquirerHelper(this[B(0xca)]);this[B(0xae)]=getCommand()[B(0xe1)]('forward')[B(0xf1)]('fwd')[B(0xdb)](B(0xf4));const y=this['getBaseCommand']()['name']('all')[B(0xdb)](B(0x100))[B(0xf2)](B(0xce),this['noDefaultsText'],![])[B(0xf2)](B(0x110),this[B(0xf6)],![])[B(0x10a)](async({noDefaults:A,teamId:X,projectId:g,skipHostnames:k})=>{const G=B;assertContextExisting(this[G(0xca)]);const I=this[G(0xd8)](k),J=A?undefined:o[G(0xf3)](),{projectId:m,teamId:L}=await this[G(0xd7)](o,E,X,g,J);try{const {services:F,addons:b}=await I[G(0x101)]({'teamId':L,'projectId':m},k);if(F['length']+b[G(0xfa)]<=0x0)warning('No\x20services\x20and\x20addons\x20to\x20forward\x20found\x20in\x20project\x20'+a15E[G(0xd9)](m));else{const q=F[G(0x117)](w=>w['length']>0x0)[G(0xfa)],V=b[G(0x117)](w=>w[G(0xfa)]>0x0)['length'],v=G(0xd6)+a15E[G(0xd9)](m);console[G(0xc0)](G(0xc9)+a15E['green'][G(0xd9)](q+G(0xa3))+G(0xc4)+a15E[G(0x10f)]['bold'](V+G(0xf0))+v),console[G(0xc0)](),console[G(0xc0)](a15E['bold'](G(0xd3))),F[G(0x112)](w=>{const K=G;if(w[K(0xfa)]>=0x1&&!w[0x0][K(0xcf)])this['printForwardingInfo'](w,{'type':K(0xe6),'name':w[0x0]['data']['id']},k);}),console['log'](a15E[G(0xd9)](G(0xea))),b[G(0x112)](w=>{const s=G;if(w[s(0xfa)]>=0x1&&!w[0x0][s(0xcf)])this[s(0xb1)](w,{'type':s(0xfb),'name':w[0x0][s(0x116)]['id']},k);}),this['printHostsFileHint']([...F[G(0x102)](),...b['flat']()],k);}}catch(w){error('Failed:\x20'+w[G(0xa8)]);}}),N=this[B(0xb9)]()[B(0xe1)](B(0xe6))[B(0xdb)](B(0xc3))[B(0xf2)](B(0xdf),B(0xbe))['option'](B(0xec),'Instance\x20to\x20forward')['option'](B(0xce),this[B(0xc1)],![])['option']('--skipHostnames',this[B(0xf6)],![])[B(0x10a)](async({noDefaults:A,teamId:X,projectId:g,serviceId:k,instanceId:I,skipHostnames:J})=>{const x=B;assertContextExisting(this[x(0xca)]);const m=this['getProxyForwarder'](J),L=A?undefined:o[x(0xf3)](),{projectId:F,teamId:b}=await this[x(0xd7)](o,E,g,X,L),q=A?undefined:o['getCurrentServiceName'](),V=k||q||await E[x(0x106)](F,b)();console[x(0xc0)](x(0xe5)+a15E[x(0xd9)](V)+x(0xd6)+a15E[x(0xd9)](F));try{const v=await m[x(0xd0)]({'teamId':b,'projectId':F,'serviceId':V,'instanceId':I},J);this[x(0xb1)](v,{'name':V,'type':x(0xe6),'instanceId':I},J),this['printHostsFileHint'](v,J);}catch(w){error(x(0xf9)+w[x(0xa8)]);}}),Z=this['getBaseCommand']()[B(0xe1)](B(0xfb))['description'](B(0xbd))[B(0xf2)](B(0xc6),B(0xd2))[B(0xf2)](B(0x110),this['skipHostnamesText'],![])[B(0x10a)](async({noDefaults:A,teamId:X,projectId:g,addonId:k,skipHostnames:I})=>{const Y=B;assertContextExisting(this[Y(0xca)]);const J=this[Y(0xd8)](I),m=A?undefined:o[Y(0xf3)](),{projectId:L,teamId:F}=await this[Y(0xd7)](o,E,g,X,m),b=k||await E['askForAddon'](L,F)();console[Y(0xc0)](Y(0xab)+a15E['bold'](b)+Y(0xd6)+a15E[Y(0xd9)](L));try{const q={'teamId':F,'projectId':L,'addonId':b},V=await J[Y(0xfc)](q,I);this[Y(0xb1)](V,{'name':b,'type':Y(0xfb)},I),this[Y(0xe0)](V,I);}catch(v){error(Y(0xf9)+v['message']);}});this['portFwdCmd'][B(0xb5)](y),this[B(0xae)][B(0xb5)](N),this[B(0xae)]['addCommand'](Z);}[a15M(0xb9)]=()=>{const p=a15M,o=getCommand(!![])[p(0xf2)](p(0xd4),p(0xfe));return this['apiClient'][p(0xa4)][p(0xcc)]()===p(0xba)&&o['option'](p(0xe3),p(0xb3)),o;};[a15M(0xd8)](o=![]){const r=a15M,l=this[r(0xca)][r(0xfd)];if(!o){const E=l['canExecuteWithHostnames']();if(E[r(0xcf)])throw new Error(E[r(0xa8)]);}return l['on'](r(0xef),(y,N)=>{const e=r,Z=a15E['bold'](N[e(0x10b)]+'\x20\x27'+N['id']+'\x27'),A=N['hostnames'][e(0xfa)]>0x0;warning(e(0xad)+N['address']+':'+N[e(0xed)]+e(0x111)+Z),o&&A&&warning(e(0xee));}),l['on']('connection-error',(y,N,Z)=>{const O=r;warning(O(0x10d)+N[O(0xdd)]+':'+N[O(0xed)]+O(0xd1)+Z?.[O(0xa8)]+'\x22');}),process['on'](r(0xde),async()=>{const U=r;try{await l[U(0x10c)]();}catch(y){error(U(0xc8)+y[U(0xa8)]);}finally{process['exit']();}}),l;}['printForwardingInfo'](o,l,E=![]){const z=a15M,{type:y,name:N,instanceId:Z}=l;if(o['length']<=0x0){const k='Please\x20ensure\x20the\x20'+l[z(0x10b)]+z(0xe8);warning('\x20\x20\x20No\x20running\x20container\x20found\x20for\x20'+y+'\x20'+a15E[z(0xd9)](N)+'.\x20'+k);return;}const A=groupBy(o,z(0xac)),X=I=>'\x20('+(I['portName']?I['portName']+z(0xcd):'')+I[z(0x114)]+')';function g(I,J=0x2){const Q=z;if(!E){const m=I[Q(0x114)]===Q(0xa9)?Q(0x105):'';I[Q(0xb2)][Q(0x112)](L=>{const C=Q;console[C(0xc0)](repeat('\x20',J)+'-\x20'+m+L+':'+I[C(0xed)]);});}}Object[z(0x108)](A)['forEach'](([I,J])=>{const D=z,m=Z?'>\x20Instance\x20\x27'+a15E[D(0xc2)]['bold'](Z)+D(0xa6)+y+'\x20\x27'+a15E[D(0xc2)][D(0xd9)](I)+'\x27':'>\x20'+capitalize(y)+'\x20\x27'+a15E[D(0xc2)][D(0xd9)](I)+'\x27';if(y===D(0xfb)){if(J[D(0xfa)]===0x1){const L=J[0x0];if(L[D(0xcf)]){error(D(0xc7)+I+':\x20'+L['error'][D(0xa8)]);return;}const F=L[D(0x116)],b=!E?'\x20'+a15E[D(0x109)]('with\x20hostname:\x20'+F[D(0xb2)][D(0x113)](',')):'';success(m+D(0xf5)+F[D(0xdd)]+':'+F[D(0xed)]+X(F)+b);}else{const q=uniqBy(J,V=>V?.['data']?.[D(0xb2)]?.['join'](','))[D(0xfa)]>0x1;success(m+'\x20is\x20exposed\x20with\x20multiple\x20'+(q?D(0xbc):D(0xa5))+':'),J['forEach'](V=>{const d=D;if(V[d(0xcf)]){error('Error\x20occured\x20while\x20trying\x20to\x20forward\x20'+I+':\x20'+V[d(0xcf)][d(0xa8)]);return;}const v=V[d(0x116)],w=!E?d(0xe7)+v[d(0xb2)]['join'](','):'';console[d(0xc0)](d(0xb7)+v[d(0xdd)]+':'+v['port']+X(v)+w);});}}if(y===D(0xe6)){if(J[D(0xfa)]===0x1){const V=J[0x0];if(V['error']){error('Error\x20occured\x20while\x20trying\x20to\x20forward\x20'+I+':\x20'+V[D(0xcf)][D(0xa8)]);return;}const v=V[D(0x116)],w=!E?D(0xb4):':',i=v[D(0xdd)]+':'+v['port']+X(v);success(m+'\x20is\x20exposed\x20on\x20'+i+w),g(v);}else success(m+D(0xf5)+J[0x0]?.[D(0x116)]?.[D(0xdd)]+D(0xcb)),J[D(0x112)](f=>{const j=D;if(f[j(0xcf)]){error('Error\x20occured\x20while\x20trying\x20to\x20forward\x20'+I+':\x20'+f[j(0xcf)][j(0xa8)]);return;}const a=f[j(0x116)];success(j(0xf7)+a[j(0xed)]+X(a)),g(a,0x4);});}});}[a15M(0xe0)](o,l=![]){const P=a15M;if(l){const E=o['flatMap'](I=>I[P(0x116)])[P(0x117)](I=>I!==undefined),y=process?.[P(0xb8)]===P(0xe9),N=a15y[P(0xb8)]()===P(0xbf),Z=y?P(0x10e):'/etc/hosts',A=a15E['bold'](P(0x104)),X=N?EOL+P(0xb6)+A+P(0xdc):undefined;let g=P(0xbb)+A+'\x20mode.\x20If\x20hostname\x20forwarding\x20is\x20required,\x20remove\x20'+P(0x110)+P(0x115)+Z+'):';X!==undefined&&warning(X??'');warning(g);const k=E['map'](I=>I[P(0xdd)]+P(0xb0)+I['hostnames'][P(0x113)]('\x20'));console[P(0xc0)](uniq(k)['join'](EOL)),console[P(0xc0)]();}}['askForProjectContext']=async(o,l,E,y,N)=>{const n=a15M,Z=o['getTokenScope']()===n(0xba)?y??await l['askForTeam']()():undefined,A=E||N||await l[n(0xc5)](Z)();return{'teamId':Z,'projectId':A};};}
1
+ function a15h(Z,h){const T=a15Z();return a15h=function(P,f){P=P-0x7e;let V=T[P];return V;},a15h(Z,h);}function a15Z(){const N=['log','address','option','Services:','>\x20Instance\x20\x27','forwardProject','\x20in\x20project\x20','\x20\x20If\x20you\x20have\x20added\x20entries\x20to\x20your\x20hosts\x20file,\x20it\x20is\x20recommended\x20to\x20remove\x20them\x20again\x20now.','forwardAddon','data.id','--addon\x20--addonId\x20[NAME]','\x20\x20-\x20Address:\x20','length','join','Port-forwarding\x20for\x20the\x20specified\x20service','\x20with\x20these\x20hostnames:','port','greenBright','33OznGxO','green','\x20to\x20','Error\x20occured\x20while\x20trying\x20to\x20forward\x20','bold','29112ndhCZm','message','Running\x20in\x20','forEach','getBaseCommand','platform','No\x20services\x20and\x20addons\x20to\x20forward\x20found\x20in\x20project\x20','10hBdCfC','forwardService','noDefaultsText','service','803844ZDsGwa','Addons:','org','\x20addon\x20ports','data','error','contextProvider','askForTeam','1WOgxtd','509511RJckqi','http://','printHostsFileHint','785988rEsPCr','type','getTokenScope','--instance\x20--instanceId\x20[NAME]','protocol','stop','name','\x20mode:\x20the\x20locally\x20forwarded\x20port\x20differs\x20from\x20the\x20actual\x20port\x20on\x20the\x20forwarded\x20service/addon.','darwin','Running\x20on\x20macOS\x20in\x20','skipHostnames','flat','Team\x20for\x20forwarding','filter','Please\x20ensure\x20the\x20','addCommand','--skipHostnames','Project\x20for\x20forwarding','432670LINTAa','apiClient','\x20\x20\x20No\x20running\x20container\x20found\x20for\x20','canExecuteWithHostnames','\x20with\x20multiple\x20ports:','--project\x20--projectId\x20[NAME]','skipHostnamesText','exit','with\x20hostname:\x20','reset','\x27:\x20\x22','alias','SIGINT','Port-forwarding\x20for\x20Northflank\x20services\x20and\x20addons.','Forwarding\x20addon\x20','connection-error','Service\x20to\x20forward','getCurrentProjectName','506612eyRQIR','2163DCvccL','portFwdCmd','--service\x20--serviceId\x20[NAME]','askForProjectContext','Stop\x20forwarding\x20traffic\x20from\x20','13pifYHh','--noDefaults','askForAddon','askForService','C:/Windows/System32/drivers/etc/hosts','description','all','getProxyForwarder','tunnel-close','win32','ports','--team\x20--teamId\x20[TEAMID]','Failed:\x20','getCurrentServiceName','Don\x27t\x20use\x20context\x20default\x20values,\x20explicitly\x20use\x20options\x20or\x20ask.','8ofJRYc','addon','\x27\x20of\x20','printForwardingInfo','action','/etc/hosts','\x20is\x20running\x20and\x20reachable\x20and\x20that\x20a\x20port\x20is\x20defined\x20on\x20the\x20networking\x20section.','portName','askForProject','fwd','hostnames','forwarding','Instance\x20to\x20forward','\x20mode.\x20If\x20hostname\x20forwarding\x20is\x20required,\x20remove\x20','1686ClmJaP','Only\x20expose\x20on\x20IP\x20address,\x20not\x20on\x20hostnames.\x20With\x20this\x20option,\x20no\x20root\x20permissions\x20are\x20required.'];a15Z=function(){return N;};return a15Z();}const a15a=a15h;(function(Z,h){const n=a15h,T=Z();while(!![]){try{const P=parseInt(n(0xc6))/0x1*(parseInt(n(0xee))/0x2)+-parseInt(n(0xc7))/0x3+parseInt(n(0xb3))/0x4*(parseInt(n(0xba))/0x5)+-parseInt(n(0x9a))/0x6*(-parseInt(n(0xef))/0x7)+-parseInt(n(0x8c))/0x8*(parseInt(n(0xca))/0x9)+-parseInt(n(0xdc))/0xa*(-parseInt(n(0xae))/0xb)+parseInt(n(0xbe))/0xc*(-parseInt(n(0xf4))/0xd);if(P===h)break;else T['push'](T['shift']());}catch(f){T['push'](T['shift']());}}}(a15Z,0x27250));import{ApiClient}from'@northflank/js-client';import a15T from'chalk';import{assertContextExisting,customUserAgent,error,getCommand,success,warning}from'../utils.js';import{InquirerHelper}from'../inquirer-helper.js';import*as a15P from'os';import{uniqBy,uniq,repeat,groupBy,capitalize}from'lodash-es';import{EOL}from'os';export class CliPortForward{[a15a(0xf0)];[a15a(0xdd)];[a15a(0xbc)]=a15a(0x8b);[a15a(0xe2)]=a15a(0x9b);constructor(Z,h){const G=a15a;this[G(0xdd)]=new ApiClient(Z,{'throwErrorOnHttpErrorCode':!![],'customUserAgent':customUserAgent,'agent':h});const T=new InquirerHelper(this[G(0xdd)]);this['portFwdCmd']=getCommand()[G(0xd0)]('forward')[G(0xe7)](G(0x95))['description'](G(0xe9));const P=this[G(0xb7)]()[G(0xd0)](G(0x83))[G(0x82)]('Port-forwarding\x20for\x20all\x20services\x20and\x20addons\x20in\x20the\x20given\x20project')[G(0x9e)](G(0x7e),this['noDefaultsText'],![])[G(0x9e)](G(0xda),this[G(0xe2)],![])[G(0x90)](async({noDefaults:x,teamId:d,projectId:U,skipHostnames:B})=>{const L=G;assertContextExisting(this['apiClient']);const q=this[L(0x84)](B),w=x?undefined:Z[L(0xed)](),{projectId:M,teamId:S}=await this[L(0xf2)](Z,T,d,U,w);try{const {services:z,addons:H}=await q[L(0xa1)]({'teamId':S,'projectId':M},B);if(z[L(0xa8)]+H[L(0xa8)]<=0x0)warning(L(0xb9)+a15T[L(0xb2)](M));else{const l=z['filter'](y=>y[L(0xa8)]>0x0)[L(0xa8)],E=H[L(0xd7)](y=>y[L(0xa8)]>0x0)['length'],Y='\x20in\x20project\x20'+a15T['bold'](M);console[L(0x9c)]('Forwarding\x20'+a15T['green'][L(0xb2)](l+'\x20service\x20ports')+'\x20and\x20'+a15T[L(0xaf)][L(0xb2)](E+L(0xc1))+Y),console[L(0x9c)](),console[L(0x9c)](a15T[L(0xb2)](L(0x9f))),z['forEach'](y=>{const Q=L;if(y[Q(0xa8)]>=0x1&&!y[0x0]['error'])this[Q(0x8f)](y,{'type':Q(0xbd),'name':y[0x0][Q(0xc2)]['id']},B);}),console[L(0x9c)](a15T[L(0xb2)](L(0xbf))),H[L(0xb6)](y=>{const O=L;if(y[O(0xa8)]>=0x1&&!y[0x0][O(0xc3)])this[O(0x8f)](y,{'type':O(0x8d),'name':y[0x0][O(0xc2)]['id']},B);}),this[L(0xc9)]([...z[L(0xd5)](),...H['flat']()],B);}}catch(y){error('Failed:\x20'+y[L(0xb4)]);}}),f=this[G(0xb7)]()[G(0xd0)](G(0xbd))[G(0x82)](G(0xaa))[G(0x9e)](G(0xf1),G(0xec))[G(0x9e)](G(0xcd),G(0x98))['option']('--noDefaults',this[G(0xbc)],![])[G(0x9e)](G(0xda),this[G(0xe2)],![])[G(0x90)](async({noDefaults:x,teamId:d,projectId:U,serviceId:B,instanceId:q,skipHostnames:w})=>{const i=G;assertContextExisting(this[i(0xdd)]);const M=this['getProxyForwarder'](w),S=x?undefined:Z[i(0xed)](),{projectId:z,teamId:H}=await this[i(0xf2)](Z,T,U,d,S),l=x?undefined:Z[i(0x8a)](),E=B||l||await T[i(0x80)](z,H)();console[i(0x9c)]('Forwarding\x20service\x20'+a15T[i(0xb2)](E)+i(0xa2)+a15T['bold'](z));try{const Y=await M[i(0xbb)]({'teamId':H,'projectId':z,'serviceId':E,'instanceId':q},w);this['printForwardingInfo'](Y,{'name':E,'type':'service','instanceId':q},w),this[i(0xc9)](Y,w);}catch(y){error(i(0x89)+y[i(0xb4)]);}}),V=this[G(0xb7)]()[G(0xd0)](G(0x8d))['description']('Port-forwarding\x20for\x20the\x20specified\x20addon')['option'](G(0xa6),'Addon\x20to\x20forward')[G(0x9e)]('--skipHostnames',this[G(0xe2)],![])[G(0x90)](async({noDefaults:x,teamId:d,projectId:U,addonId:B,skipHostnames:q})=>{const c=G;assertContextExisting(this[c(0xdd)]);const w=this[c(0x84)](q),M=x?undefined:Z['getCurrentProjectName'](),{projectId:S,teamId:z}=await this[c(0xf2)](Z,T,U,d,M),H=B||await T[c(0x7f)](S,z)();console[c(0x9c)](c(0xea)+a15T[c(0xb2)](H)+c(0xa2)+a15T[c(0xb2)](S));try{const l={'teamId':z,'projectId':S,'addonId':H},E=await w[c(0xa4)](l,q);this[c(0x8f)](E,{'name':H,'type':c(0x8d)},q),this[c(0xc9)](E,q);}catch(Y){error(c(0x89)+Y[c(0xb4)]);}});this[G(0xf0)][G(0xd9)](P),this[G(0xf0)][G(0xd9)](f),this[G(0xf0)][G(0xd9)](V);}[a15a(0xb7)]=()=>{const g=a15a,Z=getCommand(!![])['option'](g(0xe1),g(0xdb));return this[g(0xdd)][g(0xc4)][g(0xcc)]()==='org'&&Z['option'](g(0x88),g(0xd6)),Z;};[a15a(0x84)](Z=![]){const u=a15a,h=this[u(0xdd)][u(0x97)];if(!Z){const T=h[u(0xdf)]();if(T[u(0xc3)])throw new Error(T[u(0xb4)]);}return h['on'](u(0x85),(P,f)=>{const I=u,V=a15T[I(0xb2)](f[I(0xcb)]+'\x20\x27'+f['id']+'\x27'),x=f[I(0x96)][I(0xa8)]>0x0;warning(I(0xf3)+f[I(0x9d)]+':'+f[I(0xac)]+I(0xb0)+V),Z&&x&&warning(I(0xa3));}),h['on'](u(0xeb),(P,f,V)=>{const k=u;warning('Connection\x20error\x20occurred\x20when\x20forwarding\x20\x27'+f[k(0x9d)]+':'+f['port']+k(0xe6)+V?.[k(0xb4)]+'\x22');}),process['on'](u(0xe8),async()=>{const F=u;try{await h[F(0xcf)]();}catch(P){error('Cleaning\x20up\x20open\x20connections\x20failed:\x20'+P['message']);}finally{process[F(0xe3)]();}}),h;}[a15a(0x8f)](Z,h,T=![]){const J=a15a,{type:P,name:f,instanceId:V}=h;if(Z[J(0xa8)]<=0x0){const B=J(0xd8)+h[J(0xcb)]+J(0x92);warning(J(0xde)+P+'\x20'+a15T[J(0xb2)](f)+'.\x20'+B);return;}const x=groupBy(Z,J(0xa5)),d=q=>'\x20('+(q[J(0x93)]?q[J(0x93)]+'\x20-\x20':'')+q[J(0xce)]+')';function U(q,w=0x2){const o=J;if(!T){const M=q[o(0xce)]==='HTTP'?o(0xc8):'';q[o(0x96)]['forEach'](S=>{const X=o;console['log'](repeat('\x20',w)+'-\x20'+M+S+':'+q[X(0xac)]);});}}Object['entries'](x)[J(0xb6)](([q,w])=>{const s=J,M=V?s(0xa0)+a15T[s(0xad)][s(0xb2)](V)+s(0x8e)+P+'\x20\x27'+a15T['greenBright'][s(0xb2)](q)+'\x27':'>\x20'+capitalize(P)+'\x20\x27'+a15T[s(0xad)][s(0xb2)](q)+'\x27';if(P===s(0x8d)){if(w[s(0xa8)]===0x1){const S=w[0x0];if(S[s(0xc3)]){error(s(0xb1)+q+':\x20'+S[s(0xc3)]['message']);return;}const z=S[s(0xc2)],H=!T?'\x20'+a15T[s(0xe5)](s(0xe4)+z[s(0x96)]['join'](',')):'';success(M+'\x20is\x20exposed\x20on\x20'+z[s(0x9d)]+':'+z['port']+d(z)+H);}else{const l=uniqBy(w,E=>E?.[s(0xc2)]?.[s(0x96)]?.[s(0xa9)](','))[s(0xa8)]>0x1;success(M+'\x20is\x20exposed\x20with\x20multiple\x20'+(l?'hosts':s(0x87))+':'),w['forEach'](E=>{const t=s;if(E[t(0xc3)]){error(t(0xb1)+q+':\x20'+E[t(0xc3)][t(0xb4)]);return;}const Y=E[t(0xc2)],y=!T?',\x20hostname:\x20'+Y['hostnames']['join'](','):'';console[t(0x9c)](t(0xa7)+Y[t(0x9d)]+':'+Y[t(0xac)]+d(Y)+y);});}}if(P===s(0xbd)){if(w[s(0xa8)]===0x1){const E=w[0x0];if(E[s(0xc3)]){error(s(0xb1)+q+':\x20'+E[s(0xc3)][s(0xb4)]);return;}const Y=E[s(0xc2)],y=!T?s(0xab):':',r=Y['address']+':'+Y[s(0xac)]+d(Y);success(M+'\x20is\x20exposed\x20on\x20'+r+y),U(Y);}else success(M+'\x20is\x20exposed\x20on\x20'+w[0x0]?.[s(0xc2)]?.[s(0x9d)]+s(0xe0)),w['forEach'](e=>{const R=s;if(e[R(0xc3)]){error(R(0xb1)+q+':\x20'+e[R(0xc3)]['message']);return;}const A=e[R(0xc2)];success('\x20\x20-\x20port\x20'+A['port']+d(A)),U(A,0x4);});}});}['printHostsFileHint'](Z,h=![]){const b=a15a;if(h){const T=Z['flatMap'](q=>q[b(0xc2)])[b(0xd7)](q=>q!==undefined),P=process?.['platform']===b(0x86),f=a15P[b(0xb8)]()===b(0xd2),V=P?b(0x81):b(0x91),x=a15T['bold'](b(0xd4)),d=f?EOL+b(0xd3)+x+b(0xd1):undefined;let U=b(0xb5)+x+b(0x99)+b(0xda)+'\x20flag\x20or\x20manually\x20append\x20following\x20entry\x20to\x20your\x20hosts\x20file\x20('+V+'):';d!==undefined&&warning(d??'');warning(U);const B=T['map'](q=>q[b(0x9d)]+'\x20\x20\x20\x20\x20\x20\x20\x20\x20'+q['hostnames'][b(0xa9)]('\x20'));console['log'](uniq(B)['join'](EOL)),console[b(0x9c)]();}}['askForProjectContext']=async(Z,h,T,P,f)=>{const m=a15a,V=Z[m(0xcc)]()===m(0xc0)?P??await h[m(0xc5)]()():undefined,x=T||f||await h[m(0x94)](V)();return{'teamId':V,'projectId':x};};}
package/dist/ssh/index.js CHANGED
@@ -1 +1 @@
1
- const a16D=a16l;(function(o,l){const r=a16l,E=o();while(!![]){try{const y=-parseInt(r(0xe3))/0x1*(-parseInt(r(0xbd))/0x2)+parseInt(r(0xf2))/0x3*(parseInt(r(0x100))/0x4)+parseInt(r(0xca))/0x5*(parseInt(r(0xbb))/0x6)+-parseInt(r(0xea))/0x7+-parseInt(r(0xdc))/0x8*(-parseInt(r(0x109))/0x9)+-parseInt(r(0xfa))/0xa*(parseInt(r(0xd6))/0xb)+-parseInt(r(0xb9))/0xc;if(y===l)break;else E['push'](E['shift']());}catch(N){E['push'](E['shift']());}}}(a16o,0x68665));import{ApiClient}from'@northflank/js-client';import{assertContextExisting,customUserAgent,error,getCommand,success,warning}from'../utils.js';function a16o(){const h=['Team\x20id','RequestTTY=yes','/usr/bin/ssh','apiClient','\x20\x20>\x20RSYNC:\x20\x20\x09','10GhwfSE','--proxyOnly','kill','addCommand','error','Don\x27t\x20use\x20context\x20default\x20values,\x20explicitly\x20use\x20options\x20or\x20ask.','96532OysZVt','service','execFileAsync','-tt','--useHostnames','\x20file.txt\x20','startSSH',':/remote/path/','unknown\x20error','45VDZSSY','askForProjectContext','SIGINT','Replicate\x20','Must\x20be\x20run\x20in\x20an\x20interactive\x20terminal\x20(TTY\x20required).','\x22\x20./data/\x20','Only\x20startup\x20SSH\x20proxy\x20without\x20opening\x20an\x20SSH\x20terminal\x20session.','SSH\x20killed\x20by\x20signal:\x20','org','C:\x5cWindows\x5cSystem32\x5cOpenSSH\x5cssh.exe','6487608tNcDsN','askForProject','6GcMOlw','ssh','22SublzC','push','blackBright','SSH\x20binary\x20not\x20found.\x20Please\x20install\x20OpenSSH.','exit','SSH\x20exited\x20with\x20code:\x20','getTokenScope','charAt','log','default-ssh','findSSH','Instance\x20to\x20use\x20for\x20SSH\x20(random\x20instance\x20will\x20be\x20chosen\x20if\x20not\x20specified)','root','2153680flnQbZ','name','sshCmd','RemoteCommand=su\x20','inherit','--project\x20--projectId\x20[NAME]','data','Ctrl+C\x20received\x20-\x20Terminating\x20SSH\x20proxy...','askForService','toUpperCase','trim','Project\x20of\x20the\x20','8556647SdvrQD','SSH\x20for\x20Northflank\x20services\x20and\x20jobs.','find',',\x20stop\x20with\x20Ctrl+C','slice','\x20\x20>\x20SFTP:\x20\x20\x09','1185880LzRFAI','StrictHostKeyChecking=no',':/rsync-test/','description','message','Use\x20specific\x20username\x20for\x20SSH\x20connection','Use\x20with\x20any\x20SSH\x20compatible\x20client.\x20Example\x20usages:','58183Zhbble','isTTY','close','getCurrentProjectName','SIGTERM','withServiceForwarding','/usr/local/bin/ssh','2825578NUnVRf','ssh\x20','Unable\x20to\x20initiate\x20SSH\x20tunnel.\x20Ensure\x20your\x20service\x20is\x20running\x20and\x20has\x20SSH\x20enabled','--team\x20--teamId\x20[TEAMID]','\x20to\x20ssh\x20into','uncaughtException','--noDefaults','\x20\x20>\x20SCP:\x20\x20\x09','42McjpWm','option','portName'];a16o=function(){return h;};return a16o();}import{InquirerHelper}from'../inquirer-helper.js';function a16l(o,l){const E=a16o();return a16l=function(y,N){y=y-0xb1;let Z=E[y];return Z;},a16l(o,l);}import{spawn}from'child_process';import{execFile}from'child_process';import{promisify}from'util';import a16E from'chalk';export class CliSsh{['sshCmd'];['apiClient'];constructor(o,l){const e=a16l;this['apiClient']=new ApiClient(o,{'throwErrorOnHttpErrorCode':!![],'customUserAgent':customUserAgent,'agent':l});const E=new InquirerHelper(this['apiClient']);this[e(0xcc)]=getCommand(!![])[e(0xcb)](e(0xbc))['description'](e(0xd7));const y=e(0x101),N=getCommand(!![])[e(0xcb)](y)[e(0xdf)]('Establish\x20SSH\x20connectivity\x20to\x20Northflank\x20'+y+'.\x20Creates\x20an\x20SSH\x20terminal\x20session\x20by\x20default.')[e(0xf3)](e(0xcf),e(0xd5)+y)[e(0xf3)]('--'+y+'\x20--'+y+'Id\x20[NAME]',y[e(0xc4)](0x0)[e(0xd3)]()+y[e(0xda)](0x1)+e(0xee))[e(0xf3)]('--instance\x20--instanceName\x20[NAME]',e(0xc8))[e(0xf3)](e(0xfb),e(0xb5),![])[e(0xf3)](e(0x104),e(0xb2)+y+'\x20hostnames\x20on\x20local\x20machine.\x20Requires\x20sudo\x20permissions',![])[e(0xf3)]('--user\x20[USER]',e(0xe1))[e(0xf3)](e(0xf0),e(0xff),![]);this[e(0xf8)]['contextProvider']['getTokenScope']()===e(0xb7)&&N[e(0xf3)](e(0xed),e(0xf5));const Z=N['action'](async A=>{const O=e,{noDefaults:X,teamId:g,projectId:k,serviceId:I,instanceName:J,proxyOnly:m,useHostnames:L}=A,{user:user=O(0xc9),quiet:F}=A;assertContextExisting(this[O(0xf8)]);try{const b=X?undefined:o[O(0xe6)](),{projectId:q,teamId:V}=await this[O(0x10a)](o,E,k,g,b),v=X?undefined:o['getCurrentServiceName'](),w=I||v||await E[O(0xd2)](q,V)(),i=J||await E['askForContainer'](q,w,undefined,![],V,!![])(),f=process['stdin'][O(0xe4)],a=f&&!m,T={'teamId':V,'projectId':q,'serviceId':w,'instanceId':i,'portsFilter':[0x16]};await this[O(0xf8)]['forwarding'][O(0xe8)](T,async M=>{const U=O,B=M[U(0xd8)](Y=>Y[U(0xd0)]?.[U(0xf4)]===U(0xc6));if(B===undefined)throw new Error(U(0xec));if(B?.[U(0xfe)]!==undefined||B?.[U(0xd0)]===undefined)throw new Error('Error\x20trying\x20to\x20forward:\x20'+(B?.[U(0xfe)]?.[U(0xe0)]??U(0x108)));const {address:G,port:K,hostnames:s}=B[U(0xd0)],x=L?s[0x0]??G:G;a?(!F&&success('SSH\x20proxy\x20started\x20on\x20endpoint:\x20'+(x+':'+K)+',\x20stop\x20with\x20Ctrl+D'),await this[U(0x106)]({'address':x,'port':K,'user':user})):(!F?(success('SSH\x20proxy\x20started\x20on\x20endpoint:\x20'+(x+':'+K)+U(0xd9)),console[U(0xc5)](U(0xe2)),console[U(0xc5)]('\x20\x20>\x20SSH\x20session:'+a16E['blackBright'](U(0xeb)+user+'@'+x+'\x20-p\x20'+K)),console[U(0xc5)](U(0xdb)+a16E[U(0xbf)]('sftp\x20-P\x20'+K+'\x20'+user+'@'+x)),console[U(0xc5)](U(0xf9)+a16E[U(0xbf)]('rsync\x20-avz\x20-e\x20\x22ssh\x20-p\x20'+K+U(0xb4)+user+'@'+x+U(0xde))),console[U(0xc5)](U(0xf1)+a16E[U(0xbf)]('scp\x20-P\x20'+K+U(0x105)+user+'@'+x+U(0x107)))):console[U(0xc5)](user,x,K),await new Promise((Y,p)=>{const Q=U;process['on']('SIGINT',()=>{const z=a16l;if(!F)success(z(0xd1));Y();}),process['on'](Q(0xef),p);}));},!L);}catch(M){error(''+M['message']);}finally{process[O(0xc1)]();}});this[e(0xcc)][e(0xfd)](Z);}['execFileAsync']=promisify(execFile);async['findSSH'](){const C=a16l;try{const {stdout:o}=await this[C(0x102)]('which',['ssh']);return o[C(0xd4)]();}catch{const l=[C(0xbc),C(0xf7),C(0xe9),C(0xb8)];for(const E of l){try{return await this[C(0x102)](E,['-V']),E;}catch{}}return null;}}async[a16D(0x106)](o){const d=a16D,l=await this[d(0xc7)]();if(!l)throw new Error(d(0xc0));if(!process['stdin'][d(0xe4)])throw new Error(d(0xb3));const {address:E,port:port=0x16,user:user=d(0xc9),args:args=[],trusted:trusted=!![]}=o,y=[];trusted&&y['push']('-o',d(0xdd),'-o','UserKnownHostsFile=/dev/null','-o','LogLevel=ERROR');user!==d(0xc9)&&y[d(0xbe)]('-o',d(0xcd)+user+'\x20-l','-o',d(0xf6));const N=spawn(l,[d(0x103),'-p',port['toString'](),'-l','root',...y,...args,E],{'stdio':d(0xce)});await new Promise((Z,A)=>{const j=d;N['on'](j(0xe5),(X,g)=>{const P=j;if(g)warning(P(0xb6)+g);else X!==0x0?warning(P(0xc2)+X):success('SSH\x20session\x20ended.');Z(X);}),N['on'](j(0xfe),X=>{const n=j;A(new Error('Failed\x20to\x20spawn\x20SSH\x20command:\x20'+X[n(0xe0)]));}),process['on'](j(0xb1),()=>N[j(0xfc)](j(0xb1))),process['on']('SIGTERM',()=>N[j(0xfc)](j(0xe7)));});}[a16D(0x10a)]=async(o,l,E,y,N)=>{const H=a16D,Z=o[H(0xc3)]()===H(0xb7)?y??await l['askForTeam']()():undefined,A=E||N||await l[H(0xba)](Z)();return{'teamId':Z,'projectId':A};};}
1
+ const a16I=a16h;(function(Z,h){const u=a16h,T=Z();while(!![]){try{const P=parseInt(u(0x1ae))/0x1*(parseInt(u(0x1b5))/0x2)+-parseInt(u(0x1e4))/0x3*(-parseInt(u(0x1e5))/0x4)+parseInt(u(0x1ab))/0x5*(parseInt(u(0x19e))/0x6)+parseInt(u(0x192))/0x7+parseInt(u(0x198))/0x8*(parseInt(u(0x1e7))/0x9)+parseInt(u(0x1a3))/0xa+parseInt(u(0x1d7))/0xb*(-parseInt(u(0x1bc))/0xc);if(P===h)break;else T['push'](T['shift']());}catch(f){T['push'](T['shift']());}}}(a16Z,0x4c15b));function a16Z(){const j=['sshCmd','RequestTTY=yes','C:\x5cWindows\x5cSystem32\x5cOpenSSH\x5cssh.exe','getTokenScope','SSH\x20exited\x20with\x20code:\x20','/usr/local/bin/ssh','Project\x20of\x20the\x20','StrictHostKeyChecking=no','toUpperCase','askForProjectContext','\x20-l','\x20--','contextProvider','rsync\x20-avz\x20-e\x20\x22ssh\x20-p\x20','Replicate\x20','-tt','blackBright','which','\x20to\x20ssh\x20into','slice','apiClient','error','379346VVrDDI','\x22\x20./data/\x20','ssh','--noDefaults','SSH\x20killed\x20by\x20signal:\x20','\x20\x20>\x20SCP:\x20\x20\x09','SIGINT','\x20\x20>\x20SFTP:\x20\x20\x09','SSH\x20binary\x20not\x20found.\x20Please\x20install\x20OpenSSH.','--proxyOnly',',\x20stop\x20with\x20Ctrl+D','action','Only\x20startup\x20SSH\x20proxy\x20without\x20opening\x20an\x20SSH\x20terminal\x20session.','30tvOsUL','151820uRDQxR','isTTY','2889dRCFDd','--instance\x20--instanceName\x20[NAME]',':/rsync-test/','exit','--project\x20--projectId\x20[NAME]','getCurrentProjectName','root','stdin','LogLevel=ERROR','Unable\x20to\x20initiate\x20SSH\x20tunnel.\x20Ensure\x20your\x20service\x20is\x20running\x20and\x20has\x20SSH\x20enabled','UserKnownHostsFile=/dev/null','Id\x20[NAME]','log','unknown\x20error','\x20-p\x20','\x20\x20>\x20RSYNC:\x20\x20\x09','default-ssh','4051075jzqAnA','RemoteCommand=su\x20','uncaughtException','--user\x20[USER]','service','ssh\x20','10424mfErpX',',\x20stop\x20with\x20Ctrl+C','description','askForContainer','--team\x20--teamId\x20[TEAMID]','SIGTERM','71778WBDGNG','sftp\x20-P\x20','Error\x20trying\x20to\x20forward:\x20','/usr/bin/ssh','SSH\x20proxy\x20started\x20on\x20endpoint:\x20','3398450ThjsxU','.\x20Creates\x20an\x20SSH\x20terminal\x20session\x20by\x20default.','Establish\x20SSH\x20connectivity\x20to\x20Northflank\x20','name','find','startSSH','\x20file.txt\x20','message','80HiDUyB','toString','org','31vPbJzD','Instance\x20to\x20use\x20for\x20SSH\x20(random\x20instance\x20will\x20be\x20chosen\x20if\x20not\x20specified)','kill','Ctrl+C\x20received\x20-\x20Terminating\x20SSH\x20proxy...','trim','Failed\x20to\x20spawn\x20SSH\x20command:\x20','execFileAsync','28292hlrucm','SSH\x20session\x20ended.','inherit','Use\x20specific\x20username\x20for\x20SSH\x20connection','data','option','findSSH','708ZDNNLy','askForProject','push','Must\x20be\x20run\x20in\x20an\x20interactive\x20terminal\x20(TTY\x20required).','askForService'];a16Z=function(){return j;};return a16Z();}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 a16T from'chalk';function a16h(Z,h){const T=a16Z();return a16h=function(P,f){P=P-0x182;let V=T[P];return V;},a16h(Z,h);}export class CliSsh{[a16I(0x1c1)];['apiClient'];constructor(Z,h){const k=a16I;this[k(0x1d5)]=new ApiClient(Z,{'throwErrorOnHttpErrorCode':!![],'customUserAgent':customUserAgent,'agent':h});const T=new InquirerHelper(this[k(0x1d5)]);this[k(0x1c1)]=getCommand(!![])[k(0x1a6)]('ssh')[k(0x19a)]('SSH\x20for\x20Northflank\x20services\x20and\x20jobs.');const P=k(0x196),f=getCommand(!![])[k(0x1a6)](P)[k(0x19a)](k(0x1a5)+P+k(0x1a4))[k(0x1ba)](k(0x185),k(0x1c7)+P)[k(0x1ba)]('--'+P+k(0x1cc)+P+k(0x18c),P['charAt'](0x0)[k(0x1c9)]()+P[k(0x1d4)](0x1)+k(0x1d3))[k(0x1ba)](k(0x182),k(0x1af))[k(0x1ba)](k(0x1e0),k(0x1e3),![])[k(0x1ba)]('--useHostnames',k(0x1cf)+P+'\x20hostnames\x20on\x20local\x20machine.\x20Requires\x20sudo\x20permissions',![])['option'](k(0x195),k(0x1b8))['option'](k(0x1da),'Don\x27t\x20use\x20context\x20default\x20values,\x20explicitly\x20use\x20options\x20or\x20ask.',![]);this['apiClient'][k(0x1cd)][k(0x1c4)]()===k(0x1ad)&&f[k(0x1ba)](k(0x19c),'Team\x20id');const V=f[k(0x1e2)](async x=>{const F=k,{noDefaults:d,teamId:U,projectId:B,serviceId:q,instanceName:w,proxyOnly:M,useHostnames:S}=x,{user:user=F(0x187),quiet:z}=x;assertContextExisting(this[F(0x1d5)]);try{const H=d?undefined:Z[F(0x186)](),{projectId:l,teamId:E}=await this[F(0x1ca)](Z,T,B,U,H),Y=d?undefined:Z['getCurrentServiceName'](),y=q||Y||await T[F(0x1c0)](l,E)(),r=w||await T[F(0x19b)](l,y,undefined,![],E,!![])(),p=process[F(0x188)][F(0x1e6)],A=p&&!M,n={'teamId':E,'projectId':l,'serviceId':y,'instanceId':r,'portsFilter':[0x16]};await this[F(0x1d5)]['forwarding']['withServiceForwarding'](n,async a=>{const J=F,G=a[J(0x1a7)](c=>c[J(0x1b9)]?.['portName']===J(0x191));if(G===undefined)throw new Error(J(0x18a));if(G?.[J(0x1d6)]!==undefined||G?.[J(0x1b9)]===undefined)throw new Error(J(0x1a0)+(G?.[J(0x1d6)]?.['message']??J(0x18e)));const {address:L,port:Q,hostnames:O}=G['data'],i=S?O[0x0]??L:L;A?(!z&&success(J(0x1a2)+(i+':'+Q)+J(0x1e1)),await this[J(0x1a8)]({'address':i,'port':Q,'user':user})):(!z?(success(J(0x1a2)+(i+':'+Q)+J(0x199)),console[J(0x18d)]('Use\x20with\x20any\x20SSH\x20compatible\x20client.\x20Example\x20usages:'),console[J(0x18d)]('\x20\x20>\x20SSH\x20session:'+a16T[J(0x1d1)](J(0x197)+user+'@'+i+J(0x18f)+Q)),console[J(0x18d)](J(0x1de)+a16T[J(0x1d1)](J(0x19f)+Q+'\x20'+user+'@'+i)),console['log'](J(0x190)+a16T['blackBright'](J(0x1ce)+Q+J(0x1d8)+user+'@'+i+J(0x183))),console[J(0x18d)](J(0x1dc)+a16T[J(0x1d1)]('scp\x20-P\x20'+Q+J(0x1a9)+user+'@'+i+':/remote/path/'))):console['log'](user,i,Q),await new Promise((c,g)=>{const X=J;process['on']('SIGINT',()=>{const o=a16h;if(!z)success(o(0x1b1));c();}),process['on'](X(0x194),g);}));},!S);}catch(a){error(''+a['message']);}finally{process[F(0x184)]();}});this[k(0x1c1)]['addCommand'](V);}[a16I(0x1b4)]=promisify(execFile);async['findSSH'](){const s=a16I;try{const {stdout:Z}=await this[s(0x1b4)](s(0x1d2),['ssh']);return Z[s(0x1b2)]();}catch{const h=[s(0x1d9),s(0x1a1),s(0x1c6),s(0x1c3)];for(const T of h){try{return await this['execFileAsync'](T,['-V']),T;}catch{}}return null;}}async[a16I(0x1a8)](Z){const t=a16I,h=await this[t(0x1bb)]();if(!h)throw new Error(t(0x1df));if(!process[t(0x188)][t(0x1e6)])throw new Error(t(0x1bf));const {address:T,port:port=0x16,user:user=t(0x187),args:args=[],trusted:trusted=!![]}=Z,P=[];trusted&&P[t(0x1be)]('-o',t(0x1c8),'-o',t(0x18b),'-o',t(0x189));user!=='root'&&P['push']('-o',t(0x193)+user+t(0x1cb),'-o',t(0x1c2));const f=spawn(h,[t(0x1d0),'-p',port[t(0x1ac)](),'-l',t(0x187),...P,...args,T],{'stdio':t(0x1b7)});await new Promise((V,x)=>{const b=t;f['on']('close',(d,U)=>{const R=a16h;if(U)warning(R(0x1db)+U);else d!==0x0?warning(R(0x1c5)+d):success(R(0x1b6));V(d);}),f['on'](b(0x1d6),d=>{const m=b;x(new Error(m(0x1b3)+d[m(0x1aa)]));}),process['on'](b(0x1dd),()=>f[b(0x1b0)](b(0x1dd))),process['on'](b(0x19d),()=>f[b(0x1b0)](b(0x19d)));});}[a16I(0x1ca)]=async(Z,h,T,P,f)=>{const N=a16I,V=Z[N(0x1c4)]()===N(0x1ad)?P??await h['askForTeam']()():undefined,x=T||f||await h[N(0x1bd)](V)();return{'teamId':V,'projectId':x};};}
package/dist/utils.js CHANGED
@@ -1 +1 @@
1
- const a17k=a17l;(function(o,l){const g=a17l,E=o();while(!![]){try{const y=-parseInt(g(0xe5))/0x1*(parseInt(g(0xd4))/0x2)+parseInt(g(0xf1))/0x3+parseInt(g(0xcd))/0x4+-parseInt(g(0xf4))/0x5*(parseInt(g(0xd9))/0x6)+-parseInt(g(0xbe))/0x7+-parseInt(g(0xf6))/0x8+parseInt(g(0xd2))/0x9*(parseInt(g(0xcb))/0xa);if(y===l)break;else E['push'](E['shift']());}catch(N){E['push'](E['shift']());}}}(a17o,0x70e19));function a17l(o,l){const E=a17o();return a17l=function(y,N){y=y-0xb3;let Z=E[y];return Z;},a17l(o,l);}import a17E from'chalk';import{Command}from'commander';import{ProxyAgent}from'proxy-agent';import a17y from'node-fetch';import{readFileSync}from'fs';import{fileURLToPath}from'url';import{dirname,join}from'path';const __filename=fileURLToPath(import.meta[a17k(0xf7)]),__dirname=dirname(__filename),pgk=JSON[a17k(0xb9)](readFileSync(join(__dirname,a17k(0xc7)),a17k(0xf2)));export const customUserAgent=a17k(0xbf)+pgk?.[a17k(0xdb)];export const agent=new ProxyAgent();export const proxyEnvsSet=process[a17k(0xee)][a17k(0xc9)]!==undefined||process[a17k(0xee)]['HTTPS_PROXY']!==undefined;export const decodeJwtPayload=o=>{const J=a17k;try{const l=N=>{const I=a17l,Z=N[I(0xbb)](/-/g,'+')[I(0xbb)](/_/g,'/')[I(0xc2)](N[I(0xc0)]+(0x4-N[I(0xc0)]%0x4)%0x4,'=');return JSON[I(0xb9)](Buffer[I(0xb8)](Z,I(0xc1))[I(0xb7)]());},[E,y]=o[J(0xc5)]('.');return l(y);}catch(N){return{};}};export async function checkUpdate(o){const L=a17k;function l(E,y){const m=a17l,N=new Date(Number(E));return N[m(0xbd)](N[m(0xc8)]()+y),N;}try{if(l(o[L(0xb4)](),0x1)>new Date())return;const E=pgk[L(0xdb)],{name:y}=pgk;if(!E)return;const N=L(0xf0)+y+L(0xc6),Z=await a17y(N,{'agent':agent,'method':L(0xcf),'signal':AbortSignal[L(0xed)](0x1388)}),A=(await Z[L(0xe4)]())[L(0xdb)];needsUpdate(E,A)&&warning(L(0xd7)+E+L(0xe8)+A+'.'+(L(0xe7)+y+L(0xdd)+y+L(0xc4))),await o['setLastUpdateCheck'](new Date());}catch(X){}}function needsUpdate(o,l){const F=a17k,E=/(\.0+)+$/,y=o[F(0xbb)](E,'')[F(0xc5)]('.'),N=l['replace'](E,'')['split']('.');for(let Z=0x0;Z<Math[F(0xe9)](y[F(0xc0)],N['length']);Z+=0x1){const A=parseInt(N[Z],0xa)-parseInt(y[Z],0xa);if(A>0x0)return!![];if(A<0x0)return![];}return N[F(0xc0)]>y[F(0xc0)];}export function error(o){const b=a17k;console['error'](a17E[b(0xf3)](b(0xdc)+o));}export function warning(o){console['error'](a17E['yellow'](''+o));}export function success(o){const q=a17k;console[q(0xd3)](a17E[q(0xba)](''+o));}export function getCommand(o=![]){const V=a17k,l=new Command();return l[V(0xe0)](undefined,V(0xb5)),l[V(0xda)](![]),l[V(0xca)](![]),l[V(0xf5)](![]),l[V(0xd8)](![]),l[V(0xd0)](!![]),o&&(l[V(0xe6)](V(0xcc),V(0xd1),![]),l[V(0xe6)]('--quiet',V(0xd5),![]),l['option'](V(0xef),V(0xe2),![])),l;}export const retry=(o,l=0x32)=>E=>{let y=o;const N=async()=>{try{return await E();}catch(Z){if(y<=0x0)throw Z;return y-=0x1,await new Promise(A=>setTimeout(()=>A(),l)),N();}};return N();};export const asyncSequential=async(o,l)=>{const v=a17k,E=Promise[v(0xb6)]([]);return o[v(0xe3)]((y,N)=>y[v(0xb3)](Z=>l(N)[v(0xb3)](A=>{const w=v;return Z[w(0xd6)](A),Z;})),E);};function a17o(){const T=['25iSMhno','allowUnknownOption','6784800IuDxZt','url','then','getLastUpdateCheck','Display\x20help\x20for\x20command','resolve','toString','from','parse','green','replace','getCurrentToken','setDate','24703iFFtEH','northflank-cli/','length','base64','padEnd','setUTCSeconds','\x27\x20**','split','/latest','../package.json','getDate','HTTP_PROXY','storeOptionsAsProperties','190XFKANU','--verbose','2075108bRYKmM','getTime','GET','enablePositionalOptions','Verbose\x20output','244935ORZFid','log','6406byktDD','No\x20console\x20output','push','**\x20You\x27re\x20running\x20on\x20version\x20','allowExcessArguments','668928SgknFz','addHelpCommand','version','Failed:\x20','\x20-g\x27\x20or\x20\x27yarn\x20global\x20add\x20','Invalid\x20date\x20received:\x20',',\x20expected\x20valid\x20date\x20string\x20(example:\x202020-02-02T02:02:02Z)\x20or\x20unix\x20timestamp\x20(example\x201580608922)','helpOption','No\x20API\x20URL\x20present\x20in\x20context.\x20Create\x20new\x20context\x20with\x20\x27northflank\x20login\x27','Do\x20not\x20validate\x20input\x20fields\x20on\x20client\x20side','reduce','json','7GXgpzA','option','\x20Consider\x20updating\x20using\x20\x27npm\x20i\x20',',\x20the\x20latest\x20version\x20of\x20the\x20cli\x20is\x20','min','No\x20CLI\x20context\x20present.\x20Create\x20context\x20with\x20\x27northflank\x20login\x27','No\x20token\x20in\x20CLI\x20context.\x20Add\x20token\x20with\x20\x27northflank\x20set-token\x27','contextProvider','timeout','env','--skipValidation','https://registry.npmjs.org/','2573967VLCPJW','utf-8','redBright'];a17o=function(){return T;};return a17o();}export function isValidJSON(o){const i=a17k;try{return JSON[i(0xb9)](o);}catch(l){return![];}}export function assertContextExisting(o){const f=a17k;if(o['contextProvider']['getCurrentContext']()===undefined)throw new Error(f(0xea));if(o['contextProvider']['getCurrentBaseUrl']()===undefined)throw new Error(f(0xe1));if(o[f(0xec)][f(0xbc)]()===undefined)throw new Error(f(0xeb));}export const parseDateInput=o=>{const a=a17k;try{let l=new Date(o);if(isNaN(l[a(0xce)]())){const E=o['length']===0xd?o/0x3e8:o,y=new Date(0x0);y[a(0xc3)](E);if(isNaN(y['getTime']()))throw new Error();return y;}return l;}catch(N){throw new Error(a(0xde)+o+a(0xdf));}};export const tsHint='example:\x202020-02-02T02:02:02Z\x20(date\x20string)\x20or\x201580608922\x20(unix\x20ts)';
1
+ const a17B=a17h;(function(Z,h){const U=a17h,T=Z();while(!![]){try{const P=-parseInt(U(0x12d))/0x1+-parseInt(U(0x13a))/0x2*(-parseInt(U(0x130))/0x3)+parseInt(U(0x151))/0x4+parseInt(U(0x127))/0x5+parseInt(U(0x12c))/0x6*(parseInt(U(0x137))/0x7)+parseInt(U(0x155))/0x8+-parseInt(U(0x13d))/0x9;if(P===h)break;else T['push'](T['shift']());}catch(f){T['push'](T['shift']());}}}(a17Z,0x75bfc));import a17T from'chalk';function a17h(Z,h){const T=a17Z();return a17h=function(P,f){P=P-0x126;let V=T[P];return V;},a17h(Z,h);}function a17Z(){const e=['\x20Consider\x20updating\x20using\x20\x27npm\x20i\x20','then','padEnd','utf-8','setUTCSeconds','error','json','\x27\x20**','getLastUpdateCheck','parse','getCurrentContext','../package.json','push','Verbose\x20output','getCurrentBaseUrl','3193692irDXhP','No\x20CLI\x20context\x20present.\x20Create\x20context\x20with\x20\x27northflank\x20login\x27','getTime','setLastUpdateCheck','3484928ygBoFn','redBright','contextProvider','HTTP_PROXY','helpOption','replace','--quiet','resolve','toString','option','reduce',',\x20the\x20latest\x20version\x20of\x20the\x20cli\x20is\x20',',\x20expected\x20valid\x20date\x20string\x20(example:\x202020-02-02T02:02:02Z)\x20or\x20unix\x20timestamp\x20(example\x201580608922)','\x20-g\x27\x20or\x20\x27yarn\x20global\x20add\x20','enablePositionalOptions','Invalid\x20date\x20received:\x20','env','Do\x20not\x20validate\x20input\x20fields\x20on\x20client\x20side','762200xiziEU','split','from','length','base64','1139202jZIDMn','339762iIJejm','/latest','https://registry.npmjs.org/','360RxfSAU','yellow','version','**\x20You\x27re\x20running\x20on\x20version\x20','setDate','allowUnknownOption','--skipValidation','7PBXUUw','example:\x202020-02-02T02:02:02Z\x20(date\x20string)\x20or\x201580608922\x20(unix\x20ts)','No\x20API\x20URL\x20present\x20in\x20context.\x20Create\x20new\x20context\x20with\x20\x27northflank\x20login\x27','2662ftkyEe','GET','url','8226036LunNLL','northflank-cli/','getCurrentToken','Failed:\x20','--verbose'];a17Z=function(){return e;};return a17Z();}import{Command}from'commander';import{ProxyAgent}from'proxy-agent';import a17P from'node-fetch';import{readFileSync}from'fs';import{fileURLToPath}from'url';import{dirname,join}from'path';const __filename=fileURLToPath(import.meta[a17B(0x13c)]),__dirname=dirname(__filename),pgk=JSON[a17B(0x14b)](readFileSync(join(__dirname,a17B(0x14d)),a17B(0x145)));export const customUserAgent=a17B(0x13e)+pgk?.['version'];export const agent=new ProxyAgent();export const proxyEnvsSet=process[a17B(0x165)][a17B(0x158)]!==undefined||process['env']['HTTPS_PROXY']!==undefined;export const decodeJwtPayload=Z=>{const w=a17B;try{const h=f=>{const q=a17h,V=f[q(0x15a)](/-/g,'+')[q(0x15a)](/_/g,'/')[q(0x144)](f[q(0x12a)]+(0x4-f[q(0x12a)]%0x4)%0x4,'=');return JSON[q(0x14b)](Buffer[q(0x129)](V,q(0x12b))[q(0x15d)]());},[T,P]=Z[w(0x128)]('.');return h(P);}catch(f){return{};}};export async function checkUpdate(Z){const S=a17B;function h(T,P){const M=a17h,f=new Date(Number(T));return f[M(0x134)](f['getDate']()+P),f;}try{if(h(Z[S(0x14a)](),0x1)>new Date())return;const T=pgk['version'],{name:P}=pgk;if(!T)return;const f=S(0x12f)+P+S(0x12e),V=await a17P(f,{'agent':agent,'method':S(0x13b),'signal':AbortSignal['timeout'](0x1388)}),x=(await V[S(0x148)]())[S(0x132)];needsUpdate(T,x)&&warning(S(0x133)+T+S(0x160)+x+'.'+(S(0x142)+P+S(0x162)+P+S(0x149))),await Z[S(0x154)](new Date());}catch(d){}}function needsUpdate(Z,h){const z=a17B,T=/(\.0+)+$/,P=Z[z(0x15a)](T,'')[z(0x128)]('.'),f=h['replace'](T,'')[z(0x128)]('.');for(let V=0x0;V<Math['min'](P['length'],f['length']);V+=0x1){const x=parseInt(f[V],0xa)-parseInt(P[V],0xa);if(x>0x0)return!![];if(x<0x0)return![];}return f['length']>P[z(0x12a)];}export function error(Z){const H=a17B;console[H(0x147)](a17T[H(0x156)](H(0x140)+Z));}export function warning(Z){const l=a17B;console[l(0x147)](a17T[l(0x131)](''+Z));}export function success(Z){console['log'](a17T['green'](''+Z));}export function getCommand(Z=![]){const E=a17B,h=new Command();return h[E(0x159)](undefined,'Display\x20help\x20for\x20command'),h['addHelpCommand'](![]),h['storeOptionsAsProperties'](![]),h[E(0x135)](![]),h['allowExcessArguments'](![]),h[E(0x163)](!![]),Z&&(h['option'](E(0x141),E(0x14f),![]),h[E(0x15e)](E(0x15b),'No\x20console\x20output',![]),h[E(0x15e)](E(0x136),E(0x126),![])),h;}export const retry=(Z,h=0x32)=>T=>{let P=Z;const f=async()=>{try{return await T();}catch(V){if(P<=0x0)throw V;return P-=0x1,await new Promise(x=>setTimeout(()=>x(),h)),f();}};return f();};export const asyncSequential=async(Z,h)=>{const Y=a17B,T=Promise[Y(0x15c)]([]);return Z[Y(0x15f)]((P,f)=>P[Y(0x143)](V=>h(f)[Y(0x143)](x=>{const y=Y;return V[y(0x14e)](x),V;})),T);};export function isValidJSON(Z){try{return JSON['parse'](Z);}catch(h){return![];}}export function assertContextExisting(Z){const r=a17B;if(Z['contextProvider'][r(0x14c)]()===undefined)throw new Error(r(0x152));if(Z['contextProvider'][r(0x150)]()===undefined)throw new Error(r(0x139));if(Z[r(0x157)][r(0x13f)]()===undefined)throw new Error('No\x20token\x20in\x20CLI\x20context.\x20Add\x20token\x20with\x20\x27northflank\x20set-token\x27');}export const parseDateInput=Z=>{const p=a17B;try{let h=new Date(Z);if(isNaN(h[p(0x153)]())){const T=Z['length']===0xd?Z/0x3e8:Z,P=new Date(0x0);P[p(0x146)](T);if(isNaN(P[p(0x153)]()))throw new Error();return P;}return h;}catch(f){throw new Error(p(0x164)+Z+p(0x161));}};export const tsHint=a17B(0x138);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@northflank/cli",
3
- "version": "0.11.4",
3
+ "version": "0.11.5",
4
4
  "author": "Marco Suter",
5
5
  "description": "Provides a command-line interface to the Northflank platform.",
6
6
  "homepage": "https://www.northflank.com",