@dcl/ecs 7.21.0 → 7.21.1-22904194370.commit-34c867c

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 (89) hide show
  1. package/dist/components/extended/Tween.d.ts +1 -48
  2. package/dist/components/extended/Tween.js +0 -66
  3. package/dist/components/generated/component-names.gen.js +0 -2
  4. package/dist/components/generated/global.gen.d.ts +0 -4
  5. package/dist/components/generated/global.gen.js +0 -2
  6. package/dist/components/generated/index.gen.d.ts +0 -8
  7. package/dist/components/generated/index.gen.js +0 -10
  8. package/dist/components/generated/pb/decentraland/sdk/components/input_modifier.gen.d.ts +0 -2
  9. package/dist/components/generated/pb/decentraland/sdk/components/input_modifier.gen.js +0 -20
  10. package/dist/components/generated/pb/decentraland/sdk/components/tween.gen.d.ts +0 -21
  11. package/dist/components/generated/pb/decentraland/sdk/components/tween.gen.js +0 -99
  12. package/dist/components/index.d.ts +5 -0
  13. package/dist/components/index.js +5 -2
  14. package/dist/components/manual/CreatedBy.d.ts +9 -0
  15. package/dist/components/manual/CreatedBy.js +8 -0
  16. package/dist/components/manual/Transform.d.ts +9 -0
  17. package/dist/components/manual/Transform.js +3 -3
  18. package/dist/components/types.d.ts +2 -1
  19. package/dist/engine/component.d.ts +52 -1
  20. package/dist/engine/grow-only-value-set-component-definition.js +45 -2
  21. package/dist/engine/lww-element-set-component-definition.d.ts +3 -1
  22. package/dist/engine/lww-element-set-component-definition.js +64 -12
  23. package/dist/index.d.ts +2 -2
  24. package/dist/index.js +1 -1
  25. package/dist/runtime/globals.d.ts +1 -10
  26. package/dist/runtime/globals.js +2 -2
  27. package/dist/serialization/crdt/authoritativePutComponent.d.ts +15 -0
  28. package/dist/serialization/crdt/authoritativePutComponent.js +47 -0
  29. package/dist/serialization/crdt/index.d.ts +1 -0
  30. package/dist/serialization/crdt/index.js +1 -0
  31. package/dist/serialization/crdt/types.d.ts +25 -3
  32. package/dist/serialization/crdt/types.js +3 -1
  33. package/dist/systems/crdt/index.d.ts +0 -1
  34. package/dist/systems/crdt/index.js +55 -146
  35. package/dist-cjs/components/extended/Tween.d.ts +1 -48
  36. package/dist-cjs/components/extended/Tween.js +0 -66
  37. package/dist-cjs/components/generated/component-names.gen.js +0 -2
  38. package/dist-cjs/components/generated/global.gen.d.ts +0 -4
  39. package/dist-cjs/components/generated/global.gen.js +1 -3
  40. package/dist-cjs/components/generated/index.gen.d.ts +0 -8
  41. package/dist-cjs/components/generated/index.gen.js +2 -14
  42. package/dist-cjs/components/generated/pb/decentraland/sdk/components/input_modifier.gen.d.ts +0 -2
  43. package/dist-cjs/components/generated/pb/decentraland/sdk/components/input_modifier.gen.js +0 -20
  44. package/dist-cjs/components/generated/pb/decentraland/sdk/components/tween.gen.d.ts +0 -21
  45. package/dist-cjs/components/generated/pb/decentraland/sdk/components/tween.gen.js +1 -100
  46. package/dist-cjs/components/index.d.ts +5 -0
  47. package/dist-cjs/components/index.js +7 -3
  48. package/dist-cjs/components/manual/CreatedBy.d.ts +9 -0
  49. package/dist-cjs/components/manual/CreatedBy.js +10 -0
  50. package/dist-cjs/components/manual/Transform.d.ts +9 -0
  51. package/dist-cjs/components/manual/Transform.js +3 -3
  52. package/dist-cjs/components/types.d.ts +2 -1
  53. package/dist-cjs/engine/component.d.ts +52 -1
  54. package/dist-cjs/engine/grow-only-value-set-component-definition.js +44 -1
  55. package/dist-cjs/engine/lww-element-set-component-definition.d.ts +3 -1
  56. package/dist-cjs/engine/lww-element-set-component-definition.js +67 -13
  57. package/dist-cjs/index.d.ts +2 -2
  58. package/dist-cjs/index.js +2 -2
  59. package/dist-cjs/runtime/globals.d.ts +1 -10
  60. package/dist-cjs/runtime/globals.js +2 -2
  61. package/dist-cjs/serialization/crdt/authoritativePutComponent.d.ts +15 -0
  62. package/dist-cjs/serialization/crdt/authoritativePutComponent.js +50 -0
  63. package/dist-cjs/serialization/crdt/index.d.ts +1 -0
  64. package/dist-cjs/serialization/crdt/index.js +1 -0
  65. package/dist-cjs/serialization/crdt/types.d.ts +25 -3
  66. package/dist-cjs/serialization/crdt/types.js +3 -1
  67. package/dist-cjs/systems/crdt/index.d.ts +0 -1
  68. package/dist-cjs/systems/crdt/index.js +55 -169
  69. package/package.json +2 -2
  70. package/dist/components/generated/PhysicsCombinedForce.gen.d.ts +0 -1
  71. package/dist/components/generated/PhysicsCombinedForce.gen.js +0 -25
  72. package/dist/components/generated/PhysicsCombinedImpulse.gen.d.ts +0 -1
  73. package/dist/components/generated/PhysicsCombinedImpulse.gen.js +0 -25
  74. package/dist/components/generated/pb/decentraland/sdk/components/physics_combined_force.gen.d.ts +0 -25
  75. package/dist/components/generated/pb/decentraland/sdk/components/physics_combined_force.gen.js +0 -42
  76. package/dist/components/generated/pb/decentraland/sdk/components/physics_combined_impulse.gen.d.ts +0 -28
  77. package/dist/components/generated/pb/decentraland/sdk/components/physics_combined_impulse.gen.js +0 -51
  78. package/dist/serialization/crdt/network/utils.d.ts +0 -9
  79. package/dist/serialization/crdt/network/utils.js +0 -60
  80. package/dist-cjs/components/generated/PhysicsCombinedForce.gen.d.ts +0 -1
  81. package/dist-cjs/components/generated/PhysicsCombinedForce.gen.js +0 -28
  82. package/dist-cjs/components/generated/PhysicsCombinedImpulse.gen.d.ts +0 -1
  83. package/dist-cjs/components/generated/PhysicsCombinedImpulse.gen.js +0 -28
  84. package/dist-cjs/components/generated/pb/decentraland/sdk/components/physics_combined_force.gen.d.ts +0 -25
  85. package/dist-cjs/components/generated/pb/decentraland/sdk/components/physics_combined_force.gen.js +0 -48
  86. package/dist-cjs/components/generated/pb/decentraland/sdk/components/physics_combined_impulse.gen.d.ts +0 -28
  87. package/dist-cjs/components/generated/pb/decentraland/sdk/components/physics_combined_impulse.gen.js +0 -57
  88. package/dist-cjs/serialization/crdt/network/utils.d.ts +0 -9
  89. package/dist-cjs/serialization/crdt/network/utils.js +0 -67
@@ -55,8 +55,6 @@ function createBasePBInputModifier_StandardInput() {
55
55
  disableRun: undefined,
56
56
  disableJump: undefined,
57
57
  disableEmote: undefined,
58
- disableDoubleJump: undefined,
59
- disableGliding: undefined,
60
58
  };
61
59
  }
62
60
  /**
@@ -83,12 +81,6 @@ var PBInputModifier_StandardInput;
83
81
  if (message.disableEmote !== undefined) {
84
82
  writer.uint32(48).bool(message.disableEmote);
85
83
  }
86
- if (message.disableDoubleJump !== undefined) {
87
- writer.uint32(56).bool(message.disableDoubleJump);
88
- }
89
- if (message.disableGliding !== undefined) {
90
- writer.uint32(64).bool(message.disableGliding);
91
- }
92
84
  return writer;
93
85
  }
94
86
  PBInputModifier_StandardInput.encode = encode;
@@ -135,18 +127,6 @@ var PBInputModifier_StandardInput;
135
127
  }
136
128
  message.disableEmote = reader.bool();
137
129
  continue;
138
- case 7:
139
- if (tag !== 56) {
140
- break;
141
- }
142
- message.disableDoubleJump = reader.bool();
143
- continue;
144
- case 8:
145
- if (tag !== 64) {
146
- break;
147
- }
148
- message.disableGliding = reader.bool();
149
- continue;
150
130
  }
151
131
  if ((tag & 7) === 4 || tag === 0) {
152
132
  break;
@@ -77,9 +77,6 @@ export interface PBTween {
77
77
  } | {
78
78
  $case: "textureMoveContinuous";
79
79
  textureMoveContinuous: TextureMoveContinuous;
80
- } | {
81
- $case: "moveRotateScale";
82
- moveRotateScale: MoveRotateScale;
83
80
  } | undefined;
84
81
  /** default true (pause or running) */
85
82
  playing?: boolean | undefined;
@@ -108,17 +105,6 @@ export interface Scale {
108
105
  start: Vector3 | undefined;
109
106
  end: Vector3 | undefined;
110
107
  }
111
- /**
112
- * @public
113
- */
114
- export interface MoveRotateScale {
115
- positionStart: Vector3 | undefined;
116
- positionEnd: Vector3 | undefined;
117
- rotationStart: Quaternion | undefined;
118
- rotationEnd: Quaternion | undefined;
119
- scaleStart: Vector3 | undefined;
120
- scaleEnd: Vector3 | undefined;
121
- }
122
108
  /**
123
109
  * This tween mode allows to move the texture of a PbrMaterial or UnlitMaterial.
124
110
  * You can also specify the movement type (offset or tiling)
@@ -183,13 +169,6 @@ export declare namespace Scale {
183
169
  function encode(message: Scale, writer?: _m0.Writer): _m0.Writer;
184
170
  function decode(input: _m0.Reader | Uint8Array, length?: number): Scale;
185
171
  }
186
- /**
187
- * @public
188
- */
189
- export declare namespace MoveRotateScale {
190
- function encode(message: MoveRotateScale, writer?: _m0.Writer): _m0.Writer;
191
- function decode(input: _m0.Reader | Uint8Array, length?: number): MoveRotateScale;
192
- }
193
172
  /**
194
173
  * @public
195
174
  */
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.TextureMoveContinuous = exports.MoveContinuous = exports.RotateContinuous = exports.TextureMove = exports.MoveRotateScale = exports.Scale = exports.Rotate = exports.Move = exports.PBTween = exports.EasingFunction = exports.TextureMovementType = void 0;
6
+ exports.TextureMoveContinuous = exports.MoveContinuous = exports.RotateContinuous = exports.TextureMove = exports.Scale = exports.Rotate = exports.Move = exports.PBTween = exports.EasingFunction = exports.TextureMovementType = void 0;
7
7
  /* eslint-disable */
8
8
  const minimal_1 = __importDefault(require("protobufjs/minimal"));
9
9
  const vectors_gen_1 = require("../../common/vectors.gen");
@@ -96,9 +96,6 @@ var PBTween;
96
96
  case "textureMoveContinuous":
97
97
  TextureMoveContinuous.encode(message.mode.textureMoveContinuous, writer.uint32(90).fork()).ldelim();
98
98
  break;
99
- case "moveRotateScale":
100
- MoveRotateScale.encode(message.mode.moveRotateScale, writer.uint32(98).fork()).ldelim();
101
- break;
102
99
  }
103
100
  if (message.playing !== undefined) {
104
101
  writer.uint32(48).bool(message.playing);
@@ -176,12 +173,6 @@ var PBTween;
176
173
  textureMoveContinuous: TextureMoveContinuous.decode(reader, reader.uint32()),
177
174
  };
178
175
  continue;
179
- case 12:
180
- if (tag !== 98) {
181
- break;
182
- }
183
- message.mode = { $case: "moveRotateScale", moveRotateScale: MoveRotateScale.decode(reader, reader.uint32()) };
184
- continue;
185
176
  case 6:
186
177
  if (tag !== 48) {
187
178
  break;
@@ -354,96 +345,6 @@ var Scale;
354
345
  }
355
346
  Scale.decode = decode;
356
347
  })(Scale = exports.Scale || (exports.Scale = {}));
357
- function createBaseMoveRotateScale() {
358
- return {
359
- positionStart: undefined,
360
- positionEnd: undefined,
361
- rotationStart: undefined,
362
- rotationEnd: undefined,
363
- scaleStart: undefined,
364
- scaleEnd: undefined,
365
- };
366
- }
367
- /**
368
- * @public
369
- */
370
- var MoveRotateScale;
371
- (function (MoveRotateScale) {
372
- function encode(message, writer = minimal_1.default.Writer.create()) {
373
- if (message.positionStart !== undefined) {
374
- vectors_gen_1.Vector3.encode(message.positionStart, writer.uint32(10).fork()).ldelim();
375
- }
376
- if (message.positionEnd !== undefined) {
377
- vectors_gen_1.Vector3.encode(message.positionEnd, writer.uint32(18).fork()).ldelim();
378
- }
379
- if (message.rotationStart !== undefined) {
380
- vectors_gen_1.Quaternion.encode(message.rotationStart, writer.uint32(26).fork()).ldelim();
381
- }
382
- if (message.rotationEnd !== undefined) {
383
- vectors_gen_1.Quaternion.encode(message.rotationEnd, writer.uint32(34).fork()).ldelim();
384
- }
385
- if (message.scaleStart !== undefined) {
386
- vectors_gen_1.Vector3.encode(message.scaleStart, writer.uint32(42).fork()).ldelim();
387
- }
388
- if (message.scaleEnd !== undefined) {
389
- vectors_gen_1.Vector3.encode(message.scaleEnd, writer.uint32(50).fork()).ldelim();
390
- }
391
- return writer;
392
- }
393
- MoveRotateScale.encode = encode;
394
- function decode(input, length) {
395
- const reader = input instanceof minimal_1.default.Reader ? input : minimal_1.default.Reader.create(input);
396
- let end = length === undefined ? reader.len : reader.pos + length;
397
- const message = createBaseMoveRotateScale();
398
- while (reader.pos < end) {
399
- const tag = reader.uint32();
400
- switch (tag >>> 3) {
401
- case 1:
402
- if (tag !== 10) {
403
- break;
404
- }
405
- message.positionStart = vectors_gen_1.Vector3.decode(reader, reader.uint32());
406
- continue;
407
- case 2:
408
- if (tag !== 18) {
409
- break;
410
- }
411
- message.positionEnd = vectors_gen_1.Vector3.decode(reader, reader.uint32());
412
- continue;
413
- case 3:
414
- if (tag !== 26) {
415
- break;
416
- }
417
- message.rotationStart = vectors_gen_1.Quaternion.decode(reader, reader.uint32());
418
- continue;
419
- case 4:
420
- if (tag !== 34) {
421
- break;
422
- }
423
- message.rotationEnd = vectors_gen_1.Quaternion.decode(reader, reader.uint32());
424
- continue;
425
- case 5:
426
- if (tag !== 42) {
427
- break;
428
- }
429
- message.scaleStart = vectors_gen_1.Vector3.decode(reader, reader.uint32());
430
- continue;
431
- case 6:
432
- if (tag !== 50) {
433
- break;
434
- }
435
- message.scaleEnd = vectors_gen_1.Vector3.decode(reader, reader.uint32());
436
- continue;
437
- }
438
- if ((tag & 7) === 4 || tag === 0) {
439
- break;
440
- }
441
- reader.skipType(tag & 7);
442
- }
443
- return message;
444
- }
445
- MoveRotateScale.decode = decode;
446
- })(MoveRotateScale = exports.MoveRotateScale || (exports.MoveRotateScale = {}));
447
348
  function createBaseTextureMove() {
448
349
  return { start: undefined, end: undefined, movementType: undefined };
449
350
  }
@@ -19,6 +19,7 @@ import { InputModifierComponentDefinitionExtended } from './extended/InputModifi
19
19
  import { LightSourceComponentDefinitionExtended } from './extended/LightSource';
20
20
  import { TriggerAreaComponentDefinitionExtended } from './extended/TriggerArea';
21
21
  import { TagsComponentDefinitionExtended } from './manual/Tags';
22
+ import { ICreatedByType } from './manual/CreatedBy';
22
23
  export * from './generated/index.gen';
23
24
  export type { GrowOnlyValueSetComponentDefinition, LastWriteWinElementSetComponentDefinition, LwwComponentGetter, GSetComponentGetter };
24
25
  export declare const Transform: LwwComponentGetter<TransformComponentExtended>;
@@ -50,4 +51,8 @@ export declare const NetworkEntity: (engine: Pick<IEngine, 'defineComponent'>) =
50
51
  * @alpha
51
52
  */
52
53
  export declare const NetworkParent: (engine: Pick<IEngine, 'defineComponent'>) => LastWriteWinElementSetComponentDefinition<INetowrkParentType>;
54
+ /**
55
+ * @public
56
+ */
57
+ export declare const CreatedBy: (engine: Pick<IEngine, 'defineComponent'>) => LastWriteWinElementSetComponentDefinition<ICreatedByType>;
53
58
  export { MediaState };
@@ -17,7 +17,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
17
17
  return (mod && mod.__esModule) ? mod : { "default": mod };
18
18
  };
19
19
  Object.defineProperty(exports, "__esModule", { value: true });
20
- exports.MediaState = exports.NetworkParent = exports.NetworkEntity = exports.SyncComponents = exports.Tags = exports.Name = exports.TriggerArea = exports.LightSource = exports.InputModifier = exports.VirtualCamera = exports.Tween = exports.MeshCollider = exports.MeshRenderer = exports.AudioStream = exports.AudioSource = exports.Animator = exports.Material = exports.Transform = void 0;
20
+ exports.MediaState = exports.CreatedBy = exports.NetworkParent = exports.NetworkEntity = exports.SyncComponents = exports.Tags = exports.Name = exports.TriggerArea = exports.LightSource = exports.InputModifier = exports.VirtualCamera = exports.Tween = exports.MeshCollider = exports.MeshRenderer = exports.AudioStream = exports.AudioSource = exports.Animator = exports.Material = exports.Transform = void 0;
21
21
  const Animator_1 = require("./extended/Animator");
22
22
  const AudioSource_1 = require("./extended/AudioSource");
23
23
  const Material_1 = require("./extended/Material");
@@ -37,6 +37,7 @@ const InputModifier_1 = require("./extended/InputModifier");
37
37
  const LightSource_1 = require("./extended/LightSource");
38
38
  const TriggerArea_1 = require("./extended/TriggerArea");
39
39
  const Tags_1 = __importDefault(require("./manual/Tags"));
40
+ const CreatedBy_1 = __importDefault(require("./manual/CreatedBy"));
40
41
  __exportStar(require("./generated/index.gen"), exports);
41
42
  /* @__PURE__ */
42
43
  const Transform = (engine) => (0, Transform_1.defineTransformComponent)(engine);
@@ -92,12 +93,15 @@ exports.SyncComponents = SyncComponents;
92
93
  /**
93
94
  * @alpha
94
95
  */
95
- /* @__PURE__ */
96
96
  const NetworkEntity = (engine) => (0, NetworkEntity_1.default)(engine);
97
97
  exports.NetworkEntity = NetworkEntity;
98
98
  /**
99
99
  * @alpha
100
100
  */
101
- /* @__PURE__ */
102
101
  const NetworkParent = (engine) => (0, NetworkParent_1.default)(engine);
103
102
  exports.NetworkParent = NetworkParent;
103
+ /**
104
+ * @public
105
+ */
106
+ const CreatedBy = (engine) => (0, CreatedBy_1.default)(engine);
107
+ exports.CreatedBy = CreatedBy;
@@ -0,0 +1,9 @@
1
+ import { IEngine, LastWriteWinElementSetComponentDefinition } from '../../engine/types';
2
+ export interface ICreatedByType {
3
+ address: string;
4
+ }
5
+ export type ICreatedBy = LastWriteWinElementSetComponentDefinition<ICreatedByType>;
6
+ declare function defineCreatedBy(engine: Pick<IEngine, 'defineComponent'>): import("../../engine/types").MapComponentDefinition<import("../..").MapResult<{
7
+ address: import("../../schemas").ISchema<string>;
8
+ }>>;
9
+ export default defineCreatedBy;
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const schemas_1 = require("../../schemas");
4
+ function defineCreatedBy(engine) {
5
+ const CreatedBy = engine.defineComponent('core-schema::Created-By', {
6
+ address: schemas_1.Schemas.String
7
+ });
8
+ return CreatedBy;
9
+ }
10
+ exports.default = defineCreatedBy;
@@ -1,5 +1,6 @@
1
1
  import { LastWriteWinElementSetComponentDefinition, IEngine } from '../../engine';
2
2
  import { Entity } from '../../engine/entity';
3
+ import type { ISchema } from '../../schemas/ISchema';
3
4
  /**
4
5
  * @public
5
6
  */
@@ -11,6 +12,10 @@ export interface TransformComponentExtended extends TransformComponent {
11
12
  create(entity: Entity, val?: TransformTypeWithOptionals): TransformType;
12
13
  createOrReplace(entity: Entity, val?: TransformTypeWithOptionals): TransformType;
13
14
  }
15
+ /**
16
+ * @public
17
+ */
18
+ export declare const COMPONENT_ID = 1;
14
19
  /**
15
20
  * @public
16
21
  */
@@ -33,6 +38,10 @@ export type TransformType = {
33
38
  };
34
39
  parent?: Entity;
35
40
  };
41
+ /** @public */
42
+ export declare const TRANSFORM_LENGTH = 44;
43
+ /** @public */
44
+ export declare const TransformSchema: ISchema<TransformType>;
36
45
  /**
37
46
  * @public
38
47
  */
@@ -2,12 +2,12 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.defineTransformComponent = exports.TransformSchema = exports.TRANSFORM_LENGTH = exports.COMPONENT_ID = void 0;
4
4
  /**
5
- * @internal
5
+ * @public
6
6
  */
7
7
  exports.COMPONENT_ID = 1;
8
- /** @internal */
8
+ /** @public */
9
9
  exports.TRANSFORM_LENGTH = 44;
10
- /** @internal */
10
+ /** @public */
11
11
  exports.TransformSchema = {
12
12
  serialize(value, builder) {
13
13
  const ptr = builder.incrementWriteOffset(exports.TRANSFORM_LENGTH);
@@ -4,7 +4,7 @@ export type { AudioStreamComponentDefinitionExtended } from './extended/AudioStr
4
4
  export type { MeshRendererComponentDefinitionExtended } from './extended/MeshRenderer';
5
5
  export type { MeshColliderComponentDefinitionExtended } from './extended/MeshCollider';
6
6
  export type { TextureHelper, MaterialComponentDefinitionExtended, FlatTexture, ReadonlyFlatMaterial, ReadonlyFlatTexture, FlatMaterial } from './extended/Material';
7
- export type { TweenHelper, TweenComponentDefinitionExtended, SetMoveRotateScaleParams, MoveRotateScaleModeParams } from './extended/Tween';
7
+ export type { TweenHelper, TweenComponentDefinitionExtended } from './extended/Tween';
8
8
  export type { CameraTransitionHelper, VirtualCameraComponentDefinitionExtended } from './extended/VirtualCamera';
9
9
  export type { TransformComponentExtended, TransformTypeWithOptionals } from './manual/Transform';
10
10
  export type { NameComponent, NameType } from './manual/Name';
@@ -12,6 +12,7 @@ export type { TagsComponentDefinitionExtended, TagsType } from './manual/Tags';
12
12
  export type { ISyncComponents, ISyncComponentsType } from './manual/SyncComponents';
13
13
  export type { INetowrkEntity, INetowrkEntityType } from './manual/NetworkEntity';
14
14
  export type { INetowrkParent, INetowrkParentType } from './manual/NetworkParent';
15
+ export type { ICreatedBy, ICreatedByType } from './manual/CreatedBy';
15
16
  export type { InputModifierHelper, InputModifierComponentDefinitionExtended } from './extended/InputModifier';
16
17
  export type { LightSourceHelper, LightSourceComponentDefinitionExtended } from './extended/LightSource';
17
18
  export type { TriggerAreaComponentDefinitionExtended } from './extended/TriggerArea';
@@ -1,6 +1,6 @@
1
1
  import { ISchema } from '../schemas';
2
2
  import { ByteBuffer } from '../serialization/ByteBuffer';
3
- import { CrdtMessageBody, DeleteComponentMessageBody, PutComponentMessageBody } from '../serialization/crdt';
3
+ import { CrdtMessageBody, DeleteComponentMessageBody, ProcessMessageResultType, PutComponentMessageBody } from '../serialization/crdt';
4
4
  import { Entity } from './entity';
5
5
  import { DeepReadonly, DeepReadonlySet } from './readonly';
6
6
  /**
@@ -70,7 +70,58 @@ export interface BaseComponent<T> {
70
70
  * If the value is undefined, the component was deleted.
71
71
  */
72
72
  onChange(entity: Entity, cb: (value: T | undefined) => void): void;
73
+ /**
74
+ * @public
75
+ *
76
+ */
77
+ validateBeforeChange(entity: Entity, cb: ValidateCallback<T>): void;
78
+ validateBeforeChange(cb: ValidateCallback<T>): void;
79
+ /**
80
+ * Get the CRDT state for an entity (serialized data and timestamp)
81
+ * @param entity - Entity to get the CRDT state for
82
+ * @returns Object with serialized data and timestamp, or null if entity doesn't have the component
83
+ * @public
84
+ */
85
+ getCrdtState(entity: Entity): {
86
+ data: Uint8Array;
87
+ timestamp: number;
88
+ } | null;
89
+ }
90
+ /**
91
+ * Internal component interface that exposes all internal methods for SDK use
92
+ * This is not exposed to users, only for internal SDK operations
93
+ */
94
+ export interface InternalBaseComponent<T> extends BaseComponent<T> {
95
+ /**
96
+ * @public
97
+ * Dry run update to check if a CRDT message would be accepted without actually applying it
98
+ */
99
+ __dry_run_updateFromCrdt(body: CrdtMessageBody): ProcessMessageResultType;
100
+ /**
101
+ * @public
102
+ * Get the iterator to every entity has the component
103
+ */
104
+ iterator(): Iterable<[Entity, any]>;
105
+ /**
106
+ * @public
107
+ */
108
+ dirtyIterator(): Iterable<Entity>;
109
+ /**
110
+ * @public
111
+ */
112
+ __onChangeCallbacks(entity: Entity, value: T): void;
113
+ /**
114
+ * @public
115
+ */
116
+ __run_validateBeforeChange(entity: Entity, newValue: T | undefined, senderAddress: string, createdBy: string): boolean;
73
117
  }
118
+ export type ValidateCallback<T> = (value: {
119
+ entity: Entity;
120
+ currentValue: T | undefined;
121
+ newValue: T | undefined;
122
+ senderAddress: string;
123
+ createdBy: string;
124
+ }) => boolean;
74
125
  /**
75
126
  * @public
76
127
  */
@@ -5,6 +5,7 @@ const ByteBuffer_1 = require("../serialization/ByteBuffer");
5
5
  const crdt_1 = require("../serialization/crdt");
6
6
  const invariant_1 = require("../runtime/invariant");
7
7
  const emptyReadonlySet = freezeSet(new Set());
8
+ const __GLOBAL_ENTITY = '__GLOBAL_ENTITY';
8
9
  function frozenError() {
9
10
  throw new Error('The set is frozen');
10
11
  }
@@ -25,6 +26,7 @@ function createValueSetComponentDefinitionFromSchema(componentName, componentId,
25
26
  const dirtyIterator = new Set();
26
27
  const queuedCommands = [];
27
28
  const onChangeCallbacks = new Map();
29
+ const validateCallbacks = new Map();
28
30
  // only sort the array if the latest (N) element has a timestamp <= N-1
29
31
  function shouldSort(row) {
30
32
  const len = row.raw.length;
@@ -83,8 +85,11 @@ function createValueSetComponentDefinitionFromSchema(componentName, componentId,
83
85
  has(entity) {
84
86
  return data.has(entity);
85
87
  },
86
- entityDeleted(entity) {
88
+ entityDeleted(entity, markAsDirty) {
87
89
  data.delete(entity);
90
+ if (markAsDirty) {
91
+ // For grow-only sets, we don't need to mark as dirty since deletion doesn't generate CRDT messages
92
+ }
88
93
  },
89
94
  get(entity) {
90
95
  const values = data.get(entity);
@@ -155,6 +160,44 @@ function createValueSetComponentDefinitionFromSchema(componentName, componentId,
155
160
  for (const cb of cbs) {
156
161
  cb(value);
157
162
  }
163
+ },
164
+ __dry_run_updateFromCrdt(_body) {
165
+ return crdt_1.ProcessMessageResultType.StateUpdatedData;
166
+ },
167
+ validateBeforeChange(entityOrCb, cb) {
168
+ if (arguments.length === 1) {
169
+ // Second overload: just callback (global validation)
170
+ validateCallbacks.set(__GLOBAL_ENTITY, entityOrCb);
171
+ }
172
+ else {
173
+ if (cb) {
174
+ validateCallbacks.set(entityOrCb, cb);
175
+ }
176
+ }
177
+ },
178
+ __run_validateBeforeChange(entity, newValue, senderAddress, createdBy) {
179
+ const cb = entity && validateCallbacks.get(entity);
180
+ const globalCb = validateCallbacks.get(__GLOBAL_ENTITY);
181
+ const currentValue = [...this.get(entity).values()];
182
+ const value = { entity, currentValue: currentValue, newValue, senderAddress, createdBy };
183
+ const globalResult = globalCb?.(value) ?? true;
184
+ const entityResult = (globalResult && cb?.(value)) ?? true;
185
+ return globalResult && entityResult;
186
+ },
187
+ getCrdtState(entity) {
188
+ const row = data.get(entity);
189
+ if (!row || row.raw.length === 0) {
190
+ return null;
191
+ }
192
+ // For GrowOnlySet, we need to return the complete CRDT messages for all values
193
+ // This is complex because GrowOnlySet uses APPEND messages, not a single PUT
194
+ // For now, return null to indicate this component type doesn't support simple corrections
195
+ return null;
196
+ },
197
+ __forceUpdateFromCrdt(_msg) {
198
+ // GrowOnlySet doesn't support authoritative corrections in the same way as LWW
199
+ // since it uses APPEND_VALUE messages instead of PUT_COMPONENT messages
200
+ return [null, undefined];
158
201
  }
159
202
  };
160
203
  return ret;
@@ -1,8 +1,10 @@
1
1
  import { ISchema } from '../schemas';
2
2
  import { ByteBuffer } from '../serialization/ByteBuffer';
3
- import { PutComponentMessageBody, DeleteComponentMessageBody, CrdtMessageBody } from '../serialization/crdt';
3
+ import { PutComponentMessageBody, DeleteComponentMessageBody, ProcessMessageResultType, CrdtMessageBody, PutNetworkComponentMessageBody, DeleteComponentNetworkMessageBody, AuthoritativePutComponentMessageBody } from '../serialization/crdt';
4
4
  import { Entity } from './entity';
5
5
  export declare function incrementTimestamp(entity: Entity, timestamps: Map<Entity, number>): number;
6
6
  export declare function createDumpLwwFunctionFromCrdt(componentId: number, timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>): (buffer: ByteBuffer, filterEntity?: ((entity: Entity) => boolean) | undefined) => void;
7
+ export declare function createCrdtRuleValidator(timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>): (message: PutComponentMessageBody | DeleteComponentMessageBody | PutNetworkComponentMessageBody | DeleteComponentNetworkMessageBody) => ProcessMessageResultType;
8
+ export declare function createForceUpdateLwwFromCrdt(componentId: number, timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>): (msg: AuthoritativePutComponentMessageBody) => [null, any];
7
9
  export declare function createUpdateLwwFromCrdt(componentId: number, timestamps: Map<Entity, number>, schema: Pick<ISchema<any>, 'serialize' | 'deserialize'>, data: Map<Entity, unknown>): (msg: CrdtMessageBody) => [null | PutComponentMessageBody | DeleteComponentMessageBody, any];
8
10
  export declare function createGetCrdtMessagesForLww(componentId: number, timestamps: Map<Entity, number>, dirtyIterator: Set<Entity>, schema: Pick<ISchema<any>, 'serialize'>, data: Map<Entity, unknown>): () => Generator<PutComponentMessageBody | DeleteComponentMessageBody, void, unknown>;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createComponentDefinitionFromSchema = exports.createGetCrdtMessagesForLww = exports.createUpdateLwwFromCrdt = exports.createDumpLwwFunctionFromCrdt = exports.incrementTimestamp = void 0;
3
+ exports.createComponentDefinitionFromSchema = exports.createGetCrdtMessagesForLww = exports.createUpdateLwwFromCrdt = exports.createForceUpdateLwwFromCrdt = exports.createCrdtRuleValidator = exports.createDumpLwwFunctionFromCrdt = exports.incrementTimestamp = void 0;
4
4
  const ByteBuffer_1 = require("../serialization/ByteBuffer");
5
5
  const crdt_1 = require("../serialization/crdt");
6
6
  const utils_1 = require("../systems/crdt/utils");
@@ -35,16 +35,12 @@ function createDumpLwwFunctionFromCrdt(componentId, timestamps, schema, data) {
35
35
  };
36
36
  }
37
37
  exports.createDumpLwwFunctionFromCrdt = createDumpLwwFunctionFromCrdt;
38
- function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
38
+ const __GLOBAL_ENTITY = '__GLOBAL_ENTITY';
39
+ function createCrdtRuleValidator(timestamps, schema, data) {
39
40
  /**
40
- * Process the received message only if the lamport number recieved is higher
41
- * than the stored one. If its lower, we spread it to the network to correct the peer.
42
- * If they are equal, the bigger raw data wins.
43
-
44
- * Returns the recieved data if the lamport number was bigger than ours.
45
- * If it was an outdated message, then we return void
46
- * @public
47
- */
41
+ * Shared CRDT conflict resolution logic
42
+ * @public
43
+ */
48
44
  function crdtRuleForCurrentState(message) {
49
45
  const { entityId, timestamp } = message;
50
46
  const currentTimestamp = timestamps.get(entityId);
@@ -54,7 +50,6 @@ function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
54
50
  }
55
51
  // Outdated Message. Resend our state message through the wire.
56
52
  if (currentTimestamp > timestamp) {
57
- // console.log('2', currentTimestamp, timestamp)
58
53
  return crdt_1.ProcessMessageResultType.StateOutdatedTimestamp;
59
54
  }
60
55
  // Deletes are idempotent
@@ -71,7 +66,6 @@ function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
71
66
  currentDataGreater = (0, utils_1.dataCompare)(null, message.data);
72
67
  }
73
68
  // Same data, same timestamp. Weirdo echo message.
74
- // console.log('3', currentDataGreater, writeBuffer.toBinary(), (message as any).data || null)
75
69
  if (currentDataGreater === 0) {
76
70
  return crdt_1.ProcessMessageResultType.NoChanges;
77
71
  }
@@ -80,10 +74,37 @@ function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
80
74
  return crdt_1.ProcessMessageResultType.StateOutdatedData;
81
75
  }
82
76
  else {
83
- // Curent data is lower
77
+ // Current data is lower
84
78
  return crdt_1.ProcessMessageResultType.StateUpdatedData;
85
79
  }
86
80
  }
81
+ return crdtRuleForCurrentState;
82
+ }
83
+ exports.createCrdtRuleValidator = createCrdtRuleValidator;
84
+ function createForceUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
85
+ /**
86
+ * Force update component state regardless of timestamp - used for server authoritative messages
87
+ */
88
+ return (msg) => {
89
+ const buffer = new ByteBuffer_1.ReadWriteByteBuffer(msg.data);
90
+ const deserializedValue = schema.deserialize(buffer);
91
+ data.set(msg.entityId, deserializedValue);
92
+ timestamps.set(msg.entityId, msg.timestamp);
93
+ return [null, deserializedValue];
94
+ };
95
+ }
96
+ exports.createForceUpdateLwwFromCrdt = createForceUpdateLwwFromCrdt;
97
+ function createUpdateLwwFromCrdt(componentId, timestamps, schema, data) {
98
+ /**
99
+ * Process the received message only if the lamport number recieved is higher
100
+ * than the stored one. If its lower, we spread it to the network to correct the peer.
101
+ * If they are equal, the bigger raw data wins.
102
+
103
+ * Returns the recieved data if the lamport number was bigger than ours.
104
+ * If it was an outdated message, then we return void
105
+ * @public
106
+ */
107
+ const crdtRuleForCurrentState = createCrdtRuleValidator(timestamps, schema, data);
87
108
  return (msg) => {
88
109
  /* istanbul ignore next */
89
110
  if (msg.type !== crdt_1.CrdtMessageType.PUT_COMPONENT &&
@@ -178,6 +199,7 @@ function createComponentDefinitionFromSchema(componentName, componentId, schema)
178
199
  const dirtyIterator = new Set();
179
200
  const timestamps = new Map();
180
201
  const onChangeCallbacks = new Map();
202
+ const validateCallbacks = new Map();
181
203
  return {
182
204
  get componentId() {
183
205
  return componentId;
@@ -269,7 +291,39 @@ function createComponentDefinitionFromSchema(componentName, componentId, schema)
269
291
  },
270
292
  getCrdtUpdates: createGetCrdtMessagesForLww(componentId, timestamps, dirtyIterator, schema, data),
271
293
  updateFromCrdt: createUpdateLwwFromCrdt(componentId, timestamps, schema, data),
294
+ __forceUpdateFromCrdt: createForceUpdateLwwFromCrdt(componentId, timestamps, schema, data),
295
+ __dry_run_updateFromCrdt: createCrdtRuleValidator(timestamps, schema, data),
272
296
  dumpCrdtStateToBuffer: createDumpLwwFunctionFromCrdt(componentId, timestamps, schema, data),
297
+ validateBeforeChange(entityOrCb, cb) {
298
+ if (arguments.length === 1) {
299
+ // Second overload: just callback (global validation)
300
+ validateCallbacks.set(__GLOBAL_ENTITY, entityOrCb);
301
+ }
302
+ else {
303
+ if (cb) {
304
+ validateCallbacks.set(entityOrCb, cb);
305
+ }
306
+ }
307
+ },
308
+ __run_validateBeforeChange(entity, newValue, senderAddress, createdBy) {
309
+ const cb = entity && validateCallbacks.get(entity);
310
+ const globalCb = validateCallbacks.get(__GLOBAL_ENTITY);
311
+ const currentValue = data.get(entity);
312
+ const value = { entity, currentValue, newValue, senderAddress, createdBy };
313
+ const globalResult = globalCb?.(value) ?? true;
314
+ const entityResult = (globalResult && cb?.(value)) ?? true;
315
+ return globalResult && entityResult;
316
+ },
317
+ getCrdtState(entity) {
318
+ const componentData = data.get(entity);
319
+ const timestamp = timestamps.get(entity);
320
+ if (componentData && timestamp !== undefined) {
321
+ const buffer = new ByteBuffer_1.ReadWriteByteBuffer();
322
+ schema.serialize((0, readonly_1.deepReadonly)(componentData), buffer);
323
+ return { data: buffer.toBinary(), timestamp };
324
+ }
325
+ return null;
326
+ },
273
327
  onChange(entity, cb) {
274
328
  const cbs = onChangeCallbacks.get(entity) ?? [];
275
329
  cbs.push(cb);
@@ -1,6 +1,5 @@
1
1
  export * from './engine';
2
2
  export * from './schemas';
3
- export * from './runtime/globals';
4
3
  export * from './runtime/initialization';
5
4
  export * from './runtime/types';
6
5
  export * from './runtime/helpers';
@@ -14,7 +13,7 @@ export * from './systems/tween';
14
13
  export * from './systems/triggerArea';
15
14
  export * from './engine/entity';
16
15
  export * from './components/types';
17
- import { MaterialComponentDefinitionExtended, MeshColliderComponentDefinitionExtended, MeshRendererComponentDefinitionExtended, TransformComponentExtended, AnimatorComponentDefinitionExtended, AudioSourceComponentDefinitionExtended, AudioStreamComponentDefinitionExtended, ISyncComponents, TweenComponentDefinitionExtended, INetowrkEntity, INetowrkParent, VirtualCameraComponentDefinitionExtended, InputModifierComponentDefinitionExtended, LightSourceComponentDefinitionExtended, TriggerAreaComponentDefinitionExtended } from './components/types';
16
+ import { MaterialComponentDefinitionExtended, MeshColliderComponentDefinitionExtended, MeshRendererComponentDefinitionExtended, TransformComponentExtended, AnimatorComponentDefinitionExtended, AudioSourceComponentDefinitionExtended, AudioStreamComponentDefinitionExtended, ISyncComponents, TweenComponentDefinitionExtended, INetowrkEntity, INetowrkParent, VirtualCameraComponentDefinitionExtended, InputModifierComponentDefinitionExtended, LightSourceComponentDefinitionExtended, TriggerAreaComponentDefinitionExtended, ICreatedBy } from './components/types';
18
17
  import { NameComponent } from './components/manual/Name';
19
18
  import { TagsComponentDefinitionExtended } from './components/manual/Tags';
20
19
  export declare const Transform: TransformComponentExtended;
@@ -47,6 +46,7 @@ export declare const NetworkEntity: INetowrkEntity;
47
46
  * Tag a entity to be syncronized through comms
48
47
  */
49
48
  export declare const NetworkParent: INetowrkParent;
49
+ export declare const CreatedBy: ICreatedBy;
50
50
  export * from './components/generated/global.gen';
51
51
  export * from './components/generated/types.gen';
52
52
  export * from './serialization/crdt';