@northflank/cli 0.10.10 → 0.10.11

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 a14l=a14R;(function(O,R){const p=a14R,M=O();while(!![]){try{const i=-parseInt(p(0x95))/0x1*(-parseInt(p(0x7f))/0x2)+parseInt(p(0x8b))/0x3+-parseInt(p(0x81))/0x4+-parseInt(p(0x91))/0x5*(parseInt(p(0x92))/0x6)+-parseInt(p(0x9b))/0x7*(parseInt(p(0x99))/0x8)+parseInt(p(0x89))/0x9+-parseInt(p(0x8f))/0xa*(-parseInt(p(0x98))/0xb);if(i===R)break;else M['push'](M['shift']());}catch(K){M['push'](M['shift']());}}}(a14O,0xb7ad5));import a14M from'inquirer/lib/prompts/list.js';import a14i from'inquirer/lib/objects/choice.js';import a14K from'chalk';function incrementListIndex(O,R,M){const c=a14R,i=M['choices'][c(0x90)],K=c(0x7d)in M?Boolean(M[c(0x7d)]):!![];if(R==='up'){if(O>0x0)return O-0x1;return K?i-0x1:O;}if(R===c(0x8c)){if(O<i-0x1)return O+0x1;return K?0x0:O;}throw new Error(c(0x8d));}export class DynamicReloadPaginationPrompt extends a14M{[a14l(0x85)]=a14K[a14l(0x97)](a14l(0x88));[a14l(0x8e)];[a14l(0x80)]=![];['nextPageCursor'];constructor(O,R,M){const u=a14l;super(O,R,M),this[u(0x8e)]=this[u(0x93)],this[u(0x7e)]=this['pagOpt']['nextPageCursor'],this['nextPageCursor']!==undefined&&this['opt'][u(0x9a)][u(0x86)](new a14i(this[u(0x85)],this[u(0x85)]));}['onUpKey'](){const r=a14l;if(this[r(0x80)])return;this['selected']=incrementListIndex(this[r(0x82)],'up',this[r(0x93)]),this[r(0x87)]();}async[a14l(0x8a)](){const n=a14l;if(this[n(0x80)])return;this[n(0x82)]=incrementListIndex(this['selected'],n(0x8c),this[n(0x93)]),await this[n(0x96)](),this[n(0x87)]();}async[a14l(0x96)](){const Q=a14l;if(this[Q(0x82)]>=this[Q(0x93)][Q(0x9a)][Q(0x84)]-0x1){if(this[Q(0x7e)]===undefined)return;this['loading']=!![];let O=0x0;const R=setInterval(()=>{const L=Q,x=['⠋','⠙','⠹','⠸','⠼','⠴','⠦','⠧','⠇','⠏'],S=a14K[L(0x97)](x[O%x[L(0x84)]]+'\x20Loading\x20more\x20options');this[L(0x93)][L(0x9a)][L(0x9a)][this[L(0x82)]]['name']=''+S,O+=0x1,this[L(0x87)]();},0x50),{elements:M,nextPageCursor:K}=await this[Q(0x8e)][Q(0x94)]({'nextPageCursor':this[Q(0x7e)]})[Q(0x83)](()=>({'elements':[],'nextPageCursor':undefined}));this[Q(0x7e)]=K;const U=M['map'](x=>new a14i(x,x));this[Q(0x93)]['choices'][Q(0x9a)]['splice'](this[Q(0x82)],0x1),this['opt'][Q(0x9a)][Q(0x86)](...U),K!==undefined&&this[Q(0x93)][Q(0x9a)]['push'](new a14i(this[Q(0x85)],this['reloadText'])),clearInterval(R),this[Q(0x80)]=![];}}}function a14R(O,R){const M=a14O();return a14R=function(i,K){i=i-0x7d;let U=M[i];return U;},a14R(O,R);}function a14O(){const A=['nextPageCursor','446tcAWbW','loading','3389796cqRtrU','selected','catch','length','reloadText','push','render','..\x20Load\x20more\x20options\x20..','1315485VVcckS','onDownKey','1888596IyiymY','down','dir\x20must\x20be\x20up\x20or\x20down','pagOpt','3060tYJHqs','realLength','1813325vbaIRK','24SxeArp','opt','loadMore','3929zUINzl','handleDynamicPageLoad','italic','55792yNKwQJ','584RDTgPp','choices','14714zgmzvi','loop'];a14O=function(){return A;};return a14O();}
1
+ const a14Y=a14G;function a14N(){const e=['154mwupbi','20688uasbBq','loop','reloadText','splice','push','italic','choices','718010pKRjVF','opt','nextPageCursor','handleDynamicPageLoad','selected','loading','59055nFRRpO','102VajkLt','realLength','onUpKey','map','1909863CdAVEr','catch','down','onDownKey','40ggdSfx','length','2801533nakoSO','render','1240576iuetGw','\x20Loading\x20more\x20options','dir\x20must\x20be\x20up\x20or\x20down','name','8eCqegl','117805BsxcGl','loadMore','pagOpt','..\x20Load\x20more\x20options\x20..'];a14N=function(){return e;};return a14N();}(function(N,G){const I=a14G,S=N();while(!![]){try{const U=parseInt(I(0x208))/0x1+-parseInt(I(0x211))/0x2*(parseInt(I(0x1fb))/0x3)+parseInt(I(0x1f1))/0x4+-parseInt(I(0x1f6))/0x5*(-parseInt(I(0x209))/0x6)+parseInt(I(0x1ef))/0x7+parseInt(I(0x1f5))/0x8*(parseInt(I(0x20d))/0x9)+-parseInt(I(0x202))/0xa*(parseInt(I(0x1fa))/0xb);if(U===G)break;else S['push'](S['shift']());}catch(K){S['push'](S['shift']());}}}(a14N,0x3a5b4));function a14G(N,G){const S=a14N();return a14G=function(U,K){U=U-0x1ef;let r=S[U];return r;},a14G(N,G);}import a14S from'inquirer/lib/prompts/list.js';import a14U from'inquirer/lib/objects/choice.js';import a14K from'chalk';function incrementListIndex(N,G,S){const d=a14G,U=S[d(0x201)][d(0x20a)],K=d(0x1fc)in S?Boolean(S[d(0x1fc)]):!![];if(G==='up'){if(N>0x0)return N-0x1;return K?U-0x1:N;}if(G===d(0x20f)){if(N<U-0x1)return N+0x1;return K?0x0:N;}throw new Error(d(0x1f3));}export class DynamicReloadPaginationPrompt extends a14S{['reloadText']=a14K[a14Y(0x200)](a14Y(0x1f9));['pagOpt'];[a14Y(0x207)]=![];[a14Y(0x204)];constructor(N,G,S){const u=a14Y;super(N,G,S),this[u(0x1f8)]=this['opt'],this[u(0x204)]=this['pagOpt'][u(0x204)],this[u(0x204)]!==undefined&&this[u(0x203)][u(0x201)][u(0x1ff)](new a14U(this['reloadText'],this['reloadText']));}[a14Y(0x20b)](){const V=a14Y;if(this[V(0x207)])return;this[V(0x206)]=incrementListIndex(this[V(0x206)],'up',this[V(0x203)]),this['render']();}async[a14Y(0x210)](){const a=a14Y;if(this[a(0x207)])return;this[a(0x206)]=incrementListIndex(this[a(0x206)],'down',this[a(0x203)]),await this[a(0x205)](),this['render']();}async[a14Y(0x205)](){const x=a14Y;if(this['selected']>=this[x(0x203)][x(0x201)][x(0x212)]-0x1){if(this['nextPageCursor']===undefined)return;this[x(0x207)]=!![];let N=0x0;const G=setInterval(()=>{const b=x,r=['⠋','⠙','⠹','⠸','⠼','⠴','⠦','⠧','⠇','⠏'],L=a14K[b(0x200)](r[N%r[b(0x212)]]+b(0x1f2));this['opt'][b(0x201)][b(0x201)][this['selected']][b(0x1f4)]=''+L,N+=0x1,this[b(0x1f0)]();},0x50),{elements:S,nextPageCursor:U}=await this[x(0x1f8)][x(0x1f7)]({'nextPageCursor':this[x(0x204)]})[x(0x20e)](()=>({'elements':[],'nextPageCursor':undefined}));this['nextPageCursor']=U;const K=S[x(0x20c)](r=>new a14U(r,r));this[x(0x203)]['choices'][x(0x201)][x(0x1fe)](this[x(0x206)],0x1),this[x(0x203)][x(0x201)][x(0x1ff)](...K),U!==undefined&&this[x(0x203)][x(0x201)][x(0x1ff)](new a14U(this[x(0x1fd)],this['reloadText'])),clearInterval(G),this[x(0x207)]=![];}}}
@@ -1 +1 @@
1
- const a15H=a15R;(function(O,R){const d=a15R,M=O();while(!![]){try{const i=-parseInt(d(0x207))/0x1+parseInt(d(0x205))/0x2*(-parseInt(d(0x1ec))/0x3)+-parseInt(d(0x1e0))/0x4*(parseInt(d(0x1f0))/0x5)+parseInt(d(0x213))/0x6+-parseInt(d(0x1d7))/0x7*(-parseInt(d(0x232))/0x8)+parseInt(d(0x1f7))/0x9*(-parseInt(d(0x203))/0xa)+-parseInt(d(0x1eb))/0xb*(-parseInt(d(0x1da))/0xc);if(i===R)break;else M['push'](M['shift']());}catch(K){M['push'](M['shift']());}}}(a15O,0xb8028));function a15R(O,R){const M=a15O();return a15R=function(i,K){i=i-0x1cf;let U=M[i];return U;},a15R(O,R);}import{ApiClient}from'@northflank/js-client';import a15M from'chalk';import{assertContextExisting,customUserAgent,error,getCommand,success,warning}from'../utils.js';import{InquirerHelper}from'../inquirer-helper.js';function a15O(){const V=['printForwardingInfo','join','\x27:\x20\x22','Instance\x20to\x20forward','action','reset','platform','printHostsFileHint','21864VoUEAi','port','\x20is\x20exposed\x20on\x20','Services:','description','flat','service','canExecuteWithHostnames','\x20\x20\x20\x20\x20\x20\x20\x20\x20','portFwdCmd','greenBright','forwardProject','entries','Port-forwarding\x20for\x20the\x20specified\x20service','data','\x20mode:\x20the\x20locally\x20forwarded\x20port\x20differs\x20from\x20the\x20actual\x20port\x20on\x20the\x20forwarded\x20service/addon.','Only\x20expose\x20on\x20IP\x20address,\x20not\x20on\x20hostnames.\x20With\x20this\x20option,\x20no\x20root\x20permissions\x20are\x20required.','Port-forwarding\x20for\x20Northflank\x20services\x20and\x20addons.','fwd','973NeRKCd','askForProject','with\x20hostname:\x20','28495092ARCOOY','address','Don\x27t\x20use\x20context\x20default\x20values,\x20explicitly\x20use\x20options\x20or\x20ask.','\x20-\x20','Please\x20ensure\x20the\x20','green','2975944ojEZzE','--instance\x20--instanceId\x20[NAME]','\x20flag\x20or\x20manually\x20append\x20following\x20entry\x20to\x20your\x20hosts\x20file\x20(','skipHostnamesText','addon','--addon\x20--addonId\x20[NAME]','project\x20for\x20forwarding','portName',',\x20hostname:\x20','noDefaultsText','getProxyForwarder','11fzwocm','171idFRhe','log','forEach','SIGINT','5IlnSUX','C:/Windows/System32/drivers/etc/hosts','Addon\x20to\x20forward','forward','option','forwarding','\x20service\x20ports','16866hBMqCT','>\x20Instance\x20\x27','\x20\x20\x20No\x20running\x20container\x20found\x20for\x20','protocol','Project\x20for\x20forwarding','Error\x20occured\x20while\x20trying\x20to\x20forward\x20','No\x20services\x20and\x20addons\x20to\x20forward\x20found\x20in\x20project\x20','\x20and\x20','name','exit','hosts','--project\x20--projectId\x20[NAME]','3070Oocesz','\x20addon\x20ports','7472aLTfGz','Connection\x20error\x20occurred\x20when\x20forwarding\x20\x27','601724iyZWOx','forwardService','alias','apiClient','Forwarding\x20addon\x20','Port-forwarding\x20for\x20all\x20services\x20and\x20addons\x20in\x20the\x20given\x20project','all','filter','data.id','\x20\x20If\x20you\x20have\x20added\x20entries\x20to\x20your\x20hosts\x20file,\x20it\x20is\x20recommended\x20to\x20remove\x20them\x20again\x20now.','--skipHostnames','hostnames','799236yAQfWK','askForAddon','bold','tunnel-close','ports','Forwarding\x20','/etc/hosts','message','length','http://','error','\x20in\x20project\x20','win32','--service\x20--serviceId\x20[NAME]','\x20is\x20exposed\x20with\x20multiple\x20','Failed:\x20','\x20with\x20these\x20hostnames:','addCommand','type','Stop\x20forwarding\x20traffic\x20from\x20','Forwarding\x20service\x20','map','getCurrentProjectName'];a15O=function(){return V;};return a15O();}import*as a15i from'os';import{uniqBy,uniq,repeat,groupBy,capitalize}from'lodash-es';import{EOL}from'os';export class CliPortForward{['portFwdCmd'];['apiClient'];[a15H(0x1e9)]=a15H(0x1dc);['skipHostnamesText']=a15H(0x1d4);constructor(O,R){const b=a15H;this[b(0x20a)]=new ApiClient(O,{'throwErrorOnHttpErrorCode':!![],'customUserAgent':customUserAgent,'agent':R});const M=new InquirerHelper(this[b(0x20a)]);this[b(0x23b)]=getCommand()[b(0x1ff)](b(0x1f3))[b(0x209)](b(0x1d6))[b(0x236)](b(0x1d5));const i=getCommand(!![])[b(0x1ff)](b(0x20d))[b(0x236)](b(0x20c))[b(0x1f4)](b(0x202),b(0x1e6))[b(0x1f4)]('--noDefaults',this[b(0x1e9)],![])[b(0x1f4)](b(0x211),this[b(0x1e3)],![])[b(0x22e)](async({noDefaults:x,projectId:S,skipHostnames:p})=>{const I=b;assertContextExisting(this[I(0x20a)]);const c=this[I(0x1ea)](p),l=x?undefined:O[I(0x229)](),u=S||l||await M[I(0x1d8)]();try{const {services:r,addons:n}=await c[I(0x1cf)]({'projectId':u},p);if(r['length']+n[I(0x21b)]<=0x0)warning(I(0x1fd)+a15M[I(0x215)](u));else{const Q=r['filter'](h=>h[I(0x21b)]>0x0)['length'],L=n[I(0x20e)](h=>h[I(0x21b)]>0x0)[I(0x21b)],A=I(0x21e)+a15M[I(0x215)](u);console[I(0x1ed)](I(0x218)+a15M['green'][I(0x215)](Q+I(0x1f6))+I(0x1fe)+a15M[I(0x1df)][I(0x215)](L+I(0x204))+A),console['log'](),console[I(0x1ed)](a15M[I(0x215)](I(0x235))),r['forEach'](h=>{const k=I;if(h[k(0x21b)]>=0x1&&!h[0x0][k(0x21d)])this[k(0x22a)](h,{'type':k(0x238),'name':h[0x0][k(0x1d2)]['id']},p);}),console[I(0x1ed)](a15M[I(0x215)]('Addons:')),n[I(0x1ee)](h=>{const q=I;if(h[q(0x21b)]>=0x1&&!h[0x0][q(0x21d)])this[q(0x22a)](h,{'type':'addon','name':h[0x0][q(0x1d2)]['id']},p);}),this[I(0x231)]([...r[I(0x237)](),...n[I(0x237)]()],p);}}catch(h){error('Failed:\x20'+h[I(0x21a)]);}}),K=getCommand(!![])[b(0x1ff)]('service')[b(0x236)](b(0x1d1))[b(0x1f4)](b(0x202),b(0x1fb))[b(0x1f4)](b(0x220),'Service\x20to\x20forward')['option'](b(0x1e1),b(0x22d))['option']('--noDefaults',this[b(0x1e9)],![])[b(0x1f4)]('--skipHostnames',this[b(0x1e3)],![])[b(0x22e)](async({noDefaults:x,projectId:S,serviceId:p,instanceId:c,skipHostnames:l})=>{const j=b;assertContextExisting(this[j(0x20a)]);const u=this[j(0x1ea)](l),r=x?undefined:O['getCurrentProjectName'](),n=S||r||await M[j(0x1d8)](),Q=x?undefined:O['getCurrentServiceName'](),L=p||Q||await M['askForService'](n)();console[j(0x1ed)](j(0x227)+a15M[j(0x215)](L)+j(0x21e)+a15M[j(0x215)](n));try{const A=await u[j(0x208)]({'projectId':n,'serviceId':L,'instanceId':c},l);this[j(0x22a)](A,{'name':L,'type':j(0x238),'instanceId':c},l),this['printHostsFileHint'](A,l);}catch(h){error(j(0x222)+h['message']);}}),U=getCommand(!![])[b(0x1ff)](b(0x1e4))[b(0x236)]('Port-forwarding\x20for\x20the\x20specified\x20addon')['option'](b(0x202),b(0x1fb))[b(0x1f4)](b(0x1e5),b(0x1f2))[b(0x1f4)]('--skipHostnames',this[b(0x1e3)],![])[b(0x22e)](async({noDefaults:x,projectId:S,addonId:p,skipHostnames:c})=>{const D=b;assertContextExisting(this[D(0x20a)]);const l=this[D(0x1ea)](c),u=x?undefined:O[D(0x229)](),r=S||u||await M[D(0x1d8)](),n=p||await M[D(0x214)](r)();console[D(0x1ed)](D(0x20b)+a15M[D(0x215)](n)+D(0x21e)+a15M[D(0x215)](r));try{const Q={'projectId':r,'addonId':n},L=await l['forwardAddon'](Q,c);this['printForwardingInfo'](L,{'name':n,'type':D(0x1e4)},c),this[D(0x231)](L,c);}catch(A){error(D(0x222)+A[D(0x21a)]);}});this[b(0x23b)]['addCommand'](i),this[b(0x23b)][b(0x224)](K),this['portFwdCmd'][b(0x224)](U);}[a15H(0x1ea)](O=![]){const Y=a15H,R=this[Y(0x20a)][Y(0x1f5)];if(!O){const M=R[Y(0x239)]();if(M[Y(0x21d)])throw new Error(M[Y(0x21a)]);}return R['on'](Y(0x216),(i,K)=>{const N=Y,U=a15M[N(0x215)](K['type']+'\x20\x27'+K['id']+'\x27'),x=K['hostnames'][N(0x21b)]>0x0;warning(N(0x226)+K['address']+':'+K['port']+'\x20to\x20'+U),O&&x&&warning(N(0x210));}),R['on']('connection-error',(i,K,U)=>{const z=Y;warning(z(0x206)+K[z(0x1db)]+':'+K[z(0x233)]+z(0x22c)+U?.[z(0x21a)]+'\x22');}),process['on'](Y(0x1ef),async()=>{const E=Y;try{await R['stop']();}catch(i){error('Cleaning\x20up\x20open\x20connections\x20failed:\x20'+i[E(0x21a)]);}finally{process[E(0x200)]();}}),R;}[a15H(0x22a)](O,R,M=![]){const T=a15H,{type:i,name:K,instanceId:U}=R;if(O[T(0x21b)]<=0x0){const c=T(0x1de)+R[T(0x225)]+'\x20is\x20running\x20and\x20reachable\x20and\x20that\x20a\x20port\x20is\x20defined\x20on\x20the\x20networking\x20section.';warning(T(0x1f9)+i+'\x20'+a15M[T(0x215)](K)+'.\x20'+c);return;}const x=groupBy(O,T(0x20f)),S=l=>'\x20('+(l[T(0x1e7)]?l[T(0x1e7)]+T(0x1dd):'')+l['protocol']+')';function p(l,u=0x2){const W=T;if(!M){const r=l[W(0x1fa)]==='HTTP'?W(0x21c):'';l[W(0x212)]['forEach'](n=>{const F=W;console[F(0x1ed)](repeat('\x20',u)+'-\x20'+r+n+':'+l[F(0x233)]);});}}Object[T(0x1d0)](x)[T(0x1ee)](([l,u])=>{const m=T,r=U?m(0x1f8)+a15M['greenBright'][m(0x215)](U)+'\x27\x20of\x20'+i+'\x20\x27'+a15M[m(0x23c)][m(0x215)](l)+'\x27':'>\x20'+capitalize(i)+'\x20\x27'+a15M[m(0x23c)][m(0x215)](l)+'\x27';if(i===m(0x1e4)){if(u[m(0x21b)]===0x1){const n=u[0x0];if(n[m(0x21d)]){error(m(0x1fc)+l+':\x20'+n[m(0x21d)][m(0x21a)]);return;}const Q=n[m(0x1d2)],L=!M?'\x20'+a15M[m(0x22f)](m(0x1d9)+Q['hostnames'][m(0x22b)](',')):'';success(r+m(0x234)+Q[m(0x1db)]+':'+Q['port']+S(Q)+L);}else{const A=uniqBy(u,h=>h?.[m(0x1d2)]?.[m(0x212)]?.[m(0x22b)](','))[m(0x21b)]>0x1;success(r+m(0x221)+(A?m(0x201):m(0x217))+':'),u[m(0x1ee)](h=>{const w=m;if(h['error']){error('Error\x20occured\x20while\x20trying\x20to\x20forward\x20'+l+':\x20'+h[w(0x21d)][w(0x21a)]);return;}const t=h[w(0x1d2)],G=!M?w(0x1e8)+t[w(0x212)][w(0x22b)](','):'';console[w(0x1ed)]('\x20\x20-\x20Address:\x20'+t[w(0x1db)]+':'+t[w(0x233)]+S(t)+G);});}}if(i===m(0x238)){if(u['length']===0x1){const h=u[0x0];if(h['error']){error(m(0x1fc)+l+':\x20'+h['error'][m(0x21a)]);return;}const t=h[m(0x1d2)],G=!M?m(0x223):':',s=t[m(0x1db)]+':'+t[m(0x233)]+S(t);success(r+m(0x234)+s+G),p(t);}else success(r+'\x20is\x20exposed\x20on\x20'+u[0x0]?.[m(0x1d2)]?.[m(0x1db)]+'\x20with\x20multiple\x20ports:'),u[m(0x1ee)](y=>{const e=m;if(y[e(0x21d)]){error('Error\x20occured\x20while\x20trying\x20to\x20forward\x20'+l+':\x20'+y[e(0x21d)]['message']);return;}const C=y[e(0x1d2)];success('\x20\x20-\x20port\x20'+C[e(0x233)]+S(C)),p(C,0x4);});}});}['printHostsFileHint'](O,R=![]){const B=a15H;if(R){const M=O['flatMap'](l=>l[B(0x1d2)])[B(0x20e)](l=>l!==undefined),i=process?.[B(0x230)]===B(0x21f),K=a15i['platform']()==='darwin',U=i?B(0x1f1):B(0x219),x=a15M[B(0x215)]('skipHostnames'),S=K?EOL+'Running\x20on\x20macOS\x20in\x20'+x+B(0x1d3):undefined;let p='Running\x20in\x20'+x+'\x20mode.\x20If\x20hostname\x20forwarding\x20is\x20required,\x20remove\x20'+B(0x211)+B(0x1e2)+U+'):';S!==undefined&&warning(S??'');warning(p);const c=M[B(0x228)](l=>l[B(0x1db)]+B(0x23a)+l[B(0x212)][B(0x22b)]('\x20'));console[B(0x1ed)](uniq(c)[B(0x22b)](EOL)),console[B(0x1ed)]();}}}
1
+ const a15Z=a15G;(function(N,G){const W=a15G,S=N();while(!![]){try{const U=-parseInt(W(0x1b5))/0x1*(-parseInt(W(0x1e9))/0x2)+parseInt(W(0x1b8))/0x3*(parseInt(W(0x1bc))/0x4)+-parseInt(W(0x201))/0x5+-parseInt(W(0x1cc))/0x6*(parseInt(W(0x1ac))/0x7)+-parseInt(W(0x1c1))/0x8*(-parseInt(W(0x1fa))/0x9)+parseInt(W(0x1f2))/0xa*(parseInt(W(0x1e6))/0xb)+-parseInt(W(0x20b))/0xc*(parseInt(W(0x1f4))/0xd);if(U===G)break;else S['push'](S['shift']());}catch(K){S['push'](S['shift']());}}}(a15N,0x83089));import{ApiClient}from'@northflank/js-client';import a15S from'chalk';function a15G(N,G){const S=a15N();return a15G=function(U,K){U=U-0x1a3;let r=S[U];return r;},a15G(N,G);}import{assertContextExisting,customUserAgent,error,getCommand,success,warning}from'../utils.js';import{InquirerHelper}from'../inquirer-helper.js';function a15N(){const R=['skipHostnamesText','canExecuteWithHostnames','Addon\x20to\x20forward','\x20mode.\x20If\x20hostname\x20forwarding\x20is\x20required,\x20remove\x20','all','getProxyForwarder','\x20\x20\x20No\x20running\x20container\x20found\x20for\x20','flat','data.id','Addons:','\x20flag\x20or\x20manually\x20append\x20following\x20entry\x20to\x20your\x20hosts\x20file\x20(','addon','portFwdCmd','forward','No\x20services\x20and\x20addons\x20to\x20forward\x20found\x20in\x20project\x20','>\x20Instance\x20\x27','SIGINT','green','\x20with\x20these\x20hostnames:','Instance\x20to\x20forward','Cleaning\x20up\x20open\x20connections\x20failed:\x20','Forwarding\x20addon\x20','121zOKmPJ','\x20\x20If\x20you\x20have\x20added\x20entries\x20to\x20your\x20hosts\x20file,\x20it\x20is\x20recommended\x20to\x20remove\x20them\x20again\x20now.','\x20to\x20','4dLoqyv','description','Services:','Port-forwarding\x20for\x20all\x20services\x20and\x20addons\x20in\x20the\x20given\x20project','hosts','--addon\x20--addonId\x20[NAME]','fwd','data','Project\x20for\x20forwarding','220900RAHBiY','protocol','17433741PNLjKv','noDefaultsText','action','message','forwardProject','greenBright','45McJJLD','\x20and\x20','\x20is\x20exposed\x20with\x20multiple\x20','Forwarding\x20service\x20','log',',\x20hostname:\x20','Service\x20to\x20forward','1483540fydISn','portName','\x20addon\x20ports','skipHostnames','\x20is\x20exposed\x20on\x20','\x27:\x20\x22','error','Failed:\x20','option','C:/Windows/System32/drivers/etc/hosts','12KldnHn','addCommand','--project\x20--projectId\x20[NAME]','platform','getCurrentProjectName','bold','flatMap','\x20\x20-\x20port\x20','Error\x20occured\x20while\x20trying\x20to\x20forward\x20','apiClient','printForwardingInfo','\x20\x20\x20\x20\x20\x20\x20\x20\x20','245693kJGVBd','--skipHostnames','http://','forEach','\x20mode:\x20the\x20locally\x20forwarded\x20port\x20differs\x20from\x20the\x20actual\x20port\x20on\x20the\x20forwarded\x20service/addon.','\x27\x20of\x20','--noDefaults','Port-forwarding\x20for\x20the\x20specified\x20service','type','298133qwDwKF','Stop\x20forwarding\x20traffic\x20from\x20','entries','3vLaEQd','askForProject','\x20in\x20project\x20','service','3276492rdhnlo','name','getCurrentServiceName','join','printHostsFileHint','1050392VrBmqt','darwin','Port-forwarding\x20for\x20the\x20specified\x20addon','Please\x20ensure\x20the\x20','stop','hostnames','Forwarding\x20','with\x20hostname:\x20','port','filter','project\x20for\x20forwarding','24wVGmla','address','length','reset'];a15N=function(){return R;};return a15N();}import*as a15U from'os';import{uniqBy,uniq,repeat,groupBy,capitalize}from'lodash-es';import{EOL}from'os';export class CliPortForward{[a15Z(0x1dc)];['apiClient'];[a15Z(0x1f5)]='Don\x27t\x20use\x20context\x20default\x20values,\x20explicitly\x20use\x20options\x20or\x20ask.';[a15Z(0x1d0)]='Only\x20expose\x20on\x20IP\x20address,\x20not\x20on\x20hostnames.\x20With\x20this\x20option,\x20no\x20root\x20permissions\x20are\x20required.';constructor(N,G){const B=a15Z;this[B(0x1a9)]=new ApiClient(N,{'throwErrorOnHttpErrorCode':!![],'customUserAgent':customUserAgent,'agent':G});const S=new InquirerHelper(this[B(0x1a9)]);this['portFwdCmd']=getCommand()[B(0x1bd)](B(0x1dd))['alias'](B(0x1ef))[B(0x1ea)]('Port-forwarding\x20for\x20Northflank\x20services\x20and\x20addons.');const U=getCommand(!![])[B(0x1bd)](B(0x1d4))[B(0x1ea)](B(0x1ec))[B(0x209)]('--project\x20--projectId\x20[NAME]',B(0x1cb))[B(0x209)](B(0x1b2),this['noDefaultsText'],![])['option']('--skipHostnames',this[B(0x1d0)],![])['action'](async({noDefaults:L,projectId:I,skipHostnames:d})=>{const j=B;assertContextExisting(this[j(0x1a9)]);const Y=this[j(0x1d5)](d),u=L?undefined:N[j(0x1a4)](),V=I||u||await S[j(0x1b9)]();try{const {services:a,addons:x}=await Y[j(0x1f8)]({'projectId':V},d);if(a[j(0x1ce)]+x['length']<=0x0)warning(j(0x1de)+a15S[j(0x1a5)](V));else{const b=a[j(0x1ca)](D=>D[j(0x1ce)]>0x0)[j(0x1ce)],f=x[j(0x1ca)](D=>D[j(0x1ce)]>0x0)[j(0x1ce)],n='\x20in\x20project\x20'+a15S[j(0x1a5)](V);console[j(0x1fe)](j(0x1c7)+a15S[j(0x1e1)][j(0x1a5)](b+'\x20service\x20ports')+j(0x1fb)+a15S[j(0x1e1)]['bold'](f+j(0x203))+n),console['log'](),console[j(0x1fe)](a15S[j(0x1a5)](j(0x1eb))),a[j(0x1af)](D=>{const i=j;if(D['length']>=0x1&&!D[0x0][i(0x207)])this[i(0x1aa)](D,{'type':'service','name':D[0x0]['data']['id']},d);}),console[j(0x1fe)](a15S[j(0x1a5)](j(0x1d9))),x[j(0x1af)](D=>{const l=j;if(D[l(0x1ce)]>=0x1&&!D[0x0]['error'])this['printForwardingInfo'](D,{'type':l(0x1db),'name':D[0x0][l(0x1f0)]['id']},d);}),this['printHostsFileHint']([...a[j(0x1d7)](),...x[j(0x1d7)]()],d);}}catch(D){error(j(0x208)+D[j(0x1f7)]);}}),K=getCommand(!![])[B(0x1bd)](B(0x1bb))[B(0x1ea)](B(0x1b3))[B(0x209)](B(0x20d),B(0x1f1))[B(0x209)]('--service\x20--serviceId\x20[NAME]',B(0x200))[B(0x209)]('--instance\x20--instanceId\x20[NAME]',B(0x1e3))[B(0x209)](B(0x1b2),this[B(0x1f5)],![])[B(0x209)](B(0x1ad),this[B(0x1d0)],![])[B(0x1f6)](async({noDefaults:L,projectId:I,serviceId:d,instanceId:Y,skipHostnames:u})=>{const k=B;assertContextExisting(this['apiClient']);const V=this[k(0x1d5)](u),a=L?undefined:N['getCurrentProjectName'](),x=I||a||await S[k(0x1b9)](),b=L?undefined:N[k(0x1be)](),f=d||b||await S['askForService'](x)();console['log'](k(0x1fd)+a15S[k(0x1a5)](f)+k(0x1ba)+a15S['bold'](x));try{const n=await V['forwardService']({'projectId':x,'serviceId':f,'instanceId':Y},u);this[k(0x1aa)](n,{'name':f,'type':k(0x1bb),'instanceId':Y},u),this[k(0x1c0)](n,u);}catch(D){error(k(0x208)+D[k(0x1f7)]);}}),r=getCommand(!![])[B(0x1bd)](B(0x1db))['description'](B(0x1c3))[B(0x209)]('--project\x20--projectId\x20[NAME]',B(0x1f1))[B(0x209)](B(0x1ee),B(0x1d2))['option'](B(0x1ad),this['skipHostnamesText'],![])[B(0x1f6)](async({noDefaults:L,projectId:I,addonId:d,skipHostnames:Y})=>{const h=B;assertContextExisting(this[h(0x1a9)]);const u=this[h(0x1d5)](Y),V=L?undefined:N[h(0x1a4)](),a=I||V||await S[h(0x1b9)](),x=d||await S['askForAddon'](a)();console[h(0x1fe)](h(0x1e5)+a15S[h(0x1a5)](x)+h(0x1ba)+a15S['bold'](a));try{const b={'projectId':a,'addonId':x},f=await u['forwardAddon'](b,Y);this[h(0x1aa)](f,{'name':x,'type':h(0x1db)},Y),this[h(0x1c0)](f,Y);}catch(n){error(h(0x208)+n['message']);}});this[B(0x1dc)][B(0x20c)](U),this[B(0x1dc)][B(0x20c)](K),this[B(0x1dc)][B(0x20c)](r);}['getProxyForwarder'](N=![]){const O=a15Z,G=this['apiClient']['forwarding'];if(!N){const S=G[O(0x1d1)]();if(S[O(0x207)])throw new Error(S[O(0x1f7)]);}return G['on']('tunnel-close',(U,K)=>{const J=O,r=a15S[J(0x1a5)](K[J(0x1b4)]+'\x20\x27'+K['id']+'\x27'),L=K[J(0x1c6)]['length']>0x0;warning(J(0x1b6)+K[J(0x1cd)]+':'+K[J(0x1c9)]+J(0x1e8)+r),N&&L&&warning(J(0x1e7));}),G['on']('connection-error',(U,K,r)=>{const t=O;warning('Connection\x20error\x20occurred\x20when\x20forwarding\x20\x27'+K[t(0x1cd)]+':'+K[t(0x1c9)]+t(0x206)+r?.[t(0x1f7)]+'\x22');}),process['on'](O(0x1e0),async()=>{const P=O;try{await G[P(0x1c5)]();}catch(U){error(P(0x1e4)+U[P(0x1f7)]);}finally{process['exit']();}}),G;}['printForwardingInfo'](N,G,S=![]){const y=a15Z,{type:U,name:K,instanceId:r}=G;if(N['length']<=0x0){const Y=y(0x1c4)+G[y(0x1b4)]+'\x20is\x20running\x20and\x20reachable\x20and\x20that\x20a\x20port\x20is\x20defined\x20on\x20the\x20networking\x20section.';warning(y(0x1d6)+U+'\x20'+a15S['bold'](K)+'.\x20'+Y);return;}const L=groupBy(N,y(0x1d8)),I=u=>'\x20('+(u[y(0x202)]?u['portName']+'\x20-\x20':'')+u[y(0x1f3)]+')';function d(u,V=0x2){const c=y;if(!S){const a=u[c(0x1f3)]==='HTTP'?c(0x1ae):'';u[c(0x1c6)][c(0x1af)](x=>{const M=c;console[M(0x1fe)](repeat('\x20',V)+'-\x20'+a+x+':'+u[M(0x1c9)]);});}}Object[y(0x1b7)](L)[y(0x1af)](([u,V])=>{const X=y,a=r?X(0x1df)+a15S[X(0x1f9)]['bold'](r)+X(0x1b1)+U+'\x20\x27'+a15S[X(0x1f9)][X(0x1a5)](u)+'\x27':'>\x20'+capitalize(U)+'\x20\x27'+a15S[X(0x1f9)][X(0x1a5)](u)+'\x27';if(U===X(0x1db)){if(V[X(0x1ce)]===0x1){const x=V[0x0];if(x[X(0x207)]){error(X(0x1a8)+u+':\x20'+x[X(0x207)][X(0x1f7)]);return;}const b=x[X(0x1f0)],e=!S?'\x20'+a15S[X(0x1cf)](X(0x1c8)+b[X(0x1c6)][X(0x1bf)](',')):'';success(a+X(0x205)+b[X(0x1cd)]+':'+b[X(0x1c9)]+I(b)+e);}else{const f=uniqBy(V,n=>n?.[X(0x1f0)]?.[X(0x1c6)]?.[X(0x1bf)](','))['length']>0x1;success(a+X(0x1fc)+(f?X(0x1ed):'ports')+':'),V[X(0x1af)](n=>{const o=X;if(n[o(0x207)]){error(o(0x1a8)+u+':\x20'+n[o(0x207)][o(0x1f7)]);return;}const D=n[o(0x1f0)],g=!S?o(0x1ff)+D[o(0x1c6)][o(0x1bf)](','):'';console[o(0x1fe)]('\x20\x20-\x20Address:\x20'+D['address']+':'+D['port']+I(D)+g);});}}if(U==='service'){if(V[X(0x1ce)]===0x1){const n=V[0x0];if(n[X(0x207)]){error('Error\x20occured\x20while\x20trying\x20to\x20forward\x20'+u+':\x20'+n['error']['message']);return;}const D=n[X(0x1f0)],g=!S?X(0x1e2):':',z=D['address']+':'+D[X(0x1c9)]+I(D);success(a+X(0x205)+z+g),d(D);}else success(a+'\x20is\x20exposed\x20on\x20'+V[0x0]?.[X(0x1f0)]?.[X(0x1cd)]+'\x20with\x20multiple\x20ports:'),V[X(0x1af)](v=>{const p=X;if(v[p(0x207)]){error('Error\x20occured\x20while\x20trying\x20to\x20forward\x20'+u+':\x20'+v[p(0x207)][p(0x1f7)]);return;}const E=v[p(0x1f0)];success(p(0x1a7)+E[p(0x1c9)]+I(E)),d(E,0x4);});}});}[a15Z(0x1c0)](N,G=![]){const C=a15Z;if(G){const S=N[C(0x1a6)](u=>u[C(0x1f0)])[C(0x1ca)](u=>u!==undefined),U=process?.[C(0x1a3)]==='win32',K=a15U[C(0x1a3)]()===C(0x1c2),r=U?C(0x20a):'/etc/hosts',L=a15S['bold'](C(0x204)),I=K?EOL+'Running\x20on\x20macOS\x20in\x20'+L+C(0x1b0):undefined;let d='Running\x20in\x20'+L+C(0x1d3)+'--skipHostnames'+C(0x1da)+r+'):';I!==undefined&&warning(I??'');warning(d);const Y=S['map'](u=>u[C(0x1cd)]+C(0x1ab)+u[C(0x1c6)][C(0x1bf)]('\x20'));console['log'](uniq(Y)['join'](EOL)),console[C(0x1fe)]();}}}
package/dist/utils.js CHANGED
@@ -1 +1 @@
1
- const a16c=a16R;(function(O,R){const p=a16R,M=O();while(!![]){try{const i=-parseInt(p(0xc5))/0x1*(parseInt(p(0xe8))/0x2)+parseInt(p(0xcb))/0x3+-parseInt(p(0xe6))/0x4+parseInt(p(0xe1))/0x5+parseInt(p(0xed))/0x6*(parseInt(p(0xd6))/0x7)+-parseInt(p(0xda))/0x8*(parseInt(p(0xc2))/0x9)+-parseInt(p(0xe4))/0xa*(-parseInt(p(0xf3))/0xb);if(i===R)break;else M['push'](M['shift']());}catch(K){M['push'](M['shift']());}}}(a16O,0x324b9));import a16M from'chalk';import{Command}from'commander';import{ProxyAgent}from'proxy-agent';import a16i from'node-fetch';import{readFileSync}from'fs';import{fileURLToPath}from'url';import{dirname,join}from'path';function a16R(O,R){const M=a16O();return a16R=function(i,K){i=i-0xbc;let U=M[i];return U;},a16R(O,R);}const __filename=fileURLToPath(import.meta[a16c(0xe9)]),__dirname=dirname(__filename),pgk=JSON[a16c(0xdc)](readFileSync(join(__dirname,a16c(0xc9)),a16c(0xeb)));export const customUserAgent=a16c(0xc7)+pgk?.[a16c(0xec)];function a16O(){const s=['10Snrfhg','addHelpCommand','986192VRUfWd','option','2JTAOlW','url','HTTP_PROXY','utf-8','version','36fZjFlw','HTTPS_PROXY','No\x20token\x20in\x20CLI\x20context.\x20Add\x20token\x20with\x20\x27northflank\x20set-token\x27','helpOption','Failed:\x20','error','5203319DdaaoN','min','from','example:\x202020-02-02T02:02:02Z\x20(date\x20string)\x20or\x201580608922\x20(unix\x20ts)','No\x20console\x20output','/latest','setLastUpdateCheck','env',',\x20the\x20latest\x20version\x20of\x20the\x20cli\x20is\x20','**\x20You\x27re\x20running\x20on\x20version\x20','contextProvider','padEnd','35172mbJVro','allowExcessArguments','--verbose','280931KSrPsx','getLastUpdateCheck','northflank-cli/','reduce','../package.json','replace','584553kagMvU','length','\x20Consider\x20updating\x20using\x20\x27npm\x20i\x20','enablePositionalOptions','getCurrentBaseUrl','split','https://registry.npmjs.org/','Do\x20not\x20validate\x20input\x20fields\x20on\x20client\x20side','getTime','then','yellow','6727UAKZhM','--quiet',',\x20expected\x20valid\x20date\x20string\x20(example:\x202020-02-02T02:02:02Z)\x20or\x20unix\x20timestamp\x20(example\x201580608922)','No\x20CLI\x20context\x20present.\x20Create\x20context\x20with\x20\x27northflank\x20login\x27','96ZrEhZI','resolve','parse','json','Verbose\x20output','\x20-g\x27\x20or\x20\x27yarn\x20global\x20add\x20','getCurrentToken','533690OMquWE','Invalid\x20date\x20received:\x20','redBright'];a16O=function(){return s;};return a16O();}export const agent=new ProxyAgent();export const proxyEnvsSet=process[a16c(0xbd)][a16c(0xea)]!==undefined||process[a16c(0xbd)][a16c(0xee)]!==undefined;export const decodeJwtPayload=O=>{try{const R=K=>{const l=a16R,U=K['replace'](/-/g,'+')[l(0xca)](/_/g,'/')[l(0xc1)](K[l(0xcc)]+(0x4-K[l(0xcc)]%0x4)%0x4,'=');return JSON[l(0xdc)](Buffer[l(0xf5)](U,'base64')['toString']());},[M,i]=O['split']('.');return R(i);}catch(K){return{};}};export async function checkUpdate(O){const u=a16c;function R(M,i){const K=new Date(Number(M));return K['setDate'](K['getDate']()+i),K;}try{if(R(O[u(0xc6)](),0x1)>new Date())return;const M=pgk[u(0xec)],{name:i}=pgk;if(!M)return;const K=u(0xd1)+i+u(0xf8),U=await a16i(K,{'agent':agent,'method':'GET','signal':AbortSignal['timeout'](0x1388)}),x=(await U[u(0xdd)]())[u(0xec)];needsUpdate(M,x)&&warning(u(0xbf)+M+u(0xbe)+x+'.'+(u(0xcd)+i+u(0xdf)+i+'\x27\x20**')),await O[u(0xbc)](new Date());}catch(S){}}function needsUpdate(O,R){const r=a16c,M=/(\.0+)+$/,K=O[r(0xca)](M,'')[r(0xd0)]('.'),U=R[r(0xca)](M,'')['split']('.');for(let x=0x0;x<Math[r(0xf4)](K[r(0xcc)],U['length']);x+=0x1){const S=parseInt(U[x],0xa)-parseInt(K[x],0xa);if(S>0x0)return!![];if(S<0x0)return![];}return U[r(0xcc)]>K['length'];}export function error(O){const n=a16c;console[n(0xf2)](a16M[n(0xe3)](n(0xf1)+O));}export function warning(O){const Q=a16c;console[Q(0xf2)](a16M[Q(0xd5)](''+O));}export function success(O){console['log'](a16M['green'](''+O));}export function getCommand(O=![]){const L=a16c,R=new Command();return R[L(0xf0)](undefined,'Display\x20help\x20for\x20command'),R[L(0xe5)](![]),R['storeOptionsAsProperties'](![]),R['allowUnknownOption'](![]),R[L(0xc3)](![]),R[L(0xce)](!![]),O&&(R[L(0xe7)](L(0xc4),L(0xde),![]),R['option'](L(0xd7),L(0xf7),![]),R['option']('--skipValidation',L(0xd2),![])),R;}export const retry=(O,R=0x32)=>M=>{let i=O;const K=async()=>{try{return await M();}catch(U){if(i<=0x0)throw U;return i-=0x1,await new Promise(x=>setTimeout(()=>x(),R)),K();}};return K();};export const asyncSequential=async(O,R)=>{const A=a16c,M=Promise[A(0xdb)]([]);return O[A(0xc8)]((i,K)=>i[A(0xd4)](U=>R(K)[A(0xd4)](x=>{return U['push'](x),U;})),M);};export function isValidJSON(O){const h=a16c;try{return JSON[h(0xdc)](O);}catch(R){return![];}}export function assertContextExisting(O){const t=a16c;if(O[t(0xc0)]['getCurrentContext']()===undefined)throw new Error(t(0xd9));if(O['contextProvider'][t(0xcf)]()===undefined)throw new Error('No\x20API\x20URL\x20present\x20in\x20context.\x20Create\x20new\x20context\x20with\x20\x27northflank\x20login\x27');if(O[t(0xc0)][t(0xe0)]()===undefined)throw new Error(t(0xef));}export const parseDateInput=O=>{const G=a16c;try{let R=new Date(O);if(isNaN(R['getTime']())){const M=O[G(0xcc)]===0xd?O/0x3e8:O,i=new Date(0x0);i['setUTCSeconds'](M);if(isNaN(i[G(0xd3)]()))throw new Error();return i;}return R;}catch(K){throw new Error(G(0xe2)+O+G(0xd8));}};export const tsHint=a16c(0xf6);
1
+ const a16Y=a16G;(function(N,G){const d=a16G,S=N();while(!![]){try{const U=parseInt(d(0xe8))/0x1+-parseInt(d(0xf6))/0x2+-parseInt(d(0xd4))/0x3*(-parseInt(d(0xf7))/0x4)+parseInt(d(0xf0))/0x5*(-parseInt(d(0x10b))/0x6)+-parseInt(d(0xd8))/0x7+parseInt(d(0xe4))/0x8*(parseInt(d(0xe9))/0x9)+-parseInt(d(0x107))/0xa;if(U===G)break;else S['push'](S['shift']());}catch(K){S['push'](S['shift']());}}}(a16N,0x38dc7));import a16S from'chalk';import{Command}from'commander';import{ProxyAgent}from'proxy-agent';import a16U from'node-fetch';import{readFileSync}from'fs';function a16G(N,G){const S=a16N();return a16G=function(U,K){U=U-0xd1;let r=S[U];return r;},a16G(N,G);}import{fileURLToPath}from'url';import{dirname,join}from'path';const __filename=fileURLToPath(import.meta[a16Y(0xd9)]),__dirname=dirname(__filename),pgk=JSON[a16Y(0x102)](readFileSync(join(__dirname,a16Y(0xfe)),a16Y(0xd1)));export const customUserAgent=a16Y(0x10a)+pgk?.['version'];export const agent=new ProxyAgent();export const proxyEnvsSet=process[a16Y(0xd7)][a16Y(0xff)]!==undefined||process[a16Y(0xd7)][a16Y(0xdc)]!==undefined;export const decodeJwtPayload=N=>{const V=a16Y;try{const G=K=>{const u=a16G,r=K[u(0xe5)](/-/g,'+')['replace'](/_/g,'/')['padEnd'](K['length']+(0x4-K[u(0xd3)]%0x4)%0x4,'=');return JSON[u(0x102)](Buffer[u(0xd2)](r,u(0x101))[u(0x10c)]());},[S,U]=N[V(0x109)]('.');return G(U);}catch(K){return{};}};export async function checkUpdate(N){const x=a16Y;function G(S,U){const a=a16G,K=new Date(Number(S));return K[a(0xdf)](K['getDate']()+U),K;}try{if(G(N['getLastUpdateCheck'](),0x1)>new Date())return;const S=pgk[x(0xf9)],{name:U}=pgk;if(!S)return;const K=x(0x104)+U+x(0xea),r=await a16U(K,{'agent':agent,'method':x(0xf5),'signal':AbortSignal['timeout'](0x1388)}),L=(await r[x(0xeb)]())[x(0xf9)];needsUpdate(S,L)&&warning(x(0x100)+S+x(0xfc)+L+'.'+(x(0xf2)+U+x(0xda)+U+x(0xf3))),await N[x(0xe0)](new Date());}catch(I){}}function needsUpdate(N,G){const b=a16Y,S=/(\.0+)+$/,U=N[b(0xe5)](S,'')[b(0x109)]('.'),K=G[b(0xe5)](S,'')[b(0x109)]('.');for(let r=0x0;r<Math[b(0xd6)](U[b(0xd3)],K[b(0xd3)]);r+=0x1){const L=parseInt(K[r],0xa)-parseInt(U[r],0xa);if(L>0x0)return!![];if(L<0x0)return![];}return K[b(0xd3)]>U[b(0xd3)];}export function error(N){const e=a16Y;console['error'](a16S[e(0xfb)](e(0xdd)+N));}function a16N(){const W=['base64','parse','getCurrentContext','https://registry.npmjs.org/','--quiet','log','2976850KqksEB','then','split','northflank-cli/','17346VcLlLX','toString','push','getTime','utf-8','from','length','6KqUpmg','contextProvider','min','env','3066721tsPbmO','url','\x20-g\x27\x20or\x20\x27yarn\x20global\x20add\x20','Invalid\x20date\x20received:\x20','HTTPS_PROXY','Failed:\x20','addHelpCommand','setDate','setLastUpdateCheck','storeOptionsAsProperties','option','enablePositionalOptions','528sDNBIp','replace','No\x20console\x20output','getCurrentBaseUrl','148743XExyCi','61443keGazS','/latest','json','yellow','resolve','--verbose',',\x20expected\x20valid\x20date\x20string\x20(example:\x202020-02-02T02:02:02Z)\x20or\x20unix\x20timestamp\x20(example\x201580608922)','5zqLGOy','No\x20token\x20in\x20CLI\x20context.\x20Add\x20token\x20with\x20\x27northflank\x20set-token\x27','\x20Consider\x20updating\x20using\x20\x27npm\x20i\x20','\x27\x20**','--skipValidation','GET','174802izlDBk','919316VGIpqX','error','version','getCurrentToken','redBright',',\x20the\x20latest\x20version\x20of\x20the\x20cli\x20is\x20','setUTCSeconds','../package.json','HTTP_PROXY','**\x20You\x27re\x20running\x20on\x20version\x20'];a16N=function(){return W;};return a16N();}export function warning(N){const f=a16Y;console[f(0xf8)](a16S[f(0xec)](''+N));}export function success(N){const n=a16Y;console[n(0x106)](a16S['green'](''+N));}export function getCommand(N=![]){const D=a16Y,G=new Command();return G['helpOption'](undefined,'Display\x20help\x20for\x20command'),G[D(0xde)](![]),G[D(0xe1)](![]),G['allowUnknownOption'](![]),G['allowExcessArguments'](![]),G[D(0xe3)](!![]),N&&(G[D(0xe2)](D(0xee),'Verbose\x20output',![]),G[D(0xe2)](D(0x105),D(0xe6),![]),G[D(0xe2)](D(0xf4),'Do\x20not\x20validate\x20input\x20fields\x20on\x20client\x20side',![])),G;}export const retry=(N,G=0x32)=>S=>{let U=N;const K=async()=>{try{return await S();}catch(r){if(U<=0x0)throw r;return U-=0x1,await new Promise(L=>setTimeout(()=>L(),G)),K();}};return K();};export const asyncSequential=async(N,G)=>{const g=a16Y,S=Promise[g(0xed)]([]);return N['reduce']((U,K)=>U[g(0x108)](r=>G(K)[g(0x108)](L=>{const z=g;return r[z(0x10d)](L),r;})),S);};export function isValidJSON(N){try{return JSON['parse'](N);}catch(G){return![];}}export function assertContextExisting(N){const v=a16Y;if(N[v(0xd5)][v(0x103)]()===undefined)throw new Error('No\x20CLI\x20context\x20present.\x20Create\x20context\x20with\x20\x27northflank\x20login\x27');if(N[v(0xd5)][v(0xe7)]()===undefined)throw new Error('No\x20API\x20URL\x20present\x20in\x20context.\x20Create\x20new\x20context\x20with\x20\x27northflank\x20login\x27');if(N['contextProvider'][v(0xfa)]()===undefined)throw new Error(v(0xf1));}export const parseDateInput=N=>{const E=a16Y;try{let G=new Date(N);if(isNaN(G[E(0x10e)]())){const S=N[E(0xd3)]===0xd?N/0x3e8:N,U=new Date(0x0);U[E(0xfd)](S);if(isNaN(U[E(0x10e)]()))throw new Error();return U;}return G;}catch(K){throw new Error(E(0xdb)+N+E(0xef));}};export const tsHint='example:\x202020-02-02T02:02:02Z\x20(date\x20string)\x20or\x201580608922\x20(unix\x20ts)';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@northflank/cli",
3
- "version": "0.10.10",
3
+ "version": "0.10.11",
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,6 +27,7 @@
27
27
  "LICENSE"
28
28
  ],
29
29
  "dependencies": {
30
+ "@northflank/js-client": "0.8.9",
30
31
  "bufferutil": "^4.0.9",
31
32
  "chalk": "~5.6.2",
32
33
  "columnify": "^1.6.0",