@slicemachine/manager 0.1.1-dev-plugins.11 → 0.1.1-dev-plugins.13

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 (65) hide show
  1. package/README.md +85 -0
  2. package/dist/constants/API_ENDPOINTS.cjs.map +1 -1
  3. package/dist/constants/API_ENDPOINTS.d.ts +1 -2
  4. package/dist/constants/API_ENDPOINTS.js.map +1 -1
  5. package/dist/errors.cjs.map +1 -1
  6. package/dist/errors.d.ts +1 -1
  7. package/dist/errors.js.map +1 -1
  8. package/dist/lib/buildPrismicRepositoryAPIEndpoint.cjs +9 -0
  9. package/dist/lib/buildPrismicRepositoryAPIEndpoint.cjs.map +1 -0
  10. package/dist/lib/buildPrismicRepositoryAPIEndpoint.d.ts +4 -0
  11. package/dist/lib/buildPrismicRepositoryAPIEndpoint.js +9 -0
  12. package/dist/lib/buildPrismicRepositoryAPIEndpoint.js.map +1 -0
  13. package/dist/lib/decodePackageJSON.cjs +29 -0
  14. package/dist/lib/decodePackageJSON.cjs.map +1 -0
  15. package/dist/lib/decodePackageJSON.d.ts +12 -0
  16. package/dist/lib/decodePackageJSON.js +12 -0
  17. package/dist/lib/decodePackageJSON.js.map +1 -0
  18. package/dist/lib/locateFileUpward.cjs +8 -11
  19. package/dist/lib/locateFileUpward.cjs.map +1 -1
  20. package/dist/lib/locateFileUpward.js +8 -11
  21. package/dist/lib/locateFileUpward.js.map +1 -1
  22. package/dist/managers/SliceMachineManager.cjs +17 -11
  23. package/dist/managers/SliceMachineManager.cjs.map +1 -1
  24. package/dist/managers/SliceMachineManager.d.ts +6 -0
  25. package/dist/managers/SliceMachineManager.js +17 -11
  26. package/dist/managers/SliceMachineManager.js.map +1 -1
  27. package/dist/managers/createSliceMachineManager.cjs +2 -2
  28. package/dist/managers/createSliceMachineManager.cjs.map +1 -1
  29. package/dist/managers/createSliceMachineManager.d.ts +4 -3
  30. package/dist/managers/createSliceMachineManager.js +2 -2
  31. package/dist/managers/createSliceMachineManager.js.map +1 -1
  32. package/dist/managers/slices/SlicesManager.cjs +21 -4
  33. package/dist/managers/slices/SlicesManager.cjs.map +1 -1
  34. package/dist/managers/slices/SlicesManager.d.ts +1 -1
  35. package/dist/managers/slices/SlicesManager.js +21 -4
  36. package/dist/managers/slices/SlicesManager.js.map +1 -1
  37. package/dist/managers/telemetry/TelemetryManager.cjs +3 -1
  38. package/dist/managers/telemetry/TelemetryManager.cjs.map +1 -1
  39. package/dist/managers/telemetry/TelemetryManager.js +3 -1
  40. package/dist/managers/telemetry/TelemetryManager.js.map +1 -1
  41. package/dist/managers/user/UserManager.cjs +6 -2
  42. package/dist/managers/user/UserManager.cjs.map +1 -1
  43. package/dist/managers/user/UserManager.d.ts +2 -0
  44. package/dist/managers/user/UserManager.js +6 -2
  45. package/dist/managers/user/UserManager.js.map +1 -1
  46. package/dist/managers/versions/VersionsManager.cjs +14 -3
  47. package/dist/managers/versions/VersionsManager.cjs.map +1 -1
  48. package/dist/managers/versions/VersionsManager.js +14 -3
  49. package/dist/managers/versions/VersionsManager.js.map +1 -1
  50. package/dist/managers/versions/types.d.ts +1 -1
  51. package/dist/types.d.ts +1 -1
  52. package/package.json +7 -5
  53. package/src/constants/API_ENDPOINTS.ts +1 -1
  54. package/src/errors.ts +1 -74
  55. package/src/lib/buildPrismicRepositoryAPIEndpoint.ts +16 -0
  56. package/src/lib/decodePackageJSON.ts +18 -0
  57. package/src/lib/locateFileUpward.ts +8 -12
  58. package/src/managers/SliceMachineManager.ts +31 -31
  59. package/src/managers/createSliceMachineManager.ts +3 -3
  60. package/src/managers/slices/SlicesManager.ts +24 -7
  61. package/src/managers/telemetry/TelemetryManager.ts +6 -0
  62. package/src/managers/user/UserManager.ts +12 -0
  63. package/src/managers/versions/VersionsManager.ts +22 -6
  64. package/src/managers/versions/types.ts +1 -1
  65. package/src/types.ts +1 -1
package/README.md ADDED
@@ -0,0 +1,85 @@
1
+ > **Warning**
2
+ >
3
+ > This package is designed only for [Slice Machine][slice-machine]'s maintainers. If you use [Slice Machine][slice-machine] in your projects, you probably don't need to be aware of `@slicemachine/manager`.
4
+
5
+ # @slicemachine/manager
6
+
7
+ [![npm version][npm-version-src]][npm-version-href]
8
+ [![npm downloads][npm-downloads-src]][npm-downloads-href]
9
+ [![Github Actions CI][github-actions-ci-src]][github-actions-ci-href]
10
+ [![Conventional Commits][conventional-commits-src]][conventional-commits-href]
11
+ [![License][license-src]][license-href]
12
+
13
+ A low-level tool used to manage Slice Machine data.
14
+
15
+ ## Install
16
+
17
+ ```sh
18
+ npm install @slicemachine/manager
19
+ ```
20
+
21
+ ## Documentation
22
+
23
+ This low-level Slice Machine package is not publicly documented and is designed only for internal use.
24
+
25
+ ## Contributing
26
+
27
+ Whether you're helping us fix bugs, improve the docs, or spread the word, we'd love to have you as part of the Prismic developer community!
28
+
29
+ **Asking a question**: [Open a new topic][forum-question] on our community forum explaining what you want to achieve / your question. Our support team will get back to you shortly.
30
+
31
+ **Reporting a bug**: [Open an issue][repo-bug-report] explaining your application's setup and the bug you're encountering.
32
+
33
+ **Suggesting an improvement**: [Open an issue][repo-feature-request] explaining your improvement or feature so we can discuss and learn more.
34
+
35
+ **Submitting code changes**: For small fixes, feel free to [open a PR][repo-pull-requests] with a description of your changes. For large changes, please first [open an issue][repo-feature-request] so we can discuss if and how the changes should be implemented.
36
+
37
+ ## License
38
+
39
+ ```
40
+ Copyright 2013-2023 Prismic <contact@prismic.io> (https://prismic.io)
41
+
42
+ Licensed under the Apache License, Version 2.0 (the "License");
43
+ you may not use this file except in compliance with the License.
44
+ You may obtain a copy of the License at
45
+
46
+ http://www.apache.org/licenses/LICENSE-2.0
47
+
48
+ Unless required by applicable law or agreed to in writing, software
49
+ distributed under the License is distributed on an "AS IS" BASIS,
50
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
51
+ See the License for the specific language governing permissions and
52
+ limitations under the License.
53
+ ```
54
+
55
+ <!-- Links -->
56
+
57
+ [prismic]: https://prismic.io
58
+ [slice-machine]: https://prismic.io/slice-machine
59
+
60
+ <!-- TODO: Replace link with a more useful one if available -->
61
+
62
+ [prismic-docs]: https://prismic.io/docs
63
+ [changelog]: /CHANGELOG.md
64
+
65
+ <!-- TODO: Replace link with a more useful one if available -->
66
+
67
+ [forum-question]: https://community.prismic.io
68
+ [repo-bug-report]: https://github.com/prismicio/slice-machine/issues/new?assignees=&labels=bug&template=bug_report.md&title=
69
+ [repo-feature-request]: https://github.com/prismicio/slice-machine/issues/new?assignees=&labels=enhancement&template=feature_request.md&title=
70
+ [repo-pull-requests]: https://github.com/prismicio/slice-machine/pulls
71
+
72
+ <!-- Badges -->
73
+
74
+ [npm-version-src]: https://img.shields.io/npm/v/start-slicemachine/latest.svg
75
+ [npm-version-href]: https://npmjs.com/package/start-slicemachine
76
+ [npm-downloads-src]: https://img.shields.io/npm/dm/start-slicemachine.svg
77
+ [npm-downloads-href]: https://npmjs.com/package/start-slicemachine
78
+ [github-actions-ci-src]: https://github.com/prismicio/slice-machine/workflows/test/badge.svg
79
+ [github-actions-ci-href]: https://github.com/prismicio/slice-machine/actions?query=workflow%3Atest
80
+ [codecov-src]: https://img.shields.io/codecov/c/github/prismicio/slice-machine.svg
81
+ [codecov-href]: https://codecov.io/gh/prismicio/slice-machine
82
+ [conventional-commits-src]: https://img.shields.io/badge/Conventional%20Commits-1.0.0-yellow.svg
83
+ [conventional-commits-href]: https://conventionalcommits.org
84
+ [license-src]: https://img.shields.io/npm/l/start-slicemachine.svg
85
+ [license-href]: https://npmjs.com/package/start-slicemachine
@@ -1 +1 @@
1
- {"version":3,"file":"API_ENDPOINTS.cjs","sources":["../../../src/constants/API_ENDPOINTS.ts"],"sourcesContent":["import { APPLICATION_MODE } from \"./APPLICATION_MODE\";\n\ntype APIEndpoints = {\n\tPrismicWroom: string;\n\tPrismicAuthentication: string;\n\tPrismicModels: string;\n\tPrismicUser: string;\n\tAwsAclProvider: string;\n};\n\nexport const API_ENDPOINTS: APIEndpoints = (() => {\n\tswitch (process.env.SM_ENV) {\n\t\tcase APPLICATION_MODE.Development: {\n\t\t\tconst apiEndpoints = {\n\t\t\t\tPrismicWroom: process.env.wroom_endpoint,\n\t\t\t\tPrismicAuthentication: process.env.authentication_server_endpoint,\n\t\t\t\tPrismicModels: process.env.customtypesapi_endpoint,\n\t\t\t\tPrismicUser: process.env.user_service_endpoint,\n\t\t\t\tAwsAclProvider: process.env.acl_provider_endpoint,\n\t\t\t};\n\n\t\t\tconst missingAPIEndpoints = Object.keys(apiEndpoints).filter((key) => {\n\t\t\t\treturn !apiEndpoints[key as keyof typeof apiEndpoints];\n\t\t\t});\n\n\t\t\tif (missingAPIEndpoints.length > 0) {\n\t\t\t\tconsole.error(\n\t\t\t\t\t`You are running Slice Machine in development mode where API endpoints are configured via environment variables. The following endpoints were not configured: ${missingAPIEndpoints.join(\n\t\t\t\t\t\t\", \",\n\t\t\t\t\t)}. Configure them before continuing.`,\n\t\t\t\t);\n\n\t\t\t\tprocess.exit(1);\n\t\t\t}\n\n\t\t\treturn apiEndpoints as APIEndpoints;\n\t\t}\n\n\t\tcase APPLICATION_MODE.Staging: {\n\t\t\treturn {\n\t\t\t\tPrismicWroom: \"https://wroom.io/\",\n\t\t\t\tPrismicAuthentication: \"https://auth.wroom.io/\",\n\t\t\t\tPrismicModels: \"https://customtypes.wroom.io/customtypes/\",\n\t\t\t\tPrismicUser: \"https://user.wroom.io/\",\n\t\t\t\tAwsAclProvider:\n\t\t\t\t\t\"https://2iamcvnxf4.execute-api.us-east-1.amazonaws.com/stage/\",\n\t\t\t};\n\t\t}\n\n\t\tcase APPLICATION_MODE.Production:\n\t\tdefault: {\n\t\t\treturn {\n\t\t\t\tPrismicWroom: \"https://prismic.io/\",\n\t\t\t\tPrismicAuthentication: \"https://auth.prismic.io/\",\n\t\t\t\tPrismicModels: \"https://customtypes.prismic.io/customtypes/\",\n\t\t\t\tPrismicUser: \"https://user.internal-prismic.io/\",\n\t\t\t\tAwsAclProvider:\n\t\t\t\t\t\"https://0yyeb2g040.execute-api.us-east-1.amazonaws.com/prod/\",\n\t\t\t};\n\t\t}\n\t}\n})();\n"],"names":["APPLICATION_MODE"],"mappings":";;;AAUO,MAAM,iBAA+B,MAAK;AACxC,UAAA,QAAQ,IAAI,QAAQ;AAAA,IAC3B,KAAKA,iBAAAA,iBAAiB,aAAa;AAClC,YAAM,eAAe;AAAA,QACpB,cAAc,QAAQ,IAAI;AAAA,QAC1B,uBAAuB,QAAQ,IAAI;AAAA,QACnC,eAAe,QAAQ,IAAI;AAAA,QAC3B,aAAa,QAAQ,IAAI;AAAA,QACzB,gBAAgB,QAAQ,IAAI;AAAA,MAAA;AAG7B,YAAM,sBAAsB,OAAO,KAAK,YAAY,EAAE,OAAO,CAAC,QAAO;AAC7D,eAAA,CAAC,aAAa,GAAgC;AAAA,MAAA,CACrD;AAEG,UAAA,oBAAoB,SAAS,GAAG;AACnC,gBAAQ,MACP,gKAAgK,oBAAoB,KACnL,IAAI,sCACiC;AAGvC,gBAAQ,KAAK,CAAC;AAAA,MACd;AAEM,aAAA;AAAA,IACP;AAAA,IAED,KAAKA,iBAAAA,iBAAiB,SAAS;AACvB,aAAA;AAAA,QACN,cAAc;AAAA,QACd,uBAAuB;AAAA,QACvB,eAAe;AAAA,QACf,aAAa;AAAA,QACb,gBACC;AAAA,MAAA;AAAA,IAEF;AAAA,IAED,KAAKA,iBAAAA,iBAAiB;AAAA,IACtB,SAAS;AACD,aAAA;AAAA,QACN,cAAc;AAAA,QACd,uBAAuB;AAAA,QACvB,eAAe;AAAA,QACf,aAAa;AAAA,QACb,gBACC;AAAA,MAAA;AAAA,IAEF;AAAA,EACD;AACF;;"}
1
+ {"version":3,"file":"API_ENDPOINTS.cjs","sources":["../../../src/constants/API_ENDPOINTS.ts"],"sourcesContent":["import { APPLICATION_MODE } from \"./APPLICATION_MODE\";\n\nexport type APIEndpoints = {\n\tPrismicWroom: string;\n\tPrismicAuthentication: string;\n\tPrismicModels: string;\n\tPrismicUser: string;\n\tAwsAclProvider: string;\n};\n\nexport const API_ENDPOINTS: APIEndpoints = (() => {\n\tswitch (process.env.SM_ENV) {\n\t\tcase APPLICATION_MODE.Development: {\n\t\t\tconst apiEndpoints = {\n\t\t\t\tPrismicWroom: process.env.wroom_endpoint,\n\t\t\t\tPrismicAuthentication: process.env.authentication_server_endpoint,\n\t\t\t\tPrismicModels: process.env.customtypesapi_endpoint,\n\t\t\t\tPrismicUser: process.env.user_service_endpoint,\n\t\t\t\tAwsAclProvider: process.env.acl_provider_endpoint,\n\t\t\t};\n\n\t\t\tconst missingAPIEndpoints = Object.keys(apiEndpoints).filter((key) => {\n\t\t\t\treturn !apiEndpoints[key as keyof typeof apiEndpoints];\n\t\t\t});\n\n\t\t\tif (missingAPIEndpoints.length > 0) {\n\t\t\t\tconsole.error(\n\t\t\t\t\t`You are running Slice Machine in development mode where API endpoints are configured via environment variables. The following endpoints were not configured: ${missingAPIEndpoints.join(\n\t\t\t\t\t\t\", \",\n\t\t\t\t\t)}. Configure them before continuing.`,\n\t\t\t\t);\n\n\t\t\t\tprocess.exit(1);\n\t\t\t}\n\n\t\t\treturn apiEndpoints as APIEndpoints;\n\t\t}\n\n\t\tcase APPLICATION_MODE.Staging: {\n\t\t\treturn {\n\t\t\t\tPrismicWroom: \"https://wroom.io/\",\n\t\t\t\tPrismicAuthentication: \"https://auth.wroom.io/\",\n\t\t\t\tPrismicModels: \"https://customtypes.wroom.io/customtypes/\",\n\t\t\t\tPrismicUser: \"https://user.wroom.io/\",\n\t\t\t\tAwsAclProvider:\n\t\t\t\t\t\"https://2iamcvnxf4.execute-api.us-east-1.amazonaws.com/stage/\",\n\t\t\t};\n\t\t}\n\n\t\tcase APPLICATION_MODE.Production:\n\t\tdefault: {\n\t\t\treturn {\n\t\t\t\tPrismicWroom: \"https://prismic.io/\",\n\t\t\t\tPrismicAuthentication: \"https://auth.prismic.io/\",\n\t\t\t\tPrismicModels: \"https://customtypes.prismic.io/customtypes/\",\n\t\t\t\tPrismicUser: \"https://user.internal-prismic.io/\",\n\t\t\t\tAwsAclProvider:\n\t\t\t\t\t\"https://0yyeb2g040.execute-api.us-east-1.amazonaws.com/prod/\",\n\t\t\t};\n\t\t}\n\t}\n})();\n"],"names":["APPLICATION_MODE"],"mappings":";;;AAUO,MAAM,iBAA+B,MAAK;AACxC,UAAA,QAAQ,IAAI,QAAQ;AAAA,IAC3B,KAAKA,iBAAAA,iBAAiB,aAAa;AAClC,YAAM,eAAe;AAAA,QACpB,cAAc,QAAQ,IAAI;AAAA,QAC1B,uBAAuB,QAAQ,IAAI;AAAA,QACnC,eAAe,QAAQ,IAAI;AAAA,QAC3B,aAAa,QAAQ,IAAI;AAAA,QACzB,gBAAgB,QAAQ,IAAI;AAAA,MAAA;AAG7B,YAAM,sBAAsB,OAAO,KAAK,YAAY,EAAE,OAAO,CAAC,QAAO;AAC7D,eAAA,CAAC,aAAa,GAAgC;AAAA,MAAA,CACrD;AAEG,UAAA,oBAAoB,SAAS,GAAG;AACnC,gBAAQ,MACP,gKAAgK,oBAAoB,KACnL,IAAI,sCACiC;AAGvC,gBAAQ,KAAK,CAAC;AAAA,MACd;AAEM,aAAA;AAAA,IACP;AAAA,IAED,KAAKA,iBAAAA,iBAAiB,SAAS;AACvB,aAAA;AAAA,QACN,cAAc;AAAA,QACd,uBAAuB;AAAA,QACvB,eAAe;AAAA,QACf,aAAa;AAAA,QACb,gBACC;AAAA,MAAA;AAAA,IAEF;AAAA,IAED,KAAKA,iBAAAA,iBAAiB;AAAA,IACtB,SAAS;AACD,aAAA;AAAA,QACN,cAAc;AAAA,QACd,uBAAuB;AAAA,QACvB,eAAe;AAAA,QACf,aAAa;AAAA,QACb,gBACC;AAAA,MAAA;AAAA,IAEF;AAAA,EACD;AACF;;"}
@@ -1,4 +1,4 @@
1
- type APIEndpoints = {
1
+ export type APIEndpoints = {
2
2
  PrismicWroom: string;
3
3
  PrismicAuthentication: string;
4
4
  PrismicModels: string;
@@ -6,4 +6,3 @@ type APIEndpoints = {
6
6
  AwsAclProvider: string;
7
7
  };
8
8
  export declare const API_ENDPOINTS: APIEndpoints;
9
- export {};
@@ -1 +1 @@
1
- {"version":3,"file":"API_ENDPOINTS.js","sources":["../../../src/constants/API_ENDPOINTS.ts"],"sourcesContent":["import { APPLICATION_MODE } from \"./APPLICATION_MODE\";\n\ntype APIEndpoints = {\n\tPrismicWroom: string;\n\tPrismicAuthentication: string;\n\tPrismicModels: string;\n\tPrismicUser: string;\n\tAwsAclProvider: string;\n};\n\nexport const API_ENDPOINTS: APIEndpoints = (() => {\n\tswitch (process.env.SM_ENV) {\n\t\tcase APPLICATION_MODE.Development: {\n\t\t\tconst apiEndpoints = {\n\t\t\t\tPrismicWroom: process.env.wroom_endpoint,\n\t\t\t\tPrismicAuthentication: process.env.authentication_server_endpoint,\n\t\t\t\tPrismicModels: process.env.customtypesapi_endpoint,\n\t\t\t\tPrismicUser: process.env.user_service_endpoint,\n\t\t\t\tAwsAclProvider: process.env.acl_provider_endpoint,\n\t\t\t};\n\n\t\t\tconst missingAPIEndpoints = Object.keys(apiEndpoints).filter((key) => {\n\t\t\t\treturn !apiEndpoints[key as keyof typeof apiEndpoints];\n\t\t\t});\n\n\t\t\tif (missingAPIEndpoints.length > 0) {\n\t\t\t\tconsole.error(\n\t\t\t\t\t`You are running Slice Machine in development mode where API endpoints are configured via environment variables. The following endpoints were not configured: ${missingAPIEndpoints.join(\n\t\t\t\t\t\t\", \",\n\t\t\t\t\t)}. Configure them before continuing.`,\n\t\t\t\t);\n\n\t\t\t\tprocess.exit(1);\n\t\t\t}\n\n\t\t\treturn apiEndpoints as APIEndpoints;\n\t\t}\n\n\t\tcase APPLICATION_MODE.Staging: {\n\t\t\treturn {\n\t\t\t\tPrismicWroom: \"https://wroom.io/\",\n\t\t\t\tPrismicAuthentication: \"https://auth.wroom.io/\",\n\t\t\t\tPrismicModels: \"https://customtypes.wroom.io/customtypes/\",\n\t\t\t\tPrismicUser: \"https://user.wroom.io/\",\n\t\t\t\tAwsAclProvider:\n\t\t\t\t\t\"https://2iamcvnxf4.execute-api.us-east-1.amazonaws.com/stage/\",\n\t\t\t};\n\t\t}\n\n\t\tcase APPLICATION_MODE.Production:\n\t\tdefault: {\n\t\t\treturn {\n\t\t\t\tPrismicWroom: \"https://prismic.io/\",\n\t\t\t\tPrismicAuthentication: \"https://auth.prismic.io/\",\n\t\t\t\tPrismicModels: \"https://customtypes.prismic.io/customtypes/\",\n\t\t\t\tPrismicUser: \"https://user.internal-prismic.io/\",\n\t\t\t\tAwsAclProvider:\n\t\t\t\t\t\"https://0yyeb2g040.execute-api.us-east-1.amazonaws.com/prod/\",\n\t\t\t};\n\t\t}\n\t}\n})();\n"],"names":[],"mappings":";AAUO,MAAM,iBAA+B,MAAK;AACxC,UAAA,QAAQ,IAAI,QAAQ;AAAA,IAC3B,KAAK,iBAAiB,aAAa;AAClC,YAAM,eAAe;AAAA,QACpB,cAAc,QAAQ,IAAI;AAAA,QAC1B,uBAAuB,QAAQ,IAAI;AAAA,QACnC,eAAe,QAAQ,IAAI;AAAA,QAC3B,aAAa,QAAQ,IAAI;AAAA,QACzB,gBAAgB,QAAQ,IAAI;AAAA,MAAA;AAG7B,YAAM,sBAAsB,OAAO,KAAK,YAAY,EAAE,OAAO,CAAC,QAAO;AAC7D,eAAA,CAAC,aAAa,GAAgC;AAAA,MAAA,CACrD;AAEG,UAAA,oBAAoB,SAAS,GAAG;AACnC,gBAAQ,MACP,gKAAgK,oBAAoB,KACnL,IAAI,sCACiC;AAGvC,gBAAQ,KAAK,CAAC;AAAA,MACd;AAEM,aAAA;AAAA,IACP;AAAA,IAED,KAAK,iBAAiB,SAAS;AACvB,aAAA;AAAA,QACN,cAAc;AAAA,QACd,uBAAuB;AAAA,QACvB,eAAe;AAAA,QACf,aAAa;AAAA,QACb,gBACC;AAAA,MAAA;AAAA,IAEF;AAAA,IAED,KAAK,iBAAiB;AAAA,IACtB,SAAS;AACD,aAAA;AAAA,QACN,cAAc;AAAA,QACd,uBAAuB;AAAA,QACvB,eAAe;AAAA,QACf,aAAa;AAAA,QACb,gBACC;AAAA,MAAA;AAAA,IAEF;AAAA,EACD;AACF;"}
1
+ {"version":3,"file":"API_ENDPOINTS.js","sources":["../../../src/constants/API_ENDPOINTS.ts"],"sourcesContent":["import { APPLICATION_MODE } from \"./APPLICATION_MODE\";\n\nexport type APIEndpoints = {\n\tPrismicWroom: string;\n\tPrismicAuthentication: string;\n\tPrismicModels: string;\n\tPrismicUser: string;\n\tAwsAclProvider: string;\n};\n\nexport const API_ENDPOINTS: APIEndpoints = (() => {\n\tswitch (process.env.SM_ENV) {\n\t\tcase APPLICATION_MODE.Development: {\n\t\t\tconst apiEndpoints = {\n\t\t\t\tPrismicWroom: process.env.wroom_endpoint,\n\t\t\t\tPrismicAuthentication: process.env.authentication_server_endpoint,\n\t\t\t\tPrismicModels: process.env.customtypesapi_endpoint,\n\t\t\t\tPrismicUser: process.env.user_service_endpoint,\n\t\t\t\tAwsAclProvider: process.env.acl_provider_endpoint,\n\t\t\t};\n\n\t\t\tconst missingAPIEndpoints = Object.keys(apiEndpoints).filter((key) => {\n\t\t\t\treturn !apiEndpoints[key as keyof typeof apiEndpoints];\n\t\t\t});\n\n\t\t\tif (missingAPIEndpoints.length > 0) {\n\t\t\t\tconsole.error(\n\t\t\t\t\t`You are running Slice Machine in development mode where API endpoints are configured via environment variables. The following endpoints were not configured: ${missingAPIEndpoints.join(\n\t\t\t\t\t\t\", \",\n\t\t\t\t\t)}. Configure them before continuing.`,\n\t\t\t\t);\n\n\t\t\t\tprocess.exit(1);\n\t\t\t}\n\n\t\t\treturn apiEndpoints as APIEndpoints;\n\t\t}\n\n\t\tcase APPLICATION_MODE.Staging: {\n\t\t\treturn {\n\t\t\t\tPrismicWroom: \"https://wroom.io/\",\n\t\t\t\tPrismicAuthentication: \"https://auth.wroom.io/\",\n\t\t\t\tPrismicModels: \"https://customtypes.wroom.io/customtypes/\",\n\t\t\t\tPrismicUser: \"https://user.wroom.io/\",\n\t\t\t\tAwsAclProvider:\n\t\t\t\t\t\"https://2iamcvnxf4.execute-api.us-east-1.amazonaws.com/stage/\",\n\t\t\t};\n\t\t}\n\n\t\tcase APPLICATION_MODE.Production:\n\t\tdefault: {\n\t\t\treturn {\n\t\t\t\tPrismicWroom: \"https://prismic.io/\",\n\t\t\t\tPrismicAuthentication: \"https://auth.prismic.io/\",\n\t\t\t\tPrismicModels: \"https://customtypes.prismic.io/customtypes/\",\n\t\t\t\tPrismicUser: \"https://user.internal-prismic.io/\",\n\t\t\t\tAwsAclProvider:\n\t\t\t\t\t\"https://0yyeb2g040.execute-api.us-east-1.amazonaws.com/prod/\",\n\t\t\t};\n\t\t}\n\t}\n})();\n"],"names":[],"mappings":";AAUO,MAAM,iBAA+B,MAAK;AACxC,UAAA,QAAQ,IAAI,QAAQ;AAAA,IAC3B,KAAK,iBAAiB,aAAa;AAClC,YAAM,eAAe;AAAA,QACpB,cAAc,QAAQ,IAAI;AAAA,QAC1B,uBAAuB,QAAQ,IAAI;AAAA,QACnC,eAAe,QAAQ,IAAI;AAAA,QAC3B,aAAa,QAAQ,IAAI;AAAA,QACzB,gBAAgB,QAAQ,IAAI;AAAA,MAAA;AAG7B,YAAM,sBAAsB,OAAO,KAAK,YAAY,EAAE,OAAO,CAAC,QAAO;AAC7D,eAAA,CAAC,aAAa,GAAgC;AAAA,MAAA,CACrD;AAEG,UAAA,oBAAoB,SAAS,GAAG;AACnC,gBAAQ,MACP,gKAAgK,oBAAoB,KACnL,IAAI,sCACiC;AAGvC,gBAAQ,KAAK,CAAC;AAAA,MACd;AAEM,aAAA;AAAA,IACP;AAAA,IAED,KAAK,iBAAiB,SAAS;AACvB,aAAA;AAAA,QACN,cAAc;AAAA,QACd,uBAAuB;AAAA,QACvB,eAAe;AAAA,QACf,aAAa;AAAA,QACb,gBACC;AAAA,MAAA;AAAA,IAEF;AAAA,IAED,KAAK,iBAAiB;AAAA,IACtB,SAAS;AACD,aAAA;AAAA,QACN,cAAc;AAAA,QACd,uBAAuB;AAAA,QACvB,eAAe;AAAA,QACf,aAAa;AAAA,QACb,gBACC;AAAA,MAAA;AAAA,IAEF;AAAA,EACD;AACF;"}
@@ -1 +1 @@
1
- {"version":3,"file":"errors.cjs","sources":["../../src/errors.ts"],"sourcesContent":["// const Errors = {\n// \t1000: {\n// \t\tmessage: \"Could not refresh token\",\n// \t\tdescription:\n// \t\t\t\"You are not logged in. Log in before refreshing your authentication token.\",\n// \t},\n// \t1001: {\n// \t\tmessage: \"Failed to refresh authentication token\",\n// \t\tdescription:\n// \t\t\t\"The Prismic Authentication service returned an invalid response.\",\n// \t},\n// \t1002: {\n// \t\tmessage: \"Failed to refresh authentication token\",\n// \t\tdescription:\n// \t\t\t\"You are not logged in. Log in before attempting to get your authentication token.\",\n// \t},\n// \t// 1000: {\n// \t// \tmessage: \"Unauthenticated\",\n// \t// \tdescription:\n// \t// \t\t\"Unable to access the Prismic Custom Types API. Log in to fix this issue.\",\n// \t// },\n// \t// 1001: {\n// \t// \tmessage: \"Unauthorized\",\n// \t// \tdescription:\n// \t// \t\t\"Unable to access the Prismic Custom Types API. Grant the user access to the repository to fix this issue.\",\n// \t// },\n// } as const;\n// type Errors = typeof Errors;\n\nimport { HookError } from \"@slicemachine/plugin-kit\";\n\n// const InternalErrorCodes = {\n// \tUnauthorized: \"Unauthorized\",\n// \tUnauthenticated: \"Unauthenticated\",\n// \tInternalServerError: \"InternalServerError\",\n// } as const;\n// type InternalErrorCodes =\n// \ttypeof InternalErrorCodes[keyof typeof InternalErrorCodes];\n\n// type InternalErrorCode =\n// \t| typeof InternalError.Unauthorized\n// \t| typeof InternalError.Unauthenticated\n// \t| typeof InternalError.InternalServerError;\n\n// type InternalErrorArgs = {\n// \tmessage?: string;\n// \tcause?: Error;\n// };\n\nexport abstract class SliceMachineError extends Error {\n\t_sliceMachineError = true;\n\tname = \"SliceMachineError\";\n}\nexport class UnauthorizedError extends SliceMachineError {\n\tname = \"UnauthorizedError\";\n}\nexport class UnauthenticatedError extends SliceMachineError {\n\tname = \"UnauthenticatedError\";\n\tmessage = \"Authenticate before trying again.\";\n}\nexport class NotFoundError extends SliceMachineError {\n\tname = \"NotFoundError\";\n}\nexport class UnexpectedDataError extends SliceMachineError {\n\tname = \"UnexpectedDataError\";\n}\nexport class InternalError extends SliceMachineError {\n\tname = \"InternalError\";\n}\nexport class PluginError extends SliceMachineError {\n\tname = \"PluginError\";\n}\nexport class PluginHookResultError extends SliceMachineError {\n\tname = \"PluginHookResultError\";\n\n\tconstructor(errors: HookError[]) {\n\t\tsuper(\n\t\t\t`${errors.length} error${\n\t\t\t\terrors.length === 1 ? \"\" : \"s\"\n\t\t\t} were returned by one or more plugins.`,\n\t\t\t{\n\t\t\t\tcause: errors,\n\t\t\t},\n\t\t);\n\t}\n}\n\nexport const isSliceMachineError = (\n\terror: unknown,\n): error is SliceMachineError => {\n\treturn (\n\t\ttypeof error === \"object\" && error !== null && \"_sliceMachineError\" in error\n\t);\n};\n\nexport const isUnauthorizedError = (\n\terror: unknown,\n): error is UnauthorizedError => {\n\treturn isSliceMachineError(error) && error.name === UnauthorizedError.name;\n};\n\nexport const isUnauthenticatedError = (\n\terror: unknown,\n): error is UnauthenticatedError => {\n\treturn isSliceMachineError(error) && error.name === UnauthenticatedError.name;\n};\n\nexport const isNotFoundError = (error: unknown): error is NotFoundError => {\n\treturn isSliceMachineError(error) && error.name === NotFoundError.name;\n};\n\nexport const isUnexpectedDataError = (\n\terror: unknown,\n): error is UnexpectedDataError => {\n\treturn isSliceMachineError(error) && error.name === UnexpectedDataError.name;\n};\n\nexport const isInternalError = (error: unknown): error is InternalError => {\n\treturn isSliceMachineError(error) && error.name === InternalError.name;\n};\n\n// export class InternalError<TCode extends InternalErrorCode> extends Error {\n// \tstatic Unauthorized = \"Unauthorized\" as const;\n// \tstatic Unauthenticated = \"Unauthenticated\" as const;\n// \tstatic InternalServerError = \"InternalServerError\" as const;\n//\n// \tcode: TCode;\n// \tcause?: Error;\n//\n// \tconstructor(code: TCode, args: InternalErrorArgs = {}) {\n// \t\tsuper(args.message);\n//\n// \t\tthis.code = code;\n// \t\tthis.cause = args.cause;\n//\n// \t\t// const error = Errors[code];\n//\n// \t\t// this.message = error.message as TMessage;\n//\n// \t\t// if (\"description\" in error) {\n// \t\t// \tthis.description = error.description as TDescription;\n// \t\t// } else {\n// \t\t// \tthis.description = undefined as TDescription;\n// \t\t// }\n// \t}\n// }\n"],"names":[],"mappings":";;;;;;;;AAiDM,MAAgB,0BAA0B,MAAK;AAAA,EAA/C;AAAA;AACL,8CAAqB;AACrB,gCAAO;AAAA;AACP;AACK,MAAO,0BAA0B,kBAAiB;AAAA,EAAlD;AAAA;AACL,gCAAO;AAAA;AACP;AACK,MAAO,6BAA6B,kBAAiB;AAAA,EAArD;AAAA;AACL,gCAAO;AACP,mCAAU;AAAA;AACV;AACK,MAAO,sBAAsB,kBAAiB;AAAA,EAA9C;AAAA;AACL,gCAAO;AAAA;AACP;AACK,MAAO,4BAA4B,kBAAiB;AAAA,EAApD;AAAA;AACL,gCAAO;AAAA;AACP;AACK,MAAO,sBAAsB,kBAAiB;AAAA,EAA9C;AAAA;AACL,gCAAO;AAAA;AACP;AAmBY,MAAA,sBAAsB,CAClC,UAC+B;AAC/B,SACC,OAAO,UAAU,YAAY,UAAU,QAAQ,wBAAwB;AAEzE;AAEa,MAAA,sBAAsB,CAClC,UAC+B;AAC/B,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,kBAAkB;AACvE;AAEa,MAAA,yBAAyB,CACrC,UACkC;AAClC,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,qBAAqB;AAC1E;AAEa,MAAA,kBAAkB,CAAC,UAA0C;AACzE,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,cAAc;AACnE;AAEa,MAAA,wBAAwB,CACpC,UACiC;AACjC,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,oBAAoB;AACzE;AAEa,MAAA,kBAAkB,CAAC,UAA0C;AACzE,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,cAAc;AACnE;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"errors.cjs","sources":["../../src/errors.ts"],"sourcesContent":["import { HookError } from \"@slicemachine/plugin-kit\";\n\nexport class SliceMachineError extends Error {\n\t_sliceMachineError = true;\n\tname = \"SliceMachineError\";\n}\nexport class UnauthorizedError extends SliceMachineError {\n\tname = \"UnauthorizedError\";\n}\nexport class UnauthenticatedError extends SliceMachineError {\n\tname = \"UnauthenticatedError\";\n\tmessage = \"Authenticate before trying again.\";\n}\nexport class NotFoundError extends SliceMachineError {\n\tname = \"NotFoundError\";\n}\nexport class UnexpectedDataError extends SliceMachineError {\n\tname = \"UnexpectedDataError\";\n}\nexport class InternalError extends SliceMachineError {\n\tname = \"InternalError\";\n}\nexport class PluginError extends SliceMachineError {\n\tname = \"PluginError\";\n}\nexport class PluginHookResultError extends SliceMachineError {\n\tname = \"PluginHookResultError\";\n\n\tconstructor(errors: HookError[]) {\n\t\tsuper(\n\t\t\t`${errors.length} error${\n\t\t\t\terrors.length === 1 ? \"\" : \"s\"\n\t\t\t} were returned by one or more plugins.`,\n\t\t\t{\n\t\t\t\tcause: errors,\n\t\t\t},\n\t\t);\n\t}\n}\n\nexport const isSliceMachineError = (\n\terror: unknown,\n): error is SliceMachineError => {\n\treturn (\n\t\ttypeof error === \"object\" && error !== null && \"_sliceMachineError\" in error\n\t);\n};\n\nexport const isUnauthorizedError = (\n\terror: unknown,\n): error is UnauthorizedError => {\n\treturn isSliceMachineError(error) && error.name === UnauthorizedError.name;\n};\n\nexport const isUnauthenticatedError = (\n\terror: unknown,\n): error is UnauthenticatedError => {\n\treturn isSliceMachineError(error) && error.name === UnauthenticatedError.name;\n};\n\nexport const isNotFoundError = (error: unknown): error is NotFoundError => {\n\treturn isSliceMachineError(error) && error.name === NotFoundError.name;\n};\n\nexport const isUnexpectedDataError = (\n\terror: unknown,\n): error is UnexpectedDataError => {\n\treturn isSliceMachineError(error) && error.name === UnexpectedDataError.name;\n};\n\nexport const isInternalError = (error: unknown): error is InternalError => {\n\treturn isSliceMachineError(error) && error.name === InternalError.name;\n};\n"],"names":[],"mappings":";;;;;;;;AAEM,MAAO,0BAA0B,MAAK;AAAA,EAAtC;AAAA;AACL,8CAAqB;AACrB,gCAAO;AAAA;AACP;AACK,MAAO,0BAA0B,kBAAiB;AAAA,EAAlD;AAAA;AACL,gCAAO;AAAA;AACP;AACK,MAAO,6BAA6B,kBAAiB;AAAA,EAArD;AAAA;AACL,gCAAO;AACP,mCAAU;AAAA;AACV;AACK,MAAO,sBAAsB,kBAAiB;AAAA,EAA9C;AAAA;AACL,gCAAO;AAAA;AACP;AACK,MAAO,4BAA4B,kBAAiB;AAAA,EAApD;AAAA;AACL,gCAAO;AAAA;AACP;AACK,MAAO,sBAAsB,kBAAiB;AAAA,EAA9C;AAAA;AACL,gCAAO;AAAA;AACP;AAmBY,MAAA,sBAAsB,CAClC,UAC+B;AAC/B,SACC,OAAO,UAAU,YAAY,UAAU,QAAQ,wBAAwB;AAEzE;AAEa,MAAA,sBAAsB,CAClC,UAC+B;AAC/B,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,kBAAkB;AACvE;AAEa,MAAA,yBAAyB,CACrC,UACkC;AAClC,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,qBAAqB;AAC1E;AAEa,MAAA,kBAAkB,CAAC,UAA0C;AACzE,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,cAAc;AACnE;AAEa,MAAA,wBAAwB,CACpC,UACiC;AACjC,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,oBAAoB;AACzE;AAEa,MAAA,kBAAkB,CAAC,UAA0C;AACzE,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,cAAc;AACnE;;;;;;;;;;;;;"}
package/dist/errors.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import { HookError } from "@slicemachine/plugin-kit";
2
- export declare abstract class SliceMachineError extends Error {
2
+ export declare class SliceMachineError extends Error {
3
3
  _sliceMachineError: boolean;
4
4
  name: string;
5
5
  }
@@ -1 +1 @@
1
- {"version":3,"file":"errors.js","sources":["../../src/errors.ts"],"sourcesContent":["// const Errors = {\n// \t1000: {\n// \t\tmessage: \"Could not refresh token\",\n// \t\tdescription:\n// \t\t\t\"You are not logged in. Log in before refreshing your authentication token.\",\n// \t},\n// \t1001: {\n// \t\tmessage: \"Failed to refresh authentication token\",\n// \t\tdescription:\n// \t\t\t\"The Prismic Authentication service returned an invalid response.\",\n// \t},\n// \t1002: {\n// \t\tmessage: \"Failed to refresh authentication token\",\n// \t\tdescription:\n// \t\t\t\"You are not logged in. Log in before attempting to get your authentication token.\",\n// \t},\n// \t// 1000: {\n// \t// \tmessage: \"Unauthenticated\",\n// \t// \tdescription:\n// \t// \t\t\"Unable to access the Prismic Custom Types API. Log in to fix this issue.\",\n// \t// },\n// \t// 1001: {\n// \t// \tmessage: \"Unauthorized\",\n// \t// \tdescription:\n// \t// \t\t\"Unable to access the Prismic Custom Types API. Grant the user access to the repository to fix this issue.\",\n// \t// },\n// } as const;\n// type Errors = typeof Errors;\n\nimport { HookError } from \"@slicemachine/plugin-kit\";\n\n// const InternalErrorCodes = {\n// \tUnauthorized: \"Unauthorized\",\n// \tUnauthenticated: \"Unauthenticated\",\n// \tInternalServerError: \"InternalServerError\",\n// } as const;\n// type InternalErrorCodes =\n// \ttypeof InternalErrorCodes[keyof typeof InternalErrorCodes];\n\n// type InternalErrorCode =\n// \t| typeof InternalError.Unauthorized\n// \t| typeof InternalError.Unauthenticated\n// \t| typeof InternalError.InternalServerError;\n\n// type InternalErrorArgs = {\n// \tmessage?: string;\n// \tcause?: Error;\n// };\n\nexport abstract class SliceMachineError extends Error {\n\t_sliceMachineError = true;\n\tname = \"SliceMachineError\";\n}\nexport class UnauthorizedError extends SliceMachineError {\n\tname = \"UnauthorizedError\";\n}\nexport class UnauthenticatedError extends SliceMachineError {\n\tname = \"UnauthenticatedError\";\n\tmessage = \"Authenticate before trying again.\";\n}\nexport class NotFoundError extends SliceMachineError {\n\tname = \"NotFoundError\";\n}\nexport class UnexpectedDataError extends SliceMachineError {\n\tname = \"UnexpectedDataError\";\n}\nexport class InternalError extends SliceMachineError {\n\tname = \"InternalError\";\n}\nexport class PluginError extends SliceMachineError {\n\tname = \"PluginError\";\n}\nexport class PluginHookResultError extends SliceMachineError {\n\tname = \"PluginHookResultError\";\n\n\tconstructor(errors: HookError[]) {\n\t\tsuper(\n\t\t\t`${errors.length} error${\n\t\t\t\terrors.length === 1 ? \"\" : \"s\"\n\t\t\t} were returned by one or more plugins.`,\n\t\t\t{\n\t\t\t\tcause: errors,\n\t\t\t},\n\t\t);\n\t}\n}\n\nexport const isSliceMachineError = (\n\terror: unknown,\n): error is SliceMachineError => {\n\treturn (\n\t\ttypeof error === \"object\" && error !== null && \"_sliceMachineError\" in error\n\t);\n};\n\nexport const isUnauthorizedError = (\n\terror: unknown,\n): error is UnauthorizedError => {\n\treturn isSliceMachineError(error) && error.name === UnauthorizedError.name;\n};\n\nexport const isUnauthenticatedError = (\n\terror: unknown,\n): error is UnauthenticatedError => {\n\treturn isSliceMachineError(error) && error.name === UnauthenticatedError.name;\n};\n\nexport const isNotFoundError = (error: unknown): error is NotFoundError => {\n\treturn isSliceMachineError(error) && error.name === NotFoundError.name;\n};\n\nexport const isUnexpectedDataError = (\n\terror: unknown,\n): error is UnexpectedDataError => {\n\treturn isSliceMachineError(error) && error.name === UnexpectedDataError.name;\n};\n\nexport const isInternalError = (error: unknown): error is InternalError => {\n\treturn isSliceMachineError(error) && error.name === InternalError.name;\n};\n\n// export class InternalError<TCode extends InternalErrorCode> extends Error {\n// \tstatic Unauthorized = \"Unauthorized\" as const;\n// \tstatic Unauthenticated = \"Unauthenticated\" as const;\n// \tstatic InternalServerError = \"InternalServerError\" as const;\n//\n// \tcode: TCode;\n// \tcause?: Error;\n//\n// \tconstructor(code: TCode, args: InternalErrorArgs = {}) {\n// \t\tsuper(args.message);\n//\n// \t\tthis.code = code;\n// \t\tthis.cause = args.cause;\n//\n// \t\t// const error = Errors[code];\n//\n// \t\t// this.message = error.message as TMessage;\n//\n// \t\t// if (\"description\" in error) {\n// \t\t// \tthis.description = error.description as TDescription;\n// \t\t// } else {\n// \t\t// \tthis.description = undefined as TDescription;\n// \t\t// }\n// \t}\n// }\n"],"names":[],"mappings":";;;;;;AAiDM,MAAgB,0BAA0B,MAAK;AAAA,EAA/C;AAAA;AACL,8CAAqB;AACrB,gCAAO;AAAA;AACP;AACK,MAAO,0BAA0B,kBAAiB;AAAA,EAAlD;AAAA;AACL,gCAAO;AAAA;AACP;AACK,MAAO,6BAA6B,kBAAiB;AAAA,EAArD;AAAA;AACL,gCAAO;AACP,mCAAU;AAAA;AACV;AACK,MAAO,sBAAsB,kBAAiB;AAAA,EAA9C;AAAA;AACL,gCAAO;AAAA;AACP;AACK,MAAO,4BAA4B,kBAAiB;AAAA,EAApD;AAAA;AACL,gCAAO;AAAA;AACP;AACK,MAAO,sBAAsB,kBAAiB;AAAA,EAA9C;AAAA;AACL,gCAAO;AAAA;AACP;AAmBY,MAAA,sBAAsB,CAClC,UAC+B;AAC/B,SACC,OAAO,UAAU,YAAY,UAAU,QAAQ,wBAAwB;AAEzE;AAEa,MAAA,sBAAsB,CAClC,UAC+B;AAC/B,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,kBAAkB;AACvE;AAEa,MAAA,yBAAyB,CACrC,UACkC;AAClC,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,qBAAqB;AAC1E;AAEa,MAAA,kBAAkB,CAAC,UAA0C;AACzE,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,cAAc;AACnE;AAEa,MAAA,wBAAwB,CACpC,UACiC;AACjC,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,oBAAoB;AACzE;AAEa,MAAA,kBAAkB,CAAC,UAA0C;AACzE,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,cAAc;AACnE;"}
1
+ {"version":3,"file":"errors.js","sources":["../../src/errors.ts"],"sourcesContent":["import { HookError } from \"@slicemachine/plugin-kit\";\n\nexport class SliceMachineError extends Error {\n\t_sliceMachineError = true;\n\tname = \"SliceMachineError\";\n}\nexport class UnauthorizedError extends SliceMachineError {\n\tname = \"UnauthorizedError\";\n}\nexport class UnauthenticatedError extends SliceMachineError {\n\tname = \"UnauthenticatedError\";\n\tmessage = \"Authenticate before trying again.\";\n}\nexport class NotFoundError extends SliceMachineError {\n\tname = \"NotFoundError\";\n}\nexport class UnexpectedDataError extends SliceMachineError {\n\tname = \"UnexpectedDataError\";\n}\nexport class InternalError extends SliceMachineError {\n\tname = \"InternalError\";\n}\nexport class PluginError extends SliceMachineError {\n\tname = \"PluginError\";\n}\nexport class PluginHookResultError extends SliceMachineError {\n\tname = \"PluginHookResultError\";\n\n\tconstructor(errors: HookError[]) {\n\t\tsuper(\n\t\t\t`${errors.length} error${\n\t\t\t\terrors.length === 1 ? \"\" : \"s\"\n\t\t\t} were returned by one or more plugins.`,\n\t\t\t{\n\t\t\t\tcause: errors,\n\t\t\t},\n\t\t);\n\t}\n}\n\nexport const isSliceMachineError = (\n\terror: unknown,\n): error is SliceMachineError => {\n\treturn (\n\t\ttypeof error === \"object\" && error !== null && \"_sliceMachineError\" in error\n\t);\n};\n\nexport const isUnauthorizedError = (\n\terror: unknown,\n): error is UnauthorizedError => {\n\treturn isSliceMachineError(error) && error.name === UnauthorizedError.name;\n};\n\nexport const isUnauthenticatedError = (\n\terror: unknown,\n): error is UnauthenticatedError => {\n\treturn isSliceMachineError(error) && error.name === UnauthenticatedError.name;\n};\n\nexport const isNotFoundError = (error: unknown): error is NotFoundError => {\n\treturn isSliceMachineError(error) && error.name === NotFoundError.name;\n};\n\nexport const isUnexpectedDataError = (\n\terror: unknown,\n): error is UnexpectedDataError => {\n\treturn isSliceMachineError(error) && error.name === UnexpectedDataError.name;\n};\n\nexport const isInternalError = (error: unknown): error is InternalError => {\n\treturn isSliceMachineError(error) && error.name === InternalError.name;\n};\n"],"names":[],"mappings":";;;;;;AAEM,MAAO,0BAA0B,MAAK;AAAA,EAAtC;AAAA;AACL,8CAAqB;AACrB,gCAAO;AAAA;AACP;AACK,MAAO,0BAA0B,kBAAiB;AAAA,EAAlD;AAAA;AACL,gCAAO;AAAA;AACP;AACK,MAAO,6BAA6B,kBAAiB;AAAA,EAArD;AAAA;AACL,gCAAO;AACP,mCAAU;AAAA;AACV;AACK,MAAO,sBAAsB,kBAAiB;AAAA,EAA9C;AAAA;AACL,gCAAO;AAAA;AACP;AACK,MAAO,4BAA4B,kBAAiB;AAAA,EAApD;AAAA;AACL,gCAAO;AAAA;AACP;AACK,MAAO,sBAAsB,kBAAiB;AAAA,EAA9C;AAAA;AACL,gCAAO;AAAA;AACP;AAmBY,MAAA,sBAAsB,CAClC,UAC+B;AAC/B,SACC,OAAO,UAAU,YAAY,UAAU,QAAQ,wBAAwB;AAEzE;AAEa,MAAA,sBAAsB,CAClC,UAC+B;AAC/B,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,kBAAkB;AACvE;AAEa,MAAA,yBAAyB,CACrC,UACkC;AAClC,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,qBAAqB;AAC1E;AAEa,MAAA,kBAAkB,CAAC,UAA0C;AACzE,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,cAAc;AACnE;AAEa,MAAA,wBAAwB,CACpC,UACiC;AACjC,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,oBAAoB;AACzE;AAEa,MAAA,kBAAkB,CAAC,UAA0C;AACzE,SAAO,oBAAoB,KAAK,KAAK,MAAM,SAAS,cAAc;AACnE;"}
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const API_ENDPOINTS = require("../constants/API_ENDPOINTS.cjs");
4
+ const buildPrismicRepositoryAPIEndpoint = (repositoryName, { withCDN = true } = {}) => {
5
+ const baseEndpoint = new URL(API_ENDPOINTS.API_ENDPOINTS.PrismicWroom);
6
+ return `${baseEndpoint.protocol}://${repositoryName}${withCDN ? ".cdn" : ""}.${baseEndpoint.host}/api/v2`;
7
+ };
8
+ exports.buildPrismicRepositoryAPIEndpoint = buildPrismicRepositoryAPIEndpoint;
9
+ //# sourceMappingURL=buildPrismicRepositoryAPIEndpoint.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildPrismicRepositoryAPIEndpoint.cjs","sources":["../../../src/lib/buildPrismicRepositoryAPIEndpoint.ts"],"sourcesContent":["import { API_ENDPOINTS } from \"../constants/API_ENDPOINTS\";\n\nexport type BuildPrismicRepositoryAPIEndpointConfig = {\n\twithCDN?: boolean;\n};\n\nexport const buildPrismicRepositoryAPIEndpoint = (\n\trepositoryName: string,\n\t{ withCDN = true }: BuildPrismicRepositoryAPIEndpointConfig = {},\n): string => {\n\tconst baseEndpoint = new URL(API_ENDPOINTS.PrismicWroom);\n\n\treturn `${baseEndpoint.protocol}://${repositoryName}${\n\t\twithCDN ? \".cdn\" : \"\"\n\t}.${baseEndpoint.host}/api/v2`;\n};\n"],"names":["API_ENDPOINTS"],"mappings":";;;AAMa,MAAA,oCAAoC,CAChD,gBACA,EAAE,UAAU,KAAkD,IAAA,CAAA,MACnD;AACX,QAAM,eAAe,IAAI,IAAIA,cAAA,cAAc,YAAY;AAEvD,SAAO,GAAG,aAAa,cAAc,iBACpC,UAAU,SAAS,MAChB,aAAa;AAClB;;"}
@@ -0,0 +1,4 @@
1
+ export type BuildPrismicRepositoryAPIEndpointConfig = {
2
+ withCDN?: boolean;
3
+ };
4
+ export declare const buildPrismicRepositoryAPIEndpoint: (repositoryName: string, { withCDN }?: BuildPrismicRepositoryAPIEndpointConfig) => string;
@@ -0,0 +1,9 @@
1
+ import { API_ENDPOINTS } from "../constants/API_ENDPOINTS.js";
2
+ const buildPrismicRepositoryAPIEndpoint = (repositoryName, { withCDN = true } = {}) => {
3
+ const baseEndpoint = new URL(API_ENDPOINTS.PrismicWroom);
4
+ return `${baseEndpoint.protocol}://${repositoryName}${withCDN ? ".cdn" : ""}.${baseEndpoint.host}/api/v2`;
5
+ };
6
+ export {
7
+ buildPrismicRepositoryAPIEndpoint
8
+ };
9
+ //# sourceMappingURL=buildPrismicRepositoryAPIEndpoint.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"buildPrismicRepositoryAPIEndpoint.js","sources":["../../../src/lib/buildPrismicRepositoryAPIEndpoint.ts"],"sourcesContent":["import { API_ENDPOINTS } from \"../constants/API_ENDPOINTS\";\n\nexport type BuildPrismicRepositoryAPIEndpointConfig = {\n\twithCDN?: boolean;\n};\n\nexport const buildPrismicRepositoryAPIEndpoint = (\n\trepositoryName: string,\n\t{ withCDN = true }: BuildPrismicRepositoryAPIEndpointConfig = {},\n): string => {\n\tconst baseEndpoint = new URL(API_ENDPOINTS.PrismicWroom);\n\n\treturn `${baseEndpoint.protocol}://${repositoryName}${\n\t\twithCDN ? \".cdn\" : \"\"\n\t}.${baseEndpoint.host}/api/v2`;\n};\n"],"names":[],"mappings":";AAMa,MAAA,oCAAoC,CAChD,gBACA,EAAE,UAAU,KAAkD,IAAA,CAAA,MACnD;AACX,QAAM,eAAe,IAAI,IAAI,cAAc,YAAY;AAEvD,SAAO,GAAG,aAAa,cAAc,iBACpC,UAAU,SAAS,MAChB,aAAa;AAClB;"}
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const t = require("io-ts");
4
+ const decode = require("./decode.cjs");
5
+ function _interopNamespaceDefault(e) {
6
+ const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
7
+ if (e) {
8
+ for (const k in e) {
9
+ if (k !== "default") {
10
+ const d = Object.getOwnPropertyDescriptor(e, k);
11
+ Object.defineProperty(n, k, d.get ? d : {
12
+ enumerable: true,
13
+ get: () => e[k]
14
+ });
15
+ }
16
+ }
17
+ }
18
+ n.default = e;
19
+ return Object.freeze(n);
20
+ }
21
+ const t__namespace = /* @__PURE__ */ _interopNamespaceDefault(t);
22
+ const PackageJSONCodec = t__namespace.type({
23
+ version: t__namespace.string
24
+ });
25
+ const decodePackageJSON = (input) => {
26
+ return decode.decode(PackageJSONCodec, input);
27
+ };
28
+ exports.decodePackageJSON = decodePackageJSON;
29
+ //# sourceMappingURL=decodePackageJSON.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decodePackageJSON.cjs","sources":["../../../src/lib/decodePackageJSON.ts"],"sourcesContent":["import * as t from \"io-ts\";\n\nimport { decode, DecodeReturnType } from \"./decode\";\n\n/**\n * A minimally defined codec for package.json files. Only data needed for\n * version detection is defined.\n */\nconst PackageJSONCodec = t.type({\n\tversion: t.string,\n});\ntype PackageJSON = t.TypeOf<typeof PackageJSONCodec>;\n\nexport const decodePackageJSON = (\n\tinput: unknown,\n): DecodeReturnType<PackageJSON, PackageJSON, unknown> => {\n\treturn decode(PackageJSONCodec, input);\n};\n"],"names":["t","decode"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAQA,MAAM,mBAAmBA,aAAE,KAAK;AAAA,EAC/B,SAASA,aAAE;AACX,CAAA;AAGY,MAAA,oBAAoB,CAChC,UACwD;AACjD,SAAAC,OAAA,OAAO,kBAAkB,KAAK;AACtC;;"}
@@ -0,0 +1,12 @@
1
+ import * as t from "io-ts";
2
+ import { DecodeReturnType } from "./decode";
3
+ /**
4
+ * A minimally defined codec for package.json files. Only data needed for
5
+ * version detection is defined.
6
+ */
7
+ declare const PackageJSONCodec: t.TypeC<{
8
+ version: t.StringC;
9
+ }>;
10
+ type PackageJSON = t.TypeOf<typeof PackageJSONCodec>;
11
+ export declare const decodePackageJSON: (input: unknown) => DecodeReturnType<PackageJSON, PackageJSON, unknown>;
12
+ export {};
@@ -0,0 +1,12 @@
1
+ import * as t from "io-ts";
2
+ import { decode } from "./decode.js";
3
+ const PackageJSONCodec = t.type({
4
+ version: t.string
5
+ });
6
+ const decodePackageJSON = (input) => {
7
+ return decode(PackageJSONCodec, input);
8
+ };
9
+ export {
10
+ decodePackageJSON
11
+ };
12
+ //# sourceMappingURL=decodePackageJSON.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decodePackageJSON.js","sources":["../../../src/lib/decodePackageJSON.ts"],"sourcesContent":["import * as t from \"io-ts\";\n\nimport { decode, DecodeReturnType } from \"./decode\";\n\n/**\n * A minimally defined codec for package.json files. Only data needed for\n * version detection is defined.\n */\nconst PackageJSONCodec = t.type({\n\tversion: t.string,\n});\ntype PackageJSON = t.TypeOf<typeof PackageJSONCodec>;\n\nexport const decodePackageJSON = (\n\tinput: unknown,\n): DecodeReturnType<PackageJSON, PackageJSON, unknown> => {\n\treturn decode(PackageJSONCodec, input);\n};\n"],"names":[],"mappings":";;AAQA,MAAM,mBAAmB,EAAE,KAAK;AAAA,EAC/B,SAAS,EAAE;AACX,CAAA;AAGY,MAAA,oBAAoB,CAChC,UACwD;AACjD,SAAA,OAAO,kBAAkB,KAAK;AACtC;"}
@@ -24,20 +24,17 @@ const fs__namespace = /* @__PURE__ */ _interopNamespaceDefault(fs);
24
24
  const locateFileUpward = async (filePathOrPaths, { startDir = process.cwd(), stopDir = path__namespace.resolve("/"), _originalStartDir } = {}) => {
25
25
  const originalStartDir = _originalStartDir ?? startDir;
26
26
  const filePaths = castArray.castArray(filePathOrPaths);
27
- try {
28
- for (const filePath of filePaths) {
29
- const resolvedFilePath = path__namespace.resolve(startDir, filePath);
30
- try {
31
- await fs__namespace.access(resolvedFilePath);
32
- return resolvedFilePath;
33
- } catch {
34
- continue;
35
- }
27
+ for (const filePath of filePaths) {
28
+ const resolvedFilePath = path__namespace.resolve(startDir, filePath);
29
+ try {
30
+ await fs__namespace.access(resolvedFilePath);
31
+ return resolvedFilePath;
32
+ } catch {
33
+ continue;
36
34
  }
37
- } catch {
38
35
  }
39
36
  if (startDir === stopDir) {
40
- const formattedFilePaths = filePaths.map((filePath) => `\`${filePath}\``).join(" or ");
37
+ const formattedFilePaths = filePaths.map((filePath) => "`" + filePath + "`").join(" or ");
41
38
  throw new Error(`Could not locate ${formattedFilePaths} between \`${originalStartDir}\` and \`${stopDir}\`.`);
42
39
  }
43
40
  return locateFileUpward(filePathOrPaths, {
@@ -1 +1 @@
1
- {"version":3,"file":"locateFileUpward.cjs","sources":["../../../src/lib/locateFileUpward.ts"],"sourcesContent":["import * as path from \"node:path\";\nimport * as fs from \"node:fs/promises\";\n\nimport { castArray } from \"./castArray\";\n\ntype LocateFileUpwardConfig = {\n\tstartDir?: string;\n\tstopDir?: string;\n\t/**\n\t * @internal\n\t */\n\t_originalStartDir?: string;\n};\n\nexport const locateFileUpward = async (\n\tfilePathOrPaths: string | readonly string[],\n\t{\n\t\tstartDir = process.cwd(),\n\t\tstopDir = path.resolve(\"/\"),\n\t\t_originalStartDir,\n\t}: LocateFileUpwardConfig = {},\n): Promise<string> => {\n\tconst originalStartDir = _originalStartDir ?? startDir;\n\n\tconst filePaths = castArray(filePathOrPaths);\n\n\ttry {\n\t\tfor (const filePath of filePaths) {\n\t\t\tconst resolvedFilePath = path.resolve(startDir, filePath);\n\n\t\t\ttry {\n\t\t\t\tawait fs.access(resolvedFilePath);\n\n\t\t\t\treturn resolvedFilePath;\n\t\t\t} catch {\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t}\n\t} catch {\n\t\t// noop\n\t}\n\n\tif (startDir === stopDir) {\n\t\tconst formattedFilePaths = filePaths\n\t\t\t.map((filePath) => `\\`${filePath}\\``)\n\t\t\t.join(\" or \");\n\n\t\tthrow new Error(\n\t\t\t`Could not locate ${formattedFilePaths} between \\`${originalStartDir}\\` and \\`${stopDir}\\`.`,\n\t\t);\n\t}\n\n\treturn locateFileUpward(filePathOrPaths, {\n\t\tstartDir: path.resolve(startDir, \"..\"),\n\t\tstopDir,\n\t\t_originalStartDir: originalStartDir,\n\t});\n};\n"],"names":["path","castArray","fs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAcO,MAAM,mBAAmB,OAC/B,iBACA,EACC,WAAW,QAAQ,IAAK,GACxB,UAAUA,gBAAK,QAAQ,GAAG,GAC1B,kBAC2B,IAAA,CAAA,MACR;AACpB,QAAM,mBAAmB,qBAAqB;AAExC,QAAA,YAAYC,oBAAU,eAAe;AAEvC,MAAA;AACH,eAAW,YAAY,WAAW;AACjC,YAAM,mBAAmBD,gBAAK,QAAQ,UAAU,QAAQ;AAEpD,UAAA;AACG,cAAAE,cAAG,OAAO,gBAAgB;AAEzB,eAAA;AAAA,MAAA,QACN;AACD;AAAA,MACA;AAAA,IACD;AAAA,EAAA,QACA;AAAA,EAED;AAED,MAAI,aAAa,SAAS;AACnB,UAAA,qBAAqB,UACzB,IAAI,CAAC,aAAa,KAAK,YAAY,EACnC,KAAK,MAAM;AAEb,UAAM,IAAI,MACT,oBAAoB,gCAAgC,4BAA4B,YAAY;AAAA,EAE7F;AAED,SAAO,iBAAiB,iBAAiB;AAAA,IACxC,UAAUF,gBAAK,QAAQ,UAAU,IAAI;AAAA,IACrC;AAAA,IACA,mBAAmB;AAAA,EAAA,CACnB;AACF;;"}
1
+ {"version":3,"file":"locateFileUpward.cjs","sources":["../../../src/lib/locateFileUpward.ts"],"sourcesContent":["import * as path from \"node:path\";\nimport * as fs from \"node:fs/promises\";\n\nimport { castArray } from \"./castArray\";\n\ntype LocateFileUpwardConfig = {\n\tstartDir?: string;\n\tstopDir?: string;\n\t/**\n\t * @internal\n\t */\n\t_originalStartDir?: string;\n};\n\nexport const locateFileUpward = async (\n\tfilePathOrPaths: string | readonly string[],\n\t{\n\t\tstartDir = process.cwd(),\n\t\tstopDir = path.resolve(\"/\"),\n\t\t_originalStartDir,\n\t}: LocateFileUpwardConfig = {},\n): Promise<string> => {\n\tconst originalStartDir = _originalStartDir ?? startDir;\n\n\tconst filePaths = castArray(filePathOrPaths);\n\n\tfor (const filePath of filePaths) {\n\t\tconst resolvedFilePath = path.resolve(startDir, filePath);\n\n\t\ttry {\n\t\t\tawait fs.access(resolvedFilePath);\n\n\t\t\treturn resolvedFilePath;\n\t\t} catch {\n\t\t\tcontinue;\n\t\t}\n\t}\n\n\tif (startDir === stopDir) {\n\t\tconst formattedFilePaths = filePaths\n\t\t\t.map((filePath) => \"`\" + filePath + \"`\")\n\t\t\t.join(\" or \");\n\n\t\tthrow new Error(\n\t\t\t`Could not locate ${formattedFilePaths} between \\`${originalStartDir}\\` and \\`${stopDir}\\`.`,\n\t\t);\n\t}\n\n\treturn locateFileUpward(filePathOrPaths, {\n\t\tstartDir: path.resolve(startDir, \"..\"),\n\t\tstopDir,\n\t\t_originalStartDir: originalStartDir,\n\t});\n};\n"],"names":["path","castArray","fs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAcO,MAAM,mBAAmB,OAC/B,iBACA,EACC,WAAW,QAAQ,IAAK,GACxB,UAAUA,gBAAK,QAAQ,GAAG,GAC1B,kBAC2B,IAAA,CAAA,MACR;AACpB,QAAM,mBAAmB,qBAAqB;AAExC,QAAA,YAAYC,oBAAU,eAAe;AAE3C,aAAW,YAAY,WAAW;AACjC,UAAM,mBAAmBD,gBAAK,QAAQ,UAAU,QAAQ;AAEpD,QAAA;AACG,YAAAE,cAAG,OAAO,gBAAgB;AAEzB,aAAA;AAAA,IAAA,QACN;AACD;AAAA,IACA;AAAA,EACD;AAED,MAAI,aAAa,SAAS;AACnB,UAAA,qBAAqB,UACzB,IAAI,CAAC,aAAa,MAAM,WAAW,GAAG,EACtC,KAAK,MAAM;AAEb,UAAM,IAAI,MACT,oBAAoB,gCAAgC,4BAA4B,YAAY;AAAA,EAE7F;AAED,SAAO,iBAAiB,iBAAiB;AAAA,IACxC,UAAUF,gBAAK,QAAQ,UAAU,IAAI;AAAA,IACrC;AAAA,IACA,mBAAmB;AAAA,EAAA,CACnB;AACF;;"}
@@ -4,20 +4,17 @@ import { castArray } from "./castArray.js";
4
4
  const locateFileUpward = async (filePathOrPaths, { startDir = process.cwd(), stopDir = path.resolve("/"), _originalStartDir } = {}) => {
5
5
  const originalStartDir = _originalStartDir ?? startDir;
6
6
  const filePaths = castArray(filePathOrPaths);
7
- try {
8
- for (const filePath of filePaths) {
9
- const resolvedFilePath = path.resolve(startDir, filePath);
10
- try {
11
- await fs.access(resolvedFilePath);
12
- return resolvedFilePath;
13
- } catch {
14
- continue;
15
- }
7
+ for (const filePath of filePaths) {
8
+ const resolvedFilePath = path.resolve(startDir, filePath);
9
+ try {
10
+ await fs.access(resolvedFilePath);
11
+ return resolvedFilePath;
12
+ } catch {
13
+ continue;
16
14
  }
17
- } catch {
18
15
  }
19
16
  if (startDir === stopDir) {
20
- const formattedFilePaths = filePaths.map((filePath) => `\`${filePath}\``).join(" or ");
17
+ const formattedFilePaths = filePaths.map((filePath) => "`" + filePath + "`").join(" or ");
21
18
  throw new Error(`Could not locate ${formattedFilePaths} between \`${originalStartDir}\` and \`${stopDir}\`.`);
22
19
  }
23
20
  return locateFileUpward(filePathOrPaths, {
@@ -1 +1 @@
1
- {"version":3,"file":"locateFileUpward.js","sources":["../../../src/lib/locateFileUpward.ts"],"sourcesContent":["import * as path from \"node:path\";\nimport * as fs from \"node:fs/promises\";\n\nimport { castArray } from \"./castArray\";\n\ntype LocateFileUpwardConfig = {\n\tstartDir?: string;\n\tstopDir?: string;\n\t/**\n\t * @internal\n\t */\n\t_originalStartDir?: string;\n};\n\nexport const locateFileUpward = async (\n\tfilePathOrPaths: string | readonly string[],\n\t{\n\t\tstartDir = process.cwd(),\n\t\tstopDir = path.resolve(\"/\"),\n\t\t_originalStartDir,\n\t}: LocateFileUpwardConfig = {},\n): Promise<string> => {\n\tconst originalStartDir = _originalStartDir ?? startDir;\n\n\tconst filePaths = castArray(filePathOrPaths);\n\n\ttry {\n\t\tfor (const filePath of filePaths) {\n\t\t\tconst resolvedFilePath = path.resolve(startDir, filePath);\n\n\t\t\ttry {\n\t\t\t\tawait fs.access(resolvedFilePath);\n\n\t\t\t\treturn resolvedFilePath;\n\t\t\t} catch {\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t}\n\t} catch {\n\t\t// noop\n\t}\n\n\tif (startDir === stopDir) {\n\t\tconst formattedFilePaths = filePaths\n\t\t\t.map((filePath) => `\\`${filePath}\\``)\n\t\t\t.join(\" or \");\n\n\t\tthrow new Error(\n\t\t\t`Could not locate ${formattedFilePaths} between \\`${originalStartDir}\\` and \\`${stopDir}\\`.`,\n\t\t);\n\t}\n\n\treturn locateFileUpward(filePathOrPaths, {\n\t\tstartDir: path.resolve(startDir, \"..\"),\n\t\tstopDir,\n\t\t_originalStartDir: originalStartDir,\n\t});\n};\n"],"names":[],"mappings":";;;AAcO,MAAM,mBAAmB,OAC/B,iBACA,EACC,WAAW,QAAQ,IAAK,GACxB,UAAU,KAAK,QAAQ,GAAG,GAC1B,kBAC2B,IAAA,CAAA,MACR;AACpB,QAAM,mBAAmB,qBAAqB;AAExC,QAAA,YAAY,UAAU,eAAe;AAEvC,MAAA;AACH,eAAW,YAAY,WAAW;AACjC,YAAM,mBAAmB,KAAK,QAAQ,UAAU,QAAQ;AAEpD,UAAA;AACG,cAAA,GAAG,OAAO,gBAAgB;AAEzB,eAAA;AAAA,MAAA,QACN;AACD;AAAA,MACA;AAAA,IACD;AAAA,EAAA,QACA;AAAA,EAED;AAED,MAAI,aAAa,SAAS;AACnB,UAAA,qBAAqB,UACzB,IAAI,CAAC,aAAa,KAAK,YAAY,EACnC,KAAK,MAAM;AAEb,UAAM,IAAI,MACT,oBAAoB,gCAAgC,4BAA4B,YAAY;AAAA,EAE7F;AAED,SAAO,iBAAiB,iBAAiB;AAAA,IACxC,UAAU,KAAK,QAAQ,UAAU,IAAI;AAAA,IACrC;AAAA,IACA,mBAAmB;AAAA,EAAA,CACnB;AACF;"}
1
+ {"version":3,"file":"locateFileUpward.js","sources":["../../../src/lib/locateFileUpward.ts"],"sourcesContent":["import * as path from \"node:path\";\nimport * as fs from \"node:fs/promises\";\n\nimport { castArray } from \"./castArray\";\n\ntype LocateFileUpwardConfig = {\n\tstartDir?: string;\n\tstopDir?: string;\n\t/**\n\t * @internal\n\t */\n\t_originalStartDir?: string;\n};\n\nexport const locateFileUpward = async (\n\tfilePathOrPaths: string | readonly string[],\n\t{\n\t\tstartDir = process.cwd(),\n\t\tstopDir = path.resolve(\"/\"),\n\t\t_originalStartDir,\n\t}: LocateFileUpwardConfig = {},\n): Promise<string> => {\n\tconst originalStartDir = _originalStartDir ?? startDir;\n\n\tconst filePaths = castArray(filePathOrPaths);\n\n\tfor (const filePath of filePaths) {\n\t\tconst resolvedFilePath = path.resolve(startDir, filePath);\n\n\t\ttry {\n\t\t\tawait fs.access(resolvedFilePath);\n\n\t\t\treturn resolvedFilePath;\n\t\t} catch {\n\t\t\tcontinue;\n\t\t}\n\t}\n\n\tif (startDir === stopDir) {\n\t\tconst formattedFilePaths = filePaths\n\t\t\t.map((filePath) => \"`\" + filePath + \"`\")\n\t\t\t.join(\" or \");\n\n\t\tthrow new Error(\n\t\t\t`Could not locate ${formattedFilePaths} between \\`${originalStartDir}\\` and \\`${stopDir}\\`.`,\n\t\t);\n\t}\n\n\treturn locateFileUpward(filePathOrPaths, {\n\t\tstartDir: path.resolve(startDir, \"..\"),\n\t\tstopDir,\n\t\t_originalStartDir: originalStartDir,\n\t});\n};\n"],"names":[],"mappings":";;;AAcO,MAAM,mBAAmB,OAC/B,iBACA,EACC,WAAW,QAAQ,IAAK,GACxB,UAAU,KAAK,QAAQ,GAAG,GAC1B,kBAC2B,IAAA,CAAA,MACR;AACpB,QAAM,mBAAmB,qBAAqB;AAExC,QAAA,YAAY,UAAU,eAAe;AAE3C,aAAW,YAAY,WAAW;AACjC,UAAM,mBAAmB,KAAK,QAAQ,UAAU,QAAQ;AAEpD,QAAA;AACG,YAAA,GAAG,OAAO,gBAAgB;AAEzB,aAAA;AAAA,IAAA,QACN;AACD;AAAA,IACA;AAAA,EACD;AAED,MAAI,aAAa,SAAS;AACnB,UAAA,qBAAqB,UACzB,IAAI,CAAC,aAAa,MAAM,WAAW,GAAG,EACtC,KAAK,MAAM;AAEb,UAAM,IAAI,MACT,oBAAoB,gCAAgC,4BAA4B,YAAY;AAAA,EAE7F;AAED,SAAO,iBAAiB,iBAAiB;AAAA,IACxC,UAAU,KAAK,QAAQ,UAAU,IAAI;AAAA,IACrC;AAAA,IACA,mBAAmB;AAAA,EAAA,CACnB;AACF;"}
@@ -8,6 +8,7 @@ var __publicField = (obj, key, value) => {
8
8
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
9
9
  const createContentDigest = require("../lib/createContentDigest.cjs");
10
10
  const createPrismicAuthManager = require("../auth/createPrismicAuthManager.cjs");
11
+ const API_ENDPOINTS = require("../constants/API_ENDPOINTS.cjs");
11
12
  const UserManager = require("./user/UserManager.cjs");
12
13
  const PrismicRepositoryManager = require("./prismicRepository/PrismicRepositoryManager.cjs");
13
14
  const PluginsManager = require("./plugins/PluginsManager.cjs");
@@ -19,6 +20,7 @@ const ScreenshotsManager = require("./screenshots/ScreenshotsManager.cjs");
19
20
  const SimulatorManager = require("./simulator/SimulatorManager.cjs");
20
21
  const VersionsManager = require("./versions/VersionsManager.cjs");
21
22
  const TelemetryManager = require("./telemetry/TelemetryManager.cjs");
23
+ const buildPrismicRepositoryAPIEndpoint = require("../lib/buildPrismicRepositoryAPIEndpoint.cjs");
22
24
  class SliceMachineManager {
23
25
  constructor(args) {
24
26
  __publicField(this, "_sliceMachinePluginRunner");
@@ -67,17 +69,14 @@ class SliceMachineManager {
67
69
  getPrismicAuthManager() {
68
70
  return this._prismicAuthManager;
69
71
  }
72
+ getAPIEndpoints() {
73
+ return API_ENDPOINTS.API_ENDPOINTS;
74
+ }
70
75
  // TODO: Remove this global-state method. It is expensive and a
71
76
  // potential source of bugs due to data inconsistency. SM UI relies on
72
77
  // it heavily, so removal will require significant effort.
73
78
  async getState() {
74
- const [
75
- { sliceMachineConfig, libraries },
76
- { profile, remoteCustomTypes, remoteSlices },
77
- customTypes
78
- // currentVersion,
79
- // allStableVersions,
80
- ] = await Promise.all([
79
+ const [{ sliceMachineConfig, libraries }, { profile, remoteCustomTypes, remoteSlices }, customTypes] = await Promise.all([
81
80
  this.project.getSliceMachineConfig().then(async (sliceMachineConfig2) => {
82
81
  const libraries2 = await this._getLibraries(sliceMachineConfig2);
83
82
  return { sliceMachineConfig: sliceMachineConfig2, libraries: libraries2 };
@@ -102,14 +101,19 @@ class SliceMachineManager {
102
101
  }
103
102
  }),
104
103
  this._getCustomTypes()
105
- // this.versions.getRunningSliceMachineVersion(),
106
- // this.versions.getAllStableSliceMachineVersions(),
107
104
  ]);
108
- const clientError = profile ? void 0 : { message: "Could not fetch slices", status: 401 };
105
+ const clientError = profile ? void 0 : {
106
+ name: "__stub__",
107
+ message: "__stub__",
108
+ reason: "__stub__",
109
+ status: 401
110
+ // Needed to trigger the unauthorized flow.
111
+ };
109
112
  return {
110
113
  env: {
111
114
  framework: "",
112
115
  manifest: {
116
+ apiEndpoint: sliceMachineConfig.apiEndpoint || buildPrismicRepositoryAPIEndpoint.buildPrismicRepositoryAPIEndpoint(sliceMachineConfig.repositoryName),
113
117
  localSliceSimulatorURL: sliceMachineConfig.localSliceSimulatorURL
114
118
  },
115
119
  mockConfig: {},
@@ -176,7 +180,9 @@ class SliceMachineManager {
176
180
  extension: "extension",
177
181
  model,
178
182
  screenshots,
179
- mock: mocks
183
+ mock: mocks,
184
+ mockConfig: {}
185
+ // TODO: This property can probably be removed.
180
186
  });
181
187
  }
182
188
  }));
@@ -1 +1 @@
1
- {"version":3,"file":"SliceMachineManager.cjs","sources":["../../../src/managers/SliceMachineManager.ts"],"sourcesContent":["import { CustomTypes } from \"@prismicio/types-internal\";\nimport { SharedSliceContent } from \"@prismicio/types-internal/lib/content\";\nimport {\n\tSliceMachinePlugin,\n\tSliceMachinePluginRunner,\n} from \"@slicemachine/plugin-kit\";\n\nimport { createContentDigest } from \"../lib/createContentDigest\";\n\nimport {\n\tPackageChangelog,\n\tPackageManager,\n\t// PackageVersion,\n\tSliceMachineConfig,\n} from \"../types\";\nimport {\n\tPrismicAuthManager,\n\tPrismicUserProfile,\n} from \"../auth/PrismicAuthManager\";\nimport { createPrismicAuthManager } from \"../auth/createPrismicAuthManager\";\n\nimport { UserManager } from \"./user/UserManager\";\nimport { PrismicRepositoryManager } from \"./prismicRepository/PrismicRepositoryManager\";\n\nimport { PluginsManager } from \"./plugins/PluginsManager\";\n\nimport { ProjectManager } from \"./project/ProjectManager\";\nimport { CustomTypesManager } from \"./customTypes/CustomTypesManager\";\nimport { SlicesManager } from \"./slices/SlicesManager\";\nimport { SnippetsManager } from \"./snippets/SnippetsManager\";\nimport { ScreenshotsManager } from \"./screenshots/ScreenshotsManager\";\nimport { SimulatorManager } from \"./simulator/SimulatorManager\";\n\nimport { VersionsManager } from \"./versions/VersionsManager\";\n\nimport { TelemetryManager } from \"./telemetry/TelemetryManager\";\n\ntype SliceMachineManagerGetStateReturnType = {\n\tenv: {\n\t\tshortId?: string;\n\t\tintercomHash?: string;\n\t\tmanifest: {\n\t\t\tlocalSliceSimulatorURL?: string;\n\t\t};\n\t\trepo: string;\n\t\tchangelog?: PackageChangelog;\n\t\tpackageManager: PackageManager;\n\t\tmockConfig: unknown;\n\t\tframework: unknown; // TODO: Remove\n\t\tsliceMachineAPIUrl: string;\n\t};\n\tlibraries: {\n\t\tname: string;\n\t\tpath: string;\n\t\tisLocal: boolean;\n\t\tcomponents: {\n\t\t\tfrom: string;\n\t\t\thref: string;\n\t\t\tpathToSlice: string;\n\t\t\tfileName: string | null;\n\t\t\textension: string | null;\n\t\t\tmodel: CustomTypes.Widgets.Slices.SharedSlice;\n\t\t\tscreenshots: Record<\n\t\t\t\tstring,\n\t\t\t\t{\n\t\t\t\t\tpath: string;\n\t\t\t\t\thash: string;\n\t\t\t\t\tdata: Buffer;\n\t\t\t\t}\n\t\t\t>;\n\t\t\tmock?: SharedSliceContent[];\n\t\t}[];\n\t\tmeta: {\n\t\t\tname?: string;\n\t\t\tversion?: string;\n\t\t\tisNodeModule: boolean;\n\t\t\tisDownloaded: boolean;\n\t\t\tisManual: boolean;\n\t\t};\n\t}[];\n\tcustomTypes: CustomTypes.CustomType[];\n\tremoteCustomTypes: CustomTypes.CustomType[];\n\tremoteSlices: CustomTypes.Widgets.Slices.SharedSlice[];\n\tclientError?: { message: string; status: number };\n};\n\ntype SliceMachineManagerConstructorArgs = {\n\tcwd?: string;\n\tnativePlugins?: Record<string, SliceMachinePlugin>;\n};\n\nexport class SliceMachineManager {\n\tprivate _sliceMachinePluginRunner: SliceMachinePluginRunner | undefined =\n\t\tundefined;\n\tprivate _prismicAuthManager: PrismicAuthManager;\n\n\tcwd: string;\n\n\tcustomTypes: CustomTypesManager;\n\tplugins: PluginsManager;\n\tprismicRepository: PrismicRepositoryManager;\n\tproject: ProjectManager;\n\tscreenshots: ScreenshotsManager;\n\tsimulator: SimulatorManager;\n\tslices: SlicesManager;\n\tsnippets: SnippetsManager;\n\ttelemetry: TelemetryManager;\n\tuser: UserManager;\n\tversions: VersionsManager;\n\n\tconstructor(args?: SliceMachineManagerConstructorArgs) {\n\t\t// _prismicAuthManager must be set at least before UserManager\n\t\t// is instantiated. It depends on the PrismicAuthManager for\n\t\t// authentication-related methods.\n\t\tthis._prismicAuthManager = createPrismicAuthManager();\n\n\t\tthis.user = new UserManager(this);\n\t\tthis.prismicRepository = new PrismicRepositoryManager(this);\n\n\t\tthis.plugins = new PluginsManager(this, {\n\t\t\tnativePlugins: args?.nativePlugins,\n\t\t});\n\n\t\tthis.project = new ProjectManager(this);\n\t\tthis.customTypes = new CustomTypesManager(this);\n\t\tthis.slices = new SlicesManager(this);\n\t\tthis.snippets = new SnippetsManager(this);\n\t\tthis.screenshots = new ScreenshotsManager(this);\n\t\tthis.simulator = new SimulatorManager(this);\n\n\t\tthis.versions = new VersionsManager(this);\n\n\t\tthis.telemetry = new TelemetryManager(this);\n\n\t\tthis.cwd = args?.cwd ?? process.cwd();\n\t}\n\n\t// The `_sliceMachinePluginRunner` property is hidden behind a function to\n\t// discourage access. Using a function deliberatly breaks the pattern\n\t// of other child managers that are accessible as properties, like\n\t// `project`, `plugins`, etc. We do not treat SliceMachinePluginRunner\n\t// as a child manager.\n\tgetSliceMachinePluginRunner(): SliceMachinePluginRunner | undefined {\n\t\treturn this._sliceMachinePluginRunner;\n\t}\n\n\t// The `_prismicAuthManager` property is hidden behind a function to\n\t// discourage access. Using a function deliberatly breaks the pattern\n\t// of other child managers that are accessible as properties, like\n\t// `project`, `plugins`, etc. We do not treat PrismicAuthManager as a\n\t// child manager.\n\tgetPrismicAuthManager(): PrismicAuthManager {\n\t\treturn this._prismicAuthManager;\n\t}\n\n\t// TODO: Remove this global-state method. It is expensive and a\n\t// potential source of bugs due to data inconsistency. SM UI relies on\n\t// it heavily, so removal will require significant effort.\n\tasync getState(): Promise<SliceMachineManagerGetStateReturnType> {\n\t\tconst [\n\t\t\t{ sliceMachineConfig, libraries },\n\t\t\t{ profile, remoteCustomTypes, remoteSlices },\n\t\t\tcustomTypes,\n\t\t\t// currentVersion,\n\t\t\t// allStableVersions,\n\t\t] = await Promise.all([\n\t\t\tthis.project.getSliceMachineConfig().then(async (sliceMachineConfig) => {\n\t\t\t\tconst libraries = await this._getLibraries(sliceMachineConfig);\n\n\t\t\t\treturn { sliceMachineConfig, libraries };\n\t\t\t}),\n\t\t\tthis._getProfile().then(async (profile) => {\n\t\t\t\tif (profile) {\n\t\t\t\t\tconst [remoteCustomTypes, remoteSlices] = await Promise.all([\n\t\t\t\t\t\tthis.customTypes.fetchRemoteCustomTypes(),\n\t\t\t\t\t\tthis.slices.fetchRemoteSlices(),\n\t\t\t\t\t]);\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\tprofile,\n\t\t\t\t\t\tremoteCustomTypes,\n\t\t\t\t\t\tremoteSlices,\n\t\t\t\t\t};\n\t\t\t\t} else {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tprofile,\n\t\t\t\t\t\tremoteCustomTypes: [],\n\t\t\t\t\t\tremoteSlices: [],\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t}),\n\t\t\tthis._getCustomTypes(),\n\t\t\t// this.versions.getRunningSliceMachineVersion(),\n\t\t\t// this.versions.getAllStableSliceMachineVersions(),\n\t\t]);\n\n\t\t// const latestNonBreakingVersion = \"\"; // TODO\n\t\t// const updateAvailable = false; // TODO\n\t\t// const versions = await Promise.all(\n\t\t// \tallStableVersions.map(async (version): Promise<PackageVersion> => {\n\t\t// \t\tconst releaseNotes =\n\t\t// \t\t\tawait this.versions.getSliceMachineReleaseNotesForVersion({\n\t\t// \t\t\t\tversion,\n\t\t// \t\t\t});\n\t\t//\n\t\t// \t\treturn {\n\t\t// \t\t\tversionNumber: version,\n\t\t// \t\t\treleaseNote: releaseNotes ?? null,\n\t\t// \t\t\t// TODO\n\t\t// \t\t\tkind: \"MINOR\",\n\t\t// \t\t};\n\t\t// \t}),\n\t\t// );\n\n\t\t// TODO: SM UI detects if a user is logged out by looking at\n\t\t// `clientError`. Here, we simulate what the old core does by\n\t\t// returning an `ErrorWithStatus`-like object if the user is\n\t\t// not logged in.\n\t\tconst clientError: SliceMachineManagerGetStateReturnType[\"clientError\"] =\n\t\t\tprofile ? undefined : { message: \"Could not fetch slices\", status: 401 };\n\n\t\treturn {\n\t\t\tenv: {\n\t\t\t\tframework: \"\",\n\t\t\t\tmanifest: {\n\t\t\t\t\tlocalSliceSimulatorURL: sliceMachineConfig.localSliceSimulatorURL,\n\t\t\t\t},\n\t\t\t\tmockConfig: {},\n\t\t\t\t// TODO: Don't hardcode this!\n\t\t\t\tpackageManager: \"npm\",\n\t\t\t\t// TODO: Don't hardcode this!\n\t\t\t\trepo: sliceMachineConfig.repositoryName,\n\t\t\t\t// TODO: Don't hardcode this!\n\t\t\t\tsliceMachineAPIUrl: \"http://localhost:9999\",\n\t\t\t\tintercomHash: profile?.intercomHash,\n\t\t\t\tshortId: profile?.shortId,\n\t\t\t},\n\t\t\tlibraries,\n\t\t\tcustomTypes,\n\t\t\tremoteCustomTypes,\n\t\t\tremoteSlices,\n\t\t\tclientError,\n\t\t};\n\t}\n\n\tprivate async _getProfile(): Promise<PrismicUserProfile | undefined> {\n\t\tlet profile: PrismicUserProfile | undefined;\n\n\t\tconst isLoggedIn = await this.user.checkIsLoggedIn();\n\n\t\tif (isLoggedIn) {\n\t\t\tprofile = await this.user.getProfile();\n\t\t\tawait this.user.refreshAuthenticationToken();\n\t\t}\n\n\t\treturn profile;\n\t}\n\n\tprivate async _getLibraries(\n\t\tsliceMachineConfig: SliceMachineConfig,\n\t): Promise<SliceMachineManagerGetStateReturnType[\"libraries\"]> {\n\t\tconst libraries: SliceMachineManagerGetStateReturnType[\"libraries\"] = [];\n\n\t\tif (sliceMachineConfig.libraries) {\n\t\t\tawait Promise.all(\n\t\t\t\tsliceMachineConfig.libraries.map(async (libraryID) => {\n\t\t\t\t\tconst { sliceIDs } = await this.slices.readSliceLibrary({\n\t\t\t\t\t\tlibraryID,\n\t\t\t\t\t});\n\n\t\t\t\t\tif (sliceIDs) {\n\t\t\t\t\t\tconst components: SliceMachineManagerGetStateReturnType[\"libraries\"][number][\"components\"] =\n\t\t\t\t\t\t\t[];\n\n\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\tsliceIDs.map(async (sliceID) => {\n\t\t\t\t\t\t\t\tconst [{ model }, { mocks }] = await Promise.all([\n\t\t\t\t\t\t\t\t\tthis.slices.readSlice({ libraryID, sliceID }),\n\t\t\t\t\t\t\t\t\tthis.slices.readSliceMocks({ libraryID, sliceID }),\n\t\t\t\t\t\t\t\t]);\n\n\t\t\t\t\t\t\t\tif (model) {\n\t\t\t\t\t\t\t\t\tconst screenshots: typeof components[number][\"screenshots\"] =\n\t\t\t\t\t\t\t\t\t\t{};\n\t\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\t\tmodel.variations.map(async (variation) => {\n\t\t\t\t\t\t\t\t\t\t\tconst screenshot = await this.slices.readSliceScreenshot({\n\t\t\t\t\t\t\t\t\t\t\t\tlibraryID,\n\t\t\t\t\t\t\t\t\t\t\t\tsliceID,\n\t\t\t\t\t\t\t\t\t\t\t\tvariationID: variation.id,\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\tif (screenshot.data) {\n\t\t\t\t\t\t\t\t\t\t\t\tscreenshots[variation.id] = {\n\t\t\t\t\t\t\t\t\t\t\t\t\tpath: \"__stub__\",\n\t\t\t\t\t\t\t\t\t\t\t\t\thash: createContentDigest(screenshot.data),\n\t\t\t\t\t\t\t\t\t\t\t\t\tdata: screenshot.data,\n\t\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\t\tcomponents.push({\n\t\t\t\t\t\t\t\t\t\tfrom: libraryID,\n\t\t\t\t\t\t\t\t\t\thref: libraryID.replace(/\\//g, \"--\"),\n\t\t\t\t\t\t\t\t\t\tpathToSlice: \"pathToSlice\",\n\t\t\t\t\t\t\t\t\t\tfileName: \"fileName\",\n\t\t\t\t\t\t\t\t\t\textension: \"extension\",\n\t\t\t\t\t\t\t\t\t\tmodel,\n\t\t\t\t\t\t\t\t\t\tscreenshots,\n\t\t\t\t\t\t\t\t\t\tmock: mocks,\n\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tlibraries.push({\n\t\t\t\t\t\t\tname: libraryID,\n\t\t\t\t\t\t\tpath: libraryID,\n\t\t\t\t\t\t\tisLocal: true, // TODO: Do we still support node_modules-based libraries?\n\t\t\t\t\t\t\tcomponents,\n\t\t\t\t\t\t\tmeta: {\n\t\t\t\t\t\t\t\t// TODO: Do we still support node_modules-based libraries?\n\t\t\t\t\t\t\t\tisNodeModule: false,\n\t\t\t\t\t\t\t\tisDownloaded: false,\n\t\t\t\t\t\t\t\tisManual: true,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\n\t\treturn libraries;\n\t}\n\n\tprivate async _getCustomTypes(): Promise<\n\t\tSliceMachineManagerGetStateReturnType[\"customTypes\"]\n\t> {\n\t\tconst customTypes: SliceMachineManagerGetStateReturnType[\"customTypes\"] =\n\t\t\t[];\n\n\t\tconst { ids: customTypeIDs } =\n\t\t\tawait this.customTypes.readCustomTypeLibrary();\n\n\t\tif (customTypeIDs) {\n\t\t\tawait Promise.all(\n\t\t\t\tcustomTypeIDs.map(async (customTypeID) => {\n\t\t\t\t\tconst { model } = await this.customTypes.readCustomType({\n\t\t\t\t\t\tid: customTypeID,\n\t\t\t\t\t});\n\n\t\t\t\t\tif (model) {\n\t\t\t\t\t\tcustomTypes.push(model);\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\n\t\treturn customTypes;\n\t}\n}\n"],"names":["createPrismicAuthManager","UserManager","PrismicRepositoryManager","PluginsManager","ProjectManager","CustomTypesManager","SlicesManager","SnippetsManager","ScreenshotsManager","SimulatorManager","VersionsManager","TelemetryManager","sliceMachineConfig","libraries","profile","remoteCustomTypes","remoteSlices","createContentDigest"],"mappings":"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"}
1
+ {"version":3,"file":"SliceMachineManager.cjs","sources":["../../../src/managers/SliceMachineManager.ts"],"sourcesContent":["import { CustomTypes } from \"@prismicio/types-internal\";\nimport { SharedSliceContent } from \"@prismicio/types-internal/lib/content\";\nimport {\n\tSliceMachinePlugin,\n\tSliceMachinePluginRunner,\n} from \"@slicemachine/plugin-kit\";\n\nimport { createContentDigest } from \"../lib/createContentDigest\";\n\nimport { PackageChangelog, PackageManager, SliceMachineConfig } from \"../types\";\nimport {\n\tPrismicAuthManager,\n\tPrismicUserProfile,\n} from \"../auth/PrismicAuthManager\";\nimport { createPrismicAuthManager } from \"../auth/createPrismicAuthManager\";\n\nimport { API_ENDPOINTS, APIEndpoints } from \"../constants/API_ENDPOINTS\";\n\nimport { UserManager } from \"./user/UserManager\";\nimport { PrismicRepositoryManager } from \"./prismicRepository/PrismicRepositoryManager\";\n\nimport { PluginsManager } from \"./plugins/PluginsManager\";\n\nimport { ProjectManager } from \"./project/ProjectManager\";\nimport { CustomTypesManager } from \"./customTypes/CustomTypesManager\";\nimport { SlicesManager } from \"./slices/SlicesManager\";\nimport { SnippetsManager } from \"./snippets/SnippetsManager\";\nimport { ScreenshotsManager } from \"./screenshots/ScreenshotsManager\";\nimport { SimulatorManager } from \"./simulator/SimulatorManager\";\n\nimport { VersionsManager } from \"./versions/VersionsManager\";\n\nimport { TelemetryManager } from \"./telemetry/TelemetryManager\";\nimport { buildPrismicRepositoryAPIEndpoint } from \"../lib/buildPrismicRepositoryAPIEndpoint\";\n\ntype SliceMachineManagerGetStateReturnType = {\n\tenv: {\n\t\tshortId?: string;\n\t\tintercomHash?: string;\n\t\tmanifest: {\n\t\t\tapiEndpoint: string;\n\t\t\tlocalSliceSimulatorURL?: string;\n\t\t};\n\t\trepo: string;\n\t\tchangelog?: PackageChangelog;\n\t\tpackageManager: PackageManager;\n\t\tmockConfig: unknown; // TODO: Remove\n\t\tframework: unknown; // TODO: Remove\n\t\tsliceMachineAPIUrl: string;\n\t};\n\tlibraries: {\n\t\tname: string;\n\t\tpath: string;\n\t\tisLocal: boolean;\n\t\tcomponents: {\n\t\t\tfrom: string;\n\t\t\thref: string;\n\t\t\tpathToSlice: string;\n\t\t\tfileName: string | null;\n\t\t\textension: string | null;\n\t\t\tmodel: CustomTypes.Widgets.Slices.SharedSlice;\n\t\t\tscreenshots: Record<\n\t\t\t\tstring,\n\t\t\t\t{\n\t\t\t\t\tpath: string;\n\t\t\t\t\thash: string;\n\t\t\t\t\tdata: Buffer;\n\t\t\t\t}\n\t\t\t>;\n\t\t\tmock?: SharedSliceContent[];\n\t\t\tmockConfig: unknown; // TODO: Remove\n\t\t}[];\n\t\tmeta: {\n\t\t\tname?: string;\n\t\t\tversion?: string;\n\t\t\tisNodeModule: boolean;\n\t\t\tisDownloaded: boolean;\n\t\t\tisManual: boolean;\n\t\t};\n\t}[];\n\tcustomTypes: CustomTypes.CustomType[];\n\tremoteCustomTypes: CustomTypes.CustomType[];\n\tremoteSlices: CustomTypes.Widgets.Slices.SharedSlice[];\n\tclientError?: {\n\t\tname: string;\n\t\tmessage: string;\n\t\tstatus: number;\n\t\treason: string;\n\t};\n};\n\ntype SliceMachineManagerConstructorArgs = {\n\tcwd?: string;\n\tnativePlugins?: Record<string, SliceMachinePlugin>;\n};\n\nexport class SliceMachineManager {\n\tprivate _sliceMachinePluginRunner: SliceMachinePluginRunner | undefined =\n\t\tundefined;\n\tprivate _prismicAuthManager: PrismicAuthManager;\n\n\tcwd: string;\n\n\tcustomTypes: CustomTypesManager;\n\tplugins: PluginsManager;\n\tprismicRepository: PrismicRepositoryManager;\n\tproject: ProjectManager;\n\tscreenshots: ScreenshotsManager;\n\tsimulator: SimulatorManager;\n\tslices: SlicesManager;\n\tsnippets: SnippetsManager;\n\ttelemetry: TelemetryManager;\n\tuser: UserManager;\n\tversions: VersionsManager;\n\n\tconstructor(args?: SliceMachineManagerConstructorArgs) {\n\t\t// _prismicAuthManager must be set at least before UserManager\n\t\t// is instantiated. It depends on the PrismicAuthManager for\n\t\t// authentication-related methods.\n\t\tthis._prismicAuthManager = createPrismicAuthManager();\n\n\t\tthis.user = new UserManager(this);\n\t\tthis.prismicRepository = new PrismicRepositoryManager(this);\n\n\t\tthis.plugins = new PluginsManager(this, {\n\t\t\tnativePlugins: args?.nativePlugins,\n\t\t});\n\n\t\tthis.project = new ProjectManager(this);\n\t\tthis.customTypes = new CustomTypesManager(this);\n\t\tthis.slices = new SlicesManager(this);\n\t\tthis.snippets = new SnippetsManager(this);\n\t\tthis.screenshots = new ScreenshotsManager(this);\n\t\tthis.simulator = new SimulatorManager(this);\n\n\t\tthis.versions = new VersionsManager(this);\n\n\t\tthis.telemetry = new TelemetryManager(this);\n\n\t\tthis.cwd = args?.cwd ?? process.cwd();\n\t}\n\n\t// The `_sliceMachinePluginRunner` property is hidden behind a function to\n\t// discourage access. Using a function deliberatly breaks the pattern\n\t// of other child managers that are accessible as properties, like\n\t// `project`, `plugins`, etc. We do not treat SliceMachinePluginRunner\n\t// as a child manager.\n\tgetSliceMachinePluginRunner(): SliceMachinePluginRunner | undefined {\n\t\treturn this._sliceMachinePluginRunner;\n\t}\n\n\t// The `_prismicAuthManager` property is hidden behind a function to\n\t// discourage access. Using a function deliberatly breaks the pattern\n\t// of other child managers that are accessible as properties, like\n\t// `project`, `plugins`, etc. We do not treat PrismicAuthManager as a\n\t// child manager.\n\tgetPrismicAuthManager(): PrismicAuthManager {\n\t\treturn this._prismicAuthManager;\n\t}\n\n\tgetAPIEndpoints(): APIEndpoints {\n\t\treturn API_ENDPOINTS;\n\t}\n\n\t// TODO: Remove this global-state method. It is expensive and a\n\t// potential source of bugs due to data inconsistency. SM UI relies on\n\t// it heavily, so removal will require significant effort.\n\tasync getState(): Promise<SliceMachineManagerGetStateReturnType> {\n\t\tconst [\n\t\t\t{ sliceMachineConfig, libraries },\n\t\t\t{ profile, remoteCustomTypes, remoteSlices },\n\t\t\tcustomTypes,\n\t\t] = await Promise.all([\n\t\t\tthis.project.getSliceMachineConfig().then(async (sliceMachineConfig) => {\n\t\t\t\tconst libraries = await this._getLibraries(sliceMachineConfig);\n\n\t\t\t\treturn { sliceMachineConfig, libraries };\n\t\t\t}),\n\t\t\tthis._getProfile().then(async (profile) => {\n\t\t\t\tif (profile) {\n\t\t\t\t\tconst [remoteCustomTypes, remoteSlices] = await Promise.all([\n\t\t\t\t\t\tthis.customTypes.fetchRemoteCustomTypes(),\n\t\t\t\t\t\tthis.slices.fetchRemoteSlices(),\n\t\t\t\t\t]);\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\tprofile,\n\t\t\t\t\t\tremoteCustomTypes,\n\t\t\t\t\t\tremoteSlices,\n\t\t\t\t\t};\n\t\t\t\t} else {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tprofile,\n\t\t\t\t\t\tremoteCustomTypes: [],\n\t\t\t\t\t\tremoteSlices: [],\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t}),\n\t\t\tthis._getCustomTypes(),\n\t\t]);\n\n\t\t// TODO: SM UI detects if a user is logged out by looking at\n\t\t// `clientError`. Here, we simulate what the old core does by\n\t\t// returning an `ErrorWithStatus`-like object if the user is\n\t\t// not logged in.\n\t\tconst clientError: SliceMachineManagerGetStateReturnType[\"clientError\"] =\n\t\t\tprofile\n\t\t\t\t? undefined\n\t\t\t\t: {\n\t\t\t\t\t\tname: \"__stub__\",\n\t\t\t\t\t\tmessage: \"__stub__\",\n\t\t\t\t\t\treason: \"__stub__\",\n\t\t\t\t\t\tstatus: 401, // Needed to trigger the unauthorized flow.\n\t\t\t\t };\n\n\t\treturn {\n\t\t\tenv: {\n\t\t\t\tframework: \"\",\n\t\t\t\tmanifest: {\n\t\t\t\t\tapiEndpoint:\n\t\t\t\t\t\tsliceMachineConfig.apiEndpoint ||\n\t\t\t\t\t\tbuildPrismicRepositoryAPIEndpoint(\n\t\t\t\t\t\t\tsliceMachineConfig.repositoryName,\n\t\t\t\t\t\t),\n\t\t\t\t\tlocalSliceSimulatorURL: sliceMachineConfig.localSliceSimulatorURL,\n\t\t\t\t},\n\t\t\t\tmockConfig: {},\n\t\t\t\t// TODO: Don't hardcode this!\n\t\t\t\tpackageManager: \"npm\",\n\t\t\t\t// TODO: Don't hardcode this!\n\t\t\t\trepo: sliceMachineConfig.repositoryName,\n\t\t\t\t// TODO: Don't hardcode this!\n\t\t\t\tsliceMachineAPIUrl: \"http://localhost:9999\",\n\t\t\t\tintercomHash: profile?.intercomHash,\n\t\t\t\tshortId: profile?.shortId,\n\t\t\t},\n\t\t\tlibraries,\n\t\t\tcustomTypes,\n\t\t\tremoteCustomTypes,\n\t\t\tremoteSlices,\n\t\t\tclientError,\n\t\t};\n\t}\n\n\tprivate async _getProfile(): Promise<PrismicUserProfile | undefined> {\n\t\tlet profile: PrismicUserProfile | undefined;\n\n\t\tconst isLoggedIn = await this.user.checkIsLoggedIn();\n\n\t\tif (isLoggedIn) {\n\t\t\tprofile = await this.user.getProfile();\n\t\t\tawait this.user.refreshAuthenticationToken();\n\t\t}\n\n\t\treturn profile;\n\t}\n\n\tprivate async _getLibraries(\n\t\tsliceMachineConfig: SliceMachineConfig,\n\t): Promise<SliceMachineManagerGetStateReturnType[\"libraries\"]> {\n\t\tconst libraries: SliceMachineManagerGetStateReturnType[\"libraries\"] = [];\n\n\t\tif (sliceMachineConfig.libraries) {\n\t\t\tawait Promise.all(\n\t\t\t\tsliceMachineConfig.libraries.map(async (libraryID) => {\n\t\t\t\t\tconst { sliceIDs } = await this.slices.readSliceLibrary({\n\t\t\t\t\t\tlibraryID,\n\t\t\t\t\t});\n\n\t\t\t\t\tif (sliceIDs) {\n\t\t\t\t\t\tconst components: SliceMachineManagerGetStateReturnType[\"libraries\"][number][\"components\"] =\n\t\t\t\t\t\t\t[];\n\n\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\tsliceIDs.map(async (sliceID) => {\n\t\t\t\t\t\t\t\tconst [{ model }, { mocks }] = await Promise.all([\n\t\t\t\t\t\t\t\t\tthis.slices.readSlice({ libraryID, sliceID }),\n\t\t\t\t\t\t\t\t\tthis.slices.readSliceMocks({ libraryID, sliceID }),\n\t\t\t\t\t\t\t\t]);\n\n\t\t\t\t\t\t\t\tif (model) {\n\t\t\t\t\t\t\t\t\tconst screenshots: typeof components[number][\"screenshots\"] =\n\t\t\t\t\t\t\t\t\t\t{};\n\t\t\t\t\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\t\t\t\t\tmodel.variations.map(async (variation) => {\n\t\t\t\t\t\t\t\t\t\t\tconst screenshot = await this.slices.readSliceScreenshot({\n\t\t\t\t\t\t\t\t\t\t\t\tlibraryID,\n\t\t\t\t\t\t\t\t\t\t\t\tsliceID,\n\t\t\t\t\t\t\t\t\t\t\t\tvariationID: variation.id,\n\t\t\t\t\t\t\t\t\t\t\t});\n\n\t\t\t\t\t\t\t\t\t\t\tif (screenshot.data) {\n\t\t\t\t\t\t\t\t\t\t\t\tscreenshots[variation.id] = {\n\t\t\t\t\t\t\t\t\t\t\t\t\tpath: \"__stub__\",\n\t\t\t\t\t\t\t\t\t\t\t\t\thash: createContentDigest(screenshot.data),\n\t\t\t\t\t\t\t\t\t\t\t\t\tdata: screenshot.data,\n\t\t\t\t\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\t\tcomponents.push({\n\t\t\t\t\t\t\t\t\t\tfrom: libraryID,\n\t\t\t\t\t\t\t\t\t\thref: libraryID.replace(/\\//g, \"--\"),\n\t\t\t\t\t\t\t\t\t\tpathToSlice: \"pathToSlice\",\n\t\t\t\t\t\t\t\t\t\tfileName: \"fileName\",\n\t\t\t\t\t\t\t\t\t\textension: \"extension\",\n\t\t\t\t\t\t\t\t\t\tmodel,\n\t\t\t\t\t\t\t\t\t\tscreenshots,\n\t\t\t\t\t\t\t\t\t\tmock: mocks,\n\t\t\t\t\t\t\t\t\t\tmockConfig: {}, // TODO: This property can probably be removed.\n\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tlibraries.push({\n\t\t\t\t\t\t\tname: libraryID,\n\t\t\t\t\t\t\tpath: libraryID,\n\t\t\t\t\t\t\tisLocal: true, // TODO: Do we still support node_modules-based libraries?\n\t\t\t\t\t\t\tcomponents,\n\t\t\t\t\t\t\tmeta: {\n\t\t\t\t\t\t\t\t// TODO: Do we still support node_modules-based libraries?\n\t\t\t\t\t\t\t\tisNodeModule: false,\n\t\t\t\t\t\t\t\tisDownloaded: false,\n\t\t\t\t\t\t\t\tisManual: true,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\n\t\treturn libraries;\n\t}\n\n\tprivate async _getCustomTypes(): Promise<\n\t\tSliceMachineManagerGetStateReturnType[\"customTypes\"]\n\t> {\n\t\tconst customTypes: SliceMachineManagerGetStateReturnType[\"customTypes\"] =\n\t\t\t[];\n\n\t\tconst { ids: customTypeIDs } =\n\t\t\tawait this.customTypes.readCustomTypeLibrary();\n\n\t\tif (customTypeIDs) {\n\t\t\tawait Promise.all(\n\t\t\t\tcustomTypeIDs.map(async (customTypeID) => {\n\t\t\t\t\tconst { model } = await this.customTypes.readCustomType({\n\t\t\t\t\t\tid: customTypeID,\n\t\t\t\t\t});\n\n\t\t\t\t\tif (model) {\n\t\t\t\t\t\tcustomTypes.push(model);\n\t\t\t\t\t}\n\t\t\t\t}),\n\t\t\t);\n\t\t}\n\n\t\treturn customTypes;\n\t}\n}\n"],"names":["createPrismicAuthManager","UserManager","PrismicRepositoryManager","PluginsManager","ProjectManager","CustomTypesManager","SlicesManager","SnippetsManager","ScreenshotsManager","SimulatorManager","VersionsManager","TelemetryManager","API_ENDPOINTS","sliceMachineConfig","libraries","profile","remoteCustomTypes","remoteSlices","buildPrismicRepositoryAPIEndpoint","createContentDigest"],"mappings":"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"}
@@ -4,6 +4,7 @@ import { SharedSliceContent } from "@prismicio/types-internal/lib/content";
4
4
  import { SliceMachinePlugin, SliceMachinePluginRunner } from "@slicemachine/plugin-kit";
5
5
  import { PackageChangelog, PackageManager } from "../types";
6
6
  import { PrismicAuthManager } from "../auth/PrismicAuthManager";
7
+ import { APIEndpoints } from "../constants/API_ENDPOINTS";
7
8
  import { UserManager } from "./user/UserManager";
8
9
  import { PrismicRepositoryManager } from "./prismicRepository/PrismicRepositoryManager";
9
10
  import { PluginsManager } from "./plugins/PluginsManager";
@@ -20,6 +21,7 @@ type SliceMachineManagerGetStateReturnType = {
20
21
  shortId?: string;
21
22
  intercomHash?: string;
22
23
  manifest: {
24
+ apiEndpoint: string;
23
25
  localSliceSimulatorURL?: string;
24
26
  };
25
27
  repo: string;
@@ -46,6 +48,7 @@ type SliceMachineManagerGetStateReturnType = {
46
48
  data: Buffer;
47
49
  }>;
48
50
  mock?: SharedSliceContent[];
51
+ mockConfig: unknown;
49
52
  }[];
50
53
  meta: {
51
54
  name?: string;
@@ -59,8 +62,10 @@ type SliceMachineManagerGetStateReturnType = {
59
62
  remoteCustomTypes: CustomTypes.CustomType[];
60
63
  remoteSlices: CustomTypes.Widgets.Slices.SharedSlice[];
61
64
  clientError?: {
65
+ name: string;
62
66
  message: string;
63
67
  status: number;
68
+ reason: string;
64
69
  };
65
70
  };
66
71
  type SliceMachineManagerConstructorArgs = {
@@ -85,6 +90,7 @@ export declare class SliceMachineManager {
85
90
  constructor(args?: SliceMachineManagerConstructorArgs);
86
91
  getSliceMachinePluginRunner(): SliceMachinePluginRunner | undefined;
87
92
  getPrismicAuthManager(): PrismicAuthManager;
93
+ getAPIEndpoints(): APIEndpoints;
88
94
  getState(): Promise<SliceMachineManagerGetStateReturnType>;
89
95
  private _getProfile;
90
96
  private _getLibraries;