@rocicorp/zero 0.23.2025081200 → 0.23.2025081400

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 (132) hide show
  1. package/out/{chunk-ZJ4VVIKN.js → chunk-JHJ3MBXW.js} +5 -5
  2. package/out/{chunk-6TQKR5IL.js → chunk-O536GEIT.js} +89 -17
  3. package/out/chunk-O536GEIT.js.map +7 -0
  4. package/out/{chunk-YTS56A64.js → chunk-ZKRMVMWK.js} +20 -29
  5. package/out/chunk-ZKRMVMWK.js.map +7 -0
  6. package/out/{inspector-RB55U26N.js → inspector-J5P4DOGH.js} +52 -16
  7. package/out/inspector-J5P4DOGH.js.map +7 -0
  8. package/out/react.js +2 -2
  9. package/out/shared/src/binary-search.js +31 -0
  10. package/out/shared/src/binary-search.js.map +1 -0
  11. package/out/shared/src/centroid.js +28 -0
  12. package/out/shared/src/centroid.js.map +1 -0
  13. package/out/shared/src/dotenv.js +0 -5
  14. package/out/shared/src/dotenv.js.map +1 -1
  15. package/out/shared/src/logging-test-utils.d.ts +12 -0
  16. package/out/shared/src/logging-test-utils.d.ts.map +1 -0
  17. package/out/shared/src/logging-test-utils.js +21 -0
  18. package/out/shared/src/logging-test-utils.js.map +1 -0
  19. package/out/shared/src/objects.d.ts +3 -1
  20. package/out/shared/src/objects.d.ts.map +1 -1
  21. package/out/shared/src/objects.js.map +1 -1
  22. package/out/shared/src/tdigest-schema.d.ts +8 -0
  23. package/out/shared/src/tdigest-schema.d.ts.map +1 -0
  24. package/out/shared/src/tdigest-schema.js +7 -0
  25. package/out/shared/src/tdigest-schema.js.map +1 -0
  26. package/out/shared/src/tdigest.d.ts +11 -0
  27. package/out/shared/src/tdigest.d.ts.map +1 -1
  28. package/out/shared/src/tdigest.js +304 -0
  29. package/out/shared/src/tdigest.js.map +1 -0
  30. package/out/solid.js +3 -3
  31. package/out/zero/package.json +3 -1
  32. package/out/zero-cache/src/config/zero-config.d.ts +18 -287
  33. package/out/zero-cache/src/config/zero-config.d.ts.map +1 -1
  34. package/out/zero-cache/src/config/zero-config.js +43 -0
  35. package/out/zero-cache/src/config/zero-config.js.map +1 -1
  36. package/out/zero-cache/src/observability/events.d.ts +15 -0
  37. package/out/zero-cache/src/observability/events.d.ts.map +1 -0
  38. package/out/zero-cache/src/observability/events.js +93 -0
  39. package/out/zero-cache/src/observability/events.js.map +1 -0
  40. package/out/zero-cache/src/server/anonymous-otel-start.d.ts +1 -1
  41. package/out/zero-cache/src/server/anonymous-otel-start.d.ts.map +1 -1
  42. package/out/zero-cache/src/server/anonymous-otel-start.js +40 -18
  43. package/out/zero-cache/src/server/anonymous-otel-start.js.map +1 -1
  44. package/out/zero-cache/src/server/change-streamer.js +4 -4
  45. package/out/zero-cache/src/server/change-streamer.js.map +1 -1
  46. package/out/zero-cache/src/server/main.js +4 -4
  47. package/out/zero-cache/src/server/main.js.map +1 -1
  48. package/out/zero-cache/src/server/replicator.d.ts.map +1 -1
  49. package/out/zero-cache/src/server/replicator.js +7 -6
  50. package/out/zero-cache/src/server/replicator.js.map +1 -1
  51. package/out/zero-cache/src/server/runner/run-worker.d.ts.map +1 -1
  52. package/out/zero-cache/src/server/runner/run-worker.js +3 -2
  53. package/out/zero-cache/src/server/runner/run-worker.js.map +1 -1
  54. package/out/zero-cache/src/server/syncer.js +5 -5
  55. package/out/zero-cache/src/server/syncer.js.map +1 -1
  56. package/out/zero-cache/src/services/change-source/custom/change-source.d.ts.map +1 -1
  57. package/out/zero-cache/src/services/change-source/custom/change-source.js +46 -35
  58. package/out/zero-cache/src/services/change-source/custom/change-source.js.map +1 -1
  59. package/out/zero-cache/src/services/change-source/pg/initial-sync.d.ts.map +1 -1
  60. package/out/zero-cache/src/services/change-source/pg/initial-sync.js +7 -2
  61. package/out/zero-cache/src/services/change-source/pg/initial-sync.js.map +1 -1
  62. package/out/zero-cache/src/services/mutagen/mutagen.js +1 -1
  63. package/out/zero-cache/src/services/mutagen/mutagen.js.map +1 -1
  64. package/out/zero-cache/src/services/mutagen/pusher.d.ts +28 -2
  65. package/out/zero-cache/src/services/mutagen/pusher.d.ts.map +1 -1
  66. package/out/zero-cache/src/services/mutagen/pusher.js +1 -1
  67. package/out/zero-cache/src/services/mutagen/pusher.js.map +1 -1
  68. package/out/zero-cache/src/services/replicator/change-processor.d.ts +5 -1
  69. package/out/zero-cache/src/services/replicator/change-processor.d.ts.map +1 -1
  70. package/out/zero-cache/src/services/replicator/change-processor.js +10 -8
  71. package/out/zero-cache/src/services/replicator/change-processor.js.map +1 -1
  72. package/out/zero-cache/src/services/replicator/incremental-sync.d.ts +1 -1
  73. package/out/zero-cache/src/services/replicator/incremental-sync.d.ts.map +1 -1
  74. package/out/zero-cache/src/services/replicator/incremental-sync.js +17 -3
  75. package/out/zero-cache/src/services/replicator/incremental-sync.js.map +1 -1
  76. package/out/zero-cache/src/services/replicator/replication-status.d.ts +12 -0
  77. package/out/zero-cache/src/services/replicator/replication-status.d.ts.map +1 -0
  78. package/out/zero-cache/src/services/replicator/replication-status.js +92 -0
  79. package/out/zero-cache/src/services/replicator/replication-status.js.map +1 -0
  80. package/out/zero-cache/src/services/replicator/replicator.d.ts +1 -1
  81. package/out/zero-cache/src/services/replicator/replicator.d.ts.map +1 -1
  82. package/out/zero-cache/src/services/replicator/replicator.js +2 -2
  83. package/out/zero-cache/src/services/replicator/replicator.js.map +1 -1
  84. package/out/zero-cache/src/services/statz.d.ts.map +1 -1
  85. package/out/zero-cache/src/services/statz.js +0 -23
  86. package/out/zero-cache/src/services/statz.js.map +1 -1
  87. package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts +10 -1
  88. package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts.map +1 -1
  89. package/out/zero-cache/src/services/view-syncer/view-syncer.js +77 -8
  90. package/out/zero-cache/src/services/view-syncer/view-syncer.js.map +1 -1
  91. package/out/zero-client/src/client/inspector/inspector.d.ts +7 -7
  92. package/out/zero-client/src/client/inspector/inspector.d.ts.map +1 -1
  93. package/out/zero-client/src/client/inspector/types.d.ts +3 -1
  94. package/out/zero-client/src/client/inspector/types.d.ts.map +1 -1
  95. package/out/zero-client/src/client/query-manager.d.ts +8 -8
  96. package/out/zero-client/src/client/query-manager.d.ts.map +1 -1
  97. package/out/zero-client/src/client/zero.d.ts.map +1 -1
  98. package/out/zero-events/src/index.d.ts +29 -0
  99. package/out/zero-events/src/index.d.ts.map +1 -0
  100. package/out/zero-events/src/index.js +28 -0
  101. package/out/zero-events/src/index.js.map +1 -0
  102. package/out/zero-events/src/status.d.ts +113 -0
  103. package/out/zero-events/src/status.d.ts.map +1 -0
  104. package/out/zero-events/src/status.js +72 -0
  105. package/out/zero-events/src/status.js.map +1 -0
  106. package/out/zero-protocol/src/connect.d.ts.map +1 -1
  107. package/out/zero-protocol/src/connect.js +4 -1
  108. package/out/zero-protocol/src/connect.js.map +1 -1
  109. package/out/zero-protocol/src/down.d.ts +18 -2
  110. package/out/zero-protocol/src/down.d.ts.map +1 -1
  111. package/out/zero-protocol/src/inspect-down.d.ts +64 -6
  112. package/out/zero-protocol/src/inspect-down.d.ts.map +1 -1
  113. package/out/zero-protocol/src/inspect-down.js +18 -3
  114. package/out/zero-protocol/src/inspect-down.js.map +1 -1
  115. package/out/zero-protocol/src/inspect-up.d.ts +25 -6
  116. package/out/zero-protocol/src/inspect-up.d.ts.map +1 -1
  117. package/out/zero-protocol/src/inspect-up.js +8 -3
  118. package/out/zero-protocol/src/inspect-up.js.map +1 -1
  119. package/out/zero-protocol/src/protocol-version.d.ts +1 -1
  120. package/out/zero-protocol/src/protocol-version.d.ts.map +1 -1
  121. package/out/zero-protocol/src/protocol-version.js +3 -1
  122. package/out/zero-protocol/src/protocol-version.js.map +1 -1
  123. package/out/zero-protocol/src/up.d.ts +7 -2
  124. package/out/zero-protocol/src/up.d.ts.map +1 -1
  125. package/out/zero.js +3 -3
  126. package/out/zql/src/query/metrics-delegate.d.ts +5 -1
  127. package/out/zql/src/query/metrics-delegate.d.ts.map +1 -1
  128. package/package.json +3 -1
  129. package/out/chunk-6TQKR5IL.js.map +0 -7
  130. package/out/chunk-YTS56A64.js.map +0 -7
  131. package/out/inspector-RB55U26N.js.map +0 -7
  132. /package/out/{chunk-ZJ4VVIKN.js.map → chunk-JHJ3MBXW.js.map} +0 -0
@@ -1,7 +1,6 @@
1
1
  import {
2
- clientToServer,
3
- mapEntries
4
- } from "./chunk-YTS56A64.js";
2
+ clientToServer
3
+ } from "./chunk-ZKRMVMWK.js";
5
4
  import {
6
5
  AbstractQuery,
7
6
  ExpressionBuilder,
@@ -9,13 +8,14 @@ import {
9
8
  defaultFormat,
10
9
  jsonSchema,
11
10
  mapCondition,
11
+ mapEntries,
12
12
  newQuery,
13
13
  newQuerySymbol,
14
14
  readonly,
15
15
  staticParam,
16
16
  toStaticParam,
17
17
  valita_exports
18
- } from "./chunk-6TQKR5IL.js";
18
+ } from "./chunk-O536GEIT.js";
19
19
  import {
20
20
  assert
21
21
  } from "./chunk-SGW2EIVJ.js";
@@ -358,4 +358,4 @@ export {
358
358
  queries,
359
359
  queriesWithContext
360
360
  };
361
- //# sourceMappingURL=chunk-ZJ4VVIKN.js.map
361
+ //# sourceMappingURL=chunk-JHJ3MBXW.js.map
@@ -698,13 +698,13 @@ var DataNodeImpl = class extends NodeImpl {
698
698
  }
699
699
  }
700
700
  };
701
- function readonlySplice(array5, start, deleteCount, ...items) {
702
- const arr = array5.slice(0, start);
701
+ function readonlySplice(array6, start, deleteCount, ...items) {
702
+ const arr = array6.slice(0, start);
703
703
  for (let i = 0; i < items.length; i++) {
704
704
  arr.push(items[i]);
705
705
  }
706
- for (let i = start + deleteCount; i < array5.length; i++) {
707
- arr.push(array5[i]);
706
+ for (let i = start + deleteCount; i < array6.length; i++) {
707
+ arr.push(array6[i]);
708
708
  }
709
709
  return arr;
710
710
  }
@@ -2934,6 +2934,26 @@ async function setClients(clients, dagWrite) {
2934
2934
  return chunk.hash;
2935
2935
  }
2936
2936
 
2937
+ // ../shared/src/objects.ts
2938
+ function mapValues(input, mapper) {
2939
+ return mapEntries(input, (k, v2) => [k, mapper(v2)]);
2940
+ }
2941
+ function mapEntries(input, mapper) {
2942
+ const output = {};
2943
+ for (const entry of Object.entries(input)) {
2944
+ const mapped = mapper(entry[0], entry[1]);
2945
+ output[mapped[0]] = mapped[1];
2946
+ }
2947
+ return output;
2948
+ }
2949
+ function mapAllEntries(input, mapper) {
2950
+ const output = {};
2951
+ for (const mapped of mapper(Object.entries(input))) {
2952
+ output[mapped[0]] = mapped[1];
2953
+ }
2954
+ return output;
2955
+ }
2956
+
2937
2957
  // ../shared/src/must.ts
2938
2958
  function must(v2, msg) {
2939
2959
  if (v2 == null) {
@@ -3363,6 +3383,9 @@ var jsonObjectSchema = valita_exports.unknown().chain((v2) => {
3363
3383
  return rv;
3364
3384
  });
3365
3385
 
3386
+ // ../shared/src/tdigest-schema.ts
3387
+ var tdigestSchema = valita_exports.tuple([valita_exports.number()]).concat(valita_exports.array(valita_exports.number()));
3388
+
3366
3389
  // ../zero-protocol/src/ast.ts
3367
3390
  import { compareUTF8 as compareUTF83 } from "compare-utf8";
3368
3391
 
@@ -3697,6 +3720,9 @@ function compareUTF8MaybeNull(a, b) {
3697
3720
  }
3698
3721
 
3699
3722
  // ../zero-protocol/src/inspect-down.ts
3723
+ var serverMetricsSchema = valita_exports.object({
3724
+ "query-materialization-server": tdigestSchema
3725
+ });
3700
3726
  var inspectQueryRowSchema = valita_exports.object({
3701
3727
  clientID: valita_exports.string(),
3702
3728
  queryID: valita_exports.string(),
@@ -3710,28 +3736,43 @@ var inspectQueryRowSchema = valita_exports.object({
3710
3736
  deleted: valita_exports.boolean(),
3711
3737
  ttl: valita_exports.number(),
3712
3738
  inactivatedAt: valita_exports.number().nullable(),
3713
- rowCount: valita_exports.number()
3739
+ rowCount: valita_exports.number(),
3740
+ metrics: serverMetricsSchema.nullable().optional()
3741
+ });
3742
+ var inspectBaseDownSchema = valita_exports.object({
3743
+ id: valita_exports.string()
3714
3744
  });
3715
- var inspectQueriesDownSchema = valita_exports.object({
3745
+ var inspectQueriesDownSchema = inspectBaseDownSchema.extend({
3716
3746
  op: valita_exports.literal("queries"),
3717
- id: valita_exports.string(),
3718
3747
  value: valita_exports.array(inspectQueryRowSchema)
3719
3748
  });
3720
- var inspectDownBodySchema = valita_exports.union(inspectQueriesDownSchema);
3749
+ var inspectMetricsDownSchema = inspectBaseDownSchema.extend({
3750
+ op: valita_exports.literal("metrics"),
3751
+ value: serverMetricsSchema
3752
+ });
3753
+ var inspectVersionDownSchema = inspectBaseDownSchema.extend({
3754
+ op: valita_exports.literal("version"),
3755
+ value: valita_exports.string()
3756
+ });
3757
+ var inspectDownBodySchema = valita_exports.union(
3758
+ inspectQueriesDownSchema,
3759
+ inspectMetricsDownSchema,
3760
+ inspectVersionDownSchema
3761
+ );
3721
3762
  var inspectDownMessageSchema = valita_exports.tuple([
3722
3763
  valita_exports.literal("inspect"),
3723
3764
  inspectDownBodySchema
3724
3765
  ]);
3725
3766
 
3726
3767
  // ../shared/src/random-values.ts
3727
- function getNonCryptoRandomValues(array5) {
3728
- if (array5 === null) {
3768
+ function getNonCryptoRandomValues(array6) {
3769
+ if (array6 === null) {
3729
3770
  throw new TypeError("array cannot be null");
3730
3771
  }
3731
- for (let i = 0; i < array5.length; i++) {
3732
- array5[i] = Math.floor(Math.random() * 256);
3772
+ for (let i = 0; i < array6.length; i++) {
3773
+ array6[i] = Math.floor(Math.random() * 256);
3733
3774
  }
3734
- return array5;
3775
+ return array6;
3735
3776
  }
3736
3777
 
3737
3778
  // ../zero-client/src/util/nanoid.ts
@@ -3834,7 +3875,7 @@ function sortCentroidList(centroids) {
3834
3875
  }
3835
3876
 
3836
3877
  // ../shared/src/tdigest.ts
3837
- var TDigest = class {
3878
+ var TDigest = class _TDigest {
3838
3879
  compression;
3839
3880
  #maxProcessed;
3840
3881
  #maxUnprocessed;
@@ -3851,6 +3892,20 @@ var TDigest = class {
3851
3892
  this.#maxUnprocessed = unprocessedSize(0, this.compression);
3852
3893
  this.reset();
3853
3894
  }
3895
+ /**
3896
+ * fromJSON creates a TDigest from a JSON-serializable representation.
3897
+ * The data should be an object with compression and centroids array.
3898
+ */
3899
+ static fromJSON(data) {
3900
+ const digest = new _TDigest(data[0]);
3901
+ if (data.length % 2 !== 1) {
3902
+ throw new Error("Invalid centroids array");
3903
+ }
3904
+ for (let i = 1; i < data.length; i += 2) {
3905
+ digest.add(data[i], data[i + 1]);
3906
+ }
3907
+ return digest;
3908
+ }
3854
3909
  reset() {
3855
3910
  this.#processed = [];
3856
3911
  this.#unprocessed = [];
@@ -3938,6 +3993,18 @@ var TDigest = class {
3938
3993
  this.#process();
3939
3994
  return this.#processedWeight;
3940
3995
  }
3996
+ /**
3997
+ * toJSON returns a JSON-serializable representation of the digest.
3998
+ * This processes the digest and returns an object with compression and centroid data.
3999
+ */
4000
+ toJSON() {
4001
+ this.#process();
4002
+ const data = [this.compression];
4003
+ for (const centroid of this.#processed) {
4004
+ data.push(centroid.mean, centroid.weight);
4005
+ }
4006
+ return data;
4007
+ }
3941
4008
  #updateCumulative() {
3942
4009
  if (this.#cumulative.length > 0 && this.#cumulative[this.#cumulative.length - 1] === this.#processedWeight) {
3943
4010
  return;
@@ -5820,8 +5887,8 @@ var negateOperatorMap = {
5820
5887
  function negateOperator(op) {
5821
5888
  return must(negateOperatorMap[op]);
5822
5889
  }
5823
- function filterUndefined(array5) {
5824
- return array5.filter((e) => e !== void 0);
5890
+ function filterUndefined(array6) {
5891
+ return array6.filter((e) => e !== void 0);
5825
5892
  }
5826
5893
  function filterTrue(conditions) {
5827
5894
  return conditions.filter((c) => !isAlwaysTrue(c));
@@ -7155,6 +7222,9 @@ export {
7155
7222
  mapAST,
7156
7223
  mapCondition,
7157
7224
  h64,
7225
+ mapValues,
7226
+ mapEntries,
7227
+ mapAllEntries,
7158
7228
  hashOfAST,
7159
7229
  hashOfNameAndArgs,
7160
7230
  compareValues,
@@ -7179,6 +7249,8 @@ export {
7179
7249
  newQuerySymbol,
7180
7250
  AbstractQuery,
7181
7251
  inspectQueriesDownSchema,
7252
+ inspectMetricsDownSchema,
7253
+ inspectVersionDownSchema,
7182
7254
  inspectDownMessageSchema,
7183
7255
  primaryKeySchema,
7184
7256
  primaryKeyValueRecordSchema,
@@ -7194,4 +7266,4 @@ export {
7194
7266
  sourceNameFromKey,
7195
7267
  TDigest
7196
7268
  };
7197
- //# sourceMappingURL=chunk-6TQKR5IL.js.map
7269
+ //# sourceMappingURL=chunk-O536GEIT.js.map