@gadgetinc/ggt 1.0.6 → 1.2.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.
- package/README.md +1 -0
- package/dist/add-DCE6CV2D.js +78 -0
- package/dist/add-DCE6CV2D.js.map +7 -0
- package/dist/chunk-3Q3GPB6Z.js +2 -0
- package/dist/chunk-3Q3GPB6Z.js.map +7 -0
- package/dist/chunk-6FBP46EB.js +18 -0
- package/dist/chunk-6FBP46EB.js.map +7 -0
- package/dist/chunk-AB4I3BMD.js +33 -0
- package/dist/{chunk-BOQUW6DS.js.map → chunk-AB4I3BMD.js.map} +3 -3
- package/dist/{chunk-GACF5GYF.js → chunk-BYMG3KOL.js} +4 -6
- package/dist/{chunk-GACF5GYF.js.map → chunk-BYMG3KOL.js.map} +2 -2
- package/dist/chunk-BZSAGSV3.js +8 -0
- package/dist/{chunk-APHXRHNI.js.map → chunk-BZSAGSV3.js.map} +3 -3
- package/dist/chunk-CXYA3RFX.js +117 -0
- package/dist/chunk-CXYA3RFX.js.map +7 -0
- package/dist/chunk-DVKNBG4P.js +180 -0
- package/dist/chunk-DVKNBG4P.js.map +7 -0
- package/dist/chunk-EFU2JNKY.js +9 -0
- package/dist/chunk-EFU2JNKY.js.map +7 -0
- package/dist/chunk-KGOVR5SK.js +67 -0
- package/dist/chunk-KGOVR5SK.js.map +7 -0
- package/dist/chunk-KMCOZJPU.js +12 -0
- package/dist/chunk-KMCOZJPU.js.map +7 -0
- package/dist/{chunk-Q5N5L6H3.js → chunk-M4PNFOA5.js} +2 -2
- package/dist/chunk-M4PNFOA5.js.map +7 -0
- package/dist/chunk-OLKWG2EP.js +12 -0
- package/dist/chunk-OLKWG2EP.js.map +7 -0
- package/dist/{chunk-ERYUXLYS.js → chunk-THZRTDWW.js} +8 -8
- package/dist/{chunk-ERYUXLYS.js.map → chunk-THZRTDWW.js.map} +3 -3
- package/dist/context-L5YSPF3X.js +2 -0
- package/dist/deploy-PBJEUYGH.js +25 -0
- package/dist/deploy-PBJEUYGH.js.map +7 -0
- package/dist/{dev-VHJ52BEA.js → dev-OT7PEKUN.js} +9 -11
- package/dist/{dev-VHJ52BEA.js.map → dev-OT7PEKUN.js.map} +3 -3
- package/dist/esm-GJ7RK6IC.js +34 -0
- package/dist/esm-GJ7RK6IC.js.map +7 -0
- package/dist/list-CC5PICEF.js +11 -0
- package/dist/list-CC5PICEF.js.map +7 -0
- package/dist/login-SE7XIHRW.js +2 -0
- package/dist/logout-B3YAZN6R.js +7 -0
- package/dist/{logout-HX6MM4S6.js.map → logout-B3YAZN6R.js.map} +3 -3
- package/dist/main.js +6 -8
- package/dist/main.js.map +3 -3
- package/dist/{open-GEEWPSF4.js → open-OVK3YL4O.js} +3 -3
- package/dist/{open-GEEWPSF4.js.map → open-OVK3YL4O.js.map} +2 -2
- package/dist/{pull-T2Q4M4UN.js → pull-SLPBOP6Z.js} +3 -5
- package/dist/{pull-T2Q4M4UN.js.map → pull-SLPBOP6Z.js.map} +2 -2
- package/dist/push-3HGVWCKW.js +2 -0
- package/dist/push-3HGVWCKW.js.map +7 -0
- package/dist/status-7GLNL7D5.js +14 -0
- package/dist/{status-5VZH3KXH.js.map → status-7GLNL7D5.js.map} +1 -1
- package/dist/user-C34J52UL.js +2 -0
- package/dist/user-C34J52UL.js.map +7 -0
- package/dist/{version-OF4TQ2K6.js → version-AUI4NRDS.js} +2 -2
- package/dist/whoami-TXO7VJXC.js +7 -0
- package/dist/{whoami-V3XD27QH.js.map → whoami-TXO7VJXC.js.map} +2 -2
- package/package.json +20 -20
- package/dist/add-JIIVAOWH.js +0 -84
- package/dist/add-JIIVAOWH.js.map +0 -7
- package/dist/chunk-APHXRHNI.js +0 -8
- package/dist/chunk-AQRCAWW4.js +0 -24
- package/dist/chunk-AQRCAWW4.js.map +0 -7
- package/dist/chunk-BOQUW6DS.js +0 -33
- package/dist/chunk-CKSTMUDN.js +0 -17
- package/dist/chunk-CKSTMUDN.js.map +0 -7
- package/dist/chunk-GBCD37US.js +0 -57
- package/dist/chunk-GBCD37US.js.map +0 -7
- package/dist/chunk-P2XPMNL6.js +0 -183
- package/dist/chunk-P2XPMNL6.js.map +0 -7
- package/dist/chunk-PSRZ5JH5.js +0 -27
- package/dist/chunk-PSRZ5JH5.js.map +0 -7
- package/dist/chunk-Q5N5L6H3.js.map +0 -7
- package/dist/chunk-RJOIQTYZ.js +0 -126
- package/dist/chunk-RJOIQTYZ.js.map +0 -7
- package/dist/chunk-XCHCCJJZ.js +0 -2
- package/dist/chunk-XCHCCJJZ.js.map +0 -7
- package/dist/deploy-KMGAGIDE.js +0 -30
- package/dist/deploy-KMGAGIDE.js.map +0 -7
- package/dist/esm-BL3OM5UJ.js +0 -33
- package/dist/esm-BL3OM5UJ.js.map +0 -7
- package/dist/list-5E3R22IC.js +0 -11
- package/dist/list-5E3R22IC.js.map +0 -7
- package/dist/login-3DL45WY7.js +0 -2
- package/dist/logout-HX6MM4S6.js +0 -7
- package/dist/push-LUW25FYF.js +0 -2
- package/dist/status-5VZH3KXH.js +0 -14
- package/dist/whoami-V3XD27QH.js +0 -7
- /package/dist/{login-3DL45WY7.js.map → context-L5YSPF3X.js.map} +0 -0
- /package/dist/{push-LUW25FYF.js.map → login-SE7XIHRW.js.map} +0 -0
- /package/dist/{version-OF4TQ2K6.js.map → version-AUI4NRDS.js.map} +0 -0
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import{b as l}from"./chunk-THZRTDWW.js";import{f as c,g as u}from"./chunk-AB4I3BMD.js";import"./chunk-D2K5XPNJ.js";import"./chunk-3Q3GPB6Z.js";import{l as g}from"./chunk-6FBP46EB.js";import"./chunk-EFU2JNKY.js";import"./chunk-KMCOZJPU.js";import"./chunk-OLKWG2EP.js";import{$ as o,M as p,Z as a,_ as m}from"./chunk-KGOVR5SK.js";import"./chunk-F3EZ4KS3.js";import"./chunk-GOBNB5VT.js";import{g as n}from"./chunk-5WC5D4WL.js";n();var U=()=>a`
|
|
2
|
+
List the apps available to the currently logged-in user.
|
|
3
|
+
|
|
4
|
+
{bold Usage}
|
|
5
|
+
ggt list
|
|
6
|
+
`,b=async s=>{await g(s);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 f=u(e);if(p.isInteractive)f.forEach((t,r)=>{o(a`{grey ${r}}`),l({json:t,headers:["Name","Domain"],rows:t.map(i=>[i.slug,i.primaryDomain])}),o("")});else{let t="";for(let r of e)t+=m`${r.slug}\t${r.primaryDomain}`;o({json:e,content:t})}};export{b as run,U as usage};
|
|
11
|
+
//# sourceMappingURL=list-CC5PICEF.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/commands/list.ts"],
|
|
4
|
+
"sourcesContent": ["import { getApps, 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);\n\n const apps = await getApps(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": "waAAAA,IAQO,IAAMC,EAAe,IAAMC;AAAA;AAAA;AAAA;AAAA;AAAA,EAOrBC,EAAW,MAAOC,GAAQ,CACrC,MAAMC,EAAeD,CAAG,EAExB,IAAME,EAAO,MAAMC,EAAQH,CAAG,EAC9B,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", "getApps", "println", "appTeamMap", "parseAppListToTeamMap", "output", "teamName", "printTable", "app", "simpleOutput", "sprintln"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{b as a,c as b,d as c}from"./chunk-6FBP46EB.js";import"./chunk-EFU2JNKY.js";import"./chunk-KMCOZJPU.js";import"./chunk-OLKWG2EP.js";import"./chunk-KGOVR5SK.js";import"./chunk-F3EZ4KS3.js";import"./chunk-GOBNB5VT.js";import"./chunk-5WC5D4WL.js";export{c as login,b as run,a as usage};
|
|
2
|
+
//# sourceMappingURL=login-SE7XIHRW.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import{d as r,e as s}from"./chunk-KMCOZJPU.js";import{$ as o,Z as t}from"./chunk-KGOVR5SK.js";import"./chunk-GOBNB5VT.js";import{g as n}from"./chunk-5WC5D4WL.js";n();var a=()=>t`
|
|
2
|
+
Log out of your account.
|
|
3
|
+
|
|
4
|
+
{bold Usage}
|
|
5
|
+
ggt logout
|
|
6
|
+
`,p=e=>{r(e)?(s(e,void 0),o("Goodbye")):o("You are not logged in")};export{p as run,a as usage};
|
|
7
|
+
//# sourceMappingURL=logout-B3YAZN6R.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/commands/logout.ts"],
|
|
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 = (
|
|
5
|
-
"mappings": "kKAAAA,IAKO,IAAMC,EAAe,IAAMC;AAAA;AAAA;AAAA;AAAA;AAAA,EAOrBC,EAAYC,
|
|
6
|
-
"names": ["init_cjs", "usage", "sprint", "run", "
|
|
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": "kKAAAA,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"]
|
|
7
7
|
}
|
package/dist/main.js
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{a as
|
|
2
|
+
import{a as V}from"./chunk-BSCZOMV4.js";import{a as E,b as J}from"./chunk-BZSAGSV3.js";import{c as C}from"./chunk-D2K5XPNJ.js";import{d as N,e as T,f as j,g as A,i as P}from"./chunk-EFU2JNKY.js";import"./chunk-KMCOZJPU.js";import{a as v,b as L,c as F,h as w,i as c,j as x}from"./chunk-OLKWG2EP.js";import{$ as a,C as S,E as _,F as s,H as f,M as u,O,Z as l,b as h,e as m,f as b}from"./chunk-KGOVR5SK.js";import"./chunk-F3EZ4KS3.js";import"./chunk-GOBNB5VT.js";import{e as p,g as i}from"./chunk-5WC5D4WL.js";i();i();var I=p(v(),1);i();var G=p(L(),1);i();var R=p(F(),1),d=p(_(),1),y=p(v(),1),k=p(V(),1);import K from"node:assert";import M from"node:path";var z=(0,y.default)("12 hours"),H=m.object({name:m.literal("ggt"),"dist-tags":m.object({latest:m.string(),experimental:m.string()})}),q=async o=>{let t=await N({context:{ctx:o},method:"GET",url:"https://registry.npmjs.org/ggt",responseType:"json",resolveBodyOnly:!0,timeout:{request:(0,y.default)("5s")}});return H.parse(t)["dist-tags"]},Q=async o=>{try{let t=Number(await d.default.readFile(M.join(f.cacheDir,"last-update-check"),"utf8"));return K(!Number.isNaN(t)),(0,R.default)().isAfter(t+z)}catch(t){return o.log.trace("failed to check for updates",{error:t}),!0}},B=async o=>{try{if(!await Q(o))return;await d.default.outputFile(M.join(f.cacheDir,"last-update-check"),String(Date.now()));let e=await q(o),r,n,g;s.version.includes("experimental")?(r=e.experimental,n=s.version!==r,g=l`
|
|
3
3
|
Update available! {red ${s.version}} → {green ${r}}
|
|
4
4
|
Run "npm install -g ${s.name}@experimental" to update.
|
|
5
|
-
`):(r=e.latest,n=
|
|
5
|
+
`):(r=e.latest,n=k.default.lt(s.version,r),g=l`
|
|
6
6
|
Update available! {red ${s.version}} → {green ${r}}
|
|
7
7
|
Changelog: https://github.com/gadget-inc/ggt/releases/tag/v${r}
|
|
8
8
|
Run "npm install -g ${s.name}" to update.
|
|
9
|
-
`),n&&(o.log.info("update available",{current:s.version,latest:r}),a(
|
|
9
|
+
`),n&&(o.log.info("update available",{current:s.version,latest:r}),a(O(g,{padding:1,borderStyle:"round",textAlignment:"center"})))}catch(t){o.log.error("failed to check for updates",{error:t})}};var Y={"-h":{type:Boolean},"--help":{type:Boolean},"--verbose":{type:G.default.COUNT,alias:["-v","--debug"]},"--telemetry":{type:Boolean},"--json":{type:Boolean}},W=()=>l`
|
|
10
10
|
The command-line interface for Gadget.
|
|
11
11
|
|
|
12
12
|
{gray Usage}
|
|
@@ -32,14 +32,12 @@ import{a as F}from"./chunk-BSCZOMV4.js";import{a as C,b as T,c as j}from"./chunk
|
|
|
32
32
|
--telemetry Enable telemetry
|
|
33
33
|
|
|
34
34
|
Run "ggt [COMMAND] -h" for more information about a specific command.
|
|
35
|
-
`,
|
|
35
|
+
`,U=async o=>{let t=o.child({name:"root",parse:Y,argv:process.argv.slice(2),permissive:!0});t.args["--json"]&&(process.env.GGT_LOG_FORMAT="json"),t.args["--verbose"]&&(process.env.GGT_LOG_LEVEL=S(t.args["--verbose"]).toString()),await B(t);let e=t.args._.shift();if(b(e)&&(a(W(t)),process.exit(0)),e==="sync"&&(t.log.debug('renaming "sync" to "dev" for backwards compatibility'),e="dev"),!j(e)){let[n]=C(e,T);a`
|
|
36
36
|
Unknown command {yellow ${e}}
|
|
37
37
|
|
|
38
38
|
Did you mean {blueBright ${n}}?
|
|
39
39
|
|
|
40
40
|
Run {gray ggt --help} for usage
|
|
41
|
-
`,process.exit(1)}let r=await
|
|
42
|
-
`),E?.clear(),
|
|
43
|
-
Stopping {gray Press Ctrl+C again to force}
|
|
44
|
-
`;try{o.abort(),await o.done,r.succeed("Goodbye!")}catch(n){r.fail(),await c(o,n)}});await G(o)}catch(t){await c(o,t)}};await k();
|
|
41
|
+
`,process.exit(1)}let r=await A(e);P(t,e),(t.args["-h"]??t.args["--help"])&&(a(r.usage(t)),process.exit(0));try{await r.run(t.child({name:e,parse:r.args}))}catch(n){await c(t,n)}};i();var Z=function(){return String(this)},tt=function(){return Object.fromEntries(this)},ot=function(){return Array.from(this)},D=()=>{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 $=async(o=w.init({name:"ggt"}))=>{D(),await x(o);try{let t=!1;for(let e of["SIGINT","SIGTERM"])process.on(e,async()=>{if(t)return;t=!0,o.log.trace("received signal",{signal:e}),setTimeout(()=>{process.once(e,()=>{a(" Exiting immediately"),process.exit(1)})},(0,I.default)("100ms")).unref(),u.writeStdout(`
|
|
42
|
+
`),E?.clear(),u.persistFooter();let r=J({successSymbol:"\u{1F44B}",content:`Stopping ${h.gray("Press Ctrl+C again to force")}`});try{o.abort(),await o.done,r.succeed("Goodbye!")}catch(n){r.fail(),await c(o,n)}});await U(o)}catch(t){await c(o,t)}};await $();
|
|
45
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 ms from \"ms\";\nimport * as root from \"./commands/root.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 installJsonExtensions();\n await installErrorHandlers(ctx);\n\n try {\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({ successSymbol: \"\uD83D\uDC4B\" })`\n Stopping {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 await root.run(ctx);\n } catch (error) {\n await reportErrorAndExit(ctx, error);\n }\n};\n", "import arg from \"arg\";\nimport type { EmptyObject } from \"type-fest\";\nimport type { ArgsDefinition } 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;\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<EmptyObject, EmptyObject> = async (parent): Promise<void> => {\n const ctx = parent.child({\n name: \"root\",\n parse: args,\n argv: process.argv.slice(2),\n permissive: true,\n });\n\n if (ctx.args[\"--json\"]) {\n process.env[\"GGT_LOG_FORMAT\"] = \"json\";\n }\n\n if (ctx.args[\"--verbose\"]) {\n process.env[\"GGT_LOG_LEVEL\"] = verbosityToLevel(ctx.args[\"--verbose\"]).toString();\n }\n\n await warnIfUpdateAvailable(ctx);\n\n let cmd = ctx.args._.shift();\n if (isNil(cmd)) {\n println(usage(ctx));\n process.exit(0);\n }\n\n if (cmd === \"sync\") {\n ctx.log.debug('renaming \"sync\" to \"dev\" for backwards compatibility');\n cmd = \"dev\";\n }\n\n if (!isCommand(cmd)) {\n const [closest] = sortBySimilar(cmd, Commands);\n println`\n Unknown command {yellow ${cmd}}\n\n Did you mean {blueBright ${closest}}?\n\n Run {gray ggt --help} for usage\n `;\n process.exit(1);\n }\n\n const subcommand = await importCommand(cmd);\n\n if (ctx.args[\"-h\"] ?? ctx.args[\"--help\"]) {\n println(subcommand.usage(ctx));\n process.exit(0);\n }\n\n try {\n await subcommand.run(ctx.child({ command: cmd, name: cmd, parse: subcommand.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 (): 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 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();\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": ";
|
|
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", "warnIfUpdateAvailable", "tags", "latest", "updateAvailable", "updateMessage", "packageJson", "sprint", "semver", "println", "boxen", "
|
|
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 { 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 installJsonExtensions();\n await installErrorHandlers(ctx);\n\n try {\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 await root.run(ctx);\n } catch (error) {\n await reportErrorAndExit(ctx, error);\n }\n};\n", "import arg from \"arg\";\nimport type { EmptyObject } from \"type-fest\";\nimport type { ArgsDefinition } from \"../services/command/arg.js\";\nimport { Commands, importCommand, isCommand, setCurrentCommand, 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;\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<EmptyObject, EmptyObject> = async (parent): Promise<void> => {\n const ctx = parent.child({\n name: \"root\",\n parse: args,\n argv: process.argv.slice(2),\n permissive: true,\n });\n\n if (ctx.args[\"--json\"]) {\n process.env[\"GGT_LOG_FORMAT\"] = \"json\";\n }\n\n if (ctx.args[\"--verbose\"]) {\n process.env[\"GGT_LOG_LEVEL\"] = verbosityToLevel(ctx.args[\"--verbose\"]).toString();\n }\n\n await warnIfUpdateAvailable(ctx);\n\n let commandName = ctx.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 setCurrentCommand(ctx, commandName);\n\n if (ctx.args[\"-h\"] ?? ctx.args[\"--help\"]) {\n println(command.usage(ctx));\n process.exit(0);\n }\n\n try {\n await command.run(ctx.child({ name: commandName, parse: command.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": ";0fAAAA,ICAAC,IACA,IAAAC,EAAe,SCDfC,IAAA,IAAAC,EAAgB,SCAhBC,IACA,IAAAC,EAAkB,SAClBC,EAAe,SACfC,EAAe,SAGfC,EAAmB,SAFnB,OAAOC,MAAY,cACnB,OAAOC,MAAU,YAUjB,IAAMC,KAAyB,EAAAC,SAAG,UAAU,EAEtCC,EAAWC,EAAE,OAAO,CACxB,KAAMA,EAAE,QAAQ,KAAK,EACrB,YAAaA,EAAE,OAAO,CACpB,OAAQA,EAAE,OAAO,EACjB,aAAcA,EAAE,OAAO,CACzB,CAAC,CACH,CAAC,EAIYC,EAAc,MAAOC,GAAiD,CACjF,IAAMC,EAAO,MAAMC,EAAK,CACtB,QAAS,CAAE,IAAAF,CAAI,EACf,OAAQ,MACR,IAAK,iCACL,aAAc,OACd,gBAAiB,GACjB,QAAS,CACP,WAAS,EAAAJ,SAAG,IAAI,CAClB,CACF,CAAC,EAED,OAAOC,EAAS,MAAMI,CAAI,EAAE,WAAW,CACzC,EAEaE,EAAuB,MAAOH,GAAmC,CAC5E,GAAI,CACF,IAAMI,EAAY,OAAO,MAAM,EAAAC,QAAG,SAASC,EAAK,KAAKC,EAAO,SAAU,mBAAmB,EAAG,MAAM,CAAC,EACnG,OAAAC,EAAO,CAAC,OAAO,MAAMJ,CAAS,CAAC,KACxB,EAAAK,SAAM,EAAE,QAAQL,EAAYT,CAAsB,CAC3D,OAASe,EAAO,CACd,OAAAV,EAAI,IAAI,MAAM,8BAA+B,CAAE,MAAAU,CAAM,CAAC,EAC/C,EACT,CACF,EASaC,EAAwB,MAAOX,GAAgC,CAC1E,GAAI,CAEF,GAAI,CADgB,MAAMG,EAAqBH,CAAG,EAEhD,OAGF,MAAM,EAAAK,QAAG,WAAWC,EAAK,KAAKC,EAAO,SAAU,mBAAmB,EAAG,OAAO,KAAK,IAAI,CAAC,CAAC,EAEvF,IAAMK,EAAO,MAAMb,EAAYC,CAAG,EAE9Ba,EACAC,EACAC,EAEAC,EAAY,QAAQ,SAAS,cAAc,GAE7CH,EAASD,EAAK,aACdE,EAAkBE,EAAY,UAAYH,EAC1CE,EAAgBE;AAAA,iCACWD,EAAY,OAAO,cAAcH,CAAM;AAAA,8BAC1CG,EAAY,IAAI;AAAA,UAIxCH,EAASD,EAAK,OACdE,EAAkB,EAAAI,QAAO,GAAGF,EAAY,QAASH,CAAM,EACvDE,EAAgBE;AAAA,iCACWD,EAAY,OAAO,cAAcH,CAAM;AAAA,qEACHA,CAAM;AAAA,8BAC7CG,EAAY,IAAI;AAAA,SAItCF,IACFd,EAAI,IAAI,KAAK,mBAAoB,CAAE,QAASgB,EAAY,QAAS,OAAAH,CAAO,CAAC,EACzEM,EACEC,EAAML,EAAe,CACnB,QAAS,EACT,YAAa,QACb,cAAe,QACjB,CAAC,CACH,EAEJ,OAASL,EAAO,CACdV,EAAI,IAAI,MAAM,8BAA+B,CAAE,MAAAU,CAAM,CAAC,CACxD,CACF,ED7FO,IAAMW,EAAO,CAClB,KAAM,CAAE,KAAM,OAAQ,EACtB,SAAU,CAAE,KAAM,OAAQ,EAC1B,YAAa,CAAE,KAAM,EAAAC,QAAI,MAAO,MAAO,CAAC,KAAM,SAAS,CAAE,EACzD,cAAe,CAAE,KAAM,OAAQ,EAC/B,SAAU,CAAE,KAAM,OAAQ,CAC5B,EAEaC,EAAe,IACnBC;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,IA6BIC,EAAqC,MAAOC,GAA0B,CACjF,IAAMC,EAAMD,EAAO,MAAM,CACvB,KAAM,OACN,MAAOL,EACP,KAAM,QAAQ,KAAK,MAAM,CAAC,EAC1B,WAAY,EACd,CAAC,EAEGM,EAAI,KAAK,QAAQ,IACnB,QAAQ,IAAI,eAAoB,QAG9BA,EAAI,KAAK,WAAW,IACtB,QAAQ,IAAI,cAAmBC,EAAiBD,EAAI,KAAK,WAAW,CAAC,EAAE,SAAS,GAGlF,MAAME,EAAsBF,CAAG,EAE/B,IAAIG,EAAcH,EAAI,KAAK,EAAE,MAAM,EAWnC,GAVII,EAAMD,CAAW,IACnBE,EAAQT,EAAMI,CAAG,CAAC,EAClB,QAAQ,KAAK,CAAC,GAGZG,IAAgB,SAClBH,EAAI,IAAI,MAAM,sDAAsD,EACpEG,EAAc,OAGZ,CAACG,EAAUH,CAAW,EAAG,CAC3B,GAAM,CAACI,CAAO,EAAIC,EAAcL,EAAaM,CAAQ,EACrDJ;AAAA,gCAC4BF,CAAW;AAAA;AAAA,iCAEVI,CAAO;AAAA;AAAA;AAAA,MAIpC,QAAQ,KAAK,CAAC,CAChB,CAEA,IAAMG,EAAU,MAAMC,EAAcR,CAAW,EAC/CS,EAAkBZ,EAAKG,CAAW,GAE9BH,EAAI,KAAK,IAAI,GAAKA,EAAI,KAAK,QAAQ,KACrCK,EAAQK,EAAQ,MAAMV,CAAG,CAAC,EAC1B,QAAQ,KAAK,CAAC,GAGhB,GAAI,CACF,MAAMU,EAAQ,IAAIV,EAAI,MAAM,CAAE,KAAMG,EAAa,MAAOO,EAAQ,IAAK,CAAC,CAAC,CACzE,OAASG,EAAO,CACd,MAAMC,EAAmBd,EAAKa,CAAK,CACrC,CACF,EE1GAE,IAgBA,IAAMC,EAAe,UAAgC,CACnD,OAAO,OAAO,IAAI,CACpB,EAEMC,GAAY,UAAoD,CACpE,OAAO,OAAO,YAAY,IAAI,CAChC,EAEMC,GAAY,UAAgC,CAChD,OAAO,MAAM,KAAK,IAAI,CACxB,EAEaC,EAAwB,IAAY,CAC1C,OAAO,UAAU,eAAe,KAAK,OAAQ,QAAQ,IACxD,OAAO,UAAU,OAASH,GAGvB,OAAO,UAAU,eAAe,KAAK,IAAK,QAAQ,IACrD,IAAI,UAAU,OAASC,IAGpB,OAAO,UAAU,eAAe,KAAK,IAAK,QAAQ,IACrD,IAAI,UAAU,OAASC,GAE3B,EH9BO,IAAME,EAAM,MAAOC,EAAMC,EAAQ,KAAK,CAAE,KAAM,KAAM,CAAC,IAAqB,CAC/EC,EAAsB,EACtB,MAAMC,EAAqBH,CAAG,EAE9B,GAAI,CACF,IAAII,EAAW,GAEf,QAAWC,IAAU,CAAC,SAAU,SAAS,EAEvC,QAAQ,GAAGA,EAAQ,SAAY,CAC7B,GAAID,EACF,OAGFA,EAAW,GACXJ,EAAI,IAAI,MAAM,kBAAmB,CAAE,OAAAK,CAAO,CAAC,EAE3C,WAAW,IAAM,CAKf,QAAQ,KAAKA,EAAQ,IAAM,CACzBC,EAAQ,sBAAsB,EAC9B,QAAQ,KAAK,CAAC,CAChB,CAAC,CACH,KAAG,EAAAC,SAAG,OAAO,CAAC,EAAE,MAAM,EAGtBC,EAAO,YAAY;AAAA,CAAI,EAGvBC,GAAe,MAAM,EACrBD,EAAO,cAAc,EAErB,IAAME,EAAUC,EAAK,CACnB,cAAe,YACf,QAAS,YAAYC,EAAM,KAAK,6BAA6B,CAAC,EAChE,CAAC,EAED,GAAI,CACFZ,EAAI,MAAM,EACV,MAAMA,EAAI,KACVU,EAAQ,QAAQ,UAAU,CAC5B,OAASG,EAAO,CACdH,EAAQ,KAAK,EACb,MAAMI,EAAmBd,EAAKa,CAAK,CACrC,CACF,CAAC,EAGH,MAAWE,EAAIf,CAAG,CACpB,OAASa,EAAO,CACd,MAAMC,EAAmBd,EAAKa,CAAK,CACrC,CACF,ED7DA,MAAMG,EAAI",
|
|
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", "setCurrentCommand", "error", "reportErrorAndExit", "init_cjs", "bigintToJSON", "mapToJSON", "setToJSON", "installJsonExtensions", "ggt", "ctx", "Context", "installJsonExtensions", "installErrorHandlers", "stopping", "signal", "println", "ms", "output", "activeSpinner", "spinner", "spin", "source_default", "error", "reportErrorAndExit", "run", "ggt"]
|
|
7
7
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{g as y,l as f,m as u,n as $,o as v}from"./chunk-
|
|
1
|
+
import{g as y,l as f,m as u,n as $,o as v}from"./chunk-CXYA3RFX.js";import{h as w}from"./chunk-AB4I3BMD.js";import{c as g}from"./chunk-D2K5XPNJ.js";import"./chunk-M4PNFOA5.js";import"./chunk-3Q3GPB6Z.js";import{a as r}from"./chunk-6FBP46EB.js";import"./chunk-EFU2JNKY.js";import"./chunk-KMCOZJPU.js";import{g as p}from"./chunk-OLKWG2EP.js";import{$ as i,Z as t,n as h}from"./chunk-KGOVR5SK.js";import"./chunk-F3EZ4KS3.js";import"./chunk-GOBNB5VT.js";import{g as d}from"./chunk-5WC5D4WL.js";d();var R={...u,"--show-all":{type:Boolean}},J=o=>t`
|
|
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.
|
|
@@ -54,7 +54,7 @@ import{g as y,l as f,m as u,n as $,o as v}from"./chunk-RJOIQTYZ.js";import{g as
|
|
|
54
54
|
Opened log viewer for environment {cyanBright ${e.env.name}}.
|
|
55
55
|
`;break}case"permissions":{await r(`https://${e.app.primaryDomain}/edit/${e.env.name}/settings/permissions`),i`
|
|
56
56
|
Opened permissions settings for environment {cyanBright ${e.env.name}}.
|
|
57
|
-
`;break}case"data":case"schema":{let n=o.args._[0],l=(await w(o)).map(m=>m.apiIdentifier),a=o.args._[1];if(!a)if(o.args["--show-all"])a=await f({choices:l
|
|
57
|
+
`;break}case"data":case"schema":{let n=o.args._[0],l=(await w(o)).map(m=>m.apiIdentifier),a=o.args._[1];if(!a)if(o.args["--show-all"])a=await f({choices:l,content:"Which model do you wish to open?"});else throw new p(t`
|
|
58
58
|
"ggt open ${n}" requires a model to be specified.
|
|
59
59
|
|
|
60
60
|
Run with "--show-all" to choose from available models.
|
|
@@ -71,4 +71,4 @@ import{g as y,l as f,m as u,n as $,o as v}from"./chunk-RJOIQTYZ.js";import{g as
|
|
|
71
71
|
`)}await r(`https://${e.app.primaryDomain}/edit/${e.env.name}/model/${a}/${n}`),i`
|
|
72
72
|
Opened ${n} viewer for environment {cyanBright ${e.env.name}} for model {cyanBright ${a}}.
|
|
73
73
|
`;break}default:h(s)}},O=["logs","permissions","data","schema"];export{R as args,j as run,J as usage};
|
|
74
|
-
//# sourceMappingURL=open-
|
|
74
|
+
//# sourceMappingURL=open-OVK3YL4O.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/commands/open.ts"],
|
|
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) => {\n const directory = await loadSyncJsonDirectory(process.cwd());\n const syncJson = await SyncJson.load(ctx, { directory });\n if (!syncJson) {\n throw new UnknownDirectoryError(ctx, { directory });\n }\n\n const location = ctx.args._[0] as Location | undefined;\n if (!location) {\n await open(`https://${syncJson.app.primaryDomain}/edit/${syncJson.env.name}`);\n println`\n Opened editor for environment {cyanBright ${syncJson.env.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.app.primaryDomain}/edit/${syncJson.env.name}/logs`);\n println`\n Opened log viewer for environment {cyanBright ${syncJson.env.name}}.\n `;\n break;\n }\n case \"permissions\": {\n await open(`https://${syncJson.app.primaryDomain}/edit/${syncJson.env.name}/settings/permissions`);\n println`\n Opened permissions settings for environment {cyanBright ${syncJson.env.name}}.\n `;\n break;\n }\n case \"data\":\n case \"schema\": {\n const view = ctx.args._[0];\n const remoteModelApiIdentifiers = (await getModels(ctx)).map((e) => e.apiIdentifier);\n\n let modelApiIdentifier = ctx.args._[1];\n if (!modelApiIdentifier) {\n if (ctx.args[\"--show-all\"]) {\n modelApiIdentifier = await select({ choices: remoteModelApiIdentifiers
|
|
5
|
-
"mappings": "
|
|
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) => {\n const directory = await loadSyncJsonDirectory(process.cwd());\n const syncJson = await SyncJson.load(ctx, { directory });\n if (!syncJson) {\n throw new UnknownDirectoryError(ctx, { directory });\n }\n\n const location = ctx.args._[0] as Location | undefined;\n if (!location) {\n await open(`https://${syncJson.app.primaryDomain}/edit/${syncJson.env.name}`);\n println`\n Opened editor for environment {cyanBright ${syncJson.env.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.app.primaryDomain}/edit/${syncJson.env.name}/logs`);\n println`\n Opened log viewer for environment {cyanBright ${syncJson.env.name}}.\n `;\n break;\n }\n case \"permissions\": {\n await open(`https://${syncJson.app.primaryDomain}/edit/${syncJson.env.name}/settings/permissions`);\n println`\n Opened permissions settings for environment {cyanBright ${syncJson.env.name}}.\n `;\n break;\n }\n case \"data\":\n case \"schema\": {\n const view = ctx.args._[0];\n const remoteModelApiIdentifiers = (await getModels(ctx)).map((e) => e.apiIdentifier);\n\n let modelApiIdentifier = ctx.args._[1];\n if (!modelApiIdentifier) {\n if (ctx.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(`https://${syncJson.app.primaryDomain}/edit/${syncJson.env.name}/model/${modelApiIdentifier}/${view}`);\n println`\n Opened ${view} viewer for environment {cyanBright ${syncJson.env.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": "0eAAAA,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,GAAQ,CAC/C,IAAMC,EAAY,MAAMC,EAAsB,QAAQ,IAAI,CAAC,EACrDC,EAAW,MAAMC,EAAS,KAAKJ,EAAK,CAAE,UAAAC,CAAU,CAAC,EACvD,GAAI,CAACE,EACH,MAAM,IAAIE,EAAsBL,EAAK,CAAE,UAAAC,CAAU,CAAC,EAGpD,IAAMK,EAAWN,EAAI,KAAK,EAAE,CAAC,EAC7B,GAAI,CAACM,EAAU,CACb,MAAMC,EAAK,WAAWJ,EAAS,IAAI,aAAa,SAASA,EAAS,IAAI,IAAI,EAAE,EAC5EK;AAAA,kDAC8CL,EAAS,IAAI,IAAI;AAAA,MAE/D,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,IAAI,aAAa,SAASA,EAAS,IAAI,IAAI,OAAO,EACjFK;AAAA,wDACkDL,EAAS,IAAI,IAAI;AAAA,QAEnE,KACF,CACA,IAAK,cAAe,CAClB,MAAMI,EAAK,WAAWJ,EAAS,IAAI,aAAa,SAASA,EAAS,IAAI,IAAI,uBAAuB,EACjGK;AAAA,kEAC4DL,EAAS,IAAI,IAAI;AAAA,QAE7E,KACF,CACA,IAAK,OACL,IAAK,SAAU,CACb,IAAMU,EAAOb,EAAI,KAAK,EAAE,CAAC,EACnBc,GAA6B,MAAMC,EAAUf,CAAG,GAAG,IAAKgB,GAAMA,EAAE,aAAa,EAE/EC,EAAqBjB,EAAI,KAAK,EAAE,CAAC,EACrC,GAAI,CAACiB,EACH,GAAIjB,EAAI,KAAK,YAAY,EACvBiB,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,EAAK,WAAWJ,EAAS,IAAI,aAAa,SAASA,EAAS,IAAI,IAAI,UAAUc,CAAkB,IAAIJ,CAAI,EAAE,EAChHL;AAAA,iBACWK,CAAI,uCAAuCV,EAAS,IAAI,IAAI,2BAA2Bc,CAAkB;AAAA,QAEpH,KACF,CACA,QACEE,EAAQb,CAAQ,CACpB,CACF,EAEMG,EAAY,CAAC,OAAQ,cAAe,OAAQ,QAAQ",
|
|
6
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"]
|
|
7
7
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{
|
|
1
|
+
import{o as g}from"./chunk-DVKNBG4P.js";import{m as i,n as l,o as c}from"./chunk-CXYA3RFX.js";import"./chunk-THZRTDWW.js";import"./chunk-AB4I3BMD.js";import"./chunk-BZSAGSV3.js";import"./chunk-D2K5XPNJ.js";import"./chunk-M4PNFOA5.js";import"./chunk-3Q3GPB6Z.js";import"./chunk-6FBP46EB.js";import"./chunk-EFU2JNKY.js";import"./chunk-KMCOZJPU.js";import{g as a}from"./chunk-OLKWG2EP.js";import{$ as s,Z as t}from"./chunk-KGOVR5SK.js";import"./chunk-F3EZ4KS3.js";import"./chunk-GOBNB5VT.js";import{g as r}from"./chunk-5WC5D4WL.js";r();var v={...i,"--force":{type:Boolean,alias:"-f"}},w=e=>t`
|
|
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
|
|
@@ -24,7 +24,5 @@ import{m as g}from"./chunk-P2XPMNL6.js";import{m as i,n as l,o as c}from"./chunk
|
|
|
24
24
|
you must "cd" to that directory and then run "ggt push".
|
|
25
25
|
|
|
26
26
|
Run "ggt pull -h" for more information.
|
|
27
|
-
`);let p=await c(process.cwd()),y=await l.loadOrInit(e,{directory:p}),o=new g(y),n=await o.hashes(e);if(n.environmentChangesToPull.size===0){s({ensureEmptyLineAbove:!0})
|
|
28
|
-
|
|
29
|
-
`;return}n.localChangesToPush.size>0&&await o.print(e,{hashes:n}),await o.pull(e,{hashes:n})};export{v as args,P as run,w as usage};
|
|
30
|
-
//# sourceMappingURL=pull-T2Q4M4UN.js.map
|
|
27
|
+
`);let p=await c(process.cwd()),y=await l.loadOrInit(e,{directory:p}),o=new g(y),n=await o.hashes(e);if(n.environmentChangesToPull.size===0){s({ensureEmptyLineAbove:!0,content:"Nothing to pull."});return}n.localChangesToPush.size>0&&await o.print(e,{hashes:n}),await o.pull(e,{hashes:n})};export{v as args,P as run,w as usage};
|
|
28
|
+
//# sourceMappingURL=pull-SLPBOP6Z.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
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 \"--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 --from, -e, --env <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) => {\n if (ctx.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 push\".\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, { 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
|
|
5
|
-
"mappings": "
|
|
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 \"--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 --from, -e, --env <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) => {\n if (ctx.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 push\".\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, { 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 });\n};\n"],
|
|
5
|
+
"mappings": "ihBAAAA,IASO,IAAMC,EAAO,CAClB,GAAGC,EACH,UAAW,CAAE,KAAM,QAAS,MAAO,IAAK,CAC1C,EAEaC,EAAgBC,GACpBC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAsBIC,EAAqB,MAAOC,GAAQ,CAC/C,GAAIA,EAAI,KAAK,EAAE,OAAS,EACtB,MAAM,IAAIC,EAASH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,KAOlB,EAGH,IAAMI,EAAY,MAAMC,EAAsB,QAAQ,IAAI,CAAC,EACrDC,EAAW,MAAMC,EAAS,WAAWL,EAAK,CAAE,UAAAE,CAAU,CAAC,EACvDI,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,CAAO,CAAC,CACrC",
|
|
6
6
|
"names": ["init_cjs", "args", "SyncJsonArgs", "usage", "_ctx", "sprint", "run", "ctx", "ArgError", "directory", "loadSyncJsonDirectory", "syncJson", "SyncJson", "filesync", "FileSync", "hashes", "println"]
|
|
7
7
|
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{a,b,c}from"./chunk-BYMG3KOL.js";import"./chunk-DVKNBG4P.js";import"./chunk-CXYA3RFX.js";import"./chunk-THZRTDWW.js";import"./chunk-AB4I3BMD.js";import"./chunk-BZSAGSV3.js";import"./chunk-D2K5XPNJ.js";import"./chunk-M4PNFOA5.js";import"./chunk-3Q3GPB6Z.js";import"./chunk-6FBP46EB.js";import"./chunk-EFU2JNKY.js";import"./chunk-KMCOZJPU.js";import"./chunk-OLKWG2EP.js";import"./chunk-KGOVR5SK.js";import"./chunk-F3EZ4KS3.js";import"./chunk-GOBNB5VT.js";import"./chunk-5WC5D4WL.js";export{a as args,c as run,b as usage};
|
|
2
|
+
//# sourceMappingURL=push-3HGVWCKW.js.map
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import{k as m,l as p,o as h}from"./chunk-DVKNBG4P.js";import{g,m as f,n as y,o as u}from"./chunk-CXYA3RFX.js";import"./chunk-THZRTDWW.js";import"./chunk-AB4I3BMD.js";import"./chunk-BZSAGSV3.js";import"./chunk-D2K5XPNJ.js";import"./chunk-M4PNFOA5.js";import"./chunk-3Q3GPB6Z.js";import"./chunk-6FBP46EB.js";import"./chunk-EFU2JNKY.js";import"./chunk-KMCOZJPU.js";import{g as c}from"./chunk-OLKWG2EP.js";import{Z as r}from"./chunk-KGOVR5SK.js";import"./chunk-F3EZ4KS3.js";import"./chunk-GOBNB5VT.js";import{g as i}from"./chunk-5WC5D4WL.js";i();var A=f,J=()=>r`
|
|
2
|
+
Shows file changes since last sync (e.g. $ggt dev, push, deploy etc.)
|
|
3
|
+
|
|
4
|
+
{gray Usage}
|
|
5
|
+
ggt status
|
|
6
|
+
`,U=async t=>{if(t.args._.length>0)throw new c(r`
|
|
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 e=await u(process.cwd()),o=await y.load(t,{directory:e});if(!o)throw new g(t,{directory:e});o.print();let a=new h(o),s=await a.hashes(t);await a.print(t,{hashes:s});let n=m({localChanges:s.localChanges,environmentChanges:s.environmentChanges});n.size>0&&(t.log.debug("conflicts detected",{conflicts:n}),p({conflicts:n}))};export{A as args,U as run,J as usage};
|
|
14
|
+
//# sourceMappingURL=status-7GLNL7D5.js.map
|
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/commands/status.ts"],
|
|
4
4
|
"sourcesContent": ["import { ArgError } 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;\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) => {\n if (ctx.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, { directory });\n if (!syncJson) {\n throw new UnknownDirectoryError(ctx, { 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": "
|
|
5
|
+
"mappings": "0hBAAAA,IAUO,IAAMC,EAAOC,EAEPC,EAAe,IACnBC;AAAA;AAAA;AAAA;AAAA;AAAA,IAQIC,EAAuB,MAAOC,GAAQ,CACjD,GAAIA,EAAI,KAAK,EAAE,OAAS,EACtB,MAAM,IAAIC,EAASH;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,KAOlB,EAGH,IAAMI,EAAY,MAAMC,EAAsB,QAAQ,IAAI,CAAC,EACrDC,EAAW,MAAMC,EAAS,KAAKL,EAAK,CAAE,UAAAE,CAAU,CAAC,EACvD,GAAI,CAACE,EACH,MAAM,IAAIE,EAAsBN,EAAK,CAAE,UAAAE,CAAU,CAAC,EAGpDE,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
6
|
"names": ["init_cjs", "args", "SyncJsonArgs", "usage", "sprint", "run", "ctx", "ArgError", "directory", "loadSyncJsonDirectory", "syncJson", "SyncJson", "UnknownDirectoryError", "filesync", "FileSync", "hashes", "conflicts", "getConflicts", "printConflicts"]
|
|
7
7
|
}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{h as a,i as b,j as c,k as d,l as e}from"./chunk-6FBP46EB.js";import"./chunk-EFU2JNKY.js";import"./chunk-KMCOZJPU.js";import"./chunk-OLKWG2EP.js";import"./chunk-KGOVR5SK.js";import"./chunk-F3EZ4KS3.js";import"./chunk-GOBNB5VT.js";import"./chunk-5WC5D4WL.js";export{b as getCurrentUser,d as getUser,e as getUserOrLogin,a as maybeGetCurrentUser,c as setCurrentUser};
|
|
2
|
+
//# sourceMappingURL=user-C34J52UL.js.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{
|
|
1
|
+
import{$ as o,F as e,Z as n}from"./chunk-KGOVR5SK.js";import"./chunk-GOBNB5VT.js";import{g as t}from"./chunk-5WC5D4WL.js";t();var i=()=>n`
|
|
2
2
|
Print this version of ggt.
|
|
3
3
|
|
|
4
4
|
{gray Usage}
|
|
@@ -8,4 +8,4 @@ import{G as e,U as n,W as o}from"./chunk-GBCD37US.js";import"./chunk-GOBNB5VT.js
|
|
|
8
8
|
When there is a new release of ggt, running ggt will show you a message letting you
|
|
9
9
|
know that an update is available.
|
|
10
10
|
`,m=r=>{o(e.version)};export{m as run,i as usage};
|
|
11
|
-
//# sourceMappingURL=version-
|
|
11
|
+
//# sourceMappingURL=version-AUI4NRDS.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import{k as n}from"./chunk-6FBP46EB.js";import"./chunk-EFU2JNKY.js";import"./chunk-KMCOZJPU.js";import"./chunk-OLKWG2EP.js";import{$ as o,Z as a}from"./chunk-KGOVR5SK.js";import"./chunk-F3EZ4KS3.js";import"./chunk-GOBNB5VT.js";import{g as r}from"./chunk-5WC5D4WL.js";r();var g=()=>a`
|
|
2
|
+
Show the name and email address of the currently logged in user.
|
|
3
|
+
|
|
4
|
+
{gray Usage}
|
|
5
|
+
ggt whoami
|
|
6
|
+
`,u=async s=>{let e=await n(s);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}`)};export{u as run,g as usage};
|
|
7
|
+
//# sourceMappingURL=whoami-TXO7VJXC.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/commands/whoami.ts"],
|
|
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
|
|
5
|
-
"mappings": "
|
|
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": "2QAAAA,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
6
|
"names": ["init_cjs", "usage", "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.0
|
|
3
|
+
"version": "1.2.0",
|
|
4
4
|
"description": "The command-line interface for Gadget",
|
|
5
5
|
"homepage": "https://github.com/gadget-inc/ggt",
|
|
6
6
|
"bugs": {
|
|
@@ -27,29 +27,29 @@
|
|
|
27
27
|
"/README.md"
|
|
28
28
|
],
|
|
29
29
|
"devDependencies": {
|
|
30
|
-
"@changesets/cli": "^2.27.
|
|
30
|
+
"@changesets/cli": "^2.27.8",
|
|
31
31
|
"@graphql-codegen/add": "^5.0.3",
|
|
32
32
|
"@graphql-codegen/cli": "^5.0.2",
|
|
33
33
|
"@graphql-codegen/typescript": "^4.0.9",
|
|
34
34
|
"@graphql-codegen/typescript-operations": "^4.2.3",
|
|
35
|
-
"@sentry/node": "^8.
|
|
35
|
+
"@sentry/node": "^8.28.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.
|
|
40
|
+
"@types/node": "^18.19.49",
|
|
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.
|
|
48
|
-
"@typescript-eslint/eslint-plugin": "^
|
|
49
|
-
"@typescript-eslint/parser": "^
|
|
47
|
+
"@types/ws": "^8.5.12",
|
|
48
|
+
"@typescript-eslint/eslint-plugin": "^8.4.0",
|
|
49
|
+
"@typescript-eslint/parser": "^8.4.0",
|
|
50
50
|
"ansi-escapes": "^7.0.0",
|
|
51
51
|
"arg": "^5.0.2",
|
|
52
|
-
"boxen": "^8.0.
|
|
52
|
+
"boxen": "^8.0.1",
|
|
53
53
|
"chalk": "^5.3.0",
|
|
54
54
|
"chalk-template": "^1.1.0",
|
|
55
55
|
"clean-stack": "^5.2.0",
|
|
@@ -57,14 +57,14 @@
|
|
|
57
57
|
"cli-spinners": "^2.9.2",
|
|
58
58
|
"cli-table3": "^0.6.5",
|
|
59
59
|
"concurrently": "^8.2.2",
|
|
60
|
-
"cspell": "^8.
|
|
61
|
-
"dayjs": "^1.11.
|
|
62
|
-
"esbuild": "^0.23.
|
|
60
|
+
"cspell": "^8.14.2",
|
|
61
|
+
"dayjs": "^1.11.13",
|
|
62
|
+
"esbuild": "^0.23.1",
|
|
63
63
|
"eslint": "^8.57.0",
|
|
64
64
|
"eslint-config-prettier": "^9.1.0",
|
|
65
|
-
"eslint-import-resolver-typescript": "^3.6.
|
|
66
|
-
"eslint-plugin-import": "^2.
|
|
67
|
-
"eslint-plugin-jsdoc": "^
|
|
65
|
+
"eslint-import-resolver-typescript": "^3.6.3",
|
|
66
|
+
"eslint-plugin-import": "^2.30.0",
|
|
67
|
+
"eslint-plugin-jsdoc": "^50.2.2",
|
|
68
68
|
"eslint-plugin-only-warn": "^1.1.0",
|
|
69
69
|
"eslint-plugin-unicorn": "^55.0.0",
|
|
70
70
|
"execa": "^8.0.1",
|
|
@@ -76,14 +76,14 @@
|
|
|
76
76
|
"got": "^13.0.0",
|
|
77
77
|
"graphql": "^16.9.0",
|
|
78
78
|
"graphql-ws": "^5.16.0",
|
|
79
|
-
"ignore": "^5.3.
|
|
79
|
+
"ignore": "^5.3.2",
|
|
80
80
|
"indent-string": "^5.0.0",
|
|
81
81
|
"is-interactive": "^2.0.0",
|
|
82
82
|
"is-unicode-supported": "^2.0.0",
|
|
83
83
|
"is-wsl": "^3.1.0",
|
|
84
84
|
"mimic-function": "^5.0.1",
|
|
85
85
|
"ms": "^2.1.3",
|
|
86
|
-
"nock": "^13.5.
|
|
86
|
+
"nock": "^13.5.5",
|
|
87
87
|
"node-notifier": "^10.0.1",
|
|
88
88
|
"normalize-package-data": "^6.0.2",
|
|
89
89
|
"normalize-path": "^3.0.0",
|
|
@@ -95,23 +95,23 @@
|
|
|
95
95
|
"pluralize": "^8.0.0",
|
|
96
96
|
"prettier": "^3.3.3",
|
|
97
97
|
"prettier-plugin-organize-imports": "^4.0.0",
|
|
98
|
-
"prettier-plugin-packagejson": "^2.5.
|
|
98
|
+
"prettier-plugin-packagejson": "^2.5.2",
|
|
99
99
|
"remark": "^15.0.1",
|
|
100
100
|
"remark-gfm": "^4.0.0",
|
|
101
101
|
"remark-toc": "^9.0.0",
|
|
102
102
|
"rimraf": "^5.0.7",
|
|
103
103
|
"semver": "^7.6.3",
|
|
104
104
|
"serialize-error": "^11.0.3",
|
|
105
|
-
"simple-git": "^3.
|
|
105
|
+
"simple-git": "^3.26.0",
|
|
106
106
|
"stdin-discarder": "^0.2.2",
|
|
107
107
|
"string-width": "^7.2.0",
|
|
108
108
|
"strip-ansi": "^7.1.0",
|
|
109
109
|
"terminal-link": "^3.0.0",
|
|
110
110
|
"ts-dedent": "^2.2.0",
|
|
111
111
|
"ts-node": "^10.9.2",
|
|
112
|
-
"type-fest": "^4.
|
|
112
|
+
"type-fest": "^4.26.0",
|
|
113
113
|
"typescript": "^5.5.4",
|
|
114
|
-
"vitest": "^2.0.
|
|
114
|
+
"vitest": "^2.0.5",
|
|
115
115
|
"watcher": "^2.3.1",
|
|
116
116
|
"which": "^4.0.0",
|
|
117
117
|
"ws": "^8.18.0",
|