@northflank/cli 0.10.16 → 0.11.0

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
+ function a14l(){const x=['italic','loading','42nCmZqw','4PzpIHQ','length','112912pJYTVP','pagOpt','1766604rMIYQF','handleDynamicPageLoad','onUpKey','push','name','opt','367181MnKohi','render','realLength','onDownKey','map','\x20Loading\x20more\x20options','down','66267VAGUpW','11iBXNha','nextPageCursor','reloadText','selected','5112790LuuPrw','1843375JuOhbU','2tYOnMO','loop','3812148avHJor','choices','splice','..\x20Load\x20more\x20options\x20..','catch'];a14l=function(){return x;};return a14l();}function a14e(l,e){const s=a14l();return a14e=function(f,i){f=f-0x18f;let c=s[f];return c;},a14e(l,e);}const a14b=a14e;(function(l,e){const Y=a14e,s=l();while(!![]){try{const f=-parseInt(Y(0x198))/0x1*(-parseInt(Y(0x1a6))/0x2)+parseInt(Y(0x192))/0x3+-parseInt(Y(0x1b0))/0x4*(parseInt(Y(0x1a5))/0x5)+-parseInt(Y(0x1a8))/0x6+-parseInt(Y(0x1af))/0x7*(parseInt(Y(0x190))/0x8)+-parseInt(Y(0x19f))/0x9+-parseInt(Y(0x1a4))/0xa*(-parseInt(Y(0x1a0))/0xb);if(f===e)break;else s['push'](s['shift']());}catch(i){s['push'](s['shift']());}}}(a14l,0x5aa30));import a14s from'inquirer/lib/prompts/list.js';import a14f from'inquirer/lib/objects/choice.js';import a14i from'chalk';function incrementListIndex(l,e,s){const T=a14e,f=s['choices'][T(0x19a)],i=T(0x1a7)in s?Boolean(s[T(0x1a7)]):!![];if(e==='up'){if(l>0x0)return l-0x1;return i?f-0x1:l;}if(e===T(0x19e)){if(l<f-0x1)return l+0x1;return i?0x0:l;}throw new Error('dir\x20must\x20be\x20up\x20or\x20down');}export class DynamicReloadPaginationPrompt extends a14s{[a14b(0x1a2)]=a14i[a14b(0x1ad)](a14b(0x1ab));[a14b(0x191)];['loading']=![];['nextPageCursor'];constructor(l,e,s){const q=a14b;super(l,e,s),this['pagOpt']=this['opt'],this[q(0x1a1)]=this[q(0x191)][q(0x1a1)],this['nextPageCursor']!==undefined&&this['opt'][q(0x1a9)][q(0x195)](new a14f(this[q(0x1a2)],this[q(0x1a2)]));}[a14b(0x194)](){const t=a14b;if(this[t(0x1ae)])return;this['selected']=incrementListIndex(this[t(0x1a3)],'up',this[t(0x197)]),this[t(0x199)]();}async[a14b(0x19b)](){const J=a14b;if(this['loading'])return;this[J(0x1a3)]=incrementListIndex(this[J(0x1a3)],'down',this[J(0x197)]),await this[J(0x193)](),this[J(0x199)]();}async[a14b(0x193)](){const N=a14b;if(this[N(0x1a3)]>=this[N(0x197)][N(0x1a9)]['length']-0x1){if(this[N(0x1a1)]===undefined)return;this[N(0x1ae)]=!![];let l=0x0;const e=setInterval(()=>{const Z=N,a=['⠋','⠙','⠹','⠸','⠼','⠴','⠦','⠧','⠇','⠏'],D=a14i[Z(0x1ad)](a[l%a[Z(0x18f)]]+Z(0x19d));this['opt'][Z(0x1a9)][Z(0x1a9)][this[Z(0x1a3)]][Z(0x196)]=''+D,l+=0x1,this[Z(0x199)]();},0x50),{elements:s,nextPageCursor:f}=await this[N(0x191)]['loadMore']({'nextPageCursor':this[N(0x1a1)]})[N(0x1ac)](()=>({'elements':[],'nextPageCursor':undefined}));this[N(0x1a1)]=f;const c=s[N(0x19c)](a=>new a14f(a,a));this['opt']['choices'][N(0x1a9)][N(0x1aa)](this[N(0x1a3)],0x1),this[N(0x197)]['choices']['push'](...c),f!==undefined&&this[N(0x197)][N(0x1a9)][N(0x195)](new a14f(this['reloadText'],this[N(0x1a2)])),clearInterval(e),this[N(0x1ae)]=![];}}}
@@ -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 a15B=a15e;(function(l,e){const F=a15e,s=l();while(!![]){try{const f=parseInt(F(0x11a))/0x1*(parseInt(F(0x168))/0x2)+-parseInt(F(0x166))/0x3+parseInt(F(0x14f))/0x4*(-parseInt(F(0x159))/0x5)+parseInt(F(0x129))/0x6*(parseInt(F(0x154))/0x7)+-parseInt(F(0x17b))/0x8+parseInt(F(0x17d))/0x9*(parseInt(F(0x152))/0xa)+parseInt(F(0x16f))/0xb;if(f===e)break;else s['push'](s['shift']());}catch(i){s['push'](s['shift']());}}}(a15l,0x7bb1a));function a15e(l,e){const s=a15l();return a15e=function(f,i){f=f-0x109;let c=s[f];return c;},a15e(l,e);}import{ApiClient}from'@northflank/js-client';import a15s from'chalk';import{assertContextExisting,customUserAgent,error,getCommand,success,warning}from'../utils.js';import{InquirerHelper}from'../inquirer-helper.js';import*as a15f from'os';function a15l(){const n=['address','service','askForAddon','--addon\x20--addonId\x20[NAME]','Forwarding\x20','forward','>\x20Instance\x20\x27','platform','connection-error','\x20\x20-\x20Address:\x20','askForProjectContext','name','Forwarding\x20service\x20','log','askForProject','--noDefaults','getCurrentServiceName','entries','noDefaultsText','flatMap','Forwarding\x20addon\x20','length','124KoSLfD','\x20is\x20exposed\x20on\x20','stop','890150NCenbc','action','133IUezIQ','askForService','\x20flag\x20or\x20manually\x20append\x20following\x20entry\x20to\x20your\x20hosts\x20file\x20(','forEach','\x27:\x20\x22','21355ZZpZJZ',',\x20hostname:\x20','Stop\x20forwarding\x20traffic\x20from\x20','greenBright','\x20with\x20these\x20hostnames:','option','win32','hosts','Project\x20for\x20forwarding','Failed:\x20','green','No\x20services\x20and\x20addons\x20to\x20forward\x20found\x20in\x20project\x20','--instance\x20--instanceId\x20[NAME]','1471299ljtwLC','skipHostnames','5418iGgFMb','\x20in\x20project\x20','data','Team\x20for\x20forwarding','/etc/hosts','description','\x20and\x20','5211019yvOEhT','\x20mode:\x20the\x20locally\x20forwarded\x20port\x20differs\x20from\x20the\x20actual\x20port\x20on\x20the\x20forwarded\x20service/addon.','tunnel-close','--skipHostnames','protocol','Services:','forwardProject','addCommand','bold','askForTeam','reset','Cleaning\x20up\x20open\x20connections\x20failed:\x20','8079744ZrxGHW','printForwardingInfo','9MkPDbQ','Port-forwarding\x20for\x20the\x20specified\x20service','fwd','alias','\x20addon\x20ports','\x20\x20-\x20port\x20','http://','--team\x20--teamId\x20[TEAMID]','\x20\x20\x20\x20\x20\x20\x20\x20\x20','Addons:','Connection\x20error\x20occurred\x20when\x20forwarding\x20\x27','getProxyForwarder','Service\x20to\x20forward','Addon\x20to\x20forward','forwardService','forwarding','contextProvider','portFwdCmd','skipHostnamesText','darwin','Error\x20occured\x20while\x20trying\x20to\x20forward\x20','331YfAVIa','addon','hostnames','portName','Don\x27t\x20use\x20context\x20default\x20values,\x20explicitly\x20use\x20options\x20or\x20ask.','getBaseCommand','canExecuteWithHostnames','\x20with\x20multiple\x20ports:','\x20-\x20','SIGINT','\x20mode.\x20If\x20hostname\x20forwarding\x20is\x20required,\x20remove\x20','\x20\x20\x20No\x20running\x20container\x20found\x20for\x20','error','flat','Port-forwarding\x20for\x20all\x20services\x20and\x20addons\x20in\x20the\x20given\x20project','214746VhwbDs','getCurrentProjectName','port','apiClient','C:/Windows/System32/drivers/etc/hosts','--project\x20--projectId\x20[NAME]','Running\x20on\x20macOS\x20in\x20','filter','data.id','join','getTokenScope','Please\x20ensure\x20the\x20','message','org','printHostsFileHint','type'];a15l=function(){return n;};return a15l();}import{uniqBy,uniq,repeat,groupBy,capitalize}from'lodash-es';import{EOL}from'os';export class CliPortForward{['portFwdCmd'];[a15B(0x12c)];['noDefaultsText']=a15B(0x11e);[a15B(0x117)]='Only\x20expose\x20on\x20IP\x20address,\x20not\x20on\x20hostnames.\x20With\x20this\x20option,\x20no\x20root\x20permissions\x20are\x20required.';constructor(l,e){const k=a15B;this[k(0x12c)]=new ApiClient(l,{'throwErrorOnHttpErrorCode':!![],'customUserAgent':customUserAgent,'agent':e});const s=new InquirerHelper(this['apiClient']);this[k(0x116)]=getCommand()[k(0x144)](k(0x13e))[k(0x180)](k(0x17f))[k(0x16d)]('Port-forwarding\x20for\x20Northflank\x20services\x20and\x20addons.');const f=this['getBaseCommand']()[k(0x144)]('all')[k(0x16d)](k(0x128))['option'](k(0x148),this[k(0x14b)],![])[k(0x15e)]('--skipHostnames',this[k(0x117)],![])['action'](async({noDefaults:a,teamId:D,projectId:Y,skipHostnames:T})=>{const v=k;assertContextExisting(this['apiClient']);const b=this[v(0x110)](T),q=a?undefined:l[v(0x12a)](),{projectId:t,teamId:J}=await this['askForProjectContext'](l,s,D,Y,q);try{const {services:N,addons:Z}=await b[v(0x175)]({'teamId':J,'projectId':t},T);if(N[v(0x14e)]+Z['length']<=0x0)warning(v(0x164)+a15s[v(0x177)](t));else{const x=N[v(0x130)](o=>o['length']>0x0)[v(0x14e)],g=Z[v(0x130)](o=>o[v(0x14e)]>0x0)[v(0x14e)],S=v(0x169)+a15s[v(0x177)](t);console[v(0x146)](v(0x13d)+a15s[v(0x163)][v(0x177)](x+'\x20service\x20ports')+v(0x16e)+a15s[v(0x163)][v(0x177)](g+v(0x109))+S),console[v(0x146)](),console['log'](a15s[v(0x177)](v(0x174))),N[v(0x157)](o=>{const r=v;if(o[r(0x14e)]>=0x1&&!o[0x0][r(0x126)])this['printForwardingInfo'](o,{'type':r(0x13a),'name':o[0x0]['data']['id']},T);}),console[v(0x146)](a15s['bold'](v(0x10e))),Z[v(0x157)](o=>{const W=v;if(o[W(0x14e)]>=0x1&&!o[0x0][W(0x126)])this['printForwardingInfo'](o,{'type':'addon','name':o[0x0][W(0x16a)]['id']},T);}),this[v(0x137)]([...N[v(0x127)](),...Z[v(0x127)]()],T);}}catch(o){error('Failed:\x20'+o['message']);}}),i=this[k(0x11f)]()['name'](k(0x13a))[k(0x16d)](k(0x17e))[k(0x15e)]('--service\x20--serviceId\x20[NAME]',k(0x111))[k(0x15e)](k(0x165),'Instance\x20to\x20forward')[k(0x15e)](k(0x148),this['noDefaultsText'],![])['option'](k(0x172),this[k(0x117)],![])[k(0x153)](async({noDefaults:a,teamId:D,projectId:Y,serviceId:T,instanceId:b,skipHostnames:q})=>{const u=k;assertContextExisting(this[u(0x12c)]);const t=this[u(0x110)](q),J=a?undefined:l[u(0x12a)](),{projectId:N,teamId:Z}=await this[u(0x143)](l,s,Y,D,J),x=a?undefined:l[u(0x149)](),g=T||x||await s[u(0x155)](N,Z)();console[u(0x146)](u(0x145)+a15s[u(0x177)](g)+u(0x169)+a15s['bold'](N));try{const S=await t[u(0x113)]({'teamId':Z,'projectId':N,'serviceId':g,'instanceId':b},q);this[u(0x17c)](S,{'name':g,'type':'service','instanceId':b},q),this[u(0x137)](S,q);}catch(o){error(u(0x162)+o[u(0x135)]);}}),c=this['getBaseCommand']()[k(0x144)](k(0x11b))[k(0x16d)]('Port-forwarding\x20for\x20the\x20specified\x20addon')[k(0x15e)](k(0x13c),k(0x112))[k(0x15e)](k(0x172),this['skipHostnamesText'],![])[k(0x153)](async({noDefaults:a,teamId:D,projectId:Y,addonId:T,skipHostnames:b})=>{const V=k;assertContextExisting(this['apiClient']);const q=this[V(0x110)](b),t=a?undefined:l[V(0x12a)](),{projectId:J,teamId:N}=await this[V(0x143)](l,s,Y,D,t),Z=T||await s[V(0x13b)](J,N)();console['log'](V(0x14d)+a15s[V(0x177)](Z)+V(0x169)+a15s[V(0x177)](J));try{const x={'teamId':N,'projectId':J,'addonId':Z},g=await q['forwardAddon'](x,b);this[V(0x17c)](g,{'name':Z,'type':'addon'},b),this[V(0x137)](g,b);}catch(S){error(V(0x162)+S['message']);}});this[k(0x116)][k(0x176)](f),this[k(0x116)][k(0x176)](i),this[k(0x116)][k(0x176)](c);}['getBaseCommand']=()=>{const h=a15B,l=getCommand(!![])['option'](h(0x12e),h(0x161));return this[h(0x12c)][h(0x115)][h(0x133)]()===h(0x136)&&l[h(0x15e)](h(0x10c),h(0x16b)),l;};[a15B(0x110)](l=![]){const R=a15B,e=this[R(0x12c)][R(0x114)];if(!l){const s=e[R(0x120)]();if(s[R(0x126)])throw new Error(s[R(0x135)]);}return e['on'](R(0x171),(f,i)=>{const m=R,c=a15s[m(0x177)](i[m(0x138)]+'\x20\x27'+i['id']+'\x27'),a=i[m(0x11c)][m(0x14e)]>0x0;warning(m(0x15b)+i[m(0x139)]+':'+i[m(0x12b)]+'\x20to\x20'+c),l&&a&&warning('\x20\x20If\x20you\x20have\x20added\x20entries\x20to\x20your\x20hosts\x20file,\x20it\x20is\x20recommended\x20to\x20remove\x20them\x20again\x20now.');}),e['on'](R(0x141),(f,i,c)=>{const X=R;warning(X(0x10f)+i[X(0x139)]+':'+i[X(0x12b)]+X(0x158)+c?.['message']+'\x22');}),process['on'](R(0x123),async()=>{const j=R;try{await e[j(0x151)]();}catch(f){error(j(0x17a)+f[j(0x135)]);}finally{process['exit']();}}),e;}[a15B(0x17c)](l,e,s=![]){const d=a15B,{type:f,name:i,instanceId:c}=e;if(l[d(0x14e)]<=0x0){const T=d(0x134)+e['type']+'\x20is\x20running\x20and\x20reachable\x20and\x20that\x20a\x20port\x20is\x20defined\x20on\x20the\x20networking\x20section.';warning(d(0x125)+f+'\x20'+a15s[d(0x177)](i)+'.\x20'+T);return;}const a=groupBy(l,d(0x131)),D=b=>'\x20('+(b['portName']?b[d(0x11d)]+d(0x122):'')+b[d(0x173)]+')';function Y(b,q=0x2){const w=d;if(!s){const t=b[w(0x173)]==='HTTP'?w(0x10b):'';b[w(0x11c)][w(0x157)](J=>{const H=w;console[H(0x146)](repeat('\x20',q)+'-\x20'+t+J+':'+b[H(0x12b)]);});}}Object[d(0x14a)](a)[d(0x157)](([b,q])=>{const M=d,t=c?M(0x13f)+a15s[M(0x15c)]['bold'](c)+'\x27\x20of\x20'+f+'\x20\x27'+a15s[M(0x15c)][M(0x177)](b)+'\x27':'>\x20'+capitalize(f)+'\x20\x27'+a15s[M(0x15c)][M(0x177)](b)+'\x27';if(f===M(0x11b)){if(q[M(0x14e)]===0x1){const J=q[0x0];if(J['error']){error(M(0x119)+b+':\x20'+J['error'][M(0x135)]);return;}const N=J[M(0x16a)],Z=!s?'\x20'+a15s[M(0x179)]('with\x20hostname:\x20'+N[M(0x11c)][M(0x132)](',')):'';success(t+M(0x150)+N[M(0x139)]+':'+N[M(0x12b)]+D(N)+Z);}else{const x=uniqBy(q,g=>g?.['data']?.[M(0x11c)]?.[M(0x132)](','))[M(0x14e)]>0x1;success(t+'\x20is\x20exposed\x20with\x20multiple\x20'+(x?M(0x160):'ports')+':'),q['forEach'](g=>{const A=M;if(g[A(0x126)]){error(A(0x119)+b+':\x20'+g[A(0x126)][A(0x135)]);return;}const S=g[A(0x16a)],o=!s?A(0x15a)+S['hostnames'][A(0x132)](','):'';console[A(0x146)](A(0x142)+S['address']+':'+S['port']+D(S)+o);});}}if(f===M(0x13a)){if(q['length']===0x1){const g=q[0x0];if(g['error']){error(M(0x119)+b+':\x20'+g['error']['message']);return;}const S=g['data'],o=!s?M(0x15d):':',G=S[M(0x139)]+':'+S[M(0x12b)]+D(S);success(t+M(0x150)+G+o),Y(S);}else success(t+M(0x150)+q[0x0]?.[M(0x16a)]?.[M(0x139)]+M(0x121)),q[M(0x157)](I=>{const L=M;if(I[L(0x126)]){error(L(0x119)+b+':\x20'+I['error'][L(0x135)]);return;}const P=I['data'];success(L(0x10a)+P['port']+D(P)),Y(P,0x4);});}});}[a15B(0x137)](l,e=![]){const C=a15B;if(e){const s=l[C(0x14c)](b=>b[C(0x16a)])[C(0x130)](b=>b!==undefined),f=process?.[C(0x140)]===C(0x15f),i=a15f[C(0x140)]()===C(0x118),c=f?C(0x12d):C(0x16c),a=a15s['bold'](C(0x167)),D=i?EOL+C(0x12f)+a+C(0x170):undefined;let Y='Running\x20in\x20'+a+C(0x124)+'--skipHostnames'+C(0x156)+c+'):';D!==undefined&&warning(D??'');warning(Y);const T=s['map'](b=>b[C(0x139)]+C(0x10d)+b[C(0x11c)][C(0x132)]('\x20'));console[C(0x146)](uniq(T)[C(0x132)](EOL)),console[C(0x146)]();}}[a15B(0x143)]=async(l,e,s,f,i)=>{const y=a15B,c=l[y(0x133)]()===y(0x136)?f??await e[y(0x178)]():undefined,a=s||i||await e[y(0x147)](c)();return{'teamId':c,'projectId':a};};}
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 a16w=a16e;function a16l(){const n=['Replicate\x20','error','61828JDkjSp','SIGTERM','sshCmd','service','SSH\x20for\x20Northflank\x20services\x20and\x20jobs.','RequestTTY=yes','log','apiClient','\x20\x20>\x20SCP:\x20\x20\x09','2YUHlWD','288XKSlYx','--proxyOnly','Error\x20trying\x20to\x20forward:\x20','scp\x20-P\x20','Team\x20id','39466UaXqra','C:\x5cWindows\x5cSystem32\x5cOpenSSH\x5cssh.exe','findSSH','--instance\x20--instanceName\x20[NAME]','Instance\x20to\x20use\x20for\x20SSH\x20(random\x20instance\x20will\x20be\x20chosen\x20if\x20not\x20specified)','execFileAsync','getCurrentProjectName','charAt','sftp\x20-P\x20','push','Use\x20specific\x20username\x20for\x20SSH\x20connection','--team\x20--teamId\x20[TEAMID]','\x20\x20>\x20RSYNC:\x20\x20\x09','startSSH','\x20hostnames\x20on\x20local\x20machine.\x20Requires\x20sudo\x20permissions','\x20\x20>\x20SSH\x20session:','message','option','Only\x20startup\x20SSH\x20proxy\x20without\x20opening\x20an\x20SSH\x20terminal\x20session.','/usr/local/bin/ssh','1048NqPfpe','stdin','getTokenScope','\x22\x20./data/\x20','root','default-ssh','807264lWjIRg','--noDefaults','34684yhMHbc','15MmPfnf','toString',',\x20stop\x20with\x20Ctrl+C','action','\x20to\x20ssh\x20into','org','portName','name','.\x20Creates\x20an\x20SSH\x20terminal\x20session\x20by\x20default.','getCurrentServiceName','inherit','Establish\x20SSH\x20connectivity\x20to\x20Northflank\x20','1374965xvElJh','Don\x27t\x20use\x20context\x20default\x20values,\x20explicitly\x20use\x20options\x20or\x20ask.','Project\x20of\x20the\x20','blackBright','contextProvider','askForContainer','\x20--','data','exit','7011ZqWILM','isTTY','--project\x20--projectId\x20[NAME]','description','toUpperCase','17510NTuqYa','rsync\x20-avz\x20-e\x20\x22ssh\x20-p\x20','withServiceForwarding','slice','SSH\x20session\x20ended.','SSH\x20proxy\x20started\x20on\x20endpoint:\x20','\x20\x20>\x20SFTP:\x20\x20\x09','find','SSH\x20exited\x20with\x20code:\x20','Must\x20be\x20run\x20in\x20an\x20interactive\x20terminal\x20(TTY\x20required).','517gbVDDI','SIGINT','close','unknown\x20error','\x20-l','Unable\x20to\x20initiate\x20SSH\x20tunnel.\x20Ensure\x20your\x20service\x20is\x20running\x20and\x20has\x20SSH\x20enabled','SSH\x20binary\x20not\x20found.\x20Please\x20install\x20OpenSSH.','\x20file.txt\x20','askForTeam','askForProject','Ctrl+C\x20received\x20-\x20Terminating\x20SSH\x20proxy...'];a16l=function(){return n;};return a16l();}function a16e(l,e){const s=a16l();return a16e=function(f,i){f=f-0xa5;let c=s[f];return c;},a16e(l,e);}(function(l,e){const R=a16e,s=l();while(!![]){try{const f=parseInt(R(0xcf))/0x1*(parseInt(R(0xd8))/0x2)+parseInt(R(0xfb))/0x3*(parseInt(R(0xfa))/0x4)+-parseInt(R(0xaa))/0x5+parseInt(R(0xd9))/0x6*(parseInt(R(0xde))/0x7)+-parseInt(R(0xf2))/0x8*(parseInt(R(0xb3))/0x9)+-parseInt(R(0xb8))/0xa*(-parseInt(R(0xc2))/0xb)+parseInt(R(0xf8))/0xc;if(f===e)break;else s['push'](s['shift']());}catch(i){s['push'](s['shift']());}}}(a16l,0x2436e));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 a16s from'chalk';export class CliSsh{['sshCmd'];['apiClient'];constructor(l,e){const m=a16e;this[m(0xd6)]=new ApiClient(l,{'throwErrorOnHttpErrorCode':!![],'customUserAgent':customUserAgent,'agent':e});const s=new InquirerHelper(this[m(0xd6)]);this['sshCmd']=getCommand(!![])[m(0xa5)]('ssh')[m(0xb6)](m(0xd3));const f=m(0xd2),i=getCommand(!![])[m(0xa5)](f)[m(0xb6)](m(0xa9)+f+m(0xa6))[m(0xef)](m(0xb5),m(0xac)+f)[m(0xef)]('--'+f+m(0xb0)+f+'Id\x20[NAME]',f[m(0xe5)](0x0)[m(0xb7)]()+f[m(0xbb)](0x1)+m(0xff))[m(0xef)](m(0xe1),m(0xe2))[m(0xef)](m(0xda),m(0xf0),![])[m(0xef)]('--useHostnames',m(0xcd)+f+m(0xec),![])['option']('--user\x20[USER]',m(0xe8))[m(0xef)](m(0xf9),m(0xab),![]);this[m(0xd6)][m(0xae)]['getTokenScope']()===m(0x100)&&i['option'](m(0xe9),m(0xdd));const c=i[m(0xfe)](async a=>{const X=m,{noDefaults:D,teamId:Y,projectId:T,serviceId:b,instanceName:q,proxyOnly:t,useHostnames:J}=a,{user:user='root',quiet:N}=a;assertContextExisting(this[X(0xd6)]);try{const Z=D?undefined:l[X(0xe4)](),{projectId:x,teamId:g}=await this['askForProjectContext'](l,s,T,Y,Z),S=D?undefined:l[X(0xa7)](),o=b||S||await s['askForService'](x,g)(),G=q||await s[X(0xaf)](x,o,undefined,![],g,!![])(),I=process['stdin'][X(0xb4)],P=I&&!t,F={'teamId':g,'projectId':x,'serviceId':o,'instanceId':G,'portsFilter':[0x16]};await this[X(0xd6)]['forwarding'][X(0xba)](F,async B=>{const j=X,k=B[j(0xbf)](V=>V[j(0xb1)]?.[j(0x101)]===j(0xf7));if(k===undefined)throw new Error(j(0xc7));if(k?.[j(0xce)]!==undefined||k?.[j(0xb1)]===undefined)throw new Error(j(0xdb)+(k?.[j(0xce)]?.[j(0xee)]??j(0xc5)));const {address:v,port:r,hostnames:W}=k[j(0xb1)],u=J?W[0x0]??v:v;P?(!N&&success(j(0xbd)+(u+':'+r)+',\x20stop\x20with\x20Ctrl+D'),await this[j(0xeb)]({'address':u,'port':r,'user':user})):(!N?(success(j(0xbd)+(u+':'+r)+j(0xfd)),console['log']('Use\x20with\x20any\x20SSH\x20compatible\x20client.\x20Example\x20usages:'),console['log'](j(0xed)+a16s['blackBright']('ssh\x20'+user+'@'+u+'\x20-p\x20'+r)),console[j(0xd5)](j(0xbe)+a16s[j(0xad)](j(0xe6)+r+'\x20'+user+'@'+u)),console[j(0xd5)](j(0xea)+a16s[j(0xad)](j(0xb9)+r+j(0xf5)+user+'@'+u+':/rsync-test/')),console[j(0xd5)](j(0xd7)+a16s['blackBright'](j(0xdc)+r+j(0xc9)+user+'@'+u+':/remote/path/'))):console[j(0xd5)](user,u,r),await new Promise((V,h)=>{process['on']('SIGINT',()=>{const d=a16e;if(!N)success(d(0xcc));V();}),process['on']('uncaughtException',h);}));},!J);}catch(B){error(''+B['message']);}finally{process[X(0xb2)]();}});this[m(0xd1)]['addCommand'](c);}['execFileAsync']=promisify(execFile);async[a16w(0xe0)](){const H=a16w;try{const {stdout:l}=await this[H(0xe3)]('which',['ssh']);return l['trim']();}catch{const e=['ssh','/usr/bin/ssh',H(0xf1),H(0xdf)];for(const s of e){try{return await this[H(0xe3)](s,['-V']),s;}catch{}}return null;}}async[a16w(0xeb)](l){const M=a16w,e=await this[M(0xe0)]();if(!e)throw new Error(M(0xc8));if(!process[M(0xf3)][M(0xb4)])throw new Error(M(0xc1));const {address:s,port:port=0x16,user:user=M(0xf6),args:args=[],trusted:trusted=!![]}=l,f=[];trusted&&f[M(0xe7)]('-o','StrictHostKeyChecking=no','-o','UserKnownHostsFile=/dev/null','-o','LogLevel=ERROR');user!==M(0xf6)&&f[M(0xe7)]('-o','RemoteCommand=su\x20'+user+M(0xc6),'-o',M(0xd4));const i=spawn(e,['-tt','-p',port[M(0xfc)](),'-l',M(0xf6),...f,...args,s],{'stdio':M(0xa8)});await new Promise((c,a)=>{const A=M;i['on'](A(0xc4),(D,Y)=>{const L=A;if(Y)warning('SSH\x20killed\x20by\x20signal:\x20'+Y);else D!==0x0?warning(L(0xc0)+D):success(L(0xbc));c(D);}),i['on'](A(0xce),D=>{const C=A;a(new Error('Failed\x20to\x20spawn\x20SSH\x20command:\x20'+D[C(0xee)]));}),process['on']('SIGINT',()=>i['kill'](A(0xc3))),process['on'](A(0xd0),()=>i['kill'](A(0xd0)));});}['askForProjectContext']=async(l,e,s,f,i)=>{const y=a16w,c=l[y(0xf4)]()===y(0x100)?f??await e[y(0xca)]():undefined,a=s||i||await e[y(0xcb)](c)();return{'teamId':c,'projectId':a};};}
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 a17b=a17e;(function(l,e){const T=a17e,s=l();while(!![]){try{const f=-parseInt(T(0x150))/0x1*(-parseInt(T(0x11f))/0x2)+parseInt(T(0x145))/0x3+-parseInt(T(0x14d))/0x4+-parseInt(T(0x155))/0x5+-parseInt(T(0x126))/0x6*(parseInt(T(0x157))/0x7)+parseInt(T(0x13e))/0x8+parseInt(T(0x143))/0x9;if(f===e)break;else s['push'](s['shift']());}catch(i){s['push'](s['shift']());}}}(a17l,0x3136f));function a17e(l,e){const s=a17l();return a17e=function(f,i){f=f-0x119;let c=s[f];return c;},a17e(l,e);}import a17s from'chalk';import{Command}from'commander';import{ProxyAgent}from'proxy-agent';import a17f from'node-fetch';import{readFileSync}from'fs';import{fileURLToPath}from'url';function a17l(){const B=['example:\x202020-02-02T02:02:02Z\x20(date\x20string)\x20or\x201580608922\x20(unix\x20ts)','toString','setDate','413400aMfHsd','Do\x20not\x20validate\x20input\x20fields\x20on\x20client\x20side','21IXSVAa','min','\x20Consider\x20updating\x20using\x20\x27npm\x20i\x20','enablePositionalOptions','setUTCSeconds','--verbose','option','getDate','url','getCurrentToken','log','error','94LBaKNk','replace','getCurrentBaseUrl','--skipValidation','redBright','Verbose\x20output','helpOption','153192xiJtCB','utf-8','timeout','split','No\x20token\x20in\x20CLI\x20context.\x20Add\x20token\x20with\x20\x27northflank\x20set-token\x27','getLastUpdateCheck',',\x20the\x20latest\x20version\x20of\x20the\x20cli\x20is\x20','then','No\x20console\x20output','HTTPS_PROXY','setLastUpdateCheck','northflank-cli/','No\x20CLI\x20context\x20present.\x20Create\x20context\x20with\x20\x27northflank\x20login\x27','env','/latest','../package.json','allowUnknownOption','Invalid\x20date\x20received:\x20','\x20-g\x27\x20or\x20\x27yarn\x20global\x20add\x20','HTTP_PROXY','contextProvider','**\x20You\x27re\x20running\x20on\x20version\x20','version','length','260832YFvuUN','reduce',',\x20expected\x20valid\x20date\x20string\x20(example:\x202020-02-02T02:02:02Z)\x20or\x20unix\x20timestamp\x20(example\x201580608922)','getCurrentContext','https://registry.npmjs.org/','1885482WbcHdr','yellow','239451TPvZfh','parse','getTime','Display\x20help\x20for\x20command','addHelpCommand','from','GET','No\x20API\x20URL\x20present\x20in\x20context.\x20Create\x20new\x20context\x20with\x20\x27northflank\x20login\x27','1170392zYiHPm','push','json','7054ivDvWj','padEnd'];a17l=function(){return B;};return a17l();}import{dirname,join}from'path';const __filename=fileURLToPath(import.meta[a17b(0x11b)]),__dirname=dirname(__filename),pgk=JSON[a17b(0x146)](readFileSync(join(__dirname,a17b(0x135)),a17b(0x127)));export const customUserAgent=a17b(0x131)+pgk?.[a17b(0x13c)];export const agent=new ProxyAgent();export const proxyEnvsSet=process['env'][a17b(0x139)]!==undefined||process[a17b(0x133)][a17b(0x12f)]!==undefined;export const decodeJwtPayload=l=>{const t=a17b;try{const s=c=>{const q=a17e,a=c['replace'](/-/g,'+')[q(0x120)](/_/g,'/')[q(0x151)](c[q(0x13d)]+(0x4-c[q(0x13d)]%0x4)%0x4,'=');return JSON[q(0x146)](Buffer[q(0x14a)](a,'base64')[q(0x153)]());},[f,i]=l[t(0x129)]('.');return s(i);}catch(c){return{};}};export async function checkUpdate(l){const N=a17b;function s(f,i){const J=a17e,c=new Date(Number(f));return c[J(0x154)](c[J(0x11a)]()+i),c;}try{if(s(l[N(0x12b)](),0x1)>new Date())return;const f=pgk[N(0x13c)],{name:i}=pgk;if(!f)return;const c=N(0x142)+i+N(0x134),a=await a17f(c,{'agent':agent,'method':N(0x14b),'signal':AbortSignal[N(0x128)](0x1388)}),D=(await a[N(0x14f)]())[N(0x13c)];needsUpdate(f,D)&&warning(N(0x13b)+f+N(0x12c)+D+'.'+(N(0x159)+i+N(0x138)+i+'\x27\x20**')),await l[N(0x130)](new Date());}catch(Y){}}function needsUpdate(l,e){const Z=a17b,s=/(\.0+)+$/,f=l[Z(0x120)](s,'')[Z(0x129)]('.'),c=e['replace'](s,'')[Z(0x129)]('.');for(let a=0x0;a<Math[Z(0x158)](f['length'],c[Z(0x13d)]);a+=0x1){const D=parseInt(c[a],0xa)-parseInt(f[a],0xa);if(D>0x0)return!![];if(D<0x0)return![];}return c[Z(0x13d)]>f['length'];}export function error(l){const x=a17b;console[x(0x11e)](a17s[x(0x123)]('Failed:\x20'+l));}export function warning(l){const g=a17b;console['error'](a17s[g(0x144)](''+l));}export function success(l){const S=a17b;console[S(0x11d)](a17s['green'](''+l));}export function getCommand(l=![]){const o=a17b,e=new Command();return e[o(0x125)](undefined,o(0x148)),e[o(0x149)](![]),e['storeOptionsAsProperties'](![]),e[o(0x136)](![]),e['allowExcessArguments'](![]),e[o(0x15a)](!![]),l&&(e[o(0x119)](o(0x15c),o(0x124),![]),e[o(0x119)]('--quiet',o(0x12e),![]),e[o(0x119)](o(0x122),o(0x156),![])),e;}export const retry=(l,e=0x32)=>s=>{let f=l;const i=async()=>{try{return await s();}catch(c){if(f<=0x0)throw c;return f-=0x1,await new Promise(a=>setTimeout(()=>a(),e)),i();}};return i();};export const asyncSequential=async(l,e)=>{const G=a17b,s=Promise['resolve']([]);return l[G(0x13f)]((f,i)=>f[G(0x12d)](c=>e(i)[G(0x12d)](a=>{const I=G;return c[I(0x14e)](a),c;})),s);};export function isValidJSON(l){try{return JSON['parse'](l);}catch(s){return![];}}export function assertContextExisting(l){const P=a17b;if(l[P(0x13a)][P(0x141)]()===undefined)throw new Error(P(0x132));if(l[P(0x13a)][P(0x121)]()===undefined)throw new Error(P(0x14c));if(l[P(0x13a)][P(0x11c)]()===undefined)throw new Error(P(0x12a));}export const parseDateInput=l=>{const F=a17b;try{let s=new Date(l);if(isNaN(s['getTime']())){const f=l[F(0x13d)]===0xd?l/0x3e8:l,i=new Date(0x0);i[F(0x15b)](f);if(isNaN(i[F(0x147)]()))throw new Error();return i;}return s;}catch(c){throw new Error(F(0x137)+l+F(0x140));}};export const tsHint=a17b(0x152);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@northflank/cli",
3
- "version": "0.10.16",
3
+ "version": "0.11.0",
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.0",
31
31
  "bufferutil": "^4.0.9",
32
32
  "chalk": "~5.6.2",
33
33
  "columnify": "^1.6.0",