@gadgetinc/ggt 1.2.0 → 1.3.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 (112) hide show
  1. package/README.md +3 -0
  2. package/dist/add-VYOF3CRL.js +78 -0
  3. package/dist/add-VYOF3CRL.js.map +7 -0
  4. package/dist/{chunk-KMCOZJPU.js → chunk-3B5DKR5D.js} +2 -2
  5. package/dist/{chunk-KMCOZJPU.js.map → chunk-3B5DKR5D.js.map} +4 -4
  6. package/dist/chunk-3V7YWBUK.js +2 -0
  7. package/dist/{chunk-BSCZOMV4.js.map → chunk-3V7YWBUK.js.map} +1 -1
  8. package/dist/chunk-B6XQEEUK.js +2 -0
  9. package/dist/chunk-B6XQEEUK.js.map +7 -0
  10. package/dist/chunk-CQH5IRAO.js +50 -0
  11. package/dist/chunk-CQH5IRAO.js.map +7 -0
  12. package/dist/{chunk-THZRTDWW.js → chunk-ENT5WEIR.js} +2 -2
  13. package/dist/chunk-FQ2LR3BI.js +6 -0
  14. package/dist/chunk-FQ2LR3BI.js.map +7 -0
  15. package/dist/chunk-J5XIQ6N4.js +187 -0
  16. package/dist/chunk-J5XIQ6N4.js.map +7 -0
  17. package/dist/chunk-JU6IEBE5.js +65 -0
  18. package/dist/chunk-JU6IEBE5.js.map +7 -0
  19. package/dist/{chunk-BYMG3KOL.js → chunk-LQDBD3BI.js} +4 -4
  20. package/dist/{chunk-BYMG3KOL.js.map → chunk-LQDBD3BI.js.map} +2 -2
  21. package/dist/chunk-P5OUQ5XQ.js +2 -0
  22. package/dist/chunk-SGMPMYEU.js +2 -0
  23. package/dist/chunk-SGMPMYEU.js.map +7 -0
  24. package/dist/chunk-VE2URKOG.js +117 -0
  25. package/dist/chunk-VE2URKOG.js.map +7 -0
  26. package/dist/{chunk-BZSAGSV3.js → chunk-WBESFPTY.js} +2 -2
  27. package/dist/chunk-YQO2R55C.js +18 -0
  28. package/dist/{chunk-6FBP46EB.js.map → chunk-YQO2R55C.js.map} +3 -3
  29. package/dist/chunk-ZHG3WLFU.js +2 -0
  30. package/dist/chunk-ZHG3WLFU.js.map +7 -0
  31. package/dist/deploy-EEJCK2MG.js +25 -0
  32. package/dist/deploy-EEJCK2MG.js.map +7 -0
  33. package/dist/dev-G77WSGIC.js +58 -0
  34. package/dist/{dev-OT7PEKUN.js.map → dev-G77WSGIC.js.map} +4 -4
  35. package/dist/esm-3OYJEC4Z.js +36 -0
  36. package/dist/esm-3OYJEC4Z.js.map +7 -0
  37. package/dist/list-3AI2FD3F.js +11 -0
  38. package/dist/list-3AI2FD3F.js.map +7 -0
  39. package/dist/login-UGTNK3B3.js +2 -0
  40. package/dist/logout-CN5DL7Z2.js +7 -0
  41. package/dist/{logout-B3YAZN6R.js.map → logout-CN5DL7Z2.js.map} +1 -1
  42. package/dist/main.js +10 -10
  43. package/dist/main.js.map +3 -3
  44. package/dist/open-PM56SR6Z.js +74 -0
  45. package/dist/open-PM56SR6Z.js.map +7 -0
  46. package/dist/{pull-SLPBOP6Z.js → pull-TAW6KHZO.js} +4 -4
  47. package/dist/{pull-SLPBOP6Z.js.map → pull-TAW6KHZO.js.map} +2 -2
  48. package/dist/push-2NCJSDGS.js +2 -0
  49. package/dist/status-WDYI4EOU.js +14 -0
  50. package/dist/status-WDYI4EOU.js.map +7 -0
  51. package/dist/{version-AUI4NRDS.js → version-3FBGIVXT.js} +2 -2
  52. package/dist/{version-AUI4NRDS.js.map → version-3FBGIVXT.js.map} +1 -1
  53. package/dist/whoami-UALRX2FT.js +7 -0
  54. package/dist/{whoami-TXO7VJXC.js.map → whoami-UALRX2FT.js.map} +1 -1
  55. package/package.json +19 -18
  56. package/dist/add-DCE6CV2D.js +0 -78
  57. package/dist/add-DCE6CV2D.js.map +0 -7
  58. package/dist/build-4BGA4IZE.js +0 -3
  59. package/dist/build-4BGA4IZE.js.map +0 -7
  60. package/dist/chunk-3Q3GPB6Z.js +0 -2
  61. package/dist/chunk-3Q3GPB6Z.js.map +0 -7
  62. package/dist/chunk-57XALM2W.js +0 -2
  63. package/dist/chunk-57XALM2W.js.map +0 -7
  64. package/dist/chunk-5WC5D4WL.js +0 -2
  65. package/dist/chunk-5WC5D4WL.js.map +0 -7
  66. package/dist/chunk-6FBP46EB.js +0 -18
  67. package/dist/chunk-AB4I3BMD.js +0 -33
  68. package/dist/chunk-AB4I3BMD.js.map +0 -7
  69. package/dist/chunk-BSCZOMV4.js +0 -2
  70. package/dist/chunk-CXYA3RFX.js +0 -117
  71. package/dist/chunk-CXYA3RFX.js.map +0 -7
  72. package/dist/chunk-D2K5XPNJ.js +0 -2
  73. package/dist/chunk-D2K5XPNJ.js.map +0 -7
  74. package/dist/chunk-DVKNBG4P.js +0 -180
  75. package/dist/chunk-DVKNBG4P.js.map +0 -7
  76. package/dist/chunk-EFU2JNKY.js +0 -9
  77. package/dist/chunk-EFU2JNKY.js.map +0 -7
  78. package/dist/chunk-F3EZ4KS3.js +0 -2
  79. package/dist/chunk-F3EZ4KS3.js.map +0 -7
  80. package/dist/chunk-GOBNB5VT.js +0 -2
  81. package/dist/chunk-GOBNB5VT.js.map +0 -7
  82. package/dist/chunk-HKBXEZNF.js +0 -2
  83. package/dist/chunk-KGOVR5SK.js +0 -67
  84. package/dist/chunk-KGOVR5SK.js.map +0 -7
  85. package/dist/chunk-M4PNFOA5.js +0 -6
  86. package/dist/chunk-M4PNFOA5.js.map +0 -7
  87. package/dist/chunk-OLKWG2EP.js +0 -12
  88. package/dist/chunk-OLKWG2EP.js.map +0 -7
  89. package/dist/context-L5YSPF3X.js +0 -2
  90. package/dist/deploy-PBJEUYGH.js +0 -25
  91. package/dist/deploy-PBJEUYGH.js.map +0 -7
  92. package/dist/dev-OT7PEKUN.js +0 -55
  93. package/dist/esm-GJ7RK6IC.js +0 -34
  94. package/dist/esm-GJ7RK6IC.js.map +0 -7
  95. package/dist/list-CC5PICEF.js +0 -11
  96. package/dist/list-CC5PICEF.js.map +0 -7
  97. package/dist/login-SE7XIHRW.js +0 -2
  98. package/dist/logout-B3YAZN6R.js +0 -7
  99. package/dist/open-OVK3YL4O.js +0 -74
  100. package/dist/open-OVK3YL4O.js.map +0 -7
  101. package/dist/push-3HGVWCKW.js +0 -2
  102. package/dist/push-3HGVWCKW.js.map +0 -7
  103. package/dist/status-7GLNL7D5.js +0 -14
  104. package/dist/status-7GLNL7D5.js.map +0 -7
  105. package/dist/user-C34J52UL.js +0 -2
  106. package/dist/user-C34J52UL.js.map +0 -7
  107. package/dist/whoami-TXO7VJXC.js +0 -7
  108. /package/dist/{chunk-THZRTDWW.js.map → chunk-ENT5WEIR.js.map} +0 -0
  109. /package/dist/{chunk-HKBXEZNF.js.map → chunk-P5OUQ5XQ.js.map} +0 -0
  110. /package/dist/{chunk-BZSAGSV3.js.map → chunk-WBESFPTY.js.map} +0 -0
  111. /package/dist/{context-L5YSPF3X.js.map → login-UGTNK3B3.js.map} +0 -0
  112. /package/dist/{login-SE7XIHRW.js.map → push-2NCJSDGS.js.map} +0 -0
package/README.md CHANGED
@@ -109,6 +109,9 @@ Options
109
109
  --prefer <source> Auto-select changes from 'local' or 'environment' source on conflict
110
110
  --allow-unknown-directory Syncs to any local directory with existing files, even if the ".gadget/sync.json" file is missing
111
111
  --allow-different-app Syncs with a different app using the --app command, instead of the one specified in the .gadget/sync.json file
112
+ --log-level <level> Sets the log level for incoming application logs (default: info)
113
+ --no-logs Disables outputting application logs to the console
114
+ --my-logs Only outputs user sourced logs
112
115
 
113
116
  Ignoring files
114
117
  ggt dev uses a .ignore file, similar to .gitignore, to exclude specific files and
@@ -0,0 +1,78 @@
1
+ import{f as U,g as L,h as S,i as O,j as R,o as P}from"./chunk-J5XIQ6N4.js";import{g as F,l as j,m as M,n as N,o as k}from"./chunk-VE2URKOG.js";import"./chunk-ENT5WEIR.js";import"./chunk-WBESFPTY.js";import{c as f}from"./chunk-ZHG3WLFU.js";import"./chunk-FQ2LR3BI.js";import"./chunk-YQO2R55C.js";import{a as T,f as v,g as E,j as y,n as $,p as u,x as C,y as B}from"./chunk-CQH5IRAO.js";import"./chunk-3B5DKR5D.js";import{$ as p,Z as r,b as m,m as b}from"./chunk-JU6IEBE5.js";import"./chunk-B6XQEEUK.js";import{g as _}from"./chunk-SGMPMYEU.js";_();var h=class extends E{isBug=v.NO;constructor(t){let n="";if(b(t.cause)){let a=$(t.cause.map(e=>e.message));n=r` • ${a.map(e=>e.split(`
2
+ `).join(`
3
+ \u200E \u2022 `)).join(`
4
+ `)}`}else n=r`${t.cause}`;super(n)}render(){return`${m.redBright(y.cross)} Failed to add:
5
+ `+this.message}},ce={...M},I=()=>r`
6
+ Adds models, fields, actions and routes to your app.
7
+
8
+ This command first performs a sync to ensure that your local and environment directories match, changes are tracked since last sync.
9
+ If any conflicts are detected, they must be resolved before adding models, fields, actions or routes.
10
+
11
+ {gray Usage}
12
+ ggt add model <model_name> [field_name:field_type ...]
13
+
14
+ ggt add action [CONTEXT]/<action_name>
15
+ CONTEXT:Specifies the kind of action. Use "model" for model actions otherwise use "action".
16
+
17
+ ggt add route <HTTP_METHOD> <route_path>
18
+
19
+ ggt add field <model_path>/<field_name>:<field_type>
20
+
21
+ {gray Options}
22
+ -e, --env <env_name> Selects the environment to add to. Default set on ".gadget/sync.json"
23
+
24
+ {gray Examples}
25
+ Add a new model 'post' with out fields:
26
+ {cyanBright $ ggt add model modelA}
27
+
28
+ Add a new model 'post' with 2 new 'string' type fields 'title' and 'body':
29
+ {cyanBright $ ggt add model post title:string body:string}
30
+
31
+ Add new action 'publish' to the 'post' model:
32
+ {cyanBright ggt add action model/post/publish}
33
+
34
+ Add a new action 'audit'
35
+ {cyanBright ggt add action action/audit}
36
+
37
+ Add a new route 'howdy'
38
+ {cyanBright ggt add route GET howdy}
39
+
40
+ Add a new 'boolean' type field 'published' to an existing model
41
+ {cyanBright ggt add field post/published:boolean}
42
+ `,me=async(o,t)=>{let n=await k(process.cwd()),a=await N.load(o,{command:"add",args:t,directory:n});if(!a)throw new F({command:"add",args:t,directory:n});let e=new P(a),s=await e.hashes(o,!0);switch(s.inSync||await e.merge(o,{hashes:s,printEnvironmentChangesOptions:{limit:5},printLocalChangesOptions:{limit:5},quietly:!0}),p({ensureEmptyLineAbove:!0,content:`${m.greenBright(y.tick)} Sync completed ${R()}`}),t._[0]){case"model":await V(o,{args:t,filesync:e});break;case"action":await G(o,{args:t,filesync:e});break;case"route":await H(o,{args:t,filesync:e});break;case"field":await X(o,{args:t,filesync:e});break;default:p(I(o));return}},J=o=>{let t=[],n=[];return o.forEach(a=>{let e=/^(.*):+(.*)$/.exec(a);!e||e.length!==3||!e[1]||!e[2]?t.push(r`${a} is not a valid field definition`):n.push({name:e[1].replace(/:+/g,""),fieldType:e[2]})}),[n,t]},V=async(o,{args:t,filesync:n})=>{let a=n.syncJson,e=t._[1];if(!e)throw new f(r`Failed to add model, missing model path
43
+
44
+ {gray Usage}
45
+ {cyanBright ggt add model <model_name> [field_name:field_type ...]}`);let s=[];if(t._.length>2){let[c,g]=J(t._.slice(2));if(g.length>0)throw new f(r`
46
+ Failed to add model:
47
+ • ${g.join(`
48
+ \u2022 `)}
49
+
50
+ {gray Usage}
51
+ {cyanBright ggt add model ${e} [field_name:field_type ...]}`);s.push(...c)}let i;try{i=(await a.edit.mutate({mutation:U,variables:{path:e,fields:s.map(c=>({name:c.name,fieldType:c.fieldType}))}})).createModel}catch(c){throw c instanceof u?new h(c):c}p({ensureEmptyLineAbove:!0,content:m.gray("New model created in environment.")}),await n.writeToLocalFilesystem(o,{filesVersion:i.remoteFilesVersion,files:i.changed,delete:[]});let d=T.isSupported?T(e,`https://${a.environment.application.primaryDomain}/edit/${a.environment.name}/model/${e}/schema`):e;p({ensureEmptyLineAbove:!0,content:`${m.greenBright(y.tick)} Model ${m.cyanBright(d)} added successfully.`})},G=async(o,{args:t,filesync:n})=>{let a=n.syncJson,e=t._[1];if(!e)throw new f(r`Failed to add action, missing action path
52
+
53
+ {gray Usage}
54
+ {cyanBright ggt add action [CONTEXT]/<action_name>
55
+ CONTEXT:Specifies the kind of action. Use "model" for model actions otherwise use "action".}`);let s=await C(o,a.environment),i=await B(o,a.environment),d=e.split("/"),c,g=d.length>1?d.slice(0,d.length-1):d,w=d[d.length-1],x=s.find(l=>{let A=g[g.length-1];return l.apiIdentifier.toUpperCase()===A?.toUpperCase()&&l.namespace?.join("/")===g.slice(0,g.length-1).join("/")}),D=i.find(l=>l.namespace?.join("/")===g.join("/"));if(x&&D){let l=g.join("/");c=await j({choices:["models","actions"],content:r`
56
+ {bold Namespace Conflict:} The action '${w}.js' cannot be automatically added due to a namespace conflict.
57
+
58
+ How would you like to proceed?:
59
+ `,formatChoice:A=>{switch(A){case"models":return`As a Model action in ${m.gray(`models/${l}/${w}.js`)}`;case"actions":return`As an Action in ${m.gray(`actions/${l}/${w}.js`)}`}}}),p({ensureEmptyLineAbove:!0,content:r`${m.yellowBright(y.info)} You can override the context of the action by specifying the context in the path. For example: {gray ggt add action ${c}/${e}}`})}try{let l=(await a.edit.mutate({mutation:L,variables:{path:c?`${c}/`+e:e}})).createAction;await n.writeToLocalFilesystem(o,{filesVersion:l.remoteFilesVersion,files:l.changed,delete:[]})}catch(l){throw l instanceof u?new h(l):l}p({ensureEmptyLineAbove:!0,content:`Action ${m.cyanBright(e)} added successfully.`})},H=async(o,{args:t,filesync:n})=>{let a=n.syncJson,e=t._[1],s=t._[2];if(!e)throw new f(r`Failed to add route, missing route method
60
+
61
+ {gray Usage}
62
+ {cyanBright ggt add route <HTTP_METHOD> <route_path>}`);if(!s)throw new f(r`Failed to add route, missing route path
63
+
64
+ {gray Usage}
65
+ {cyanBright ggt add route ${e} <route_path>}`);try{let i=(await a.edit.mutate({mutation:S,variables:{method:e,path:s}})).createRoute;await n.writeToLocalFilesystem(o,{filesVersion:i.remoteFilesVersion,files:i.changed,delete:[]})}catch(i){throw i instanceof u?new h(i):i}p({ensureEmptyLineAbove:!0,content:`Route ${m.cyanBright(s)} added successfully.`})},X=async(o,{args:t,filesync:n})=>{let a=n.syncJson,e=t._[1]?.split("/");if(!e)throw new f(r`Failed to add field, invalid field path definition
66
+
67
+ {gray Usage}
68
+ {cyanBright ggt add field <model_path>/<field_name>:<field_type>}`);let s=[];if(e[1]){let[i,d]=J([e[1]]);if(d.length>0)throw new f(r`
69
+ Failed to add field:
70
+ • ${d.join(`
71
+ \u2022`)}
72
+
73
+ {gray Usage}
74
+ {cyanBright ggt add field ${e[0]}/<field_name>:<field_type>}`);s.push(...i)}else throw new f(r`Failed to add field, invalid field definition
75
+
76
+ {gray Usage}
77
+ {cyanBright ggt add field ${e[0]}/<field_name>:<field_type>}`);try{let i=(await a.edit.mutate({mutation:O,variables:{path:e[0],fields:s.map(d=>({name:d.name,fieldType:d.fieldType}))}})).createModelFields;await n.writeToLocalFilesystem(o,{filesVersion:i.remoteFilesVersion,files:i.changed,delete:[]})}catch(i){throw i instanceof u?new h(i):i}p({ensureEmptyLineAbove:!0,content:`Field ${m.cyanBright(s[0]?.name)} added successfully.`})};export{h as AddClientError,ce as args,me as run,I as usage};
78
+ //# sourceMappingURL=add-VYOF3CRL.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/commands/add.ts"],
4
+ "sourcesContent": ["/* eslint-disable no-case-declarations */\nimport chalk from \"chalk\";\nimport terminalLink from \"terminal-link\";\nimport { getGlobalActions, getModels } from \"../services/app/app.js\";\nimport {\n CREATE_ACTION_MUTATION,\n CREATE_MODEL_FIELDS_MUTATION,\n CREATE_MODEL_MUTATION,\n CREATE_ROUTE_MUTATION,\n} from \"../services/app/edit/operation.js\";\nimport { ClientError } from \"../services/app/error.js\";\nimport { ArgError, type ArgsDefinitionResult } from \"../services/command/arg.js\";\nimport type { Run, Usage } from \"../services/command/command.js\";\nimport type { Context } from \"../services/command/context.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 { println } from \"../services/output/print.js\";\nimport { GGTError, IsBug } from \"../services/output/report.js\";\nimport { select } from \"../services/output/select.js\";\nimport { sprint } from \"../services/output/sprint.js\";\nimport { symbol } from \"../services/output/symbols.js\";\nimport { ts } from \"../services/output/timestamp.js\";\nimport { uniq } from \"../services/util/collection.js\";\nimport { isGraphQLErrors } from \"../services/util/is.js\";\n\nexport class AddClientError extends GGTError {\n isBug = IsBug.NO;\n\n constructor(error: ClientError) {\n let template = \"\";\n\n if (isGraphQLErrors(error.cause)) {\n const errors = uniq(error.cause.map((x) => x.message));\n\n template = sprint` \u2022 ${errors.map((e) => e.split(\"\\n\").join(\"\\n\u200E \u2022 \")).join(\"\\n\")}`; // Why in gods name do I have to put an empty character for the tab to work?\n } else {\n template = sprint`${error.cause}`;\n }\n\n super(template);\n }\n\n protected override render(): string {\n return `${chalk.redBright(symbol.cross)} Failed to add:\\n ` + this.message;\n }\n}\n\nexport type AddArgs = typeof args;\nexport type AddArgsResult = ArgsDefinitionResult<AddArgs>;\n\nexport const args = {\n ...SyncJsonArgs,\n};\n\nexport const usage: Usage = () => {\n return sprint`\n Adds models, fields, actions and routes to your app.\n\n This command first performs a sync to ensure that your local and environment directories match, changes are tracked since last sync.\n If any conflicts are detected, they must be resolved before adding models, fields, actions or routes.\n\n {gray Usage}\n ggt add model <model_name> [field_name:field_type ...]\n\n ggt add action [CONTEXT]/<action_name>\n CONTEXT:Specifies the kind of action. Use \"model\" for model actions otherwise use \"action\".\n\n ggt add route <HTTP_METHOD> <route_path>\n\n ggt add field <model_path>/<field_name>:<field_type>\n\n {gray Options}\n -e, --env <env_name> Selects the environment to add to. Default set on \".gadget/sync.json\"\n\n {gray Examples}\n Add a new model 'post' with out fields:\n {cyanBright $ ggt add model modelA}\n\n Add a new model 'post' with 2 new 'string' type fields 'title' and 'body':\n {cyanBright $ ggt add model post title:string body:string}\n\n Add new action 'publish' to the 'post' model:\n {cyanBright ggt add action model/post/publish}\n\n Add a new action 'audit'\n {cyanBright ggt add action action/audit}\n\n Add a new route 'howdy'\n {cyanBright ggt add route GET howdy}\n\n Add a new 'boolean' type field 'published' to an existing model\n {cyanBright ggt add field post/published:boolean}\n `;\n};\n\nexport const run: Run<AddArgs> = async (ctx, args) => {\n const directory = await loadSyncJsonDirectory(process.cwd());\n const syncJson = await SyncJson.load(ctx, { command: \"add\", args, directory });\n if (!syncJson) {\n throw new UnknownDirectoryError({ command: \"add\", args, directory });\n }\n\n const filesync = new FileSync(syncJson);\n const hashes = await filesync.hashes(ctx, true);\n\n if (!hashes.inSync) {\n await filesync.merge(ctx, {\n hashes,\n printEnvironmentChangesOptions: {\n limit: 5,\n },\n printLocalChangesOptions: {\n limit: 5,\n },\n quietly: true,\n });\n }\n\n println({ ensureEmptyLineAbove: true, content: `${chalk.greenBright(symbol.tick)} Sync completed ${ts()}` });\n\n switch (args._[0]) {\n case \"model\":\n await modelSubCommand(ctx, { args, filesync });\n break;\n case \"action\":\n await actionSubCommand(ctx, { args, filesync });\n break;\n case \"route\":\n await routeSubCommand(ctx, { args, filesync });\n break;\n case \"field\":\n await fieldSubCommand(ctx, { args, filesync });\n break;\n default:\n println(usage(ctx));\n return;\n }\n};\n\nconst parseFieldValues = (fields: string[]): [{ name: string; fieldType: string }[], problems: string[]] => {\n const problems: string[] = [];\n const modelFields: { name: string; fieldType: string }[] = [];\n\n fields.forEach((field) => {\n const matches = /^(.*):+(.*)$/.exec(field);\n if (!matches || matches.length !== 3 || !matches[1] || !matches[2]) {\n problems.push(sprint`${field} is not a valid field definition`);\n } else {\n modelFields.push({ name: matches[1].replace(/:+/g, \"\"), fieldType: matches[2] });\n }\n });\n\n return [modelFields, problems];\n};\n\nconst modelSubCommand = async (ctx: Context, { args, filesync }: { args: AddArgsResult; filesync: FileSync }): Promise<void> => {\n const syncJson = filesync.syncJson;\n const modelApiIdentifier = args._[1];\n\n if (!modelApiIdentifier) {\n throw new ArgError(sprint`Failed to add model, missing model path\n\n {gray Usage}\n {cyanBright ggt add model <model_name> [field_name:field_type ...]}`);\n }\n\n const modelFieldsList: { name: string; fieldType: string }[] = [];\n if (args._.length > 2) {\n const [modelFields, problems] = parseFieldValues(args._.slice(2));\n\n if (problems.length > 0) {\n throw new ArgError(sprint`\n Failed to add model:\n \u2022 ${problems.join(\"\\n \u2022 \")}\n\n {gray Usage}\n {cyanBright ggt add model ${modelApiIdentifier} [field_name:field_type ...]}`);\n }\n\n modelFieldsList.push(...modelFields);\n }\n\n let result;\n\n try {\n result = (\n await syncJson.edit.mutate({\n mutation: CREATE_MODEL_MUTATION,\n variables: {\n path: modelApiIdentifier,\n fields: modelFieldsList.map((fields) => ({\n name: fields.name,\n fieldType: fields.fieldType,\n })),\n },\n })\n ).createModel;\n } catch (error) {\n if (error instanceof ClientError) {\n throw new AddClientError(error);\n } else {\n throw error;\n }\n }\n\n println({ ensureEmptyLineAbove: true, content: chalk.gray(\"New model created in environment.\") });\n\n await filesync.writeToLocalFilesystem(ctx, {\n filesVersion: result.remoteFilesVersion,\n files: result.changed,\n delete: [],\n });\n\n const modelPrintout = terminalLink.isSupported\n ? terminalLink(\n modelApiIdentifier,\n `https://${syncJson.environment.application.primaryDomain}/edit/${syncJson.environment.name}/model/${modelApiIdentifier}/schema`,\n )\n : modelApiIdentifier;\n\n println({\n ensureEmptyLineAbove: true,\n content: `${chalk.greenBright(symbol.tick)} Model ${chalk.cyanBright(modelPrintout)} added successfully.`,\n });\n};\n\nconst actionSubCommand = async (ctx: Context, { args, filesync }: { args: AddArgsResult; filesync: FileSync }): Promise<void> => {\n const syncJson = filesync.syncJson;\n const path = args._[1];\n\n if (!path) {\n throw new ArgError(sprint`Failed to add action, missing action path\n\n {gray Usage}\n {cyanBright ggt add action [CONTEXT]/<action_name>\n CONTEXT:Specifies the kind of action. Use \"model\" for model actions otherwise use \"action\".}`);\n }\n\n const models = await getModels(ctx, syncJson.environment);\n const globalActions = await getGlobalActions(ctx, syncJson.environment);\n const splitPath = path.split(\"/\");\n\n let overrideContextAction: \"models\" | \"actions\" | undefined;\n\n const parsedPaths = splitPath.length > 1 ? splitPath.slice(0, splitPath.length - 1) : splitPath;\n const parsedAction = splitPath[splitPath.length - 1];\n\n const conflictingModel = models.find((model) => {\n const modelName = parsedPaths[parsedPaths.length - 1];\n\n return (\n model.apiIdentifier.toUpperCase() === modelName?.toUpperCase() &&\n model.namespace?.join(\"/\") === parsedPaths.slice(0, parsedPaths.length - 1).join(\"/\")\n );\n });\n\n const conflictingActionNamespace = globalActions.find((action) => {\n return action.namespace?.join(\"/\") === parsedPaths.join(\"/\");\n });\n\n if (conflictingModel && conflictingActionNamespace) {\n const joinedParsedPaths = parsedPaths.join(\"/\");\n overrideContextAction = await select({\n choices: [\"models\", \"actions\"] as const,\n content: sprint`\n {bold Namespace Conflict:} The action '${parsedAction}.js' cannot be automatically added due to a namespace conflict.\n\n How would you like to proceed?:\n `,\n formatChoice: (choice) => {\n switch (choice) {\n case \"models\": {\n return `As a Model action in ${chalk.gray(`models/${joinedParsedPaths}/${parsedAction}.js`)}`;\n }\n case \"actions\": {\n return `As an Action in ${chalk.gray(`actions/${joinedParsedPaths}/${parsedAction}.js`)}`;\n }\n }\n },\n });\n\n println({\n ensureEmptyLineAbove: true,\n content: sprint`${chalk.yellowBright(symbol.info)} You can override the context of the action by specifying the context in the path. For example: {gray ggt add action ${overrideContextAction}/${path}}`,\n });\n }\n\n try {\n const result = (\n await syncJson.edit.mutate({\n mutation: CREATE_ACTION_MUTATION,\n variables: { path: overrideContextAction ? `${overrideContextAction}/` + path : path },\n })\n ).createAction;\n\n await filesync.writeToLocalFilesystem(ctx, {\n filesVersion: result.remoteFilesVersion,\n files: result.changed,\n delete: [],\n });\n } catch (error) {\n if (error instanceof ClientError) {\n throw new AddClientError(error);\n } else {\n throw error;\n }\n }\n\n println({\n ensureEmptyLineAbove: true,\n content: `Action ${chalk.cyanBright(path)} added successfully.`,\n });\n};\n\nconst routeSubCommand = async (ctx: Context, { args, filesync }: { args: AddArgsResult; filesync: FileSync }): Promise<void> => {\n const syncJson = filesync.syncJson;\n const routeMethod = args._[1];\n const routePath = args._[2];\n\n if (!routeMethod) {\n throw new ArgError(sprint`Failed to add route, missing route method\n\n {gray Usage}\n {cyanBright ggt add route <HTTP_METHOD> <route_path>}`);\n }\n\n if (!routePath) {\n throw new ArgError(sprint`Failed to add route, missing route path\n\n {gray Usage}\n {cyanBright ggt add route ${routeMethod} <route_path>}`);\n }\n\n try {\n const result = (\n await syncJson.edit.mutate({\n mutation: CREATE_ROUTE_MUTATION,\n variables: { method: routeMethod, path: routePath },\n })\n ).createRoute;\n\n await filesync.writeToLocalFilesystem(ctx, {\n filesVersion: result.remoteFilesVersion,\n files: result.changed,\n delete: [],\n });\n } catch (error) {\n if (error instanceof ClientError) {\n throw new AddClientError(error);\n } else {\n throw error;\n }\n }\n\n println({\n ensureEmptyLineAbove: true,\n content: `Route ${chalk.cyanBright(routePath)} added successfully.`,\n });\n};\n\nconst fieldSubCommand = async (ctx: Context, { args, filesync }: { args: AddArgsResult; filesync: FileSync }): Promise<void> => {\n const syncJson = filesync.syncJson;\n\n const splitPathAndField = args._[1]?.split(\"/\");\n\n if (!splitPathAndField) {\n throw new ArgError(sprint`Failed to add field, invalid field path definition\n\n {gray Usage}\n {cyanBright ggt add field <model_path>/<field_name>:<field_type>}`);\n }\n\n const modelFieldsList: { name: string; fieldType: string }[] = [];\n\n if (splitPathAndField[1]) {\n const [modelFields, problems] = parseFieldValues([splitPathAndField[1]]);\n\n if (problems.length > 0) {\n throw new ArgError(sprint`\n Failed to add field:\n \u2022 ${problems.join(\"\\n \u2022\")}\n\n {gray Usage}\n {cyanBright ggt add field ${splitPathAndField[0]}/<field_name>:<field_type>}`);\n }\n\n modelFieldsList.push(...modelFields);\n } else {\n throw new ArgError(sprint`Failed to add field, invalid field definition\n\n {gray Usage}\n {cyanBright ggt add field ${splitPathAndField[0]}/<field_name>:<field_type>}`);\n }\n\n try {\n const result = (\n await syncJson.edit.mutate({\n mutation: CREATE_MODEL_FIELDS_MUTATION,\n variables: {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n path: splitPathAndField[0]!,\n fields: modelFieldsList.map((field) => ({\n name: field.name,\n fieldType: field.fieldType,\n })),\n },\n })\n ).createModelFields;\n\n await filesync.writeToLocalFilesystem(ctx, {\n filesVersion: result.remoteFilesVersion,\n files: result.changed,\n delete: [],\n });\n } catch (error) {\n if (error instanceof ClientError) {\n throw new AddClientError(error);\n } else {\n throw error;\n }\n }\n\n println({\n ensureEmptyLineAbove: true,\n content: `Field ${chalk.cyanBright(modelFieldsList[0]?.name)} added successfully.`,\n });\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["init_cjs", "AddClientError", "GGTError", "IsBug", "error", "template", "isGraphQLErrors", "errors", "uniq", "x", "sprint", "source_default", "symbol", "args", "SyncJsonArgs", "usage", "run", "ctx", "directory", "loadSyncJsonDirectory", "syncJson", "SyncJson", "UnknownDirectoryError", "filesync", "FileSync", "hashes", "println", "ts", "modelSubCommand", "actionSubCommand", "routeSubCommand", "fieldSubCommand", "parseFieldValues", "fields", "problems", "modelFields", "field", "matches", "modelApiIdentifier", "ArgError", "modelFieldsList", "result", "CREATE_MODEL_MUTATION", "ClientError", "modelPrintout", "terminalLink", "path", "models", "getModels", "globalActions", "getGlobalActions", "splitPath", "overrideContextAction", "parsedPaths", "parsedAction", "conflictingModel", "model", "modelName", "conflictingActionNamespace", "action", "joinedParsedPaths", "select", "choice", "CREATE_ACTION_MUTATION", "routeMethod", "routePath", "CREATE_ROUTE_MUTATION", "splitPathAndField", "CREATE_MODEL_FIELDS_MUTATION"]
7
+ }
@@ -1,4 +1,4 @@
1
- import{E as $,I as u,x as E}from"./chunk-KGOVR5SK.js";import{c as N,e as g,g as a}from"./chunk-5WC5D4WL.js";var k=N((_e,F)=>{a();function G(t){return Array.isArray(t)?t:[t]}var S="",C=" ",p="\\",B=/^\s+$/,W=/(?:[^\\]|^)\\$/,K=/^\\!/,V=/^\\#/,Y=/\r?\n/g,M=/^\.*\/|^\.+$/,y="/",T="node-ignore";typeof Symbol<"u"&&(T=Symbol.for("node-ignore"));var I=T,q=(t,e,s)=>Object.defineProperty(t,e,{value:s}),J=/([0-z])-([0-z])/g,H=()=>!1,Q=t=>t.replace(J,(e,s,r)=>s.charCodeAt(0)<=r.charCodeAt(0)?e:S),U=t=>{let{length:e}=t;return t.slice(0,e-e%2)},Z=[[/^\uFEFF/,()=>S],[/((?:\\\\)*?)(\\?\s+)$/,(t,e,s)=>e+(s.indexOf("\\")===0?C:S)],[/(\\+?)\s/g,(t,e)=>{let{length:s}=e;return e.slice(0,s-s%2)+C}],[/[\\$.|*+(){^]/g,t=>`\\${t}`],[/(?!\\)\?/g,()=>"[^/]"],[/^\//,()=>"^"],[/\//g,()=>"\\/"],[/^\^*\\\*\\\*\\\//,()=>"^(?:.*\\/)?"],[/^(?=[^^])/,function(){return/\/(?!$)/.test(this)?"^":"(?:^|\\/)"}],[/\\\/\\\*\\\*(?=\\\/|$)/g,(t,e,s)=>e+6<s.length?"(?:\\/[^\\/]+)*":"\\/.+"],[/(^|[^\\]+)(\\\*)+(?=.+)/g,(t,e,s)=>{let r=s.replace(/\\\*/g,"[^\\/]*");return e+r}],[/\\\\\\(?=[$.|*+(){^])/g,()=>p],[/\\\\/g,()=>p],[/(\\)?\[([^\]/]*?)(\\*)($|\])/g,(t,e,s,r,n)=>e===p?`\\[${s}${U(r)}${n}`:n==="]"&&r.length%2===0?`[${Q(s)}${r}]`:"[]"],[/(?:[^*])$/,t=>/\/$/.test(t)?`${t}$`:`${t}(?=$|\\/$)`],[/(\^|\\\/)?\\\*$/,(t,e)=>`${e?`${e}[^/]+`:"[^/]*"}(?=$|\\/$)`]],O=Object.create(null),ee=(t,e)=>{let s=O[t];return s||(s=Z.reduce((r,[n,i])=>r.replace(n,i.bind(t)),t),O[t]=s),e?new RegExp(s,"i"):new RegExp(s)},R=t=>typeof t=="string",te=t=>t&&R(t)&&!B.test(t)&&!W.test(t)&&t.indexOf("#")!==0,se=t=>t.split(Y),x=class{constructor(e,s,r,n){this.origin=e,this.pattern=s,this.negative=r,this.regex=n}},re=(t,e)=>{let s=t,r=!1;t.indexOf("!")===0&&(r=!0,t=t.substr(1)),t=t.replace(K,"!").replace(V,"#");let n=ee(t,e);return new x(s,t,r,n)},ne=(t,e)=>{throw new e(t)},o=(t,e,s)=>R(t)?t?o.isNotRelative(t)?s(`path should be a \`path.relative()\`d string, but got "${e}"`,RangeError):!0:s("path must not be empty",TypeError):s(`path must be a string, but got \`${e}\``,TypeError),L=t=>M.test(t);o.isNotRelative=L;o.convert=t=>t;var v=class{constructor({ignorecase:e=!0,ignoreCase:s=e,allowRelativePaths:r=!1}={}){q(this,I,!0),this._rules=[],this._ignoreCase=s,this._allowRelativePaths=r,this._initCache()}_initCache(){this._ignoreCache=Object.create(null),this._testCache=Object.create(null)}_addPattern(e){if(e&&e[I]){this._rules=this._rules.concat(e._rules),this._added=!0;return}if(te(e)){let s=re(e,this._ignoreCase);this._added=!0,this._rules.push(s)}}add(e){return this._added=!1,G(R(e)?se(e):e).forEach(this._addPattern,this),this._added&&this._initCache(),this}addPattern(e){return this.add(e)}_testOne(e,s){let r=!1,n=!1;return this._rules.forEach(i=>{let{negative:l}=i;if(n===l&&r!==n||l&&!r&&!n&&!s)return;i.regex.test(e)&&(r=!l,n=l)}),{ignored:r,unignored:n}}_test(e,s,r,n){let i=e&&o.convert(e);return o(i,e,this._allowRelativePaths?H:ne),this._t(i,s,r,n)}_t(e,s,r,n){if(e in s)return s[e];if(n||(n=e.split(y)),n.pop(),!n.length)return s[e]=this._testOne(e,r);let i=this._t(n.join(y)+y,s,r,n);return s[e]=i.ignored?i:this._testOne(e,r)}ignores(e){return this._test(e,this._ignoreCache,!1).ignored}createFilter(){return e=>!this.ignores(e)}filter(e){return G(e).filter(this.createFilter())}test(e){return this._test(e,this._testCache,!0)}},d=t=>new v(t),ie=t=>o(t&&o.convert(t),t,H);d.isPathValid=ie;d.default=d;F.exports=d;if(typeof process<"u"&&(process.env&&process.env.IGNORE_TEST_WIN32||process.platform==="win32")){let t=s=>/^\\\\\?\\/.test(s)||/["<>|\u0000-\u001F]+/u.test(s)?s:s.replace(/\\/g,"/");o.convert=t;let e=/^[a-z]:\//i;o.isNotRelative=s=>e.test(s)||L(s)}});var D=N((Ee,X)=>{a();X.exports=function(t,e){if(typeof t!="string")throw new TypeError("expected path to be a string");if(t==="\\"||t==="/")return"/";var s=t.length;if(s<=1)return t;var r="";if(s>4&&t[3]==="\\"){var n=t[2];(n==="?"||n===".")&&t.slice(0,2)==="\\\\"&&(t=t.slice(2),r="//")}var i=t.split(/[/\\]+/);return e!==!1&&i[i.length-1]===""&&i.pop(),r+i.join("/")}});a();var _=g($(),1);a();var f=g($(),1),j=g(k(),1),A=g(D(),1);import oe from"node:assert";import{createHash as ae}from"node:crypto";import c from"node:path";import{Transform as ce}from"node:stream";import{pipeline as le}from"node:stream/promises";var ue=[".DS_Store","node_modules",".git"],fe=[".gadget/sync.json",".gadget/backup","yarn-error.log"],z=class t{constructor(e){this.path=e}_ignorer;_isHashing=!1;static async init(e){let s=new t(e);return await s.loadIgnoreFile(),s}relative(e){return c.isAbsolute(e)?c.relative(this.path,e):e}absolute(...e){let s=c.resolve(this.path,...e);return oe(s.startsWith(this.path),`expected ${s} to be within ${this.path}`),s}normalize(e,s){return c.isAbsolute(e)&&(e=this.relative(e)),e=(0,A.default)(e,!0),s&&(e+="/"),e}async loadIgnoreFile(){this._ignorer=j.default.default(),this._ignorer.add(ue);try{let e=await f.default.readFile(this.absolute(".ignore"),"utf8");this._ignorer.add(e)}catch(e){h(e)}}ignores(e){return e=this.relative(e),e===""?!1:e.startsWith("..")||(e=(0,A.default)(e,!1),this._isHashing&&fe.some(s=>e.startsWith(s)))?!0:this._ignorer.ignores(e)}async*walk({dir:e=this.path}={}){e!==this.path&&(yield this.normalize(e,!0));for await(let s of await f.default.opendir(e)){let r=c.join(e,s.name);this.ignores(r)||(s.isDirectory()?yield*this.walk({dir:r}):s.isFile()&&(yield this.normalize(r,!1)))}}async hashes(){try{this._isHashing=!0;let e={};for await(let s of this.walk()){let r=this.absolute(s);e[s]=await de(r)}return e}finally{this._isHashing=!1}}async hasFiles(){return!await this.isEmptyOrNonExistent()}async isEmptyOrNonExistent(){let e=!0;try{for await(let s of this.walk()){e=!1;break}}catch(s){h(s)}return e}},ge=process.platform==="linux"||process.platform==="darwin",de=async t=>{let e=ae("sha1");e.update(c.basename(t));let s=await f.default.stat(t),r;if(ge&&(r=s.mode&511),s.isDirectory())return{sha1:e.digest("hex"),permissions:r};let n=new ce({transform(i,l,m){if(!i.includes(13)){m(void 0,i);return}let w=Buffer.alloc(i.length),P=0;for(let b of i)b!==13&&(w[P++]=b);m(void 0,w.subarray(0,P))}});return await le(f.default.createReadStream(t),n,e),{sha1:e.digest("hex"),permissions:r}},h=t=>{if(!(t&&typeof t=="object"&&"code"in t&&t.code==="ENOENT"))throw t};var he=E(t=>{if(process.env.GGT_SESSION)return t.log.debug("reading session from env"),process.env.GGT_SESSION;try{return t.log.debug("reading session from disk"),_.default.readFileSync(u("session.txt"),"utf8")}catch(e){h(e);return}}),$e=(t,e)=>{he.clear(),process.env.GGT_SESSION&&(t.log.debug("writing session to env",{session:!!e}),process.env.GGT_SESSION=e),t.log.debug("writing session to disk",{session:!!e,path:u("session.txt")}),e?_.default.outputFileSync(u("session.txt"),e):_.default.removeSync(u("session.txt"))},Ge=E(t=>(t.log.debug("reading token from env"),process.env.GGT_TOKEN));export{z as a,ge as b,h as c,he as d,$e as e,Ge as f};
1
+ import{I as E,Q as u,z as $}from"./chunk-JU6IEBE5.js";import{c as b,e as g,g as a}from"./chunk-SGMPMYEU.js";var k=b((me,F)=>{a();function G(t){return Array.isArray(t)?t:[t]}var S="",C=" ",p="\\",B=/^\s+$/,W=/(?:[^\\]|^)\\$/,K=/^\\!/,V=/^\\#/,Y=/\r?\n/g,M=/^\.*\/|^\.+$/,y="/",T="node-ignore";typeof Symbol<"u"&&(T=Symbol.for("node-ignore"));var I=T,q=(t,e,s)=>Object.defineProperty(t,e,{value:s}),J=/([0-z])-([0-z])/g,H=()=>!1,Q=t=>t.replace(J,(e,s,r)=>s.charCodeAt(0)<=r.charCodeAt(0)?e:S),U=t=>{let{length:e}=t;return t.slice(0,e-e%2)},Z=[[/^\uFEFF/,()=>S],[/((?:\\\\)*?)(\\?\s+)$/,(t,e,s)=>e+(s.indexOf("\\")===0?C:S)],[/(\\+?)\s/g,(t,e)=>{let{length:s}=e;return e.slice(0,s-s%2)+C}],[/[\\$.|*+(){^]/g,t=>`\\${t}`],[/(?!\\)\?/g,()=>"[^/]"],[/^\//,()=>"^"],[/\//g,()=>"\\/"],[/^\^*\\\*\\\*\\\//,()=>"^(?:.*\\/)?"],[/^(?=[^^])/,function(){return/\/(?!$)/.test(this)?"^":"(?:^|\\/)"}],[/\\\/\\\*\\\*(?=\\\/|$)/g,(t,e,s)=>e+6<s.length?"(?:\\/[^\\/]+)*":"\\/.+"],[/(^|[^\\]+)(\\\*)+(?=.+)/g,(t,e,s)=>{let r=s.replace(/\\\*/g,"[^\\/]*");return e+r}],[/\\\\\\(?=[$.|*+(){^])/g,()=>p],[/\\\\/g,()=>p],[/(\\)?\[([^\]/]*?)(\\*)($|\])/g,(t,e,s,r,n)=>e===p?`\\[${s}${U(r)}${n}`:n==="]"&&r.length%2===0?`[${Q(s)}${r}]`:"[]"],[/(?:[^*])$/,t=>/\/$/.test(t)?`${t}$`:`${t}(?=$|\\/$)`],[/(\^|\\\/)?\\\*$/,(t,e)=>`${e?`${e}[^/]+`:"[^/]*"}(?=$|\\/$)`]],O=Object.create(null),ee=(t,e)=>{let s=O[t];return s||(s=Z.reduce((r,[n,i])=>r.replace(n,i.bind(t)),t),O[t]=s),e?new RegExp(s,"i"):new RegExp(s)},R=t=>typeof t=="string",te=t=>t&&R(t)&&!B.test(t)&&!W.test(t)&&t.indexOf("#")!==0,se=t=>t.split(Y),x=class{constructor(e,s,r,n){this.origin=e,this.pattern=s,this.negative=r,this.regex=n}},re=(t,e)=>{let s=t,r=!1;t.indexOf("!")===0&&(r=!0,t=t.substr(1)),t=t.replace(K,"!").replace(V,"#");let n=ee(t,e);return new x(s,t,r,n)},ne=(t,e)=>{throw new e(t)},o=(t,e,s)=>R(t)?t?o.isNotRelative(t)?s(`path should be a \`path.relative()\`d string, but got "${e}"`,RangeError):!0:s("path must not be empty",TypeError):s(`path must be a string, but got \`${e}\``,TypeError),L=t=>M.test(t);o.isNotRelative=L;o.convert=t=>t;var v=class{constructor({ignorecase:e=!0,ignoreCase:s=e,allowRelativePaths:r=!1}={}){q(this,I,!0),this._rules=[],this._ignoreCase=s,this._allowRelativePaths=r,this._initCache()}_initCache(){this._ignoreCache=Object.create(null),this._testCache=Object.create(null)}_addPattern(e){if(e&&e[I]){this._rules=this._rules.concat(e._rules),this._added=!0;return}if(te(e)){let s=re(e,this._ignoreCase);this._added=!0,this._rules.push(s)}}add(e){return this._added=!1,G(R(e)?se(e):e).forEach(this._addPattern,this),this._added&&this._initCache(),this}addPattern(e){return this.add(e)}_testOne(e,s){let r=!1,n=!1;return this._rules.forEach(i=>{let{negative:l}=i;if(n===l&&r!==n||l&&!r&&!n&&!s)return;i.regex.test(e)&&(r=!l,n=l)}),{ignored:r,unignored:n}}_test(e,s,r,n){let i=e&&o.convert(e);return o(i,e,this._allowRelativePaths?H:ne),this._t(i,s,r,n)}_t(e,s,r,n){if(e in s)return s[e];if(n||(n=e.split(y)),n.pop(),!n.length)return s[e]=this._testOne(e,r);let i=this._t(n.join(y)+y,s,r,n);return s[e]=i.ignored?i:this._testOne(e,r)}ignores(e){return this._test(e,this._ignoreCache,!1).ignored}createFilter(){return e=>!this.ignores(e)}filter(e){return G(e).filter(this.createFilter())}test(e){return this._test(e,this._testCache,!0)}},d=t=>new v(t),ie=t=>o(t&&o.convert(t),t,H);d.isPathValid=ie;d.default=d;F.exports=d;if(typeof process<"u"&&(process.env&&process.env.IGNORE_TEST_WIN32||process.platform==="win32")){let t=s=>/^\\\\\?\\/.test(s)||/["<>|\u0000-\u001F]+/u.test(s)?s:s.replace(/\\/g,"/");o.convert=t;let e=/^[a-z]:\//i;o.isNotRelative=s=>e.test(s)||L(s)}});var D=b((pe,X)=>{a();X.exports=function(t,e){if(typeof t!="string")throw new TypeError("expected path to be a string");if(t==="\\"||t==="/")return"/";var s=t.length;if(s<=1)return t;var r="";if(s>4&&t[3]==="\\"){var n=t[2];(n==="?"||n===".")&&t.slice(0,2)==="\\\\"&&(t=t.slice(2),r="//")}var i=t.split(/[/\\]+/);return e!==!1&&i[i.length-1]===""&&i.pop(),r+i.join("/")}});a();var _=g($(),1);a();var f=g($(),1),j=g(k(),1),A=g(D(),1);import oe from"node:assert";import{createHash as ae}from"node:crypto";import c from"node:path";import{Transform as ce}from"node:stream";import{pipeline as le}from"node:stream/promises";var ue=[".gadget/"],fe=[".DS_Store","node_modules",".git"],ge=[".gadget/sync.json",".gadget/backup","yarn-error.log"],z=class t{constructor(e){this.path=e}_ignorer;_isHashing=!1;static async init(e){let s=new t(e);return await s.loadIgnoreFile(),s}relative(e){return c.isAbsolute(e)?c.relative(this.path,e):e}absolute(...e){let s=c.resolve(this.path,...e);return oe(s.startsWith(this.path),`expected ${s} to be within ${this.path}`),s}normalize(e,s){return c.isAbsolute(e)&&(e=this.relative(e)),e=(0,A.default)(e,!0),s&&(e+="/"),e}async loadIgnoreFile(){this._ignorer=j.default.default(),this._ignorer.add(fe);try{let e=await f.default.readFile(this.absolute(".ignore"),"utf8");this._ignorer.add(e)}catch(e){h(e)}}ignores(e){return e=this.relative(e),e===""?!1:e.startsWith("..")||(e=(0,A.default)(e,!1),this._isHashing&&ge.some(s=>e.startsWith(s)))?!0:ue.some(s=>e.startsWith(s))?!1:this._ignorer.ignores(e)}async*walk({dir:e=this.path}={}){e!==this.path&&(yield this.normalize(e,!0));for await(let s of await f.default.opendir(e)){let r=c.join(e,s.name);this.ignores(r)||(s.isDirectory()?yield*this.walk({dir:r}):s.isFile()&&(yield this.normalize(r,!1)))}}async hashes(){try{this._isHashing=!0;let e={};for await(let s of this.walk()){let r=this.absolute(s);e[s]=await he(r)}return e}finally{this._isHashing=!1}}async hasFiles(){return!await this.isEmptyOrNonExistent()}async isEmptyOrNonExistent(){let e=!0;try{for await(let s of this.walk()){e=!1;break}}catch(s){h(s)}return e}},de=process.platform==="linux"||process.platform==="darwin",he=async t=>{let e=ae("sha1");e.update(c.basename(t));let s=await f.default.stat(t),r;if(de&&(r=s.mode&511),s.isDirectory())return{sha1:e.digest("hex"),permissions:r};let n=new ce({transform(i,l,m){if(!i.includes(13)){m(void 0,i);return}let w=Buffer.alloc(i.length),N=0;for(let P of i)P!==13&&(w[N++]=P);m(void 0,w.subarray(0,N))}});return await le(f.default.createReadStream(t),n,e),{sha1:e.digest("hex"),permissions:r}},h=t=>{if(!(t&&typeof t=="object"&&"code"in t&&t.code==="ENOENT"))throw t};var _e=E(t=>{if(process.env.GGT_SESSION)return t.log.debug("reading session from env"),process.env.GGT_SESSION;try{return t.log.debug("reading session from disk"),_.default.readFileSync(u("session.txt"),"utf8")}catch(e){h(e);return}}),Ge=(t,e)=>{_e.clear(),process.env.GGT_SESSION&&(t.log.debug("writing session to env",{session:!!e}),process.env.GGT_SESSION=e),t.log.debug("writing session to disk",{session:!!e,path:u("session.txt")}),e?_.default.outputFileSync(u("session.txt"),e):_.default.removeSync(u("session.txt"))},Ce=E(t=>(t.log.debug("reading token from env"),process.env.GGT_TOKEN));export{z as a,de as b,h as c,_e as d,Ge as e,Ce as f};
2
2
  /*! Bundled license information:
3
3
 
4
4
  normalize-path/index.js:
@@ -9,4 +9,4 @@ normalize-path/index.js:
9
9
  * Released under the MIT License.
10
10
  *)
11
11
  */
12
- //# sourceMappingURL=chunk-KMCOZJPU.js.map
12
+ //# sourceMappingURL=chunk-3B5DKR5D.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../node_modules/.pnpm/ignore@5.3.2/node_modules/ignore/index.js", "../node_modules/.pnpm/normalize-path@3.0.0/node_modules/normalize-path/index.js", "../src/services/user/session.ts", "../src/services/filesync/directory.ts"],
4
- "sourcesContent": ["// A simple implementation of make-array\nfunction makeArray (subject) {\n return Array.isArray(subject)\n ? subject\n : [subject]\n}\n\nconst EMPTY = ''\nconst SPACE = ' '\nconst ESCAPE = '\\\\'\nconst REGEX_TEST_BLANK_LINE = /^\\s+$/\nconst REGEX_INVALID_TRAILING_BACKSLASH = /(?:[^\\\\]|^)\\\\$/\nconst REGEX_REPLACE_LEADING_EXCAPED_EXCLAMATION = /^\\\\!/\nconst REGEX_REPLACE_LEADING_EXCAPED_HASH = /^\\\\#/\nconst REGEX_SPLITALL_CRLF = /\\r?\\n/g\n// /foo,\n// ./foo,\n// ../foo,\n// .\n// ..\nconst REGEX_TEST_INVALID_PATH = /^\\.*\\/|^\\.+$/\n\nconst SLASH = '/'\n\n// Do not use ternary expression here, since \"istanbul ignore next\" is buggy\nlet TMP_KEY_IGNORE = 'node-ignore'\n/* istanbul ignore else */\nif (typeof Symbol !== 'undefined') {\n TMP_KEY_IGNORE = Symbol.for('node-ignore')\n}\nconst KEY_IGNORE = TMP_KEY_IGNORE\n\nconst define = (object, key, value) =>\n Object.defineProperty(object, key, {value})\n\nconst REGEX_REGEXP_RANGE = /([0-z])-([0-z])/g\n\nconst RETURN_FALSE = () => false\n\n// Sanitize the range of a regular expression\n// The cases are complicated, see test cases for details\nconst sanitizeRange = range => range.replace(\n REGEX_REGEXP_RANGE,\n (match, from, to) => from.charCodeAt(0) <= to.charCodeAt(0)\n ? match\n // Invalid range (out of order) which is ok for gitignore rules but\n // fatal for JavaScript regular expression, so eliminate it.\n : EMPTY\n)\n\n// See fixtures #59\nconst cleanRangeBackSlash = slashes => {\n const {length} = slashes\n return slashes.slice(0, length - length % 2)\n}\n\n// > If the pattern ends with a slash,\n// > it is removed for the purpose of the following description,\n// > but it would only find a match with a directory.\n// > In other words, foo/ will match a directory foo and paths underneath it,\n// > but will not match a regular file or a symbolic link foo\n// > (this is consistent with the way how pathspec works in general in Git).\n// '`foo/`' will not match regular file '`foo`' or symbolic link '`foo`'\n// -> ignore-rules will not deal with it, because it costs extra `fs.stat` call\n// you could use option `mark: true` with `glob`\n\n// '`foo/`' should not continue with the '`..`'\nconst REPLACERS = [\n\n [\n // remove BOM\n // TODO:\n // Other similar zero-width characters?\n /^\\uFEFF/,\n () => EMPTY\n ],\n\n // > Trailing spaces are ignored unless they are quoted with backslash (\"\\\")\n [\n // (a\\ ) -> (a )\n // (a ) -> (a)\n // (a ) -> (a)\n // (a \\ ) -> (a )\n /((?:\\\\\\\\)*?)(\\\\?\\s+)$/,\n (_, m1, m2) => m1 + (\n m2.indexOf('\\\\') === 0\n ? SPACE\n : EMPTY\n )\n ],\n\n // replace (\\ ) with ' '\n // (\\ ) -> ' '\n // (\\\\ ) -> '\\\\ '\n // (\\\\\\ ) -> '\\\\ '\n [\n /(\\\\+?)\\s/g,\n (_, m1) => {\n const {length} = m1\n return m1.slice(0, length - length % 2) + SPACE\n }\n ],\n\n // Escape metacharacters\n // which is written down by users but means special for regular expressions.\n\n // > There are 12 characters with special meanings:\n // > - the backslash \\,\n // > - the caret ^,\n // > - the dollar sign $,\n // > - the period or dot .,\n // > - the vertical bar or pipe symbol |,\n // > - the question mark ?,\n // > - the asterisk or star *,\n // > - the plus sign +,\n // > - the opening parenthesis (,\n // > - the closing parenthesis ),\n // > - and the opening square bracket [,\n // > - the opening curly brace {,\n // > These special characters are often called \"metacharacters\".\n [\n /[\\\\$.|*+(){^]/g,\n match => `\\\\${match}`\n ],\n\n [\n // > a question mark (?) matches a single character\n /(?!\\\\)\\?/g,\n () => '[^/]'\n ],\n\n // leading slash\n [\n\n // > A leading slash matches the beginning of the pathname.\n // > For example, \"/*.c\" matches \"cat-file.c\" but not \"mozilla-sha1/sha1.c\".\n // A leading slash matches the beginning of the pathname\n /^\\//,\n () => '^'\n ],\n\n // replace special metacharacter slash after the leading slash\n [\n /\\//g,\n () => '\\\\/'\n ],\n\n [\n // > A leading \"**\" followed by a slash means match in all directories.\n // > For example, \"**/foo\" matches file or directory \"foo\" anywhere,\n // > the same as pattern \"foo\".\n // > \"**/foo/bar\" matches file or directory \"bar\" anywhere that is directly\n // > under directory \"foo\".\n // Notice that the '*'s have been replaced as '\\\\*'\n /^\\^*\\\\\\*\\\\\\*\\\\\\//,\n\n // '**/foo' <-> 'foo'\n () => '^(?:.*\\\\/)?'\n ],\n\n // starting\n [\n // there will be no leading '/'\n // (which has been replaced by section \"leading slash\")\n // If starts with '**', adding a '^' to the regular expression also works\n /^(?=[^^])/,\n function startingReplacer () {\n // If has a slash `/` at the beginning or middle\n return !/\\/(?!$)/.test(this)\n // > Prior to 2.22.1\n // > If the pattern does not contain a slash /,\n // > Git treats it as a shell glob pattern\n // Actually, if there is only a trailing slash,\n // git also treats it as a shell glob pattern\n\n // After 2.22.1 (compatible but clearer)\n // > If there is a separator at the beginning or middle (or both)\n // > of the pattern, then the pattern is relative to the directory\n // > level of the particular .gitignore file itself.\n // > Otherwise the pattern may also match at any level below\n // > the .gitignore level.\n ? '(?:^|\\\\/)'\n\n // > Otherwise, Git treats the pattern as a shell glob suitable for\n // > consumption by fnmatch(3)\n : '^'\n }\n ],\n\n // two globstars\n [\n // Use lookahead assertions so that we could match more than one `'/**'`\n /\\\\\\/\\\\\\*\\\\\\*(?=\\\\\\/|$)/g,\n\n // Zero, one or several directories\n // should not use '*', or it will be replaced by the next replacer\n\n // Check if it is not the last `'/**'`\n (_, index, str) => index + 6 < str.length\n\n // case: /**/\n // > A slash followed by two consecutive asterisks then a slash matches\n // > zero or more directories.\n // > For example, \"a/**/b\" matches \"a/b\", \"a/x/b\", \"a/x/y/b\" and so on.\n // '/**/'\n ? '(?:\\\\/[^\\\\/]+)*'\n\n // case: /**\n // > A trailing `\"/**\"` matches everything inside.\n\n // #21: everything inside but it should not include the current folder\n : '\\\\/.+'\n ],\n\n // normal intermediate wildcards\n [\n // Never replace escaped '*'\n // ignore rule '\\*' will match the path '*'\n\n // 'abc.*/' -> go\n // 'abc.*' -> skip this rule,\n // coz trailing single wildcard will be handed by [trailing wildcard]\n /(^|[^\\\\]+)(\\\\\\*)+(?=.+)/g,\n\n // '*.js' matches '.js'\n // '*.js' doesn't match 'abc'\n (_, p1, p2) => {\n // 1.\n // > An asterisk \"*\" matches anything except a slash.\n // 2.\n // > Other consecutive asterisks are considered regular asterisks\n // > and will match according to the previous rules.\n const unescaped = p2.replace(/\\\\\\*/g, '[^\\\\/]*')\n return p1 + unescaped\n }\n ],\n\n [\n // unescape, revert step 3 except for back slash\n // For example, if a user escape a '\\\\*',\n // after step 3, the result will be '\\\\\\\\\\\\*'\n /\\\\\\\\\\\\(?=[$.|*+(){^])/g,\n () => ESCAPE\n ],\n\n [\n // '\\\\\\\\' -> '\\\\'\n /\\\\\\\\/g,\n () => ESCAPE\n ],\n\n [\n // > The range notation, e.g. [a-zA-Z],\n // > can be used to match one of the characters in a range.\n\n // `\\` is escaped by step 3\n /(\\\\)?\\[([^\\]/]*?)(\\\\*)($|\\])/g,\n (match, leadEscape, range, endEscape, close) => leadEscape === ESCAPE\n // '\\\\[bar]' -> '\\\\\\\\[bar\\\\]'\n ? `\\\\[${range}${cleanRangeBackSlash(endEscape)}${close}`\n : close === ']'\n ? endEscape.length % 2 === 0\n // A normal case, and it is a range notation\n // '[bar]'\n // '[bar\\\\\\\\]'\n ? `[${sanitizeRange(range)}${endEscape}]`\n // Invalid range notaton\n // '[bar\\\\]' -> '[bar\\\\\\\\]'\n : '[]'\n : '[]'\n ],\n\n // ending\n [\n // 'js' will not match 'js.'\n // 'ab' will not match 'abc'\n /(?:[^*])$/,\n\n // WTF!\n // https://git-scm.com/docs/gitignore\n // changes in [2.22.1](https://git-scm.com/docs/gitignore/2.22.1)\n // which re-fixes #24, #38\n\n // > If there is a separator at the end of the pattern then the pattern\n // > will only match directories, otherwise the pattern can match both\n // > files and directories.\n\n // 'js*' will not match 'a.js'\n // 'js/' will not match 'a.js'\n // 'js' will match 'a.js' and 'a.js/'\n match => /\\/$/.test(match)\n // foo/ will not match 'foo'\n ? `${match}$`\n // foo matches 'foo' and 'foo/'\n : `${match}(?=$|\\\\/$)`\n ],\n\n // trailing wildcard\n [\n /(\\^|\\\\\\/)?\\\\\\*$/,\n (_, p1) => {\n const prefix = p1\n // '\\^':\n // '/*' does not match EMPTY\n // '/*' does not match everything\n\n // '\\\\\\/':\n // 'abc/*' does not match 'abc/'\n ? `${p1}[^/]+`\n\n // 'a*' matches 'a'\n // 'a*' matches 'aa'\n : '[^/]*'\n\n return `${prefix}(?=$|\\\\/$)`\n }\n ],\n]\n\n// A simple cache, because an ignore rule only has only one certain meaning\nconst regexCache = Object.create(null)\n\n// @param {pattern}\nconst makeRegex = (pattern, ignoreCase) => {\n let source = regexCache[pattern]\n\n if (!source) {\n source = REPLACERS.reduce(\n (prev, [matcher, replacer]) =>\n prev.replace(matcher, replacer.bind(pattern)),\n pattern\n )\n regexCache[pattern] = source\n }\n\n return ignoreCase\n ? new RegExp(source, 'i')\n : new RegExp(source)\n}\n\nconst isString = subject => typeof subject === 'string'\n\n// > A blank line matches no files, so it can serve as a separator for readability.\nconst checkPattern = pattern => pattern\n && isString(pattern)\n && !REGEX_TEST_BLANK_LINE.test(pattern)\n && !REGEX_INVALID_TRAILING_BACKSLASH.test(pattern)\n\n // > A line starting with # serves as a comment.\n && pattern.indexOf('#') !== 0\n\nconst splitPattern = pattern => pattern.split(REGEX_SPLITALL_CRLF)\n\nclass IgnoreRule {\n constructor (\n origin,\n pattern,\n negative,\n regex\n ) {\n this.origin = origin\n this.pattern = pattern\n this.negative = negative\n this.regex = regex\n }\n}\n\nconst createRule = (pattern, ignoreCase) => {\n const origin = pattern\n let negative = false\n\n // > An optional prefix \"!\" which negates the pattern;\n if (pattern.indexOf('!') === 0) {\n negative = true\n pattern = pattern.substr(1)\n }\n\n pattern = pattern\n // > Put a backslash (\"\\\") in front of the first \"!\" for patterns that\n // > begin with a literal \"!\", for example, `\"\\!important!.txt\"`.\n .replace(REGEX_REPLACE_LEADING_EXCAPED_EXCLAMATION, '!')\n // > Put a backslash (\"\\\") in front of the first hash for patterns that\n // > begin with a hash.\n .replace(REGEX_REPLACE_LEADING_EXCAPED_HASH, '#')\n\n const regex = makeRegex(pattern, ignoreCase)\n\n return new IgnoreRule(\n origin,\n pattern,\n negative,\n regex\n )\n}\n\nconst throwError = (message, Ctor) => {\n throw new Ctor(message)\n}\n\nconst checkPath = (path, originalPath, doThrow) => {\n if (!isString(path)) {\n return doThrow(\n `path must be a string, but got \\`${originalPath}\\``,\n TypeError\n )\n }\n\n // We don't know if we should ignore EMPTY, so throw\n if (!path) {\n return doThrow(`path must not be empty`, TypeError)\n }\n\n // Check if it is a relative path\n if (checkPath.isNotRelative(path)) {\n const r = '`path.relative()`d'\n return doThrow(\n `path should be a ${r} string, but got \"${originalPath}\"`,\n RangeError\n )\n }\n\n return true\n}\n\nconst isNotRelative = path => REGEX_TEST_INVALID_PATH.test(path)\n\ncheckPath.isNotRelative = isNotRelative\ncheckPath.convert = p => p\n\nclass Ignore {\n constructor ({\n ignorecase = true,\n ignoreCase = ignorecase,\n allowRelativePaths = false\n } = {}) {\n define(this, KEY_IGNORE, true)\n\n this._rules = []\n this._ignoreCase = ignoreCase\n this._allowRelativePaths = allowRelativePaths\n this._initCache()\n }\n\n _initCache () {\n this._ignoreCache = Object.create(null)\n this._testCache = Object.create(null)\n }\n\n _addPattern (pattern) {\n // #32\n if (pattern && pattern[KEY_IGNORE]) {\n this._rules = this._rules.concat(pattern._rules)\n this._added = true\n return\n }\n\n if (checkPattern(pattern)) {\n const rule = createRule(pattern, this._ignoreCase)\n this._added = true\n this._rules.push(rule)\n }\n }\n\n // @param {Array<string> | string | Ignore} pattern\n add (pattern) {\n this._added = false\n\n makeArray(\n isString(pattern)\n ? splitPattern(pattern)\n : pattern\n ).forEach(this._addPattern, this)\n\n // Some rules have just added to the ignore,\n // making the behavior changed.\n if (this._added) {\n this._initCache()\n }\n\n return this\n }\n\n // legacy\n addPattern (pattern) {\n return this.add(pattern)\n }\n\n // | ignored : unignored\n // negative | 0:0 | 0:1 | 1:0 | 1:1\n // -------- | ------- | ------- | ------- | --------\n // 0 | TEST | TEST | SKIP | X\n // 1 | TESTIF | SKIP | TEST | X\n\n // - SKIP: always skip\n // - TEST: always test\n // - TESTIF: only test if checkUnignored\n // - X: that never happen\n\n // @param {boolean} whether should check if the path is unignored,\n // setting `checkUnignored` to `false` could reduce additional\n // path matching.\n\n // @returns {TestResult} true if a file is ignored\n _testOne (path, checkUnignored) {\n let ignored = false\n let unignored = false\n\n this._rules.forEach(rule => {\n const {negative} = rule\n if (\n unignored === negative && ignored !== unignored\n || negative && !ignored && !unignored && !checkUnignored\n ) {\n return\n }\n\n const matched = rule.regex.test(path)\n\n if (matched) {\n ignored = !negative\n unignored = negative\n }\n })\n\n return {\n ignored,\n unignored\n }\n }\n\n // @returns {TestResult}\n _test (originalPath, cache, checkUnignored, slices) {\n const path = originalPath\n // Supports nullable path\n && checkPath.convert(originalPath)\n\n checkPath(\n path,\n originalPath,\n this._allowRelativePaths\n ? RETURN_FALSE\n : throwError\n )\n\n return this._t(path, cache, checkUnignored, slices)\n }\n\n _t (path, cache, checkUnignored, slices) {\n if (path in cache) {\n return cache[path]\n }\n\n if (!slices) {\n // path/to/a.js\n // ['path', 'to', 'a.js']\n slices = path.split(SLASH)\n }\n\n slices.pop()\n\n // If the path has no parent directory, just test it\n if (!slices.length) {\n return cache[path] = this._testOne(path, checkUnignored)\n }\n\n const parent = this._t(\n slices.join(SLASH) + SLASH,\n cache,\n checkUnignored,\n slices\n )\n\n // If the path contains a parent directory, check the parent first\n return cache[path] = parent.ignored\n // > It is not possible to re-include a file if a parent directory of\n // > that file is excluded.\n ? parent\n : this._testOne(path, checkUnignored)\n }\n\n ignores (path) {\n return this._test(path, this._ignoreCache, false).ignored\n }\n\n createFilter () {\n return path => !this.ignores(path)\n }\n\n filter (paths) {\n return makeArray(paths).filter(this.createFilter())\n }\n\n // @returns {TestResult}\n test (path) {\n return this._test(path, this._testCache, true)\n }\n}\n\nconst factory = options => new Ignore(options)\n\nconst isPathValid = path =>\n checkPath(path && checkPath.convert(path), path, RETURN_FALSE)\n\nfactory.isPathValid = isPathValid\n\n// Fixes typescript\nfactory.default = factory\n\nmodule.exports = factory\n\n// Windows\n// --------------------------------------------------------------\n/* istanbul ignore if */\nif (\n // Detect `process` so that it can run in browsers.\n typeof process !== 'undefined'\n && (\n process.env && process.env.IGNORE_TEST_WIN32\n || process.platform === 'win32'\n )\n) {\n /* eslint no-control-regex: \"off\" */\n const makePosix = str => /^\\\\\\\\\\?\\\\/.test(str)\n || /[\"<>|\\u0000-\\u001F]+/u.test(str)\n ? str\n : str.replace(/\\\\/g, '/')\n\n checkPath.convert = makePosix\n\n // 'C:\\\\foo' <- 'C:\\\\foo' has been converted to 'C:/'\n // 'd:\\\\foo'\n const REGIX_IS_WINDOWS_PATH_ABSOLUTE = /^[a-z]:\\//i\n checkPath.isNotRelative = path =>\n REGIX_IS_WINDOWS_PATH_ABSOLUTE.test(path)\n || isNotRelative(path)\n}\n", "/*!\n * normalize-path <https://github.com/jonschlinkert/normalize-path>\n *\n * Copyright (c) 2014-2018, Jon Schlinkert.\n * Released under the MIT License.\n */\n\nmodule.exports = function(path, stripTrailing) {\n if (typeof path !== 'string') {\n throw new TypeError('expected path to be a string');\n }\n\n if (path === '\\\\' || path === '/') return '/';\n\n var len = path.length;\n if (len <= 1) return path;\n\n // ensure that win32 namespaces has two leading slashes, so that the path is\n // handled properly by the win32 version of path.parse() after being normalized\n // https://msdn.microsoft.com/library/windows/desktop/aa365247(v=vs.85).aspx#namespaces\n var prefix = '';\n if (len > 4 && path[3] === '\\\\') {\n var ch = path[2];\n if ((ch === '?' || ch === '.') && path.slice(0, 2) === '\\\\\\\\') {\n path = path.slice(2);\n prefix = '//';\n }\n }\n\n var segs = path.split(/[/\\\\]+/);\n if (stripTrailing !== false && segs[segs.length - 1] === '') {\n segs.pop();\n }\n return prefix + segs.join('/');\n};\n", "import fs from \"fs-extra\";\nimport type { Context } from \"../command/context.js\";\nimport { configPath } from \"../config/config.js\";\nimport { swallowEnoent } from \"../filesync/directory.js\";\nimport { memo } from \"../util/function.js\";\n\n/**\n * Reads the session from either the environment variable `GGT_SESSION`\n * or from the `session.txt` file in the config directory.\n *\n * @returns The session string if found, otherwise undefined.\n */\nexport const readSession = memo((ctx: Context): string | undefined => {\n if (process.env[\"GGT_SESSION\"]) {\n ctx.log.debug(\"reading session from env\");\n return process.env[\"GGT_SESSION\"];\n }\n\n try {\n ctx.log.debug(\"reading session from disk\");\n return fs.readFileSync(configPath(\"session.txt\"), \"utf8\");\n } catch (error) {\n swallowEnoent(error);\n return undefined;\n }\n});\n\n/**\n * Writes the session to disk in the `session.txt` file in the config.\n *\n * @param ctx - The context object.\n * @param session - The session to write to disk.\n */\nexport const writeSession = (ctx: Context, session: string | undefined): void => {\n readSession.clear();\n\n if (process.env[\"GGT_SESSION\"]) {\n ctx.log.debug(\"writing session to env\", { session: Boolean(session) });\n process.env[\"GGT_SESSION\"] = session;\n }\n\n ctx.log.debug(\"writing session to disk\", { session: Boolean(session), path: configPath(\"session.txt\") });\n\n if (session) {\n fs.outputFileSync(configPath(\"session.txt\"), session);\n } else {\n fs.removeSync(configPath(\"session.txt\"));\n }\n};\n\nexport const readToken = memo((ctx: Context): string | undefined => {\n ctx.log.debug(\"reading token from env\");\n return process.env[\"GGT_TOKEN\"];\n});\n", "/**\n * DO NOT MODIFY\n *\n * Everything in this file also exists in gadget to ensure that this logic\n * is the same between the two projects.\n */\nimport fs from \"fs-extra\";\nimport type { Ignore } from \"ignore\";\nimport ignore from \"ignore\";\nimport assert from \"node:assert\";\nimport { createHash } from \"node:crypto\";\nimport path from \"node:path\";\nimport { Transform } from \"node:stream\";\nimport { pipeline } from \"node:stream/promises\";\nimport normalizePath from \"normalize-path\";\n\n/**\n * Paths that are always ignored, regardless of the contents of the `.ignore` file.\n */\nexport const ALWAYS_IGNORE_PATHS = [\".DS_Store\", \"node_modules\", \".git\"] as const;\n\n/**\n * Paths that are ignored when hashing the directory.\n *\n * NOTE: This is the _only_ thing that is allowed to be different between gadget and ggt.\n */\nexport const HASHING_IGNORE_PATHS = [\".gadget/sync.json\", \".gadget/backup\", \"yarn-error.log\"] as const;\n\n/**\n * Represents a directory that is being synced.\n */\nexport class Directory {\n /**\n * A gitignore-style file parser used to determine which files to\n * ignore while syncing.\n *\n * @see https://www.npmjs.com/package/ignore\n */\n private _ignorer!: Ignore;\n\n /**\n * Whether the directory is currently being hashed.\n */\n private _isHashing = false;\n\n private constructor(\n /**\n * An absolute path to the directory that is being synced.\n */\n readonly path: string,\n ) {}\n\n /**\n * Initializes a directory to be synced.\n *\n * If the directory does not exist, it is created.\n *\n * @param dir - The directory to initialize.\n * @returns A Promise that resolves to a Directory instance.\n */\n static async init(dir: string): Promise<Directory> {\n const directory = new Directory(dir);\n await directory.loadIgnoreFile();\n return directory;\n }\n\n /**\n * Returns the relative path from this directory to the specified path.\n *\n * @param to - The path to which the relative path is calculated.\n * @returns The relative path from this directory to the specified path.\n */\n relative(to: string): string {\n if (!path.isAbsolute(to)) {\n // the filepath is already relative\n return to;\n }\n\n return path.relative(this.path, to);\n }\n\n /**\n * Returns the absolute path by resolving the given path segments\n * relative to the directory path.\n *\n * @param pathSegments - The path segments to resolve.\n * @returns The absolute path.\n */\n absolute(...pathSegments: string[]): string {\n const result = path.resolve(this.path, ...pathSegments);\n assert(result.startsWith(this.path), `expected ${result} to be within ${this.path}`);\n return result;\n }\n\n /**\n * Similar to {@linkcode relative} in that it converts an absolute\n * path into a relative one from {@linkcode path}. However, it also\n * changes any slashes to be posix/unix-like forward slashes,\n * condenses repeated slashes into a single slash, and adds a trailing\n * slash if the path is a directory.\n *\n * This is used when sending files to Gadget to ensure that the paths\n * are consistent across platforms.\n *\n * @see https://www.npmjs.com/package/normalize-path\n */\n normalize(filepath: string, isDirectory: boolean): string {\n if (path.isAbsolute(filepath)) {\n filepath = this.relative(filepath);\n }\n\n // true = trim trailing slashes\n filepath = normalizePath(filepath, true);\n\n if (isDirectory) {\n filepath += \"/\";\n }\n\n return filepath;\n }\n\n /**\n * Loads the `.ignore` file in the directory. If the file does not\n * exist, it is silently ignored.\n */\n async loadIgnoreFile(): Promise<void> {\n this._ignorer = ignore.default();\n this._ignorer.add(ALWAYS_IGNORE_PATHS);\n\n try {\n const content = await fs.readFile(this.absolute(\".ignore\"), \"utf8\");\n this._ignorer.add(content);\n } catch (error) {\n swallowEnoent(error);\n }\n }\n\n /**\n * Determines if a file should be ignored based on its filepath.\n *\n * @param filepath - The filepath of the file to check.\n * @returns True if the file should be ignored, false otherwise.\n */\n ignores(filepath: string): boolean {\n filepath = this.relative(filepath);\n if (filepath === \"\") {\n // don't ignore the root dir\n return false;\n }\n\n if (filepath.startsWith(\"..\")) {\n // anything above the root dir is ignored\n return true;\n }\n\n // false = don't trim trailing slashes\n filepath = normalizePath(filepath, false);\n if (this._isHashing && HASHING_IGNORE_PATHS.some((ignored) => filepath.startsWith(ignored))) {\n // special case for hashing\n return true;\n }\n\n return this._ignorer.ignores(filepath);\n }\n\n /**\n * Recursively walks through the directory and yields all non-ignored\n * files and directories within it.\n *\n * @yields - The normalized path of each file and directory.\n */\n async *walk({ dir = this.path } = {}): AsyncGenerator<string> {\n // don't yield the root directory\n if (dir !== this.path) {\n yield this.normalize(dir, true);\n }\n\n for await (const entry of await fs.opendir(dir)) {\n const filepath = path.join(dir, entry.name);\n if (this.ignores(filepath)) {\n continue;\n }\n\n if (entry.isDirectory()) {\n yield* this.walk({ dir: filepath });\n } else if (entry.isFile()) {\n yield this.normalize(filepath, false);\n }\n }\n }\n\n /**\n * Calculates the hash of each file and directory and returns an\n * object containing the hashes keyed by the normalized file path.\n *\n * @returns A Promise that resolves to an object containing the hashes\n * of each file.\n */\n async hashes(): Promise<Hashes> {\n try {\n this._isHashing = true;\n const files = {} as Hashes;\n\n for await (const normalizedPath of this.walk()) {\n const absolutePath = this.absolute(normalizedPath);\n files[normalizedPath] = await hash(absolutePath);\n }\n\n return files;\n } finally {\n this._isHashing = false;\n }\n }\n\n async hasFiles(): Promise<boolean> {\n return !(await this.isEmptyOrNonExistent());\n }\n\n async isEmptyOrNonExistent(): Promise<boolean> {\n let isEmptyOrNonExistent = true;\n try {\n for await (const _ of this.walk()) {\n isEmptyOrNonExistent = false;\n break;\n }\n } catch (error) {\n swallowEnoent(error);\n }\n return isEmptyOrNonExistent;\n }\n}\n\n/**\n * Key/value pairs where the key is the normalized path and the value is\n * the result of {@linkcode hash} for that path.\n */\nexport type Hashes = Record<string, Hash>;\n\nexport type Hash = {\n /**\n * The SHA-1 hash of the file or directory.\n *\n * If the path points to a directory, the hash is calculated based on\n * the directory's basename. If the path points to a file, the hash is\n * calculated based on the file's basename and contents.\n */\n sha1: string;\n\n /**\n * The Unix-style file permissions of the file or directory, or\n * undefined if the platform that generated this hash doesn't support\n * them.\n *\n * @example 0o644\n * @see supportsPermissions\n */\n permissions?: number;\n};\n\n/**\n * Whether the current platform supports Unix-style file permissions.\n *\n * Windows doesn't support Unix-style file permissions and all file\n * permissions retrieved via `node:fs` on Windows are translated to 666\n * or 444.\n */\nexport const supportsPermissions = process.platform === \"linux\" || process.platform === \"darwin\";\n\n/**\n * Calculates the {@linkcode Hash} of the file or directory at the\n * specified absolute path.\n *\n * @param absolutePath - The absolute path to the file or directory.\n * @returns A Promise that resolves to the {@linkcode Hash} of the file\n * or directory.\n */\nconst hash = async (absolutePath: string): Promise<Hash> => {\n const sha1 = createHash(\"sha1\");\n sha1.update(path.basename(absolutePath));\n\n const stats = await fs.stat(absolutePath);\n\n let permissions;\n if (supportsPermissions) {\n // strip everything but the permissions\n permissions = stats.mode & 0o777;\n }\n\n if (stats.isDirectory()) {\n return { sha1: sha1.digest(\"hex\"), permissions };\n }\n\n // windows uses CRLF line endings whereas unix uses LF line endings so\n // we always strip out CR bytes (0x0d) when hashing files. this does\n // make us blind to files that only differ by CR bytes, but that's a\n // tradeoff we're willing to make.\n const removeCR = new Transform({\n transform(chunk: Buffer, _encoding, callback) {\n if (!chunk.includes(0x0d)) {\n callback(undefined, chunk);\n return;\n }\n\n const filteredChunk = Buffer.alloc(chunk.length);\n let i = 0;\n for (const byte of chunk) {\n if (byte !== 0x0d) {\n filteredChunk[i++] = byte;\n }\n }\n\n callback(undefined, filteredChunk.subarray(0, i));\n },\n });\n\n await pipeline(fs.createReadStream(absolutePath), removeCR, sha1);\n\n return { sha1: sha1.digest(\"hex\"), permissions };\n};\n\n/**\n * Swallows ENOENT errors and throws any other errors.\n *\n * @param error - The error to handle.\n * @throws The original error if it is not an ENOENT error.\n */\nexport const swallowEnoent = (error: unknown): void => {\n if (error && typeof error === \"object\" && \"code\" in error && error.code === \"ENOENT\") {\n return;\n }\n throw error;\n};\n"],
5
- "mappings": "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",
6
- "names": ["require_ignore", "__commonJSMin", "exports", "module", "init_cjs", "makeArray", "subject", "EMPTY", "SPACE", "ESCAPE", "REGEX_TEST_BLANK_LINE", "REGEX_INVALID_TRAILING_BACKSLASH", "REGEX_REPLACE_LEADING_EXCAPED_EXCLAMATION", "REGEX_REPLACE_LEADING_EXCAPED_HASH", "REGEX_SPLITALL_CRLF", "REGEX_TEST_INVALID_PATH", "SLASH", "TMP_KEY_IGNORE", "KEY_IGNORE", "define", "object", "key", "value", "REGEX_REGEXP_RANGE", "RETURN_FALSE", "sanitizeRange", "range", "match", "from", "to", "cleanRangeBackSlash", "slashes", "length", "REPLACERS", "_", "m1", "m2", "index", "str", "p1", "p2", "unescaped", "leadEscape", "endEscape", "close", "regexCache", "makeRegex", "pattern", "ignoreCase", "source", "prev", "matcher", "replacer", "isString", "checkPattern", "splitPattern", "IgnoreRule", "origin", "negative", "regex", "createRule", "throwError", "message", "Ctor", "checkPath", "path", "originalPath", "doThrow", "isNotRelative", "p", "Ignore", "ignorecase", "allowRelativePaths", "rule", "checkUnignored", "ignored", "unignored", "cache", "slices", "parent", "paths", "factory", "options", "isPathValid", "makePosix", "REGIX_IS_WINDOWS_PATH_ABSOLUTE", "require_normalize_path", "__commonJSMin", "exports", "module", "init_cjs", "path", "stripTrailing", "len", "prefix", "ch", "segs", "init_cjs", "import_fs_extra", "init_cjs", "import_fs_extra", "import_ignore", "import_normalize_path", "assert", "createHash", "path", "Transform", "pipeline", "ALWAYS_IGNORE_PATHS", "HASHING_IGNORE_PATHS", "Directory", "_Directory", "dir", "directory", "to", "pathSegments", "result", "filepath", "isDirectory", "normalizePath", "ignore", "content", "fs", "error", "swallowEnoent", "ignored", "entry", "files", "normalizedPath", "absolutePath", "hash", "isEmptyOrNonExistent", "_", "supportsPermissions", "sha1", "stats", "permissions", "removeCR", "chunk", "_encoding", "callback", "filteredChunk", "i", "byte", "readSession", "memo", "ctx", "fs", "configPath", "error", "swallowEnoent", "writeSession", "session", "readToken"]
3
+ "sources": ["../node_modules/.pnpm/ignore@6.0.2/node_modules/ignore/index.js", "../node_modules/.pnpm/normalize-path@3.0.0/node_modules/normalize-path/index.js", "../src/services/user/session.ts", "../src/services/filesync/directory.ts"],
4
+ "sourcesContent": ["// A simple implementation of make-array\nfunction makeArray (subject) {\n return Array.isArray(subject)\n ? subject\n : [subject]\n}\n\nconst EMPTY = ''\nconst SPACE = ' '\nconst ESCAPE = '\\\\'\nconst REGEX_TEST_BLANK_LINE = /^\\s+$/\nconst REGEX_INVALID_TRAILING_BACKSLASH = /(?:[^\\\\]|^)\\\\$/\nconst REGEX_REPLACE_LEADING_EXCAPED_EXCLAMATION = /^\\\\!/\nconst REGEX_REPLACE_LEADING_EXCAPED_HASH = /^\\\\#/\nconst REGEX_SPLITALL_CRLF = /\\r?\\n/g\n// /foo,\n// ./foo,\n// ../foo,\n// .\n// ..\nconst REGEX_TEST_INVALID_PATH = /^\\.*\\/|^\\.+$/\n\nconst SLASH = '/'\n\n// Do not use ternary expression here, since \"istanbul ignore next\" is buggy\nlet TMP_KEY_IGNORE = 'node-ignore'\n/* istanbul ignore else */\nif (typeof Symbol !== 'undefined') {\n TMP_KEY_IGNORE = Symbol.for('node-ignore')\n}\nconst KEY_IGNORE = TMP_KEY_IGNORE\n\nconst define = (object, key, value) =>\n Object.defineProperty(object, key, {value})\n\nconst REGEX_REGEXP_RANGE = /([0-z])-([0-z])/g\n\nconst RETURN_FALSE = () => false\n\n// Sanitize the range of a regular expression\n// The cases are complicated, see test cases for details\nconst sanitizeRange = range => range.replace(\n REGEX_REGEXP_RANGE,\n (match, from, to) => from.charCodeAt(0) <= to.charCodeAt(0)\n ? match\n // Invalid range (out of order) which is ok for gitignore rules but\n // fatal for JavaScript regular expression, so eliminate it.\n : EMPTY\n)\n\n// See fixtures #59\nconst cleanRangeBackSlash = slashes => {\n const {length} = slashes\n return slashes.slice(0, length - length % 2)\n}\n\n// > If the pattern ends with a slash,\n// > it is removed for the purpose of the following description,\n// > but it would only find a match with a directory.\n// > In other words, foo/ will match a directory foo and paths underneath it,\n// > but will not match a regular file or a symbolic link foo\n// > (this is consistent with the way how pathspec works in general in Git).\n// '`foo/`' will not match regular file '`foo`' or symbolic link '`foo`'\n// -> ignore-rules will not deal with it, because it costs extra `fs.stat` call\n// you could use option `mark: true` with `glob`\n\n// '`foo/`' should not continue with the '`..`'\nconst REPLACERS = [\n\n [\n // remove BOM\n // TODO:\n // Other similar zero-width characters?\n /^\\uFEFF/,\n () => EMPTY\n ],\n\n // > Trailing spaces are ignored unless they are quoted with backslash (\"\\\")\n [\n // (a\\ ) -> (a )\n // (a ) -> (a)\n // (a ) -> (a)\n // (a \\ ) -> (a )\n /((?:\\\\\\\\)*?)(\\\\?\\s+)$/,\n (_, m1, m2) => m1 + (\n m2.indexOf('\\\\') === 0\n ? SPACE\n : EMPTY\n )\n ],\n\n // replace (\\ ) with ' '\n // (\\ ) -> ' '\n // (\\\\ ) -> '\\\\ '\n // (\\\\\\ ) -> '\\\\ '\n [\n /(\\\\+?)\\s/g,\n (_, m1) => {\n const {length} = m1\n return m1.slice(0, length - length % 2) + SPACE\n }\n ],\n\n // Escape metacharacters\n // which is written down by users but means special for regular expressions.\n\n // > There are 12 characters with special meanings:\n // > - the backslash \\,\n // > - the caret ^,\n // > - the dollar sign $,\n // > - the period or dot .,\n // > - the vertical bar or pipe symbol |,\n // > - the question mark ?,\n // > - the asterisk or star *,\n // > - the plus sign +,\n // > - the opening parenthesis (,\n // > - the closing parenthesis ),\n // > - and the opening square bracket [,\n // > - the opening curly brace {,\n // > These special characters are often called \"metacharacters\".\n [\n /[\\\\$.|*+(){^]/g,\n match => `\\\\${match}`\n ],\n\n [\n // > a question mark (?) matches a single character\n /(?!\\\\)\\?/g,\n () => '[^/]'\n ],\n\n // leading slash\n [\n\n // > A leading slash matches the beginning of the pathname.\n // > For example, \"/*.c\" matches \"cat-file.c\" but not \"mozilla-sha1/sha1.c\".\n // A leading slash matches the beginning of the pathname\n /^\\//,\n () => '^'\n ],\n\n // replace special metacharacter slash after the leading slash\n [\n /\\//g,\n () => '\\\\/'\n ],\n\n [\n // > A leading \"**\" followed by a slash means match in all directories.\n // > For example, \"**/foo\" matches file or directory \"foo\" anywhere,\n // > the same as pattern \"foo\".\n // > \"**/foo/bar\" matches file or directory \"bar\" anywhere that is directly\n // > under directory \"foo\".\n // Notice that the '*'s have been replaced as '\\\\*'\n /^\\^*\\\\\\*\\\\\\*\\\\\\//,\n\n // '**/foo' <-> 'foo'\n () => '^(?:.*\\\\/)?'\n ],\n\n // starting\n [\n // there will be no leading '/'\n // (which has been replaced by section \"leading slash\")\n // If starts with '**', adding a '^' to the regular expression also works\n /^(?=[^^])/,\n function startingReplacer () {\n // If has a slash `/` at the beginning or middle\n return !/\\/(?!$)/.test(this)\n // > Prior to 2.22.1\n // > If the pattern does not contain a slash /,\n // > Git treats it as a shell glob pattern\n // Actually, if there is only a trailing slash,\n // git also treats it as a shell glob pattern\n\n // After 2.22.1 (compatible but clearer)\n // > If there is a separator at the beginning or middle (or both)\n // > of the pattern, then the pattern is relative to the directory\n // > level of the particular .gitignore file itself.\n // > Otherwise the pattern may also match at any level below\n // > the .gitignore level.\n ? '(?:^|\\\\/)'\n\n // > Otherwise, Git treats the pattern as a shell glob suitable for\n // > consumption by fnmatch(3)\n : '^'\n }\n ],\n\n // two globstars\n [\n // Use lookahead assertions so that we could match more than one `'/**'`\n /\\\\\\/\\\\\\*\\\\\\*(?=\\\\\\/|$)/g,\n\n // Zero, one or several directories\n // should not use '*', or it will be replaced by the next replacer\n\n // Check if it is not the last `'/**'`\n (_, index, str) => index + 6 < str.length\n\n // case: /**/\n // > A slash followed by two consecutive asterisks then a slash matches\n // > zero or more directories.\n // > For example, \"a/**/b\" matches \"a/b\", \"a/x/b\", \"a/x/y/b\" and so on.\n // '/**/'\n ? '(?:\\\\/[^\\\\/]+)*'\n\n // case: /**\n // > A trailing `\"/**\"` matches everything inside.\n\n // #21: everything inside but it should not include the current folder\n : '\\\\/.+'\n ],\n\n // normal intermediate wildcards\n [\n // Never replace escaped '*'\n // ignore rule '\\*' will match the path '*'\n\n // 'abc.*/' -> go\n // 'abc.*' -> skip this rule,\n // coz trailing single wildcard will be handed by [trailing wildcard]\n /(^|[^\\\\]+)(\\\\\\*)+(?=.+)/g,\n\n // '*.js' matches '.js'\n // '*.js' doesn't match 'abc'\n (_, p1, p2) => {\n // 1.\n // > An asterisk \"*\" matches anything except a slash.\n // 2.\n // > Other consecutive asterisks are considered regular asterisks\n // > and will match according to the previous rules.\n const unescaped = p2.replace(/\\\\\\*/g, '[^\\\\/]*')\n return p1 + unescaped\n }\n ],\n\n [\n // unescape, revert step 3 except for back slash\n // For example, if a user escape a '\\\\*',\n // after step 3, the result will be '\\\\\\\\\\\\*'\n /\\\\\\\\\\\\(?=[$.|*+(){^])/g,\n () => ESCAPE\n ],\n\n [\n // '\\\\\\\\' -> '\\\\'\n /\\\\\\\\/g,\n () => ESCAPE\n ],\n\n [\n // > The range notation, e.g. [a-zA-Z],\n // > can be used to match one of the characters in a range.\n\n // `\\` is escaped by step 3\n /(\\\\)?\\[([^\\]/]*?)(\\\\*)($|\\])/g,\n (match, leadEscape, range, endEscape, close) => leadEscape === ESCAPE\n // '\\\\[bar]' -> '\\\\\\\\[bar\\\\]'\n ? `\\\\[${range}${cleanRangeBackSlash(endEscape)}${close}`\n : close === ']'\n ? endEscape.length % 2 === 0\n // A normal case, and it is a range notation\n // '[bar]'\n // '[bar\\\\\\\\]'\n ? `[${sanitizeRange(range)}${endEscape}]`\n // Invalid range notaton\n // '[bar\\\\]' -> '[bar\\\\\\\\]'\n : '[]'\n : '[]'\n ],\n\n // ending\n [\n // 'js' will not match 'js.'\n // 'ab' will not match 'abc'\n /(?:[^*])$/,\n\n // WTF!\n // https://git-scm.com/docs/gitignore\n // changes in [2.22.1](https://git-scm.com/docs/gitignore/2.22.1)\n // which re-fixes #24, #38\n\n // > If there is a separator at the end of the pattern then the pattern\n // > will only match directories, otherwise the pattern can match both\n // > files and directories.\n\n // 'js*' will not match 'a.js'\n // 'js/' will not match 'a.js'\n // 'js' will match 'a.js' and 'a.js/'\n match => /\\/$/.test(match)\n // foo/ will not match 'foo'\n ? `${match}$`\n // foo matches 'foo' and 'foo/'\n : `${match}(?=$|\\\\/$)`\n ],\n\n // trailing wildcard\n [\n /(\\^|\\\\\\/)?\\\\\\*$/,\n (_, p1) => {\n const prefix = p1\n // '\\^':\n // '/*' does not match EMPTY\n // '/*' does not match everything\n\n // '\\\\\\/':\n // 'abc/*' does not match 'abc/'\n ? `${p1}[^/]+`\n\n // 'a*' matches 'a'\n // 'a*' matches 'aa'\n : '[^/]*'\n\n return `${prefix}(?=$|\\\\/$)`\n }\n ],\n]\n\n// A simple cache, because an ignore rule only has only one certain meaning\nconst regexCache = Object.create(null)\n\n// @param {pattern}\nconst makeRegex = (pattern, ignoreCase) => {\n let source = regexCache[pattern]\n\n if (!source) {\n source = REPLACERS.reduce(\n (prev, [matcher, replacer]) =>\n prev.replace(matcher, replacer.bind(pattern)),\n pattern\n )\n regexCache[pattern] = source\n }\n\n return ignoreCase\n ? new RegExp(source, 'i')\n : new RegExp(source)\n}\n\nconst isString = subject => typeof subject === 'string'\n\n// > A blank line matches no files, so it can serve as a separator for readability.\nconst checkPattern = pattern => pattern\n && isString(pattern)\n && !REGEX_TEST_BLANK_LINE.test(pattern)\n && !REGEX_INVALID_TRAILING_BACKSLASH.test(pattern)\n\n // > A line starting with # serves as a comment.\n && pattern.indexOf('#') !== 0\n\nconst splitPattern = pattern => pattern.split(REGEX_SPLITALL_CRLF)\n\nclass IgnoreRule {\n constructor (\n origin,\n pattern,\n negative,\n regex\n ) {\n this.origin = origin\n this.pattern = pattern\n this.negative = negative\n this.regex = regex\n }\n}\n\nconst createRule = (pattern, ignoreCase) => {\n const origin = pattern\n let negative = false\n\n // > An optional prefix \"!\" which negates the pattern;\n if (pattern.indexOf('!') === 0) {\n negative = true\n pattern = pattern.substr(1)\n }\n\n pattern = pattern\n // > Put a backslash (\"\\\") in front of the first \"!\" for patterns that\n // > begin with a literal \"!\", for example, `\"\\!important!.txt\"`.\n .replace(REGEX_REPLACE_LEADING_EXCAPED_EXCLAMATION, '!')\n // > Put a backslash (\"\\\") in front of the first hash for patterns that\n // > begin with a hash.\n .replace(REGEX_REPLACE_LEADING_EXCAPED_HASH, '#')\n\n const regex = makeRegex(pattern, ignoreCase)\n\n return new IgnoreRule(\n origin,\n pattern,\n negative,\n regex\n )\n}\n\nconst throwError = (message, Ctor) => {\n throw new Ctor(message)\n}\n\nconst checkPath = (path, originalPath, doThrow) => {\n if (!isString(path)) {\n return doThrow(\n `path must be a string, but got \\`${originalPath}\\``,\n TypeError\n )\n }\n\n // We don't know if we should ignore EMPTY, so throw\n if (!path) {\n return doThrow(`path must not be empty`, TypeError)\n }\n\n // Check if it is a relative path\n if (checkPath.isNotRelative(path)) {\n const r = '`path.relative()`d'\n return doThrow(\n `path should be a ${r} string, but got \"${originalPath}\"`,\n RangeError\n )\n }\n\n return true\n}\n\nconst isNotRelative = path => REGEX_TEST_INVALID_PATH.test(path)\n\ncheckPath.isNotRelative = isNotRelative\ncheckPath.convert = p => p\n\nclass Ignore {\n constructor ({\n ignorecase = true,\n ignoreCase = ignorecase,\n allowRelativePaths = false\n } = {}) {\n define(this, KEY_IGNORE, true)\n\n this._rules = []\n this._ignoreCase = ignoreCase\n this._allowRelativePaths = allowRelativePaths\n this._initCache()\n }\n\n _initCache () {\n this._ignoreCache = Object.create(null)\n this._testCache = Object.create(null)\n }\n\n _addPattern (pattern) {\n // #32\n if (pattern && pattern[KEY_IGNORE]) {\n this._rules = this._rules.concat(pattern._rules)\n this._added = true\n return\n }\n\n if (checkPattern(pattern)) {\n const rule = createRule(pattern, this._ignoreCase)\n this._added = true\n this._rules.push(rule)\n }\n }\n\n // @param {Array<string> | string | Ignore} pattern\n add (pattern) {\n this._added = false\n\n makeArray(\n isString(pattern)\n ? splitPattern(pattern)\n : pattern\n ).forEach(this._addPattern, this)\n\n // Some rules have just added to the ignore,\n // making the behavior changed.\n if (this._added) {\n this._initCache()\n }\n\n return this\n }\n\n // legacy\n addPattern (pattern) {\n return this.add(pattern)\n }\n\n // | ignored : unignored\n // negative | 0:0 | 0:1 | 1:0 | 1:1\n // -------- | ------- | ------- | ------- | --------\n // 0 | TEST | TEST | SKIP | X\n // 1 | TESTIF | SKIP | TEST | X\n\n // - SKIP: always skip\n // - TEST: always test\n // - TESTIF: only test if checkUnignored\n // - X: that never happen\n\n // @param {boolean} whether should check if the path is unignored,\n // setting `checkUnignored` to `false` could reduce additional\n // path matching.\n\n // @returns {TestResult} true if a file is ignored\n _testOne (path, checkUnignored) {\n let ignored = false\n let unignored = false\n\n this._rules.forEach(rule => {\n const {negative} = rule\n if (\n unignored === negative && ignored !== unignored\n || negative && !ignored && !unignored && !checkUnignored\n ) {\n return\n }\n\n const matched = rule.regex.test(path)\n\n if (matched) {\n ignored = !negative\n unignored = negative\n }\n })\n\n return {\n ignored,\n unignored\n }\n }\n\n // @returns {TestResult}\n _test (originalPath, cache, checkUnignored, slices) {\n const path = originalPath\n // Supports nullable path\n && checkPath.convert(originalPath)\n\n checkPath(\n path,\n originalPath,\n this._allowRelativePaths\n ? RETURN_FALSE\n : throwError\n )\n\n return this._t(path, cache, checkUnignored, slices)\n }\n\n _t (path, cache, checkUnignored, slices) {\n if (path in cache) {\n return cache[path]\n }\n\n if (!slices) {\n // path/to/a.js\n // ['path', 'to', 'a.js']\n slices = path.split(SLASH)\n }\n\n slices.pop()\n\n // If the path has no parent directory, just test it\n if (!slices.length) {\n return cache[path] = this._testOne(path, checkUnignored)\n }\n\n const parent = this._t(\n slices.join(SLASH) + SLASH,\n cache,\n checkUnignored,\n slices\n )\n\n // If the path contains a parent directory, check the parent first\n return cache[path] = parent.ignored\n // > It is not possible to re-include a file if a parent directory of\n // > that file is excluded.\n ? parent\n : this._testOne(path, checkUnignored)\n }\n\n ignores (path) {\n return this._test(path, this._ignoreCache, false).ignored\n }\n\n createFilter () {\n return path => !this.ignores(path)\n }\n\n filter (paths) {\n return makeArray(paths).filter(this.createFilter())\n }\n\n // @returns {TestResult}\n test (path) {\n return this._test(path, this._testCache, true)\n }\n}\n\nconst factory = options => new Ignore(options)\n\nconst isPathValid = path =>\n checkPath(path && checkPath.convert(path), path, RETURN_FALSE)\n\nfactory.isPathValid = isPathValid\n\n// Fixes typescript\nfactory.default = factory\n\nmodule.exports = factory\n\n// Windows\n// --------------------------------------------------------------\n/* istanbul ignore if */\nif (\n // Detect `process` so that it can run in browsers.\n typeof process !== 'undefined'\n && (\n process.env && process.env.IGNORE_TEST_WIN32\n || process.platform === 'win32'\n )\n) {\n /* eslint no-control-regex: \"off\" */\n const makePosix = str => /^\\\\\\\\\\?\\\\/.test(str)\n || /[\"<>|\\u0000-\\u001F]+/u.test(str)\n ? str\n : str.replace(/\\\\/g, '/')\n\n checkPath.convert = makePosix\n\n // 'C:\\\\foo' <- 'C:\\\\foo' has been converted to 'C:/'\n // 'd:\\\\foo'\n const REGIX_IS_WINDOWS_PATH_ABSOLUTE = /^[a-z]:\\//i\n checkPath.isNotRelative = path =>\n REGIX_IS_WINDOWS_PATH_ABSOLUTE.test(path)\n || isNotRelative(path)\n}\n", "/*!\n * normalize-path <https://github.com/jonschlinkert/normalize-path>\n *\n * Copyright (c) 2014-2018, Jon Schlinkert.\n * Released under the MIT License.\n */\n\nmodule.exports = function(path, stripTrailing) {\n if (typeof path !== 'string') {\n throw new TypeError('expected path to be a string');\n }\n\n if (path === '\\\\' || path === '/') return '/';\n\n var len = path.length;\n if (len <= 1) return path;\n\n // ensure that win32 namespaces has two leading slashes, so that the path is\n // handled properly by the win32 version of path.parse() after being normalized\n // https://msdn.microsoft.com/library/windows/desktop/aa365247(v=vs.85).aspx#namespaces\n var prefix = '';\n if (len > 4 && path[3] === '\\\\') {\n var ch = path[2];\n if ((ch === '?' || ch === '.') && path.slice(0, 2) === '\\\\\\\\') {\n path = path.slice(2);\n prefix = '//';\n }\n }\n\n var segs = path.split(/[/\\\\]+/);\n if (stripTrailing !== false && segs[segs.length - 1] === '') {\n segs.pop();\n }\n return prefix + segs.join('/');\n};\n", "import fs from \"fs-extra\";\nimport type { Context } from \"../command/context.js\";\nimport { configPath } from \"../config/config.js\";\nimport { swallowEnoent } from \"../filesync/directory.js\";\nimport { memo } from \"../util/function.js\";\n\n/**\n * Reads the session from either the environment variable `GGT_SESSION`\n * or from the `session.txt` file in the config directory.\n *\n * @returns The session string if found, otherwise undefined.\n */\nexport const readSession = memo((ctx: Context): string | undefined => {\n if (process.env[\"GGT_SESSION\"]) {\n ctx.log.debug(\"reading session from env\");\n return process.env[\"GGT_SESSION\"];\n }\n\n try {\n ctx.log.debug(\"reading session from disk\");\n return fs.readFileSync(configPath(\"session.txt\"), \"utf8\");\n } catch (error) {\n swallowEnoent(error);\n return undefined;\n }\n});\n\n/**\n * Writes the session to disk in the `session.txt` file in the config.\n *\n * @param ctx - The context object.\n * @param session - The session to write to disk.\n */\nexport const writeSession = (ctx: Context, session: string | undefined): void => {\n readSession.clear();\n\n if (process.env[\"GGT_SESSION\"]) {\n ctx.log.debug(\"writing session to env\", { session: Boolean(session) });\n process.env[\"GGT_SESSION\"] = session;\n }\n\n ctx.log.debug(\"writing session to disk\", { session: Boolean(session), path: configPath(\"session.txt\") });\n\n if (session) {\n fs.outputFileSync(configPath(\"session.txt\"), session);\n } else {\n fs.removeSync(configPath(\"session.txt\"));\n }\n};\n\nexport const readToken = memo((ctx: Context): string | undefined => {\n ctx.log.debug(\"reading token from env\");\n return process.env[\"GGT_TOKEN\"];\n});\n", "/**\n * DO NOT MODIFY\n *\n * Everything in this file also exists in gadget to ensure that this logic\n * is the same between the two projects.\n */\nimport fs from \"fs-extra\";\nimport type { Ignore } from \"ignore\";\nimport ignore from \"ignore\";\nimport assert from \"node:assert\";\nimport { createHash } from \"node:crypto\";\nimport path from \"node:path\";\nimport { Transform } from \"node:stream\";\nimport { pipeline } from \"node:stream/promises\";\nimport normalizePath from \"normalize-path\";\n\n/**\n * Paths that are never ignored, regardless of the contents of the `.ignore` file.\n */\nexport const NEVER_IGNORE_PATHS = [\".gadget/\"] as const;\n\n/**\n * Paths that are always ignored, regardless of the contents of the `.ignore` file.\n */\nexport const ALWAYS_IGNORE_PATHS = [\".DS_Store\", \"node_modules\", \".git\"] as const;\n\n/**\n * Paths that are ignored when hashing the directory.\n *\n * NOTE: This is the _only_ thing that is allowed to be different between gadget and ggt.\n */\nexport const HASHING_IGNORE_PATHS = [\".gadget/sync.json\", \".gadget/backup\", \"yarn-error.log\"] as const;\n\n/**\n * Represents a directory that is being synced.\n */\nexport class Directory {\n /**\n * A gitignore-style file parser used to determine which files to\n * ignore while syncing.\n *\n * @see https://www.npmjs.com/package/ignore\n */\n private _ignorer!: Ignore;\n\n /**\n * Whether the directory is currently being hashed.\n */\n private _isHashing = false;\n\n private constructor(\n /**\n * An absolute path to the directory that is being synced.\n */\n readonly path: string,\n ) {}\n\n /**\n * Initializes a directory to be synced.\n *\n * If the directory does not exist, it is created.\n *\n * @param dir - The directory to initialize.\n * @returns A Promise that resolves to a Directory instance.\n */\n static async init(dir: string): Promise<Directory> {\n const directory = new Directory(dir);\n await directory.loadIgnoreFile();\n return directory;\n }\n\n /**\n * Returns the relative path from this directory to the specified path.\n *\n * @param to - The path to which the relative path is calculated.\n * @returns The relative path from this directory to the specified path.\n */\n relative(to: string): string {\n if (!path.isAbsolute(to)) {\n // the filepath is already relative\n return to;\n }\n\n return path.relative(this.path, to);\n }\n\n /**\n * Returns the absolute path by resolving the given path segments\n * relative to the directory path.\n *\n * @param pathSegments - The path segments to resolve.\n * @returns The absolute path.\n */\n absolute(...pathSegments: string[]): string {\n const result = path.resolve(this.path, ...pathSegments);\n assert(result.startsWith(this.path), `expected ${result} to be within ${this.path}`);\n return result;\n }\n\n /**\n * Similar to {@linkcode relative} in that it converts an absolute\n * path into a relative one from {@linkcode path}. However, it also\n * changes any slashes to be posix/unix-like forward slashes,\n * condenses repeated slashes into a single slash, and adds a trailing\n * slash if the path is a directory.\n *\n * This is used when sending files to Gadget to ensure that the paths\n * are consistent across platforms.\n *\n * @see https://www.npmjs.com/package/normalize-path\n */\n normalize(filepath: string, isDirectory: boolean): string {\n if (path.isAbsolute(filepath)) {\n filepath = this.relative(filepath);\n }\n\n // true = trim trailing slashes\n filepath = normalizePath(filepath, true);\n\n if (isDirectory) {\n filepath += \"/\";\n }\n\n return filepath;\n }\n\n /**\n * Loads the `.ignore` file in the directory. If the file does not\n * exist, it is silently ignored.\n */\n async loadIgnoreFile(): Promise<void> {\n this._ignorer = ignore.default();\n this._ignorer.add(ALWAYS_IGNORE_PATHS);\n\n try {\n const content = await fs.readFile(this.absolute(\".ignore\"), \"utf8\");\n this._ignorer.add(content);\n } catch (error) {\n swallowEnoent(error);\n }\n }\n\n /**\n * Determines if a file should be ignored based on its filepath.\n *\n * @param filepath - The filepath of the file to check.\n * @returns True if the file should be ignored, false otherwise.\n */\n ignores(filepath: string): boolean {\n filepath = this.relative(filepath);\n if (filepath === \"\") {\n // don't ignore the root dir\n return false;\n }\n\n if (filepath.startsWith(\"..\")) {\n // anything above the root dir is ignored\n return true;\n }\n\n // false = don't trim trailing slashes\n filepath = normalizePath(filepath, false);\n if (this._isHashing && HASHING_IGNORE_PATHS.some((ignored) => filepath.startsWith(ignored))) {\n // special case for hashing\n return true;\n }\n\n if (NEVER_IGNORE_PATHS.some((neverIgnored) => filepath.startsWith(neverIgnored))) {\n // special case for never ignored paths\n return false;\n }\n\n return this._ignorer.ignores(filepath);\n }\n\n /**\n * Recursively walks through the directory and yields all non-ignored\n * files and directories within it.\n *\n * @yields - The normalized path of each file and directory.\n */\n async *walk({ dir = this.path } = {}): AsyncGenerator<string> {\n // don't yield the root directory\n if (dir !== this.path) {\n yield this.normalize(dir, true);\n }\n\n for await (const entry of await fs.opendir(dir)) {\n const filepath = path.join(dir, entry.name);\n if (this.ignores(filepath)) {\n continue;\n }\n\n if (entry.isDirectory()) {\n yield* this.walk({ dir: filepath });\n } else if (entry.isFile()) {\n yield this.normalize(filepath, false);\n }\n }\n }\n\n /**\n * Calculates the hash of each file and directory and returns an\n * object containing the hashes keyed by the normalized file path.\n *\n * @returns A Promise that resolves to an object containing the hashes\n * of each file.\n */\n async hashes(): Promise<Hashes> {\n try {\n this._isHashing = true;\n const files = {} as Hashes;\n\n for await (const normalizedPath of this.walk()) {\n const absolutePath = this.absolute(normalizedPath);\n files[normalizedPath] = await hash(absolutePath);\n }\n\n return files;\n } finally {\n this._isHashing = false;\n }\n }\n\n async hasFiles(): Promise<boolean> {\n return !(await this.isEmptyOrNonExistent());\n }\n\n async isEmptyOrNonExistent(): Promise<boolean> {\n let isEmptyOrNonExistent = true;\n try {\n for await (const _ of this.walk()) {\n isEmptyOrNonExistent = false;\n break;\n }\n } catch (error) {\n swallowEnoent(error);\n }\n return isEmptyOrNonExistent;\n }\n}\n\n/**\n * Key/value pairs where the key is the normalized path and the value is\n * the result of {@linkcode hash} for that path.\n */\nexport type Hashes = Record<string, Hash>;\n\nexport type Hash = {\n /**\n * The SHA-1 hash of the file or directory.\n *\n * If the path points to a directory, the hash is calculated based on\n * the directory's basename. If the path points to a file, the hash is\n * calculated based on the file's basename and contents.\n */\n sha1: string;\n\n /**\n * The Unix-style file permissions of the file or directory, or\n * undefined if the platform that generated this hash doesn't support\n * them.\n *\n * @example 0o644\n * @see supportsPermissions\n */\n permissions?: number;\n};\n\n/**\n * Whether the current platform supports Unix-style file permissions.\n *\n * Windows doesn't support Unix-style file permissions and all file\n * permissions retrieved via `node:fs` on Windows are translated to 666\n * or 444.\n */\nexport const supportsPermissions = process.platform === \"linux\" || process.platform === \"darwin\";\n\n/**\n * Calculates the {@linkcode Hash} of the file or directory at the\n * specified absolute path.\n *\n * @param absolutePath - The absolute path to the file or directory.\n * @returns A Promise that resolves to the {@linkcode Hash} of the file\n * or directory.\n */\nconst hash = async (absolutePath: string): Promise<Hash> => {\n const sha1 = createHash(\"sha1\");\n sha1.update(path.basename(absolutePath));\n\n const stats = await fs.stat(absolutePath);\n\n let permissions;\n if (supportsPermissions) {\n // strip everything but the permissions\n permissions = stats.mode & 0o777;\n }\n\n if (stats.isDirectory()) {\n return { sha1: sha1.digest(\"hex\"), permissions };\n }\n\n // windows uses CRLF line endings whereas unix uses LF line endings so\n // we always strip out CR bytes (0x0d) when hashing files. this does\n // make us blind to files that only differ by CR bytes, but that's a\n // tradeoff we're willing to make.\n const removeCR = new Transform({\n transform(chunk: Buffer, _encoding, callback) {\n if (!chunk.includes(0x0d)) {\n callback(undefined, chunk);\n return;\n }\n\n const filteredChunk = Buffer.alloc(chunk.length);\n let i = 0;\n for (const byte of chunk) {\n if (byte !== 0x0d) {\n filteredChunk[i++] = byte;\n }\n }\n\n callback(undefined, filteredChunk.subarray(0, i));\n },\n });\n\n await pipeline(fs.createReadStream(absolutePath), removeCR, sha1);\n\n return { sha1: sha1.digest(\"hex\"), permissions };\n};\n\n/**\n * Swallows ENOENT errors and throws any other errors.\n *\n * @param error - The error to handle.\n * @throws The original error if it is not an ENOENT error.\n */\nexport const swallowEnoent = (error: unknown): void => {\n if (error && typeof error === \"object\" && \"code\" in error && error.code === \"ENOENT\") {\n return;\n }\n throw error;\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["require_ignore", "__commonJSMin", "exports", "module", "init_cjs", "makeArray", "subject", "EMPTY", "SPACE", "ESCAPE", "REGEX_TEST_BLANK_LINE", "REGEX_INVALID_TRAILING_BACKSLASH", "REGEX_REPLACE_LEADING_EXCAPED_EXCLAMATION", "REGEX_REPLACE_LEADING_EXCAPED_HASH", "REGEX_SPLITALL_CRLF", "REGEX_TEST_INVALID_PATH", "SLASH", "TMP_KEY_IGNORE", "KEY_IGNORE", "define", "object", "key", "value", "REGEX_REGEXP_RANGE", "RETURN_FALSE", "sanitizeRange", "range", "match", "from", "to", "cleanRangeBackSlash", "slashes", "length", "REPLACERS", "_", "m1", "m2", "index", "str", "p1", "p2", "unescaped", "leadEscape", "endEscape", "close", "regexCache", "makeRegex", "pattern", "ignoreCase", "source", "prev", "matcher", "replacer", "isString", "checkPattern", "splitPattern", "IgnoreRule", "origin", "negative", "regex", "createRule", "throwError", "message", "Ctor", "checkPath", "path", "originalPath", "doThrow", "isNotRelative", "p", "Ignore", "ignorecase", "allowRelativePaths", "rule", "checkUnignored", "ignored", "unignored", "cache", "slices", "parent", "paths", "factory", "options", "isPathValid", "makePosix", "REGIX_IS_WINDOWS_PATH_ABSOLUTE", "require_normalize_path", "__commonJSMin", "exports", "module", "init_cjs", "path", "stripTrailing", "len", "prefix", "ch", "segs", "init_cjs", "import_fs_extra", "init_cjs", "import_fs_extra", "import_ignore", "import_normalize_path", "assert", "createHash", "path", "Transform", "pipeline", "NEVER_IGNORE_PATHS", "ALWAYS_IGNORE_PATHS", "HASHING_IGNORE_PATHS", "Directory", "_Directory", "dir", "directory", "to", "pathSegments", "result", "filepath", "isDirectory", "normalizePath", "ignore", "content", "fs", "error", "swallowEnoent", "ignored", "neverIgnored", "entry", "files", "normalizedPath", "absolutePath", "hash", "isEmptyOrNonExistent", "_", "supportsPermissions", "sha1", "stats", "permissions", "removeCR", "chunk", "_encoding", "callback", "filteredChunk", "i", "byte", "readSession", "memo", "ctx", "fs", "configPath", "error", "swallowEnoent", "writeSession", "session", "readToken"]
7
7
  }
@@ -0,0 +1,2 @@
1
+ import{c as m,g as l,h as Z,i as b,j as O,k as M,l as Or,m as v,n as C,o as Cr,p as Ar}from"./chunk-SGMPMYEU.js";var te=m((tn,re)=>{l();var ee=v(),Lr=(t,e,r,s,i)=>{typeof r=="string"&&(i=s,s=r,r=void 0);try{return new ee(t instanceof ee?t.version:t,r).inc(e,s,i).version}catch{return null}};re.exports=Lr});var ie=m((nn,ne)=>{l();var se=C(),jr=(t,e)=>{let r=se(t,null,!0),s=se(e,null,!0),i=r.compare(s);if(i===0)return null;let n=i>0,o=n?r:s,c=n?s:r,a=!!o.prerelease.length;if(!!c.prerelease.length&&!a)return!c.patch&&!c.minor?"major":o.patch?"patch":o.minor?"minor":"major";let p=a?"pre":"";return r.major!==s.major?p+"major":r.minor!==s.minor?p+"minor":r.patch!==s.patch?p+"patch":"prerelease"};ne.exports=jr});var le=m((ln,oe)=>{l();var Vr=v(),Ir=(t,e)=>new Vr(t,e).major;oe.exports=Ir});var ae=m((an,ce)=>{l();var Nr=v(),Gr=(t,e)=>new Nr(t,e).minor;ce.exports=Gr});var fe=m((fn,ue)=>{l();var Wr=v(),Yr=(t,e)=>new Wr(t,e).patch;ue.exports=Yr});var pe=m((pn,he)=>{l();var Dr=C(),Hr=(t,e)=>{let r=Dr(t,e);return r&&r.prerelease.length?r.prerelease:null};he.exports=Hr});var R=m((qn,qe)=>{l();var me=v(),Xr=(t,e,r)=>new me(t,r).compare(new me(e,r));qe.exports=Xr});var de=m((dn,$e)=>{l();var kr=R(),Br=(t,e,r)=>kr(e,t,r);$e.exports=Br});var ve=m((vn,we)=>{l();var _r=R(),zr=(t,e)=>_r(t,e,!0);we.exports=zr});var A=m((Rn,Re)=>{l();var ge=v(),Fr=(t,e,r)=>{let s=new ge(t,r),i=new ge(e,r);return s.compare(i)||s.compareBuild(i)};Re.exports=Fr});var Se=m((Sn,Ee)=>{l();var Ur=A(),Kr=(t,e)=>t.sort((r,s)=>Ur(r,s,e));Ee.exports=Kr});var Te=m((Tn,xe)=>{l();var Jr=A(),Qr=(t,e)=>t.sort((r,s)=>Jr(s,r,e));xe.exports=Qr});var S=m((Pn,ye)=>{l();var Zr=R(),br=(t,e,r)=>Zr(t,e,r)>0;ye.exports=br});var L=m((Cn,Pe)=>{l();var Mr=R(),et=(t,e,r)=>Mr(t,e,r)<0;Pe.exports=et});var W=m((Ln,Oe)=>{l();var rt=R(),tt=(t,e,r)=>rt(t,e,r)===0;Oe.exports=tt});var Y=m((Vn,Ce)=>{l();var st=R(),nt=(t,e,r)=>st(t,e,r)!==0;Ce.exports=nt});var j=m((Nn,Ae)=>{l();var it=R(),ot=(t,e,r)=>it(t,e,r)>=0;Ae.exports=ot});var V=m((Wn,Le)=>{l();var lt=R(),ct=(t,e,r)=>lt(t,e,r)<=0;Le.exports=ct});var D=m((Dn,je)=>{l();var at=W(),ut=Y(),ft=S(),ht=j(),pt=L(),mt=V(),qt=(t,e,r,s)=>{switch(e){case"===":return typeof t=="object"&&(t=t.version),typeof r=="object"&&(r=r.version),t===r;case"!==":return typeof t=="object"&&(t=t.version),typeof r=="object"&&(r=r.version),t!==r;case"":case"=":case"==":return at(t,r,s);case"!=":return ut(t,r,s);case">":return ft(t,r,s);case">=":return ht(t,r,s);case"<":return pt(t,r,s);case"<=":return mt(t,r,s);default:throw new TypeError(`Invalid operator: ${e}`)}};je.exports=qt});var Ie=m((Xn,Ve)=>{l();var $t=v(),dt=C(),{safeRe:I,t:N}=O(),wt=(t,e)=>{if(t instanceof $t)return t;if(typeof t=="number"&&(t=String(t)),typeof t!="string")return null;e=e||{};let r=null;if(!e.rtl)r=t.match(e.includePrerelease?I[N.COERCEFULL]:I[N.COERCE]);else{let a=e.includePrerelease?I[N.COERCERTLFULL]:I[N.COERCERTL],h;for(;(h=a.exec(t))&&(!r||r.index+r[0].length!==t.length);)(!r||h.index+h[0].length!==r.index+r[0].length)&&(r=h),a.lastIndex=h.index+h[1].length+h[2].length;a.lastIndex=-1}if(r===null)return null;let s=r[2],i=r[3]||"0",n=r[4]||"0",o=e.includePrerelease&&r[5]?`-${r[5]}`:"",c=e.includePrerelease&&r[6]?`+${r[6]}`:"";return dt(`${s}.${i}.${n}${o}${c}`,e)};Ve.exports=wt});var Ge=m((Bn,Ne)=>{l();var H=class{constructor(){this.max=1e3,this.map=new Map}get(e){let r=this.map.get(e);if(r!==void 0)return this.map.delete(e),this.map.set(e,r),r}delete(e){return this.map.delete(e)}set(e,r){if(!this.delete(e)&&r!==void 0){if(this.map.size>=this.max){let i=this.map.keys().next().value;this.delete(i)}this.map.set(e,r)}return this}};Ne.exports=H});var E=m((zn,He)=>{l();var vt=/\s+/g,X=class t{constructor(e,r){if(r=Rt(r),e instanceof t)return e.loose===!!r.loose&&e.includePrerelease===!!r.includePrerelease?e:new t(e.raw,r);if(e instanceof k)return this.raw=e.value,this.set=[[e]],this.formatted=void 0,this;if(this.options=r,this.loose=!!r.loose,this.includePrerelease=!!r.includePrerelease,this.raw=e.trim().replace(vt," "),this.set=this.raw.split("||").map(s=>this.parseRange(s.trim())).filter(s=>s.length),!this.set.length)throw new TypeError(`Invalid SemVer Range: ${this.raw}`);if(this.set.length>1){let s=this.set[0];if(this.set=this.set.filter(i=>!Ye(i[0])),this.set.length===0)this.set=[s];else if(this.set.length>1){for(let i of this.set)if(i.length===1&&Ot(i[0])){this.set=[i];break}}}this.formatted=void 0}get range(){if(this.formatted===void 0){this.formatted="";for(let e=0;e<this.set.length;e++){e>0&&(this.formatted+="||");let r=this.set[e];for(let s=0;s<r.length;s++)s>0&&(this.formatted+=" "),this.formatted+=r[s].toString().trim()}}return this.formatted}format(){return this.range}toString(){return this.range}parseRange(e){let s=((this.options.includePrerelease&&yt)|(this.options.loose&&Pt))+":"+e,i=We.get(s);if(i)return i;let n=this.options.loose,o=n?g[d.HYPHENRANGELOOSE]:g[d.HYPHENRANGE];e=e.replace(o,Yt(this.options.includePrerelease)),q("hyphen replace",e),e=e.replace(g[d.COMPARATORTRIM],St),q("comparator trim",e),e=e.replace(g[d.TILDETRIM],xt),q("tilde trim",e),e=e.replace(g[d.CARETTRIM],Tt),q("caret trim",e);let c=e.split(" ").map(u=>Ct(u,this.options)).join(" ").split(/\s+/).map(u=>Wt(u,this.options));n&&(c=c.filter(u=>(q("loose invalid filter",u,this.options),!!u.match(g[d.COMPARATORLOOSE])))),q("range list",c);let a=new Map,h=c.map(u=>new k(u,this.options));for(let u of h){if(Ye(u))return[u];a.set(u.value,u)}a.size>1&&a.has("")&&a.delete("");let p=[...a.values()];return We.set(s,p),p}intersects(e,r){if(!(e instanceof t))throw new TypeError("a Range is required");return this.set.some(s=>De(s,r)&&e.set.some(i=>De(i,r)&&s.every(n=>i.every(o=>n.intersects(o,r)))))}test(e){if(!e)return!1;if(typeof e=="string")try{e=new Et(e,this.options)}catch{return!1}for(let r=0;r<this.set.length;r++)if(Dt(this.set[r],e,this.options))return!0;return!1}};He.exports=X;var gt=Ge(),We=new gt,Rt=M(),k=x(),q=Z(),Et=v(),{safeRe:g,t:d,comparatorTrimReplace:St,tildeTrimReplace:xt,caretTrimReplace:Tt}=O(),{FLAG_INCLUDE_PRERELEASE:yt,FLAG_LOOSE:Pt}=b(),Ye=t=>t.value==="<0.0.0-0",Ot=t=>t.value==="",De=(t,e)=>{let r=!0,s=t.slice(),i=s.pop();for(;r&&s.length;)r=s.every(n=>i.intersects(n,e)),i=s.pop();return r},Ct=(t,e)=>(q("comp",t,e),t=jt(t,e),q("caret",t),t=At(t,e),q("tildes",t),t=It(t,e),q("xrange",t),t=Gt(t,e),q("stars",t),t),w=t=>!t||t.toLowerCase()==="x"||t==="*",At=(t,e)=>t.trim().split(/\s+/).map(r=>Lt(r,e)).join(" "),Lt=(t,e)=>{let r=e.loose?g[d.TILDELOOSE]:g[d.TILDE];return t.replace(r,(s,i,n,o,c)=>{q("tilde",t,s,i,n,o,c);let a;return w(i)?a="":w(n)?a=`>=${i}.0.0 <${+i+1}.0.0-0`:w(o)?a=`>=${i}.${n}.0 <${i}.${+n+1}.0-0`:c?(q("replaceTilde pr",c),a=`>=${i}.${n}.${o}-${c} <${i}.${+n+1}.0-0`):a=`>=${i}.${n}.${o} <${i}.${+n+1}.0-0`,q("tilde return",a),a})},jt=(t,e)=>t.trim().split(/\s+/).map(r=>Vt(r,e)).join(" "),Vt=(t,e)=>{q("caret",t,e);let r=e.loose?g[d.CARETLOOSE]:g[d.CARET],s=e.includePrerelease?"-0":"";return t.replace(r,(i,n,o,c,a)=>{q("caret",t,i,n,o,c,a);let h;return w(n)?h="":w(o)?h=`>=${n}.0.0${s} <${+n+1}.0.0-0`:w(c)?n==="0"?h=`>=${n}.${o}.0${s} <${n}.${+o+1}.0-0`:h=`>=${n}.${o}.0${s} <${+n+1}.0.0-0`:a?(q("replaceCaret pr",a),n==="0"?o==="0"?h=`>=${n}.${o}.${c}-${a} <${n}.${o}.${+c+1}-0`:h=`>=${n}.${o}.${c}-${a} <${n}.${+o+1}.0-0`:h=`>=${n}.${o}.${c}-${a} <${+n+1}.0.0-0`):(q("no pr"),n==="0"?o==="0"?h=`>=${n}.${o}.${c}${s} <${n}.${o}.${+c+1}-0`:h=`>=${n}.${o}.${c}${s} <${n}.${+o+1}.0-0`:h=`>=${n}.${o}.${c} <${+n+1}.0.0-0`),q("caret return",h),h})},It=(t,e)=>(q("replaceXRanges",t,e),t.split(/\s+/).map(r=>Nt(r,e)).join(" ")),Nt=(t,e)=>{t=t.trim();let r=e.loose?g[d.XRANGELOOSE]:g[d.XRANGE];return t.replace(r,(s,i,n,o,c,a)=>{q("xRange",t,s,i,n,o,c,a);let h=w(n),p=h||w(o),u=p||w(c),$=u;return i==="="&&$&&(i=""),a=e.includePrerelease?"-0":"",h?i===">"||i==="<"?s="<0.0.0-0":s="*":i&&$?(p&&(o=0),c=0,i===">"?(i=">=",p?(n=+n+1,o=0,c=0):(o=+o+1,c=0)):i==="<="&&(i="<",p?n=+n+1:o=+o+1),i==="<"&&(a="-0"),s=`${i+n}.${o}.${c}${a}`):p?s=`>=${n}.0.0${a} <${+n+1}.0.0-0`:u&&(s=`>=${n}.${o}.0${a} <${n}.${+o+1}.0-0`),q("xRange return",s),s})},Gt=(t,e)=>(q("replaceStars",t,e),t.trim().replace(g[d.STAR],"")),Wt=(t,e)=>(q("replaceGTE0",t,e),t.trim().replace(g[e.includePrerelease?d.GTE0PRE:d.GTE0],"")),Yt=t=>(e,r,s,i,n,o,c,a,h,p,u,$)=>(w(s)?r="":w(i)?r=`>=${s}.0.0${t?"-0":""}`:w(n)?r=`>=${s}.${i}.0${t?"-0":""}`:o?r=`>=${r}`:r=`>=${r}${t?"-0":""}`,w(h)?a="":w(p)?a=`<${+h+1}.0.0-0`:w(u)?a=`<${h}.${+p+1}.0-0`:$?a=`<=${h}.${p}.${u}-${$}`:t?a=`<${h}.${p}.${+u+1}-0`:a=`<=${a}`,`${r} ${a}`.trim()),Dt=(t,e,r)=>{for(let s=0;s<t.length;s++)if(!t[s].test(e))return!1;if(e.prerelease.length&&!r.includePrerelease){for(let s=0;s<t.length;s++)if(q(t[s].semver),t[s].semver!==k.ANY&&t[s].semver.prerelease.length>0){let i=t[s].semver;if(i.major===e.major&&i.minor===e.minor&&i.patch===e.patch)return!0}return!1}return!0}});var x=m((Un,Fe)=>{l();var T=Symbol("SemVer ANY"),z=class t{static get ANY(){return T}constructor(e,r){if(r=Xe(r),e instanceof t){if(e.loose===!!r.loose)return e;e=e.value}e=e.trim().split(/\s+/).join(" "),_("comparator",e,r),this.options=r,this.loose=!!r.loose,this.parse(e),this.semver===T?this.value="":this.value=this.operator+this.semver.version,_("comp",this)}parse(e){let r=this.options.loose?ke[Be.COMPARATORLOOSE]:ke[Be.COMPARATOR],s=e.match(r);if(!s)throw new TypeError(`Invalid comparator: ${e}`);this.operator=s[1]!==void 0?s[1]:"",this.operator==="="&&(this.operator=""),s[2]?this.semver=new _e(s[2],this.options.loose):this.semver=T}toString(){return this.value}test(e){if(_("Comparator.test",e,this.options.loose),this.semver===T||e===T)return!0;if(typeof e=="string")try{e=new _e(e,this.options)}catch{return!1}return B(e,this.operator,this.semver,this.options)}intersects(e,r){if(!(e instanceof t))throw new TypeError("a Comparator is required");return this.operator===""?this.value===""?!0:new ze(e.value,r).test(this.value):e.operator===""?e.value===""?!0:new ze(this.value,r).test(e.semver):(r=Xe(r),r.includePrerelease&&(this.value==="<0.0.0-0"||e.value==="<0.0.0-0")||!r.includePrerelease&&(this.value.startsWith("<0.0.0")||e.value.startsWith("<0.0.0"))?!1:!!(this.operator.startsWith(">")&&e.operator.startsWith(">")||this.operator.startsWith("<")&&e.operator.startsWith("<")||this.semver.version===e.semver.version&&this.operator.includes("=")&&e.operator.includes("=")||B(this.semver,"<",e.semver,r)&&this.operator.startsWith(">")&&e.operator.startsWith("<")||B(this.semver,">",e.semver,r)&&this.operator.startsWith("<")&&e.operator.startsWith(">")))}};Fe.exports=z;var Xe=M(),{safeRe:ke,t:Be}=O(),B=D(),_=Z(),_e=v(),ze=E()});var y=m((Jn,Ue)=>{l();var Ht=E(),Xt=(t,e,r)=>{try{e=new Ht(e,r)}catch{return!1}return e.test(t)};Ue.exports=Xt});var Je=m((Zn,Ke)=>{l();var kt=E(),Bt=(t,e)=>new kt(t,e).set.map(r=>r.map(s=>s.value).join(" ").trim().split(" "));Ke.exports=Bt});var Ze=m((Mn,Qe)=>{l();var _t=v(),zt=E(),Ft=(t,e,r)=>{let s=null,i=null,n=null;try{n=new zt(e,r)}catch{return null}return t.forEach(o=>{n.test(o)&&(!s||i.compare(o)===-1)&&(s=o,i=new _t(s,r))}),s};Qe.exports=Ft});var Me=m((ri,be)=>{l();var Ut=v(),Kt=E(),Jt=(t,e,r)=>{let s=null,i=null,n=null;try{n=new Kt(e,r)}catch{return null}return t.forEach(o=>{n.test(o)&&(!s||i.compare(o)===1)&&(s=o,i=new Ut(s,r))}),s};be.exports=Jt});var tr=m((si,rr)=>{l();var F=v(),Qt=E(),er=S(),Zt=(t,e)=>{t=new Qt(t,e);let r=new F("0.0.0");if(t.test(r)||(r=new F("0.0.0-0"),t.test(r)))return r;r=null;for(let s=0;s<t.set.length;++s){let i=t.set[s],n=null;i.forEach(o=>{let c=new F(o.semver.version);switch(o.operator){case">":c.prerelease.length===0?c.patch++:c.prerelease.push(0),c.raw=c.format();case"":case">=":(!n||er(c,n))&&(n=c);break;case"<":case"<=":break;default:throw new Error(`Unexpected operation: ${o.operator}`)}}),n&&(!r||er(r,n))&&(r=n)}return r&&t.test(r)?r:null};rr.exports=Zt});var nr=m((ii,sr)=>{l();var bt=E(),Mt=(t,e)=>{try{return new bt(t,e).range||"*"}catch{return null}};sr.exports=Mt});var G=m((li,cr)=>{l();var es=v(),lr=x(),{ANY:rs}=lr,ts=E(),ss=y(),ir=S(),or=L(),ns=V(),is=j(),os=(t,e,r,s)=>{t=new es(t,s),e=new ts(e,s);let i,n,o,c,a;switch(r){case">":i=ir,n=ns,o=or,c=">",a=">=";break;case"<":i=or,n=is,o=ir,c="<",a="<=";break;default:throw new TypeError('Must provide a hilo val of "<" or ">"')}if(ss(t,e,s))return!1;for(let h=0;h<e.set.length;++h){let p=e.set[h],u=null,$=null;if(p.forEach(f=>{f.semver===rs&&(f=new lr(">=0.0.0")),u=u||f,$=$||f,i(f.semver,u.semver,s)?u=f:o(f.semver,$.semver,s)&&($=f)}),u.operator===c||u.operator===a||(!$.operator||$.operator===c)&&n(t,$.semver))return!1;if($.operator===a&&o(t,$.semver))return!1}return!0};cr.exports=os});var ur=m((ai,ar)=>{l();var ls=G(),cs=(t,e,r)=>ls(t,e,">",r);ar.exports=cs});var hr=m((fi,fr)=>{l();var as=G(),us=(t,e,r)=>as(t,e,"<",r);fr.exports=us});var qr=m((pi,mr)=>{l();var pr=E(),fs=(t,e,r)=>(t=new pr(t,r),e=new pr(e,r),t.intersects(e,r));mr.exports=fs});var dr=m((qi,$r)=>{l();var hs=y(),ps=R();$r.exports=(t,e,r)=>{let s=[],i=null,n=null,o=t.sort((p,u)=>ps(p,u,r));for(let p of o)hs(p,e,r)?(n=p,i||(i=p)):(n&&s.push([i,n]),n=null,i=null);i&&s.push([i,null]);let c=[];for(let[p,u]of s)p===u?c.push(p):!u&&p===o[0]?c.push("*"):u?p===o[0]?c.push(`<=${u}`):c.push(`${p} - ${u}`):c.push(`>=${p}`);let a=c.join(" || "),h=typeof e.raw=="string"?e.raw:String(e);return a.length<h.length?a:e}});var Sr=m((di,Er)=>{l();var wr=E(),K=x(),{ANY:U}=K,P=y(),J=R(),ms=(t,e,r={})=>{if(t===e)return!0;t=new wr(t,r),e=new wr(e,r);let s=!1;e:for(let i of t.set){for(let n of e.set){let o=$s(i,n,r);if(s=s||o!==null,o)continue e}if(s)return!1}return!0},qs=[new K(">=0.0.0-0")],vr=[new K(">=0.0.0")],$s=(t,e,r)=>{if(t===e)return!0;if(t.length===1&&t[0].semver===U){if(e.length===1&&e[0].semver===U)return!0;r.includePrerelease?t=qs:t=vr}if(e.length===1&&e[0].semver===U){if(r.includePrerelease)return!0;e=vr}let s=new Set,i,n;for(let f of t)f.operator===">"||f.operator===">="?i=gr(i,f,r):f.operator==="<"||f.operator==="<="?n=Rr(n,f,r):s.add(f.semver);if(s.size>1)return null;let o;if(i&&n){if(o=J(i.semver,n.semver,r),o>0)return null;if(o===0&&(i.operator!==">="||n.operator!=="<="))return null}for(let f of s){if(i&&!P(f,String(i),r)||n&&!P(f,String(n),r))return null;for(let Pr of e)if(!P(f,String(Pr),r))return!1;return!0}let c,a,h,p,u=n&&!r.includePrerelease&&n.semver.prerelease.length?n.semver:!1,$=i&&!r.includePrerelease&&i.semver.prerelease.length?i.semver:!1;u&&u.prerelease.length===1&&n.operator==="<"&&u.prerelease[0]===0&&(u=!1);for(let f of e){if(p=p||f.operator===">"||f.operator===">=",h=h||f.operator==="<"||f.operator==="<=",i){if($&&f.semver.prerelease&&f.semver.prerelease.length&&f.semver.major===$.major&&f.semver.minor===$.minor&&f.semver.patch===$.patch&&($=!1),f.operator===">"||f.operator===">="){if(c=gr(i,f,r),c===f&&c!==i)return!1}else if(i.operator===">="&&!P(i.semver,String(f),r))return!1}if(n){if(u&&f.semver.prerelease&&f.semver.prerelease.length&&f.semver.major===u.major&&f.semver.minor===u.minor&&f.semver.patch===u.patch&&(u=!1),f.operator==="<"||f.operator==="<="){if(a=Rr(n,f,r),a===f&&a!==n)return!1}else if(n.operator==="<="&&!P(n.semver,String(f),r))return!1}if(!f.operator&&(n||i)&&o!==0)return!1}return!(i&&h&&!n&&o!==0||n&&p&&!i&&o!==0||$||u)},gr=(t,e,r)=>{if(!t)return e;let s=J(t.semver,e.semver,r);return s>0?t:s<0||e.operator===">"&&t.operator===">="?e:t},Rr=(t,e,r)=>{if(!t)return e;let s=J(t.semver,e.semver,r);return s<0?t:s>0||e.operator==="<"&&t.operator==="<="?e:t};Er.exports=ms});var rn=m((vi,yr)=>{l();var Q=O(),xr=b(),ds=v(),Tr=Or(),ws=C(),vs=Cr(),gs=Ar(),Rs=te(),Es=ie(),Ss=le(),xs=ae(),Ts=fe(),ys=pe(),Ps=R(),Os=de(),Cs=ve(),As=A(),Ls=Se(),js=Te(),Vs=S(),Is=L(),Ns=W(),Gs=Y(),Ws=j(),Ys=V(),Ds=D(),Hs=Ie(),Xs=x(),ks=E(),Bs=y(),_s=Je(),zs=Ze(),Fs=Me(),Us=tr(),Ks=nr(),Js=G(),Qs=ur(),Zs=hr(),bs=qr(),Ms=dr(),en=Sr();yr.exports={parse:ws,valid:vs,clean:gs,inc:Rs,diff:Es,major:Ss,minor:xs,patch:Ts,prerelease:ys,compare:Ps,rcompare:Os,compareLoose:Cs,compareBuild:As,sort:Ls,rsort:js,gt:Vs,lt:Is,eq:Ns,neq:Gs,gte:Ws,lte:Ys,cmp:Ds,coerce:Hs,Comparator:Xs,Range:ks,satisfies:Bs,toComparators:_s,maxSatisfying:zs,minSatisfying:Fs,minVersion:Us,validRange:Ks,outside:Js,gtr:Qs,ltr:Zs,intersects:bs,simplifyRange:Ms,subset:en,SemVer:ds,re:Q.re,src:Q.src,tokens:Q.t,SEMVER_SPEC_VERSION:xr.SEMVER_SPEC_VERSION,RELEASE_TYPES:xr.RELEASE_TYPES,compareIdentifiers:Tr.compareIdentifiers,rcompareIdentifiers:Tr.rcompareIdentifiers}});export{rn as a};
2
+ //# sourceMappingURL=chunk-3V7YWBUK.js.map