@gadgetinc/ggt 1.3.2 → 1.4.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.
Files changed (92) hide show
  1. package/README.md +2 -2
  2. package/dist/add-FTY6SEGW.js +78 -0
  3. package/dist/{add-OTQMXZUR.js.map → add-FTY6SEGW.js.map} +2 -2
  4. package/dist/chunk-6BALPDKR.js +2 -0
  5. package/dist/{chunk-3V7YWBUK.js.map → chunk-6BALPDKR.js.map} +2 -2
  6. package/dist/chunk-B2QVXD4S.js +2 -0
  7. package/dist/{chunk-B6XQEEUK.js.map → chunk-B2QVXD4S.js.map} +2 -2
  8. package/dist/chunk-DKP76YB2.js +11 -0
  9. package/dist/{chunk-HCQR6OPH.js.map → chunk-DKP76YB2.js.map} +2 -2
  10. package/dist/{chunk-3HRT72TB.js → chunk-FLX4WQHD.js} +7 -5
  11. package/dist/chunk-FLX4WQHD.js.map +7 -0
  12. package/dist/chunk-IOJ2LNUK.js +2 -0
  13. package/dist/{chunk-SGMPMYEU.js.map → chunk-IOJ2LNUK.js.map} +2 -2
  14. package/dist/chunk-KXSKHE3X.js +65 -0
  15. package/dist/chunk-KXSKHE3X.js.map +7 -0
  16. package/dist/chunk-LMY5YGE5.js +121 -0
  17. package/dist/chunk-LMY5YGE5.js.map +7 -0
  18. package/dist/chunk-O3D5GVFK.js +8 -0
  19. package/dist/{chunk-W5JAWOQQ.js.map → chunk-O3D5GVFK.js.map} +2 -2
  20. package/dist/chunk-P5UB5UJ6.js +6 -0
  21. package/dist/chunk-P5UB5UJ6.js.map +7 -0
  22. package/dist/chunk-RLMEA3WE.js +2 -0
  23. package/dist/{chunk-P5OUQ5XQ.js.map → chunk-RLMEA3WE.js.map} +2 -2
  24. package/dist/chunk-SWVUOPJX.js +12 -0
  25. package/dist/{chunk-AGRDDZFS.js.map → chunk-SWVUOPJX.js.map} +2 -2
  26. package/dist/chunk-VF4CDM7R.js +18 -0
  27. package/dist/{chunk-XB3JTJT6.js.map → chunk-VF4CDM7R.js.map} +2 -2
  28. package/dist/chunk-WCP5LTNQ.js +50 -0
  29. package/dist/{chunk-O2K4B6AL.js.map → chunk-WCP5LTNQ.js.map} +4 -4
  30. package/dist/chunk-YB7NQA2X.js +2 -0
  31. package/dist/{chunk-W4IVYUHW.js.map → chunk-YB7NQA2X.js.map} +2 -2
  32. package/dist/chunk-ZZIIWV6T.js +187 -0
  33. package/dist/chunk-ZZIIWV6T.js.map +7 -0
  34. package/dist/deploy-PQZW3X7G.js +25 -0
  35. package/dist/{deploy-RK5PRQ4T.js.map → deploy-PQZW3X7G.js.map} +2 -2
  36. package/dist/dev-27YLA4GG.js +58 -0
  37. package/dist/{dev-J6QHZMPR.js.map → dev-27YLA4GG.js.map} +2 -2
  38. package/dist/esm-RPCDY7LG.js +36 -0
  39. package/dist/esm-RPCDY7LG.js.map +7 -0
  40. package/dist/list-OTGSESA6.js +11 -0
  41. package/dist/{list-A7LFGUXG.js.map → list-OTGSESA6.js.map} +2 -2
  42. package/dist/login-YOXXXAJN.js +2 -0
  43. package/dist/logout-5YOHPXGR.js +7 -0
  44. package/dist/{logout-PPA6JCDY.js.map → logout-5YOHPXGR.js.map} +2 -2
  45. package/dist/main.js +12 -12
  46. package/dist/main.js.map +3 -3
  47. package/dist/{open-OZDKOY6V.js → open-QPMDV7ZL.js} +7 -7
  48. package/dist/{open-OZDKOY6V.js.map → open-QPMDV7ZL.js.map} +2 -2
  49. package/dist/{pull-YLUFPDDX.js → pull-3DUIUAIP.js} +7 -7
  50. package/dist/pull-3DUIUAIP.js.map +7 -0
  51. package/dist/push-RS6QHKDD.js +2 -0
  52. package/dist/status-N3VF5MBE.js +14 -0
  53. package/dist/{status-MP45HWIM.js.map → status-N3VF5MBE.js.map} +2 -2
  54. package/dist/version-EGM7PLFX.js +11 -0
  55. package/dist/{version-CXGPMLMK.js.map → version-EGM7PLFX.js.map} +2 -2
  56. package/dist/whoami-ES6XN3RI.js +7 -0
  57. package/dist/{whoami-PPXXBHUR.js.map → whoami-ES6XN3RI.js.map} +2 -2
  58. package/package.json +34 -34
  59. package/dist/add-OTQMXZUR.js +0 -78
  60. package/dist/chunk-3HRT72TB.js.map +0 -7
  61. package/dist/chunk-3V7YWBUK.js +0 -2
  62. package/dist/chunk-AGRDDZFS.js +0 -12
  63. package/dist/chunk-B6XQEEUK.js +0 -2
  64. package/dist/chunk-BKO2TX4J.js +0 -117
  65. package/dist/chunk-BKO2TX4J.js.map +0 -7
  66. package/dist/chunk-FQ2LR3BI.js +0 -6
  67. package/dist/chunk-FQ2LR3BI.js.map +0 -7
  68. package/dist/chunk-GIAIN3IJ.js +0 -65
  69. package/dist/chunk-GIAIN3IJ.js.map +0 -7
  70. package/dist/chunk-HCQR6OPH.js +0 -11
  71. package/dist/chunk-O2K4B6AL.js +0 -50
  72. package/dist/chunk-P5OUQ5XQ.js +0 -2
  73. package/dist/chunk-PC6ANBC6.js +0 -187
  74. package/dist/chunk-PC6ANBC6.js.map +0 -7
  75. package/dist/chunk-SGMPMYEU.js +0 -2
  76. package/dist/chunk-W4IVYUHW.js +0 -2
  77. package/dist/chunk-W5JAWOQQ.js +0 -8
  78. package/dist/chunk-XB3JTJT6.js +0 -18
  79. package/dist/deploy-RK5PRQ4T.js +0 -25
  80. package/dist/dev-J6QHZMPR.js +0 -58
  81. package/dist/esm-46TFUFSK.js +0 -36
  82. package/dist/esm-46TFUFSK.js.map +0 -7
  83. package/dist/list-A7LFGUXG.js +0 -11
  84. package/dist/login-BP4XIHLA.js +0 -2
  85. package/dist/logout-PPA6JCDY.js +0 -7
  86. package/dist/pull-YLUFPDDX.js.map +0 -7
  87. package/dist/push-FFLXHGFG.js +0 -2
  88. package/dist/status-MP45HWIM.js +0 -14
  89. package/dist/version-CXGPMLMK.js +0 -11
  90. package/dist/whoami-PPXXBHUR.js +0 -7
  91. /package/dist/{login-BP4XIHLA.js.map → login-YOXXXAJN.js.map} +0 -0
  92. /package/dist/{push-FFLXHGFG.js.map → push-RS6QHKDD.js.map} +0 -0
@@ -0,0 +1,11 @@
1
+ import{b as g}from"./chunk-DKP76YB2.js";import{i as f}from"./chunk-VF4CDM7R.js";import{v as c,w as u}from"./chunk-WCP5LTNQ.js";import"./chunk-SWVUOPJX.js";import{$ as o,U as m,Z as i,_ as l}from"./chunk-KXSKHE3X.js";import"./chunk-B2QVXD4S.js";import{a,h as p}from"./chunk-IOJ2LNUK.js";p();var b=a(()=>i`
2
+ List the apps available to the currently logged-in user.
3
+
4
+ {bold Usage}
5
+ ggt list
6
+ `,"usage"),j=a(async s=>{await f(s,"list");let e=await c(s);if(e.length===0){o`
7
+ It doesn't look like you have any applications.
8
+
9
+ Visit https://gadget.new to create one!
10
+ `;return}let y=u(e);if(m.isInteractive)y.forEach((t,r)=>{o(i`{grey ${r}}`),g({json:t,headers:["Name","Domain"],rows:t.map(n=>[n.slug,n.primaryDomain])}),o("")});else{let t="";for(let r of e)t+=l`${r.slug}\t${r.primaryDomain}`;o({json:e,content:t})}},"run");export{j as run,b as usage};
11
+ //# sourceMappingURL=list-OTGSESA6.js.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/commands/list.ts"],
4
4
  "sourcesContent": ["import { getApplications, parseAppListToTeamMap } from \"../services/app/app.js\";\nimport type { Run, Usage } from \"../services/command/command.js\";\nimport { output } from \"../services/output/output.js\";\nimport { println } from \"../services/output/print.js\";\nimport { sprint, sprintln } from \"../services/output/sprint.js\";\nimport { printTable } from \"../services/output/table.js\";\nimport { getUserOrLogin } from \"../services/user/user.js\";\n\nexport const usage: Usage = () => sprint`\n List the apps available to the currently logged-in user.\n\n {bold Usage}\n ggt list\n`;\n\nexport const run: Run = async (ctx) => {\n await getUserOrLogin(ctx, \"list\");\n\n const apps = await getApplications(ctx);\n if (apps.length === 0) {\n println`\n It doesn't look like you have any applications.\n\n Visit https://gadget.new to create one!\n `;\n return;\n }\n\n const appTeamMap = parseAppListToTeamMap(apps);\n\n if (output.isInteractive) {\n appTeamMap.forEach((apps, teamName) => {\n println(sprint`{grey ${teamName}}`);\n printTable({\n json: apps,\n headers: [\"Name\", \"Domain\"],\n rows: apps.map((app) => [app.slug, app.primaryDomain]),\n });\n println(\"\");\n });\n } else {\n let simpleOutput = \"\";\n for (const app of apps) {\n simpleOutput += sprintln`${app.slug}\\t${app.primaryDomain}`;\n }\n\n println({ json: apps, content: simpleOutput });\n }\n};\n"],
5
- "mappings": "4RAAAA,IAQO,IAAMC,EAAe,IAAMC;AAAA;AAAA;AAAA;AAAA;AAAA,EAOrBC,EAAW,MAAOC,GAAQ,CACrC,MAAMC,EAAeD,EAAK,MAAM,EAEhC,IAAME,EAAO,MAAMC,EAAgBH,CAAG,EACtC,GAAIE,EAAK,SAAW,EAAG,CACrBE;AAAA;AAAA;AAAA;AAAA,MAKA,MACF,CAEA,IAAMC,EAAaC,EAAsBJ,CAAI,EAE7C,GAAIK,EAAO,cACTF,EAAW,QAAQ,CAACH,EAAMM,IAAa,CACrCJ,EAAQN,UAAeU,CAAQ,GAAG,EAClCC,EAAW,CACT,KAAMP,EACN,QAAS,CAAC,OAAQ,QAAQ,EAC1B,KAAMA,EAAK,IAAKQ,GAAQ,CAACA,EAAI,KAAMA,EAAI,aAAa,CAAC,CACvD,CAAC,EACDN,EAAQ,EAAE,CACZ,CAAC,MACI,CACL,IAAIO,EAAe,GACnB,QAAWD,KAAOR,EAChBS,GAAgBC,IAAWF,EAAI,IAAI,KAAKA,EAAI,aAAa,GAG3DN,EAAQ,CAAE,KAAMF,EAAM,QAASS,CAAa,CAAC,CAC/C,CACF",
6
- "names": ["init_cjs", "usage", "sprint", "run", "ctx", "getUserOrLogin", "apps", "getApplications", "println", "appTeamMap", "parseAppListToTeamMap", "output", "teamName", "printTable", "app", "simpleOutput", "sprintln"]
5
+ "mappings": "8RAAAA,IAQO,IAAMC,EAAeC,EAAA,IAAMC;AAAA;AAAA;AAAA;AAAA;AAAA,EAAN,SAOfC,EAAWF,EAAA,MAAOG,GAAQ,CACrC,MAAMC,EAAeD,EAAK,MAAM,EAEhC,IAAME,EAAO,MAAMC,EAAgBH,CAAG,EACtC,GAAIE,EAAK,SAAW,EAAG,CACrBE;AAAA;AAAA;AAAA;AAAA,MAKA,MACF,CAEA,IAAMC,EAAaC,EAAsBJ,CAAI,EAE7C,GAAIK,EAAO,cACTF,EAAW,QAAQ,CAACH,EAAMM,IAAa,CACrCJ,EAAQN,UAAeU,CAAQ,GAAG,EAClCC,EAAW,CACT,KAAMP,EACN,QAAS,CAAC,OAAQ,QAAQ,EAC1B,KAAMA,EAAK,IAAKQ,GAAQ,CAACA,EAAI,KAAMA,EAAI,aAAa,CAAC,CACvD,CAAC,EACDN,EAAQ,EAAE,CACZ,CAAC,MACI,CACL,IAAIO,EAAe,GACnB,QAAWD,KAAOR,EAChBS,GAAgBC,IAAWF,EAAI,IAAI,KAAKA,EAAI,aAAa,GAG3DN,EAAQ,CAAE,KAAMF,EAAM,QAASS,CAAa,CAAC,CAC/C,CACF,EAjCwB",
6
+ "names": ["init_cjs", "usage", "__name", "sprint", "run", "ctx", "getUserOrLogin", "apps", "getApplications", "println", "appTeamMap", "parseAppListToTeamMap", "output", "teamName", "printTable", "app", "simpleOutput", "sprintln"]
7
7
  }
@@ -0,0 +1,2 @@
1
+ import{e as a,f as b,g as c}from"./chunk-VF4CDM7R.js";import"./chunk-WCP5LTNQ.js";import"./chunk-SWVUOPJX.js";import"./chunk-KXSKHE3X.js";import"./chunk-B2QVXD4S.js";import"./chunk-IOJ2LNUK.js";export{c as login,b as run,a as usage};
2
+ //# sourceMappingURL=login-YOXXXAJN.js.map
@@ -0,0 +1,7 @@
1
+ import{d as s,e as i}from"./chunk-SWVUOPJX.js";import{$ as e,Z as r}from"./chunk-KXSKHE3X.js";import{a as o,h as t}from"./chunk-IOJ2LNUK.js";t();var p=o(()=>r`
2
+ Log out of your account.
3
+
4
+ {bold Usage}
5
+ ggt logout
6
+ `,"usage"),d=o(n=>{s(n)?(i(n,void 0),e("Goodbye")):e("You are not logged in")},"run");export{d as run,p as usage};
7
+ //# sourceMappingURL=logout-5YOHPXGR.js.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/commands/logout.ts"],
4
4
  "sourcesContent": ["import type { Run, Usage } from \"../services/command/command.js\";\nimport { println } from \"../services/output/print.js\";\nimport { sprint } from \"../services/output/sprint.js\";\nimport { readSession, writeSession } from \"../services/user/session.js\";\n\nexport const usage: Usage = () => sprint`\n Log out of your account.\n\n {bold Usage}\n ggt logout\n`;\n\nexport const run: Run = (ctx) => {\n const token = readSession(ctx);\n if (token) {\n writeSession(ctx, undefined);\n println(\"Goodbye\");\n } else {\n println(\"You are not logged in\");\n }\n};\n"],
5
- "mappings": "sIAAAA,IAKO,IAAMC,EAAe,IAAMC;AAAA;AAAA;AAAA;AAAA;AAAA,EAOrBC,EAAYC,GAAQ,CACjBC,EAAYD,CAAG,GAE3BE,EAAaF,EAAK,MAAS,EAC3BG,EAAQ,SAAS,GAEjBA,EAAQ,uBAAuB,CAEnC",
6
- "names": ["init_cjs", "usage", "sprint", "run", "ctx", "readSession", "writeSession", "println"]
5
+ "mappings": "6IAAAA,IAKO,IAAMC,EAAeC,EAAA,IAAMC;AAAA;AAAA;AAAA;AAAA;AAAA,EAAN,SAOfC,EAAWF,EAACG,GAAQ,CACjBC,EAAYD,CAAG,GAE3BE,EAAaF,EAAK,MAAS,EAC3BG,EAAQ,SAAS,GAEjBA,EAAQ,uBAAuB,CAEnC,EARwB",
6
+ "names": ["init_cjs", "usage", "__name", "sprint", "run", "ctx", "readSession", "writeSession", "println"]
7
7
  }
package/dist/main.js CHANGED
@@ -1,12 +1,12 @@
1
- #!/usr/bin/env node
2
- import{a as V}from"./chunk-3V7YWBUK.js";import{a as J,b as R}from"./chunk-W5JAWOQQ.js";import{a as _,b as u,d as T,e as E,f as j}from"./chunk-W4IVYUHW.js";import{D as A,E as C,d as g,e as N,k as K,o as x}from"./chunk-O2K4B6AL.js";import"./chunk-AGRDDZFS.js";import{$ as a,A as s,O,P as f,U as d,W as w,Z as c,b as v,e as m,f as S,z as F}from"./chunk-GIAIN3IJ.js";import{a as b}from"./chunk-B6XQEEUK.js";import{e as l,g as i}from"./chunk-SGMPMYEU.js";i();i();var $=l(b(),1);i();var B=l(_(),1);i();var P=l(K(),1),y=l(F(),1),h=l(b(),1),M=l(V(),1);import H from"node:assert";import D from"node:path";var z=(0,h.default)("12 hours"),q=m.object({name:m.literal("ggt"),"dist-tags":m.object({latest:m.string(),experimental:m.string()})}),Q=async o=>{let t=await C({context:{ctx:o},method:"GET",url:"https://registry.npmjs.org/ggt",responseType:"json",resolveBodyOnly:!0,timeout:{request:(0,h.default)("5s")}});return q.parse(t)["dist-tags"]},Y=async o=>{try{let t=Number(await y.default.readFile(D.join(f.cacheDir,"last-update-check"),"utf8"));return H(!Number.isNaN(t)),(0,P.default)().isAfter(t+z)}catch(t){return o.log.trace("failed to check for updates",{error:t}),!0}},k=async o=>{try{if(!await Y(o))return;await y.default.outputFile(D.join(f.cacheDir,"last-update-check"),String(Date.now()));let r=await Q(o),e,n,p;s.version.includes("experimental")?(e=r.experimental,n=s.version!==e,p=c`
3
- Update available! {red ${s.version}} → {green ${e}}
4
- Run "npm install -g ${s.name}@experimental" to update.
5
- `):(e=r.latest,n=M.default.lt(s.version,e),p=c`
6
- Update available! {red ${s.version}} → {green ${e}}
1
+ #!/usr/bin/env -S node --enable-source-maps
2
+ import{a as K}from"./chunk-6BALPDKR.js";import{a as R,b as T}from"./chunk-O3D5GVFK.js";import{a as F,b as f,d as E,e as j,f as P}from"./chunk-YB7NQA2X.js";import{D as C,E as J,d as u,e as x,k as H,o as A}from"./chunk-WCP5LTNQ.js";import"./chunk-SWVUOPJX.js";import{$ as p,A as a,O as w,P as d,U as y,W as N,Z as g,b,e as c,f as O,z as V}from"./chunk-KXSKHE3X.js";import{a as S}from"./chunk-B2QVXD4S.js";import{a as r,f as m,h as n}from"./chunk-IOJ2LNUK.js";n();n();var L=m(S(),1);n();var G=m(F(),1);n();var D=m(H(),1),h=m(V(),1),v=m(S(),1),k=m(K(),1);import z from"node:assert";import M from"node:path";var q=(0,v.default)("12 hours"),Q=c.object({name:c.literal("ggt"),"dist-tags":c.object({latest:c.string(),experimental:c.string()})}),Y=r(async o=>{let t=await J({context:{ctx:o},method:"GET",url:"https://registry.npmjs.org/ggt",responseType:"json",resolveBodyOnly:!0,timeout:{request:(0,v.default)("5s")}});return Q.parse(t)["dist-tags"]},"getDistTags"),W=r(async o=>{try{let t=Number(await h.default.readFile(M.join(d.cacheDir,"last-update-check"),"utf8"));return z(!Number.isNaN(t)),(0,D.default)().isAfter(t+q)}catch(t){return o.log.trace("failed to check for updates",{error:t}),!0}},"shouldCheckForUpdate"),B=r(async o=>{try{if(!await W(o))return;await h.default.outputFile(M.join(d.cacheDir,"last-update-check"),String(Date.now()));let i=await Y(o),e,s,l;a.version.includes("experimental")?(e=i.experimental,s=a.version!==e,l=g`
3
+ Update available! {red ${a.version}} → {green ${e}}
4
+ Run "npm install -g ${a.name}@experimental" to update.
5
+ `):(e=i.latest,s=k.default.lt(a.version,e),l=g`
6
+ Update available! {red ${a.version}} → {green ${e}}
7
7
  Changelog: https://github.com/gadget-inc/ggt/releases/tag/v${e}
8
- Run "npm install -g ${s.name}" to update.
9
- `),n&&(o.log.info("update available",{current:s.version,latest:e}),a(w(p,{padding:1,borderStyle:"round",textAlignment:"center"})))}catch(t){o.log.error("failed to check for updates",{error:t})}};var G={"-h":{type:Boolean},"--help":{type:Boolean},"--verbose":{type:B.default.COUNT,alias:["-v","--debug"]},"--telemetry":{type:Boolean},"--json":{type:Boolean}},W=()=>c`
8
+ Run "npm install -g ${a.name}" to update.
9
+ `),s&&(o.log.info("update available",{current:a.version,latest:e}),p(N(l,{padding:1,borderStyle:"round",textAlignment:"center"})))}catch(t){o.log.error("failed to check for updates",{error:t})}},"warnIfUpdateAvailable");var U={"-h":{type:Boolean},"--help":{type:Boolean},"--verbose":{type:G.default.COUNT,alias:["-v","--debug"]},"--telemetry":{type:Boolean},"--json":{type:Boolean}},X=r(()=>g`
10
10
  The command-line interface for Gadget.
11
11
 
12
12
  {gray Usage}
@@ -32,12 +32,12 @@ import{a as V}from"./chunk-3V7YWBUK.js";import{a as J,b as R}from"./chunk-W5JAWO
32
32
  --telemetry Enable telemetry
33
33
 
34
34
  Run "ggt [COMMAND] -h" for more information about a specific command.
35
- `,U=async(o,t)=>{let r=o.child({name:"root"});t["--json"]&&(process.env.GGT_LOG_FORMAT="json"),t["--verbose"]&&(process.env.GGT_LOG_LEVEL=O(t["--verbose"]).toString()),await k(r);let e=t._.shift();if(S(e)&&(a(W(r)),process.exit(0)),e==="sync"&&(r.log.debug('renaming "sync" to "dev" for backwards compatibility'),e="dev"),!E(e)){let[p]=x(e,T);a`
35
+ `,"usage"),I=r(async(o,t)=>{let i=o.child({name:"root"});t["--json"]&&(process.env.GGT_LOG_FORMAT="json"),t["--verbose"]&&(process.env.GGT_LOG_LEVEL=w(t["--verbose"]).toString()),await B(i);let e=t._.shift();if(O(e)&&(p(X(i)),process.exit(0)),e==="sync"&&(i.log.debug('renaming "sync" to "dev" for backwards compatibility'),e="dev"),!j(e)){let[l]=A(e,E);p`
36
36
  Unknown command {yellow ${e}}
37
37
 
38
- Did you mean {blueBright ${p}}?
38
+ Did you mean {blueBright ${l}}?
39
39
 
40
40
  Run {gray ggt --help} for usage
41
- `,process.exit(1)}let n=await j(e);(t["-h"]??t["--help"])&&(a(n.usage(r)),process.exit(0));try{await n.run(r.child({name:e}),u(n.args??{},{argv:t._}))}catch(p){await g(r,p)}};i();var Z=function(){return String(this)},tt=function(){return Object.fromEntries(this)},ot=function(){return Array.from(this)},I=()=>{Object.prototype.hasOwnProperty.call(BigInt,"toJSON")||(BigInt.prototype.toJSON=Z),Object.prototype.hasOwnProperty.call(Map,"toJSON")||(Map.prototype.toJSON=tt),Object.prototype.hasOwnProperty.call(Set,"toJSON")||(Set.prototype.toJSON=ot)};var L=async(o=A.init({name:"ggt"}))=>{try{let t=u(G,{argv:process.argv.slice(2),permissive:!0});I(),await N(o,t),et(o),await U(o,t)}catch(t){await g(o,t)}},et=o=>{let t=!1;for(let r of["SIGINT","SIGTERM"])process.on(r,async()=>{if(t)return;t=!0,o.log.trace("received signal",{signal:r}),setTimeout(()=>{process.once(r,()=>{a(" Exiting immediately"),process.exit(1)})},(0,$.default)("100ms")).unref(),d.writeStdout(`
42
- `),J?.clear(),d.persistFooter();let e=R({successSymbol:"\u{1F44B}",content:`Stopping ${v.gray("Press Ctrl+C again to force")}`});try{o.abort(),await o.done,e.succeed("Goodbye!")}catch(n){e.fail(),await g(o,n)}})};await L();
41
+ `,process.exit(1)}let s=await P(e);(t["-h"]??t["--help"])&&(p(s.usage(i)),process.exit(0));try{await s.run(i.child({name:e}),f(s.args??{},{argv:t._}))}catch(l){await u(i,l)}},"run");n();var tt=r(function(){return String(this)},"bigintToJSON"),ot=r(function(){return Object.fromEntries(this)},"mapToJSON"),et=r(function(){return Array.from(this)},"setToJSON"),$=r(()=>{Object.prototype.hasOwnProperty.call(BigInt,"toJSON")||(BigInt.prototype.toJSON=tt),Object.prototype.hasOwnProperty.call(Map,"toJSON")||(Map.prototype.toJSON=ot),Object.prototype.hasOwnProperty.call(Set,"toJSON")||(Set.prototype.toJSON=et)},"installJsonExtensions");var _=r(async(o=C.init({name:"ggt"}))=>{try{let t=f(U,{argv:process.argv.slice(2),permissive:!0});$(),await x(o,t),rt(o),await I(o,t)}catch(t){await u(o,t)}},"ggt"),rt=r(o=>{let t=!1;for(let i of["SIGINT","SIGTERM"])process.on(i,async()=>{if(t)return;t=!0,o.log.trace("received signal",{signal:i}),setTimeout(()=>{process.once(i,()=>{p(" Exiting immediately"),process.exit(1)})},(0,L.default)("100ms")).unref(),y.writeStdout(`
42
+ `),R?.clear(),y.persistFooter();let e=T({successSymbol:"\u{1F44B}",content:`Stopping ${b.gray("Press Ctrl+C again to force")}`});try{o.abort(),await o.done,e.succeed("Goodbye!")}catch(s){e.fail(),await u(o,s)}})},"installSignalHandler");await _();
43
43
  //# sourceMappingURL=main.js.map
package/dist/main.js.map CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../src/main.ts", "../src/ggt.ts", "../src/commands/root.ts", "../src/services/output/update.ts", "../src/services/util/json.ts"],
4
- "sourcesContent": ["#!/usr/bin/env node\n\nimport { ggt } from \"./ggt.js\";\n\nawait ggt();\n", "import chalk from \"chalk\";\nimport ms from \"ms\";\nimport * as root from \"./commands/root.js\";\nimport { parseArgs } from \"./services/command/arg.js\";\nimport { Context } from \"./services/command/context.js\";\nimport { output } from \"./services/output/output.js\";\nimport { println } from \"./services/output/print.js\";\nimport { installErrorHandlers, reportErrorAndExit } from \"./services/output/report.js\";\nimport { activeSpinner, spin } from \"./services/output/spinner.js\";\nimport { installJsonExtensions } from \"./services/util/json.js\";\n\nexport const ggt = async (ctx = Context.init({ name: \"ggt\" })): Promise<void> => {\n try {\n const rootArgs = parseArgs(root.args, { argv: process.argv.slice(2), permissive: true });\n\n installJsonExtensions();\n await installErrorHandlers(ctx, rootArgs);\n installSignalHandler(ctx);\n\n await root.run(ctx, rootArgs);\n } catch (error) {\n await reportErrorAndExit(ctx, error);\n }\n};\n\nconst installSignalHandler = (ctx: Context): void => {\n let stopping = false;\n\n for (const signal of [\"SIGINT\", \"SIGTERM\"] as const) {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n process.on(signal, async () => {\n if (stopping) {\n return;\n }\n\n stopping = true;\n ctx.log.trace(\"received signal\", { signal });\n\n setTimeout(() => {\n // when ggt is run with npx, and the user presses ctrl+c, ggt\n // receives SIGINT twice in quick succession. in order to\n // prevent the second SIGINT from triggering the force exit\n // listener, we wait a bit in this setTimeout before adding it\n process.once(signal, () => {\n println(\" Exiting immediately\");\n process.exit(1);\n });\n }, ms(\"100ms\")).unref();\n\n // ctrl+c was pressed, so we need to clear the line\n output.writeStdout(\"\\n\");\n\n // if there was any sticky text, it needs to be persisted now\n activeSpinner?.clear();\n output.persistFooter();\n\n const spinner = spin({\n successSymbol: \"\uD83D\uDC4B\",\n content: `Stopping ${chalk.gray(\"Press Ctrl+C again to force\")}`,\n });\n\n try {\n ctx.abort();\n await ctx.done;\n spinner.succeed(\"Goodbye!\");\n } catch (error) {\n spinner.fail();\n await reportErrorAndExit(ctx, error);\n }\n });\n }\n};\n", "import arg from \"arg\";\nimport { parseArgs, type ArgsDefinition, type ArgsDefinitionResult } from \"../services/command/arg.js\";\nimport { Commands, importCommand, isCommand, type Run, type Usage } from \"../services/command/command.js\";\nimport { verbosityToLevel } from \"../services/output/log/level.js\";\nimport { println } from \"../services/output/print.js\";\nimport { reportErrorAndExit } from \"../services/output/report.js\";\nimport { sprint } from \"../services/output/sprint.js\";\nimport { warnIfUpdateAvailable } from \"../services/output/update.js\";\nimport { sortBySimilar } from \"../services/util/collection.js\";\nimport { isNil } from \"../services/util/is.js\";\n\nexport type RootArgs = typeof args;\nexport type RootArgsResult = ArgsDefinitionResult<RootArgs>;\n\nexport const args = {\n \"-h\": { type: Boolean },\n \"--help\": { type: Boolean },\n \"--verbose\": { type: arg.COUNT, alias: [\"-v\", \"--debug\"] },\n \"--telemetry\": { type: Boolean },\n \"--json\": { type: Boolean },\n} satisfies ArgsDefinition;\n\nexport const usage: Usage = () => {\n return sprint`\n The command-line interface for Gadget.\n\n {gray Usage}\n ggt [COMMAND]\n\n {gray Commands}\n dev Start developing your application\n deploy Deploy your environment to production\n status Show your local and environment's file changes\n push Push your local files to your environment\n pull Pull your environment's files to your local computer\n add Add models, fields, actions and routes to your app\n open Open a Gadget location in your browser\n list List your available applications\n login Log in to your account\n logout Log out of your account\n whoami Print the currently logged in account\n version Print this version of ggt\n\n {gray Flags}\n -h, --help Print how to use a command\n -v, --verbose Print more verbose output\n --telemetry Enable telemetry\n\n Run \"ggt [COMMAND] -h\" for more information about a specific command.\n `;\n};\n\nexport const run: Run<RootArgs> = async (parent, args): Promise<void> => {\n const ctx = parent.child({ name: \"root\" });\n\n if (args[\"--json\"]) {\n process.env[\"GGT_LOG_FORMAT\"] = \"json\";\n }\n\n if (args[\"--verbose\"]) {\n process.env[\"GGT_LOG_LEVEL\"] = verbosityToLevel(args[\"--verbose\"]).toString();\n }\n\n await warnIfUpdateAvailable(ctx);\n\n let commandName = args._.shift();\n if (isNil(commandName)) {\n println(usage(ctx));\n process.exit(0);\n }\n\n if (commandName === \"sync\") {\n ctx.log.debug('renaming \"sync\" to \"dev\" for backwards compatibility');\n commandName = \"dev\";\n }\n\n if (!isCommand(commandName)) {\n const [closest] = sortBySimilar(commandName, Commands);\n println`\n Unknown command {yellow ${commandName}}\n\n Did you mean {blueBright ${closest}}?\n\n Run {gray ggt --help} for usage\n `;\n process.exit(1);\n }\n\n const command = await importCommand(commandName);\n\n if (args[\"-h\"] ?? args[\"--help\"]) {\n println(command.usage(ctx));\n process.exit(0);\n }\n\n try {\n await command.run(ctx.child({ name: commandName }), parseArgs(command.args ?? {}, { argv: args._ }));\n } catch (error) {\n await reportErrorAndExit(ctx, error);\n }\n};\n", "import boxen from \"boxen\";\nimport dayjs from \"dayjs\";\nimport fs from \"fs-extra\";\nimport ms from \"ms\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport semver from \"semver\";\nimport { z } from \"zod\";\nimport type { Context } from \"../command/context.js\";\nimport { config } from \"../config/config.js\";\nimport { http } from \"../http/http.js\";\nimport { packageJson } from \"../util/package-json.js\";\nimport { println } from \"./print.js\";\nimport { sprint } from \"./sprint.js\";\n\nconst UPDATE_CHECK_FREQUENCY = ms(\"12 hours\");\n\nconst Registry = z.object({\n name: z.literal(\"ggt\"),\n \"dist-tags\": z.object({\n latest: z.string(),\n experimental: z.string(),\n }),\n});\n\ntype Registry = z.infer<typeof Registry>;\n\nexport const getDistTags = async (ctx: Context): Promise<Registry[\"dist-tags\"]> => {\n const json = await http({\n context: { ctx },\n method: \"GET\",\n url: \"https://registry.npmjs.org/ggt\",\n responseType: \"json\",\n resolveBodyOnly: true,\n timeout: {\n request: ms(\"5s\"),\n },\n });\n\n return Registry.parse(json)[\"dist-tags\"];\n};\n\nexport const shouldCheckForUpdate = async (ctx: Context): Promise<boolean> => {\n try {\n const lastCheck = Number(await fs.readFile(path.join(config.cacheDir, \"last-update-check\"), \"utf8\"));\n assert(!Number.isNaN(lastCheck));\n return dayjs().isAfter(lastCheck + UPDATE_CHECK_FREQUENCY);\n } catch (error) {\n ctx.log.trace(\"failed to check for updates\", { error });\n return true;\n }\n};\n\n/**\n * Checks for updates to the `ggt` npm package and logs a warning\n * message if an update is available.\n *\n * @returns A Promise that resolves with void when the check is\n * complete.\n */\nexport const warnIfUpdateAvailable = async (ctx: Context): Promise<void> => {\n try {\n const shouldCheck = await shouldCheckForUpdate(ctx);\n if (!shouldCheck) {\n return;\n }\n\n await fs.outputFile(path.join(config.cacheDir, \"last-update-check\"), String(Date.now()));\n\n const tags = await getDistTags(ctx);\n\n let latest: string;\n let updateAvailable: boolean;\n let updateMessage: string;\n\n if (packageJson.version.includes(\"experimental\")) {\n // this is an experimental release\n latest = tags.experimental;\n updateAvailable = packageJson.version !== latest;\n updateMessage = sprint`\n Update available! {red ${packageJson.version}} \u2192 {green ${latest}}\n Run \"npm install -g ${packageJson.name}@experimental\" to update.\n `;\n } else {\n // this is a stable release\n latest = tags.latest;\n updateAvailable = semver.lt(packageJson.version, latest);\n updateMessage = sprint`\n Update available! {red ${packageJson.version}} \u2192 {green ${latest}}\n Changelog: https://github.com/gadget-inc/ggt/releases/tag/v${latest}\n Run \"npm install -g ${packageJson.name}\" to update.\n `;\n }\n\n if (updateAvailable) {\n ctx.log.info(\"update available\", { current: packageJson.version, latest });\n println(\n boxen(updateMessage, {\n padding: 1,\n borderStyle: \"round\",\n textAlignment: \"center\",\n }),\n );\n }\n } catch (error) {\n ctx.log.error(\"failed to check for updates\", { error });\n }\n};\n", "/* eslint-disable @typescript-eslint/no-unused-vars */\n/* eslint-disable @typescript-eslint/no-unsafe-return */\n/* eslint-disable @typescript-eslint/consistent-type-definitions */\n\ndeclare global {\n interface BigInt {\n toJSON?(): string;\n }\n interface Map<K, V> {\n toJSON?(): Record<string, V>;\n }\n interface Set<T> {\n toJSON?(): T[];\n }\n}\n\nconst bigintToJSON = function (this: bigint): string {\n return String(this);\n};\n\nconst mapToJSON = function <K, V>(this: Map<K, V>): Record<string, V> {\n return Object.fromEntries(this);\n};\n\nconst setToJSON = function <T>(this: Set<T>): T[] {\n return Array.from(this);\n};\n\nexport const installJsonExtensions = (): void => {\n if (!Object.prototype.hasOwnProperty.call(BigInt, \"toJSON\")) {\n BigInt.prototype.toJSON = bigintToJSON;\n }\n\n if (!Object.prototype.hasOwnProperty.call(Map, \"toJSON\")) {\n Map.prototype.toJSON = mapToJSON;\n }\n\n if (!Object.prototype.hasOwnProperty.call(Set, \"toJSON\")) {\n Set.prototype.toJSON = setToJSON;\n }\n};\n\nexport const uninstallJsonExtensions = (): void => {\n if (BigInt.prototype.toJSON === bigintToJSON) {\n delete BigInt.prototype.toJSON;\n }\n\n if (Map.prototype.toJSON === mapToJSON) {\n delete Map.prototype.toJSON;\n }\n\n if (Set.prototype.toJSON === setToJSON) {\n delete Set.prototype.toJSON;\n }\n};\n"],
5
- "mappings": "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",
6
- "names": ["init_cjs", "init_cjs", "import_ms", "init_cjs", "import_arg", "init_cjs", "import_dayjs", "import_fs_extra", "import_ms", "import_semver", "assert", "path", "UPDATE_CHECK_FREQUENCY", "ms", "Registry", "z", "getDistTags", "ctx", "json", "http", "shouldCheckForUpdate", "lastCheck", "fs", "path", "config", "assert", "dayjs", "error", "warnIfUpdateAvailable", "tags", "latest", "updateAvailable", "updateMessage", "packageJson", "sprint", "semver", "println", "boxen", "args", "arg", "usage", "sprint", "run", "parent", "ctx", "verbosityToLevel", "warnIfUpdateAvailable", "commandName", "isNil", "println", "isCommand", "closest", "sortBySimilar", "Commands", "command", "importCommand", "parseArgs", "error", "reportErrorAndExit", "init_cjs", "bigintToJSON", "mapToJSON", "setToJSON", "installJsonExtensions", "ggt", "ctx", "Context", "rootArgs", "parseArgs", "args", "installJsonExtensions", "installErrorHandlers", "installSignalHandler", "run", "error", "reportErrorAndExit", "stopping", "signal", "println", "ms", "output", "activeSpinner", "spinner", "spin", "source_default", "ggt"]
4
+ "sourcesContent": ["#!/usr/bin/env -S node --enable-source-maps\n\nimport { ggt } from \"./ggt.js\";\n\nawait ggt();\n", "import chalk from \"chalk\";\nimport ms from \"ms\";\nimport * as root from \"./commands/root.js\";\nimport { parseArgs } from \"./services/command/arg.js\";\nimport { Context } from \"./services/command/context.js\";\nimport { output } from \"./services/output/output.js\";\nimport { println } from \"./services/output/print.js\";\nimport { installErrorHandlers, reportErrorAndExit } from \"./services/output/report.js\";\nimport { activeSpinner, spin } from \"./services/output/spinner.js\";\nimport { installJsonExtensions } from \"./services/util/json.js\";\n\nexport const ggt = async (ctx = Context.init({ name: \"ggt\" })): Promise<void> => {\n try {\n const rootArgs = parseArgs(root.args, { argv: process.argv.slice(2), permissive: true });\n\n installJsonExtensions();\n await installErrorHandlers(ctx, rootArgs);\n installSignalHandler(ctx);\n\n await root.run(ctx, rootArgs);\n } catch (error) {\n await reportErrorAndExit(ctx, error);\n }\n};\n\nconst installSignalHandler = (ctx: Context): void => {\n let stopping = false;\n\n for (const signal of [\"SIGINT\", \"SIGTERM\"] as const) {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n process.on(signal, async () => {\n if (stopping) {\n return;\n }\n\n stopping = true;\n ctx.log.trace(\"received signal\", { signal });\n\n setTimeout(() => {\n // when ggt is run with npx, and the user presses ctrl+c, ggt\n // receives SIGINT twice in quick succession. in order to\n // prevent the second SIGINT from triggering the force exit\n // listener, we wait a bit in this setTimeout before adding it\n process.once(signal, () => {\n println(\" Exiting immediately\");\n process.exit(1);\n });\n }, ms(\"100ms\")).unref();\n\n // ctrl+c was pressed, so we need to clear the line\n output.writeStdout(\"\\n\");\n\n // if there was any sticky text, it needs to be persisted now\n activeSpinner?.clear();\n output.persistFooter();\n\n const spinner = spin({\n successSymbol: \"\uD83D\uDC4B\",\n content: `Stopping ${chalk.gray(\"Press Ctrl+C again to force\")}`,\n });\n\n try {\n ctx.abort();\n await ctx.done;\n spinner.succeed(\"Goodbye!\");\n } catch (error) {\n spinner.fail();\n await reportErrorAndExit(ctx, error);\n }\n });\n }\n};\n", "import arg from \"arg\";\nimport { parseArgs, type ArgsDefinition, type ArgsDefinitionResult } from \"../services/command/arg.js\";\nimport { Commands, importCommand, isCommand, type Run, type Usage } from \"../services/command/command.js\";\nimport { verbosityToLevel } from \"../services/output/log/level.js\";\nimport { println } from \"../services/output/print.js\";\nimport { reportErrorAndExit } from \"../services/output/report.js\";\nimport { sprint } from \"../services/output/sprint.js\";\nimport { warnIfUpdateAvailable } from \"../services/output/update.js\";\nimport { sortBySimilar } from \"../services/util/collection.js\";\nimport { isNil } from \"../services/util/is.js\";\n\nexport type RootArgs = typeof args;\nexport type RootArgsResult = ArgsDefinitionResult<RootArgs>;\n\nexport const args = {\n \"-h\": { type: Boolean },\n \"--help\": { type: Boolean },\n \"--verbose\": { type: arg.COUNT, alias: [\"-v\", \"--debug\"] },\n \"--telemetry\": { type: Boolean },\n \"--json\": { type: Boolean },\n} satisfies ArgsDefinition;\n\nexport const usage: Usage = () => {\n return sprint`\n The command-line interface for Gadget.\n\n {gray Usage}\n ggt [COMMAND]\n\n {gray Commands}\n dev Start developing your application\n deploy Deploy your environment to production\n status Show your local and environment's file changes\n push Push your local files to your environment\n pull Pull your environment's files to your local computer\n add Add models, fields, actions and routes to your app\n open Open a Gadget location in your browser\n list List your available applications\n login Log in to your account\n logout Log out of your account\n whoami Print the currently logged in account\n version Print this version of ggt\n\n {gray Flags}\n -h, --help Print how to use a command\n -v, --verbose Print more verbose output\n --telemetry Enable telemetry\n\n Run \"ggt [COMMAND] -h\" for more information about a specific command.\n `;\n};\n\nexport const run: Run<RootArgs> = async (parent, args): Promise<void> => {\n const ctx = parent.child({ name: \"root\" });\n\n if (args[\"--json\"]) {\n process.env[\"GGT_LOG_FORMAT\"] = \"json\";\n }\n\n if (args[\"--verbose\"]) {\n process.env[\"GGT_LOG_LEVEL\"] = verbosityToLevel(args[\"--verbose\"]).toString();\n }\n\n await warnIfUpdateAvailable(ctx);\n\n let commandName = args._.shift();\n if (isNil(commandName)) {\n println(usage(ctx));\n process.exit(0);\n }\n\n if (commandName === \"sync\") {\n ctx.log.debug('renaming \"sync\" to \"dev\" for backwards compatibility');\n commandName = \"dev\";\n }\n\n if (!isCommand(commandName)) {\n const [closest] = sortBySimilar(commandName, Commands);\n println`\n Unknown command {yellow ${commandName}}\n\n Did you mean {blueBright ${closest}}?\n\n Run {gray ggt --help} for usage\n `;\n process.exit(1);\n }\n\n const command = await importCommand(commandName);\n\n if (args[\"-h\"] ?? args[\"--help\"]) {\n println(command.usage(ctx));\n process.exit(0);\n }\n\n try {\n await command.run(ctx.child({ name: commandName }), parseArgs(command.args ?? {}, { argv: args._ }));\n } catch (error) {\n await reportErrorAndExit(ctx, error);\n }\n};\n", "import boxen from \"boxen\";\nimport dayjs from \"dayjs\";\nimport fs from \"fs-extra\";\nimport ms from \"ms\";\nimport assert from \"node:assert\";\nimport path from \"node:path\";\nimport semver from \"semver\";\nimport { z } from \"zod\";\nimport type { Context } from \"../command/context.js\";\nimport { config } from \"../config/config.js\";\nimport { http } from \"../http/http.js\";\nimport { packageJson } from \"../util/package-json.js\";\nimport { println } from \"./print.js\";\nimport { sprint } from \"./sprint.js\";\n\nconst UPDATE_CHECK_FREQUENCY = ms(\"12 hours\");\n\nconst Registry = z.object({\n name: z.literal(\"ggt\"),\n \"dist-tags\": z.object({\n latest: z.string(),\n experimental: z.string(),\n }),\n});\n\ntype Registry = z.infer<typeof Registry>;\n\nexport const getDistTags = async (ctx: Context): Promise<Registry[\"dist-tags\"]> => {\n const json = await http({\n context: { ctx },\n method: \"GET\",\n url: \"https://registry.npmjs.org/ggt\",\n responseType: \"json\",\n resolveBodyOnly: true,\n timeout: {\n request: ms(\"5s\"),\n },\n });\n\n return Registry.parse(json)[\"dist-tags\"];\n};\n\nexport const shouldCheckForUpdate = async (ctx: Context): Promise<boolean> => {\n try {\n const lastCheck = Number(await fs.readFile(path.join(config.cacheDir, \"last-update-check\"), \"utf8\"));\n assert(!Number.isNaN(lastCheck));\n return dayjs().isAfter(lastCheck + UPDATE_CHECK_FREQUENCY);\n } catch (error) {\n ctx.log.trace(\"failed to check for updates\", { error });\n return true;\n }\n};\n\n/**\n * Checks for updates to the `ggt` npm package and logs a warning\n * message if an update is available.\n *\n * @returns A Promise that resolves with void when the check is\n * complete.\n */\nexport const warnIfUpdateAvailable = async (ctx: Context): Promise<void> => {\n try {\n const shouldCheck = await shouldCheckForUpdate(ctx);\n if (!shouldCheck) {\n return;\n }\n\n await fs.outputFile(path.join(config.cacheDir, \"last-update-check\"), String(Date.now()));\n\n const tags = await getDistTags(ctx);\n\n let latest: string;\n let updateAvailable: boolean;\n let updateMessage: string;\n\n if (packageJson.version.includes(\"experimental\")) {\n // this is an experimental release\n latest = tags.experimental;\n updateAvailable = packageJson.version !== latest;\n updateMessage = sprint`\n Update available! {red ${packageJson.version}} \u2192 {green ${latest}}\n Run \"npm install -g ${packageJson.name}@experimental\" to update.\n `;\n } else {\n // this is a stable release\n latest = tags.latest;\n updateAvailable = semver.lt(packageJson.version, latest);\n updateMessage = sprint`\n Update available! {red ${packageJson.version}} \u2192 {green ${latest}}\n Changelog: https://github.com/gadget-inc/ggt/releases/tag/v${latest}\n Run \"npm install -g ${packageJson.name}\" to update.\n `;\n }\n\n if (updateAvailable) {\n ctx.log.info(\"update available\", { current: packageJson.version, latest });\n println(\n boxen(updateMessage, {\n padding: 1,\n borderStyle: \"round\",\n textAlignment: \"center\",\n }),\n );\n }\n } catch (error) {\n ctx.log.error(\"failed to check for updates\", { error });\n }\n};\n", "/* eslint-disable @typescript-eslint/no-unused-vars */\n/* eslint-disable @typescript-eslint/no-unsafe-return */\n/* eslint-disable @typescript-eslint/consistent-type-definitions */\n\ndeclare global {\n interface BigInt {\n toJSON?(): string;\n }\n interface Map<K, V> {\n toJSON?(): Record<string, V>;\n }\n interface Set<T> {\n toJSON?(): T[];\n }\n}\n\nconst bigintToJSON = function (this: bigint): string {\n return String(this);\n};\n\nconst mapToJSON = function <K, V>(this: Map<K, V>): Record<string, V> {\n return Object.fromEntries(this);\n};\n\nconst setToJSON = function <T>(this: Set<T>): T[] {\n return Array.from(this);\n};\n\nexport const installJsonExtensions = (): void => {\n if (!Object.prototype.hasOwnProperty.call(BigInt, \"toJSON\")) {\n BigInt.prototype.toJSON = bigintToJSON;\n }\n\n if (!Object.prototype.hasOwnProperty.call(Map, \"toJSON\")) {\n Map.prototype.toJSON = mapToJSON;\n }\n\n if (!Object.prototype.hasOwnProperty.call(Set, \"toJSON\")) {\n Set.prototype.toJSON = setToJSON;\n }\n};\n\nexport const uninstallJsonExtensions = (): void => {\n if (BigInt.prototype.toJSON === bigintToJSON) {\n delete BigInt.prototype.toJSON;\n }\n\n if (Map.prototype.toJSON === mapToJSON) {\n delete Map.prototype.toJSON;\n }\n\n if (Set.prototype.toJSON === setToJSON) {\n delete Set.prototype.toJSON;\n }\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["init_cjs", "init_cjs", "import_ms", "init_cjs", "import_arg", "init_cjs", "import_dayjs", "import_fs_extra", "import_ms", "import_semver", "assert", "path", "UPDATE_CHECK_FREQUENCY", "ms", "Registry", "z", "getDistTags", "__name", "ctx", "json", "http", "shouldCheckForUpdate", "lastCheck", "fs", "path", "config", "assert", "dayjs", "error", "warnIfUpdateAvailable", "tags", "latest", "updateAvailable", "updateMessage", "packageJson", "sprint", "semver", "println", "boxen", "args", "arg", "usage", "__name", "sprint", "run", "parent", "ctx", "verbosityToLevel", "warnIfUpdateAvailable", "commandName", "isNil", "println", "isCommand", "closest", "sortBySimilar", "Commands", "command", "importCommand", "parseArgs", "error", "reportErrorAndExit", "init_cjs", "bigintToJSON", "__name", "mapToJSON", "setToJSON", "installJsonExtensions", "ggt", "__name", "ctx", "Context", "rootArgs", "parseArgs", "args", "installJsonExtensions", "installErrorHandlers", "installSignalHandler", "run", "error", "reportErrorAndExit", "stopping", "signal", "println", "ms", "output", "activeSpinner", "spinner", "spin", "source_default", "ggt"]
7
7
  }
@@ -1,4 +1,4 @@
1
- import{g as f,l as v,m as u,n as $,o as O}from"./chunk-BKO2TX4J.js";import{c as p}from"./chunk-W4IVYUHW.js";import"./chunk-FQ2LR3BI.js";import{d as r}from"./chunk-XB3JTJT6.js";import{o as g,x as w}from"./chunk-O2K4B6AL.js";import"./chunk-AGRDDZFS.js";import{$ as s,Z as i,n as y}from"./chunk-GIAIN3IJ.js";import"./chunk-B6XQEEUK.js";import{g as h}from"./chunk-SGMPMYEU.js";h();var R={...u,"--show-all":{type:Boolean}},J=m=>i`
1
+ import{g as w,l as u,m as $,n as O,o as B}from"./chunk-LMY5YGE5.js";import{c as p}from"./chunk-YB7NQA2X.js";import"./chunk-P5UB5UJ6.js";import{d as r}from"./chunk-VF4CDM7R.js";import{o as d,x as v}from"./chunk-WCP5LTNQ.js";import"./chunk-SWVUOPJX.js";import{$ as s,Z as i,n as f}from"./chunk-KXSKHE3X.js";import"./chunk-B2QVXD4S.js";import{a as g,h as y}from"./chunk-IOJ2LNUK.js";y();var J={...$,"--show-all":{type:Boolean}},j=g(m=>i`
2
2
  This command opens a specific Gadget page in your browser, allowing you to directly access
3
3
  various parts of your application's interface such as logs, permissions, data views, or
4
4
  schemas.
@@ -42,9 +42,9 @@ import{g as f,l as v,m as u,n as $,o as O}from"./chunk-BKO2TX4J.js";import{c as
42
42
 
43
43
  Opens data editor for 'post' model of app 'myBlog' in the 'staging' environment
44
44
  {cyanBright $ ggt open data post --app myBlog --env staging}
45
- `,j=async(m,t)=>{let d=await O(process.cwd()),e=await $.load(m,{command:"open",args:t,directory:d});if(!e)throw new f({command:"open",args:t,directory:d});let a=t._[0];if(!a){await r(`https://${e.environment.application.primaryDomain}/edit/${e.environment.name}`),s`
45
+ `,"usage"),E=g(async(m,t)=>{let h=await B(process.cwd()),e=await O.load(m,{command:"open",args:t,directory:h});if(!e)throw new w({command:"open",args:t,directory:h});let a=t._[0];if(!a){await r(`https://${e.environment.application.primaryDomain}/edit/${e.environment.name}`),s`
46
46
  Opened editor for environment {cyanBright ${e.environment.name}}.
47
- `;return}if(!B.includes(a)){let[o]=g(a,B);throw new p(i`
47
+ `;return}if(!b.includes(a)){let[o]=d(a,b);throw new p(i`
48
48
  Unknown location {yellow ${a}}
49
49
 
50
50
  Did you mean {blueBright ${o}}?
@@ -54,13 +54,13 @@ import{g as f,l as v,m as u,n as $,o as O}from"./chunk-BKO2TX4J.js";import{c as
54
54
  Opened log viewer for environment {cyanBright ${e.environment.name}}.
55
55
  `;break}case"permissions":{await r(`https://${e.environment.application.primaryDomain}/edit/${e.environment.name}/settings/permissions`),s`
56
56
  Opened permissions settings for environment {cyanBright ${e.environment.name}}.
57
- `;break}case"data":case"schema":{let o=t._[0],l=(await w(m,e.environment)).map(c=>c.apiIdentifier),n=t._[1];if(!n)if(t["--show-all"])n=await v({choices:l,content:"Which model do you wish to open?"});else throw new p(i`
57
+ `;break}case"data":case"schema":{let o=t._[0],l=(await v(m,e.environment)).map(c=>c.apiIdentifier),n=t._[1];if(!n)if(t["--show-all"])n=await u({choices:l,content:"Which model do you wish to open?"});else throw new p(i`
58
58
  "ggt open ${o}" requires a model to be specified.
59
59
 
60
60
  Run with "--show-all" to choose from available models.
61
61
 
62
62
  ggt open ${o} --show-all
63
- `);if(!l.includes(n)){let[c]=g(n,l);throw new p(i`
63
+ `);if(!l.includes(n)){let[c]=d(n,l);throw new p(i`
64
64
  Unknown model {yellow ${n}}
65
65
 
66
66
  Did you mean {blueBright ${c}}?
@@ -70,5 +70,5 @@ import{g as f,l as v,m as u,n as $,o as O}from"./chunk-BKO2TX4J.js";import{c as
70
70
  ggt open ${o} --show-all
71
71
  `)}await r(`https://${e.environment.application.primaryDomain}/edit/${e.environment.name}/model/${n}/${o}`),s`
72
72
  Opened ${o} viewer for environment {cyanBright ${e.environment.name}} for model {cyanBright ${n}}.
73
- `;break}default:y(a)}},B=["logs","permissions","data","schema"];export{R as args,j as run,J as usage};
74
- //# sourceMappingURL=open-OZDKOY6V.js.map
73
+ `;break}default:f(a)}},"run"),b=["logs","permissions","data","schema"];export{J as args,E as run,j as usage};
74
+ //# sourceMappingURL=open-QPMDV7ZL.js.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/commands/open.ts"],
4
4
  "sourcesContent": ["import open from \"open\";\nimport { getModels } from \"../services/app/app.js\";\nimport { ArgError } from \"../services/command/arg.js\";\nimport type { Run, Usage } from \"../services/command/command.js\";\nimport { UnknownDirectoryError } from \"../services/filesync/error.js\";\nimport { SyncJson, SyncJsonArgs, loadSyncJsonDirectory } from \"../services/filesync/sync-json.js\";\nimport { println } from \"../services/output/print.js\";\nimport { select } from \"../services/output/select.js\";\nimport { sprint } from \"../services/output/sprint.js\";\nimport { sortBySimilar } from \"../services/util/collection.js\";\nimport { isNever } from \"../services/util/is.js\";\n\nexport type OpenArgs = typeof args;\n\nexport const args = {\n ...SyncJsonArgs,\n \"--show-all\": { type: Boolean },\n};\n\nexport const usage: Usage = (_ctx) => {\n return sprint`\n This command opens a specific Gadget page in your browser, allowing you to directly access\n various parts of your application's interface such as logs, permissions, data views, or\n schemas.\n\n {gray Usage}\n ggt open [LOCATION] [model_name] [--show-all] [options]\n\n LOCATION: specifies the part of Gadget to open, by default it'll open the apps home page:\n\n + logs Opens logs\n + permissions Opens permissions\n + data Opens data editor for a specific model\n + schema Opens schema editor for a specific model\n\n {gray Options}\n -a, --app <app_name> Selects the application to open in your browser. Default set on \".gadget/sync.json\"\n -e, --env <env_name> Selects the environment to open in your browser. Default set on \".gadget/sync.json\"\n --show-all Shows all schema, or data options by listing your available models\n\n {gray Examples}\n Opens editor home\n {cyanBright $ ggt open}\n\n Opens logs\n {cyanBright $ ggt open logs}\n\n Opens permissions\n {cyanBright $ ggt open permissions}\n\n Opens data editor for the 'post' model\n {cyanBright $ ggt open data post}\n\n Opens schema for 'post' model\n {cyanBright $ ggt open schema post}\n\n Shows all models available in the data editor\n {cyanBright $ ggt open data -show-all}\n\n Shows all models available in the schema viewer\n {cyanBright $ ggt open schema --show-all}\n\n Opens data editor for 'post' model of app 'myBlog' in the 'staging' environment\n {cyanBright $ ggt open data post --app myBlog --env staging}\n `;\n};\n\nexport const run: Run<OpenArgs> = async (ctx, args) => {\n const directory = await loadSyncJsonDirectory(process.cwd());\n const syncJson = await SyncJson.load(ctx, { command: \"open\", args, directory });\n if (!syncJson) {\n throw new UnknownDirectoryError({ command: \"open\", args, directory });\n }\n\n const location = args._[0] as Location | undefined;\n if (!location) {\n await open(`https://${syncJson.environment.application.primaryDomain}/edit/${syncJson.environment.name}`);\n println`\n Opened editor for environment {cyanBright ${syncJson.environment.name}}.\n `;\n return;\n }\n\n if (!Locations.includes(location)) {\n const [closest] = sortBySimilar(location, Locations);\n throw new ArgError(sprint`\n Unknown location {yellow ${location}}\n\n Did you mean {blueBright ${closest}}?\n\n Run \"ggt open --help\" for usage\n `);\n }\n\n switch (location) {\n case \"logs\": {\n await open(`https://${syncJson.environment.application.primaryDomain}/edit/${syncJson.environment.name}/logs`);\n println`\n Opened log viewer for environment {cyanBright ${syncJson.environment.name}}.\n `;\n break;\n }\n case \"permissions\": {\n await open(`https://${syncJson.environment.application.primaryDomain}/edit/${syncJson.environment.name}/settings/permissions`);\n println`\n Opened permissions settings for environment {cyanBright ${syncJson.environment.name}}.\n `;\n break;\n }\n case \"data\":\n case \"schema\": {\n const view = args._[0];\n const remoteModelApiIdentifiers = (await getModels(ctx, syncJson.environment)).map((e) => e.apiIdentifier);\n\n let modelApiIdentifier = args._[1];\n if (!modelApiIdentifier) {\n if (args[\"--show-all\"]) {\n modelApiIdentifier = await select({ choices: remoteModelApiIdentifiers, content: \"Which model do you wish to open?\" });\n } else {\n throw new ArgError(sprint`\n \"ggt open ${view}\" requires a model to be specified.\n\n Run with \"--show-all\" to choose from available models.\n\n ggt open ${view} --show-all\n `);\n }\n }\n\n if (!remoteModelApiIdentifiers.includes(modelApiIdentifier)) {\n const [closest] = sortBySimilar(modelApiIdentifier, remoteModelApiIdentifiers);\n throw new ArgError(sprint`\n Unknown model {yellow ${modelApiIdentifier}}\n\n Did you mean {blueBright ${closest}}?\n\n Run with \"--show-all\" to choose from available models.\n\n ggt open ${view} --show-all\n `);\n }\n\n await open(\n `https://${syncJson.environment.application.primaryDomain}/edit/${syncJson.environment.name}/model/${modelApiIdentifier}/${view}`,\n );\n println`\n Opened ${view} viewer for environment {cyanBright ${syncJson.environment.name}} for model {cyanBright ${modelApiIdentifier}}.\n `;\n break;\n }\n default:\n isNever(location);\n }\n};\n\nconst Locations = [\"logs\", \"permissions\", \"data\", \"schema\"] as const;\n\ntype Location = (typeof Locations)[number];\n"],
5
- "mappings": "qXAAAA,IAcO,IAAMC,EAAO,CAClB,GAAGC,EACH,aAAc,CAAE,KAAM,OAAQ,CAChC,EAEaC,EAAgBC,GACpBC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IA+CIC,EAAqB,MAAOC,EAAKN,IAAS,CACrD,IAAMO,EAAY,MAAMC,EAAsB,QAAQ,IAAI,CAAC,EACrDC,EAAW,MAAMC,EAAS,KAAKJ,EAAK,CAAE,QAAS,OAAQ,KAAAN,EAAM,UAAAO,CAAU,CAAC,EAC9E,GAAI,CAACE,EACH,MAAM,IAAIE,EAAsB,CAAE,QAAS,OAAQ,KAAAX,EAAM,UAAAO,CAAU,CAAC,EAGtE,IAAMK,EAAWZ,EAAK,EAAE,CAAC,EACzB,GAAI,CAACY,EAAU,CACb,MAAMC,EAAK,WAAWJ,EAAS,YAAY,YAAY,aAAa,SAASA,EAAS,YAAY,IAAI,EAAE,EACxGK;AAAA,kDAC8CL,EAAS,YAAY,IAAI;AAAA,MAEvE,MACF,CAEA,GAAI,CAACM,EAAU,SAASH,CAAQ,EAAG,CACjC,GAAM,CAACI,CAAO,EAAIC,EAAcL,EAAUG,CAAS,EACnD,MAAM,IAAIG,EAASd;AAAA,iCACUQ,CAAQ;AAAA;AAAA,iCAERI,CAAO;AAAA;AAAA;AAAA,KAGnC,CACH,CAEA,OAAQJ,EAAU,CAChB,IAAK,OAAQ,CACX,MAAMC,EAAK,WAAWJ,EAAS,YAAY,YAAY,aAAa,SAASA,EAAS,YAAY,IAAI,OAAO,EAC7GK;AAAA,wDACkDL,EAAS,YAAY,IAAI;AAAA,QAE3E,KACF,CACA,IAAK,cAAe,CAClB,MAAMI,EAAK,WAAWJ,EAAS,YAAY,YAAY,aAAa,SAASA,EAAS,YAAY,IAAI,uBAAuB,EAC7HK;AAAA,kEAC4DL,EAAS,YAAY,IAAI;AAAA,QAErF,KACF,CACA,IAAK,OACL,IAAK,SAAU,CACb,IAAMU,EAAOnB,EAAK,EAAE,CAAC,EACfoB,GAA6B,MAAMC,EAAUf,EAAKG,EAAS,WAAW,GAAG,IAAKa,GAAMA,EAAE,aAAa,EAErGC,EAAqBvB,EAAK,EAAE,CAAC,EACjC,GAAI,CAACuB,EACH,GAAIvB,EAAK,YAAY,EACnBuB,EAAqB,MAAMC,EAAO,CAAE,QAASJ,EAA2B,QAAS,kCAAmC,CAAC,MAErH,OAAM,IAAIF,EAASd;AAAA,wBACLe,CAAI;AAAA;AAAA;AAAA;AAAA,yBAIHA,CAAI;AAAA,WAClB,EAIL,GAAI,CAACC,EAA0B,SAASG,CAAkB,EAAG,CAC3D,GAAM,CAACP,CAAO,EAAIC,EAAcM,EAAoBH,CAAyB,EAC7E,MAAM,IAAIF,EAASd;AAAA,kCACOmB,CAAkB;AAAA;AAAA,qCAEfP,CAAO;AAAA;AAAA;AAAA;AAAA,uBAIrBG,CAAI;AAAA,SAClB,CACH,CAEA,MAAMN,EACJ,WAAWJ,EAAS,YAAY,YAAY,aAAa,SAASA,EAAS,YAAY,IAAI,UAAUc,CAAkB,IAAIJ,CAAI,EACjI,EACAL;AAAA,iBACWK,CAAI,uCAAuCV,EAAS,YAAY,IAAI,2BAA2Bc,CAAkB;AAAA,QAE5H,KACF,CACA,QACEE,EAAQb,CAAQ,CACpB,CACF,EAEMG,EAAY,CAAC,OAAQ,cAAe,OAAQ,QAAQ",
6
- "names": ["init_cjs", "args", "SyncJsonArgs", "usage", "_ctx", "sprint", "run", "ctx", "directory", "loadSyncJsonDirectory", "syncJson", "SyncJson", "UnknownDirectoryError", "location", "open_default", "println", "Locations", "closest", "sortBySimilar", "ArgError", "view", "remoteModelApiIdentifiers", "getModels", "e", "modelApiIdentifier", "select", "isNever"]
5
+ "mappings": "4XAAAA,IAcO,IAAMC,EAAO,CAClB,GAAGC,EACH,aAAc,CAAE,KAAM,OAAQ,CAChC,EAEaC,EAAeC,EAACC,GACpBC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IADmB,SAgDfC,EAAqBH,EAAA,MAAOI,EAAKP,IAAS,CACrD,IAAMQ,EAAY,MAAMC,EAAsB,QAAQ,IAAI,CAAC,EACrDC,EAAW,MAAMC,EAAS,KAAKJ,EAAK,CAAE,QAAS,OAAQ,KAAAP,EAAM,UAAAQ,CAAU,CAAC,EAC9E,GAAI,CAACE,EACH,MAAM,IAAIE,EAAsB,CAAE,QAAS,OAAQ,KAAAZ,EAAM,UAAAQ,CAAU,CAAC,EAGtE,IAAMK,EAAWb,EAAK,EAAE,CAAC,EACzB,GAAI,CAACa,EAAU,CACb,MAAMC,EAAK,WAAWJ,EAAS,YAAY,YAAY,aAAa,SAASA,EAAS,YAAY,IAAI,EAAE,EACxGK;AAAA,kDAC8CL,EAAS,YAAY,IAAI;AAAA,MAEvE,MACF,CAEA,GAAI,CAACM,EAAU,SAASH,CAAQ,EAAG,CACjC,GAAM,CAACI,CAAO,EAAIC,EAAcL,EAAUG,CAAS,EACnD,MAAM,IAAIG,EAASd;AAAA,iCACUQ,CAAQ;AAAA;AAAA,iCAERI,CAAO;AAAA;AAAA;AAAA,KAGnC,CACH,CAEA,OAAQJ,EAAU,CAChB,IAAK,OAAQ,CACX,MAAMC,EAAK,WAAWJ,EAAS,YAAY,YAAY,aAAa,SAASA,EAAS,YAAY,IAAI,OAAO,EAC7GK;AAAA,wDACkDL,EAAS,YAAY,IAAI;AAAA,QAE3E,KACF,CACA,IAAK,cAAe,CAClB,MAAMI,EAAK,WAAWJ,EAAS,YAAY,YAAY,aAAa,SAASA,EAAS,YAAY,IAAI,uBAAuB,EAC7HK;AAAA,kEAC4DL,EAAS,YAAY,IAAI;AAAA,QAErF,KACF,CACA,IAAK,OACL,IAAK,SAAU,CACb,IAAMU,EAAOpB,EAAK,EAAE,CAAC,EACfqB,GAA6B,MAAMC,EAAUf,EAAKG,EAAS,WAAW,GAAG,IAAKa,GAAMA,EAAE,aAAa,EAErGC,EAAqBxB,EAAK,EAAE,CAAC,EACjC,GAAI,CAACwB,EACH,GAAIxB,EAAK,YAAY,EACnBwB,EAAqB,MAAMC,EAAO,CAAE,QAASJ,EAA2B,QAAS,kCAAmC,CAAC,MAErH,OAAM,IAAIF,EAASd;AAAA,wBACLe,CAAI;AAAA;AAAA;AAAA;AAAA,yBAIHA,CAAI;AAAA,WAClB,EAIL,GAAI,CAACC,EAA0B,SAASG,CAAkB,EAAG,CAC3D,GAAM,CAACP,CAAO,EAAIC,EAAcM,EAAoBH,CAAyB,EAC7E,MAAM,IAAIF,EAASd;AAAA,kCACOmB,CAAkB;AAAA;AAAA,qCAEfP,CAAO;AAAA;AAAA;AAAA;AAAA,uBAIrBG,CAAI;AAAA,SAClB,CACH,CAEA,MAAMN,EACJ,WAAWJ,EAAS,YAAY,YAAY,aAAa,SAASA,EAAS,YAAY,IAAI,UAAUc,CAAkB,IAAIJ,CAAI,EACjI,EACAL;AAAA,iBACWK,CAAI,uCAAuCV,EAAS,YAAY,IAAI,2BAA2Bc,CAAkB;AAAA,QAE5H,KACF,CACA,QACEE,EAAQb,CAAQ,CACpB,CACF,EAtFkC,OAwF5BG,EAAY,CAAC,OAAQ,cAAe,OAAQ,QAAQ",
6
+ "names": ["init_cjs", "args", "SyncJsonArgs", "usage", "__name", "_ctx", "sprint", "run", "ctx", "directory", "loadSyncJsonDirectory", "syncJson", "SyncJson", "UnknownDirectoryError", "location", "open_default", "println", "Locations", "closest", "sortBySimilar", "ArgError", "view", "remoteModelApiIdentifiers", "getModels", "e", "modelApiIdentifier", "select", "isNever"]
7
7
  }
@@ -1,4 +1,4 @@
1
- import{o as g}from"./chunk-PC6ANBC6.js";import{m as l,n as c,o as p}from"./chunk-BKO2TX4J.js";import"./chunk-HCQR6OPH.js";import"./chunk-W5JAWOQQ.js";import{c as i}from"./chunk-W4IVYUHW.js";import"./chunk-FQ2LR3BI.js";import"./chunk-XB3JTJT6.js";import"./chunk-O2K4B6AL.js";import"./chunk-AGRDDZFS.js";import{$ as a,Z as r}from"./chunk-GIAIN3IJ.js";import"./chunk-B6XQEEUK.js";import{g as s}from"./chunk-SGMPMYEU.js";s();var w={...l,"--force":{type:Boolean,alias:"-f"}},P=e=>r`
1
+ import{o as m}from"./chunk-ZZIIWV6T.js";import{m as c,n as p,o as g}from"./chunk-LMY5YGE5.js";import"./chunk-DKP76YB2.js";import"./chunk-O3D5GVFK.js";import{c as l}from"./chunk-YB7NQA2X.js";import"./chunk-P5UB5UJ6.js";import"./chunk-VF4CDM7R.js";import"./chunk-WCP5LTNQ.js";import"./chunk-SWVUOPJX.js";import{$ as i,Z as s}from"./chunk-KXSKHE3X.js";import"./chunk-B2QVXD4S.js";import{a as r,h as a}from"./chunk-IOJ2LNUK.js";a();var P={...c,"--env":{type:String,alias:["-e","--environment","--from"]},"--force":{type:Boolean,alias:"-f"}},A=r(e=>s`
2
2
  Pulls your environment files to your local directory.
3
3
 
4
4
  This command first tracks changes in your local directory since the last sync. If changes are
@@ -9,7 +9,7 @@ import{o as g}from"./chunk-PC6ANBC6.js";import{m as l,n as c,o as p}from"./chunk
9
9
 
10
10
  {gray Options}
11
11
  -a, --app <app_name> Selects the app to pull your environment changes from. Default set on ".gadget/sync.json"
12
- --from, -e, --env <env_name> Selects the environment to pull changes from. Default set on ".gadget/sync.json"
12
+ -e, --env, --from <env_name> Selects the environment to pull changes from. Default set on ".gadget/sync.json"
13
13
  --force Forces a pull by discarding any changes made on your local directory since last sync
14
14
  --allow-different-directory Pulls changes from any environment directory, even if the ".gadget/sync.json" file is missing
15
15
  --allow-different-app Pulls changes to a different app using --app command, instead of the one in the “.gadget/sync.json” file
@@ -17,12 +17,12 @@ import{o as g}from"./chunk-PC6ANBC6.js";import{m as l,n as c,o as p}from"./chunk
17
17
  {gray Examples}
18
18
  Pull all development environment changes by discarding any changes made locally
19
19
  {cyanBright $ ggt pull --env development --force}
20
- `,A=async(e,o)=>{if(o._.length>0)throw new i(r`
20
+ `,"usage"),S=r(async(e,o)=>{if(o._.length>0)throw new l(s`
21
21
  "ggt pull" does not take any positional arguments.
22
22
 
23
23
  If you are trying to pull changes to a specific directory,
24
- you must "cd" to that directory and then run "ggt push".
24
+ you must "cd" to that directory and then run "ggt pull".
25
25
 
26
- Run "ggt pull -h" for more information.
27
- `);let y=await p(process.cwd()),m=await c.loadOrInit(e,{command:"pull",args:o,directory:y}),t=new g(m),n=await t.hashes(e);if(n.environmentChangesToPull.size===0){a({ensureEmptyLineAbove:!0,content:"Nothing to pull."});return}n.localChangesToPush.size>0&&await t.print(e,{hashes:n}),await t.pull(e,{hashes:n,force:o["--force"]})};export{w as args,A as run,P as usage};
28
- //# sourceMappingURL=pull-YLUFPDDX.js.map
26
+ Run "ggt pull -h" for more information.
27
+ `);let y=await g(process.cwd()),f=await p.loadOrInit(e,{command:"pull",args:o,directory:y}),t=new m(f),n=await t.hashes(e);if(n.environmentChangesToPull.size===0){i({ensureEmptyLineAbove:!0,content:"Nothing to pull."});return}n.localChangesToPush.size>0&&await t.print(e,{hashes:n}),await t.pull(e,{hashes:n,force:o["--force"]})},"run");export{P as args,S as run,A as usage};
28
+ //# sourceMappingURL=pull-3DUIUAIP.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/commands/pull.ts"],
4
+ "sourcesContent": ["import { ArgError, type ArgsDefinition } from \"../services/command/arg.js\";\nimport type { Run, Usage } from \"../services/command/command.js\";\nimport { FileSync } from \"../services/filesync/filesync.js\";\nimport { SyncJson, SyncJsonArgs, loadSyncJsonDirectory } from \"../services/filesync/sync-json.js\";\nimport { println } from \"../services/output/print.js\";\nimport { sprint } from \"../services/output/sprint.js\";\n\nexport type PullArgs = typeof args;\n\nexport const args = {\n ...SyncJsonArgs,\n \"--env\": { type: String, alias: [\"-e\", \"--environment\", \"--from\"] },\n \"--force\": { type: Boolean, alias: \"-f\" },\n} satisfies ArgsDefinition;\n\nexport const usage: Usage = (_ctx) => {\n return sprint`\n Pulls your environment files to your local directory.\n\n This command first tracks changes in your local directory since the last sync. If changes are\n detected, you will be prompted to discard them or abort the pull.\n\n {gray Usage}\n ggt pull [options]\n\n {gray Options}\n -a, --app <app_name> Selects the app to pull your environment changes from. Default set on \".gadget/sync.json\"\n -e, --env, --from <env_name> Selects the environment to pull changes from. Default set on \".gadget/sync.json\"\n --force Forces a pull by discarding any changes made on your local directory since last sync\n --allow-different-directory Pulls changes from any environment directory, even if the \".gadget/sync.json\" file is missing\n --allow-different-app Pulls changes to a different app using --app command, instead of the one in the \u201C.gadget/sync.json\u201D file\n\n {gray Examples}\n Pull all development environment changes by discarding any changes made locally\n {cyanBright $ ggt pull --env development --force}\n `;\n};\n\nexport const run: Run<PullArgs> = async (ctx, args) => {\n if (args._.length > 0) {\n throw new ArgError(sprint`\n \"ggt pull\" does not take any positional arguments.\n\n If you are trying to pull changes to a specific directory,\n you must \"cd\" to that directory and then run \"ggt pull\".\n\n Run \"ggt pull -h\" for more information.\n `);\n }\n\n const directory = await loadSyncJsonDirectory(process.cwd());\n const syncJson = await SyncJson.loadOrInit(ctx, { command: \"pull\", args, directory });\n const filesync = new FileSync(syncJson);\n const hashes = await filesync.hashes(ctx);\n\n if (hashes.environmentChangesToPull.size === 0) {\n println({ ensureEmptyLineAbove: true, content: \"Nothing to pull.\" });\n return;\n }\n\n if (hashes.localChangesToPush.size > 0) {\n // show them the local changes they will discard\n await filesync.print(ctx, { hashes });\n }\n\n await filesync.pull(ctx, { hashes, force: args[\"--force\"] });\n};\n"],
5
+ "mappings": "waAAAA,IASO,IAAMC,EAAO,CAClB,GAAGC,EACH,QAAS,CAAE,KAAM,OAAQ,MAAO,CAAC,KAAM,gBAAiB,QAAQ,CAAE,EAClE,UAAW,CAAE,KAAM,QAAS,MAAO,IAAK,CAC1C,EAEaC,EAAeC,EAACC,GACpBC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IADmB,SAuBfC,EAAqBH,EAAA,MAAOI,EAAKP,IAAS,CACrD,GAAIA,EAAK,EAAE,OAAS,EAClB,MAAM,IAAIQ,EAASH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,KAOlB,EAGH,IAAMI,EAAY,MAAMC,EAAsB,QAAQ,IAAI,CAAC,EACrDC,EAAW,MAAMC,EAAS,WAAWL,EAAK,CAAE,QAAS,OAAQ,KAAAP,EAAM,UAAAS,CAAU,CAAC,EAC9EI,EAAW,IAAIC,EAASH,CAAQ,EAChCI,EAAS,MAAMF,EAAS,OAAON,CAAG,EAExC,GAAIQ,EAAO,yBAAyB,OAAS,EAAG,CAC9CC,EAAQ,CAAE,qBAAsB,GAAM,QAAS,kBAAmB,CAAC,EACnE,MACF,CAEID,EAAO,mBAAmB,KAAO,GAEnC,MAAMF,EAAS,MAAMN,EAAK,CAAE,OAAAQ,CAAO,CAAC,EAGtC,MAAMF,EAAS,KAAKN,EAAK,CAAE,OAAAQ,EAAQ,MAAOf,EAAK,SAAS,CAAE,CAAC,CAC7D,EA5BkC",
6
+ "names": ["init_cjs", "args", "SyncJsonArgs", "usage", "__name", "_ctx", "sprint", "run", "ctx", "ArgError", "directory", "loadSyncJsonDirectory", "syncJson", "SyncJson", "filesync", "FileSync", "hashes", "println"]
7
+ }
@@ -0,0 +1,2 @@
1
+ import{a,b,c}from"./chunk-FLX4WQHD.js";import"./chunk-ZZIIWV6T.js";import"./chunk-LMY5YGE5.js";import"./chunk-DKP76YB2.js";import"./chunk-O3D5GVFK.js";import"./chunk-YB7NQA2X.js";import"./chunk-P5UB5UJ6.js";import"./chunk-VF4CDM7R.js";import"./chunk-WCP5LTNQ.js";import"./chunk-SWVUOPJX.js";import"./chunk-KXSKHE3X.js";import"./chunk-B2QVXD4S.js";import"./chunk-IOJ2LNUK.js";export{a as args,c as run,b as usage};
2
+ //# sourceMappingURL=push-RS6QHKDD.js.map
@@ -0,0 +1,14 @@
1
+ import{k as p,l as f,o as h}from"./chunk-ZZIIWV6T.js";import{g as u,m as y,n as l,o as d}from"./chunk-LMY5YGE5.js";import"./chunk-DKP76YB2.js";import"./chunk-O3D5GVFK.js";import{c as m}from"./chunk-YB7NQA2X.js";import"./chunk-P5UB5UJ6.js";import"./chunk-VF4CDM7R.js";import"./chunk-WCP5LTNQ.js";import"./chunk-SWVUOPJX.js";import{Z as a}from"./chunk-KXSKHE3X.js";import"./chunk-B2QVXD4S.js";import{a as r,h as g}from"./chunk-IOJ2LNUK.js";g();var D=y,J=r(()=>a`
2
+ Shows file changes since last sync (e.g. $ggt dev, push, deploy etc.)
3
+
4
+ {gray Usage}
5
+ ggt status
6
+ `,"usage"),U=r(async(t,s)=>{if(s._.length>0)throw new m(a`
7
+ "ggt status" does not take any positional arguments.
8
+
9
+ If you are trying to see the status of a specific directory,
10
+ you must "cd" to that directory and then run "ggt status".
11
+
12
+ Run "ggt status -h" for more information.
13
+ `);let i=await d(process.cwd()),o=await l.load(t,{command:"status",args:s,directory:i});if(!o)throw new u({command:"status",args:s,directory:i});o.print();let c=new h(o),n=await c.hashes(t);await c.print(t,{hashes:n});let e=p({localChanges:n.localChanges,environmentChanges:n.environmentChanges});e.size>0&&(t.log.debug("conflicts detected",{conflicts:e}),f({conflicts:e}))},"run");export{D as args,U as run,J as usage};
14
+ //# sourceMappingURL=status-N3VF5MBE.js.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/commands/status.ts"],
4
4
  "sourcesContent": ["import { ArgError, type ArgsDefinitionResult } from \"../services/command/arg.js\";\nimport type { Run, Usage } from \"../services/command/command.js\";\nimport { getConflicts, printConflicts } from \"../services/filesync/conflicts.js\";\nimport { UnknownDirectoryError } from \"../services/filesync/error.js\";\nimport { FileSync } from \"../services/filesync/filesync.js\";\nimport { SyncJson, SyncJsonArgs, loadSyncJsonDirectory } from \"../services/filesync/sync-json.js\";\nimport { sprint } from \"../services/output/sprint.js\";\n\nexport type StatusArgs = typeof args;\nexport type StatusArgsResult = ArgsDefinitionResult<StatusArgs>;\n\nexport const args = SyncJsonArgs;\n\nexport const usage: Usage = () => {\n return sprint`\n Shows file changes since last sync (e.g. $ggt dev, push, deploy etc.)\n\n {gray Usage}\n ggt status\n `;\n};\n\nexport const run: Run<StatusArgs> = async (ctx, args) => {\n if (args._.length > 0) {\n throw new ArgError(sprint`\n \"ggt status\" does not take any positional arguments.\n\n If you are trying to see the status of a specific directory,\n you must \"cd\" to that directory and then run \"ggt status\".\n\n Run \"ggt status -h\" for more information.\n `);\n }\n\n const directory = await loadSyncJsonDirectory(process.cwd());\n const syncJson = await SyncJson.load(ctx, { command: \"status\", args, directory });\n if (!syncJson) {\n throw new UnknownDirectoryError({ command: \"status\", args, directory });\n }\n\n syncJson.print();\n\n const filesync = new FileSync(syncJson);\n const hashes = await filesync.hashes(ctx);\n await filesync.print(ctx, { hashes });\n\n const conflicts = getConflicts({ localChanges: hashes.localChanges, environmentChanges: hashes.environmentChanges });\n if (conflicts.size > 0) {\n ctx.log.debug(\"conflicts detected\", { conflicts });\n printConflicts({ conflicts });\n }\n};\n"],
5
- "mappings": "+aAAAA,IAWO,IAAMC,EAAOC,EAEPC,EAAe,IACnBC;AAAA;AAAA;AAAA;AAAA;AAAA,IAQIC,EAAuB,MAAOC,EAAKL,IAAS,CACvD,GAAIA,EAAK,EAAE,OAAS,EAClB,MAAM,IAAIM,EAASH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,KAOlB,EAGH,IAAMI,EAAY,MAAMC,EAAsB,QAAQ,IAAI,CAAC,EACrDC,EAAW,MAAMC,EAAS,KAAKL,EAAK,CAAE,QAAS,SAAU,KAAAL,EAAM,UAAAO,CAAU,CAAC,EAChF,GAAI,CAACE,EACH,MAAM,IAAIE,EAAsB,CAAE,QAAS,SAAU,KAAAX,EAAM,UAAAO,CAAU,CAAC,EAGxEE,EAAS,MAAM,EAEf,IAAMG,EAAW,IAAIC,EAASJ,CAAQ,EAChCK,EAAS,MAAMF,EAAS,OAAOP,CAAG,EACxC,MAAMO,EAAS,MAAMP,EAAK,CAAE,OAAAS,CAAO,CAAC,EAEpC,IAAMC,EAAYC,EAAa,CAAE,aAAcF,EAAO,aAAc,mBAAoBA,EAAO,kBAAmB,CAAC,EAC/GC,EAAU,KAAO,IACnBV,EAAI,IAAI,MAAM,qBAAsB,CAAE,UAAAU,CAAU,CAAC,EACjDE,EAAe,CAAE,UAAAF,CAAU,CAAC,EAEhC",
6
- "names": ["init_cjs", "args", "SyncJsonArgs", "usage", "sprint", "run", "ctx", "ArgError", "directory", "loadSyncJsonDirectory", "syncJson", "SyncJson", "UnknownDirectoryError", "filesync", "FileSync", "hashes", "conflicts", "getConflicts", "printConflicts"]
5
+ "mappings": "sbAAAA,IAWO,IAAMC,EAAOC,EAEPC,EAAeC,EAAA,IACnBC;AAAA;AAAA;AAAA;AAAA;AAAA,IADmB,SASfC,EAAuBF,EAAA,MAAOG,EAAKN,IAAS,CACvD,GAAIA,EAAK,EAAE,OAAS,EAClB,MAAM,IAAIO,EAASH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,KAOlB,EAGH,IAAMI,EAAY,MAAMC,EAAsB,QAAQ,IAAI,CAAC,EACrDC,EAAW,MAAMC,EAAS,KAAKL,EAAK,CAAE,QAAS,SAAU,KAAAN,EAAM,UAAAQ,CAAU,CAAC,EAChF,GAAI,CAACE,EACH,MAAM,IAAIE,EAAsB,CAAE,QAAS,SAAU,KAAAZ,EAAM,UAAAQ,CAAU,CAAC,EAGxEE,EAAS,MAAM,EAEf,IAAMG,EAAW,IAAIC,EAASJ,CAAQ,EAChCK,EAAS,MAAMF,EAAS,OAAOP,CAAG,EACxC,MAAMO,EAAS,MAAMP,EAAK,CAAE,OAAAS,CAAO,CAAC,EAEpC,IAAMC,EAAYC,EAAa,CAAE,aAAcF,EAAO,aAAc,mBAAoBA,EAAO,kBAAmB,CAAC,EAC/GC,EAAU,KAAO,IACnBV,EAAI,IAAI,MAAM,qBAAsB,CAAE,UAAAU,CAAU,CAAC,EACjDE,EAAe,CAAE,UAAAF,CAAU,CAAC,EAEhC,EA7BoC",
6
+ "names": ["init_cjs", "args", "SyncJsonArgs", "usage", "__name", "sprint", "run", "ctx", "ArgError", "directory", "loadSyncJsonDirectory", "syncJson", "SyncJson", "UnknownDirectoryError", "filesync", "FileSync", "hashes", "conflicts", "getConflicts", "printConflicts"]
7
7
  }
@@ -0,0 +1,11 @@
1
+ import{$ as r,A as n,Z as o}from"./chunk-KXSKHE3X.js";import{a as t,h as e}from"./chunk-IOJ2LNUK.js";e();var m=t(()=>o`
2
+ Print this version of ggt.
3
+
4
+ {gray Usage}
5
+ ggt version
6
+
7
+ {gray Updating ggt}
8
+ When there is a new release of ggt, running ggt will show you a message letting you
9
+ know that an update is available.
10
+ `,"usage"),p=t(a=>{r(n.version)},"run");export{p as run,m as usage};
11
+ //# sourceMappingURL=version-EGM7PLFX.js.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/commands/version.ts"],
4
4
  "sourcesContent": ["import type { Run, Usage } from \"../services/command/command.js\";\nimport { println } from \"../services/output/print.js\";\nimport { sprint } from \"../services/output/sprint.js\";\nimport { packageJson } from \"../services/util/package-json.js\";\n\nexport const usage: Usage = () => sprint`\n Print this version of ggt.\n\n {gray Usage}\n ggt version\n\n {gray Updating ggt}\n When there is a new release of ggt, running ggt will show you a message letting you\n know that an update is available.\n`;\n\nexport const run: Run = (_ctx) => {\n println(packageJson.version);\n};\n"],
5
- "mappings": "8FAAAA,IAKO,IAAMC,EAAe,IAAMC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWrBC,EAAYC,GAAS,CAChCC,EAAQC,EAAY,OAAO,CAC7B",
6
- "names": ["init_cjs", "usage", "sprint", "run", "_ctx", "println", "packageJson"]
5
+ "mappings": "qGAAAA,IAKO,IAAMC,EAAeC,EAAA,IAAMC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAAN,SAWfC,EAAWF,EAACG,GAAS,CAChCC,EAAQC,EAAY,OAAO,CAC7B,EAFwB",
6
+ "names": ["init_cjs", "usage", "__name", "sprint", "run", "_ctx", "println", "packageJson"]
7
7
  }
@@ -0,0 +1,7 @@
1
+ import{h as s}from"./chunk-VF4CDM7R.js";import"./chunk-WCP5LTNQ.js";import"./chunk-SWVUOPJX.js";import{$ as o,Z as n}from"./chunk-KXSKHE3X.js";import"./chunk-B2QVXD4S.js";import{a as r,h as a}from"./chunk-IOJ2LNUK.js";a();var u=r(()=>n`
2
+ Show the name and email address of the currently logged in user.
3
+
4
+ {gray Usage}
5
+ ggt whoami
6
+ `,"usage"),l=r(async t=>{let e=await s(t);if(!e){o("You are not logged in");return}e.name?o(`You are logged in as ${e.name} (${e.email})`):o(`You are logged in as ${e.email}`)},"run");export{l as run,u as usage};
7
+ //# sourceMappingURL=whoami-ES6XN3RI.js.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/commands/whoami.ts"],
4
4
  "sourcesContent": ["import type { Run, Usage } from \"../services/command/command.js\";\nimport { println } from \"../services/output/print.js\";\nimport { sprint } from \"../services/output/sprint.js\";\nimport { getUser } from \"../services/user/user.js\";\n\nexport const usage: Usage = () => sprint`\n Show the name and email address of the currently logged in user.\n\n {gray Usage}\n ggt whoami\n`;\n\nexport const run: Run = async (ctx) => {\n const user = await getUser(ctx);\n if (!user) {\n println(\"You are not logged in\");\n return;\n }\n\n if (user.name) {\n println(`You are logged in as ${user.name} (${user.email})`);\n } else {\n println(`You are logged in as ${user.email}`);\n }\n};\n"],
5
- "mappings": "mNAAAA,IAKO,IAAMC,EAAe,IAAMC;AAAA;AAAA;AAAA;AAAA;AAAA,EAOrBC,EAAW,MAAOC,GAAQ,CACrC,IAAMC,EAAO,MAAMC,EAAQF,CAAG,EAC9B,GAAI,CAACC,EAAM,CACTE,EAAQ,uBAAuB,EAC/B,MACF,CAEIF,EAAK,KACPE,EAAQ,wBAAwBF,EAAK,IAAI,KAAKA,EAAK,KAAK,GAAG,EAE3DE,EAAQ,wBAAwBF,EAAK,KAAK,EAAE,CAEhD",
6
- "names": ["init_cjs", "usage", "sprint", "run", "ctx", "user", "getUser", "println"]
5
+ "mappings": "0NAAAA,IAKO,IAAMC,EAAeC,EAAA,IAAMC;AAAA;AAAA;AAAA;AAAA;AAAA,EAAN,SAOfC,EAAWF,EAAA,MAAOG,GAAQ,CACrC,IAAMC,EAAO,MAAMC,EAAQF,CAAG,EAC9B,GAAI,CAACC,EAAM,CACTE,EAAQ,uBAAuB,EAC/B,MACF,CAEIF,EAAK,KACPE,EAAQ,wBAAwBF,EAAK,IAAI,KAAKA,EAAK,KAAK,GAAG,EAE3DE,EAAQ,wBAAwBF,EAAK,KAAK,EAAE,CAEhD,EAZwB",
6
+ "names": ["init_cjs", "usage", "__name", "sprint", "run", "ctx", "user", "getUser", "println"]
7
7
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@gadgetinc/ggt",
3
- "version": "1.3.2",
3
+ "version": "1.4.0",
4
4
  "description": "The command-line interface for Gadget",
5
5
  "homepage": "https://github.com/gadget-inc/ggt",
6
6
  "bugs": {
@@ -27,56 +27,56 @@
27
27
  "/README.md"
28
28
  ],
29
29
  "devDependencies": {
30
- "@changesets/cli": "^2.27.8",
30
+ "@changesets/cli": "^2.27.12",
31
31
  "@graphql-codegen/add": "^5.0.3",
32
- "@graphql-codegen/cli": "^5.0.2",
33
- "@graphql-codegen/typescript": "^4.0.9",
34
- "@graphql-codegen/typescript-operations": "^4.2.3",
35
- "@sentry/node": "^8.33.0",
32
+ "@graphql-codegen/cli": "^5.0.3",
33
+ "@graphql-codegen/typescript": "^4.1.2",
34
+ "@graphql-codegen/typescript-operations": "^4.4.0",
35
+ "@sentry/node": "^8.51.0",
36
36
  "@types/eslint": "^8.56.7",
37
37
  "@types/fast-levenshtein": "^0.0.4",
38
38
  "@types/fs-extra": "^11.0.4",
39
39
  "@types/ms": "^0.7.34",
40
- "@types/node": "^18.19.54",
40
+ "@types/node": "^18.19.74",
41
41
  "@types/node-notifier": "^8.0.5",
42
42
  "@types/normalize-package-data": "^2.4.4",
43
43
  "@types/normalize-path": "^3.0.2",
44
44
  "@types/pluralize": "^0.0.33",
45
45
  "@types/semver": "^7.5.8",
46
46
  "@types/which": "^3.0.4",
47
- "@types/ws": "^8.5.12",
48
- "@typescript-eslint/eslint-plugin": "^8.8.0",
49
- "@typescript-eslint/parser": "^8.8.0",
47
+ "@types/ws": "^8.5.13",
48
+ "@typescript-eslint/eslint-plugin": "^8.11.0",
49
+ "@typescript-eslint/parser": "^8.11.0",
50
50
  "ansi-escapes": "^7.0.0",
51
51
  "arg": "^5.0.2",
52
52
  "boxen": "^8.0.1",
53
- "chalk": "^5.3.0",
53
+ "chalk": "^5.4.1",
54
54
  "chalk-template": "^1.1.0",
55
55
  "clean-stack": "^5.2.0",
56
56
  "cli-cursor": "^5.0.0",
57
57
  "cli-spinners": "^2.9.2",
58
58
  "cli-table3": "^0.6.5",
59
- "concurrently": "^9.0.1",
60
- "cspell": "^8.14.4",
59
+ "concurrently": "^9.1.2",
60
+ "cspell": "^8.17.2",
61
61
  "dayjs": "^1.11.13",
62
- "esbuild": "^0.24.0",
62
+ "esbuild": "^0.24.2",
63
63
  "eslint": "^8.57.0",
64
- "eslint-config-prettier": "^9.1.0",
65
- "eslint-import-resolver-typescript": "^3.6.3",
64
+ "eslint-config-prettier": "^10.0.1",
65
+ "eslint-import-resolver-typescript": "^3.7.0",
66
66
  "eslint-plugin-import": "^2.31.0",
67
- "eslint-plugin-jsdoc": "^50.3.1",
67
+ "eslint-plugin-jsdoc": "^50.6.3",
68
68
  "eslint-plugin-only-warn": "^1.1.0",
69
- "eslint-plugin-unicorn": "^56.0.0",
69
+ "eslint-plugin-unicorn": "^56.0.1",
70
70
  "execa": "^8.0.1",
71
71
  "fast-levenshtein": "^3.0.0",
72
72
  "fast-querystring": "^1.1.2",
73
73
  "figures": "^6.1.0",
74
74
  "find-up": "^7.0.0",
75
- "fs-extra": "^11.2.0",
75
+ "fs-extra": "^11.3.0",
76
76
  "get-port": "^7.1.0",
77
77
  "got": "^13.0.0",
78
- "graphql": "^16.9.0",
79
- "graphql-ws": "^5.16.0",
78
+ "graphql": "^16.10.0",
79
+ "graphql-ws": "^5.16.2",
80
80
  "ignore": "^6.0.2",
81
81
  "indent-string": "^5.0.0",
82
82
  "is-interactive": "^2.0.0",
@@ -84,19 +84,19 @@
84
84
  "is-wsl": "^3.1.0",
85
85
  "mimic-function": "^5.0.1",
86
86
  "ms": "^2.1.3",
87
- "nock": "^13.5.5",
87
+ "nock": "^13.5.6",
88
88
  "node-notifier": "^10.0.1",
89
89
  "normalize-package-data": "^7.0.0",
90
90
  "normalize-path": "^3.0.0",
91
91
  "open": "^10.1.0",
92
- "p-map": "^7.0.2",
93
- "p-queue": "^8.0.1",
94
- "p-retry": "^6.2.0",
95
- "p-timeout": "^6.1.2",
92
+ "p-map": "^7.0.3",
93
+ "p-queue": "^8.1.0",
94
+ "p-retry": "^6.2.1",
95
+ "p-timeout": "^6.1.4",
96
96
  "pluralize": "^8.0.0",
97
- "prettier": "^3.3.3",
97
+ "prettier": "^3.4.2",
98
98
  "prettier-plugin-organize-imports": "^4.1.0",
99
- "prettier-plugin-packagejson": "^2.5.2",
99
+ "prettier-plugin-packagejson": "^2.5.8",
100
100
  "remark": "^15.0.1",
101
101
  "remark-gfm": "^4.0.0",
102
102
  "remark-toc": "^9.0.0",
@@ -110,23 +110,23 @@
110
110
  "terminal-link": "^3.0.0",
111
111
  "ts-dedent": "^2.2.0",
112
112
  "ts-node": "^10.9.2",
113
- "type-fest": "^4.26.1",
114
- "typescript": "^5.6.2",
115
- "vitest": "^2.1.2",
113
+ "type-fest": "^4.33.0",
114
+ "typescript": "^5.7.3",
115
+ "vitest": "^3.0.1",
116
116
  "watcher": "^2.3.1",
117
117
  "which": "^5.0.0",
118
118
  "ws": "^8.18.0",
119
- "zod": "^3.23.8"
119
+ "zod": "^3.24.1"
120
120
  },
121
121
  "packageManager": "pnpm@8.12.0",
122
122
  "engines": {
123
123
  "node": ">=18.0.0"
124
124
  },
125
125
  "scripts": {
126
- "build": "pnpm run clean && esbuild src/main.ts --outdir=dist --format=esm --platform=node --target=node20 --inject:./shims/cjs.js --bundle --splitting --minify --sourcemap",
126
+ "build": "pnpm run clean && esbuild src/main.ts --outdir=dist --format=esm --platform=node --target=node20 --inject:./shims/cjs.js --bundle --splitting --minify --keep-names --sourcemap",
127
127
  "changeset": "changeset",
128
128
  "clean": "rimraf dist tmp/spec",
129
- "dev": "pnpm run build --minify=false --watch",
129
+ "dev": "pnpm run build --minify=false --sources-content=false --watch",
130
130
  "generate:graphql": "graphql-codegen --config=graphql-codegen.yml",
131
131
  "lint": "concurrently 'npm:lint:*(!fix)' --group --names --prefix-colors=auto",
132
132
  "lint:cspell": "cspell . --no-progress --show-suggestions --show-context",