@needle-tools/engine 5.1.0-canary.deec6e4 → 5.1.0-canary.e6680fa

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 (326) hide show
  1. package/CHANGELOG.md +99 -1
  2. package/SKILL.md +4 -1
  3. package/components.needle.json +1 -1
  4. package/dist/needle-engine.bundle-Bl_hyH5G.umd.cjs +1734 -0
  5. package/dist/needle-engine.bundle-Cduc1gj6.min.js +1734 -0
  6. package/dist/{needle-engine.bundle-CvtELXh0.js → needle-engine.bundle-DNcqT8nJ.js} +19415 -18452
  7. package/dist/needle-engine.d.ts +1588 -374
  8. package/dist/needle-engine.js +572 -569
  9. package/dist/needle-engine.min.js +1 -1
  10. package/dist/needle-engine.umd.cjs +1 -1
  11. package/dist/three.js +1 -0
  12. package/dist/three.min.js +21 -21
  13. package/dist/three.umd.cjs +16 -16
  14. package/lib/engine/api.d.ts +8 -1
  15. package/lib/engine/api.js +7 -1
  16. package/lib/engine/api.js.map +1 -1
  17. package/lib/engine/codegen/register_types.js +10 -18
  18. package/lib/engine/codegen/register_types.js.map +1 -1
  19. package/lib/engine/engine_audio.d.ts +68 -0
  20. package/lib/engine/engine_audio.js +172 -0
  21. package/lib/engine/engine_audio.js.map +1 -1
  22. package/lib/engine/engine_camera.fit.js +16 -4
  23. package/lib/engine/engine_camera.fit.js.map +1 -1
  24. package/lib/engine/engine_components.js +1 -1
  25. package/lib/engine/engine_components.js.map +1 -1
  26. package/lib/engine/engine_context.d.ts +21 -8
  27. package/lib/engine/engine_context.js +46 -16
  28. package/lib/engine/engine_context.js.map +1 -1
  29. package/lib/engine/engine_context_eventbus.d.ts +47 -0
  30. package/lib/engine/engine_context_eventbus.js +47 -0
  31. package/lib/engine/engine_context_eventbus.js.map +1 -0
  32. package/lib/engine/engine_disposable.d.ts +172 -0
  33. package/lib/engine/engine_disposable.js +136 -0
  34. package/lib/engine/engine_disposable.js.map +1 -0
  35. package/lib/engine/engine_gameobject.d.ts +1 -10
  36. package/lib/engine/engine_gameobject.js +22 -120
  37. package/lib/engine/engine_gameobject.js.map +1 -1
  38. package/lib/engine/engine_gltf_builtin_components.js +7 -69
  39. package/lib/engine/engine_gltf_builtin_components.js.map +1 -1
  40. package/lib/engine/engine_init.js +7 -7
  41. package/lib/engine/engine_init.js.map +1 -1
  42. package/lib/engine/engine_input.d.ts +24 -5
  43. package/lib/engine/engine_input.js +3 -2
  44. package/lib/engine/engine_input.js.map +1 -1
  45. package/lib/engine/engine_instantiate_resolve.d.ts +42 -0
  46. package/lib/engine/engine_instantiate_resolve.js +372 -0
  47. package/lib/engine/engine_instantiate_resolve.js.map +1 -0
  48. package/lib/engine/engine_license.d.ts +7 -7
  49. package/lib/engine/engine_license.js +186 -58
  50. package/lib/engine/engine_license.js.map +1 -1
  51. package/lib/engine/engine_mainloop_utils.js +7 -4
  52. package/lib/engine/engine_mainloop_utils.js.map +1 -1
  53. package/lib/engine/engine_networking.d.ts +51 -37
  54. package/lib/engine/engine_networking.js +132 -82
  55. package/lib/engine/engine_networking.js.map +1 -1
  56. package/lib/engine/engine_networking.transport.websocket.d.ts +15 -0
  57. package/lib/engine/engine_networking.transport.websocket.js +38 -0
  58. package/lib/engine/engine_networking.transport.websocket.js.map +1 -0
  59. package/lib/engine/engine_networking_blob.js +4 -4
  60. package/lib/engine/engine_networking_blob.js.map +1 -1
  61. package/lib/engine/engine_networking_instantiate.js +2 -2
  62. package/lib/engine/engine_networking_instantiate.js.map +1 -1
  63. package/lib/engine/engine_networking_types.d.ts +39 -1
  64. package/lib/engine/engine_networking_types.js +7 -0
  65. package/lib/engine/engine_networking_types.js.map +1 -1
  66. package/lib/engine/engine_physics_rapier.d.ts +21 -3
  67. package/lib/engine/engine_physics_rapier.js +94 -25
  68. package/lib/engine/engine_physics_rapier.js.map +1 -1
  69. package/lib/engine/engine_pmrem.js +51 -3
  70. package/lib/engine/engine_pmrem.js.map +1 -1
  71. package/lib/engine/engine_scenedata.js +2 -2
  72. package/lib/engine/engine_scenedata.js.map +1 -1
  73. package/lib/engine/engine_serialization_builtin_serializer.js +28 -5
  74. package/lib/engine/engine_serialization_builtin_serializer.js.map +1 -1
  75. package/lib/engine/engine_serialization_core.d.ts +1 -0
  76. package/lib/engine/engine_serialization_core.js +7 -0
  77. package/lib/engine/engine_serialization_core.js.map +1 -1
  78. package/lib/engine/engine_types.d.ts +29 -11
  79. package/lib/engine/engine_types.js +1 -1
  80. package/lib/engine/engine_types.js.map +1 -1
  81. package/lib/engine/engine_util_decorator.js +7 -2
  82. package/lib/engine/engine_util_decorator.js.map +1 -1
  83. package/lib/engine/engine_utils.d.ts +1 -1
  84. package/lib/engine/engine_utils.js +19 -5
  85. package/lib/engine/engine_utils.js.map +1 -1
  86. package/lib/engine/engine_utils_format.js +20 -14
  87. package/lib/engine/engine_utils_format.js.map +1 -1
  88. package/lib/engine/engine_utils_qrcode.js +2 -2
  89. package/lib/engine/engine_utils_qrcode.js.map +1 -1
  90. package/lib/engine/physics/workers/mesh-bvh/GenerateMeshBVHWorker.js +1 -1
  91. package/lib/engine/physics/workers/mesh-bvh/GenerateMeshBVHWorker.js.map +1 -1
  92. package/lib/engine/webcomponents/needle menu/needle-menu-spatial.js +2 -2
  93. package/lib/engine/webcomponents/needle menu/needle-menu-spatial.js.map +1 -1
  94. package/lib/engine/webcomponents/needle menu/needle-menu.d.ts +1 -1
  95. package/lib/engine/webcomponents/needle menu/needle-menu.js +6 -6
  96. package/lib/engine/webcomponents/needle menu/needle-menu.js.map +1 -1
  97. package/lib/engine/webcomponents/needle-engine.d.ts +10 -4
  98. package/lib/engine/webcomponents/needle-engine.js +3 -3
  99. package/lib/engine/webcomponents/needle-engine.js.map +1 -1
  100. package/lib/engine/webcomponents/needle-engine.loading.js +2 -2
  101. package/lib/engine/webcomponents/needle-engine.loading.js.map +1 -1
  102. package/lib/engine/xr/NeedleXRSession.d.ts +3 -2
  103. package/lib/engine/xr/NeedleXRSession.js +50 -14
  104. package/lib/engine/xr/NeedleXRSession.js.map +1 -1
  105. package/lib/engine/xr/TempXRContext.js +2 -2
  106. package/lib/engine/xr/TempXRContext.js.map +1 -1
  107. package/lib/engine/xr/events.d.ts +1 -1
  108. package/lib/engine/xr/events.js.map +1 -1
  109. package/lib/engine-components/Animation.js +17 -16
  110. package/lib/engine-components/Animation.js.map +1 -1
  111. package/lib/engine-components/AnimationBuilder.d.ts +158 -0
  112. package/lib/engine-components/AnimationBuilder.js +305 -0
  113. package/lib/engine-components/AnimationBuilder.js.map +1 -0
  114. package/lib/engine-components/Animator.d.ts +6 -0
  115. package/lib/engine-components/Animator.js +23 -13
  116. package/lib/engine-components/Animator.js.map +1 -1
  117. package/lib/engine-components/AnimatorController.builder.d.ts +191 -0
  118. package/lib/engine-components/AnimatorController.builder.js +263 -0
  119. package/lib/engine-components/AnimatorController.builder.js.map +1 -0
  120. package/lib/engine-components/AnimatorController.d.ts +2 -119
  121. package/lib/engine-components/AnimatorController.js +33 -232
  122. package/lib/engine-components/AnimatorController.js.map +1 -1
  123. package/lib/engine-components/AudioSource.d.ts +19 -3
  124. package/lib/engine-components/AudioSource.js +121 -68
  125. package/lib/engine-components/AudioSource.js.map +1 -1
  126. package/lib/engine-components/Camera.d.ts +6 -1
  127. package/lib/engine-components/Camera.js +16 -3
  128. package/lib/engine-components/Camera.js.map +1 -1
  129. package/lib/engine-components/CameraUtils.js +14 -6
  130. package/lib/engine-components/CameraUtils.js.map +1 -1
  131. package/lib/engine-components/Collider.d.ts +18 -9
  132. package/lib/engine-components/Collider.js +61 -14
  133. package/lib/engine-components/Collider.js.map +1 -1
  134. package/lib/engine-components/Component.d.ts +72 -9
  135. package/lib/engine-components/Component.js +114 -10
  136. package/lib/engine-components/Component.js.map +1 -1
  137. package/lib/engine-components/ContactShadows.d.ts +1 -0
  138. package/lib/engine-components/ContactShadows.js +14 -1
  139. package/lib/engine-components/ContactShadows.js.map +1 -1
  140. package/lib/engine-components/DragControls.d.ts +7 -0
  141. package/lib/engine-components/DragControls.js +19 -7
  142. package/lib/engine-components/DragControls.js.map +1 -1
  143. package/lib/engine-components/DropListener.js +4 -0
  144. package/lib/engine-components/DropListener.js.map +1 -1
  145. package/lib/engine-components/EventList.d.ts +31 -9
  146. package/lib/engine-components/EventList.js +37 -76
  147. package/lib/engine-components/EventList.js.map +1 -1
  148. package/lib/engine-components/Joints.d.ts +4 -2
  149. package/lib/engine-components/Joints.js +19 -3
  150. package/lib/engine-components/Joints.js.map +1 -1
  151. package/lib/engine-components/Light.js +9 -1
  152. package/lib/engine-components/Light.js.map +1 -1
  153. package/lib/engine-components/Networking.d.ts +1 -1
  154. package/lib/engine-components/Networking.js +1 -1
  155. package/lib/engine-components/OrbitControls.d.ts +1 -2
  156. package/lib/engine-components/OrbitControls.js +37 -14
  157. package/lib/engine-components/OrbitControls.js.map +1 -1
  158. package/lib/engine-components/RigidBody.d.ts +12 -4
  159. package/lib/engine-components/RigidBody.js +18 -4
  160. package/lib/engine-components/RigidBody.js.map +1 -1
  161. package/lib/engine-components/SceneSwitcher.js +3 -0
  162. package/lib/engine-components/SceneSwitcher.js.map +1 -1
  163. package/lib/engine-components/SeeThrough.js +2 -2
  164. package/lib/engine-components/SeeThrough.js.map +1 -1
  165. package/lib/engine-components/VideoPlayer.d.ts +8 -2
  166. package/lib/engine-components/VideoPlayer.js +42 -19
  167. package/lib/engine-components/VideoPlayer.js.map +1 -1
  168. package/lib/engine-components/Voip.d.ts +16 -7
  169. package/lib/engine-components/Voip.js +90 -53
  170. package/lib/engine-components/Voip.js.map +1 -1
  171. package/lib/engine-components/api.d.ts +3 -1
  172. package/lib/engine-components/api.js +3 -1
  173. package/lib/engine-components/api.js.map +1 -1
  174. package/lib/engine-components/codegen/components.d.ts +7 -13
  175. package/lib/engine-components/codegen/components.js +7 -13
  176. package/lib/engine-components/codegen/components.js.map +1 -1
  177. package/lib/engine-components/export/usdz/USDZExporter.js +4 -4
  178. package/lib/engine-components/export/usdz/USDZExporter.js.map +1 -1
  179. package/lib/engine-components/postprocessing/Effects/Tonemapping.utils.d.ts +1 -1
  180. package/lib/engine-components/timeline/PlayableDirector.d.ts +21 -11
  181. package/lib/engine-components/timeline/PlayableDirector.js +75 -67
  182. package/lib/engine-components/timeline/PlayableDirector.js.map +1 -1
  183. package/lib/engine-components/timeline/SignalAsset.d.ts +3 -1
  184. package/lib/engine-components/timeline/SignalAsset.js +1 -0
  185. package/lib/engine-components/timeline/SignalAsset.js.map +1 -1
  186. package/lib/engine-components/timeline/TimelineBuilder.d.ts +413 -0
  187. package/lib/engine-components/timeline/TimelineBuilder.js +506 -0
  188. package/lib/engine-components/timeline/TimelineBuilder.js.map +1 -0
  189. package/lib/engine-components/timeline/TimelineModels.d.ts +2 -1
  190. package/lib/engine-components/timeline/TimelineModels.js +3 -0
  191. package/lib/engine-components/timeline/TimelineModels.js.map +1 -1
  192. package/lib/engine-components/timeline/TimelineTracks.d.ts +37 -6
  193. package/lib/engine-components/timeline/TimelineTracks.js +92 -26
  194. package/lib/engine-components/timeline/TimelineTracks.js.map +1 -1
  195. package/lib/engine-components/timeline/index.d.ts +2 -1
  196. package/lib/engine-components/timeline/index.js +2 -0
  197. package/lib/engine-components/timeline/index.js.map +1 -1
  198. package/lib/engine-components/ui/Canvas.d.ts +1 -1
  199. package/lib/engine-components/ui/Canvas.js +2 -8
  200. package/lib/engine-components/ui/Canvas.js.map +1 -1
  201. package/lib/engine-components/ui/Text.d.ts +1 -0
  202. package/lib/engine-components/ui/Text.js +10 -7
  203. package/lib/engine-components/ui/Text.js.map +1 -1
  204. package/lib/engine-components/web/CursorFollow.d.ts +0 -1
  205. package/lib/engine-components/web/CursorFollow.js +21 -13
  206. package/lib/engine-components/web/CursorFollow.js.map +1 -1
  207. package/lib/engine-components/webxr/WebXRImageTracking.d.ts +62 -1
  208. package/lib/engine-components/webxr/WebXRImageTracking.js +59 -2
  209. package/lib/engine-components/webxr/WebXRImageTracking.js.map +1 -1
  210. package/package.json +2 -83
  211. package/plugins/common/cloud.js +6 -1
  212. package/plugins/common/license.js +55 -12
  213. package/plugins/common/worker.js +9 -4
  214. package/plugins/types/userconfig.d.ts +4 -1
  215. package/plugins/vite/asap.js +17 -8
  216. package/plugins/vite/build-pipeline.js +57 -20
  217. package/plugins/vite/dependencies.js +29 -10
  218. package/plugins/vite/dependency-watcher.js +2 -2
  219. package/plugins/vite/editor-connection.js +3 -3
  220. package/plugins/vite/license.js +42 -7
  221. package/plugins/vite/local-files-core.js +3 -3
  222. package/plugins/vite/local-files-utils.d.ts +3 -1
  223. package/plugins/vite/local-files-utils.js +29 -5
  224. package/plugins/vite/reload.js +1 -1
  225. package/plugins/vite/server.js +2 -1
  226. package/src/engine/api.ts +11 -1
  227. package/src/engine/codegen/register_types.ts +10 -18
  228. package/src/engine/engine_audio.ts +184 -0
  229. package/src/engine/engine_camera.fit.ts +15 -4
  230. package/src/engine/engine_components.ts +1 -1
  231. package/src/engine/engine_context.ts +52 -19
  232. package/src/engine/engine_context_eventbus.ts +73 -0
  233. package/src/engine/engine_disposable.ts +214 -0
  234. package/src/engine/engine_gameobject.ts +54 -159
  235. package/src/engine/engine_gltf_builtin_components.ts +7 -76
  236. package/src/engine/engine_init.ts +7 -7
  237. package/src/engine/engine_input.ts +28 -7
  238. package/src/engine/engine_instantiate_resolve.ts +407 -0
  239. package/src/engine/engine_license.ts +202 -56
  240. package/src/engine/engine_mainloop_utils.ts +7 -4
  241. package/src/engine/engine_networking.transport.websocket.ts +45 -0
  242. package/src/engine/engine_networking.ts +161 -137
  243. package/src/engine/engine_networking_blob.ts +4 -4
  244. package/src/engine/engine_networking_instantiate.ts +2 -2
  245. package/src/engine/engine_networking_types.ts +41 -1
  246. package/src/engine/engine_physics_rapier.ts +102 -33
  247. package/src/engine/engine_pmrem.ts +53 -3
  248. package/src/engine/engine_scenedata.ts +3 -3
  249. package/src/engine/engine_serialization_builtin_serializer.ts +32 -9
  250. package/src/engine/engine_serialization_core.ts +9 -0
  251. package/src/engine/engine_types.ts +46 -27
  252. package/src/engine/engine_util_decorator.ts +7 -2
  253. package/src/engine/engine_utils.ts +16 -5
  254. package/src/engine/engine_utils_format.ts +20 -14
  255. package/src/engine/engine_utils_qrcode.ts +2 -2
  256. package/src/engine/physics/workers/mesh-bvh/GenerateMeshBVHWorker.js +1 -1
  257. package/src/engine/webcomponents/needle menu/needle-menu-spatial.ts +2 -2
  258. package/src/engine/webcomponents/needle menu/needle-menu.ts +6 -6
  259. package/src/engine/webcomponents/needle-engine.loading.ts +6 -6
  260. package/src/engine/webcomponents/needle-engine.ts +12 -6
  261. package/src/engine/xr/NeedleXRSession.ts +48 -13
  262. package/src/engine/xr/TempXRContext.ts +2 -2
  263. package/src/engine/xr/events.ts +1 -1
  264. package/src/engine-components/Animation.ts +19 -16
  265. package/src/engine-components/AnimationBuilder.ts +472 -0
  266. package/src/engine-components/Animator.ts +24 -12
  267. package/src/engine-components/AnimatorController.builder.ts +387 -0
  268. package/src/engine-components/AnimatorController.ts +20 -291
  269. package/src/engine-components/AudioSource.ts +130 -79
  270. package/src/engine-components/Camera.ts +16 -3
  271. package/src/engine-components/CameraUtils.ts +12 -5
  272. package/src/engine-components/Collider.ts +66 -18
  273. package/src/engine-components/Component.ts +118 -20
  274. package/src/engine-components/ContactShadows.ts +15 -1
  275. package/src/engine-components/DragControls.ts +18 -11
  276. package/src/engine-components/DropListener.ts +4 -0
  277. package/src/engine-components/EventList.ts +45 -83
  278. package/src/engine-components/Joints.ts +20 -4
  279. package/src/engine-components/Light.ts +10 -2
  280. package/src/engine-components/Networking.ts +1 -1
  281. package/src/engine-components/OrbitControls.ts +42 -16
  282. package/src/engine-components/RigidBody.ts +18 -4
  283. package/src/engine-components/SceneSwitcher.ts +3 -0
  284. package/src/engine-components/SeeThrough.ts +2 -2
  285. package/src/engine-components/VideoPlayer.ts +40 -17
  286. package/src/engine-components/Voip.ts +88 -53
  287. package/src/engine-components/api.ts +3 -1
  288. package/src/engine-components/codegen/components.ts +7 -13
  289. package/src/engine-components/export/usdz/USDZExporter.ts +4 -4
  290. package/src/engine-components/timeline/PlayableDirector.ts +83 -81
  291. package/src/engine-components/timeline/SignalAsset.ts +4 -1
  292. package/src/engine-components/timeline/TimelineBuilder.ts +824 -0
  293. package/src/engine-components/timeline/TimelineModels.ts +5 -1
  294. package/src/engine-components/timeline/TimelineTracks.ts +96 -27
  295. package/src/engine-components/timeline/index.ts +2 -1
  296. package/src/engine-components/ui/Canvas.ts +2 -8
  297. package/src/engine-components/ui/Text.ts +12 -8
  298. package/src/engine-components/web/CursorFollow.ts +21 -14
  299. package/src/engine-components/webxr/WebXRImageTracking.ts +79 -7
  300. package/dist/needle-engine.bundle-1s2gOoKZ.min.js +0 -1732
  301. package/dist/needle-engine.bundle-j4nGJXCs.umd.cjs +0 -1732
  302. package/lib/engine-components/AvatarLoader.d.ts +0 -80
  303. package/lib/engine-components/AvatarLoader.js +0 -232
  304. package/lib/engine-components/AvatarLoader.js.map +0 -1
  305. package/lib/engine-components/avatar/AvatarBlink_Simple.d.ts +0 -11
  306. package/lib/engine-components/avatar/AvatarBlink_Simple.js +0 -77
  307. package/lib/engine-components/avatar/AvatarBlink_Simple.js.map +0 -1
  308. package/lib/engine-components/avatar/AvatarEyeLook_Rotation.d.ts +0 -14
  309. package/lib/engine-components/avatar/AvatarEyeLook_Rotation.js +0 -69
  310. package/lib/engine-components/avatar/AvatarEyeLook_Rotation.js.map +0 -1
  311. package/lib/engine-components/avatar/Avatar_Brain_LookAt.d.ts +0 -29
  312. package/lib/engine-components/avatar/Avatar_Brain_LookAt.js +0 -122
  313. package/lib/engine-components/avatar/Avatar_Brain_LookAt.js.map +0 -1
  314. package/lib/engine-components/avatar/Avatar_MouthShapes.d.ts +0 -15
  315. package/lib/engine-components/avatar/Avatar_MouthShapes.js +0 -80
  316. package/lib/engine-components/avatar/Avatar_MouthShapes.js.map +0 -1
  317. package/lib/engine-components/avatar/Avatar_MustacheShake.d.ts +0 -9
  318. package/lib/engine-components/avatar/Avatar_MustacheShake.js +0 -30
  319. package/lib/engine-components/avatar/Avatar_MustacheShake.js.map +0 -1
  320. package/src/engine-components/AvatarLoader.ts +0 -264
  321. package/src/engine-components/avatar/AvatarBlink_Simple.ts +0 -70
  322. package/src/engine-components/avatar/AvatarEyeLook_Rotation.ts +0 -64
  323. package/src/engine-components/avatar/Avatar_Brain_LookAt.ts +0 -140
  324. package/src/engine-components/avatar/Avatar_MouthShapes.ts +0 -84
  325. package/src/engine-components/avatar/Avatar_MustacheShake.ts +0 -32
  326. package/src/vite-env.d.ts +0 -16
@@ -3,23 +3,37 @@ import { ContextEvent, ContextRegistry } from "./engine_context_registry.js";
3
3
  import { onInitialized } from "./engine_lifecycle_api.js";
4
4
  import { isLocalNetwork } from "./engine_networking_utils.js";
5
5
  import { Context } from "./engine_setup.js";
6
+ import { SSR } from "./engine_ssr.js";
6
7
  import type { IContext } from "./engine_types.js";
7
8
  import { getParam } from "./engine_utils.js";
8
- import { SSR } from "./engine_ssr.js";
9
9
 
10
- const debug = getParam("debuglicense");
10
+ const debug = getParam("__debuglic__");
11
+
12
+ const $nNBkvau: ((result: boolean) => void)[] = [];
11
13
 
12
- const _licenseCheckResultChangedCallbacks: ((result: boolean) => void)[] = [];
14
+ // DO NOT EDIT MANUALLY
15
+ let _Ktp: string = "";
16
+ // eslint-disable-next-line prefer-const
17
+ let _HXKeIG: string = "";
13
18
 
14
- // This is modified by a bundler (e.g. vite)
15
- // Do not edit manually
16
- let NEEDLE_ENGINE_LICENSE_TYPE: string = "basic";
17
- if (debug)
18
- console.log("License Type: " + NEEDLE_ENGINE_LICENSE_TYPE)
19
+ if (debug) {
20
+ console.log("License Type: " + _Ktp);
21
+ if (_HXKeIG) {
22
+ console.log("License JWT: " + _HXKeIG);
23
+ try {
24
+ const payload = JSON.parse(atob(_HXKeIG.split(".")[1].replace(/-/g, '+').replace(/_/g, '/')));
25
+ console.log("License JWT payload:", payload);
26
+ }
27
+ catch { console.log("License JWT payload: (failed to decode)"); }
28
+ }
29
+ else {
30
+ console.log("License JWT: (none)");
31
+ }
32
+ }
19
33
 
20
34
  /** @internal */
21
- export function hasProLicense() {
22
- switch (NEEDLE_ENGINE_LICENSE_TYPE) {
35
+ export function $TXm() {
36
+ switch (_Ktp) {
23
37
  case "pro":
24
38
  case "enterprise":
25
39
  return true;
@@ -28,8 +42,8 @@ export function hasProLicense() {
28
42
  }
29
43
 
30
44
  /** @internal */
31
- export function hasIndieLicense() {
32
- switch (NEEDLE_ENGINE_LICENSE_TYPE) {
45
+ export function __CYjiNy() {
46
+ switch (_Ktp) {
33
47
  case "indie":
34
48
  return true;
35
49
  }
@@ -37,8 +51,8 @@ export function hasIndieLicense() {
37
51
  }
38
52
 
39
53
  /** @internal */
40
- export function hasEduLicense() {
41
- switch (NEEDLE_ENGINE_LICENSE_TYPE) {
54
+ export function _$qXuwVrGy() {
55
+ switch (_Ktp) {
42
56
  case "edu":
43
57
  return true;
44
58
  }
@@ -46,20 +60,20 @@ export function hasEduLicense() {
46
60
  }
47
61
 
48
62
  /** @internal */
49
- export function hasCommercialLicense() {
50
- return hasProLicense() || hasIndieLicense() || hasEduLicense();
63
+ export function __gGoBKfJa() {
64
+ return $TXm() || __CYjiNy() || _$qXuwVrGy();
51
65
  }
52
66
 
53
67
 
54
68
  /** @internal */
55
- export function onLicenseCheckResultChanged(cb: (result: boolean) => void) {
56
- if (hasProLicense() || hasIndieLicense() || hasEduLicense())
69
+ export function _MFjTEBcQ(cb: (result: boolean) => void) {
70
+ if ($TXm() || __CYjiNy() || _$qXuwVrGy())
57
71
  return cb(true);
58
- _licenseCheckResultChangedCallbacks.push(cb);
72
+ $nNBkvau.push(cb);
59
73
  }
60
74
 
61
- function invokeLicenseCheckResultChanged(result: boolean) {
62
- for (const cb of _licenseCheckResultChangedCallbacks) {
75
+ function __AiHRn(result: boolean) {
76
+ for (const cb of $nNBkvau) {
63
77
  try {
64
78
  cb(result);
65
79
  }
@@ -70,6 +84,128 @@ function invokeLicenseCheckResultChanged(result: boolean) {
70
84
  }
71
85
 
72
86
 
87
+ // #region JWT
88
+
89
+ // ECDSA P-256 public key for verifying license JWTs (verification-only, safe to ship)
90
+ /* eslint-disable no-secrets/no-secrets -- public key, not a secret */
91
+ const __jOdcGEzl = {
92
+ kty: "EC",
93
+ crv: "P-256",
94
+ x: "A34nyKMjhQYVgzeE4tyLUYdx34TAKogDa7v7PRaO9Lg",
95
+ y: "JZI9IQavGCpGjEG_-pa0J-MHQYWJYINUM-MnvSu0TmE",
96
+ } as const;
97
+ /* eslint-enable no-secrets/no-secrets */
98
+
99
+ /** Base64url decode (RFC 7515) */
100
+ function base64urlDecode(str: string): Uint8Array {
101
+ const base64 = str.replace(/-/g, '+').replace(/_/g, '/');
102
+ const padded = base64 + '='.repeat((4 - base64.length % 4) % 4);
103
+ const binary = atob(padded);
104
+ const bytes = new Uint8Array(binary.length);
105
+ for (let i = 0; i < binary.length; i++) {
106
+ bytes[i] = binary.charCodeAt(i);
107
+ }
108
+ return bytes;
109
+ }
110
+
111
+ /**
112
+ * Verify a JWT license token and return the `type` claim if valid.
113
+ * Returns null if the JWT is missing, malformed, or has an invalid signature.
114
+ */
115
+ async function __sGba(jwt: string): Promise<string | null> {
116
+ if (!jwt) return null;
117
+ try {
118
+ const parts = jwt.split(".");
119
+ if (parts.length !== 3) return null;
120
+
121
+ const [headerB64, payloadB64, signatureB64] = parts;
122
+
123
+ const key = await crypto.subtle.importKey(
124
+ "jwk",
125
+ __jOdcGEzl,
126
+ { name: "ECDSA", namedCurve: "P-256" },
127
+ false,
128
+ ["verify"]
129
+ );
130
+
131
+ const signingInput = new TextEncoder().encode(`${headerB64}.${payloadB64}`);
132
+ const signature = base64urlDecode(signatureB64);
133
+
134
+ const valid = await crypto.subtle.verify(
135
+ { name: "ECDSA", hash: "SHA-256" },
136
+ key,
137
+ signature.buffer as ArrayBuffer,
138
+ signingInput
139
+ );
140
+
141
+ if (!valid) {
142
+ if (debug) console.warn("JWT: signature verification failed");
143
+ return null;
144
+ }
145
+
146
+ const payloadStr = new TextDecoder().decode(base64urlDecode(payloadB64));
147
+ const payload = JSON.parse(payloadStr);
148
+
149
+ if (typeof payload.type !== "string" || payload.type.length === 0) {
150
+ if (debug) console.warn("JWT: missing or invalid 'type' claim");
151
+ return null;
152
+ }
153
+
154
+ // Optional: check expiration if present (future-proof — server doesn't set this yet)
155
+ if (typeof payload.exp === "number") {
156
+ const nowSeconds = Math.floor(Date.now() / 1000);
157
+ if (nowSeconds > payload.exp) {
158
+ if (debug) console.warn("JWT: token has expired (exp=" + payload.exp + ", now=" + nowSeconds + ")");
159
+ return null;
160
+ }
161
+ }
162
+
163
+ // Optional: check audience/domain if present (future-proof — server doesn't set this yet)
164
+ if (payload.aud) {
165
+ const currentHost = typeof window !== "undefined" ? window.location.hostname : undefined;
166
+ if (currentHost) {
167
+ const allowed = Array.isArray(payload.aud) ? payload.aud : [payload.aud];
168
+ if (!allowed.some((a: string) => currentHost === a || currentHost.endsWith("." + a))) {
169
+ if (debug) console.warn("JWT: domain '" + currentHost + "' not in allowed audience: " + allowed.join(", "));
170
+ return null;
171
+ }
172
+ }
173
+ }
174
+
175
+ if (debug) console.log("JWT: verified license type: " + payload.type);
176
+ return payload.type;
177
+ }
178
+ catch (err) {
179
+ if (debug) console.error("JWT: verification error", err);
180
+ return null;
181
+ }
182
+ }
183
+
184
+ /** Verify the injected JWT and update the license type if valid.
185
+ * The engine ONLY trusts the JWT — the plain _Ktp string is ignored. */
186
+ let _jwtVerificationPromise: Promise<void> | undefined = undefined;
187
+ async function $IHlIUG(): Promise<void> {
188
+ // NOTE: do NOT add an `if (!_HXKeIG) return` guard here.
189
+ // esbuild (Vite dependency pre-bundling) would see the variable as constant ""
190
+ // and tree-shake the entire JWT verification code path.
191
+ const jwt = _HXKeIG;
192
+ // Clear after reading — this reassignment also prevents esbuild from
193
+ // constant-folding the variable (it now has multiple assignment sites).
194
+ _HXKeIG = "";
195
+ const verifiedType = await __sGba(jwt);
196
+ if (verifiedType) {
197
+ _Ktp = verifiedType;
198
+ if (debug) console.log("License type set from verified JWT: " + verifiedType);
199
+ __AiHRn(__gGoBKfJa());
200
+ }
201
+ else {
202
+ _Ktp = "basic";
203
+ if (debug && jwt) console.warn("JWT verification failed — license reset to basic");
204
+ }
205
+ }
206
+
207
+ // #endregion JWT License Verification
208
+
73
209
 
74
210
  // #region Telemetry
75
211
  export namespace Telemetry {
@@ -135,7 +271,7 @@ export namespace Telemetry {
135
271
 
136
272
  const attribute = domElement?.getAttribute("no-telemetry");
137
273
  if (attribute === "" || attribute === "true" || attribute === "1") {
138
- if (NEEDLE_ENGINE_LICENSE_TYPE === "pro" || NEEDLE_ENGINE_LICENSE_TYPE === "enterprise") {
274
+ if (_Ktp === "pro" || _Ktp === "enterprise") {
139
275
  if (debug) console.debug("Telemetry is disabled via no-telemetry attribute");
140
276
  return false;
141
277
  }
@@ -242,22 +378,32 @@ export namespace Telemetry {
242
378
  }
243
379
 
244
380
 
245
- export function initLicense() {
381
+ export function YftDqQmq() {
382
+
383
+ if(_Ktp === "") _Ktp = "basic";
384
+
385
+ // Start JWT verification — must be here (not top-level) to avoid tree-shaking
386
+ _jwtVerificationPromise = $IHlIUG();
387
+
246
388
  Telemetry.init();
247
389
  ContextRegistry.registerCallback(ContextEvent.ContextRegistered, evt => {
248
- showLicenseInfo(evt.context);
249
- handleForbidden(evt.context);
250
- setTimeout(() => sendUsageMessageToAnalyticsBackend(evt.context), 2000);
390
+ $zlkki(evt.context);
391
+ __sRmQXZcI(evt.context);
392
+ setTimeout(() => __QwnVOJb(evt.context), 2000);
251
393
  });
252
394
  }
253
395
 
254
- export let runtimeLicenseCheckPromise: Promise<void> | undefined = undefined;
396
+ export let $NzCTiAr: Promise<void> | undefined = undefined;
255
397
  let applicationIsForbidden = false;
256
398
  let applicationForbiddenText = "";
257
- async function checkLicense() {
399
+ async function _eUjaC() {
258
400
  // Only perform the runtime license check once
259
- if (runtimeLicenseCheckPromise) return runtimeLicenseCheckPromise;
260
- if (NEEDLE_ENGINE_LICENSE_TYPE === "basic") {
401
+ if ($NzCTiAr) return $NzCTiAr;
402
+ // Wait for JWT verification to complete first (if running)
403
+ if (_jwtVerificationPromise) {
404
+ await _jwtVerificationPromise;
405
+ }
406
+ if (_Ktp === "basic") {
261
407
  try {
262
408
  const licenseUrl = "https://needle.tools/api/v1/needle-engine/check?location=" + encodeURIComponent(window.location.href) + "&version=" + VERSION + "&generator=" + encodeURIComponent(GENERATOR);
263
409
  const res = await fetch(licenseUrl, {
@@ -269,29 +415,29 @@ async function checkLicense() {
269
415
  if (res?.status === 200) {
270
416
  applicationIsForbidden = false;
271
417
  if (debug) console.log("License check succeeded");
272
- NEEDLE_ENGINE_LICENSE_TYPE = "pro";
273
- invokeLicenseCheckResultChanged(true);
418
+ _Ktp = "pro";
419
+ __AiHRn(true);
274
420
  }
275
421
  else if (res?.status === 403) {
276
- invokeLicenseCheckResultChanged(false);
422
+ __AiHRn(false);
277
423
  applicationIsForbidden = true;
278
424
  applicationForbiddenText = await res.text();
279
425
  }
280
426
  else {
281
- invokeLicenseCheckResultChanged(false);
427
+ __AiHRn(false);
282
428
  if (debug) console.log("License check failed with status " + res?.status);
283
429
  }
284
430
  }
285
431
  catch (err) {
286
- invokeLicenseCheckResultChanged(false);
432
+ __AiHRn(false);
287
433
  if (debug) console.error("License check failed", err);
288
434
  }
289
435
  }
290
- else if (debug) console.log("Runtime license check is skipped because license is already applied as \"" + NEEDLE_ENGINE_LICENSE_TYPE + "\"");
436
+ else if (debug) console.log("Runtime license check is skipped because license is already applied as \"" + _Ktp + "\"");
291
437
  }
292
- runtimeLicenseCheckPromise = checkLicense();
438
+ $NzCTiAr = _eUjaC();
293
439
 
294
- async function handleForbidden(ctx: IContext) {
440
+ async function __sRmQXZcI(ctx: IContext) {
295
441
  function createForbiddenElement() {
296
442
  const div = document.createElement("div");
297
443
  div.className = "needle-forbidden";
@@ -356,40 +502,40 @@ async function handleForbidden(ctx: IContext) {
356
502
  }, 500)
357
503
  }
358
504
 
359
- async function showLicenseInfo(ctx: IContext) {
505
+ async function $zlkki(ctx: IContext) {
360
506
  try {
361
- if (!hasProLicense() && !hasIndieLicense()) {
362
- return onNonCommercialVersionDetected(ctx);
507
+ if (!$TXm() && !__CYjiNy()) {
508
+ return _$ZUnMZ(ctx);
363
509
  }
364
510
  }
365
511
  catch (err) {
366
512
  if (debug) console.log("License check failed", err)
367
- return onNonCommercialVersionDetected(ctx)
513
+ return _$ZUnMZ(ctx)
368
514
  }
369
- if (debug) onNonCommercialVersionDetected(ctx)
515
+ if (debug) _$ZUnMZ(ctx)
370
516
  }
371
517
 
372
518
 
373
519
 
374
- async function onNonCommercialVersionDetected(ctx: IContext) {
520
+ async function _$ZUnMZ(ctx: IContext) {
375
521
 
376
522
  // if the engine loads faster than the license check, we need to capture the ready event here
377
523
  let isReady = false;
378
524
  ctx.domElement.addEventListener("ready", () => isReady = true);
379
525
 
380
- await runtimeLicenseCheckPromise?.catch(() => { });
526
+ await $NzCTiAr?.catch(() => { });
381
527
 
382
528
 
383
- if (hasProLicense() || hasIndieLicense()) return;
384
- if (hasCommercialLicense() === false) logNonCommercialUse();
529
+ if ($TXm() || __CYjiNy()) return;
530
+ if (__gGoBKfJa() === false) $wrvl();
385
531
 
386
532
  // check if the engine is already ready (meaning has finished loading)
387
533
  if (isReady) {
388
- insertNonCommercialUseHint(ctx);
534
+ $fObl(ctx);
389
535
  }
390
536
  else {
391
537
  ctx.domElement.addEventListener("ready", () => {
392
- insertNonCommercialUseHint(ctx);
538
+ $fObl(ctx);
393
539
  });
394
540
  }
395
541
  }
@@ -397,7 +543,7 @@ async function onNonCommercialVersionDetected(ctx: IContext) {
397
543
  // const licenseElementIdentifier = "needle-license-element";
398
544
  // const licenseDuration = 10000;
399
545
  // const licenseDelay = 1200;
400
- function insertNonCommercialUseHint(ctx: IContext) {
546
+ function $fObl(ctx: IContext) {
401
547
 
402
548
  const style = `
403
549
  position: relative;
@@ -410,7 +556,7 @@ function insertNonCommercialUseHint(ctx: IContext) {
410
556
  padding: 10px;
411
557
  padding-left: 30px;
412
558
  `;
413
- if (NEEDLE_ENGINE_LICENSE_TYPE === "edu") {
559
+ if (_Ktp === "edu") {
414
560
  if (navigator.webdriver) {
415
561
  console.log("This project is supported by Needle for Education – https://needle.tools");
416
562
  }
@@ -467,7 +613,7 @@ function insertNonCommercialUseHint(ctx: IContext) {
467
613
  }
468
614
  }, 1000);
469
615
 
470
- if (hasEduLicense()) {
616
+ if (_$qXuwVrGy()) {
471
617
  const removeDelay = 20_000;
472
618
  setTimeout(() => {
473
619
  clearInterval(interval);
@@ -476,7 +622,7 @@ function insertNonCommercialUseHint(ctx: IContext) {
476
622
  const intervalInMinutes = 5;
477
623
  setTimeout(() => {
478
624
  if (ctx.domElement.parentNode)
479
- insertNonCommercialUseHint(ctx);
625
+ $fObl(ctx);
480
626
  }, 1000 * 60 * intervalInMinutes)
481
627
  }, removeDelay);
482
628
  }
@@ -487,7 +633,7 @@ function insertNonCommercialUseHint(ctx: IContext) {
487
633
  const base64Logo = "data:image/webp;base64,UklGRrABAABXRUJQVlA4WAoAAAAQAAAAHwAAHwAAQUxQSKEAAAARN6CmbSM4WR7vdARON11EBDq3fLiNbVtVzpMCPlKAEzsx0Y/x+Ovuv4dn0EFE/ydAvz6YggXzgh5sVgXM/zOC/4sii7qgGvB5N7hmuQYwkvazWAu1JPW41FXSHq6pnaQWvqYH18Fc0j1hO/BFTtIeSBlJi5w6qIIO7IOrwhFsB2Yxukif0FTRLpXswHR8MxbslKe9VZsn/Ub5C7YFOpqSTABWUDgg6AAAAFAGAJ0BKiAAIAA+7VyoTqmkpCI3+qgBMB2JbACdMt69DwMIQBLhkTO6XwY00UEDK6cNIDnuNibPf0EgAP7Y1myuiQHLDsF/0h5unrGh6WAbv7aegg2ZMd3uRKfT/3SJztcaujYfTvMXspfCTmYcoO6a+vhC3ss4M8uM58t4siiu59I4aOl59e9Sr6xoxYlHf2v+NnBNpJYeJf8jABQAId/PXuBkLEFkiCucgSGEcfhvajql/j3reCGl0M5/9gQWy7ayNPs+wlvIxFnNfSlfuND4CZOCyxOHhRqOmHN4ULHo3tCSrUNvgAA=";
488
634
 
489
635
  let lastLogTime = 0;
490
- async function logNonCommercialUse(_logo?: string) {
636
+ async function $wrvl(_logo?: string) {
491
637
  const now = Date.now();
492
638
  if (now - lastLogTime < 2000) return;
493
639
  lastLogTime = now;
@@ -520,7 +666,7 @@ async function logNonCommercialUse(_logo?: string) {
520
666
  }
521
667
 
522
668
 
523
- async function sendUsageMessageToAnalyticsBackend(context: IContext) {
669
+ async function __QwnVOJb(context: IContext) {
524
670
  // We can't send beacons from cross-origin isolated pages
525
671
  if (window.crossOriginIsolated) return;
526
672
 
@@ -535,7 +681,7 @@ async function sendUsageMessageToAnalyticsBackend(context: IContext) {
535
681
 
536
682
  // current url without query parameters
537
683
  const currentUrl = window.location.href.split("?")[0];
538
- const license = NEEDLE_ENGINE_LICENSE_TYPE;
684
+ const license = _Ktp;
539
685
 
540
686
  const beaconData = {
541
687
  license,
@@ -344,8 +344,11 @@ function updateIsActiveInHierarchyRecursiveRuntime(go: Object3D, activeInHierarc
344
344
  if (allowEventCall) {
345
345
  const components = go.userData?.components;
346
346
  if (components) {
347
- for (let ci = components.length - 1, cl = -1; ci > cl; ci--) {
348
- const comp = components[ci];
347
+ // We need to iterate on components in the original order right now to work-around UI related initialization bugs where RectTransform must be initialized before e.g. Graphic components. https://linear.app/needle/issue/NE-6986
348
+ // In the future we can reverse iterate this once the UI system has been replaced (that being said it's probably expected that component enable in the order in which they're added to an object)
349
+ const componentsCopy = [...components];
350
+ for (let ci = 0; ci < componentsCopy.length; ci++) {
351
+ const comp = componentsCopy[ci];
349
352
  if (activeInHierarchy) {
350
353
  if (comp?.enabled) {
351
354
  try { comp.__internalAwake(); }
@@ -357,8 +360,8 @@ function updateIsActiveInHierarchyRecursiveRuntime(go: Object3D, activeInHierarc
357
360
  }
358
361
  else if(comp) {
359
362
  if (comp["__didAwake"] && comp.enabled) {
360
- comp["__didEnable"] = false;
361
- comp.onDisable();
363
+ // autoCleanup uses __internalDisable; isRemovingFromScene=true preserves __isEnabled
364
+ comp.__internalDisable(true);
362
365
  }
363
366
  }
364
367
  }
@@ -0,0 +1,45 @@
1
+ import type { INetworkTransport } from './engine_networking_types.js';
2
+
3
+ /** Default transport that wraps the `websocket-ts` library */
4
+ export class WebsocketTransport implements INetworkTransport {
5
+ private _url: string;
6
+ private _ws: import('websocket-ts').Websocket | undefined;
7
+
8
+ onOpen: (() => void) | null = null;
9
+ onClose: (() => void) | null = null;
10
+ onError: ((err: any) => void) | null = null;
11
+ onMessage: ((data: string | Blob) => void) | null = null;
12
+
13
+ get url() { return this._ws?.url ?? this._url; }
14
+
15
+ constructor(url: string) {
16
+ this._url = url;
17
+ }
18
+
19
+ async start() {
20
+ const pkg = await import('websocket-ts');
21
+ // @ts-ignore
22
+ const WebsocketBuilder = pkg.default?.WebsocketBuilder ?? pkg.WebsocketBuilder;
23
+ const ExponentialBackoff = pkg.default?.ExponentialBackoff ?? pkg.ExponentialBackoff;
24
+ const ws = new WebsocketBuilder(this._url)
25
+ .withMaxRetries(10)
26
+ .withBackoff(new ExponentialBackoff(2000, 4))
27
+ .onOpen(() => { this._ws = ws; this.onOpen?.(); })
28
+ .onClose(() => { this.onClose?.(); })
29
+ .onError(() => { this.onError?.(new Error("Websocket connection failed")); })
30
+ .onRetry(() => { console.log("Retry connecting to networking websocket"); })
31
+ .build();
32
+ ws.addEventListener(pkg.WebsocketEvent.message, (_, msg) => {
33
+ this.onMessage?.(msg.data);
34
+ });
35
+ }
36
+
37
+ send(data: string | Uint8Array) {
38
+ this._ws?.send(data);
39
+ }
40
+
41
+ close() {
42
+ this._ws?.close();
43
+ this._ws = undefined;
44
+ }
45
+ }