node-opcua-address-space 2.71.0 → 2.72.2

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 (408) hide show
  1. package/dist/source/address_space_ts.d.ts +118 -118
  2. package/dist/source/address_space_ts.js +17 -17
  3. package/dist/source/continuation_points/continuation_point_manager.d.ts +32 -32
  4. package/dist/source/continuation_points/continuation_point_manager.js +195 -195
  5. package/dist/source/helpers/adjust_browse_direction.d.ts +5 -5
  6. package/dist/source/helpers/adjust_browse_direction.js +11 -11
  7. package/dist/source/helpers/argument_list.d.ts +34 -34
  8. package/dist/source/helpers/argument_list.js +285 -285
  9. package/dist/source/helpers/call_helpers.d.ts +6 -6
  10. package/dist/source/helpers/call_helpers.js +70 -70
  11. package/dist/source/helpers/check_event_clause.d.ts +17 -17
  12. package/dist/source/helpers/check_event_clause.js +52 -52
  13. package/dist/source/helpers/coerce_enum_value.d.ts +6 -6
  14. package/dist/source/helpers/coerce_enum_value.js +33 -33
  15. package/dist/source/helpers/dump_tools.d.ts +14 -14
  16. package/dist/source/helpers/dump_tools.js +78 -78
  17. package/dist/source/helpers/ensure_secure_access.d.ts +9 -9
  18. package/dist/source/helpers/ensure_secure_access.js +76 -76
  19. package/dist/source/helpers/make_optionals_map.d.ts +21 -21
  20. package/dist/source/helpers/make_optionals_map.js +29 -29
  21. package/dist/source/helpers/multiform_func.d.ts +11 -11
  22. package/dist/source/helpers/multiform_func.js +73 -73
  23. package/dist/source/helpers/resolve_opaque_on_address_space.d.ts +3 -3
  24. package/dist/source/helpers/resolve_opaque_on_address_space.js +36 -36
  25. package/dist/source/index.d.ts +40 -40
  26. package/dist/source/index.js +66 -66
  27. package/dist/source/interfaces/alarms_and_conditions/condition_info_i.d.ts +12 -12
  28. package/dist/source/interfaces/alarms_and_conditions/condition_info_i.js +2 -2
  29. package/dist/source/interfaces/data_access/ua_multistate_discrete_ex.d.ts +21 -21
  30. package/dist/source/interfaces/data_access/ua_multistate_discrete_ex.js +2 -2
  31. package/dist/source/interfaces/data_access/ua_multistate_value_discrete_ex.d.ts +24 -24
  32. package/dist/source/interfaces/data_access/ua_multistate_value_discrete_ex.js +2 -2
  33. package/dist/source/interfaces/data_access/ua_two_state_discrete_ex.d.ts +12 -12
  34. package/dist/source/interfaces/data_access/ua_two_state_discrete_ex.js +2 -2
  35. package/dist/source/interfaces/data_access/ua_y_array_item_ex.d.ts +8 -8
  36. package/dist/source/interfaces/data_access/ua_y_array_item_ex.js +2 -2
  37. package/dist/source/interfaces/state_machine/ua_exclusive_limit_state_machine_type_ex.d.ts +12 -12
  38. package/dist/source/interfaces/state_machine/ua_exclusive_limit_state_machine_type_ex.js +2 -2
  39. package/dist/source/interfaces/state_machine/ua_finite_state_machine_type.d.ts +49 -49
  40. package/dist/source/interfaces/state_machine/ua_finite_state_machine_type.js +2 -2
  41. package/dist/source/interfaces/state_machine/ua_program_state_machine_type.d.ts +11 -11
  42. package/dist/source/interfaces/state_machine/ua_program_state_machine_type.js +2 -2
  43. package/dist/source/interfaces/state_machine/ua_state_machine_type.d.ts +222 -222
  44. package/dist/source/interfaces/state_machine/ua_state_machine_type.js +2 -2
  45. package/dist/source/interfaces/state_machine/ua_transition_ex.d.ts +6 -6
  46. package/dist/source/interfaces/state_machine/ua_transition_ex.js +2 -2
  47. package/dist/source/interfaces/ua_subscription_diagnostics_variable_ex.d.ts +8 -8
  48. package/dist/source/interfaces/ua_subscription_diagnostics_variable_ex.js +2 -2
  49. package/dist/source/loader/decode_xml_extension_object.d.ts +6 -6
  50. package/dist/source/loader/decode_xml_extension_object.js +71 -71
  51. package/dist/source/loader/ensure_datatype_extracted.d.ts +5 -5
  52. package/dist/source/loader/ensure_datatype_extracted.js +45 -45
  53. package/dist/source/loader/generateAddressSpaceRaw.d.ts +10 -10
  54. package/dist/source/loader/generateAddressSpaceRaw.js +45 -45
  55. package/dist/source/loader/load_nodeset2.d.ts +16 -16
  56. package/dist/source/loader/load_nodeset2.js +1468 -1464
  57. package/dist/source/loader/load_nodeset2.js.map +1 -1
  58. package/dist/source/loader/make_semver_compatible.d.ts +6 -0
  59. package/dist/source/loader/make_semver_compatible.js +26 -0
  60. package/dist/source/loader/make_semver_compatible.js.map +1 -0
  61. package/dist/source/loader/make_xml_extension_object_parser.d.ts +28 -28
  62. package/dist/source/loader/make_xml_extension_object_parser.js +325 -315
  63. package/dist/source/loader/make_xml_extension_object_parser.js.map +1 -1
  64. package/dist/source/loader/namespace_post_step.d.ts +6 -6
  65. package/dist/source/loader/namespace_post_step.js +47 -47
  66. package/dist/source/loader/register_node_promoter.d.ts +3 -3
  67. package/dist/source/loader/register_node_promoter.js +9 -9
  68. package/dist/source/namespace.d.ts +6 -6
  69. package/dist/source/namespace.js +2 -2
  70. package/dist/source/namespace_alarm_and_condition.d.ts +24 -24
  71. package/dist/source/namespace_alarm_and_condition.js +2 -2
  72. package/dist/source/namespace_data_access.d.ts +42 -42
  73. package/dist/source/namespace_data_access.js +2 -2
  74. package/dist/source/namespace_machine_state.d.ts +7 -7
  75. package/dist/source/namespace_machine_state.js +2 -2
  76. package/dist/source/pseudo_session.d.ts +55 -55
  77. package/dist/source/pseudo_session.js +203 -203
  78. package/dist/source/session_context.d.ts +111 -111
  79. package/dist/source/session_context.js +265 -265
  80. package/dist/source/set_namespace_meta_data.d.ts +2 -2
  81. package/dist/source/set_namespace_meta_data.js +59 -59
  82. package/dist/source/ua_root_folder.d.ts +9 -9
  83. package/dist/source/ua_root_folder.js +2 -2
  84. package/dist/source/ua_two_state_variable_ex.d.ts +23 -23
  85. package/dist/source/ua_two_state_variable_ex.js +2 -2
  86. package/dist/source/xml_writer.d.ts +9 -9
  87. package/dist/source/xml_writer.js +2 -2
  88. package/dist/src/address_space.d.ts +392 -392
  89. package/dist/src/address_space.js +1387 -1387
  90. package/dist/src/address_space_change_event_tools.d.ts +6 -6
  91. package/dist/src/address_space_change_event_tools.js +149 -149
  92. package/dist/src/address_space_private.d.ts +43 -43
  93. package/dist/src/address_space_private.js +2 -2
  94. package/dist/src/alarms_and_conditions/check_where_clause.d.ts +4 -4
  95. package/dist/src/alarms_and_conditions/check_where_clause.js +109 -109
  96. package/dist/src/alarms_and_conditions/condition.d.ts +5 -5
  97. package/dist/src/alarms_and_conditions/condition.js +80 -80
  98. package/dist/src/alarms_and_conditions/condition_info.d.ts +27 -27
  99. package/dist/src/alarms_and_conditions/condition_info.js +54 -54
  100. package/dist/src/alarms_and_conditions/condition_snapshot.d.ts +233 -233
  101. package/dist/src/alarms_and_conditions/condition_snapshot.js +666 -666
  102. package/dist/src/alarms_and_conditions/deviation_alarm_helper.d.ts +21 -21
  103. package/dist/src/alarms_and_conditions/deviation_alarm_helper.js +46 -46
  104. package/dist/src/alarms_and_conditions/extract_event_fields.d.ts +10 -10
  105. package/dist/src/alarms_and_conditions/extract_event_fields.js +89 -89
  106. package/dist/src/alarms_and_conditions/index.d.ts +18 -18
  107. package/dist/src/alarms_and_conditions/index.js +34 -34
  108. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_impl.d.ts +64 -62
  109. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_impl.js +244 -244
  110. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_impl.js.map +1 -1
  111. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.d.ts +124 -118
  112. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.js +416 -416
  113. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.js.map +1 -1
  114. package/dist/src/alarms_and_conditions/ua_base_event_impl.d.ts +29 -29
  115. package/dist/src/alarms_and_conditions/ua_base_event_impl.js +38 -38
  116. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.d.ts +36 -21
  117. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.js +115 -25
  118. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.js.map +1 -1
  119. package/dist/src/alarms_and_conditions/ua_condition_impl.d.ts +187 -182
  120. package/dist/src/alarms_and_conditions/ua_condition_impl.js +1024 -1022
  121. package/dist/src/alarms_and_conditions/ua_condition_impl.js.map +1 -1
  122. package/dist/src/alarms_and_conditions/ua_discrete_alarm_impl.d.ts +18 -17
  123. package/dist/src/alarms_and_conditions/ua_discrete_alarm_impl.js +57 -57
  124. package/dist/src/alarms_and_conditions/ua_discrete_alarm_impl.js.map +1 -1
  125. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.d.ts +30 -27
  126. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.js +56 -56
  127. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.js.map +1 -1
  128. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm_impl.d.ts +11 -9
  129. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm_impl.js +11 -11
  130. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm_impl.js.map +1 -1
  131. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.d.ts +40 -38
  132. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.js +86 -86
  133. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.js.map +1 -1
  134. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm_impl.d.ts +10 -10
  135. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm_impl.js +7 -7
  136. package/dist/src/alarms_and_conditions/ua_limit_alarm_impl.d.ts +105 -97
  137. package/dist/src/alarms_and_conditions/ua_limit_alarm_impl.js +250 -250
  138. package/dist/src/alarms_and_conditions/ua_limit_alarm_impl.js.map +1 -1
  139. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.d.ts +29 -28
  140. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.js +50 -50
  141. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.js.map +1 -1
  142. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.d.ts +26 -25
  143. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.js +162 -162
  144. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.js.map +1 -1
  145. package/dist/src/alarms_and_conditions/ua_off_normal_alarm_impl.d.ts +48 -39
  146. package/dist/src/alarms_and_conditions/ua_off_normal_alarm_impl.js +161 -135
  147. package/dist/src/alarms_and_conditions/ua_off_normal_alarm_impl.js.map +1 -1
  148. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.d.ts +17 -16
  149. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.js +17 -17
  150. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.js.map +1 -1
  151. package/dist/src/apply_condition_refresh.d.ts +6 -6
  152. package/dist/src/apply_condition_refresh.js +27 -27
  153. package/dist/src/base_node_impl.d.ts +281 -281
  154. package/dist/src/base_node_impl.js +1395 -1395
  155. package/dist/src/base_node_private.d.ts +61 -61
  156. package/dist/src/base_node_private.js +705 -705
  157. package/dist/src/data_access/add_dataItem_stuff.d.ts +11 -11
  158. package/dist/src/data_access/add_dataItem_stuff.js +61 -61
  159. package/dist/src/data_access/check_variant_compatibility_ua_analog_item.d.ts +1 -1
  160. package/dist/src/data_access/check_variant_compatibility_ua_analog_item.js +34 -34
  161. package/dist/src/data_access/ua_multistate_discrete_impl.d.ts +32 -32
  162. package/dist/src/data_access/ua_multistate_discrete_impl.js +130 -130
  163. package/dist/src/data_access/ua_multistate_value_discrete.d.ts +51 -51
  164. package/dist/src/data_access/ua_multistate_value_discrete.js +249 -249
  165. package/dist/src/data_access/ua_two_state_discrete.d.ts +25 -25
  166. package/dist/src/data_access/ua_two_state_discrete.js +153 -153
  167. package/dist/src/event_data.d.ts +29 -29
  168. package/dist/src/event_data.js +95 -95
  169. package/dist/src/extension_object_array_node.d.ts +61 -61
  170. package/dist/src/extension_object_array_node.js +276 -276
  171. package/dist/src/historical_access/address_space_historical_data_node.d.ts +26 -26
  172. package/dist/src/historical_access/address_space_historical_data_node.js +630 -630
  173. package/dist/src/index_current.d.ts +45 -45
  174. package/dist/src/index_current.js +77 -77
  175. package/dist/src/namespace_impl.d.ts +457 -457
  176. package/dist/src/namespace_impl.js +1733 -1733
  177. package/dist/src/namespace_private.d.ts +21 -21
  178. package/dist/src/namespace_private.js +32 -32
  179. package/dist/src/nodeid_manager.d.ts +36 -36
  180. package/dist/src/nodeid_manager.js +197 -197
  181. package/dist/src/nodeset_tools/adjust_namespace_array.d.ts +2 -2
  182. package/dist/src/nodeset_tools/adjust_namespace_array.js +13 -13
  183. package/dist/src/nodeset_tools/construct_namespace_dependency.d.ts +2 -2
  184. package/dist/src/nodeset_tools/construct_namespace_dependency.js +83 -83
  185. package/dist/src/nodeset_tools/nodeset_to_xml.d.ts +2 -2
  186. package/dist/src/nodeset_tools/nodeset_to_xml.js +1143 -1143
  187. package/dist/src/nodeset_tools/typedictionary_to_xml.d.ts +2 -2
  188. package/dist/src/nodeset_tools/typedictionary_to_xml.js +154 -154
  189. package/dist/src/reference_impl.d.ts +43 -43
  190. package/dist/src/reference_impl.js +139 -139
  191. package/dist/src/role_permissions.d.ts +2 -2
  192. package/dist/src/role_permissions.js +10 -10
  193. package/dist/src/state_machine/finite_state_machine.d.ts +67 -67
  194. package/dist/src/state_machine/finite_state_machine.js +353 -353
  195. package/dist/src/state_machine/ua_shelving_state_machine_ex.d.ts +34 -34
  196. package/dist/src/state_machine/ua_shelving_state_machine_ex.js +250 -250
  197. package/dist/src/state_machine/ua_two_state_variable.d.ts +61 -61
  198. package/dist/src/state_machine/ua_two_state_variable.js +331 -331
  199. package/dist/src/tool_isSupertypeOf.d.ts +17 -17
  200. package/dist/src/tool_isSupertypeOf.js +108 -108
  201. package/dist/src/ua_condition_type.d.ts +8 -8
  202. package/dist/src/ua_condition_type.js +2 -2
  203. package/dist/src/ua_data_type_impl.d.ts +93 -93
  204. package/dist/src/ua_data_type_impl.js +368 -368
  205. package/dist/src/ua_method_impl.d.ts +41 -41
  206. package/dist/src/ua_method_impl.js +208 -208
  207. package/dist/src/ua_object_impl.d.ts +35 -33
  208. package/dist/src/ua_object_impl.js +162 -156
  209. package/dist/src/ua_object_impl.js.map +1 -1
  210. package/dist/src/ua_object_type_impl.d.ts +48 -48
  211. package/dist/src/ua_object_type_impl.js +124 -124
  212. package/dist/src/ua_reference_type_impl.d.ts +43 -43
  213. package/dist/src/ua_reference_type_impl.js +139 -139
  214. package/dist/src/ua_variable_impl.d.ts +351 -351
  215. package/dist/src/ua_variable_impl.js +1604 -1604
  216. package/dist/src/ua_variable_impl_ext_obj.d.ts +17 -17
  217. package/dist/src/ua_variable_impl_ext_obj.js +437 -437
  218. package/dist/src/ua_variable_type_impl.d.ts +62 -62
  219. package/dist/src/ua_variable_type_impl.js +570 -570
  220. package/dist/src/ua_view_impl.d.ts +19 -15
  221. package/dist/src/ua_view_impl.js +43 -36
  222. package/dist/src/ua_view_impl.js.map +1 -1
  223. package/distHelpers/add_event_generator_object.d.ts +3 -3
  224. package/distHelpers/add_event_generator_object.js +65 -65
  225. package/distHelpers/alarms_and_conditions_demo.d.ts +10 -10
  226. package/distHelpers/alarms_and_conditions_demo.js +114 -114
  227. package/distHelpers/assertHasMatchingReference.d.ts +19 -19
  228. package/distHelpers/assertHasMatchingReference.js +40 -40
  229. package/distHelpers/boiler_system.d.ts +113 -113
  230. package/distHelpers/boiler_system.js +395 -395
  231. package/distHelpers/create_minimalist_address_space_nodeset.d.ts +5 -5
  232. package/distHelpers/create_minimalist_address_space_nodeset.js +171 -171
  233. package/distHelpers/date_utils.d.ts +3 -3
  234. package/distHelpers/date_utils.js +9 -9
  235. package/distHelpers/dump_statemachine.js +127 -127
  236. package/distHelpers/get_address_space_fixture.d.ts +1 -1
  237. package/distHelpers/get_address_space_fixture.js +30 -30
  238. package/distHelpers/get_mini_address_space.d.ts +7 -7
  239. package/distHelpers/get_mini_address_space.js +36 -36
  240. package/distHelpers/index.d.ts +12 -12
  241. package/distHelpers/index.js +28 -28
  242. package/distHelpers/mock_session.d.ts +14 -14
  243. package/distHelpers/mock_session.js +25 -25
  244. package/distNodeJS/generate_address_space.d.ts +4 -4
  245. package/distNodeJS/generate_address_space.js +41 -41
  246. package/distNodeJS/index.d.ts +1 -1
  247. package/distNodeJS/index.js +17 -17
  248. package/package.json +23 -23
  249. package/source/loader/load_nodeset2.ts +21 -17
  250. package/source/loader/make_semver_compatible.ts +23 -0
  251. package/source/loader/make_xml_extension_object_parser.ts +16 -6
  252. package/src/alarms_and_conditions/ua_acknowledgeable_condition_impl.ts +13 -6
  253. package/src/alarms_and_conditions/ua_alarm_condition_impl.ts +15 -10
  254. package/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.ts +126 -10
  255. package/src/alarms_and_conditions/ua_condition_impl.ts +26 -13
  256. package/src/alarms_and_conditions/ua_discrete_alarm_impl.ts +10 -4
  257. package/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.ts +7 -6
  258. package/src/alarms_and_conditions/ua_exclusive_level_alarm_impl.ts +5 -3
  259. package/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.ts +7 -6
  260. package/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm_impl.ts +1 -1
  261. package/src/alarms_and_conditions/ua_limit_alarm_impl.ts +23 -13
  262. package/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.ts +6 -7
  263. package/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.ts +6 -7
  264. package/src/alarms_and_conditions/ua_off_normal_alarm_impl.ts +62 -30
  265. package/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.ts +5 -5
  266. package/src/ua_object_impl.ts +11 -3
  267. package/src/ua_view_impl.ts +6 -4
  268. package/test_helpers/test_fixtures/dataType_issue.xml +9 -9
  269. package/test_helpers/test_fixtures/nodeset_with_guid.xml +1442 -0
  270. package/test_helpers/test_fixtures/nodeset_with_int64_values.xml +31 -0
  271. package/dist/source/interfaces/alarms_and_conditions/ua_condition_base_i.d.ts +0 -23
  272. package/dist/source/interfaces/alarms_and_conditions/ua_condition_base_i.js +0 -3
  273. package/dist/source/interfaces/alarms_and_conditions/ua_condition_base_i.js.map +0 -1
  274. package/dist/source/interfaces/data_access/ua_discrete_item.d.ts +0 -6
  275. package/dist/source/interfaces/data_access/ua_discrete_item.js +0 -3
  276. package/dist/source/interfaces/data_access/ua_discrete_item.js.map +0 -1
  277. package/dist/source/interfaces/data_access/ua_multistate_discrete.d.ts +0 -25
  278. package/dist/source/interfaces/data_access/ua_multistate_discrete.js +0 -3
  279. package/dist/source/interfaces/data_access/ua_multistate_discrete.js.map +0 -1
  280. package/dist/source/interfaces/data_access/ua_multistate_value_discrete.d.ts +0 -27
  281. package/dist/source/interfaces/data_access/ua_multistate_value_discrete.js +0 -3
  282. package/dist/source/interfaces/data_access/ua_multistate_value_discrete.js.map +0 -1
  283. package/dist/source/interfaces/data_access/ua_two_state_discrete.d.ts +0 -17
  284. package/dist/source/interfaces/data_access/ua_two_state_discrete.js +0 -3
  285. package/dist/source/interfaces/data_access/ua_two_state_discrete.js.map +0 -1
  286. package/dist/source/interfaces/data_access/ua_y_array_item.d.ts +0 -19
  287. package/dist/source/interfaces/data_access/ua_y_array_item.js +0 -3
  288. package/dist/source/interfaces/data_access/ua_y_array_item.js.map +0 -1
  289. package/dist/source/interfaces/state_machine/exclusive_limit_state_machine.d.ts +0 -11
  290. package/dist/source/interfaces/state_machine/exclusive_limit_state_machine.js +0 -3
  291. package/dist/source/interfaces/state_machine/exclusive_limit_state_machine.js.map +0 -1
  292. package/dist/source/interfaces/state_machine/finite_state_machine.d.ts +0 -70
  293. package/dist/source/interfaces/state_machine/finite_state_machine.js +0 -3
  294. package/dist/source/interfaces/state_machine/finite_state_machine.js.map +0 -1
  295. package/dist/source/interfaces/state_machine/program_finite_state_machine.d.ts +0 -74
  296. package/dist/source/interfaces/state_machine/program_finite_state_machine.js +0 -3
  297. package/dist/source/interfaces/state_machine/program_finite_state_machine.js.map +0 -1
  298. package/dist/source/interfaces/state_machine/state_machine.d.ts +0 -342
  299. package/dist/source/interfaces/state_machine/state_machine.js +0 -3
  300. package/dist/source/interfaces/state_machine/state_machine.js.map +0 -1
  301. package/dist/source/interfaces/state_machine/ua_finite_state_variable.d.ts +0 -18
  302. package/dist/source/interfaces/state_machine/ua_finite_state_variable.js +0 -3
  303. package/dist/source/interfaces/state_machine/ua_finite_state_variable.js.map +0 -1
  304. package/dist/source/interfaces/state_machine/ua_state_variable.d.ts +0 -29
  305. package/dist/source/interfaces/state_machine/ua_state_variable.js +0 -3
  306. package/dist/source/interfaces/state_machine/ua_state_variable.js.map +0 -1
  307. package/dist/source/interfaces/state_machine/ua_two_state_variable.d.ts +0 -26
  308. package/dist/source/interfaces/state_machine/ua_two_state_variable.js +0 -3
  309. package/dist/source/interfaces/state_machine/ua_two_state_variable.js.map +0 -1
  310. package/dist/source/interfaces/subscription_diagnostics_variable.d.ts +0 -41
  311. package/dist/source/interfaces/subscription_diagnostics_variable.js +0 -3
  312. package/dist/source/interfaces/subscription_diagnostics_variable.js.map +0 -1
  313. package/dist/src/alarms_and_conditions/base_event_type.d.ts +0 -26
  314. package/dist/src/alarms_and_conditions/base_event_type.js +0 -41
  315. package/dist/src/alarms_and_conditions/base_event_type.js.map +0 -1
  316. package/dist/src/alarms_and_conditions/shelving_state_machine.d.ts +0 -22
  317. package/dist/src/alarms_and_conditions/shelving_state_machine.js +0 -241
  318. package/dist/src/alarms_and_conditions/shelving_state_machine.js.map +0 -1
  319. package/dist/src/alarms_and_conditions/trip_alarm.d.ts +0 -16
  320. package/dist/src/alarms_and_conditions/trip_alarm.js +0 -21
  321. package/dist/src/alarms_and_conditions/trip_alarm.js.map +0 -1
  322. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_base.d.ts +0 -54
  323. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_base.js +0 -255
  324. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_base.js.map +0 -1
  325. package/dist/src/alarms_and_conditions/ua_alarm_condition_base.d.ts +0 -138
  326. package/dist/src/alarms_and_conditions/ua_alarm_condition_base.js +0 -460
  327. package/dist/src/alarms_and_conditions/ua_alarm_condition_base.js.map +0 -1
  328. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm.d.ts +0 -35
  329. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm.js +0 -32
  330. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm.js.map +0 -1
  331. package/dist/src/alarms_and_conditions/ua_condition_base.d.ts +0 -191
  332. package/dist/src/alarms_and_conditions/ua_condition_base.js +0 -1029
  333. package/dist/src/alarms_and_conditions/ua_condition_base.js.map +0 -1
  334. package/dist/src/alarms_and_conditions/ua_discrete_alarm.d.ts +0 -11
  335. package/dist/src/alarms_and_conditions/ua_discrete_alarm.js +0 -58
  336. package/dist/src/alarms_and_conditions/ua_discrete_alarm.js.map +0 -1
  337. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm.d.ts +0 -24
  338. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm.js +0 -59
  339. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm.js.map +0 -1
  340. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm.d.ts +0 -14
  341. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm.js +0 -17
  342. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm.js.map +0 -1
  343. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm.d.ts +0 -22
  344. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm.js +0 -87
  345. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm.js.map +0 -1
  346. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm.d.ts +0 -6
  347. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm.js +0 -11
  348. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm.js.map +0 -1
  349. package/dist/src/alarms_and_conditions/ua_limit_alarm.d.ts +0 -76
  350. package/dist/src/alarms_and_conditions/ua_limit_alarm.js +0 -237
  351. package/dist/src/alarms_and_conditions/ua_limit_alarm.js.map +0 -1
  352. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm.d.ts +0 -27
  353. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm.js +0 -62
  354. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm.js.map +0 -1
  355. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm.d.ts +0 -49
  356. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm.js +0 -176
  357. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm.js.map +0 -1
  358. package/dist/src/alarms_and_conditions/ua_off_normal_alarm.d.ts +0 -47
  359. package/dist/src/alarms_and_conditions/ua_off_normal_alarm.js +0 -151
  360. package/dist/src/alarms_and_conditions/ua_off_normal_alarm.js.map +0 -1
  361. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm.d.ts +0 -16
  362. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm.js +0 -18
  363. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm.js.map +0 -1
  364. package/dist/src/base_node.d.ts +0 -270
  365. package/dist/src/base_node.js +0 -1299
  366. package/dist/src/base_node.js.map +0 -1
  367. package/dist/src/data_access/ua_analog_item.d.ts +0 -13
  368. package/dist/src/data_access/ua_analog_item.js +0 -37
  369. package/dist/src/data_access/ua_analog_item.js.map +0 -1
  370. package/dist/src/data_access/ua_data_item.d.ts +0 -16
  371. package/dist/src/data_access/ua_data_item.js +0 -66
  372. package/dist/src/data_access/ua_data_item.js.map +0 -1
  373. package/dist/src/data_access/ua_multistate_discrete.d.ts +0 -24
  374. package/dist/src/data_access/ua_multistate_discrete.js +0 -132
  375. package/dist/src/data_access/ua_multistate_discrete.js.map +0 -1
  376. package/dist/src/namespace.d.ts +0 -472
  377. package/dist/src/namespace.js +0 -1759
  378. package/dist/src/namespace.js.map +0 -1
  379. package/dist/src/reference.d.ts +0 -43
  380. package/dist/src/reference.js +0 -138
  381. package/dist/src/reference.js.map +0 -1
  382. package/dist/src/session_context.d.ts +0 -4
  383. package/dist/src/session_context.js +0 -9
  384. package/dist/src/session_context.js.map +0 -1
  385. package/dist/src/ua_data_type.d.ts +0 -81
  386. package/dist/src/ua_data_type.js +0 -259
  387. package/dist/src/ua_data_type.js.map +0 -1
  388. package/dist/src/ua_method.d.ts +0 -33
  389. package/dist/src/ua_method.js +0 -194
  390. package/dist/src/ua_method.js.map +0 -1
  391. package/dist/src/ua_object.d.ts +0 -27
  392. package/dist/src/ua_object.js +0 -153
  393. package/dist/src/ua_object.js.map +0 -1
  394. package/dist/src/ua_object_type.d.ts +0 -49
  395. package/dist/src/ua_object_type.js +0 -123
  396. package/dist/src/ua_object_type.js.map +0 -1
  397. package/dist/src/ua_reference_type.d.ts +0 -31
  398. package/dist/src/ua_reference_type.js +0 -108
  399. package/dist/src/ua_reference_type.js.map +0 -1
  400. package/dist/src/ua_variable.d.ts +0 -346
  401. package/dist/src/ua_variable.js +0 -1651
  402. package/dist/src/ua_variable.js.map +0 -1
  403. package/dist/src/ua_variable_type.d.ts +0 -57
  404. package/dist/src/ua_variable_type.js +0 -530
  405. package/dist/src/ua_variable_type.js.map +0 -1
  406. package/dist/src/ua_view.d.ts +0 -16
  407. package/dist/src/ua_view.js +0 -41
  408. package/dist/src/ua_view.js.map +0 -1
@@ -1,1299 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BaseNode = exports.makeAttributeEventName = void 0;
4
- /**
5
- * @module node-opcua-address-space
6
- */
7
- const chalk = require("chalk");
8
- const events_1 = require("events");
9
- const lodash_1 = require("lodash");
10
- const node_opcua_assert_1 = require("node-opcua-assert");
11
- const node_opcua_data_model_1 = require("node-opcua-data-model");
12
- const node_opcua_data_value_1 = require("node-opcua-data-value");
13
- const node_opcua_debug_1 = require("node-opcua-debug");
14
- const node_opcua_nodeid_1 = require("node-opcua-nodeid");
15
- const node_opcua_status_code_1 = require("node-opcua-status-code");
16
- const utils = require("node-opcua-utils");
17
- const node_opcua_utils_1 = require("node-opcua-utils");
18
- const node_opcua_variant_1 = require("node-opcua-variant");
19
- const source_1 = require("../source");
20
- const cetools = require("./address_space_change_event_tools");
21
- const base_node_private_1 = require("./base_node_private");
22
- const reference_1 = require("./reference");
23
- // tslint:disable:no-var-requires
24
- // tslint:disable:no-bitwise
25
- // tslint:disable:no-console
26
- const doDebug = false;
27
- function defaultBrowseFilterFunc(context) {
28
- return true;
29
- }
30
- function _get_QualifiedBrowseName(browseName) {
31
- return node_opcua_data_model_1.coerceQualifiedName(browseName);
32
- }
33
- function _is_valid_BrowseDirection(browseDirection) {
34
- return (browseDirection === node_opcua_data_model_1.BrowseDirection.Forward ||
35
- browseDirection === node_opcua_data_model_1.BrowseDirection.Inverse ||
36
- browseDirection === node_opcua_data_model_1.BrowseDirection.Both);
37
- }
38
- function makeAttributeEventName(attributeId) {
39
- const attributeName = node_opcua_data_model_1.attributeNameById[attributeId];
40
- return attributeName + "_changed";
41
- }
42
- exports.makeAttributeEventName = makeAttributeEventName;
43
- /**
44
- * Base class for all Node classes
45
- *
46
- * BaseNode is the base class for all the OPCUA objects in the address space
47
- * It provides attributes and a set of references to other nodes.
48
- * see:
49
- * {{#crossLink "UAObject"}}{{/crossLink}},
50
- * {{#crossLink "UAVariable"}}{{/crossLink}},
51
- * {{#crossLink "Reference"}}{{/crossLink}},
52
- * {{#crossLink "UAMethod"}}{{/crossLink}},
53
- * {{#crossLink "UAView"}}{{/crossLink}},
54
- * {{#crossLink "UAObjectType"}}{{/crossLink}},
55
- * {{#crossLink "UADataType"}}{{/crossLink}},
56
- * {{#crossLink "UAVariableType"}}{{/crossLink}},
57
- *
58
- *
59
- */
60
- class BaseNode extends events_1.EventEmitter {
61
- /**
62
- * @internal
63
- * @param options
64
- */
65
- constructor(options) {
66
- super();
67
- this.nodeClass = node_opcua_data_model_1.NodeClass.Unspecified;
68
- const _private = base_node_private_1.BaseNode_initPrivate(this);
69
- node_opcua_assert_1.assert(this.nodeClass === node_opcua_data_model_1.NodeClass.Unspecified, "must not be specify a nodeClass");
70
- node_opcua_assert_1.assert(options.addressSpace); // expecting an address space
71
- node_opcua_assert_1.assert(options.browseName instanceof node_opcua_data_model_1.QualifiedName, "Expecting a valid QualifiedName");
72
- node_opcua_assert_1.assert(options.nodeId instanceof node_opcua_nodeid_1.NodeId, "Expecting a valid NodeId");
73
- options.references = options.references || [];
74
- _private.__address_space = options.addressSpace;
75
- this.nodeId = node_opcua_nodeid_1.resolveNodeId(options.nodeId);
76
- // QualifiedName
77
- /**
78
- * the node browseName
79
- * @property browseName
80
- * @type QualifiedName
81
- * @static
82
- */
83
- this.browseName = _get_QualifiedBrowseName(options.browseName);
84
- // re-use browseName as displayName if displayName is missing
85
- options.displayName = options.displayName || this.browseName.name.toString();
86
- if (options.description === undefined) {
87
- options.description = null;
88
- }
89
- this._setDisplayName(options.displayName);
90
- this._setDescription(options.description);
91
- // user defined filter function for browsing
92
- const _browseFilter = options.browseFilter || defaultBrowseFilterFunc;
93
- node_opcua_assert_1.assert(typeof _browseFilter === "function");
94
- _private._browseFilter = _browseFilter;
95
- // normalize reference type
96
- // this will convert any referenceType expressed with its inverseName into
97
- // its normal name and fix the isForward flag accordingly.
98
- // ( e.g "ComponentOf" isForward:true => "HasComponent", isForward:false)
99
- for (const reference of options.references) {
100
- this.__addReference(reference);
101
- }
102
- }
103
- get addressSpace() {
104
- const _private = base_node_private_1.BaseNode_getPrivate(this);
105
- if (!_private) {
106
- throw new Error("Internal error , cannot extract private data from " + this.browseName.toString());
107
- }
108
- return _private.__address_space;
109
- }
110
- get displayName() {
111
- const _private = base_node_private_1.BaseNode_getPrivate(this);
112
- return _private._displayName;
113
- }
114
- set displayName(value) {
115
- this._setDisplayName(value);
116
- /**
117
- * fires when the displayName is changed.
118
- * @event DisplayName_changed
119
- * @param dataValue {DataValue}
120
- */
121
- this._notifyAttributeChange(node_opcua_data_model_1.AttributeIds.DisplayName);
122
- }
123
- get description() {
124
- const _private = base_node_private_1.BaseNode_getPrivate(this);
125
- return _private._description;
126
- }
127
- set description(value) {
128
- this._setDescription(value);
129
- /**
130
- * fires when the description attribute is changed.
131
- * @event Description_changed
132
- * @param dataValue {DataValue}
133
- */
134
- this._notifyAttributeChange(node_opcua_data_model_1.AttributeIds.Description);
135
- }
136
- /**
137
- * returns the nodeId of this node's Type Definition
138
- */
139
- get typeDefinition() {
140
- const _private = base_node_private_1.BaseNode_getPrivate(this);
141
- if (!_private._cache.typeDefinition) {
142
- const has_type_definition_ref = this.findReference("HasTypeDefinition", true);
143
- _private._cache.typeDefinition = has_type_definition_ref ? has_type_definition_ref.nodeId : null;
144
- }
145
- return _private._cache.typeDefinition;
146
- }
147
- /**
148
- * returns the nodeId of this node's Type Definition
149
- */
150
- get typeDefinitionObj() {
151
- const _private = base_node_private_1.BaseNode_getPrivate(this);
152
- if (undefined === _private._cache.typeDefinitionObj) {
153
- const nodeId = this.typeDefinition;
154
- _private._cache.typeDefinitionObj = nodeId ? this.addressSpace.findNode(nodeId) : null;
155
- }
156
- return _private._cache.typeDefinitionObj;
157
- }
158
- get parentNodeId() {
159
- const parent = this.parent;
160
- return parent ? parent.nodeId : undefined;
161
- }
162
- /**
163
- * namespace index
164
- */
165
- get namespaceIndex() {
166
- return this.nodeId.namespace;
167
- }
168
- /**
169
- * namespace uri
170
- */
171
- get namespaceUri() {
172
- const _private = base_node_private_1.BaseNode_getPrivate(this);
173
- if (!_private._cache.namespaceUri) {
174
- _private._cache.namespaceUri = this.addressSpace.getNamespaceUri(this.namespaceIndex);
175
- }
176
- return _private._cache.namespaceUri;
177
- }
178
- /**
179
- * the parent node
180
- */
181
- get parent() {
182
- const _private = base_node_private_1.BaseNode_getPrivate(this);
183
- if (_private._parent === undefined) {
184
- // never been set before
185
- _private._parent = _setup_parent_item.call(this, _private._referenceIdx);
186
- }
187
- return _private._parent || null;
188
- }
189
- /**
190
- * @property modellingRule
191
- * @type {String|undefined}
192
- */
193
- get modellingRule() {
194
- const node = this;
195
- const r = node.findReferencesAsObject("HasModellingRule");
196
- if (!r || r.length === 0) {
197
- return null; /// "? modellingRule missing ?"; // consider "Mandatory"
198
- }
199
- const r0 = r[0];
200
- return r0.browseName.toString();
201
- }
202
- static makeAttributeEventName(attributeId) {
203
- return makeAttributeEventName(attributeId);
204
- }
205
- static _getCache(baseNode) {
206
- const _private = base_node_private_1.BaseNode_getPrivate(baseNode);
207
- return _private._cache;
208
- }
209
- getDisplayName(locale) {
210
- const _private = base_node_private_1.BaseNode_getPrivate(this);
211
- return _private._displayName[0].text;
212
- }
213
- get namespace() {
214
- return this.addressSpace.getNamespace(this.nodeId.namespace);
215
- }
216
- // ---------------------------------------------------------------------------------------------------
217
- // Finders
218
- // ---------------------------------------------------------------------------------------------------
219
- findReferencesEx(strReference, browseDirection) {
220
- browseDirection = browseDirection !== undefined ? browseDirection : node_opcua_data_model_1.BrowseDirection.Forward;
221
- node_opcua_assert_1.assert(_is_valid_BrowseDirection(browseDirection));
222
- node_opcua_assert_1.assert(browseDirection !== node_opcua_data_model_1.BrowseDirection.Both);
223
- let referenceType = null;
224
- if (typeof strReference === "string") {
225
- // xx strReference = strReference.browseName.toString();
226
- referenceType = this.addressSpace.findReferenceType(strReference);
227
- if (!referenceType) {
228
- throw new Error("Cannot resolve referenceType : " + strReference);
229
- }
230
- }
231
- else {
232
- referenceType = strReference;
233
- }
234
- if (!referenceType) {
235
- // note: when loading nodeset2.xml files, reference type may not exit yet
236
- // throw new Error("expecting valid reference name " + strReference);
237
- return [];
238
- }
239
- node_opcua_assert_1.assert(referenceType.nodeId instanceof node_opcua_nodeid_1.NodeId);
240
- const _private = base_node_private_1.BaseNode_getPrivate(this);
241
- const hash = "_refEx_" + referenceType.nodeId.toString() + browseDirection.toString();
242
- if (_private._cache[hash]) {
243
- return _private._cache[hash];
244
- }
245
- // find a map of all types that derive from the provided reference type
246
- const keys = base_node_private_1.getSubtypeIndex.call(referenceType);
247
- const isForward = browseDirection === node_opcua_data_model_1.BrowseDirection.Forward;
248
- const references = [];
249
- function process(referenceIdx) {
250
- const referenceTypes = Object.values(referenceIdx);
251
- for (const ref of referenceTypes) {
252
- const h = ref.referenceType.toString();
253
- if (ref.isForward === isForward && keys[h]) {
254
- node_opcua_assert_1.assert(ref._referenceType.browseName.toString());
255
- references.push(ref);
256
- }
257
- }
258
- }
259
- process(_private._referenceIdx);
260
- process(_private._back_referenceIdx);
261
- _private._cache[hash] = references;
262
- return references;
263
- }
264
- // public findReferencesExDescription(
265
- // strReference: string,
266
- // browseDirection: BrowseDirection
267
- // ): any {
268
- // const refs = this.findReferencesEx(strReference, browseDirection);
269
- // const addressSpace = this.addressSpace;
270
- // return refs.map((ref: Reference) => _makeReferenceDescription(addressSpace, ref, 0x3F));
271
- // }
272
- /**
273
- * @method findReferences
274
- * @param referenceType {String|NodeId|ReferenceType} the referenceType as a string.
275
- * @param [isForward] default=true
276
- * @return an array with references
277
- */
278
- findReferences(referenceType, isForward) {
279
- const _private = base_node_private_1.BaseNode_getPrivate(this);
280
- isForward = utils.isNullOrUndefined(isForward) ? true : !!isForward;
281
- node_opcua_assert_1.assert(typeof isForward === "boolean");
282
- const referenceTypeNode = this._coerceReferenceType(referenceType);
283
- const hash = "_ref_" + referenceTypeNode.nodeId.toString() + isForward.toString();
284
- if (_private._cache[hash]) {
285
- return _private._cache[hash];
286
- }
287
- // istanbul ignore next
288
- if (doDebug && !this.addressSpace.findReferenceType(referenceTypeNode)) {
289
- throw new Error("expecting valid reference name " + referenceType);
290
- }
291
- const result = [];
292
- for (const ref of Object.values(_private._referenceIdx)) {
293
- if (ref.isForward === isForward) {
294
- if (node_opcua_nodeid_1.sameNodeId(ref.referenceType, referenceTypeNode.nodeId)) {
295
- result.push(ref);
296
- }
297
- }
298
- }
299
- for (const ref of Object.values(_private._back_referenceIdx)) {
300
- if (ref.isForward === isForward) {
301
- if (node_opcua_nodeid_1.sameNodeId(ref.referenceType, referenceTypeNode.nodeId)) {
302
- result.push(ref);
303
- }
304
- }
305
- }
306
- _private._cache[hash] = result;
307
- return result;
308
- }
309
- /**
310
- * @method findReference
311
- * @param strReference the referenceType as a string.
312
- * @param [isForward]
313
- * @return {Reference}
314
- */
315
- findReference(strReference, isForward) {
316
- const refs = this.findReferences(strReference, isForward);
317
- // yy if (optionalSymbolicName) {
318
- // yy // search reference that matches symbolic name
319
- // yy refs = refs.filter((ref: Reference) => ref.symbolicName === optionalSymbolicName);
320
- // yy }
321
- node_opcua_assert_1.assert(refs.length === 1 || refs.length === 0, "findReference: expecting only one or zero element here");
322
- return refs.length === 0 ? null : refs[0];
323
- }
324
- findReferencesExAsObject(strReference, browseDirection) {
325
- const references = this.findReferencesEx(strReference, browseDirection);
326
- return _asObject(references, this.addressSpace);
327
- }
328
- findReferencesAsObject(strReference, isForward) {
329
- const references = this.findReferences(strReference, isForward);
330
- return _asObject(references, this.addressSpace);
331
- }
332
- /**
333
- * return an array with the Aggregates of this object.
334
- */
335
- getAggregates() {
336
- const _private = base_node_private_1.BaseNode_getPrivate(this);
337
- if (!_private._cache._aggregates) {
338
- _private._cache._aggregates = this.findReferencesExAsObject("Aggregates", node_opcua_data_model_1.BrowseDirection.Forward);
339
- }
340
- return _private._cache._aggregates;
341
- }
342
- /**
343
- * return an array with the components of this object.
344
- */
345
- getComponents() {
346
- const _private = base_node_private_1.BaseNode_getPrivate(this);
347
- if (!_private._cache._components) {
348
- _private._cache._components = this.findReferencesExAsObject("HasComponent", node_opcua_data_model_1.BrowseDirection.Forward);
349
- }
350
- return _private._cache._components;
351
- }
352
- /**
353
- * return a array with the properties of this object.
354
- */
355
- getProperties() {
356
- const _private = base_node_private_1.BaseNode_getPrivate(this);
357
- if (!_private._cache._properties) {
358
- _private._cache._properties = this.findReferencesExAsObject("HasProperty", node_opcua_data_model_1.BrowseDirection.Forward);
359
- }
360
- return _private._cache._properties;
361
- }
362
- /**
363
- * return a array with the notifiers of this object.
364
- */
365
- getNotifiers() {
366
- const _private = base_node_private_1.BaseNode_getPrivate(this);
367
- if (!_private._cache._notifiers) {
368
- _private._cache._notifiers = this.findReferencesAsObject("HasNotifier", true);
369
- }
370
- return _private._cache._notifiers;
371
- }
372
- /**
373
- * return a array with the event source of this object.
374
- */
375
- getEventSources() {
376
- const _private = base_node_private_1.BaseNode_getPrivate(this);
377
- if (!_private._cache._eventSources) {
378
- _private._cache._eventSources = this.findReferencesAsObject("HasEventSource", true);
379
- }
380
- return _private._cache._eventSources;
381
- }
382
- /**
383
- * return a array of the objects for which this node is an EventSource
384
- */
385
- getEventSourceOfs() {
386
- const _private = base_node_private_1.BaseNode_getPrivate(this);
387
- if (!_private._cache._eventSources) {
388
- _private._cache._eventSources = this.findReferencesAsObject("HasEventSource", false);
389
- }
390
- return _private._cache._eventSources;
391
- }
392
- /**
393
- * retrieve a component by name
394
- */
395
- getComponentByName(browseName, namespaceIndex) {
396
- const components = this.getComponents();
397
- const select = _filter_by_browse_name(components, browseName, namespaceIndex);
398
- node_opcua_assert_1.assert(select.length <= 1, "BaseNode#getComponentByName found duplicated reference");
399
- if (select.length === 1) {
400
- const component = select[0];
401
- if (component.nodeClass === node_opcua_data_model_1.NodeClass.Method) {
402
- console.log("please use getMethodByName to retrieve a method");
403
- return null;
404
- }
405
- node_opcua_assert_1.assert(component.nodeClass === node_opcua_data_model_1.NodeClass.Variable || component.nodeClass === node_opcua_data_model_1.NodeClass.Object);
406
- return component;
407
- }
408
- else {
409
- return null;
410
- }
411
- }
412
- /**
413
- * retrieve a property by name
414
- */
415
- getPropertyByName(browseName, namespaceIndex) {
416
- const properties = this.getProperties();
417
- const select = _filter_by_browse_name(properties, browseName, namespaceIndex);
418
- node_opcua_assert_1.assert(select.length <= 1, "BaseNode#getPropertyByName found duplicated reference");
419
- if (select.length === 1 && select[0].nodeClass !== node_opcua_data_model_1.NodeClass.Variable) {
420
- throw new Error("Expecting a property to be of TypeVariable");
421
- }
422
- return select.length === 1 ? select[0] : null;
423
- }
424
- /**
425
- * retrieve a folder by name
426
- */
427
- getFolderElementByName(browseName, namespaceIndex) {
428
- node_opcua_assert_1.assert(typeof browseName === "string");
429
- const elements = this.getFolderElements();
430
- const select = _filter_by_browse_name(elements, browseName, namespaceIndex);
431
- return select.length === 1 ? select[0] : null;
432
- }
433
- /**
434
- * returns the list of nodes that this folder object organizes
435
- */
436
- getFolderElements() {
437
- return this.findReferencesAsObject("Organizes", true);
438
- }
439
- /**
440
- * returns the list of methods that this object provides
441
- * @method getMethods
442
- * @return an array with Method objects.
443
- *
444
- *
445
- * Note: internally, methods are special types of components
446
- */
447
- getMethods() {
448
- const _private = base_node_private_1.BaseNode_getPrivate(this);
449
- if (!_private._cache._methods) {
450
- const components = this.getComponents();
451
- _private._cache._methods = components.filter((obj) => obj.nodeClass === node_opcua_data_model_1.NodeClass.Method);
452
- }
453
- return _private._cache._methods;
454
- }
455
- /**
456
- * returns the method exposed by this object and with the given nodeId
457
- */
458
- getMethodById(nodeId) {
459
- const methods = this.getMethods();
460
- const found = methods.find((m) => m.nodeId.toString() === nodeId.toString());
461
- return found || null;
462
- }
463
- getMethodByName(browseName, namespaceIndex) {
464
- const methods = this.getMethods();
465
- const select = _filter_by_browse_name(methods, browseName, namespaceIndex);
466
- node_opcua_assert_1.assert(select.length <= 1, "BaseNode#getMethodByName found duplicated reference");
467
- return select.length === 1 ? select[0] : null;
468
- }
469
- getWriteMask() {
470
- return 0;
471
- }
472
- getUserWriteMask() {
473
- return 0;
474
- }
475
- readAttribute(context, attributeId, indexRange, dataEncoding) {
476
- node_opcua_assert_1.assert(!context || context instanceof source_1.SessionContext);
477
- const options = {};
478
- options.statusCode = node_opcua_status_code_1.StatusCodes.Good;
479
- switch (attributeId) {
480
- case node_opcua_data_model_1.AttributeIds.NodeId: // NodeId
481
- options.value = { dataType: node_opcua_variant_1.DataType.NodeId, value: this.nodeId };
482
- break;
483
- case node_opcua_data_model_1.AttributeIds.NodeClass: // NodeClass
484
- node_opcua_assert_1.assert(isFinite(this.nodeClass));
485
- options.value = { dataType: node_opcua_variant_1.DataType.Int32, value: this.nodeClass };
486
- break;
487
- case node_opcua_data_model_1.AttributeIds.BrowseName: // QualifiedName
488
- node_opcua_assert_1.assert(this.browseName instanceof node_opcua_data_model_1.QualifiedName);
489
- options.value = { dataType: node_opcua_variant_1.DataType.QualifiedName, value: this.browseName };
490
- break;
491
- case node_opcua_data_model_1.AttributeIds.DisplayName: // LocalizedText
492
- options.value = { dataType: node_opcua_variant_1.DataType.LocalizedText, value: this.displayName[0] };
493
- break;
494
- case node_opcua_data_model_1.AttributeIds.Description: // LocalizedText
495
- options.value = { dataType: node_opcua_variant_1.DataType.LocalizedText, value: this.description };
496
- break;
497
- case node_opcua_data_model_1.AttributeIds.WriteMask:
498
- options.value = { dataType: node_opcua_variant_1.DataType.UInt32, value: this.getWriteMask() };
499
- break;
500
- case node_opcua_data_model_1.AttributeIds.UserWriteMask:
501
- options.value = { dataType: node_opcua_variant_1.DataType.UInt32, value: this.getUserWriteMask() };
502
- break;
503
- default:
504
- options.value = null;
505
- options.statusCode = node_opcua_status_code_1.StatusCodes.BadAttributeIdInvalid;
506
- break;
507
- }
508
- // xx options.serverTimestamp = new Date();
509
- return new node_opcua_data_value_1.DataValue(options);
510
- }
511
- writeAttribute(context, writeValue, callback) {
512
- node_opcua_assert_1.assert(context instanceof source_1.SessionContext);
513
- node_opcua_assert_1.assert(typeof callback === "function");
514
- if (writeValue.attributeId <= 0 || writeValue.attributeId > node_opcua_data_model_1.AttributeIds.UserExecutable) {
515
- return callback(null, node_opcua_status_code_1.StatusCodes.BadAttributeIdInvalid);
516
- }
517
- // by default Node is read-only,
518
- // this method needs to be overridden to change the behavior
519
- callback(null, node_opcua_status_code_1.StatusCodes.BadNotWritable);
520
- }
521
- fullName() {
522
- if (this.parentNodeId) {
523
- const parent = this.addressSpace.findNode(this.parentNodeId);
524
- // istanbul ignore else
525
- if (parent) {
526
- return parent.fullName() + "." + this.browseName.toString() + "";
527
- }
528
- else {
529
- return "NOT YET REGISTERED" + this.parentNodeId.toString() + "." + this.browseName.toString() + "";
530
- }
531
- }
532
- return this.browseName.toString();
533
- }
534
- ownReferences() {
535
- const _private = base_node_private_1.BaseNode_getPrivate(this);
536
- return Object.values(_private._referenceIdx);
537
- }
538
- /**
539
- * @method browseNodeByTargetName
540
- *
541
- * @param relativePathElement
542
- * @param isLast
543
- * @return {NodeId[]}
544
- */
545
- browseNodeByTargetName(relativePathElement, isLast) {
546
- relativePathElement.targetName = relativePathElement.targetName || new node_opcua_data_model_1.QualifiedName({});
547
- // part 4.0 v1.03 $7.26 RelativePath
548
- // The BrowseName of the target node.
549
- // The final element may have an empty targetName. In this situation all targets of the references identified by
550
- // the referenceTypeId are the targets of the RelativePath.
551
- // The targetName shall be specified for all other elements.
552
- // The current path cannot be followed any further if no targets with the specified BrowseName exist.
553
- node_opcua_assert_1.assert(relativePathElement.targetName instanceof node_opcua_data_model_1.QualifiedName);
554
- node_opcua_assert_1.assert(relativePathElement.targetName.namespaceIndex >= 0);
555
- node_opcua_assert_1.assert(relativePathElement.targetName.name.length > 0);
556
- // The type of reference to follow from the current node.
557
- // The current path cannot be followed any further if the referenceTypeId is not available on the Node instance.
558
- // If not specified then all References are included and the parameter includeSubtypes is ignored.
559
- node_opcua_assert_1.assert(relativePathElement.hasOwnProperty("referenceTypeId"));
560
- // Indicates whether the inverse Reference should be followed.
561
- // The inverse reference is followed if this value is TRUE.
562
- node_opcua_assert_1.assert(relativePathElement.hasOwnProperty("isInverse"));
563
- // Indicates whether subtypes of the ReferenceType should be followed.
564
- // Subtypes are included if this value is TRUE.
565
- node_opcua_assert_1.assert(relativePathElement.hasOwnProperty("includeSubtypes"));
566
- const references = this.allReferences();
567
- const _check_reference = (reference) => {
568
- if (relativePathElement.referenceTypeId.isEmpty()) {
569
- return true;
570
- }
571
- node_opcua_assert_1.assert(relativePathElement.referenceTypeId instanceof node_opcua_nodeid_1.NodeId);
572
- if ((relativePathElement.isInverse && reference.isForward) ||
573
- (!relativePathElement.isInverse && !reference.isForward)) {
574
- return false;
575
- }
576
- node_opcua_assert_1.assert(reference.hasOwnProperty("isForward"));
577
- const referenceType = resolveReferenceType(this.addressSpace, reference);
578
- const referenceTypeId = referenceType.nodeId;
579
- if (node_opcua_nodeid_1.sameNodeId(relativePathElement.referenceTypeId, referenceTypeId)) {
580
- return true;
581
- }
582
- if (relativePathElement.includeSubtypes) {
583
- const baseType = this.addressSpace.findReferenceType(relativePathElement.referenceTypeId);
584
- if (baseType && referenceType.isSupertypeOf(baseType)) {
585
- return true;
586
- }
587
- }
588
- return false;
589
- };
590
- const nodeIdsMap = {};
591
- let nodeIds = [];
592
- for (const reference of references) {
593
- if (!_check_reference(reference)) {
594
- continue;
595
- }
596
- const obj = resolveReferenceNode(this.addressSpace, reference);
597
- // istanbul ignore next
598
- if (!obj) {
599
- throw new Error(" cannot find node with id " + reference.nodeId.toString());
600
- }
601
- if (lodash_1.isEqual(obj.browseName, relativePathElement.targetName)) {
602
- // compare QualifiedName
603
- const key = obj.nodeId.toString();
604
- if (!nodeIdsMap.hasOwnProperty(key)) {
605
- nodeIds.push(obj.nodeId);
606
- nodeIdsMap[key] = obj;
607
- }
608
- }
609
- }
610
- if (nodeIds.length === 0 && (this.nodeClass === node_opcua_data_model_1.NodeClass.ObjectType || this.nodeClass === node_opcua_data_model_1.NodeClass.VariableType)) {
611
- const nodeType = this;
612
- if (nodeType.subtypeOf) {
613
- // browsing also InstanceDeclarations included in base type
614
- const baseType = this.addressSpace.findNode(nodeType.subtypeOf);
615
- const n = baseType.browseNodeByTargetName(relativePathElement, isLast);
616
- nodeIds = [].concat(nodeIds, n);
617
- }
618
- }
619
- return nodeIds;
620
- }
621
- /**
622
- * browse the node to extract information requested in browseDescription
623
- * @method browseNode
624
- * @param browseDescription
625
- * @param context
626
- * @return an array with reference descriptions
627
- */
628
- browseNode(browseDescription, context) {
629
- node_opcua_assert_1.assert(isFinite(browseDescription.nodeClassMask));
630
- node_opcua_assert_1.assert(isFinite(browseDescription.browseDirection));
631
- const do_debug = false;
632
- const _private = base_node_private_1.BaseNode_getPrivate(this);
633
- const addressSpace = this.addressSpace;
634
- const referenceTypeId = normalize_referenceTypeId(addressSpace, browseDescription.referenceTypeId);
635
- node_opcua_assert_1.assert(referenceTypeId instanceof node_opcua_nodeid_1.NodeId);
636
- const browseDirection = browseDescription.browseDirection !== undefined ? browseDescription.browseDirection : node_opcua_data_model_1.BrowseDirection.Both;
637
- // get all possible references
638
- let references = [].concat(Object.values(_private._referenceIdx), Object.values(_private._back_referenceIdx));
639
- /* istanbul ignore next */
640
- if (do_debug) {
641
- console.log("all references :", this.nodeId.toString(), this.browseName.toString());
642
- source_1.dumpReferences(addressSpace, Object.values(_private._referenceIdx));
643
- }
644
- // filter out references not matching referenceType
645
- references = _filter_by_referenceType.call(this, browseDescription, references, referenceTypeId);
646
- references = _filter_by_direction(references, browseDirection);
647
- references = _filter_by_nodeClass.call(this, references, browseDescription.nodeClassMask);
648
- references = _filter_by_userFilter.call(this, references, context);
649
- const referenceDescriptions = base_node_private_1._constructReferenceDescription(addressSpace, references, browseDescription.resultMask);
650
- /* istanbul ignore next */
651
- if (do_debug) {
652
- source_1.dumpReferenceDescriptions(this.addressSpace, referenceDescriptions);
653
- }
654
- return referenceDescriptions;
655
- }
656
- allReferences() {
657
- const _private = base_node_private_1.BaseNode_getPrivate(this);
658
- return [].concat(Object.values(_private._referenceIdx), Object.values(_private._back_referenceIdx));
659
- }
660
- /**
661
- * @method addReference
662
- * @param reference
663
- * @param reference.referenceType {String}
664
- * @param [reference.isForward = true] {Boolean}
665
- * @param reference.nodeId {Node|NodeId|String}
666
- *
667
- * @example
668
- *
669
- * view.addReference({ referenceType: "Organizes", nodeId: myDevice });
670
- *
671
- * or
672
- *
673
- * myDevice1.addReference({ referenceType: "OrganizedBy", nodeId: view });
674
- */
675
- addReference(reference) {
676
- const referenceNode = this.__addReference(reference);
677
- const addressSpace = this.addressSpace;
678
- if (!resolveReferenceType(addressSpace, referenceNode)) {
679
- throw new Error("BaseNode#addReference : invalid reference " + reference.toString());
680
- }
681
- this._clear_caches();
682
- _propagate_ref.call(this, addressSpace, referenceNode);
683
- this.install_extra_properties();
684
- cetools._handle_add_reference_change_event(this, referenceNode.nodeId);
685
- }
686
- removeReference(referenceOpts) {
687
- const _private = base_node_private_1.BaseNode_getPrivate(this);
688
- node_opcua_assert_1.assert(referenceOpts.hasOwnProperty("referenceType"));
689
- // xx isForward is optional : assert(reference.hasOwnProperty("isForward"));
690
- node_opcua_assert_1.assert(referenceOpts.hasOwnProperty("nodeId"));
691
- const addressSpace = this.addressSpace;
692
- if (!addressSpace) {
693
- console.log(" Where is addressSpace ?");
694
- }
695
- const reference = addressSpace.normalizeReferenceTypes([referenceOpts])[0];
696
- const h = reference.hash;
697
- const relatedNode = addressSpace.findNode(reference.nodeId);
698
- const invReference = new reference_1.Reference({
699
- isForward: !reference.isForward,
700
- nodeId: this.nodeId,
701
- referenceType: reference.referenceType
702
- });
703
- if (_private._referenceIdx[h]) {
704
- delete _private._referenceIdx[h];
705
- base_node_private_1.BaseNode_remove_backward_reference.call(relatedNode, invReference);
706
- }
707
- else if (_private._back_referenceIdx[h]) {
708
- relatedNode.removeReference(invReference);
709
- }
710
- else {
711
- // throw new Error("Cannot find reference " + reference);
712
- }
713
- base_node_private_1._handle_HierarchicalReference(this, reference);
714
- this.uninstall_extra_properties(reference);
715
- this._clear_caches();
716
- }
717
- /**
718
- *
719
- */
720
- resolveNodeId(nodeId) {
721
- return this.addressSpace.resolveNodeId(nodeId);
722
- }
723
- install_extra_properties() {
724
- const addressSpace = this.addressSpace;
725
- if (addressSpace.isFrugal) {
726
- // skipping
727
- return;
728
- }
729
- install_components_as_object_properties(this);
730
- function install_extra_properties_on_parent(ref) {
731
- const node = reference_1.Reference.resolveReferenceNode(addressSpace, ref);
732
- install_components_as_object_properties(node);
733
- }
734
- // make sure parent have extra properties updated
735
- const parentComponents = this.findReferences("HasComponent", false);
736
- const parentSubfolders = this.findReferences("Organizes", false);
737
- const parentProperties = this.findReferences("HasProperty", false);
738
- for (const p of parentComponents) {
739
- install_extra_properties_on_parent(p);
740
- }
741
- for (const p of parentSubfolders) {
742
- install_extra_properties_on_parent(p);
743
- }
744
- for (const p of parentProperties) {
745
- install_extra_properties_on_parent(p);
746
- }
747
- }
748
- uninstall_extra_properties(reference) {
749
- const addressSpace = this.addressSpace;
750
- if (addressSpace.isFrugal) {
751
- // skipping
752
- return;
753
- }
754
- const childNode = resolveReferenceNode(addressSpace, reference);
755
- const name = node_opcua_utils_1.lowerFirstLetter(childNode.browseName.name.toString());
756
- if (reservedNames.hasOwnProperty(name)) {
757
- if (doDebug) {
758
- // tslint:disable-next-line:no-console
759
- console.log(chalk.bgWhite.red("Ignoring reserved keyword " + name));
760
- }
761
- return;
762
- }
763
- /* istanbul ignore next */
764
- if (!this.hasOwnProperty(name)) {
765
- return;
766
- }
767
- Object.defineProperty(this, name, {
768
- value: undefined
769
- });
770
- }
771
- toString() {
772
- const options = new base_node_private_1.ToStringBuilder();
773
- base_node_private_1.BaseNode_toString.call(this, options);
774
- return options.toString();
775
- }
776
- /**
777
- * @property isFalseSubStateOf
778
- * @type {BaseNode|null}
779
- */
780
- get isFalseSubStateOf() {
781
- const node = this;
782
- const r = node.findReferencesAsObject("HasFalseSubState", false);
783
- if (!r || r.length === 0) {
784
- return null;
785
- }
786
- node_opcua_assert_1.assert(r.length === 1);
787
- return r[0];
788
- }
789
- /**
790
- * @property isTrueSubStateOf
791
- * @type {BaseNode|null}
792
- */
793
- get isTrueSubStateOf() {
794
- const node = this;
795
- const r = node.findReferencesAsObject("HasTrueSubState", false);
796
- if (!r || r.length === 0) {
797
- return null;
798
- }
799
- node_opcua_assert_1.assert(r.length === 1);
800
- return r[0];
801
- }
802
- /**
803
- * @method getFalseSubStates
804
- * @return {UAStateVariable[]} return an array with the SubStates of this object.
805
- */
806
- getFalseSubStates() {
807
- return this.findReferencesAsObject("HasFalseSubState");
808
- }
809
- /**
810
- * @method getTrueSubStates
811
- * @return {UAStateVariable[]} return an array with the SubStates of this object.
812
- */
813
- getTrueSubStates() {
814
- return this.findReferencesAsObject("HasTrueSubState");
815
- }
816
- findHierarchicalReferences() {
817
- const node = this;
818
- return node.findReferencesEx("HierarchicalReferences", node_opcua_data_model_1.BrowseDirection.Forward);
819
- // const _private = BaseNode_getPrivate(node);
820
- //
821
- // if (!_private._cache._HasChildReferences) {
822
- // //xx console.log("node ",node.nodeId.toString());
823
- // //xx _private._cache._HasChildReferences =
824
- // node.findReferencesEx("HierarchicalReferences",BrowseDirection.Forward);
825
- // const r1 =
826
- // const r2 = node.findReferencesEx("Organizes",BrowseDirection.Forward);
827
- // _private._cache._HasChildReferences = r1.concat(r2);
828
- // }
829
- // return _private._cache._HasChildReferences;
830
- }
831
- getChildByName(browseName) {
832
- // Attention: getChild doesn't care about namespace on browseName
833
- // !!!!
834
- if (browseName instanceof node_opcua_data_model_1.QualifiedName) {
835
- browseName = browseName.name.toString();
836
- }
837
- node_opcua_assert_1.assert(typeof browseName === "string");
838
- const node = this;
839
- const _private = base_node_private_1.BaseNode_getPrivate(node);
840
- const addressSpace = node.addressSpace;
841
- if (!_private._cache._childByNameMap) {
842
- _private._cache._childByNameMap = {};
843
- const childReferenceTypes = node.findReferencesEx("HasChild");
844
- for (const r of childReferenceTypes) {
845
- const child = resolveReferenceNode(addressSpace, r);
846
- _private._cache._childByNameMap[child.browseName.name.toString()] = child;
847
- }
848
- }
849
- const ret = _private._cache._childByNameMap[browseName] || null;
850
- return ret;
851
- }
852
- get toStateNode() {
853
- const nodes = this.findReferencesAsObject("ToState", true);
854
- node_opcua_assert_1.assert(nodes.length <= 1);
855
- return nodes.length === 1 ? nodes[0] : null;
856
- }
857
- get fromStateNode() {
858
- const nodes = this.findReferencesAsObject("FromState", true);
859
- node_opcua_assert_1.assert(nodes.length <= 1);
860
- return nodes.length === 1 ? nodes[0] : null;
861
- }
862
- /**
863
- * this methods propagates the forward references to the pointed node
864
- * by inserting backward references to the counter part node
865
- */
866
- propagate_back_references() {
867
- const _private = base_node_private_1.BaseNode_getPrivate(this);
868
- if (this.addressSpace.suspendBackReference) {
869
- // this indicates that the base node is constructed from an xml definition
870
- // propagate_back_references will be called later once the file has been completely processed.
871
- return;
872
- }
873
- const addressSpace = this.addressSpace;
874
- for (const reference of Object.values(_private._referenceIdx)) {
875
- _propagate_ref.call(this, addressSpace, reference);
876
- }
877
- }
878
- /**
879
- * the dispose method should be called when the node is no longer used, to release
880
- * back pointer to the address space and clear caches.
881
- *
882
- * @method dispose
883
- *
884
- */
885
- dispose() {
886
- const _private = base_node_private_1.BaseNode_getPrivate(this);
887
- this.emit("dispose");
888
- this.removeAllListeners();
889
- this._clear_caches();
890
- Object.values(_private._back_referenceIdx).forEach((ref) => ref.dispose());
891
- Object.values(_private._referenceIdx).forEach((ref) => ref.dispose());
892
- _private._cache = {};
893
- _private.__address_space = null;
894
- _private._back_referenceIdx = null;
895
- _private._referenceIdx = null;
896
- base_node_private_1.BaseNode_removePrivate(this);
897
- }
898
- // istanbul ignore next
899
- dumpXML(xmlWriter) {
900
- console.error(" This ", node_opcua_data_model_1.NodeClass[this.nodeClass]);
901
- node_opcua_assert_1.assert(false, "BaseNode#dumpXML NOT IMPLEMENTED !");
902
- node_opcua_assert_1.assert(xmlWriter);
903
- }
904
- /**
905
- * Undo the effect of propagate_back_references
906
- */
907
- unpropagate_back_references() {
908
- const _private = base_node_private_1.BaseNode_getPrivate(this);
909
- const addressSpace = this.addressSpace;
910
- for (const reference of Object.values(_private._referenceIdx)) {
911
- // filter out non Hierarchical References
912
- const referenceType = resolveReferenceType(addressSpace, reference);
913
- // istanbul ignore next
914
- if (!referenceType) {
915
- console.error(chalk.red(" ERROR"), " cannot find reference ", reference.referenceType, reference.toString());
916
- }
917
- const related_node = resolveReferenceNode(addressSpace, reference);
918
- if (related_node) {
919
- node_opcua_assert_1.assert(reference.nodeId.toString() !== this.nodeId.toString());
920
- base_node_private_1.BaseNode_remove_backward_reference.call(related_node, new reference_1.Reference({
921
- isForward: !reference.isForward,
922
- nodeId: this.nodeId,
923
- referenceType: reference.referenceType
924
- }));
925
- } // else addressSpace may be incomplete
926
- }
927
- }
928
- installPostInstallFunc(f) {
929
- if (!f) {
930
- // nothing to do
931
- return;
932
- }
933
- function chain(f1, f2) {
934
- return function chaiFunc() {
935
- const args = arguments;
936
- if (f1) {
937
- f1.apply(this, args);
938
- }
939
- if (f2) {
940
- f2.apply(this, args);
941
- }
942
- };
943
- }
944
- this._postInstantiateFunc = chain.call(this, this._postInstantiateFunc, f);
945
- }
946
- _on_child_added() {
947
- this._clear_caches();
948
- }
949
- _on_child_removed(obj) {
950
- // obj; // unused;
951
- this._clear_caches();
952
- }
953
- _add_backward_reference(reference) {
954
- base_node_private_1.BaseNode_add_backward_reference.call(this, reference);
955
- }
956
- _coerceReferenceType(referenceType) {
957
- let result;
958
- if (typeof referenceType === "string") {
959
- result = this.addressSpace.findReferenceType(referenceType);
960
- /* istanbul ignore next */
961
- if (!result) {
962
- throw new Error("Cannot coerce reference with name " + referenceType);
963
- }
964
- }
965
- else if (referenceType instanceof node_opcua_nodeid_1.NodeId) {
966
- result = this.addressSpace.findNode(referenceType);
967
- }
968
- else {
969
- result = referenceType;
970
- }
971
- node_opcua_assert_1.assert(result.nodeClass === node_opcua_data_model_1.NodeClass.ReferenceType);
972
- return result;
973
- }
974
- __addReference(referenceOpts) {
975
- const _private = base_node_private_1.BaseNode_getPrivate(this);
976
- node_opcua_assert_1.assert(referenceOpts.hasOwnProperty("referenceType"));
977
- // xx isForward is optional : assert(reference.hasOwnProperty("isForward"));
978
- node_opcua_assert_1.assert(referenceOpts.hasOwnProperty("nodeId"));
979
- const addressSpace = this.addressSpace;
980
- const reference = addressSpace.normalizeReferenceTypes([referenceOpts])[0];
981
- node_opcua_assert_1.assert(reference instanceof reference_1.Reference);
982
- const h = reference.hash;
983
- node_opcua_assert_1.assert(!_private._back_referenceIdx[h], "reference exists already in _back_references");
984
- node_opcua_assert_1.assert(!_private._referenceIdx[h], "reference exists already in _references");
985
- _private._referenceIdx[h] = reference;
986
- base_node_private_1._handle_HierarchicalReference(this, reference);
987
- return reference;
988
- }
989
- _setDisplayName(displayName) {
990
- const displayNames = Array.isArray(displayName) ? displayName : [displayName];
991
- const _displayNames = displayNames.map(node_opcua_data_model_1.coerceLocalizedText);
992
- const _private = base_node_private_1.BaseNode_getPrivate(this);
993
- _private._displayName = _displayNames;
994
- }
995
- _setDescription(description) {
996
- const __description = node_opcua_data_model_1.coerceLocalizedText(description);
997
- const _private = base_node_private_1.BaseNode_getPrivate(this);
998
- _private._description = __description;
999
- }
1000
- _notifyAttributeChange(attributeId) {
1001
- const event_name = BaseNode.makeAttributeEventName(attributeId);
1002
- this.emit(event_name, this.readAttribute(source_1.SessionContext.defaultContext, attributeId));
1003
- }
1004
- _clear_caches() {
1005
- const _private = base_node_private_1.BaseNode_getPrivate(this);
1006
- _private._cache = {};
1007
- }
1008
- }
1009
- exports.BaseNode = BaseNode;
1010
- let displayWarning = true;
1011
- function toString_ReferenceDescription(ref, options) {
1012
- const addressSpace = options.addressSpace;
1013
- // xx assert(ref instanceof ReferenceDescription);
1014
- const refNode = addressSpace.findNode(ref.referenceType);
1015
- if (!refNode) {
1016
- return "Unknown Ref : " + ref;
1017
- }
1018
- const r = new reference_1.Reference({
1019
- isForward: ref.isForward,
1020
- nodeId: ref.nodeId,
1021
- referenceType: refNode.browseName.toString()
1022
- });
1023
- const str = r.toString(options);
1024
- r.dispose();
1025
- return str;
1026
- }
1027
- /* jshint latedef: false */
1028
- function _setup_parent_item(references) {
1029
- references = Object.values(references);
1030
- const _private = base_node_private_1.BaseNode_getPrivate(this);
1031
- node_opcua_assert_1.assert(!_private._parent, "_setup_parent_item has been already called");
1032
- const addressSpace = this.addressSpace;
1033
- if (references.length > 0) {
1034
- references = this.findReferencesEx("HasChild", node_opcua_data_model_1.BrowseDirection.Inverse);
1035
- if (references.length >= 1) {
1036
- // istanbul ignore next
1037
- if (references.length > 1) {
1038
- if (displayWarning) {
1039
- const options = { addressSpace };
1040
- // tslint:disable-next-line:no-console
1041
- console.warn(" More than one HasChild reference have been found for parent of object");
1042
- // tslint:disable-next-line:no-console
1043
- console.warn(" object node id:", this.nodeId.toString(), chalk.cyan(this.browseName.toString()));
1044
- // tslint:disable-next-line:no-console
1045
- console.warn(" browseResults:");
1046
- // tslint:disable-next-line:no-console
1047
- console.warn(references.map((f) => toString_ReferenceDescription(f, options)).join("\n"));
1048
- // tslint:disable-next-line:no-console
1049
- console.warn(" first one will be used as parent");
1050
- // xx assert(browseResults.length === 1);
1051
- displayWarning = false;
1052
- }
1053
- }
1054
- return reference_1.Reference.resolveReferenceNode(addressSpace, references[0]);
1055
- }
1056
- }
1057
- return null;
1058
- }
1059
- function _asObject(references, addressSpace) {
1060
- function toObject(reference) {
1061
- const obj = resolveReferenceNode(addressSpace, reference);
1062
- // istanbul ignore next
1063
- if (false && !obj) {
1064
- // tslint:disable-next-line:no-console
1065
- console.log(chalk.red(" Warning : object with nodeId ") +
1066
- chalk.cyan(reference.nodeId.toString()) +
1067
- chalk.red(" cannot be found in the address space !"));
1068
- }
1069
- return obj;
1070
- }
1071
- function remove_null(o) {
1072
- return !!o;
1073
- }
1074
- return references.map(toObject).filter(remove_null);
1075
- }
1076
- function _filter_by_browse_name(components, browseName, namespaceIndex) {
1077
- let select = [];
1078
- if (namespaceIndex === null || namespaceIndex === undefined) {
1079
- select = components.filter((c) => c.browseName.name.toString() === browseName);
1080
- }
1081
- else {
1082
- select = components.filter((c) => c.browseName.name.toString() === browseName && c.browseName.namespaceIndex === namespaceIndex);
1083
- }
1084
- return select;
1085
- }
1086
- let displayWarningReferencePointingToItSelf = true;
1087
- function _is_massively_used_reference(referenceType) {
1088
- const name = referenceType.browseName.toString();
1089
- return name === "HasTypeDefinition" || name === "HasModellingRule";
1090
- }
1091
- function _propagate_ref(addressSpace, reference) {
1092
- // filter out non Hierarchical References
1093
- const referenceType = reference_1.Reference.resolveReferenceType(addressSpace, reference);
1094
- // istanbul ignore next
1095
- if (!referenceType) {
1096
- // tslint:disable-next-line:no-console
1097
- console.error(chalk.red(" ERROR"), " cannot find reference ", reference.referenceType, reference.toString());
1098
- }
1099
- // ------------------------------- Filter out back reference when reference type
1100
- // is HasTypeDefinition, HasModellingRule, etc ...
1101
- //
1102
- // var referenceNode = Reference.resolveReferenceNode(addressSpace,reference);
1103
- // ignore propagation on back reference to UAVariableType or UAObject Type reference
1104
- // because there are too many !
1105
- if (!referenceType || _is_massively_used_reference(referenceType)) {
1106
- return;
1107
- }
1108
- // ------------------------------- EXPERIMENT
1109
- // xx if (!referenceType.isSupertypeOf(hierarchicalReferencesId)) { return; }
1110
- const related_node = resolveReferenceNode(addressSpace, reference);
1111
- if (related_node) {
1112
- // verify that reference doesn't point to object itthis (see mantis 3099)
1113
- if (node_opcua_nodeid_1.sameNodeId(reference.nodeId, this.nodeId)) {
1114
- // istanbul ignore next
1115
- if (displayWarningReferencePointingToItSelf) {
1116
- // this could happen with method
1117
- console.warn(" Warning: a Reference is pointing to itthis ", this.nodeId.toString(), this.browseName.toString());
1118
- displayWarningReferencePointingToItSelf = false;
1119
- }
1120
- }
1121
- // xx ignore this assert(reference.nodeId.toString() !== this.nodeId.toString());
1122
- // function w(s,l) { return (s+" ").substr(0,l);}
1123
- // if (reference.isForward) {
1124
- // console.log(" CHILD => ",w(related_node.browseName + " " + related_node.nodeId.toString(),30),
1125
- // " PARENT ",w(this.browseName + " " + this.nodeId.toString(),30) , reference.toString());
1126
- // } else {
1127
- // console.log(" CHILD => ",w(this.browseName + " " + this.nodeId.toString(),30),
1128
- // " PARENT ",w(related_node.browseName + " " + related_node.nodeId.toString(),30) , reference.toString());
1129
- //
1130
- // }
1131
- related_node._add_backward_reference(new reference_1.Reference({
1132
- _referenceType: reference._referenceType,
1133
- isForward: !reference.isForward,
1134
- node: this,
1135
- nodeId: this.nodeId,
1136
- referenceType: reference.referenceType
1137
- }));
1138
- } // else addressSpace may be incomplete and under construction (while loading a nodeset.xml file for instance)
1139
- }
1140
- function nodeid_is_nothing(nodeid) {
1141
- return nodeid.value === 0 && nodeid.namespace === 0;
1142
- }
1143
- /**
1144
- * @method normalize_referenceTypeId
1145
- * @param addressSpace {AddressSpace}
1146
- * @param referenceTypeId {String|NodeId|null} : the referenceType either as a string or a nodeId
1147
- * @return {NodeId}
1148
- */
1149
- function normalize_referenceTypeId(addressSpace, referenceTypeId) {
1150
- if (!referenceTypeId) {
1151
- return node_opcua_nodeid_1.makeNodeId(0);
1152
- }
1153
- if (typeof referenceTypeId === "string") {
1154
- const ref = addressSpace.findReferenceType(referenceTypeId);
1155
- if (ref) {
1156
- return ref.nodeId;
1157
- }
1158
- }
1159
- let nodeId;
1160
- try {
1161
- nodeId = addressSpace.resolveNodeId(referenceTypeId);
1162
- }
1163
- catch (err) {
1164
- console.log("cannot normalize_referenceTypeId", referenceTypeId);
1165
- throw err;
1166
- }
1167
- node_opcua_assert_1.assert(nodeId);
1168
- return nodeId;
1169
- }
1170
- const resolveReferenceNode = reference_1.Reference.resolveReferenceNode;
1171
- const resolveReferenceType = reference_1.Reference.resolveReferenceType;
1172
- function _filter_by_referenceType(browseDescription, references, referenceTypeId) {
1173
- // make sure we have a valid referenceTypeId if not null
1174
- if (!nodeid_is_nothing(referenceTypeId)) {
1175
- node_opcua_assert_1.assert(referenceTypeId instanceof node_opcua_nodeid_1.NodeId);
1176
- const referenceType = this.addressSpace.findNode(referenceTypeId);
1177
- node_opcua_debug_1.dumpIf(!referenceType, referenceTypeId);
1178
- if (!referenceType || referenceType.nodeClass !== node_opcua_data_model_1.NodeClass.ReferenceType) {
1179
- throw new Error("Cannot find reference type");
1180
- }
1181
- references = references.filter((reference) => {
1182
- const ref = resolveReferenceType(this.addressSpace, reference);
1183
- if (!ref) {
1184
- return false;
1185
- } // unknown type ... this may happen when the address space is not fully build
1186
- node_opcua_assert_1.assert(ref.nodeClass === node_opcua_data_model_1.NodeClass.ReferenceType);
1187
- const is_of_type = ref.nodeId.toString() === referenceType.nodeId.toString();
1188
- if (is_of_type) {
1189
- return true;
1190
- }
1191
- if (browseDescription.includeSubtypes) {
1192
- return ref.isSupertypeOf(referenceType);
1193
- }
1194
- else {
1195
- return false;
1196
- }
1197
- });
1198
- }
1199
- return references;
1200
- }
1201
- function forwardOnly(reference) {
1202
- return reference.isForward;
1203
- }
1204
- function reverseOnly(reference) {
1205
- return !reference.isForward;
1206
- }
1207
- function _filter_by_direction(references, browseDirection) {
1208
- if (browseDirection === node_opcua_data_model_1.BrowseDirection.Both) {
1209
- return references;
1210
- }
1211
- if (browseDirection === node_opcua_data_model_1.BrowseDirection.Forward) {
1212
- return references.filter(forwardOnly);
1213
- }
1214
- else {
1215
- return references.filter(reverseOnly);
1216
- }
1217
- }
1218
- function _filter_by_nodeClass(references, nodeClassMask) {
1219
- node_opcua_assert_1.assert(isFinite(nodeClassMask));
1220
- if (nodeClassMask === 0) {
1221
- return references;
1222
- }
1223
- const addressSpace = this.addressSpace;
1224
- return references.filter((reference) => {
1225
- const obj = resolveReferenceNode(addressSpace, reference);
1226
- if (!obj) {
1227
- return false;
1228
- }
1229
- const nodeClassName = node_opcua_data_model_1.NodeClass[obj.nodeClass];
1230
- const value = node_opcua_data_model_1.makeNodeClassMask(nodeClassName);
1231
- return (value & nodeClassMask) === value;
1232
- });
1233
- }
1234
- function _filter_by_userFilter(references, context) {
1235
- const addressSpace = this.addressSpace;
1236
- return references.filter((reference) => {
1237
- const obj = resolveReferenceNode(addressSpace, reference);
1238
- if (!obj) {
1239
- return false;
1240
- }
1241
- const _private = base_node_private_1.BaseNode_getPrivate(obj);
1242
- if (!_private._browseFilter) {
1243
- throw Error("Internal error : cannot find browseFilter");
1244
- }
1245
- return _private._browseFilter.call(obj, context);
1246
- });
1247
- }
1248
- const reservedNames = {
1249
- __description: 0,
1250
- __displayName: 0,
1251
- browseName: 0,
1252
- description: 0,
1253
- displayName: 0,
1254
- nodeClass: 0,
1255
- nodeId: 0,
1256
- typeDefinition: 0
1257
- };
1258
- /*
1259
- * install hierarchical references as javascript properties
1260
- * Components/Properties/Organizes
1261
- */
1262
- function install_components_as_object_properties(parentObj) {
1263
- if (!parentObj) {
1264
- return;
1265
- }
1266
- const addressSpace = parentObj.addressSpace;
1267
- const hierarchicalRefs = parentObj.findHierarchicalReferences();
1268
- const children = hierarchicalRefs.map((r) => reference_1.Reference.resolveReferenceNode(addressSpace, r));
1269
- for (const child of children) {
1270
- if (!child) {
1271
- continue;
1272
- }
1273
- // assumption: we ignore namespace here .
1274
- const name = node_opcua_utils_1.lowerFirstLetter(child.browseName.name.toString());
1275
- if (reservedNames.hasOwnProperty(name)) {
1276
- if (doDebug) {
1277
- console.log(chalk.bgWhite.red("Ignoring reserved keyword " + name));
1278
- }
1279
- continue;
1280
- }
1281
- if (doDebug) {
1282
- console.log("Installing property " + name, " on ", parentObj.browseName.toString());
1283
- }
1284
- /* istanbul ignore next */
1285
- if (parentObj.hasOwnProperty(name)) {
1286
- continue;
1287
- }
1288
- Object.defineProperty(parentObj, name, {
1289
- configurable: true,
1290
- enumerable: true,
1291
- // xx writable: false,
1292
- get() {
1293
- return child;
1294
- }
1295
- // value: child
1296
- });
1297
- }
1298
- }
1299
- //# sourceMappingURL=base_node.js.map