@dcl/ecs 7.21.1-22917715332.commit-e5d969d → 7.21.1-22918726402.commit-ee210ee

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 (256) hide show
  1. package/dist/components/extended/MeshCollider.d.ts +0 -8
  2. package/dist/components/extended/MeshCollider.js +0 -6
  3. package/dist/components/extended/MeshRenderer.d.ts +0 -8
  4. package/dist/components/extended/MeshRenderer.js +0 -5
  5. package/dist/components/extended/Tween.d.ts +48 -1
  6. package/dist/components/extended/Tween.js +66 -0
  7. package/dist/components/generated/PhysicsCombinedForce.gen.js +25 -0
  8. package/dist/components/generated/PhysicsCombinedImpulse.gen.js +25 -0
  9. package/dist/components/generated/component-names.gen.js +2 -11
  10. package/dist/components/generated/global.gen.d.ts +4 -22
  11. package/dist/components/generated/global.gen.js +2 -11
  12. package/dist/components/generated/index.gen.d.ts +8 -44
  13. package/dist/components/generated/index.gen.js +10 -55
  14. package/dist/components/generated/pb/decentraland/common/texture.gen.d.ts +0 -20
  15. package/dist/components/generated/pb/decentraland/common/texture.gen.js +0 -65
  16. package/dist/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.d.ts +0 -2
  17. package/dist/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.js +1 -10
  18. package/dist/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.d.ts +0 -43
  19. package/dist/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.js +1 -151
  20. package/dist/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.d.ts +0 -2
  21. package/dist/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.js +0 -10
  22. package/dist/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.d.ts +1 -37
  23. package/dist/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.js +1 -119
  24. package/dist/components/generated/pb/decentraland/sdk/components/common/input_action.gen.d.ts +2 -6
  25. package/dist/components/generated/pb/decentraland/sdk/components/common/input_action.gen.js +0 -4
  26. package/dist/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.d.ts +0 -19
  27. package/dist/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.js +1 -46
  28. package/dist/components/generated/pb/decentraland/sdk/components/input_modifier.gen.d.ts +2 -0
  29. package/dist/components/generated/pb/decentraland/sdk/components/input_modifier.gen.js +20 -0
  30. package/dist/components/generated/pb/decentraland/sdk/components/material.gen.d.ts +0 -22
  31. package/dist/components/generated/pb/decentraland/sdk/components/material.gen.js +1 -57
  32. package/dist/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.d.ts +0 -20
  33. package/dist/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.js +0 -56
  34. package/dist/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.d.ts +3 -21
  35. package/dist/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.js +0 -56
  36. package/dist/components/generated/pb/decentraland/sdk/components/physics_combined_force.gen.d.ts +25 -0
  37. package/dist/components/generated/pb/decentraland/sdk/components/{ui_scroll_result.gen.js → physics_combined_force.gen.js} +12 -12
  38. package/dist/components/generated/pb/decentraland/sdk/components/physics_combined_impulse.gen.d.ts +28 -0
  39. package/dist/components/generated/pb/decentraland/sdk/components/physics_combined_impulse.gen.js +51 -0
  40. package/dist/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.d.ts +2 -8
  41. package/dist/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.js +0 -3
  42. package/dist/components/generated/pb/decentraland/sdk/components/raycast.gen.d.ts +0 -13
  43. package/dist/components/generated/pb/decentraland/sdk/components/raycast.gen.js +0 -30
  44. package/dist/components/generated/pb/decentraland/sdk/components/tween.gen.d.ts +21 -0
  45. package/dist/components/generated/pb/decentraland/sdk/components/tween.gen.js +99 -0
  46. package/dist/components/generated/pb/decentraland/sdk/components/ui_text.gen.d.ts +0 -4
  47. package/dist/components/generated/pb/decentraland/sdk/components/ui_text.gen.js +0 -20
  48. package/dist/components/generated/pb/decentraland/sdk/components/ui_transform.gen.d.ts +0 -35
  49. package/dist/components/generated/pb/decentraland/sdk/components/ui_transform.gen.js +0 -90
  50. package/dist/components/index.d.ts +12 -11
  51. package/dist/components/index.js +10 -13
  52. package/dist/components/manual/CreatedBy.d.ts +9 -0
  53. package/dist/components/manual/CreatedBy.js +8 -0
  54. package/dist/components/manual/Transform.d.ts +9 -0
  55. package/dist/components/manual/Transform.js +3 -3
  56. package/dist/components/types.d.ts +2 -3
  57. package/dist/engine/component.d.ts +52 -1
  58. package/dist/engine/entity.js +4 -2
  59. package/dist/engine/grow-only-value-set-component-definition.js +46 -3
  60. package/dist/engine/input.d.ts +0 -6
  61. package/dist/engine/input.js +4 -9
  62. package/dist/engine/lww-element-set-component-definition.d.ts +3 -1
  63. package/dist/engine/lww-element-set-component-definition.js +64 -12
  64. package/dist/index.d.ts +3 -2
  65. package/dist/index.js +2 -1
  66. package/dist/runtime/globals.d.ts +1 -2
  67. package/dist/runtime/globals.js +1 -2
  68. package/dist/serialization/crdt/authoritativePutComponent.d.ts +15 -0
  69. package/dist/serialization/crdt/authoritativePutComponent.js +47 -0
  70. package/dist/serialization/crdt/index.d.ts +1 -0
  71. package/dist/serialization/crdt/index.js +1 -0
  72. package/dist/serialization/crdt/types.d.ts +25 -3
  73. package/dist/serialization/crdt/types.js +3 -1
  74. package/dist/systems/crdt/index.d.ts +0 -1
  75. package/dist/systems/crdt/index.js +55 -146
  76. package/dist/systems/events.d.ts +1 -100
  77. package/dist/systems/events.js +65 -143
  78. package/dist/systems/raycast.d.ts +1 -3
  79. package/dist/systems/raycast.js +0 -2
  80. package/dist-cjs/components/extended/MeshCollider.d.ts +0 -8
  81. package/dist-cjs/components/extended/MeshCollider.js +0 -6
  82. package/dist-cjs/components/extended/MeshRenderer.d.ts +0 -8
  83. package/dist-cjs/components/extended/MeshRenderer.js +0 -5
  84. package/dist-cjs/components/extended/Tween.d.ts +48 -1
  85. package/dist-cjs/components/extended/Tween.js +66 -0
  86. package/dist-cjs/components/generated/PhysicsCombinedForce.gen.js +28 -0
  87. package/dist-cjs/components/generated/PhysicsCombinedImpulse.gen.js +28 -0
  88. package/dist-cjs/components/generated/component-names.gen.js +2 -11
  89. package/dist-cjs/components/generated/global.gen.d.ts +4 -22
  90. package/dist-cjs/components/generated/global.gen.js +3 -13
  91. package/dist-cjs/components/generated/index.gen.d.ts +8 -44
  92. package/dist-cjs/components/generated/index.gen.js +14 -68
  93. package/dist-cjs/components/generated/pb/decentraland/common/texture.gen.d.ts +0 -20
  94. package/dist-cjs/components/generated/pb/decentraland/common/texture.gen.js +1 -66
  95. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.d.ts +0 -2
  96. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_equipped_data.gen.js +1 -10
  97. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.d.ts +0 -43
  98. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_modifier_area.gen.js +2 -152
  99. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.d.ts +0 -2
  100. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_shape.gen.js +0 -10
  101. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.d.ts +1 -37
  102. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_mode_area.gen.js +2 -120
  103. package/dist-cjs/components/generated/pb/decentraland/sdk/components/common/input_action.gen.d.ts +2 -6
  104. package/dist-cjs/components/generated/pb/decentraland/sdk/components/common/input_action.gen.js +0 -4
  105. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.d.ts +0 -19
  106. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_container_loading_state.gen.js +1 -46
  107. package/dist-cjs/components/generated/pb/decentraland/sdk/components/input_modifier.gen.d.ts +2 -0
  108. package/dist-cjs/components/generated/pb/decentraland/sdk/components/input_modifier.gen.js +20 -0
  109. package/dist-cjs/components/generated/pb/decentraland/sdk/components/material.gen.d.ts +0 -22
  110. package/dist-cjs/components/generated/pb/decentraland/sdk/components/material.gen.js +2 -58
  111. package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.d.ts +0 -20
  112. package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_collider.gen.js +1 -57
  113. package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.d.ts +3 -21
  114. package/dist-cjs/components/generated/pb/decentraland/sdk/components/mesh_renderer.gen.js +1 -57
  115. package/dist-cjs/components/generated/pb/decentraland/sdk/components/physics_combined_force.gen.d.ts +25 -0
  116. package/dist-cjs/components/generated/pb/decentraland/sdk/components/{ui_scroll_result.gen.js → physics_combined_force.gen.js} +12 -12
  117. package/dist-cjs/components/generated/pb/decentraland/sdk/components/physics_combined_impulse.gen.d.ts +28 -0
  118. package/dist-cjs/components/generated/pb/decentraland/sdk/components/{ui_canvas.gen.js → physics_combined_impulse.gen.js} +17 -26
  119. package/dist-cjs/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.d.ts +2 -8
  120. package/dist-cjs/components/generated/pb/decentraland/sdk/components/primary_pointer_info.gen.js +0 -3
  121. package/dist-cjs/components/generated/pb/decentraland/sdk/components/raycast.gen.d.ts +0 -13
  122. package/dist-cjs/components/generated/pb/decentraland/sdk/components/raycast.gen.js +1 -31
  123. package/dist-cjs/components/generated/pb/decentraland/sdk/components/tween.gen.d.ts +21 -0
  124. package/dist-cjs/components/generated/pb/decentraland/sdk/components/tween.gen.js +100 -1
  125. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_text.gen.d.ts +0 -4
  126. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_text.gen.js +0 -20
  127. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_transform.gen.d.ts +0 -35
  128. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_transform.gen.js +1 -91
  129. package/dist-cjs/components/index.d.ts +12 -11
  130. package/dist-cjs/components/index.js +13 -17
  131. package/dist-cjs/components/manual/CreatedBy.d.ts +9 -0
  132. package/dist-cjs/components/manual/CreatedBy.js +10 -0
  133. package/dist-cjs/components/manual/Transform.d.ts +9 -0
  134. package/dist-cjs/components/manual/Transform.js +3 -3
  135. package/dist-cjs/components/types.d.ts +2 -3
  136. package/dist-cjs/engine/component.d.ts +52 -1
  137. package/dist-cjs/engine/entity.js +4 -2
  138. package/dist-cjs/engine/grow-only-value-set-component-definition.js +45 -2
  139. package/dist-cjs/engine/input.d.ts +0 -6
  140. package/dist-cjs/engine/input.js +4 -9
  141. package/dist-cjs/engine/lww-element-set-component-definition.d.ts +3 -1
  142. package/dist-cjs/engine/lww-element-set-component-definition.js +67 -13
  143. package/dist-cjs/index.d.ts +3 -2
  144. package/dist-cjs/index.js +3 -2
  145. package/dist-cjs/runtime/globals.d.ts +1 -2
  146. package/dist-cjs/runtime/globals.js +1 -2
  147. package/dist-cjs/serialization/crdt/authoritativePutComponent.d.ts +15 -0
  148. package/dist-cjs/serialization/crdt/authoritativePutComponent.js +50 -0
  149. package/dist-cjs/serialization/crdt/index.d.ts +1 -0
  150. package/dist-cjs/serialization/crdt/index.js +1 -0
  151. package/dist-cjs/serialization/crdt/types.d.ts +25 -3
  152. package/dist-cjs/serialization/crdt/types.js +3 -1
  153. package/dist-cjs/systems/crdt/index.d.ts +0 -1
  154. package/dist-cjs/systems/crdt/index.js +55 -169
  155. package/dist-cjs/systems/events.d.ts +1 -100
  156. package/dist-cjs/systems/events.js +65 -143
  157. package/dist-cjs/systems/raycast.d.ts +1 -3
  158. package/dist-cjs/systems/raycast.js +0 -2
  159. package/package.json +2 -2
  160. package/dist/components/extended/AvatarEquippedData.d.ts +0 -10
  161. package/dist/components/extended/AvatarEquippedData.js +0 -15
  162. package/dist/components/extended/AvatarShape.d.ts +0 -10
  163. package/dist/components/extended/AvatarShape.js +0 -15
  164. package/dist/components/generated/AvatarLocomotionSettings.gen.d.ts +0 -1
  165. package/dist/components/generated/AvatarLocomotionSettings.gen.js +0 -25
  166. package/dist/components/generated/AvatarMovement.gen.d.ts +0 -1
  167. package/dist/components/generated/AvatarMovement.gen.js +0 -25
  168. package/dist/components/generated/AvatarMovementInfo.gen.d.ts +0 -1
  169. package/dist/components/generated/AvatarMovementInfo.gen.js +0 -25
  170. package/dist/components/generated/CameraLayer.gen.d.ts +0 -1
  171. package/dist/components/generated/CameraLayer.gen.js +0 -25
  172. package/dist/components/generated/CameraLayers.gen.d.ts +0 -1
  173. package/dist/components/generated/CameraLayers.gen.js +0 -25
  174. package/dist/components/generated/GlobalLight.gen.d.ts +0 -1
  175. package/dist/components/generated/GlobalLight.gen.js +0 -25
  176. package/dist/components/generated/GltfNode.gen.d.ts +0 -1
  177. package/dist/components/generated/GltfNode.gen.js +0 -25
  178. package/dist/components/generated/GltfNodeState.gen.d.ts +0 -1
  179. package/dist/components/generated/GltfNodeState.gen.js +0 -25
  180. package/dist/components/generated/TextureCamera.gen.d.ts +0 -1
  181. package/dist/components/generated/TextureCamera.gen.js +0 -25
  182. package/dist/components/generated/UiCanvas.gen.d.ts +0 -1
  183. package/dist/components/generated/UiCanvas.gen.js +0 -25
  184. package/dist/components/generated/UiScrollResult.gen.d.ts +0 -1
  185. package/dist/components/generated/UiScrollResult.gen.js +0 -25
  186. package/dist/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.d.ts +0 -29
  187. package/dist/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.js +0 -93
  188. package/dist/components/generated/pb/decentraland/sdk/components/avatar_movement.gen.d.ts +0 -20
  189. package/dist/components/generated/pb/decentraland/sdk/components/avatar_movement.gen.js +0 -69
  190. package/dist/components/generated/pb/decentraland/sdk/components/avatar_movement_info.gen.d.ts +0 -32
  191. package/dist/components/generated/pb/decentraland/sdk/components/avatar_movement_info.gen.js +0 -126
  192. package/dist/components/generated/pb/decentraland/sdk/components/camera_layer.gen.d.ts +0 -30
  193. package/dist/components/generated/pb/decentraland/sdk/components/camera_layer.gen.js +0 -104
  194. package/dist/components/generated/pb/decentraland/sdk/components/camera_layers.gen.d.ts +0 -14
  195. package/dist/components/generated/pb/decentraland/sdk/components/camera_layers.gen.js +0 -50
  196. package/dist/components/generated/pb/decentraland/sdk/components/global_light.gen.d.ts +0 -34
  197. package/dist/components/generated/pb/decentraland/sdk/components/global_light.gen.js +0 -61
  198. package/dist/components/generated/pb/decentraland/sdk/components/gltf_node.gen.d.ts +0 -50
  199. package/dist/components/generated/pb/decentraland/sdk/components/gltf_node.gen.js +0 -41
  200. package/dist/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.d.ts +0 -27
  201. package/dist/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.js +0 -59
  202. package/dist/components/generated/pb/decentraland/sdk/components/texture_camera.gen.d.ts +0 -74
  203. package/dist/components/generated/pb/decentraland/sdk/components/texture_camera.gen.js +0 -191
  204. package/dist/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.d.ts +0 -19
  205. package/dist/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.js +0 -60
  206. package/dist/components/generated/pb/decentraland/sdk/components/ui_scroll_result.gen.d.ts +0 -15
  207. package/dist/serialization/crdt/network/utils.d.ts +0 -9
  208. package/dist/serialization/crdt/network/utils.js +0 -60
  209. package/dist-cjs/components/extended/AvatarEquippedData.d.ts +0 -10
  210. package/dist-cjs/components/extended/AvatarEquippedData.js +0 -19
  211. package/dist-cjs/components/extended/AvatarShape.d.ts +0 -10
  212. package/dist-cjs/components/extended/AvatarShape.js +0 -19
  213. package/dist-cjs/components/generated/AvatarLocomotionSettings.gen.js +0 -28
  214. package/dist-cjs/components/generated/AvatarMovement.gen.js +0 -28
  215. package/dist-cjs/components/generated/AvatarMovementInfo.gen.js +0 -28
  216. package/dist-cjs/components/generated/CameraLayer.gen.js +0 -28
  217. package/dist-cjs/components/generated/CameraLayers.gen.d.ts +0 -1
  218. package/dist-cjs/components/generated/CameraLayers.gen.js +0 -28
  219. package/dist-cjs/components/generated/GlobalLight.gen.d.ts +0 -1
  220. package/dist-cjs/components/generated/GlobalLight.gen.js +0 -28
  221. package/dist-cjs/components/generated/GltfNode.gen.d.ts +0 -1
  222. package/dist-cjs/components/generated/GltfNode.gen.js +0 -28
  223. package/dist-cjs/components/generated/GltfNodeState.gen.d.ts +0 -1
  224. package/dist-cjs/components/generated/GltfNodeState.gen.js +0 -28
  225. package/dist-cjs/components/generated/TextureCamera.gen.d.ts +0 -1
  226. package/dist-cjs/components/generated/TextureCamera.gen.js +0 -28
  227. package/dist-cjs/components/generated/UiCanvas.gen.d.ts +0 -1
  228. package/dist-cjs/components/generated/UiCanvas.gen.js +0 -28
  229. package/dist-cjs/components/generated/UiScrollResult.gen.d.ts +0 -1
  230. package/dist-cjs/components/generated/UiScrollResult.gen.js +0 -28
  231. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.d.ts +0 -29
  232. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_locomotion_settings.gen.js +0 -99
  233. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_movement.gen.d.ts +0 -20
  234. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_movement.gen.js +0 -75
  235. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_movement_info.gen.d.ts +0 -32
  236. package/dist-cjs/components/generated/pb/decentraland/sdk/components/avatar_movement_info.gen.js +0 -132
  237. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layer.gen.d.ts +0 -30
  238. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layer.gen.js +0 -110
  239. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layers.gen.d.ts +0 -14
  240. package/dist-cjs/components/generated/pb/decentraland/sdk/components/camera_layers.gen.js +0 -56
  241. package/dist-cjs/components/generated/pb/decentraland/sdk/components/global_light.gen.d.ts +0 -34
  242. package/dist-cjs/components/generated/pb/decentraland/sdk/components/global_light.gen.js +0 -67
  243. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node.gen.d.ts +0 -50
  244. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node.gen.js +0 -47
  245. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.d.ts +0 -27
  246. package/dist-cjs/components/generated/pb/decentraland/sdk/components/gltf_node_state.gen.js +0 -65
  247. package/dist-cjs/components/generated/pb/decentraland/sdk/components/texture_camera.gen.d.ts +0 -74
  248. package/dist-cjs/components/generated/pb/decentraland/sdk/components/texture_camera.gen.js +0 -197
  249. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_canvas.gen.d.ts +0 -19
  250. package/dist-cjs/components/generated/pb/decentraland/sdk/components/ui_scroll_result.gen.d.ts +0 -15
  251. package/dist-cjs/serialization/crdt/network/utils.d.ts +0 -9
  252. package/dist-cjs/serialization/crdt/network/utils.js +0 -67
  253. /package/{dist-cjs/components/generated/AvatarMovementInfo.gen.d.ts → dist/components/generated/PhysicsCombinedForce.gen.d.ts} +0 -0
  254. /package/{dist-cjs/components/generated/CameraLayer.gen.d.ts → dist/components/generated/PhysicsCombinedImpulse.gen.d.ts} +0 -0
  255. /package/dist-cjs/components/generated/{AvatarLocomotionSettings.gen.d.ts → PhysicsCombinedForce.gen.d.ts} +0 -0
  256. /package/dist-cjs/components/generated/{AvatarMovement.gen.d.ts → PhysicsCombinedImpulse.gen.d.ts} +0 -0
@@ -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
  */
@@ -64,8 +64,10 @@ var EntityState;
64
64
  */
65
65
  function createEntityContainer(opts) {
66
66
  const reservedStaticEntities = opts?.reservedStaticEntities ?? exports.RESERVED_STATIC_ENTITIES;
67
- // Local entities counter
68
- let entityCounter = reservedStaticEntities;
67
+ // If a build tool has set DCL_MAX_COMPOSITE_ENTITY (via esbuild define),
68
+ // start the counter past composite entities to prevent ID collisions.
69
+ const maxCompositeEntity = typeof DCL_MAX_COMPOSITE_ENTITY !== 'undefined' ? DCL_MAX_COMPOSITE_ENTITY : 0;
70
+ let entityCounter = Math.max(reservedStaticEntities, maxCompositeEntity > 0 ? maxCompositeEntity + 1 : 0);
69
71
  const usedEntities = new Set();
70
72
  let toRemoveEntities = [];
71
73
  const removedEntities = (0, gset_1.createVersionGSet)();
@@ -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
  }
@@ -15,7 +16,7 @@ function freezeSet(set) {
15
16
  return set;
16
17
  }
17
18
  function sortByTimestamp(a, b) {
18
- return a.timestamp > b.timestamp ? 1 : -1;
19
+ return a.timestamp - b.timestamp;
19
20
  }
20
21
  /**
21
22
  * @internal
@@ -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;
@@ -32,12 +32,6 @@ export type IInputSystem = {
32
32
  * @returns the input command info or undefined if there is no command in the last tick-update
33
33
  */
34
34
  getInputCommand: (inputAction: InputAction, pointerEventType: PointerEventType, entity?: Entity) => PBPointerEventsResult | null;
35
- /**
36
- * @public
37
- * Get an ordered iterator over events received within the current frame.
38
- * @returns the iterator
39
- */
40
- getInputCommands: () => Generator<PBPointerEventsResult>;
41
35
  };
42
36
  /**
43
37
  * @public
@@ -144,8 +144,9 @@ function createInputSystem(engine) {
144
144
  }
145
145
  if (!up || !down)
146
146
  return null;
147
- // If the DOWN command has happen before the UP commands, it means that that a clicked has happen
148
- if (down.timestamp < up.timestamp && timestampIsCurrentFrame(up.timestamp)) {
147
+ // If the DOWN command has happened before or at the same time as the UP command, a click has happened.
148
+ // Same-timestamp is possible when both events are produced within the same renderer tick.
149
+ if (down.timestamp <= up.timestamp && timestampIsCurrentFrame(up.timestamp)) {
149
150
  return { up, down };
150
151
  }
151
152
  return null;
@@ -211,18 +212,12 @@ function createInputSystem(engine) {
211
212
  function isPressed(inputAction) {
212
213
  return globalState.buttonState.get(inputAction)?.state === 1 /* PointerEventType.PET_DOWN */;
213
214
  }
214
- function* getInputCommands() {
215
- for (let i = globalState.thisFrameCommands.length - 1; i >= 0; i--) {
216
- yield globalState.thisFrameCommands[i];
217
- }
218
- }
219
215
  return {
220
216
  isPressed,
221
217
  getClick,
222
218
  getInputCommand,
223
219
  isClicked,
224
- isTriggered,
225
- getInputCommands
220
+ isTriggered
226
221
  };
227
222
  }
228
223
  exports.createInputSystem = createInputSystem;
@@ -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,9 +1,9 @@
1
1
  export * from './engine';
2
2
  export * from './schemas';
3
+ export * from './runtime/globals';
3
4
  export * from './runtime/initialization';
4
5
  export * from './runtime/types';
5
6
  export * from './runtime/helpers';
6
- export * from './runtime/globals';
7
7
  export { cyclicParentingChecker } from './systems/cyclicParentingChecker';
8
8
  export * from './systems/events';
9
9
  export * from './systems/raycast';
@@ -14,7 +14,7 @@ export * from './systems/tween';
14
14
  export * from './systems/triggerArea';
15
15
  export * from './engine/entity';
16
16
  export * from './components/types';
17
- import { MaterialComponentDefinitionExtended, MeshColliderComponentDefinitionExtended, MeshRendererComponentDefinitionExtended, TransformComponentExtended, AnimatorComponentDefinitionExtended, AudioSourceComponentDefinitionExtended, AudioStreamComponentDefinitionExtended, ISyncComponents, TweenComponentDefinitionExtended, INetowrkEntity, INetowrkParent, VirtualCameraComponentDefinitionExtended, InputModifierComponentDefinitionExtended, LightSourceComponentDefinitionExtended, TriggerAreaComponentDefinitionExtended } from './components/types';
17
+ import { MaterialComponentDefinitionExtended, MeshColliderComponentDefinitionExtended, MeshRendererComponentDefinitionExtended, TransformComponentExtended, AnimatorComponentDefinitionExtended, AudioSourceComponentDefinitionExtended, AudioStreamComponentDefinitionExtended, ISyncComponents, TweenComponentDefinitionExtended, INetowrkEntity, INetowrkParent, VirtualCameraComponentDefinitionExtended, InputModifierComponentDefinitionExtended, LightSourceComponentDefinitionExtended, TriggerAreaComponentDefinitionExtended, ICreatedBy } from './components/types';
18
18
  import { NameComponent } from './components/manual/Name';
19
19
  import { TagsComponentDefinitionExtended } from './components/manual/Tags';
20
20
  export declare const Transform: TransformComponentExtended;
@@ -47,6 +47,7 @@ export declare const NetworkEntity: INetowrkEntity;
47
47
  * Tag a entity to be syncronized through comms
48
48
  */
49
49
  export declare const NetworkParent: INetowrkParent;
50
+ export declare const CreatedBy: ICreatedBy;
50
51
  export * from './components/generated/global.gen';
51
52
  export * from './components/generated/types.gen';
52
53
  export * from './serialization/crdt';
package/dist-cjs/index.js CHANGED
@@ -26,14 +26,14 @@ var __importStar = (this && this.__importStar) || function (mod) {
26
26
  return result;
27
27
  };
28
28
  Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.NetworkParent = exports.NetworkEntity = exports.SyncComponents = exports.TriggerArea = exports.LightSource = exports.InputModifier = exports.VirtualCamera = exports.Tween = exports.Tags = exports.Name = exports.MeshCollider = exports.MeshRenderer = exports.Material = exports.AudioStream = exports.AudioSource = exports.Animator = exports.Transform = exports.components = exports.cyclicParentingChecker = void 0;
29
+ exports.CreatedBy = exports.NetworkParent = exports.NetworkEntity = exports.SyncComponents = exports.TriggerArea = exports.LightSource = exports.InputModifier = exports.VirtualCamera = exports.Tween = exports.Tags = exports.Name = exports.MeshCollider = exports.MeshRenderer = exports.Material = exports.AudioStream = exports.AudioSource = exports.Animator = exports.Transform = exports.components = exports.cyclicParentingChecker = void 0;
30
30
  // The order of the following imports matters. Please do not auto-sort
31
31
  __exportStar(require("./engine"), exports);
32
32
  __exportStar(require("./schemas"), exports);
33
+ __exportStar(require("./runtime/globals"), exports);
33
34
  __exportStar(require("./runtime/initialization"), exports);
34
35
  __exportStar(require("./runtime/types"), exports);
35
36
  __exportStar(require("./runtime/helpers"), exports);
36
- __exportStar(require("./runtime/globals"), exports);
37
37
  var cyclicParentingChecker_1 = require("./systems/cyclicParentingChecker");
38
38
  Object.defineProperty(exports, "cyclicParentingChecker", { enumerable: true, get: function () { return cyclicParentingChecker_1.cyclicParentingChecker; } });
39
39
  __exportStar(require("./systems/events"), exports);
@@ -80,6 +80,7 @@ exports.NetworkEntity = components.NetworkEntity(initialization_1.engine);
80
80
  * Tag a entity to be syncronized through comms
81
81
  */
82
82
  exports.NetworkParent = components.NetworkParent(initialization_1.engine);
83
+ exports.CreatedBy = components.CreatedBy(initialization_1.engine);
83
84
  // export components for global engine
84
85
  __exportStar(require("./components/generated/global.gen"), exports);
85
86
  __exportStar(require("./components/generated/types.gen"), exports);
@@ -1,6 +1,5 @@
1
1
  /**
2
- * Utilities for standardized globalThis access.
3
- * @public
2
+ * Internal utilities for standardized globalThis access.
4
3
  */
5
4
  /**
6
5
  * Type-safe globalThis property access.
@@ -1,7 +1,6 @@
1
1
  "use strict";
2
2
  /**
3
- * Utilities for standardized globalThis access.
4
- * @public
3
+ * Internal utilities for standardized globalThis access.
5
4
  */
6
5
  Object.defineProperty(exports, "__esModule", { value: true });
7
6
  exports.setGlobalPolyfill = exports.getGlobal = void 0;
@@ -0,0 +1,15 @@
1
+ import { Entity } from '../../engine/entity';
2
+ import { ByteBuffer } from '../ByteBuffer';
3
+ import { AuthoritativePutComponentMessage } from './types';
4
+ /**
5
+ * @public
6
+ */
7
+ export declare namespace AuthoritativePutComponentOperation {
8
+ const MESSAGE_HEADER_LENGTH = 16;
9
+ /**
10
+ * Call this function for an optimal writing data passing the ByteBuffer
11
+ * already allocated
12
+ */
13
+ function write(entity: Entity, timestamp: number, componentId: number, data: Uint8Array, buf: ByteBuffer): void;
14
+ function read(buf: ByteBuffer): AuthoritativePutComponentMessage | null;
15
+ }
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AuthoritativePutComponentOperation = void 0;
4
+ const crdtMessageProtocol_1 = require("./crdtMessageProtocol");
5
+ const types_1 = require("./types");
6
+ /**
7
+ * @public
8
+ */
9
+ var AuthoritativePutComponentOperation;
10
+ (function (AuthoritativePutComponentOperation) {
11
+ AuthoritativePutComponentOperation.MESSAGE_HEADER_LENGTH = 16;
12
+ /**
13
+ * Call this function for an optimal writing data passing the ByteBuffer
14
+ * already allocated
15
+ */
16
+ function write(entity, timestamp, componentId, data, buf) {
17
+ // reserve the beginning
18
+ const startMessageOffset = buf.incrementWriteOffset(types_1.CRDT_MESSAGE_HEADER_LENGTH + AuthoritativePutComponentOperation.MESSAGE_HEADER_LENGTH);
19
+ // write body
20
+ buf.writeBuffer(data, false);
21
+ const messageLength = buf.currentWriteOffset() - startMessageOffset;
22
+ // Write CrdtMessage header
23
+ buf.setUint32(startMessageOffset, messageLength);
24
+ buf.setUint32(startMessageOffset + 4, types_1.CrdtMessageType.AUTHORITATIVE_PUT_COMPONENT);
25
+ // Write ComponentOperation header
26
+ buf.setUint32(startMessageOffset + 8, entity);
27
+ buf.setUint32(startMessageOffset + 12, componentId);
28
+ buf.setUint32(startMessageOffset + 16, timestamp);
29
+ const newLocal = messageLength - AuthoritativePutComponentOperation.MESSAGE_HEADER_LENGTH - types_1.CRDT_MESSAGE_HEADER_LENGTH;
30
+ buf.setUint32(startMessageOffset + 20, newLocal);
31
+ }
32
+ AuthoritativePutComponentOperation.write = write;
33
+ function read(buf) {
34
+ const header = crdtMessageProtocol_1.CrdtMessageProtocol.readHeader(buf);
35
+ if (!header) {
36
+ return null;
37
+ }
38
+ if (header.type !== types_1.CrdtMessageType.AUTHORITATIVE_PUT_COMPONENT) {
39
+ throw new Error('AuthoritativePutComponentOperation tried to read another message type.');
40
+ }
41
+ return {
42
+ ...header,
43
+ entityId: buf.readUint32(),
44
+ componentId: buf.readUint32(),
45
+ timestamp: buf.readUint32(),
46
+ data: buf.readBuffer()
47
+ };
48
+ }
49
+ AuthoritativePutComponentOperation.read = read;
50
+ })(AuthoritativePutComponentOperation = exports.AuthoritativePutComponentOperation || (exports.AuthoritativePutComponentOperation = {}));
@@ -7,3 +7,4 @@ export * from './network/deleteComponentNetwork';
7
7
  export * from './network/deleteEntityNetwork';
8
8
  export * from './types';
9
9
  export * from './crdtMessageProtocol';
10
+ export * from './authoritativePutComponent';
@@ -23,3 +23,4 @@ __exportStar(require("./network/deleteComponentNetwork"), exports);
23
23
  __exportStar(require("./network/deleteEntityNetwork"), exports);
24
24
  __exportStar(require("./types"), exports);
25
25
  __exportStar(require("./crdtMessageProtocol"), exports);
26
+ __exportStar(require("./authoritativePutComponent"), exports);
@@ -11,7 +11,8 @@ export declare enum CrdtMessageType {
11
11
  PUT_COMPONENT_NETWORK = 5,
12
12
  DELETE_COMPONENT_NETWORK = 6,
13
13
  DELETE_ENTITY_NETWORK = 7,
14
- MAX_MESSAGE_TYPE = 8
14
+ AUTHORITATIVE_PUT_COMPONENT = 8,
15
+ MAX_MESSAGE_TYPE = 9
15
16
  }
16
17
  /**
17
18
  * Min length = 8 bytes
@@ -48,6 +49,23 @@ export type PutNetworkComponentMessageBody = Omit<PutComponentMessageBody, 'type
48
49
  type: CrdtMessageType.PUT_COMPONENT_NETWORK;
49
50
  networkId: number;
50
51
  };
52
+ /**
53
+ * Server authoritative message - identical to PutComponentMessageBody but with forced processing
54
+ * Min. length = header (8 bytes) + 16 bytes = 24 bytes
55
+ *
56
+ * @param entity - Uint32 number of the entity
57
+ * @param componentId - Uint32 number of id
58
+ * @param timestamp - Uint32 Lamport timestamp (server's authoritative timestamp)
59
+ * @param data - Uint8[] data of component => length(4 bytes) + block of bytes[0..length-1]
60
+ * @public
61
+ */
62
+ export type AuthoritativePutComponentMessageBody = {
63
+ type: CrdtMessageType.AUTHORITATIVE_PUT_COMPONENT;
64
+ entityId: Entity;
65
+ componentId: number;
66
+ timestamp: number;
67
+ data: Uint8Array;
68
+ };
51
69
  /**
52
70
  * Min. length = header (8 bytes) + 16 bytes = 24 bytes
53
71
  *
@@ -114,6 +132,10 @@ export type AppendValueMessage = CrdtMessageHeader & AppendValueMessageBody;
114
132
  * @public
115
133
  */
116
134
  export type PutComponentMessage = CrdtMessageHeader & PutComponentMessageBody;
135
+ /**
136
+ * @public
137
+ */
138
+ export type AuthoritativePutComponentMessage = CrdtMessageHeader & AuthoritativePutComponentMessageBody;
117
139
  /**
118
140
  * @public
119
141
  */
@@ -137,7 +159,7 @@ export type DeleteEntityNetworkMessage = CrdtMessageHeader & DeleteEntityNetwork
137
159
  /**
138
160
  * @public
139
161
  */
140
- export type CrdtMessage = PutComponentMessage | DeleteComponentMessage | AppendValueMessage | DeleteEntityMessage | PutNetworkComponentMessage | DeleteComponentNetworkMessage | DeleteEntityNetworkMessage;
162
+ export type CrdtMessage = PutComponentMessage | AuthoritativePutComponentMessage | DeleteComponentMessage | AppendValueMessage | DeleteEntityMessage | PutNetworkComponentMessage | DeleteComponentNetworkMessage | DeleteEntityNetworkMessage;
141
163
  /**
142
164
  * @public
143
165
  */
@@ -145,7 +167,7 @@ export type CrdtNetworkMessageBody = PutNetworkComponentMessageBody | DeleteComp
145
167
  /**
146
168
  * @public
147
169
  */
148
- export type CrdtMessageBody = PutComponentMessageBody | DeleteComponentMessageBody | DeleteEntityMessageBody | AppendValueMessageBody | CrdtNetworkMessageBody;
170
+ export type CrdtMessageBody = PutComponentMessageBody | AuthoritativePutComponentMessageBody | DeleteComponentMessageBody | DeleteEntityMessageBody | AppendValueMessageBody | CrdtNetworkMessageBody;
149
171
  export declare enum ProcessMessageResultType {
150
172
  /**
151
173
  * Typical message and new state set.
@@ -16,7 +16,9 @@ var CrdtMessageType;
16
16
  CrdtMessageType[CrdtMessageType["PUT_COMPONENT_NETWORK"] = 5] = "PUT_COMPONENT_NETWORK";
17
17
  CrdtMessageType[CrdtMessageType["DELETE_COMPONENT_NETWORK"] = 6] = "DELETE_COMPONENT_NETWORK";
18
18
  CrdtMessageType[CrdtMessageType["DELETE_ENTITY_NETWORK"] = 7] = "DELETE_ENTITY_NETWORK";
19
- CrdtMessageType[CrdtMessageType["MAX_MESSAGE_TYPE"] = 8] = "MAX_MESSAGE_TYPE";
19
+ // Server authoritative operation - forces component state regardless of timestamp
20
+ CrdtMessageType[CrdtMessageType["AUTHORITATIVE_PUT_COMPONENT"] = 8] = "AUTHORITATIVE_PUT_COMPONENT";
21
+ CrdtMessageType[CrdtMessageType["MAX_MESSAGE_TYPE"] = 9] = "MAX_MESSAGE_TYPE";
20
22
  })(CrdtMessageType = exports.CrdtMessageType || (exports.CrdtMessageType = {}));
21
23
  /**
22
24
  * @public
@@ -1,7 +1,6 @@
1
1
  import { Entity } from '../../engine/entity';
2
2
  import type { ComponentDefinition } from '../../engine';
3
3
  import { CrdtMessageType } from '../../serialization/crdt/types';
4
- export declare const LIVEKIT_MAX_SIZE = 12;
5
4
  /**
6
5
  * @public
7
6
  */