@powerhousedao/shared 6.0.0-staging.4 → 6.0.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 (220) hide show
  1. package/README.md +1 -1
  2. package/dist/actions-UH5nIJcP.d.ts +21068 -0
  3. package/dist/actions-UH5nIJcP.d.ts.map +1 -0
  4. package/dist/analytics/index.d.ts +43 -0
  5. package/dist/analytics/index.d.ts.map +1 -0
  6. package/dist/analytics/index.js +308 -0
  7. package/dist/analytics/index.js.map +1 -0
  8. package/dist/clis/args/access-token.d.mts +18 -0
  9. package/dist/clis/args/access-token.d.mts.map +1 -0
  10. package/dist/clis/args/access-token.mjs +22 -0
  11. package/dist/clis/args/access-token.mjs.map +1 -0
  12. package/dist/clis/args/common-DPYlcz-d.mjs +275 -0
  13. package/dist/clis/args/common-DPYlcz-d.mjs.map +1 -0
  14. package/dist/clis/args/common-Dmf4BGPa.d.mts +177 -0
  15. package/dist/clis/args/common-Dmf4BGPa.d.mts.map +1 -0
  16. package/dist/clis/args/common.d.mts +2 -0
  17. package/dist/clis/args/common.mjs +2 -0
  18. package/dist/clis/args/connect.d.mts +204 -0
  19. package/dist/clis/args/connect.d.mts.map +1 -0
  20. package/dist/clis/args/connect.mjs +51 -0
  21. package/dist/clis/args/connect.mjs.map +1 -0
  22. package/dist/clis/args/generate-BJPBa0mK.mjs +153 -0
  23. package/dist/clis/args/generate-BJPBa0mK.mjs.map +1 -0
  24. package/dist/clis/args/generate.d.mts +87 -0
  25. package/dist/clis/args/generate.d.mts.map +1 -0
  26. package/dist/clis/args/generate.mjs +2 -0
  27. package/dist/clis/args/help-CYjFrzIJ.d.mts +193 -0
  28. package/dist/clis/args/help-CYjFrzIJ.d.mts.map +1 -0
  29. package/dist/clis/args/help-rztSuf9S.mjs +152 -0
  30. package/dist/clis/args/help-rztSuf9S.mjs.map +1 -0
  31. package/dist/clis/args/help.d.mts +2 -0
  32. package/dist/clis/args/help.mjs +14 -0
  33. package/dist/clis/args/index.d.mts +19 -0
  34. package/dist/clis/args/index.mjs +19 -0
  35. package/dist/clis/args/init.d.mts +49 -0
  36. package/dist/clis/args/init.d.mts.map +1 -0
  37. package/dist/clis/args/init.mjs +56 -0
  38. package/dist/clis/args/init.mjs.map +1 -0
  39. package/dist/clis/args/inspect.d.mts +15 -0
  40. package/dist/clis/args/inspect.d.mts.map +1 -0
  41. package/dist/clis/args/inspect.mjs +15 -0
  42. package/dist/clis/args/inspect.mjs.map +1 -0
  43. package/dist/clis/args/install.d.mts +40 -0
  44. package/dist/clis/args/install.d.mts.map +1 -0
  45. package/dist/clis/args/install.mjs +32 -0
  46. package/dist/clis/args/install.mjs.map +1 -0
  47. package/dist/clis/args/list.d.mts +12 -0
  48. package/dist/clis/args/list.d.mts.map +1 -0
  49. package/dist/clis/args/list.mjs +7 -0
  50. package/dist/clis/args/list.mjs.map +1 -0
  51. package/dist/clis/args/login.d.mts +27 -0
  52. package/dist/clis/args/login.d.mts.map +1 -0
  53. package/dist/clis/args/login.mjs +40 -0
  54. package/dist/clis/args/login.mjs.map +1 -0
  55. package/dist/clis/args/migrate.d.mts +21 -0
  56. package/dist/clis/args/migrate.d.mts.map +1 -0
  57. package/dist/clis/args/migrate.mjs +29 -0
  58. package/dist/clis/args/migrate.mjs.map +1 -0
  59. package/dist/clis/args/publish.d.mts +18 -0
  60. package/dist/clis/args/publish.d.mts.map +1 -0
  61. package/dist/clis/args/publish.mjs +19 -0
  62. package/dist/clis/args/publish.mjs.map +1 -0
  63. package/dist/clis/args/registry.d.mts +19 -0
  64. package/dist/clis/args/registry.d.mts.map +1 -0
  65. package/dist/clis/args/registry.mjs +23 -0
  66. package/dist/clis/args/registry.mjs.map +1 -0
  67. package/dist/clis/args/service-DVB7CNJn.d.mts +106 -0
  68. package/dist/clis/args/service-DVB7CNJn.d.mts.map +1 -0
  69. package/dist/clis/args/service.d.mts +2 -0
  70. package/dist/clis/args/service.mjs +11 -0
  71. package/dist/clis/args/service.mjs.map +1 -0
  72. package/dist/clis/args/switchboard.d.mts +72 -0
  73. package/dist/clis/args/switchboard.d.mts.map +1 -0
  74. package/dist/clis/args/switchboard.mjs +85 -0
  75. package/dist/clis/args/switchboard.mjs.map +1 -0
  76. package/dist/clis/args/uninstall.d.mts +31 -0
  77. package/dist/clis/args/uninstall.d.mts.map +1 -0
  78. package/dist/clis/args/uninstall.mjs +16 -0
  79. package/dist/clis/args/uninstall.mjs.map +1 -0
  80. package/dist/clis/args/unpublish.d.mts +24 -0
  81. package/dist/clis/args/unpublish.d.mts.map +1 -0
  82. package/dist/clis/args/unpublish.mjs +30 -0
  83. package/dist/clis/args/unpublish.mjs.map +1 -0
  84. package/dist/clis/args/vetra.d.mts +96 -0
  85. package/dist/clis/args/vetra.d.mts.map +1 -0
  86. package/dist/clis/args/vetra.mjs +69 -0
  87. package/dist/clis/args/vetra.mjs.map +1 -0
  88. package/dist/clis/build-config.d.mts +10623 -0
  89. package/dist/clis/build-config.d.mts.map +1 -0
  90. package/dist/clis/build-config.mjs +86 -0
  91. package/dist/clis/build-config.mjs.map +1 -0
  92. package/dist/clis/command-names.d.mts +5 -0
  93. package/dist/clis/command-names.d.mts.map +1 -0
  94. package/dist/clis/command-names.mjs +28 -0
  95. package/dist/clis/command-names.mjs.map +1 -0
  96. package/dist/clis/constants.d.mts +333 -0
  97. package/dist/clis/constants.d.mts.map +1 -0
  98. package/dist/clis/constants.mjs +194 -0
  99. package/dist/clis/constants.mjs.map +1 -0
  100. package/dist/clis/index.d.mts +1538 -0
  101. package/dist/clis/index.d.mts.map +1 -0
  102. package/dist/clis/index.mjs +7464 -0
  103. package/dist/clis/index.mjs.map +1 -0
  104. package/dist/clis/services/telemetry.d.mts +57 -0
  105. package/dist/clis/services/telemetry.d.mts.map +1 -0
  106. package/dist/clis/services/telemetry.mjs +221 -0
  107. package/dist/clis/services/telemetry.mjs.map +1 -0
  108. package/dist/clis/utils.d.mts +19 -0
  109. package/dist/clis/utils.d.mts.map +1 -0
  110. package/dist/clis/utils.mjs +388 -0
  111. package/dist/clis/utils.mjs.map +1 -0
  112. package/dist/connect/index.d.ts +377 -1
  113. package/dist/connect/index.d.ts.map +1 -1
  114. package/dist/connect/index.js +253 -1
  115. package/dist/connect/index.js.map +1 -1
  116. package/dist/constants-xNwF0jSl.d.ts +8 -0
  117. package/dist/constants-xNwF0jSl.d.ts.map +1 -0
  118. package/dist/constants.d.ts +2 -0
  119. package/dist/constants.js +40 -0
  120. package/dist/constants.js.map +1 -0
  121. package/dist/document-drive/index.d.ts +224 -0
  122. package/dist/document-drive/index.d.ts.map +1 -0
  123. package/dist/document-drive/index.js +963 -0
  124. package/dist/document-drive/index.js.map +1 -0
  125. package/dist/document-model/index.d.ts +5 -5
  126. package/dist/document-model/index.js +3465 -2
  127. package/dist/document-model/index.js.map +1 -1
  128. package/dist/document-model/mock.d.ts +2 -0
  129. package/dist/document-model/mock.js +9 -0
  130. package/dist/document-model/mock.js.map +1 -0
  131. package/dist/document-model/utils.d.ts +3 -0
  132. package/dist/document-model/utils.js +3 -0
  133. package/dist/index-C_iVZe7f.d.ts +7 -0
  134. package/dist/index-C_iVZe7f.d.ts.map +1 -0
  135. package/dist/index-DhPr5zSB.d.ts +306 -0
  136. package/dist/index-DhPr5zSB.d.ts.map +1 -0
  137. package/dist/index.d.ts +6 -0
  138. package/dist/index.js +14 -0
  139. package/dist/index.js.map +1 -0
  140. package/dist/mock-Cgn-VBF_.d.ts +7 -0
  141. package/dist/mock-Cgn-VBF_.d.ts.map +1 -0
  142. package/dist/processors/index.d.ts +2 -5
  143. package/dist/processors/index.js +116 -3
  144. package/dist/processors/index.js.map +1 -1
  145. package/dist/registry/index.d.ts +80 -0
  146. package/dist/registry/index.d.ts.map +1 -0
  147. package/dist/registry/index.js +157 -0
  148. package/dist/registry/index.js.map +1 -0
  149. package/dist/types-BFDlQkXZ.d.ts +158 -0
  150. package/dist/types-BFDlQkXZ.d.ts.map +1 -0
  151. package/dist/types-WzwAClp2.d.ts +410 -0
  152. package/dist/types-WzwAClp2.d.ts.map +1 -0
  153. package/dist/utils-CJF4w5Bp.d.ts +9 -0
  154. package/dist/utils-CJF4w5Bp.d.ts.map +1 -0
  155. package/dist/utils-bCWnsmtD.js +70 -0
  156. package/dist/utils-bCWnsmtD.js.map +1 -0
  157. package/package.json +105 -17
  158. package/dist/connect/env-config.d.ts +0 -844
  159. package/dist/connect/env-config.d.ts.map +0 -1
  160. package/dist/connect/env-config.js +0 -518
  161. package/dist/connect/env-config.js.map +0 -1
  162. package/dist/document-model/core/actions.d.ts +0 -62
  163. package/dist/document-model/core/actions.d.ts.map +0 -1
  164. package/dist/document-model/core/actions.js +0 -2
  165. package/dist/document-model/core/actions.js.map +0 -1
  166. package/dist/document-model/core/constants.d.ts +0 -6
  167. package/dist/document-model/core/constants.d.ts.map +0 -1
  168. package/dist/document-model/core/constants.js +0 -8
  169. package/dist/document-model/core/constants.js.map +0 -1
  170. package/dist/document-model/core/documents.d.ts +0 -102
  171. package/dist/document-model/core/documents.d.ts.map +0 -1
  172. package/dist/document-model/core/documents.js +0 -2
  173. package/dist/document-model/core/documents.js.map +0 -1
  174. package/dist/document-model/core/operations.d.ts +0 -74
  175. package/dist/document-model/core/operations.d.ts.map +0 -1
  176. package/dist/document-model/core/operations.js +0 -2
  177. package/dist/document-model/core/operations.js.map +0 -1
  178. package/dist/document-model/core/ph-types.d.ts +0 -7
  179. package/dist/document-model/core/ph-types.d.ts.map +0 -1
  180. package/dist/document-model/core/ph-types.js +0 -2
  181. package/dist/document-model/core/ph-types.js.map +0 -1
  182. package/dist/document-model/core/signatures.d.ts +0 -52
  183. package/dist/document-model/core/signatures.d.ts.map +0 -1
  184. package/dist/document-model/core/signatures.js +0 -2
  185. package/dist/document-model/core/signatures.js.map +0 -1
  186. package/dist/document-model/core/state.d.ts +0 -38
  187. package/dist/document-model/core/state.d.ts.map +0 -1
  188. package/dist/document-model/core/state.js +0 -2
  189. package/dist/document-model/core/state.js.map +0 -1
  190. package/dist/document-model/core/types.d.ts +0 -533
  191. package/dist/document-model/core/types.d.ts.map +0 -1
  192. package/dist/document-model/core/types.js +0 -2
  193. package/dist/document-model/core/types.js.map +0 -1
  194. package/dist/document-model/core/upgrades.d.ts +0 -24
  195. package/dist/document-model/core/upgrades.d.ts.map +0 -1
  196. package/dist/document-model/core/upgrades.js +0 -2
  197. package/dist/document-model/core/upgrades.js.map +0 -1
  198. package/dist/document-model/index.d.ts.map +0 -1
  199. package/dist/document-model/types.d.ts +0 -97
  200. package/dist/document-model/types.d.ts.map +0 -1
  201. package/dist/document-model/types.js +0 -2
  202. package/dist/document-model/types.js.map +0 -1
  203. package/dist/processors/constants.d.ts +0 -4
  204. package/dist/processors/constants.d.ts.map +0 -1
  205. package/dist/processors/constants.js +0 -4
  206. package/dist/processors/constants.js.map +0 -1
  207. package/dist/processors/index.d.ts.map +0 -1
  208. package/dist/processors/relational/types.d.ts +0 -72
  209. package/dist/processors/relational/types.d.ts.map +0 -1
  210. package/dist/processors/relational/types.js +0 -45
  211. package/dist/processors/relational/types.js.map +0 -1
  212. package/dist/processors/relational/utils.d.ts +0 -29
  213. package/dist/processors/relational/utils.d.ts.map +0 -1
  214. package/dist/processors/relational/utils.js +0 -67
  215. package/dist/processors/relational/utils.js.map +0 -1
  216. package/dist/processors/types.d.ts +0 -76
  217. package/dist/processors/types.d.ts.map +0 -1
  218. package/dist/processors/types.js +0 -2
  219. package/dist/processors/types.js.map +0 -1
  220. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -0,0 +1,80 @@
1
+ import { B as RegistryPackageStatus, F as PackageInfo, I as RegistryPackage, L as RegistryPackageList, R as RegistryPackageMap, kt as DEFAULT_REGISTRY_URL, z as RegistryPackageSource } from "../types-WzwAClp2.js";
2
+
3
+ //#region registry/registry.d.ts
4
+ /**
5
+ * Extract the host portion of a registry URL — what npm uses as the key in
6
+ * `~/.npmrc` for per-registry tokens (e.g. `//registry.dev.vetra.io/`).
7
+ */
8
+ declare function registryAuthKey(registryUrl: string): string;
9
+ interface ResolveRegistryUrlOptions {
10
+ /** Explicit registry URL (e.g. from --registry flag). Highest priority. */
11
+ registry?: string;
12
+ /** Project path to read powerhouse.config.json from. */
13
+ projectPath: string;
14
+ /** Environment variables. Defaults to process.env. */
15
+ env?: Record<string, string | undefined>;
16
+ }
17
+ /**
18
+ * Resolve the registry URL with priority: flag > env > config > default.
19
+ */
20
+ declare function resolveRegistryUrl(options: ResolveRegistryUrlOptions): string;
21
+ /**
22
+ * Check if the user is authenticated with the given npm registry.
23
+ * Returns the username on success, throws on failure.
24
+ */
25
+ declare function checkNpmAuth(registryUrl: string): Promise<string>;
26
+ interface NpmPublishOptions {
27
+ /** Registry URL to publish to. */
28
+ registryUrl: string;
29
+ /** Working directory (project root). */
30
+ cwd: string;
31
+ /** Additional arguments forwarded to npm publish. */
32
+ args?: string[];
33
+ /** Bearer token for the registry. When set, passed via a registry-scoped
34
+ * `_authToken` config flag rather than read from the user's `.npmrc`. */
35
+ authToken?: string;
36
+ }
37
+ interface NpmPublishResult {
38
+ /** stdout from npm publish. */
39
+ stdout: string;
40
+ }
41
+ /**
42
+ * Run `npm publish` against the given registry.
43
+ * Uses spawn with args array to avoid shell injection.
44
+ *
45
+ * When `authToken` is provided, the token is passed via a registry-scoped
46
+ * `--//host/:_authToken=<token>` flag (npm's standard form for per-registry
47
+ * tokens) so we never have to write to `~/.npmrc`.
48
+ */
49
+ declare function npmPublish(options: NpmPublishOptions): Promise<NpmPublishResult>;
50
+ /**
51
+ * Write `_authToken=<token>` for the given registry host into `~/.npmrc`,
52
+ * preserving any other lines. Replaces the existing entry for the same key
53
+ * if present. Returns the absolute path to the npmrc that was written.
54
+ */
55
+ declare function writeRegistryAuthToken(registryUrl: string, token: string): Promise<string>;
56
+ interface NpmUnpublishOptions {
57
+ /** Registry URL to unpublish from. */
58
+ registryUrl: string;
59
+ /** Working directory (project root). */
60
+ cwd: string;
61
+ /** Package spec: `<name>` (whole package) or `<name>@<version>` (single version). */
62
+ spec: string;
63
+ /** Additional arguments forwarded to npm unpublish. */
64
+ args?: string[];
65
+ /** Bearer token for the registry (same semantics as `NpmPublishOptions.authToken`). */
66
+ authToken?: string;
67
+ }
68
+ interface NpmUnpublishResult {
69
+ /** stdout from npm unpublish. */
70
+ stdout: string;
71
+ }
72
+ /**
73
+ * Run `npm unpublish` against the given registry.
74
+ * Always passes `--force` because npm otherwise refuses to unpublish packages
75
+ * older than 72h (a public-npmjs safeguard that doesn't apply to private registries).
76
+ */
77
+ declare function npmUnpublish(options: NpmUnpublishOptions): Promise<NpmUnpublishResult>;
78
+ //#endregion
79
+ export { DEFAULT_REGISTRY_URL, NpmPublishOptions, NpmPublishResult, NpmUnpublishOptions, NpmUnpublishResult, PackageInfo, RegistryPackage, RegistryPackageList, RegistryPackageMap, RegistryPackageSource, RegistryPackageStatus, ResolveRegistryUrlOptions, checkNpmAuth, npmPublish, npmUnpublish, registryAuthKey, resolveRegistryUrl, writeRegistryAuthToken };
80
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","names":[],"sources":["../../registry/registry.ts"],"mappings":";;;;;;;iBAgBgB,eAAA,CAAgB,WAAA;AAAA,UAQf,yBAAA;;EAEf,QAAA;EAViD;EAYjD,WAAA;EAJwC;EAMxC,GAAA,GAAM,MAAA;AAAA;;;;iBAMQ,kBAAA,CAAmB,OAAA,EAAS,yBAAA;;;AAA5C;;iBAiBsB,YAAA,CAAa,WAAA,WAAsB,OAAA;AAAA,UAIxC,iBAAA;EArBoD;EAuBnE,WAAA;EANgC;EAQhC,GAAA;EARiC;EAUjC,IAAA;EANe;;EASf,SAAA;AAAA;AAAA,UAGe,gBAAA;EARf;EAUA,MAAA;AAAA;;;AAFF;;;;;AAaA;iBAAsB,UAAA,CACpB,OAAA,EAAS,iBAAA,GACR,OAAA,CAAQ,gBAAA;;;;;;iBAeW,sBAAA,CACpB,WAAA,UACA,KAAA,WACC,OAAA;AAAA,UAmBc,mBAAA;EAtCf;EAwCA,WAAA;EAvCS;EAyCT,GAAA;EAzCyB;EA2CzB,IAAA;EA5B0C;EA8B1C,IAAA;EA3BQ;EA6BR,SAAA;AAAA;AAAA,UAGe,kBAAA;EAhCP;EAkCR,MAAA;AAAA;;;;;;iBAQoB,YAAA,CACpB,OAAA,EAAS,mBAAA,GACR,OAAA,CAAQ,kBAAA"}
@@ -0,0 +1,157 @@
1
+ import { promises, readFileSync } from "node:fs";
2
+ import { homedir } from "node:os";
3
+ import { join } from "node:path";
4
+ import { spawn } from "node:child_process";
5
+ const DEFAULT_REGISTRY_URL = "https://registry.dev.vetra.io";
6
+ const POWERHOUSE_CONFIG_FILE = "powerhouse.config.json";
7
+ join(homedir(), ".ph");
8
+ const VERSIONED_PEER_DEPENDENCIES = ["document-model", "@powerhousedao/reactor-browser"];
9
+ const FEATURE_DEPENDENCIES = { analyticsProcessor: {
10
+ peerVersioned: ["@powerhousedao/analytics-engine-core"],
11
+ peerExternal: {}
12
+ } };
13
+ [...VERSIONED_PEER_DEPENDENCIES, ...FEATURE_DEPENDENCIES.analyticsProcessor.peerVersioned];
14
+ const DEFAULT_CONFIG = {
15
+ documentModelsDir: "./document-models",
16
+ editorsDir: "./editors",
17
+ processorsDir: "./processors",
18
+ subgraphsDir: "./subgraphs",
19
+ importScriptsDir: "./scripts",
20
+ skipFormat: false,
21
+ logLevel: "info",
22
+ auth: {
23
+ enabled: false,
24
+ admins: []
25
+ }
26
+ };
27
+ //#endregion
28
+ //#region clis/file-system/get-config.ts
29
+ function getConfig(path = "./powerhouse.config.json") {
30
+ let config = { ...DEFAULT_CONFIG };
31
+ try {
32
+ const configStr = readFileSync(path, "utf-8");
33
+ const userConfig = JSON.parse(configStr);
34
+ config = {
35
+ ...config,
36
+ ...userConfig
37
+ };
38
+ } catch {}
39
+ return config;
40
+ }
41
+ //#endregion
42
+ //#region clis/file-system/spawn-async.ts
43
+ function spawnAsync(command, args, options = {}) {
44
+ return new Promise((resolve, reject) => {
45
+ const child = spawn(process.platform === "win32" && command === "npm" ? "npm.cmd" : command, args, {
46
+ cwd: options.cwd,
47
+ env: options.env,
48
+ stdio: [
49
+ "ignore",
50
+ "pipe",
51
+ "pipe"
52
+ ]
53
+ });
54
+ let stdout = "";
55
+ let stderr = "";
56
+ child.stdout.on("data", (d) => {
57
+ stdout += d.toString();
58
+ });
59
+ child.stderr.on("data", (d) => {
60
+ stderr += d.toString();
61
+ });
62
+ child.on("error", reject);
63
+ child.on("close", (code) => {
64
+ if (code === 0) resolve(stdout.trim());
65
+ else reject(new Error(stderr.trim() || `${command} exited with code ${code}`));
66
+ });
67
+ });
68
+ }
69
+ //#endregion
70
+ //#region registry/registry.ts
71
+ /**
72
+ * Extract the host portion of a registry URL — what npm uses as the key in
73
+ * `~/.npmrc` for per-registry tokens (e.g. `//registry.dev.vetra.io/`).
74
+ */
75
+ function registryAuthKey(registryUrl) {
76
+ const url = new URL(registryUrl);
77
+ const path = url.pathname.endsWith("/") ? url.pathname : `${url.pathname}/`;
78
+ return `//${url.host}${path}:_authToken`;
79
+ }
80
+ /**
81
+ * Resolve the registry URL with priority: flag > env > config > default.
82
+ */
83
+ function resolveRegistryUrl(options) {
84
+ const { registry, projectPath, env = process.env } = options;
85
+ const config = getConfig(join(projectPath, POWERHOUSE_CONFIG_FILE));
86
+ return registry ?? env.PH_REGISTRY_URL ?? config.packageRegistryUrl ?? "https://registry.dev.vetra.io";
87
+ }
88
+ /**
89
+ * Check if the user is authenticated with the given npm registry.
90
+ * Returns the username on success, throws on failure.
91
+ */
92
+ async function checkNpmAuth(registryUrl) {
93
+ return spawnAsync("npm", [
94
+ "whoami",
95
+ "--registry",
96
+ registryUrl
97
+ ]);
98
+ }
99
+ /**
100
+ * Run `npm publish` against the given registry.
101
+ * Uses spawn with args array to avoid shell injection.
102
+ *
103
+ * When `authToken` is provided, the token is passed via a registry-scoped
104
+ * `--//host/:_authToken=<token>` flag (npm's standard form for per-registry
105
+ * tokens) so we never have to write to `~/.npmrc`.
106
+ */
107
+ async function npmPublish(options) {
108
+ const { registryUrl, cwd, args = [], authToken } = options;
109
+ return { stdout: await spawnAsync("npm", [
110
+ "publish",
111
+ "--registry",
112
+ registryUrl,
113
+ ...authToken ? [`--${registryAuthKey(registryUrl)}=${authToken}`] : [],
114
+ ...args
115
+ ], { cwd }) };
116
+ }
117
+ /**
118
+ * Write `_authToken=<token>` for the given registry host into `~/.npmrc`,
119
+ * preserving any other lines. Replaces the existing entry for the same key
120
+ * if present. Returns the absolute path to the npmrc that was written.
121
+ */
122
+ async function writeRegistryAuthToken(registryUrl, token) {
123
+ const npmrcPath = join(homedir(), ".npmrc");
124
+ const key = registryAuthKey(registryUrl);
125
+ let existing = "";
126
+ try {
127
+ existing = await promises.readFile(npmrcPath, "utf8");
128
+ } catch (err) {
129
+ if (err.code !== "ENOENT") throw err;
130
+ }
131
+ const filtered = existing.split("\n").filter((line) => !line.startsWith(`${key}=`));
132
+ while (filtered.length && filtered[filtered.length - 1] === "") filtered.pop();
133
+ filtered.push(`${key}=${token}`);
134
+ await promises.writeFile(npmrcPath, `${filtered.join("\n")}\n`, "utf8");
135
+ return npmrcPath;
136
+ }
137
+ /**
138
+ * Run `npm unpublish` against the given registry.
139
+ * Always passes `--force` because npm otherwise refuses to unpublish packages
140
+ * older than 72h (a public-npmjs safeguard that doesn't apply to private registries).
141
+ */
142
+ async function npmUnpublish(options) {
143
+ const { registryUrl, cwd, spec, args = [], authToken } = options;
144
+ return { stdout: await spawnAsync("npm", [
145
+ "unpublish",
146
+ spec,
147
+ "--registry",
148
+ registryUrl,
149
+ "--force",
150
+ ...authToken ? [`--${registryAuthKey(registryUrl)}=${authToken}`] : [],
151
+ ...args
152
+ ], { cwd }) };
153
+ }
154
+ //#endregion
155
+ export { DEFAULT_REGISTRY_URL, checkNpmAuth, npmPublish, npmUnpublish, registryAuthKey, resolveRegistryUrl, writeRegistryAuthToken };
156
+
157
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","names":["fs"],"sources":["../../clis/constants.ts","../../clis/file-system/get-config.ts","../../clis/file-system/spawn-async.ts","../../registry/registry.ts"],"sourcesContent":["import { homedir } from \"node:os\";\nimport { join } from \"node:path\";\nimport type { Manifest } from \"../document-model/types.js\";\nimport type { PowerhouseConfig } from \"./types.js\";\n\nexport const SERVICE_ACTIONS = [\n \"start\",\n \"stop\",\n \"status\",\n \"setup\",\n \"restart\",\n] as const;\n\nexport const SECONDS_IN_DAY = 24 * 60 * 60;\nexport const DEFAULT_EXPIRY_DAYS = 7;\nexport const DEFAULT_EXPIRY_SECONDS = DEFAULT_EXPIRY_DAYS * SECONDS_IN_DAY;\n\nexport const DRIVES_PRESERVE_STRATEGIES = [\n \"preserve-all\",\n \"preserve-by-url-and-detach\",\n] as const;\n\nexport const LOG_LEVELS = [\n \"debug\",\n \"info\",\n \"warn\",\n \"error\",\n \"verbose\",\n] as const;\n\nexport const DEFAULT_TIMEOUT = 300 as const;\n\nexport const DEFAULT_CONNECT_STUDIO_PORT = 3000 as const;\n\nexport const DEFAULT_VETRA_CONNECT_PORT = 3001 as const;\n\nexport const DEFAULT_CONNECT_PREVIEW_PORT = 4173 as const;\n\nexport const DEFAULT_CONNECT_OUTDIR = \".ph/connect-build/dist/\" as const;\n\nexport const DEFAULT_RENOWN_URL = \"https://www.renown.id\" as const;\n\nexport const DEFAULT_REGISTRY_URL = \"https://registry.dev.vetra.io\" as const;\n\nexport const DEFAULT_SWITCHBOARD_PORT = 4001 as const;\n\nexport const DEFAULT_VETRA_DRIVE_ID = \"vetra\" as const;\n\nexport const MINIMUM_NODE_VERSION = \"24.0.0\" as const;\nexport const PH_BIN = \"ph-cli-legacy\" as const;\nexport const POWERHOUSE_CONFIG_FILE = \"powerhouse.config.json\" as const;\nexport const PH_GLOBAL_DIR_NAME = \".ph\" as const;\n// Keep PH_GLOBAL_PROJECT_NAME for backwards compatibility\nexport const PH_GLOBAL_PROJECT_NAME = PH_GLOBAL_DIR_NAME;\n\nexport const HOME_DIR = homedir();\n\nexport const POWERHOUSE_GLOBAL_DIR = join(HOME_DIR, PH_GLOBAL_DIR_NAME);\n\n// Workspace packages that go in peerDependencies of every generated project.\nexport const VERSIONED_PEER_DEPENDENCIES = [\n \"document-model\",\n \"@powerhousedao/reactor-browser\",\n];\n\ntype PeerSpec = { peer: string; dev: string };\n\nexport const REACTOR_API_PACKAGE = \"@powerhousedao/reactor-api\";\nexport const ANALYTICS_ENGINE_CORE_PACKAGE =\n \"@powerhousedao/analytics-engine-core\";\nexport const GRAPHQL_PACKAGE = \"graphql\";\nexport const GRAPHQL_TAG_PACKAGE = \"graphql-tag\";\n\n// External peerDependencies of every generated project.\n// `peer` is the consumer-facing range; `dev` is the exact build-tested pin.\n// graphql / graphql-tag are always-on because the workspace packages pulled\n// in by every `ph init` project (codegen, reactor-api, reactor-browser,\n// vetra-packages) declare them as peers — even projects without subgraphs\n// need them in scope so pnpm hoists a single graphql instance.\nexport const PEER_EXTERNAL_DEPENDENCIES = {\n [GRAPHQL_PACKAGE]: { peer: \"^16\", dev: \"16.12.0\" },\n [GRAPHQL_TAG_PACKAGE]: { peer: \"^2\", dev: \"2.12.6\" },\n react: { peer: \"^19\", dev: \"19.2.3\" },\n \"react-dom\": { peer: \"^19\", dev: \"19.2.3\" },\n zod: { peer: \"^4\", dev: \"4.3.6\" },\n} as const satisfies Record<string, PeerSpec>;\n\n// Per-feature deps added dynamically by codegen when required.\nexport const FEATURE_DEPENDENCIES = {\n analyticsProcessor: {\n peerVersioned: [ANALYTICS_ENGINE_CORE_PACKAGE],\n peerExternal: {},\n },\n} as const satisfies Record<\n string,\n { peerVersioned: readonly string[]; peerExternal: Record<string, PeerSpec> }\n>;\n\nexport const VERSIONED_DEPENDENCIES = [\n ...VERSIONED_PEER_DEPENDENCIES,\n ...FEATURE_DEPENDENCIES.analyticsProcessor.peerVersioned,\n];\n\n// Transitive dependencies whose postinstall scripts the generated project\n// trusts. Mirrors the `allowBuilds` map in the boilerplate's\n// pnpm-workspace.yaml and is also passed as `--allow-build` flags to\n// `pnpm dlx @powerhousedao/ph-cli init` so pnpm 11's strict-dep-builds\n// default doesn't prompt during the outer dlx download.\nexport const BOILERPLATE_ALLOWED_BUILDS = [\n \"@apollo/protobufjs\",\n \"@datadog/pprof\",\n \"@parcel/watcher\",\n \"esbuild\",\n \"protobufjs\",\n] as const;\n\nexport const VERSIONED_DEV_DEPENDENCIES = [\n \"@powerhousedao/ph-cli\",\n \"@powerhousedao/reactor\",\n \"@powerhousedao/shared\",\n \"@powerhousedao/connect\",\n \"@powerhousedao/design-system\",\n];\n\nexport const packageJsonExports = {\n \".\": {\n types: \"./dist/types/index.d.ts\",\n browser: \"./dist/browser/index.js\",\n node: \"./dist/node/index.mjs\",\n },\n \"./document-models\": {\n types: \"./dist/types/document-models/index.d.ts\",\n browser: \"./dist/browser/document-models/index.js\",\n node: \"./dist/node/document-models/index.mjs\",\n },\n \"./document-models/*\": {\n types: \"./dist/types/document-models/*/index.d.ts\",\n browser: \"./dist/browser/document-models/*/index.js\",\n node: \"./dist/node/document-models/*/index.mjs\",\n },\n \"./editors\": {\n types: \"./dist/types/editors/index.d.ts\",\n browser: \"./dist/browser/editors/index.js\",\n node: \"./dist/node/editors/index.mjs\",\n },\n \"./editors/*\": {\n types: \"./dist/types/editors/*/editor.d.ts\",\n browser: \"./dist/browser/editors/*/editor.js\",\n node: \"./dist/node/editors/*/editor.mjs\",\n },\n \"./subgraphs\": {\n types: \"./dist/types/subgraphs/index.d.ts\",\n browser: \"./dist/browser/subgraphs/index.js\",\n node: \"./dist/node/subgraphs/index.mjs\",\n },\n \"./processors\": {\n types: \"./dist/types/processors/index.d.ts\",\n browser: \"./dist/browser/processors/index.js\",\n node: \"./dist/node/processors/index.mjs\",\n },\n \"./manifest\": \"./dist/powerhouse.manifest.json\",\n \"./style.css\": \"./dist/style.css\",\n} as const;\n\nexport const packageScripts = {\n \"test:watch\": \"vitest\",\n lint: \"eslint --config eslint.config.js --cache\",\n \"lint:fix\": \"npm run lint -- --fix\",\n tsc: \"tsc\",\n \"tsc:watch\": \"tsc --watch\",\n generate: \"ph-cli generate\",\n connect: \"ph-cli connect\",\n build: \"ph-cli build\",\n reactor: \"ph-cli reactor\",\n service: \"ph-cli service\",\n vetra: \"ph-cli vetra\",\n \"service-startup\":\n \"bash ./node_modules/@powerhousedao/ph-cli/dist/scripts/service-startup.sh\",\n \"service-unstartup\":\n \"bash ./node_modules/@powerhousedao/ph-cli/dist/scripts/service-unstartup.sh\",\n} as const;\n\nexport const externalDependencies = {} as const;\n\nexport const externalDevDependencies = {\n \"@electric-sql/pglite\": \"0.3.15\",\n \"@electric-sql/pglite-tools\": \"0.2.20\",\n \"@eslint/js\": \"^9.38.0\",\n \"@powerhousedao/document-engineering\": \"1.40.5\",\n \"@tailwindcss/cli\": \"^4.1.18\",\n \"@tailwindcss/vite\": \"^4.1.18\",\n \"@types/node\": \"^24.9.2\",\n \"@types/react\": \"^19.2.3\",\n \"@types/react-dom\": \"^19.2.3\",\n \"@vitejs/plugin-react\": \"^6.0.1\",\n \"@vitest/coverage-v8\": \"4.1.1\",\n eslint: \"^9.38.0\",\n \"eslint-config-prettier\": \"^10.1.8\",\n \"eslint-plugin-prettier\": \"^5.5.4\",\n \"eslint-plugin-react\": \"^7.37.5\",\n \"eslint-plugin-react-hooks\": \"^7.0.1\",\n globals: \"^16.4.0\",\n tailwindcss: \"^4.1.16\",\n typescript: \"^5.9.3\",\n \"typescript-eslint\": \"^8.46.2\",\n vite: \"^8.0.8\",\n \"vite-tsconfig-paths\": \"6.1.1\",\n vitest: \"4.1.1\",\n} as const;\n\nexport const defaultManifest: Manifest = {\n name: \"\",\n description: \"\",\n category: \"\",\n publisher: {\n name: \"\",\n url: \"\",\n },\n documentModels: [],\n editors: [],\n apps: [],\n subgraphs: [],\n processors: [],\n};\n\nconst DEFAULT_DOCUMENT_MODELS_DIR = \"./document-models\";\nconst DEFAULT_EDITORS_DIR = \"./editors\";\nconst DEFAULT_PROCESSORS_DIR = \"./processors\";\nconst DEFAULT_SUBGRAPHS_DIR = \"./subgraphs\";\nconst DEFAULT_IMPORT_SCRIPTS_DIR = \"./scripts\";\nconst DEFAULT_SKIP_FORMAT = false;\nconst DEFAULT_LOG_LEVEL = \"info\";\n\nexport const DEFAULT_CONFIG: PowerhouseConfig = {\n documentModelsDir: DEFAULT_DOCUMENT_MODELS_DIR,\n editorsDir: DEFAULT_EDITORS_DIR,\n processorsDir: DEFAULT_PROCESSORS_DIR,\n subgraphsDir: DEFAULT_SUBGRAPHS_DIR,\n importScriptsDir: DEFAULT_IMPORT_SCRIPTS_DIR,\n skipFormat: DEFAULT_SKIP_FORMAT,\n logLevel: DEFAULT_LOG_LEVEL,\n auth: {\n enabled: false,\n admins: [],\n },\n};\n","import { readFileSync } from \"node:fs\";\nimport { DEFAULT_CONFIG } from \"../constants.js\";\nimport type { PowerhouseConfig } from \"../types.js\";\n\nexport function getConfig(path = \"./powerhouse.config.json\") {\n let config: PowerhouseConfig = { ...DEFAULT_CONFIG };\n try {\n const configStr = readFileSync(path, \"utf-8\");\n const userConfig = JSON.parse(configStr) as PowerhouseConfig;\n config = { ...config, ...userConfig };\n } catch {\n // console.warn(\"No powerhouse.config.json found, using defaults\");\n }\n\n return config;\n}\n","import { spawn } from \"node:child_process\";\n\nexport function spawnAsync(\n command: string,\n args: string[],\n options: {\n cwd?: string;\n env?: NodeJS.ProcessEnv;\n } = {},\n): Promise<string> {\n return new Promise((resolve, reject) => {\n const cmd =\n process.platform === \"win32\" && command === \"npm\" ? \"npm.cmd\" : command;\n\n const child = spawn(cmd, args, {\n cwd: options.cwd,\n env: options.env,\n stdio: [\"ignore\", \"pipe\", \"pipe\"],\n });\n\n let stdout = \"\";\n let stderr = \"\";\n\n child.stdout.on(\"data\", (d: Buffer) => {\n stdout += d.toString();\n });\n\n child.stderr.on(\"data\", (d: Buffer) => {\n stderr += d.toString();\n });\n\n child.on(\"error\", reject);\n\n child.on(\"close\", (code) => {\n if (code === 0) {\n resolve(stdout.trim());\n } else {\n reject(\n new Error(stderr.trim() || `${command} exited with code ${code}`),\n );\n }\n });\n });\n}\n","import { promises as fs } from \"node:fs\";\nimport { homedir } from \"node:os\";\nimport { join } from \"node:path\";\nimport {\n DEFAULT_REGISTRY_URL,\n POWERHOUSE_CONFIG_FILE,\n} from \"../clis/constants.js\";\nimport { getConfig } from \"../clis/file-system/get-config.js\";\nimport { spawnAsync } from \"../clis/file-system/spawn-async.js\";\n\nexport { DEFAULT_REGISTRY_URL } from \"../clis/constants.js\";\n\n/**\n * Extract the host portion of a registry URL — what npm uses as the key in\n * `~/.npmrc` for per-registry tokens (e.g. `//registry.dev.vetra.io/`).\n */\nexport function registryAuthKey(registryUrl: string): string {\n const url = new URL(registryUrl);\n // Always trailing slash; npm's lookup is exact-match against the leading\n // path of the registry URL, with `//` prefix and trailing `/`.\n const path = url.pathname.endsWith(\"/\") ? url.pathname : `${url.pathname}/`;\n return `//${url.host}${path}:_authToken`;\n}\n\nexport interface ResolveRegistryUrlOptions {\n /** Explicit registry URL (e.g. from --registry flag). Highest priority. */\n registry?: string;\n /** Project path to read powerhouse.config.json from. */\n projectPath: string;\n /** Environment variables. Defaults to process.env. */\n env?: Record<string, string | undefined>;\n}\n\n/**\n * Resolve the registry URL with priority: flag > env > config > default.\n */\nexport function resolveRegistryUrl(options: ResolveRegistryUrlOptions): string {\n const { registry, projectPath, env = process.env } = options;\n const configPath = join(projectPath, POWERHOUSE_CONFIG_FILE);\n const config = getConfig(configPath);\n\n return (\n registry ??\n env.PH_REGISTRY_URL ??\n config.packageRegistryUrl ??\n DEFAULT_REGISTRY_URL\n );\n}\n\n/**\n * Check if the user is authenticated with the given npm registry.\n * Returns the username on success, throws on failure.\n */\nexport async function checkNpmAuth(registryUrl: string): Promise<string> {\n return spawnAsync(\"npm\", [\"whoami\", \"--registry\", registryUrl]);\n}\n\nexport interface NpmPublishOptions {\n /** Registry URL to publish to. */\n registryUrl: string;\n /** Working directory (project root). */\n cwd: string;\n /** Additional arguments forwarded to npm publish. */\n args?: string[];\n /** Bearer token for the registry. When set, passed via a registry-scoped\n * `_authToken` config flag rather than read from the user's `.npmrc`. */\n authToken?: string;\n}\n\nexport interface NpmPublishResult {\n /** stdout from npm publish. */\n stdout: string;\n}\n\n/**\n * Run `npm publish` against the given registry.\n * Uses spawn with args array to avoid shell injection.\n *\n * When `authToken` is provided, the token is passed via a registry-scoped\n * `--//host/:_authToken=<token>` flag (npm's standard form for per-registry\n * tokens) so we never have to write to `~/.npmrc`.\n */\nexport async function npmPublish(\n options: NpmPublishOptions,\n): Promise<NpmPublishResult> {\n const { registryUrl, cwd, args = [], authToken } = options;\n const tokenArg = authToken\n ? [`--${registryAuthKey(registryUrl)}=${authToken}`]\n : [];\n const npmArgs = [\"publish\", \"--registry\", registryUrl, ...tokenArg, ...args];\n const stdout = await spawnAsync(\"npm\", npmArgs, { cwd });\n return { stdout };\n}\n\n/**\n * Write `_authToken=<token>` for the given registry host into `~/.npmrc`,\n * preserving any other lines. Replaces the existing entry for the same key\n * if present. Returns the absolute path to the npmrc that was written.\n */\nexport async function writeRegistryAuthToken(\n registryUrl: string,\n token: string,\n): Promise<string> {\n const npmrcPath = join(homedir(), \".npmrc\");\n const key = registryAuthKey(registryUrl);\n let existing = \"\";\n try {\n existing = await fs.readFile(npmrcPath, \"utf8\");\n } catch (err) {\n if ((err as NodeJS.ErrnoException).code !== \"ENOENT\") throw err;\n }\n const lines = existing.split(\"\\n\");\n const filtered = lines.filter((line) => !line.startsWith(`${key}=`));\n // Also drop any trailing empties to avoid stacking blank lines on rewrite.\n while (filtered.length && filtered[filtered.length - 1] === \"\")\n filtered.pop();\n filtered.push(`${key}=${token}`);\n await fs.writeFile(npmrcPath, `${filtered.join(\"\\n\")}\\n`, \"utf8\");\n return npmrcPath;\n}\n\nexport interface NpmUnpublishOptions {\n /** Registry URL to unpublish from. */\n registryUrl: string;\n /** Working directory (project root). */\n cwd: string;\n /** Package spec: `<name>` (whole package) or `<name>@<version>` (single version). */\n spec: string;\n /** Additional arguments forwarded to npm unpublish. */\n args?: string[];\n /** Bearer token for the registry (same semantics as `NpmPublishOptions.authToken`). */\n authToken?: string;\n}\n\nexport interface NpmUnpublishResult {\n /** stdout from npm unpublish. */\n stdout: string;\n}\n\n/**\n * Run `npm unpublish` against the given registry.\n * Always passes `--force` because npm otherwise refuses to unpublish packages\n * older than 72h (a public-npmjs safeguard that doesn't apply to private registries).\n */\nexport async function npmUnpublish(\n options: NpmUnpublishOptions,\n): Promise<NpmUnpublishResult> {\n const { registryUrl, cwd, spec, args = [], authToken } = options;\n const tokenArg = authToken\n ? [`--${registryAuthKey(registryUrl)}=${authToken}`]\n : [];\n const npmArgs = [\n \"unpublish\",\n spec,\n \"--registry\",\n registryUrl,\n \"--force\",\n ...tokenArg,\n ...args,\n ];\n const stdout = await spawnAsync(\"npm\", npmArgs, { cwd });\n return { stdout };\n}\n"],"mappings":"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"}
@@ -0,0 +1,158 @@
1
+ import { DateTime } from "luxon";
2
+
3
+ //#region analytics/constants.d.ts
4
+ declare enum AnalyticsSerializerTypes {
5
+ AnalyticsPath = 0,
6
+ AnalyticsPathSegment = 1,
7
+ AnalyticsPeriod = 2
8
+ }
9
+ declare enum AnalyticsPeriodType {
10
+ Year = 0,
11
+ Quarter = 1,
12
+ Month = 2
13
+ }
14
+ declare enum AnalyticsMetric {
15
+ Budget = 0,
16
+ Forecast = 1,
17
+ Actuals = 2,
18
+ PaymentsOnChain = 3,
19
+ PaymentsOffChainIncluded = 4,
20
+ FTEs = 5
21
+ }
22
+ declare enum CompoundOperator {
23
+ VectorAdd = 0,
24
+ VectorSubtract = 1,
25
+ ScalarMultiply = 2,
26
+ ScalarDivide = 3
27
+ }
28
+ declare enum AnalyticsGranularity {
29
+ Total = 0,
30
+ Annual = 1,
31
+ SemiAnnual = 2,
32
+ Quarterly = 3,
33
+ Monthly = 4,
34
+ Weekly = 5,
35
+ Daily = 6,
36
+ Hourly = 7
37
+ }
38
+ //#endregion
39
+ //#region analytics/analytics-path.d.ts
40
+ declare class AnalyticsPath {
41
+ get segments(): AnalyticsPathSegment[];
42
+ private _segments;
43
+ static fromString(path: string): AnalyticsPath;
44
+ static fromStringArray(segments: string[]): AnalyticsPath;
45
+ static fromArray(segments: AnalyticsPathSegment[]): AnalyticsPath;
46
+ static fromJSON(json: any): AnalyticsPath;
47
+ constructor(segments: AnalyticsPathSegment[]);
48
+ toJSON(): {
49
+ _t: AnalyticsSerializerTypes;
50
+ _v: string;
51
+ };
52
+ toString(tail?: string): string;
53
+ firstSegment(): AnalyticsPathSegment;
54
+ reduce(): AnalyticsPath;
55
+ applyLod(levelOfDetail: number): AnalyticsPath;
56
+ }
57
+ declare class AnalyticsPathSegment {
58
+ get filters(): NullableStrings;
59
+ get groups(): NullableStrings;
60
+ private _filters;
61
+ private _groups;
62
+ static fromString(segment: string): AnalyticsPathSegment;
63
+ static escape(segment: string): string;
64
+ static unescape(segment: string): string;
65
+ constructor(filters?: NullableStrings, groups?: NullableStrings);
66
+ toJSON(): {
67
+ _t: AnalyticsSerializerTypes;
68
+ _v: string;
69
+ };
70
+ toString(): string;
71
+ }
72
+ type NullableStrings = string[] | null;
73
+ //#endregion
74
+ //#region analytics/types.d.ts
75
+ type AnalyticsSeriesQuery = {
76
+ start: DateTime | null;
77
+ end: DateTime | null;
78
+ metrics: string[];
79
+ currency?: AnalyticsPath;
80
+ select: Record<string, AnalyticsPath[]>;
81
+ };
82
+ type AnalyticsQuery = AnalyticsSeriesQuery & {
83
+ granularity: AnalyticsGranularity;
84
+ lod: Record<string, number | null>;
85
+ };
86
+ type AnalyticsSeries<D = string | AnalyticsDimension> = {
87
+ source: AnalyticsPath;
88
+ start: DateTime;
89
+ end: DateTime | null;
90
+ metric: string;
91
+ value: number;
92
+ unit: string | null;
93
+ fn: string;
94
+ params: Record<string, unknown> | null;
95
+ dimensions: Record<string, D>;
96
+ };
97
+ type AnalyticsDimension = {
98
+ path: AnalyticsPath;
99
+ icon: string;
100
+ label: string;
101
+ description: string;
102
+ };
103
+ type CompoundAnalyticsQuery = {
104
+ start: DateTime | null;
105
+ end: DateTime | null;
106
+ granularity: AnalyticsGranularity;
107
+ lod: Record<string, number | null>;
108
+ select: Record<string, AnalyticsPath[]>;
109
+ expression: CompoundAnalyticsExpression;
110
+ };
111
+ type CompoundAnalyticsExpression = {
112
+ inputs: CompoundAnalyticsInputs;
113
+ operator: CompoundOperator;
114
+ operand: AnalyticsOperand;
115
+ resultCurrency?: AnalyticsPath;
116
+ };
117
+ type CompoundAnalyticsInputs = {
118
+ metrics: string[];
119
+ currency?: AnalyticsPath;
120
+ };
121
+ type AnalyticsOperand = {
122
+ metric: string;
123
+ currency?: AnalyticsPath;
124
+ useSum: boolean;
125
+ };
126
+ type MultiCurrencyConversion = {
127
+ targetCurrency?: AnalyticsPath;
128
+ conversions: ConversionMetric[];
129
+ };
130
+ type ConversionMetric = {
131
+ metric: string;
132
+ currency?: AnalyticsPath;
133
+ };
134
+ type AnalyticsSeriesInput = {
135
+ start: DateTime;
136
+ end?: DateTime | null;
137
+ source: AnalyticsPath;
138
+ metric: string;
139
+ value: number;
140
+ unit?: string | null;
141
+ fn?: string | null;
142
+ params?: Record<string, any> | null;
143
+ dimensions: Record<string, AnalyticsPath>;
144
+ dimensionMetadata?: Record<string, string>;
145
+ };
146
+ type AnalyticsUpdateCallback = (source: AnalyticsPath) => void;
147
+ interface IAnalyticsStore {
148
+ clearSeriesBySource: (source: AnalyticsPath, cleanUpDimensions?: boolean) => Promise<number>;
149
+ clearEmptyAnalyticsDimensions: () => Promise<number>;
150
+ getMatchingSeries: (query: AnalyticsSeriesQuery) => Promise<AnalyticsSeries[]>;
151
+ addSeriesValue: (input: AnalyticsSeriesInput) => Promise<void>;
152
+ addSeriesValues: (inputs: AnalyticsSeriesInput[]) => Promise<void>;
153
+ getDimensions: () => Promise<any>;
154
+ subscribeToSource: (source: AnalyticsPath, callback: AnalyticsUpdateCallback) => () => void;
155
+ }
156
+ //#endregion
157
+ export { AnalyticsMetric as _, AnalyticsSeriesInput as a, CompoundOperator as b, CompoundAnalyticsExpression as c, ConversionMetric as d, IAnalyticsStore as f, AnalyticsGranularity as g, AnalyticsPathSegment as h, AnalyticsSeries as i, CompoundAnalyticsInputs as l, AnalyticsPath as m, AnalyticsOperand as n, AnalyticsSeriesQuery as o, MultiCurrencyConversion as p, AnalyticsQuery as r, AnalyticsUpdateCallback as s, AnalyticsDimension as t, CompoundAnalyticsQuery as u, AnalyticsPeriodType as v, AnalyticsSerializerTypes as y };
158
+ //# sourceMappingURL=types-BFDlQkXZ.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types-BFDlQkXZ.d.ts","names":[],"sources":["../analytics/constants.ts","../analytics/analytics-path.ts","../analytics/types.ts"],"mappings":";;;aAAY,wBAAA;EACV,aAAA;EACA,oBAAA;EACA,eAAA;AAAA;AAAA,aAGU,mBAAA;EACV,IAAA;EACA,OAAA;EACA,KAAA;AAAA;AAAA,aAGU,eAAA;EACV,MAAA;EACA,QAAA;EACA,OAAA;EACA,eAAA;EACA,wBAAA;EACA,IAAA;AAAA;AAAA,aAEU,gBAAA;EACV,SAAA;EACA,cAAA;EACA,cAAA;EACA,YAAA;AAAA;AAAA,aAEU,oBAAA;EACV,KAAA;EACA,MAAA;EACA,UAAA;EACA,SAAA;EACA,OAAA;EACA,MAAA;EACA,KAAA;EACA,MAAA;AAAA;;;cC5BW,aAAA;EAAA,IACP,QAAA,CAAA,GAAY,oBAAA;EAAA,QAIR,SAAA;EAAA,OAEM,UAAA,CAAW,IAAA,WAAe,aAAA;EAAA,OAQ1B,eAAA,CAAgB,QAAA,aAAqB,aAAA;EAAA,OAMrC,SAAA,CAAU,QAAA,EAAU,oBAAA,KAAyB,aAAA;EAAA,OAI7C,QAAA,CAAS,IAAA,QAAY,aAAA;cAOvB,QAAA,EAAU,oBAAA;EAIf,MAAA,CAAA;;;;EAOA,QAAA,CAAS,IAAA;EAIT,YAAA,CAAA,GAAgB,oBAAA;EAMhB,MAAA,CAAA,GAAU,aAAA;EAUV,QAAA,CAAS,aAAA,WAAwB,aAAA;AAAA;AAAA,cAW7B,oBAAA;EAAA,IACP,OAAA,CAAA,GAAW,eAAA;EAAA,IAGX,MAAA,CAAA,GAAU,eAAA;EAAA,QAIN,QAAA;EAAA,QACA,OAAA;EAAA,OAEM,UAAA,CAAW,OAAA,WAAkB,oBAAA;EAAA,OA0B7B,MAAA,CAAO,OAAA;EAAA,OAKP,QAAA,CAAS,OAAA;cAKX,OAAA,GAAS,eAAA,EAAwB,MAAA,GAAQ,eAAA;EAK9C,MAAA,CAAA;;;;EAOA,QAAA,CAAA;AAAA;AAAA,KAsBJ,eAAA;;;KC7JO,oBAAA;EACV,KAAA,EAAO,QAAA;EACP,GAAA,EAAK,QAAA;EACL,OAAA;EACA,QAAA,GAAW,aAAA;EACX,MAAA,EAAQ,MAAA,SAAe,aAAA;AAAA;AAAA,KAEb,cAAA,GAAiB,oBAAA;EAC3B,WAAA,EAAa,oBAAA;EACb,GAAA,EAAK,MAAA;AAAA;AAAA,KAEK,eAAA,cAA6B,kBAAA;EACvC,MAAA,EAAQ,aAAA;EACR,KAAA,EAAO,QAAA;EACP,GAAA,EAAK,QAAA;EACL,MAAA;EACA,KAAA;EACA,IAAA;EACA,EAAA;EACA,MAAA,EAAQ,MAAA;EACR,UAAA,EAAY,MAAA,SAAe,CAAA;AAAA;AAAA,KAEjB,kBAAA;EACV,IAAA,EAAM,aAAA;EACN,IAAA;EACA,KAAA;EACA,WAAA;AAAA;AAAA,KAEU,sBAAA;EACV,KAAA,EAAO,QAAA;EACP,GAAA,EAAK,QAAA;EACL,WAAA,EAAa,oBAAA;EACb,GAAA,EAAK,MAAA;EACL,MAAA,EAAQ,MAAA,SAAe,aAAA;EACvB,UAAA,EAAY,2BAAA;AAAA;AAAA,KAEF,2BAAA;EACV,MAAA,EAAQ,uBAAA;EACR,QAAA,EAAU,gBAAA;EACV,OAAA,EAAS,gBAAA;EACT,cAAA,GAAiB,aAAA;AAAA;AAAA,KAEP,uBAAA;EACV,OAAA;EACA,QAAA,GAAW,aAAA;AAAA;AAAA,KAED,gBAAA;EACV,MAAA;EACA,QAAA,GAAW,aAAA;EACX,MAAA;AAAA;AAAA,KAEU,uBAAA;EACV,cAAA,GAAiB,aAAA;EACjB,WAAA,EAAa,gBAAA;AAAA;AAAA,KAEH,gBAAA;EACV,MAAA;EACA,QAAA,GAAW,aAAA;AAAA;AAAA,KAGD,oBAAA;EACV,KAAA,EAAO,QAAA;EACP,GAAA,GAAM,QAAA;EACN,MAAA,EAAQ,aAAA;EACR,MAAA;EACA,KAAA;EACA,IAAA;EACA,EAAA;EACA,MAAA,GAAS,MAAA;EACT,UAAA,EAAY,MAAA,SAAe,aAAA;EAC3B,iBAAA,GAAoB,MAAA;AAAA;AAAA,KAGV,uBAAA,IAA2B,MAAA,EAAQ,aAAA;AAAA,UAE9B,eAAA;EACf,mBAAA,GACE,MAAA,EAAQ,aAAA,EACR,iBAAA,eACG,OAAA;EACL,6BAAA,QAAqC,OAAA;EACrC,iBAAA,GACE,KAAA,EAAO,oBAAA,KACJ,OAAA,CAAQ,eAAA;EACb,cAAA,GAAiB,KAAA,EAAO,oBAAA,KAAyB,OAAA;EACjD,eAAA,GAAkB,MAAA,EAAQ,oBAAA,OAA2B,OAAA;EACrD,aAAA,QAAqB,OAAA;EAErB,iBAAA,GACE,MAAA,EAAQ,aAAA,EACR,QAAA,EAAU,uBAAA;AAAA"}