node-opcua-address-space 2.96.0 → 2.98.0

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 (433) hide show
  1. package/package.json +37 -37
  2. package/source/interfaces/alarms_and_conditions/ua_condition_ex.ts +4 -3
  3. package/source/loader/make_xml_extension_object_parser.ts +10 -9
  4. package/src/address_space.ts +6 -5
  5. package/src/alarms_and_conditions/ua_condition_impl.ts +14 -9
  6. package/src/base_node_impl.ts +6 -2
  7. package/src/base_node_private.ts +73 -28
  8. package/src/data_access/ua_two_state_discrete_impl.ts +2 -0
  9. package/src/ua_variable_impl.ts +2039 -2037
  10. package/src/ua_variable_type_impl.ts +35 -17
  11. package/dist/source/address_space_ts.d.ts +0 -118
  12. package/dist/source/address_space_ts.js +0 -18
  13. package/dist/source/address_space_ts.js.map +0 -1
  14. package/dist/source/continuation_points/continuation_point_manager.d.ts +0 -91
  15. package/dist/source/continuation_points/continuation_point_manager.js +0 -201
  16. package/dist/source/continuation_points/continuation_point_manager.js.map +0 -1
  17. package/dist/source/helpers/adjust_browse_direction.d.ts +0 -5
  18. package/dist/source/helpers/adjust_browse_direction.js +0 -12
  19. package/dist/source/helpers/adjust_browse_direction.js.map +0 -1
  20. package/dist/source/helpers/argument_list.d.ts +0 -33
  21. package/dist/source/helpers/argument_list.js +0 -255
  22. package/dist/source/helpers/argument_list.js.map +0 -1
  23. package/dist/source/helpers/call_helpers.d.ts +0 -6
  24. package/dist/source/helpers/call_helpers.js +0 -72
  25. package/dist/source/helpers/call_helpers.js.map +0 -1
  26. package/dist/source/helpers/coerce_enum_value.d.ts +0 -6
  27. package/dist/source/helpers/coerce_enum_value.js +0 -34
  28. package/dist/source/helpers/coerce_enum_value.js.map +0 -1
  29. package/dist/source/helpers/dump_tools.d.ts +0 -14
  30. package/dist/source/helpers/dump_tools.js +0 -79
  31. package/dist/source/helpers/dump_tools.js.map +0 -1
  32. package/dist/source/helpers/ensure_secure_access.d.ts +0 -9
  33. package/dist/source/helpers/ensure_secure_access.js +0 -77
  34. package/dist/source/helpers/ensure_secure_access.js.map +0 -1
  35. package/dist/source/helpers/make_optionals_map.d.ts +0 -21
  36. package/dist/source/helpers/make_optionals_map.js +0 -30
  37. package/dist/source/helpers/make_optionals_map.js.map +0 -1
  38. package/dist/source/helpers/multiform_func.d.ts +0 -11
  39. package/dist/source/helpers/multiform_func.js +0 -76
  40. package/dist/source/helpers/multiform_func.js.map +0 -1
  41. package/dist/source/helpers/resolve_opaque_on_address_space.d.ts +0 -3
  42. package/dist/source/helpers/resolve_opaque_on_address_space.js +0 -37
  43. package/dist/source/helpers/resolve_opaque_on_address_space.js.map +0 -1
  44. package/dist/source/index.d.ts +0 -61
  45. package/dist/source/index.js +0 -90
  46. package/dist/source/index.js.map +0 -1
  47. package/dist/source/interfaces/alarms_and_conditions/condition_info_i.d.ts +0 -19
  48. package/dist/source/interfaces/alarms_and_conditions/condition_info_i.js +0 -3
  49. package/dist/source/interfaces/alarms_and_conditions/condition_info_i.js.map +0 -1
  50. package/dist/source/interfaces/alarms_and_conditions/condition_snapshot.d.ts +0 -193
  51. package/dist/source/interfaces/alarms_and_conditions/condition_snapshot.js +0 -3
  52. package/dist/source/interfaces/alarms_and_conditions/condition_snapshot.js.map +0 -1
  53. package/dist/source/interfaces/alarms_and_conditions/deviation_stuff.d.ts +0 -12
  54. package/dist/source/interfaces/alarms_and_conditions/deviation_stuff.js +0 -3
  55. package/dist/source/interfaces/alarms_and_conditions/deviation_stuff.js.map +0 -1
  56. package/dist/source/interfaces/alarms_and_conditions/install_setpoint_options.d.ts +0 -10
  57. package/dist/source/interfaces/alarms_and_conditions/install_setpoint_options.js +0 -3
  58. package/dist/source/interfaces/alarms_and_conditions/install_setpoint_options.js.map +0 -1
  59. package/dist/source/interfaces/alarms_and_conditions/instantiate_alarm_condition_options.d.ts +0 -7
  60. package/dist/source/interfaces/alarms_and_conditions/instantiate_alarm_condition_options.js +0 -3
  61. package/dist/source/interfaces/alarms_and_conditions/instantiate_alarm_condition_options.js.map +0 -1
  62. package/dist/source/interfaces/alarms_and_conditions/instantiate_condition_options.d.ts +0 -7
  63. package/dist/source/interfaces/alarms_and_conditions/instantiate_condition_options.js +0 -3
  64. package/dist/source/interfaces/alarms_and_conditions/instantiate_condition_options.js.map +0 -1
  65. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_deviation_alarm_options.d.ts +0 -4
  66. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_deviation_alarm_options.js +0 -3
  67. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_deviation_alarm_options.js.map +0 -1
  68. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_limit_alarm_options.d.ts +0 -4
  69. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_limit_alarm_options.js +0 -3
  70. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_limit_alarm_options.js.map +0 -1
  71. package/dist/source/interfaces/alarms_and_conditions/instantiate_limit_alarm_options.d.ts +0 -9
  72. package/dist/source/interfaces/alarms_and_conditions/instantiate_limit_alarm_options.js +0 -3
  73. package/dist/source/interfaces/alarms_and_conditions/instantiate_limit_alarm_options.js.map +0 -1
  74. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_deviation_alarm_options.d.ts +0 -4
  75. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_deviation_alarm_options.js +0 -3
  76. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_deviation_alarm_options.js.map +0 -1
  77. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_limit_alarm_options.d.ts +0 -4
  78. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_limit_alarm_options.js +0 -3
  79. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_limit_alarm_options.js.map +0 -1
  80. package/dist/source/interfaces/alarms_and_conditions/instantiate_off_normal_alarm_options.d.ts +0 -20
  81. package/dist/source/interfaces/alarms_and_conditions/instantiate_off_normal_alarm_options.js +0 -3
  82. package/dist/source/interfaces/alarms_and_conditions/instantiate_off_normal_alarm_options.js.map +0 -1
  83. package/dist/source/interfaces/alarms_and_conditions/ua_acknowledgeable_condition_ex.d.ts +0 -23
  84. package/dist/source/interfaces/alarms_and_conditions/ua_acknowledgeable_condition_ex.js +0 -3
  85. package/dist/source/interfaces/alarms_and_conditions/ua_acknowledgeable_condition_ex.js.map +0 -1
  86. package/dist/source/interfaces/alarms_and_conditions/ua_alarm_condition_ex.d.ts +0 -32
  87. package/dist/source/interfaces/alarms_and_conditions/ua_alarm_condition_ex.js +0 -3
  88. package/dist/source/interfaces/alarms_and_conditions/ua_alarm_condition_ex.js.map +0 -1
  89. package/dist/source/interfaces/alarms_and_conditions/ua_certificate_expiration_alarm_ex.d.ts +0 -19
  90. package/dist/source/interfaces/alarms_and_conditions/ua_certificate_expiration_alarm_ex.js +0 -3
  91. package/dist/source/interfaces/alarms_and_conditions/ua_certificate_expiration_alarm_ex.js.map +0 -1
  92. package/dist/source/interfaces/alarms_and_conditions/ua_condition_ex.d.ts +0 -42
  93. package/dist/source/interfaces/alarms_and_conditions/ua_condition_ex.js +0 -3
  94. package/dist/source/interfaces/alarms_and_conditions/ua_condition_ex.js.map +0 -1
  95. package/dist/source/interfaces/alarms_and_conditions/ua_discrete_alarm_ex.d.ts +0 -7
  96. package/dist/source/interfaces/alarms_and_conditions/ua_discrete_alarm_ex.js +0 -26
  97. package/dist/source/interfaces/alarms_and_conditions/ua_discrete_alarm_ex.js.map +0 -1
  98. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_deviation_alarm_ex.d.ts +0 -5
  99. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_deviation_alarm_ex.js +0 -3
  100. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_deviation_alarm_ex.js.map +0 -1
  101. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_limit_alarm_ex.d.ts +0 -20
  102. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_limit_alarm_ex.js +0 -3
  103. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_limit_alarm_ex.js.map +0 -1
  104. package/dist/source/interfaces/alarms_and_conditions/ua_limit_alarm_ex.d.ts +0 -26
  105. package/dist/source/interfaces/alarms_and_conditions/ua_limit_alarm_ex.js +0 -3
  106. package/dist/source/interfaces/alarms_and_conditions/ua_limit_alarm_ex.js.map +0 -1
  107. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_deviation_alarm_ex.d.ts +0 -8
  108. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_deviation_alarm_ex.js +0 -3
  109. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_deviation_alarm_ex.js.map +0 -1
  110. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_limit_alarm_ex.d.ts +0 -10
  111. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_limit_alarm_ex.js +0 -3
  112. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_limit_alarm_ex.js.map +0 -1
  113. package/dist/source/interfaces/data_access/ua_multistate_discrete_ex.d.ts +0 -21
  114. package/dist/source/interfaces/data_access/ua_multistate_discrete_ex.js +0 -3
  115. package/dist/source/interfaces/data_access/ua_multistate_discrete_ex.js.map +0 -1
  116. package/dist/source/interfaces/data_access/ua_multistate_value_discrete_ex.d.ts +0 -24
  117. package/dist/source/interfaces/data_access/ua_multistate_value_discrete_ex.js +0 -3
  118. package/dist/source/interfaces/data_access/ua_multistate_value_discrete_ex.js.map +0 -1
  119. package/dist/source/interfaces/data_access/ua_two_state_discrete_ex.d.ts +0 -12
  120. package/dist/source/interfaces/data_access/ua_two_state_discrete_ex.js +0 -3
  121. package/dist/source/interfaces/data_access/ua_two_state_discrete_ex.js.map +0 -1
  122. package/dist/source/interfaces/data_access/ua_y_array_item_ex.d.ts +0 -8
  123. package/dist/source/interfaces/data_access/ua_y_array_item_ex.js +0 -3
  124. package/dist/source/interfaces/data_access/ua_y_array_item_ex.js.map +0 -1
  125. package/dist/source/interfaces/extension_object_constructor.d.ts +0 -10
  126. package/dist/source/interfaces/extension_object_constructor.js +0 -3
  127. package/dist/source/interfaces/extension_object_constructor.js.map +0 -1
  128. package/dist/source/interfaces/nodeset_loader_options.d.ts +0 -4
  129. package/dist/source/interfaces/nodeset_loader_options.js +0 -3
  130. package/dist/source/interfaces/nodeset_loader_options.js.map +0 -1
  131. package/dist/source/interfaces/state_machine/ua_exclusive_limit_state_machine_type_ex.d.ts +0 -12
  132. package/dist/source/interfaces/state_machine/ua_exclusive_limit_state_machine_type_ex.js +0 -3
  133. package/dist/source/interfaces/state_machine/ua_exclusive_limit_state_machine_type_ex.js.map +0 -1
  134. package/dist/source/interfaces/state_machine/ua_finite_state_machine_type.d.ts +0 -49
  135. package/dist/source/interfaces/state_machine/ua_finite_state_machine_type.js +0 -3
  136. package/dist/source/interfaces/state_machine/ua_finite_state_machine_type.js.map +0 -1
  137. package/dist/source/interfaces/state_machine/ua_program_state_machine_type.d.ts +0 -11
  138. package/dist/source/interfaces/state_machine/ua_program_state_machine_type.js +0 -3
  139. package/dist/source/interfaces/state_machine/ua_program_state_machine_type.js.map +0 -1
  140. package/dist/source/interfaces/state_machine/ua_shelved_state_machine_ex.d.ts +0 -30
  141. package/dist/source/interfaces/state_machine/ua_shelved_state_machine_ex.js +0 -3
  142. package/dist/source/interfaces/state_machine/ua_shelved_state_machine_ex.js.map +0 -1
  143. package/dist/source/interfaces/state_machine/ua_state_machine_type.d.ts +0 -234
  144. package/dist/source/interfaces/state_machine/ua_state_machine_type.js +0 -3
  145. package/dist/source/interfaces/state_machine/ua_state_machine_type.js.map +0 -1
  146. package/dist/source/interfaces/state_machine/ua_transition_ex.d.ts +0 -6
  147. package/dist/source/interfaces/state_machine/ua_transition_ex.js +0 -3
  148. package/dist/source/interfaces/state_machine/ua_transition_ex.js.map +0 -1
  149. package/dist/source/interfaces/ua_subscription_diagnostics_variable_ex.d.ts +0 -8
  150. package/dist/source/interfaces/ua_subscription_diagnostics_variable_ex.js +0 -3
  151. package/dist/source/interfaces/ua_subscription_diagnostics_variable_ex.js.map +0 -1
  152. package/dist/source/loader/decode_xml_extension_object.d.ts +0 -6
  153. package/dist/source/loader/decode_xml_extension_object.js +0 -72
  154. package/dist/source/loader/decode_xml_extension_object.js.map +0 -1
  155. package/dist/source/loader/ensure_datatype_extracted.d.ts +0 -5
  156. package/dist/source/loader/ensure_datatype_extracted.js +0 -71
  157. package/dist/source/loader/ensure_datatype_extracted.js.map +0 -1
  158. package/dist/source/loader/generateAddressSpaceRaw.d.ts +0 -11
  159. package/dist/source/loader/generateAddressSpaceRaw.js +0 -46
  160. package/dist/source/loader/generateAddressSpaceRaw.js.map +0 -1
  161. package/dist/source/loader/load_nodeset2.d.ts +0 -17
  162. package/dist/source/loader/load_nodeset2.js +0 -1484
  163. package/dist/source/loader/load_nodeset2.js.map +0 -1
  164. package/dist/source/loader/make_semver_compatible.d.ts +0 -6
  165. package/dist/source/loader/make_semver_compatible.js +0 -26
  166. package/dist/source/loader/make_semver_compatible.js.map +0 -1
  167. package/dist/source/loader/make_xml_extension_object_parser.d.ts +0 -28
  168. package/dist/source/loader/make_xml_extension_object_parser.js +0 -326
  169. package/dist/source/loader/make_xml_extension_object_parser.js.map +0 -1
  170. package/dist/source/loader/namespace_post_step.d.ts +0 -10
  171. package/dist/source/loader/namespace_post_step.js +0 -62
  172. package/dist/source/loader/namespace_post_step.js.map +0 -1
  173. package/dist/source/loader/register_node_promoter.d.ts +0 -2
  174. package/dist/source/loader/register_node_promoter.js +0 -10
  175. package/dist/source/loader/register_node_promoter.js.map +0 -1
  176. package/dist/source/namespace.d.ts +0 -6
  177. package/dist/source/namespace.js +0 -3
  178. package/dist/source/namespace.js.map +0 -1
  179. package/dist/source/namespace_alarm_and_condition.d.ts +0 -32
  180. package/dist/source/namespace_alarm_and_condition.js +0 -3
  181. package/dist/source/namespace_alarm_and_condition.js.map +0 -1
  182. package/dist/source/namespace_data_access.d.ts +0 -42
  183. package/dist/source/namespace_data_access.js +0 -3
  184. package/dist/source/namespace_data_access.js.map +0 -1
  185. package/dist/source/namespace_machine_state.d.ts +0 -8
  186. package/dist/source/namespace_machine_state.js +0 -3
  187. package/dist/source/namespace_machine_state.js.map +0 -1
  188. package/dist/source/pseudo_session.d.ts +0 -72
  189. package/dist/source/pseudo_session.js +0 -255
  190. package/dist/source/pseudo_session.js.map +0 -1
  191. package/dist/source/session_context.d.ts +0 -111
  192. package/dist/source/session_context.js +0 -265
  193. package/dist/source/session_context.js.map +0 -1
  194. package/dist/source/set_namespace_meta_data.d.ts +0 -2
  195. package/dist/source/set_namespace_meta_data.js +0 -60
  196. package/dist/source/set_namespace_meta_data.js.map +0 -1
  197. package/dist/source/ua_root_folder.d.ts +0 -9
  198. package/dist/source/ua_root_folder.js +0 -3
  199. package/dist/source/ua_root_folder.js.map +0 -1
  200. package/dist/source/ua_two_state_variable_ex.d.ts +0 -23
  201. package/dist/source/ua_two_state_variable_ex.js +0 -3
  202. package/dist/source/ua_two_state_variable_ex.js.map +0 -1
  203. package/dist/source/xml_writer.d.ts +0 -18
  204. package/dist/source/xml_writer.js +0 -3
  205. package/dist/source/xml_writer.js.map +0 -1
  206. package/dist/src/address_space.d.ts +0 -387
  207. package/dist/src/address_space.js +0 -1385
  208. package/dist/src/address_space.js.map +0 -1
  209. package/dist/src/address_space_change_event_tools.d.ts +0 -6
  210. package/dist/src/address_space_change_event_tools.js +0 -153
  211. package/dist/src/address_space_change_event_tools.js.map +0 -1
  212. package/dist/src/address_space_private.d.ts +0 -43
  213. package/dist/src/address_space_private.js +0 -3
  214. package/dist/src/address_space_private.js.map +0 -1
  215. package/dist/src/alarms_and_conditions/condition.d.ts +0 -5
  216. package/dist/src/alarms_and_conditions/condition.js +0 -79
  217. package/dist/src/alarms_and_conditions/condition.js.map +0 -1
  218. package/dist/src/alarms_and_conditions/condition_info_impl.d.ts +0 -26
  219. package/dist/src/alarms_and_conditions/condition_info_impl.js +0 -55
  220. package/dist/src/alarms_and_conditions/condition_info_impl.js.map +0 -1
  221. package/dist/src/alarms_and_conditions/condition_snapshot_impl.d.ts +0 -222
  222. package/dist/src/alarms_and_conditions/condition_snapshot_impl.js +0 -658
  223. package/dist/src/alarms_and_conditions/condition_snapshot_impl.js.map +0 -1
  224. package/dist/src/alarms_and_conditions/deviation_alarm_helper.d.ts +0 -9
  225. package/dist/src/alarms_and_conditions/deviation_alarm_helper.js +0 -61
  226. package/dist/src/alarms_and_conditions/deviation_alarm_helper.js.map +0 -1
  227. package/dist/src/alarms_and_conditions/index.d.ts +0 -16
  228. package/dist/src/alarms_and_conditions/index.js +0 -33
  229. package/dist/src/alarms_and_conditions/index.js.map +0 -1
  230. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_impl.d.ts +0 -44
  231. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_impl.js +0 -245
  232. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_impl.js.map +0 -1
  233. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.d.ts +0 -93
  234. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.js +0 -419
  235. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.js.map +0 -1
  236. package/dist/src/alarms_and_conditions/ua_base_event_impl.d.ts +0 -26
  237. package/dist/src/alarms_and_conditions/ua_base_event_impl.js +0 -39
  238. package/dist/src/alarms_and_conditions/ua_base_event_impl.js.map +0 -1
  239. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.d.ts +0 -44
  240. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.js +0 -184
  241. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.js.map +0 -1
  242. package/dist/src/alarms_and_conditions/ua_condition_impl.d.ts +0 -153
  243. package/dist/src/alarms_and_conditions/ua_condition_impl.js +0 -1029
  244. package/dist/src/alarms_and_conditions/ua_condition_impl.js.map +0 -1
  245. package/dist/src/alarms_and_conditions/ua_discrete_alarm_impl.d.ts +0 -14
  246. package/dist/src/alarms_and_conditions/ua_discrete_alarm_impl.js +0 -35
  247. package/dist/src/alarms_and_conditions/ua_discrete_alarm_impl.js.map +0 -1
  248. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.d.ts +0 -24
  249. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.js +0 -57
  250. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.js.map +0 -1
  251. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm_impl.d.ts +0 -11
  252. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm_impl.js +0 -12
  253. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm_impl.js.map +0 -1
  254. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.d.ts +0 -23
  255. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.js +0 -87
  256. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.js.map +0 -1
  257. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm_impl.d.ts +0 -11
  258. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm_impl.js +0 -8
  259. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm_impl.js.map +0 -1
  260. package/dist/src/alarms_and_conditions/ua_limit_alarm_impl.d.ts +0 -79
  261. package/dist/src/alarms_and_conditions/ua_limit_alarm_impl.js +0 -251
  262. package/dist/src/alarms_and_conditions/ua_limit_alarm_impl.js.map +0 -1
  263. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.d.ts +0 -24
  264. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.js +0 -51
  265. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.js.map +0 -1
  266. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.d.ts +0 -19
  267. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.js +0 -163
  268. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.js.map +0 -1
  269. package/dist/src/alarms_and_conditions/ua_off_normal_alarm_impl.d.ts +0 -46
  270. package/dist/src/alarms_and_conditions/ua_off_normal_alarm_impl.js +0 -166
  271. package/dist/src/alarms_and_conditions/ua_off_normal_alarm_impl.js.map +0 -1
  272. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.d.ts +0 -18
  273. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.js +0 -18
  274. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.js.map +0 -1
  275. package/dist/src/apply_condition_refresh.d.ts +0 -6
  276. package/dist/src/apply_condition_refresh.js +0 -28
  277. package/dist/src/apply_condition_refresh.js.map +0 -1
  278. package/dist/src/base_node_impl.d.ts +0 -283
  279. package/dist/src/base_node_impl.js +0 -1452
  280. package/dist/src/base_node_impl.js.map +0 -1
  281. package/dist/src/base_node_private.d.ts +0 -81
  282. package/dist/src/base_node_private.js +0 -804
  283. package/dist/src/base_node_private.js.map +0 -1
  284. package/dist/src/check_value_rank_compatibility.d.ts +0 -15
  285. package/dist/src/check_value_rank_compatibility.js +0 -82
  286. package/dist/src/check_value_rank_compatibility.js.map +0 -1
  287. package/dist/src/data_access/add_dataItem_stuff.d.ts +0 -11
  288. package/dist/src/data_access/add_dataItem_stuff.js +0 -62
  289. package/dist/src/data_access/add_dataItem_stuff.js.map +0 -1
  290. package/dist/src/data_access/check_variant_compatibility_ua_analog_item.d.ts +0 -1
  291. package/dist/src/data_access/check_variant_compatibility_ua_analog_item.js +0 -35
  292. package/dist/src/data_access/check_variant_compatibility_ua_analog_item.js.map +0 -1
  293. package/dist/src/data_access/ua_multistate_discrete_impl.d.ts +0 -32
  294. package/dist/src/data_access/ua_multistate_discrete_impl.js +0 -131
  295. package/dist/src/data_access/ua_multistate_discrete_impl.js.map +0 -1
  296. package/dist/src/data_access/ua_multistate_value_discrete_impl.d.ts +0 -52
  297. package/dist/src/data_access/ua_multistate_value_discrete_impl.js +0 -254
  298. package/dist/src/data_access/ua_multistate_value_discrete_impl.js.map +0 -1
  299. package/dist/src/data_access/ua_two_state_discrete_impl.d.ts +0 -25
  300. package/dist/src/data_access/ua_two_state_discrete_impl.js +0 -154
  301. package/dist/src/data_access/ua_two_state_discrete_impl.js.map +0 -1
  302. package/dist/src/event_data.d.ts +0 -34
  303. package/dist/src/event_data.js +0 -65
  304. package/dist/src/event_data.js.map +0 -1
  305. package/dist/src/extension_object_array_node.d.ts +0 -23
  306. package/dist/src/extension_object_array_node.js +0 -249
  307. package/dist/src/extension_object_array_node.js.map +0 -1
  308. package/dist/src/historical_access/address_space_historical_data_node.d.ts +0 -26
  309. package/dist/src/historical_access/address_space_historical_data_node.js +0 -653
  310. package/dist/src/historical_access/address_space_historical_data_node.js.map +0 -1
  311. package/dist/src/idx_iterator.d.ts +0 -8
  312. package/dist/src/idx_iterator.js +0 -51
  313. package/dist/src/idx_iterator.js.map +0 -1
  314. package/dist/src/index_current.d.ts +0 -46
  315. package/dist/src/index_current.js +0 -78
  316. package/dist/src/index_current.js.map +0 -1
  317. package/dist/src/namespace_impl.d.ts +0 -456
  318. package/dist/src/namespace_impl.js +0 -1763
  319. package/dist/src/namespace_impl.js.map +0 -1
  320. package/dist/src/namespace_private.d.ts +0 -23
  321. package/dist/src/namespace_private.js +0 -33
  322. package/dist/src/namespace_private.js.map +0 -1
  323. package/dist/src/nodeid_manager.d.ts +0 -37
  324. package/dist/src/nodeid_manager.js +0 -184
  325. package/dist/src/nodeid_manager.js.map +0 -1
  326. package/dist/src/nodeset_tools/adjust_namespace_array.d.ts +0 -2
  327. package/dist/src/nodeset_tools/adjust_namespace_array.js +0 -14
  328. package/dist/src/nodeset_tools/adjust_namespace_array.js.map +0 -1
  329. package/dist/src/nodeset_tools/construct_namespace_dependency.d.ts +0 -18
  330. package/dist/src/nodeset_tools/construct_namespace_dependency.js +0 -141
  331. package/dist/src/nodeset_tools/construct_namespace_dependency.js.map +0 -1
  332. package/dist/src/nodeset_tools/dump_to_bsd.d.ts +0 -2
  333. package/dist/src/nodeset_tools/dump_to_bsd.js +0 -164
  334. package/dist/src/nodeset_tools/dump_to_bsd.js.map +0 -1
  335. package/dist/src/nodeset_tools/nodeset_to_xml.d.ts +0 -10
  336. package/dist/src/nodeset_tools/nodeset_to_xml.js +0 -1288
  337. package/dist/src/nodeset_tools/nodeset_to_xml.js.map +0 -1
  338. package/dist/src/private_namespace.d.ts +0 -5
  339. package/dist/src/private_namespace.js +0 -20
  340. package/dist/src/private_namespace.js.map +0 -1
  341. package/dist/src/reference_impl.d.ts +0 -43
  342. package/dist/src/reference_impl.js +0 -140
  343. package/dist/src/reference_impl.js.map +0 -1
  344. package/dist/src/role_permissions.d.ts +0 -2
  345. package/dist/src/role_permissions.js +0 -11
  346. package/dist/src/role_permissions.js.map +0 -1
  347. package/dist/src/state_machine/finite_state_machine.d.ts +0 -81
  348. package/dist/src/state_machine/finite_state_machine.js +0 -389
  349. package/dist/src/state_machine/finite_state_machine.js.map +0 -1
  350. package/dist/src/state_machine/ua_shelving_state_machine_ex.d.ts +0 -38
  351. package/dist/src/state_machine/ua_shelving_state_machine_ex.js +0 -251
  352. package/dist/src/state_machine/ua_shelving_state_machine_ex.js.map +0 -1
  353. package/dist/src/state_machine/ua_two_state_variable.d.ts +0 -61
  354. package/dist/src/state_machine/ua_two_state_variable.js +0 -332
  355. package/dist/src/state_machine/ua_two_state_variable.js.map +0 -1
  356. package/dist/src/tool_isSubtypeOf.d.ts +0 -18
  357. package/dist/src/tool_isSubtypeOf.js +0 -125
  358. package/dist/src/tool_isSubtypeOf.js.map +0 -1
  359. package/dist/src/tool_isSupertypeOf.d.ts +0 -18
  360. package/dist/src/tool_isSupertypeOf.js +0 -125
  361. package/dist/src/tool_isSupertypeOf.js.map +0 -1
  362. package/dist/src/ua_condition_type.d.ts +0 -8
  363. package/dist/src/ua_condition_type.js +0 -3
  364. package/dist/src/ua_condition_type.js.map +0 -1
  365. package/dist/src/ua_data_type_impl.d.ts +0 -89
  366. package/dist/src/ua_data_type_impl.js +0 -369
  367. package/dist/src/ua_data_type_impl.js.map +0 -1
  368. package/dist/src/ua_method_impl.d.ts +0 -42
  369. package/dist/src/ua_method_impl.js +0 -218
  370. package/dist/src/ua_method_impl.js.map +0 -1
  371. package/dist/src/ua_object_impl.d.ts +0 -35
  372. package/dist/src/ua_object_impl.js +0 -169
  373. package/dist/src/ua_object_impl.js.map +0 -1
  374. package/dist/src/ua_object_type_impl.d.ts +0 -50
  375. package/dist/src/ua_object_type_impl.js +0 -127
  376. package/dist/src/ua_object_type_impl.js.map +0 -1
  377. package/dist/src/ua_reference_type_impl.d.ts +0 -45
  378. package/dist/src/ua_reference_type_impl.js +0 -142
  379. package/dist/src/ua_reference_type_impl.js.map +0 -1
  380. package/dist/src/ua_variable_impl.d.ts +0 -380
  381. package/dist/src/ua_variable_impl.js +0 -1738
  382. package/dist/src/ua_variable_impl.js.map +0 -1
  383. package/dist/src/ua_variable_impl_ext_obj.d.ts +0 -23
  384. package/dist/src/ua_variable_impl_ext_obj.js +0 -671
  385. package/dist/src/ua_variable_impl_ext_obj.js.map +0 -1
  386. package/dist/src/ua_variable_type_impl.d.ts +0 -74
  387. package/dist/src/ua_variable_type_impl.js +0 -582
  388. package/dist/src/ua_variable_type_impl.js.map +0 -1
  389. package/dist/src/ua_view_impl.d.ts +0 -19
  390. package/dist/src/ua_view_impl.js +0 -44
  391. package/dist/src/ua_view_impl.js.map +0 -1
  392. package/distHelpers/add_event_generator_object.d.ts +0 -3
  393. package/distHelpers/add_event_generator_object.js +0 -65
  394. package/distHelpers/add_event_generator_object.js.map +0 -1
  395. package/distHelpers/alarms_and_conditions_demo.d.ts +0 -9
  396. package/distHelpers/alarms_and_conditions_demo.js +0 -116
  397. package/distHelpers/alarms_and_conditions_demo.js.map +0 -1
  398. package/distHelpers/assertHasMatchingReference.d.ts +0 -19
  399. package/distHelpers/assertHasMatchingReference.js +0 -41
  400. package/distHelpers/assertHasMatchingReference.js.map +0 -1
  401. package/distHelpers/boiler_system.d.ts +0 -113
  402. package/distHelpers/boiler_system.js +0 -396
  403. package/distHelpers/boiler_system.js.map +0 -1
  404. package/distHelpers/create_minimalist_address_space_nodeset.d.ts +0 -5
  405. package/distHelpers/create_minimalist_address_space_nodeset.js +0 -172
  406. package/distHelpers/create_minimalist_address_space_nodeset.js.map +0 -1
  407. package/distHelpers/date_utils.d.ts +0 -3
  408. package/distHelpers/date_utils.js +0 -10
  409. package/distHelpers/date_utils.js.map +0 -1
  410. package/distHelpers/dump_statemachine.d.ts +0 -0
  411. package/distHelpers/dump_statemachine.js +0 -128
  412. package/distHelpers/dump_statemachine.js.map +0 -1
  413. package/distHelpers/get_address_space_fixture.d.ts +0 -1
  414. package/distHelpers/get_address_space_fixture.js +0 -31
  415. package/distHelpers/get_address_space_fixture.js.map +0 -1
  416. package/distHelpers/get_mini_address_space.d.ts +0 -7
  417. package/distHelpers/get_mini_address_space.js +0 -37
  418. package/distHelpers/get_mini_address_space.js.map +0 -1
  419. package/distHelpers/index.d.ts +0 -12
  420. package/distHelpers/index.js +0 -29
  421. package/distHelpers/index.js.map +0 -1
  422. package/distHelpers/mock_session.d.ts +0 -10
  423. package/distHelpers/mock_session.js +0 -26
  424. package/distHelpers/mock_session.js.map +0 -1
  425. package/distNodeJS/generate_address_space.d.ts +0 -6
  426. package/distNodeJS/generate_address_space.js +0 -53
  427. package/distNodeJS/generate_address_space.js.map +0 -1
  428. package/distNodeJS/index.d.ts +0 -1
  429. package/distNodeJS/index.js +0 -18
  430. package/distNodeJS/index.js.map +0 -1
  431. package/source/helpers/dump_tools.ts +0 -92
  432. package/src/nodeset_tools/dump_to_bsd.ts +0 -196
  433. package/test_helpers/dump_statemachine.ts +0 -155
@@ -1,1385 +0,0 @@
1
- "use strict";
2
- /**
3
- * @module node-opcua-address-space
4
- */
5
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
6
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
7
- return new (P || (P = Promise))(function (resolve, reject) {
8
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
9
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
10
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
11
- step((generator = generator.apply(thisArg, _arguments || [])).next());
12
- });
13
- };
14
- Object.defineProperty(exports, "__esModule", { value: true });
15
- exports.AddressSpace = void 0;
16
- const crypto_1 = require("crypto");
17
- const chalk = require("chalk");
18
- const node_opcua_assert_1 = require("node-opcua-assert");
19
- const node_opcua_constants_1 = require("node-opcua-constants");
20
- const node_opcua_data_model_1 = require("node-opcua-data-model");
21
- const node_opcua_nodeid_1 = require("node-opcua-nodeid");
22
- const node_opcua_object_registry_1 = require("node-opcua-object-registry");
23
- const node_opcua_service_browse_1 = require("node-opcua-service-browse");
24
- const node_opcua_status_code_1 = require("node-opcua-status-code");
25
- const node_opcua_types_1 = require("node-opcua-types");
26
- const utils = require("node-opcua-utils");
27
- const node_opcua_utils_1 = require("node-opcua-utils");
28
- const node_opcua_variant_1 = require("node-opcua-variant");
29
- const node_opcua_debug_1 = require("node-opcua-debug");
30
- const adjust_browse_direction_1 = require("../source/helpers/adjust_browse_direction");
31
- const alarms_and_conditions_1 = require("./alarms_and_conditions");
32
- const event_data_1 = require("./event_data");
33
- const address_space_historical_data_node_1 = require("./historical_access/address_space_historical_data_node");
34
- const namespace_impl_1 = require("./namespace_impl");
35
- const namespace_impl_2 = require("./namespace_impl");
36
- const ua_data_type_impl_1 = require("./ua_data_type_impl");
37
- const ua_object_type_impl_1 = require("./ua_object_type_impl");
38
- const ua_object_impl_1 = require("./ua_object_impl");
39
- const reference_impl_1 = require("./reference_impl");
40
- const ua_reference_type_impl_1 = require("./ua_reference_type_impl");
41
- const base_node_impl_1 = require("./base_node_impl");
42
- const doDebug = false;
43
- const errorLog = (0, node_opcua_debug_1.make_errorLog)(__filename);
44
- // tslint:disable-next-line:no-var-requires
45
- const Dequeue = require("dequeue");
46
- const regexNumberColumnString = /^([0-9]+):(.*)/;
47
- const enumerationTypeNodeId = (0, node_opcua_nodeid_1.coerceNodeId)(node_opcua_constants_1.DataTypeIds.Enumeration);
48
- function _extract_namespace_and_browse_name_as_string(addressSpace, browseName, namespaceIndex) {
49
- (0, node_opcua_assert_1.assert)(!namespaceIndex || namespaceIndex >= 0);
50
- let result;
51
- if (namespaceIndex !== undefined && namespaceIndex > 0) {
52
- (0, node_opcua_assert_1.assert)(typeof browseName === "string", "expecting a string when namespaceIndex is specified");
53
- result = [addressSpace.getNamespace(namespaceIndex), browseName];
54
- }
55
- else if (typeof browseName === "string") {
56
- // split
57
- if (browseName.indexOf(":") >= 0) {
58
- const a = browseName.split(":");
59
- namespaceIndex = a.length === 2 ? parseInt(a[0], 10) : namespaceIndex;
60
- browseName = a.length === 2 ? a[1] : browseName;
61
- }
62
- result = [addressSpace.getNamespace(namespaceIndex || 0), browseName];
63
- }
64
- else if (browseName instanceof node_opcua_data_model_1.QualifiedName) {
65
- namespaceIndex = browseName.namespaceIndex;
66
- result = [addressSpace.getNamespace(namespaceIndex), browseName.name];
67
- }
68
- else if (typeof browseName === "number") {
69
- result = [addressSpace.getDefaultNamespace(), node_opcua_variant_1.DataType[browseName]];
70
- }
71
- /* istanbul ignore next */
72
- if (!result || !result[0]) {
73
- throw new Error(` Cannot find namespace associated with ${browseName} ${namespaceIndex}`);
74
- }
75
- return result;
76
- }
77
- /**
78
- * returns true if str matches a nodeID, e.g i=123 or ns=...
79
- * @method isNodeIdString
80
- * @param str
81
- * @type {boolean}
82
- */
83
- function isNodeIdString(str) {
84
- if (typeof str !== "string") {
85
- return false;
86
- }
87
- return str.substring(0, 2) === "i=" || str.substring(0, 3) === "ns=";
88
- }
89
- /**
90
- * `AddressSpace` is a collection of UA nodes.
91
- *
92
- * const addressSpace = AddressSpace.create();
93
- */
94
- class AddressSpace {
95
- constructor() {
96
- /***
97
- * @internal
98
- * @private
99
- */
100
- this.suspendBackReference = false;
101
- this.isFrugal = false;
102
- this.historizingNodes = {};
103
- this._condition_refresh_in_progress = false;
104
- this.isNodeIdString = isNodeIdString;
105
- this._modelChangeTransactionCounter = 0;
106
- this._modelChanges = [];
107
- this._private_namespaceIndex = 1;
108
- this._namespaceArray = [];
109
- // special namespace 0 is reserved for the UA namespace
110
- this.registerNamespace("http://opcfoundation.org/UA/");
111
- AddressSpace.registry.register(this);
112
- }
113
- get rootFolder() {
114
- const rootFolder = this.findNode(this.resolveNodeId("RootFolder"));
115
- if (!rootFolder) {
116
- // throw new Error("AddressSpace doesn't contain rootFolder object");
117
- return null;
118
- }
119
- return rootFolder;
120
- }
121
- static create() {
122
- return new AddressSpace();
123
- }
124
- /**
125
- * @internal
126
- */
127
- getDataTypeManager() {
128
- const addressSpacePriv = this;
129
- (0, node_opcua_assert_1.assert)(addressSpacePriv.$$extraDataTypeManager, "expecting a $$extraDataTypeManager please make sure ensureDatatypeExtracted is called");
130
- return addressSpacePriv.$$extraDataTypeManager;
131
- }
132
- getNamespaceUri(namespaceIndex) {
133
- (0, node_opcua_assert_1.assert)(namespaceIndex >= 0 && namespaceIndex < this._namespaceArray.length);
134
- return this._namespaceArray[namespaceIndex].namespaceUri;
135
- }
136
- /***
137
- * @method getNamespace
138
- * @param {string|number} namespace index or namespace uri.
139
- * @return {NameSpace} the namespace
140
- */
141
- getNamespace(namespaceIndexOrName) {
142
- if (typeof namespaceIndexOrName === "number") {
143
- const namespaceIndex = namespaceIndexOrName;
144
- (0, node_opcua_assert_1.assert)(namespaceIndex >= 0 && namespaceIndex < this._namespaceArray.length, "invalid namespace index ( out of bound)");
145
- return this._namespaceArray[namespaceIndex];
146
- }
147
- else {
148
- const namespaceUri = namespaceIndexOrName;
149
- (0, node_opcua_assert_1.assert)(typeof namespaceUri === "string");
150
- const index = this.getNamespaceIndex(namespaceUri);
151
- return this._namespaceArray[index];
152
- }
153
- }
154
- /***
155
- * @method getDefaultNamespace
156
- * @return the default namespace (standard OPCUA namespace)
157
- */
158
- getDefaultNamespace() {
159
- return this.getNamespace(0);
160
- }
161
- /***
162
- * @method getOwnNamespace
163
- *
164
- * objects instances managed by the server will be created in this namespace.
165
- *
166
- * @return address space own namespace
167
- */
168
- getOwnNamespace() {
169
- /* istanbul ignore next */
170
- if (this._private_namespaceIndex >= this._namespaceArray.length) {
171
- throw new Error("please create the private namespace");
172
- }
173
- return this.getNamespace(this._private_namespaceIndex);
174
- }
175
- /**
176
- * @method getNamespaceIndex
177
- * @param namespaceUri
178
- * @return the namespace index of a namespace given by its namespace uri
179
- *
180
- */
181
- getNamespaceIndex(namespaceUri) {
182
- (0, node_opcua_assert_1.assert)(typeof namespaceUri === "string");
183
- return this._namespaceArray.findIndex((ns) => ns.namespaceUri === namespaceUri);
184
- }
185
- /**
186
- * @method registerNamespace
187
- *
188
- * register a new namespace
189
- *
190
- * @param namespaceUri {string}
191
- * @returns {Namespace}
192
- */
193
- registerNamespace(namespaceUri) {
194
- let index = this._namespaceArray.findIndex((ns) => ns.namespaceUri === namespaceUri);
195
- if (index !== -1) {
196
- (0, node_opcua_assert_1.assert)(this._namespaceArray[index].addressSpace === this);
197
- return this._namespaceArray[index];
198
- }
199
- index = this._namespaceArray.length;
200
- this._namespaceArray.push(new namespace_impl_1.NamespaceImpl({
201
- addressSpace: this,
202
- index,
203
- namespaceUri,
204
- publicationDate: new Date(),
205
- version: "undefined"
206
- }));
207
- return this._namespaceArray[index];
208
- }
209
- /***
210
- * @method getNamespaceArray
211
- * @return {Namespace[]} the namespace array
212
- */
213
- getNamespaceArray() {
214
- return this._namespaceArray;
215
- }
216
- /**
217
- *
218
- * @method addAlias
219
- * @param alias {String} the alias name
220
- * @param nodeId {NodeId}
221
- * @internal
222
- */
223
- addAlias(alias, nodeId) {
224
- (0, node_opcua_assert_1.assert)(typeof alias === "string");
225
- (0, node_opcua_assert_1.assert)(nodeId instanceof node_opcua_nodeid_1.NodeId);
226
- this.getNamespace(nodeId.namespace).addAlias(alias, nodeId);
227
- }
228
- /**
229
- * find an node by node Id
230
- * @method findNode
231
- * @param nodeId a nodeId or a string coerce-able to nodeID, representing the object to find.
232
- * @return {BaseNode|null}
233
- */
234
- findNode(nodeId) {
235
- if (!(nodeId instanceof node_opcua_nodeid_1.NodeId)) {
236
- nodeId = this.resolveNodeId(nodeId);
237
- }
238
- if (nodeId.namespace < 0 || nodeId.namespace >= this._namespaceArray.length) {
239
- // namespace index is out of bound
240
- return null;
241
- }
242
- const namespace = this._namespaceArray[nodeId.namespace];
243
- return namespace.findNode2(nodeId);
244
- }
245
- findMethod(nodeId) {
246
- const node = this.findNode(nodeId);
247
- if (!node || node.nodeClass !== node_opcua_data_model_1.NodeClass.Method) {
248
- return null;
249
- }
250
- return node;
251
- }
252
- /**
253
- * resolved a string or a nodeId to a nodeID
254
- */
255
- resolveNodeId(nodeId) {
256
- if (typeof nodeId === "string") {
257
- const m = nodeId.match(regexNumberColumnString);
258
- if (m && m.length === 3) {
259
- const namespaceIndex = parseInt(m[1], 10);
260
- const aliasName = m[2];
261
- const namespace = this.getNamespace(namespaceIndex);
262
- // check if the string is a known alias
263
- const aliasNodeId = namespace.resolveAlias(aliasName);
264
- if (aliasNodeId !== null) {
265
- return aliasNodeId;
266
- }
267
- }
268
- }
269
- return (0, node_opcua_nodeid_1.resolveNodeId)(nodeId);
270
- }
271
- /**
272
- *
273
- * @method findObjectType
274
- * @param objectType {String|NodeId|QualifiedName}
275
- * @param [namespaceIndex=0 {Number}] an optional namespace index
276
- * @return {UAObjectType|null}
277
- *
278
- * @example
279
- *
280
- * ```javascript
281
- * const objectType = addressSpace.findObjectType("ns=0;i=58");
282
- * objectType.browseName.toString().should.eql("BaseObjectType");
283
- *
284
- * const objectType = addressSpace.findObjectType("BaseObjectType");
285
- * objectType.browseName.toString().should.eql("BaseObjectType");
286
- *
287
- * const objectType = addressSpace.findObjectType(resolveNodeId("ns=0;i=58"));
288
- * objectType.browseName.toString().should.eql("BaseObjectType");
289
- *
290
- * const objectType = addressSpace.findObjectType("CustomObjectType",36);
291
- * objectType.nodeId.namespace.should.eql(36);
292
- * objectType.browseName.toString().should.eql("BaseObjectType");
293
- *
294
- * const objectType = addressSpace.findObjectType("36:CustomObjectType");
295
- * objectType.nodeId.namespace.should.eql(36);
296
- * objectType.browseName.toString().should.eql("BaseObjectType");
297
- * ```
298
- */
299
- findObjectType(objectType, namespaceIndex) {
300
- if (objectType instanceof node_opcua_nodeid_1.NodeId) {
301
- return _find_by_node_id(this, objectType, namespaceIndex);
302
- }
303
- const [namespace, browseName] = _extract_namespace_and_browse_name_as_string(this, objectType, namespaceIndex);
304
- return namespace.findObjectType(browseName);
305
- }
306
- /**
307
- * @method findVariableType
308
- * @param variableType {String|NodeId}
309
- * @param [namespaceIndex=0 {Number}] an optional namespace index
310
- * @return {UAObjectType|null}
311
- *
312
- * @example
313
- *
314
- * ```javascript
315
- * const objectType = addressSpace.findVariableType("ns=0;i=62");
316
- * objectType.browseName.toString().should.eql("BaseVariableType");
317
- *
318
- * const objectType = addressSpace.findVariableType("BaseVariableType");
319
- * objectType.browseName.toString().should.eql("BaseVariableType");
320
- *
321
- * const objectType = addressSpace.findVariableType(resolveNodeId("ns=0;i=62"));
322
- * objectType.browseName.toString().should.eql("BaseVariableType");
323
- * ```
324
- */
325
- findVariableType(variableType, namespaceIndex) {
326
- if (variableType instanceof node_opcua_nodeid_1.NodeId) {
327
- return _find_by_node_id(this, variableType, namespaceIndex);
328
- }
329
- const [namespace, browseName] = _extract_namespace_and_browse_name_as_string(this, variableType, namespaceIndex);
330
- return namespace.findVariableType(browseName);
331
- }
332
- /**
333
- * Find the DataType node from a NodeId or a browseName
334
- * @method findDataType
335
- * @param dataType {String|NodeId}
336
- * @param [namespaceIndex=0 {Number}] an optional namespace index
337
- * @return {DataType|null}
338
- *
339
- *
340
- * @example
341
- *
342
- * ```javascript
343
- * const dataDouble = addressSpace.findDataType("Double");
344
- * const dataDouble = addressSpace.findDataType(resolveNodeId("ns=0;i=3"));
345
- * ```
346
- */
347
- findDataType(dataType, namespaceIndex) {
348
- // startingNode i=24 :
349
- // BaseDataType
350
- // +-> Boolean (i=1) {BooleanDataType (ns=2:9898)
351
- // +-> String (i=12)
352
- // +->NumericRange
353
- // +->Time
354
- // +-> DateTime
355
- // +-> Structure
356
- // +-> Node
357
- // +-> ObjectNode
358
- if (dataType instanceof ua_data_type_impl_1.UADataTypeImpl) {
359
- return this.findDataType(dataType.nodeId);
360
- }
361
- else if (dataType instanceof node_opcua_nodeid_1.NodeId) {
362
- return _find_by_node_id(this, dataType, namespaceIndex);
363
- }
364
- if (typeof dataType === "number") {
365
- if (node_opcua_variant_1.DataType[dataType] !== undefined) {
366
- dataType = node_opcua_variant_1.DataType[dataType];
367
- }
368
- else {
369
- return this.findDataType((0, node_opcua_nodeid_1.resolveNodeId)(dataType));
370
- }
371
- }
372
- const res = _extract_namespace_and_browse_name_as_string(this, dataType, namespaceIndex);
373
- const namespace = res[0];
374
- const browseName = res[1];
375
- return namespace.findDataType(browseName);
376
- }
377
- /**
378
- * @method findCorrespondingBasicDataType
379
- *
380
- * @example
381
- *
382
- * const dataType = addressSpace.findDataType("ns=0;i=12");
383
- * addressSpace.findCorrespondingBasicDataType(dataType).should.eql(DataType.String);
384
- *
385
- * const dataType = addressSpace.findDataType("ServerStatusDataType"); // ServerStatus
386
- * addressSpace.findCorrespondingBasicDataType(dataType).should.eql(DataType.ExtensionObject);
387
- *
388
- */
389
- findCorrespondingBasicDataType(dataTypeNode) {
390
- const _orig_dataTypeNode = dataTypeNode;
391
- if (typeof dataTypeNode === "string") {
392
- const resolvedDataType = this.resolveNodeId(dataTypeNode);
393
- /* istanbul ignore next */
394
- if (!resolvedDataType) {
395
- throw new Error("Cannot resolve " + _orig_dataTypeNode.toString());
396
- }
397
- dataTypeNode = resolvedDataType;
398
- }
399
- if (dataTypeNode instanceof node_opcua_nodeid_1.NodeId) {
400
- dataTypeNode = this.findDataType(dataTypeNode);
401
- /* istanbul ignore next */
402
- if (!dataTypeNode) {
403
- throw Error("cannot find dataTypeNode " + _orig_dataTypeNode.toString());
404
- }
405
- }
406
- /* istanbul ignore next */
407
- if (!(dataTypeNode instanceof ua_data_type_impl_1.UADataTypeImpl)) {
408
- throw new Error("we are expecting an UADataType here : " +
409
- _orig_dataTypeNode.toString() +
410
- " should not refer to a " +
411
- dataTypeNode.browseName.name);
412
- }
413
- if ((0, node_opcua_nodeid_1.sameNodeId)(enumerationTypeNodeId, dataTypeNode.nodeId)) {
414
- return node_opcua_variant_1.DataType.Int32;
415
- }
416
- if (dataTypeNode.nodeId.namespace === 0 && dataTypeNode.nodeId.value === 29) {
417
- // Number
418
- return node_opcua_variant_1.DataType.Null; //which one ?
419
- }
420
- if (dataTypeNode.nodeId.namespace === 0 && dataTypeNode.nodeId.value === 0) {
421
- return node_opcua_variant_1.DataType.Null;
422
- }
423
- if (dataTypeNode.nodeId.namespace === 0 && dataTypeNode.nodeId.value <= 25) {
424
- return dataTypeNode.nodeId.value;
425
- }
426
- const result = this.findCorrespondingBasicDataType(dataTypeNode.subtypeOfObj);
427
- return result;
428
- }
429
- /**
430
- * find a ReferenceType by its inverse name.
431
- * @method findReferenceTypeFromInverseName
432
- * @param inverseName the inverse name of the ReferenceType to find
433
- * @deprecated
434
- */
435
- findReferenceTypeFromInverseName(inverseName) {
436
- return this.getDefaultNamespace().findReferenceTypeFromInverseName(inverseName);
437
- }
438
- /**
439
- * @method findReferenceType
440
- * @param refType {String|NodeId}
441
- * @param [namespaceIndex=0 {Number}] an optional namespace index
442
- * @return {ReferenceType|null}
443
- *
444
- * refType could be
445
- * - a string representing a nodeid : e.g. `i=9004` or ns=1;i=6030
446
- * - a string representing a browse name : e.g `"HasTypeDefinition"`.
447
- * In this case it should be in the alias list.
448
- *
449
- */
450
- findReferenceType(refType, namespaceIndex) {
451
- // startingNode ns=0;i=31 : References
452
- // +-> References i=31
453
- // +->(hasSubtype) NonHierarchicalReferences
454
- // +->(hasSubtype) HasTypeDefinition
455
- // +->(hasSubtype) HierarchicalReferences
456
- // +->(hasSubtype) HasChild/ChildOf
457
- // +->(hasSubtype) Aggregates/AggregatedBy
458
- // +-> HasProperty/PropertyOf
459
- // +-> HasComponent/ComponentOf
460
- // +-> HasHistoricalConfiguration/HistoricalConfigurationOf
461
- // +->(hasSubtype) HasSubtype/HasSupertype
462
- // +->(hasSubtype) Organizes/OrganizedBy
463
- // +->(hasSubtype) HasEventSource/EventSourceOf
464
- let node;
465
- if (isNodeIdString(refType) || typeof refType === "number") {
466
- refType = (0, node_opcua_nodeid_1.resolveNodeId)(refType);
467
- }
468
- if (refType instanceof node_opcua_nodeid_1.NodeId) {
469
- node = this.findNode(refType);
470
- /* istanbul ignore next */
471
- if (!(node && node.nodeClass === node_opcua_data_model_1.NodeClass.ReferenceType)) {
472
- // throw new Error("cannot resolve referenceId "+ refType.toString());
473
- return null;
474
- }
475
- }
476
- else {
477
- (0, node_opcua_assert_1.assert)(typeof refType === "string");
478
- node = this._findReferenceType(refType, namespaceIndex);
479
- }
480
- return node;
481
- }
482
- /**
483
- * returns the inverse name of the referenceType.
484
- *
485
- * @method inverseReferenceType
486
- * @param referenceType {String} : the reference type name
487
- * @return {String} the name of the inverse reference type.
488
- *
489
- * @example
490
- *
491
- * ```javascript
492
- * addressSpace.inverseReferenceType("OrganizedBy").should.eql("Organizes");
493
- * addressSpace.inverseReferenceType("Organizes").should.eql("OrganizedBy");
494
- * ```
495
- *
496
- */
497
- inverseReferenceType(referenceType) {
498
- (0, node_opcua_assert_1.assert)(typeof referenceType === "string");
499
- const n1 = this.findReferenceType(referenceType);
500
- const n2 = this.findReferenceTypeFromInverseName(referenceType);
501
- if (n1) {
502
- (0, node_opcua_assert_1.assert)(!n2);
503
- return n1.inverseName.text;
504
- }
505
- else {
506
- (0, node_opcua_assert_1.assert)(n2);
507
- return n2.browseName.toString();
508
- }
509
- }
510
- /**
511
- * find an EventType node in the address space
512
- * @method findEventType
513
- * @param eventTypeId {String|NodeId|UAObjectType} the eventType to find
514
- * @param namespaceIndex the namespace index of the event to find
515
- * @return {UAObjectType|null} the EventType found or null.
516
- *
517
- * note:
518
- * - the method with throw an exception if a node is found
519
- * that is not a BaseEventType or a subtype of it.
520
- *
521
- * @example
522
- *
523
- * var evtType = addressSpace.findEventType("AuditEventType");
524
- *
525
- */
526
- findEventType(eventTypeId, namespaceIndex) {
527
- let eventType;
528
- if (eventTypeId instanceof base_node_impl_1.BaseNodeImpl) {
529
- eventType = eventTypeId;
530
- }
531
- else {
532
- eventType = this.findObjectType(eventTypeId, namespaceIndex);
533
- }
534
- if (!eventType) {
535
- return null;
536
- }
537
- const baseEventType = this.findObjectType("BaseEventType");
538
- /* istanbul ignore next */
539
- if (!baseEventType) {
540
- throw new Error("expecting BaseEventType - please check you nodeset xml file!");
541
- }
542
- if ((0, node_opcua_nodeid_1.sameNodeId)(eventType.nodeId, baseEventType.nodeId)) {
543
- return eventType;
544
- }
545
- /* eventTypeNode should be a sub type of "BaseEventType" */
546
- /* istanbul ignore next */
547
- if (!eventType.isSubtypeOf(baseEventType)) {
548
- throw new Error("findEventType: event found is not subType of BaseEventType");
549
- }
550
- return eventType;
551
- }
552
- /**
553
- * EventId is generated by the Server to uniquely identify a particular Event Notification.
554
- * @method generateEventId
555
- * @return {Variant} dataType: "ByteString"
556
- */
557
- generateEventId() {
558
- /*
559
- * OpcUA 1.02 part 5 : 6.4.2 BaseEventType
560
- * The Server is responsible to ensure that each Event has its unique EventId.
561
- * It may do this, for example, by putting GUIDs into the ByteString.
562
- * Clients can use the EventId to assist in minimizing or eliminating gaps and overlaps that may occur during
563
- * a redundancy fail-over. The EventId shall always be returned as value and the Server is not allowed to
564
- * return a StatusCode for the EventId indicating an error.
565
- *
566
- */
567
- const offset = 16;
568
- const self = this;
569
- if (!self._eventIdCounter) {
570
- self._eventIdCounter = (0, crypto_1.randomBytes)(20);
571
- self._eventIdCounter.writeInt32BE(0, offset);
572
- }
573
- self._eventIdCounter.writeInt32BE(self._eventIdCounter.readInt32BE(offset) + 1, offset);
574
- return new node_opcua_variant_1.Variant({
575
- dataType: node_opcua_variant_1.DataType.ByteString,
576
- value: Buffer.from(self._eventIdCounter)
577
- });
578
- }
579
- /*=
580
- * construct a simple javascript object with all the default properties of the event
581
- * @method constructEventData
582
- *
583
- * @return result.$eventDataSource {BaseNode} the event type node
584
- * @return result.eventId {NodeId} the
585
- * ...
586
- *
587
- *
588
- * eventTypeId can be a UAEventType
589
- *
590
- * @private
591
- */
592
- constructEventData(eventTypeId, data) {
593
- data = data || {};
594
- // construct the reference dataStructure to store event Data
595
- let eventTypeNode = eventTypeId;
596
- // make sure that eventType is really a object that derived from EventType
597
- if (eventTypeId instanceof ua_object_type_impl_1.UAObjectTypeImpl) {
598
- eventTypeNode = this.findEventType(eventTypeId);
599
- }
600
- /* istanbul ignore next */
601
- if (!eventTypeNode) {
602
- throw new Error(" cannot find EvenType for " + eventTypeId);
603
- }
604
- (0, node_opcua_assert_1.assert)(eventTypeNode instanceof ua_object_type_impl_1.UAObjectTypeImpl, "eventTypeId must represent a UAObjectType");
605
- // eventId
606
- (0, node_opcua_assert_1.assert)(!Object.prototype.hasOwnProperty.call(data, "eventId"), "eventId constructEventData : options object should not have eventId property");
607
- data.eventId = data.eventId || this.generateEventId();
608
- // eventType
609
- data.eventType = { dataType: node_opcua_variant_1.DataType.NodeId, value: eventTypeNode.nodeId };
610
- // sourceNode
611
- (0, node_opcua_assert_1.assert)(Object.prototype.hasOwnProperty.call(data, "sourceNode"), "expecting a source node to be defined");
612
- data.sourceNode = new node_opcua_variant_1.Variant(data.sourceNode);
613
- (0, node_opcua_assert_1.assert)(data.sourceNode.dataType === node_opcua_variant_1.DataType.NodeId);
614
- // sourceName
615
- const sourceNode = this.findNode(data.sourceNode.value);
616
- data.sourceName = data.sourceName || {
617
- dataType: node_opcua_variant_1.DataType.String,
618
- value: sourceNode.getDisplayName("en")
619
- };
620
- const nowUTC = new Date();
621
- // time (UtcTime)
622
- // TODO
623
- data.time = data.time || { dataType: node_opcua_variant_1.DataType.DateTime, value: nowUTC };
624
- // receivedTime (UtcTime)
625
- // TODO
626
- data.receiveTime = data.receiveTime || { dataType: node_opcua_variant_1.DataType.DateTime, value: nowUTC };
627
- // localTime (UtcTime)
628
- // TODO
629
- data.localTime = data.localTime || { dataType: node_opcua_variant_1.DataType.DateTime, value: nowUTC };
630
- // message (LocalizedText)
631
- data.message = data.message || { dataType: node_opcua_variant_1.DataType.LocalizedText, value: { text: "" } };
632
- // severity (UInt16)
633
- data.severity = data.severity || { dataType: node_opcua_variant_1.DataType.UInt16, value: 0 };
634
- // xx // reminder : event type cannot be instantiated directly !
635
- // xx assert(eventTypeNode.isAbstract);
636
- const baseObjectType = this.findObjectType("BaseObjectType"); // i=58
637
- /* istanbul ignore next */
638
- if (!baseObjectType) {
639
- throw new Error("BaseObjectType must be defined in the address space");
640
- }
641
- const hasProperty = (data, propertyName) => Object.prototype.hasOwnProperty.call(data, propertyName);
642
- const visitedProperties = {};
643
- const alreadyVisited = (key) => Object.prototype.hasOwnProperty.call(visitedProperties, key);
644
- const markAsVisited = (key) => (visitedProperties[key] = 1);
645
- function _process_var(self, prefixLower, prefixStandard, node) {
646
- const lowerName = prefixLower + (0, node_opcua_utils_1.lowerFirstLetter)(node.browseName.name);
647
- const fullBrowsePath = prefixStandard + node.browseName.toString();
648
- if (alreadyVisited(lowerName)) {
649
- return;
650
- }
651
- markAsVisited(lowerName);
652
- if (hasProperty(data, lowerName)) {
653
- eventData._createValue(fullBrowsePath, node, data[lowerName]);
654
- }
655
- else {
656
- // add a property , but with a null variant
657
- eventData._createValue(fullBrowsePath, node, { dataType: node_opcua_variant_1.DataType.Null });
658
- if (doDebug) {
659
- if (node.modellingRule === "Mandatory") {
660
- // tslint:disable:no-console
661
- console.log(chalk.red("ERROR : AddressSpace#constructEventData(eventType,options) " + "cannot find property ") +
662
- self.browseName.toString() +
663
- " => " +
664
- chalk.cyan(lowerName));
665
- }
666
- else {
667
- console.log(chalk.yellow("Warning : AddressSpace#constructEventData(eventType,options)" + " cannot find property ") +
668
- self.browseName.toString() +
669
- " => " +
670
- chalk.cyan(lowerName));
671
- }
672
- }
673
- }
674
- }
675
- // verify that all elements of data are valid
676
- function verify_data_is_valid(data1) {
677
- Object.keys(data1).map((k) => {
678
- if (k === "$eventDataSource") {
679
- return;
680
- }
681
- /* istanbul ignore next */
682
- if (!alreadyVisited(k)) {
683
- throw new Error(" cannot find property '" +
684
- k +
685
- "' in [ " +
686
- Object.keys(visitedProperties).join(", ") +
687
- "] when filling " +
688
- eventTypeNode.browseName.toString());
689
- }
690
- });
691
- }
692
- const populate_data = (self, eventData1) => {
693
- if ((0, node_opcua_nodeid_1.sameNodeId)(baseObjectType.nodeId, self.nodeId)) {
694
- return; // nothing to do
695
- }
696
- const baseTypeNodeId = self.subtypeOf;
697
- /* istanbul ignore next */
698
- if (!baseTypeNodeId) {
699
- throw new Error("Object " + self.browseName.toString() + " with nodeId " + self.nodeId + " has no Type");
700
- }
701
- const baseType = this.findNode(baseTypeNodeId);
702
- /* istanbul ignore next */
703
- if (!baseType) {
704
- throw new Error(chalk.red("Cannot find object with nodeId ") + baseTypeNodeId);
705
- }
706
- populate_data(baseType, eventData1);
707
- // get properties and components from base class
708
- const properties = self.getProperties();
709
- const components = self.getComponents();
710
- const children = [].concat(properties, components);
711
- // istanbul ignore next
712
- if (doDebug) {
713
- console.log(" " + chalk.bgWhite.cyan(self.browseName.toString()));
714
- }
715
- for (const node of children) {
716
- // only keep those that have a "HasModellingRule"
717
- if (!node.modellingRule) {
718
- // xx console.log(" skipping node without modelling rule", node.browseName.toString());
719
- continue;
720
- }
721
- // ignore also methods
722
- if (node.nodeClass === node_opcua_data_model_1.NodeClass.Method) {
723
- // xx console.log(" skipping method ", node.browseName.toString());
724
- continue;
725
- }
726
- _process_var(self, "", "", node);
727
- // also store value in index
728
- // xx eventData.__nodes[node.nodeId.toString()] = eventData[lowerName];
729
- const children2 = node.getAggregates();
730
- if (children2.length > 0) {
731
- const lowerName = (0, node_opcua_utils_1.lowerFirstLetter)(node.browseName.name);
732
- const standardName = node.browseName.toString();
733
- // console.log(" Children to visit = ",lowerName,
734
- // children.map(function(a){ return a.browseName.toString();}).join(" "));
735
- for (const child2 of children2) {
736
- _process_var(self, lowerName + ".", standardName + ".", child2);
737
- }
738
- }
739
- }
740
- };
741
- const eventData = new event_data_1.EventData(eventTypeNode);
742
- // verify standard properties...
743
- populate_data(eventTypeNode, eventData);
744
- verify_data_is_valid(data);
745
- return eventData;
746
- }
747
- // - Browse --------------------------------------------------------------------------------------------------------
748
- /**
749
- * browse some path.
750
- *
751
- * @method browsePath
752
- * @param {BrowsePath} browsePath
753
- * @return {BrowsePathResult}
754
- *
755
- * This service can be used translates one or more browse paths into NodeIds.
756
- * A browse path is constructed of a starting Node and a RelativePath. The specified starting Node
757
- * identifies the Node from which the RelativePath is based. The RelativePath contains a sequence of
758
- * ReferenceTypes and BrowseNames.
759
- *
760
- * |StatusCode | |
761
- * |------------------------------|:-----------------------------------------------------------|
762
- * |BadNodeIdUnknown | |
763
- * |BadNodeIdInvalid | |
764
- * |BadNothingToDo | - the relative path contains an empty list ) |
765
- * |BadBrowseNameInvalid | - target name is missing in relative path |
766
- * |UncertainReferenceOutOfServer | - The path element has targets which are in another server.|
767
- * |BadTooManyMatches | |
768
- * |BadQueryTooComplex | |
769
- * |BadNoMatch | |
770
- *
771
- *
772
- *
773
- */
774
- browsePath(browsePath) {
775
- (0, node_opcua_assert_1.assert)(browsePath instanceof node_opcua_types_1.BrowsePath);
776
- const startingNode = this.findNode(browsePath.startingNode);
777
- if (!startingNode) {
778
- return new node_opcua_types_1.BrowsePathResult({ statusCode: node_opcua_status_code_1.StatusCodes.BadNodeIdUnknown });
779
- }
780
- if (!browsePath.relativePath.elements || browsePath.relativePath.elements.length === 0) {
781
- return new node_opcua_types_1.BrowsePathResult({
782
- statusCode: node_opcua_status_code_1.StatusCodes.BadNothingToDo,
783
- targets: []
784
- });
785
- }
786
- const elements_length = browsePath.relativePath.elements.length;
787
- // -------------------------------------------------------------------------------------------------------
788
- // verify standard RelativePath construction
789
- // from OPCUA 1.03 - PArt 3 - 7.6 RelativePath:
790
- // TargetName The BrowseName of the target node.
791
- // The final element may have an empty targetName. In this situation all targets of the
792
- // references identified by the referenceTypeId are the targets of the RelativePath.
793
- // The targetName shall be specified for all other elements.
794
- // The current path cannot be followed any further if no targets with the specified
795
- // BrowseName exist.
796
- // Let's detect null targetName which are not in last position and return BadBrowseNameInvalid if not
797
- //
798
- const empty_targetName_not_in_lastPos = browsePath.relativePath.elements.reduce((prev, e, index) => {
799
- const is_last = index + 1 === elements_length;
800
- const isBad = !is_last && (!e.targetName || e.targetName.isEmpty());
801
- return prev + (!is_last && (!e.targetName || e.targetName.isEmpty()) ? 1 : 0);
802
- }, 0);
803
- if (empty_targetName_not_in_lastPos) {
804
- return new node_opcua_types_1.BrowsePathResult({ statusCode: node_opcua_status_code_1.StatusCodes.BadBrowseNameInvalid });
805
- }
806
- // from OPCUA 1.03 - PArt 3 - 5.8.4 TranslateBrowsePathToNodeIds
807
- // TranslateBrowsePathToNodeIds further restrict RelativePath targetName rules:
808
- // The last element in the relativePath shall always have a targetName specified.
809
- const last_el = browsePath.relativePath.elements[elements_length - 1];
810
- if (!last_el.targetName || !last_el.targetName.name || last_el.targetName.name.length === 0) {
811
- return new node_opcua_types_1.BrowsePathResult({ statusCode: node_opcua_status_code_1.StatusCodes.BadBrowseNameInvalid });
812
- }
813
- const res = [];
814
- const explore_element = (curNodeObject, elements, index) => {
815
- const element = elements[index];
816
- (0, node_opcua_assert_1.assert)(element instanceof node_opcua_types_1.RelativePathElement);
817
- const is_last = index + 1 === elements.length;
818
- const nodeIds = curNodeObject.browseNodeByTargetName(element, is_last);
819
- const targets = nodeIds.map((nodeId) => {
820
- return {
821
- remainingPathIndex: elements.length - index,
822
- targetId: nodeId
823
- };
824
- });
825
- if (!is_last) {
826
- // explorer
827
- for (const target of targets) {
828
- const node = this.findNode(target.targetId);
829
- if (!node) {
830
- continue;
831
- }
832
- explore_element(node, elements, index + 1);
833
- }
834
- }
835
- else {
836
- for (const target of targets) {
837
- res.push({
838
- remainingPathIndex: 0xffffffff,
839
- targetId: (0, node_opcua_nodeid_1.coerceExpandedNodeId)(target.targetId)
840
- });
841
- }
842
- }
843
- };
844
- explore_element(startingNode, browsePath.relativePath.elements, 0);
845
- if (res.length === 0) {
846
- return new node_opcua_types_1.BrowsePathResult({ statusCode: node_opcua_status_code_1.StatusCodes.BadNoMatch });
847
- }
848
- return new node_opcua_types_1.BrowsePathResult({
849
- statusCode: node_opcua_status_code_1.StatusCodes.Good,
850
- targets: res
851
- });
852
- }
853
- // - Extension Object ----------------------------------------------------------------------------------------------
854
- getExtensionObjectConstructor(dataType) {
855
- (0, node_opcua_assert_1.assert)(dataType, "expecting a dataType");
856
- if (dataType instanceof node_opcua_nodeid_1.NodeId) {
857
- const tmp = this.findNode(dataType);
858
- /* istanbul ignore next */
859
- if (!tmp) {
860
- throw new Error("getExtensionObjectConstructor: cannot resolve dataType " + dataType);
861
- }
862
- dataType = tmp;
863
- }
864
- /* istanbul ignore next */
865
- if (!(dataType instanceof ua_data_type_impl_1.UADataTypeImpl)) {
866
- // may be dataType was the NodeId of the "Binary Encoding" node
867
- throw new Error("getExtensionObjectConstructor: dataType has unexpected type" + dataType);
868
- }
869
- const _dataType = dataType;
870
- // to do verify that dataType is of type "Structure"
871
- /* istanbul ignore next */
872
- if (!_dataType.isSubtypeOf(this.findDataType("Structure"))) {
873
- console.log(_dataType.toString());
874
- }
875
- (0, node_opcua_assert_1.assert)(_dataType.isSubtypeOf(this.findDataType("Structure")));
876
- if (!_dataType._extensionObjectConstructor) {
877
- const dataTypeManager = this.$$extraDataTypeManager;
878
- _dataType._extensionObjectConstructor = dataTypeManager.getExtensionObjectConstructorFromDataType(_dataType.nodeId);
879
- }
880
- (0, node_opcua_assert_1.assert)(_dataType._extensionObjectConstructor, "dataType must have a constructor");
881
- const Constructor = _dataType._extensionObjectConstructor;
882
- return Constructor;
883
- }
884
- /**
885
- * @param dataType
886
- * @param [options]
887
- * @return the constructed extension object
888
- *
889
- *
890
- * @example
891
- *
892
- * // example 1
893
- * var extObj = addressSpace.constructExtensionObject("BuildInfo",{ productName: "PRODUCT_NAME"});
894
- *
895
- * // example 2
896
- * serverStatusDataType.nodeClass.should.eql(NodeClass.DataType);
897
- * serverStatusDataType.browseName.toString().should.eql("ServerStatusDataType");
898
- * var serverStatus = addressSpace.constructExtensionObject(serverStatusDataType);
899
- * serverStatus.should.be.instanceof(ServerStatusDataType);
900
- */
901
- constructExtensionObject(dataType, options) {
902
- const Constructor = this.getExtensionObjectConstructor(dataType);
903
- return new Constructor(options);
904
- }
905
- /**
906
- * cleanup all resources maintained by this addressSpace.
907
- * @method dispose
908
- */
909
- dispose() {
910
- this._namespaceArray.map((namespace) => namespace.dispose());
911
- AddressSpace.registry.unregister(this);
912
- /* istanbul ignore next */
913
- if (this._shutdownTask && this._shutdownTask.length > 0) {
914
- throw new Error("AddressSpace#dispose : shutdown has not been called");
915
- }
916
- }
917
- /**
918
- * register a function that will be called when the server will perform its shut down.
919
- * @method registerShutdownTask
920
- */
921
- registerShutdownTask(task) {
922
- this._shutdownTask = this._shutdownTask || [];
923
- (0, node_opcua_assert_1.assert)(typeof task === "function");
924
- this._shutdownTask.push(task);
925
- }
926
- shutdown() {
927
- return __awaiter(this, void 0, void 0, function* () {
928
- const performTasks = (tasks) => __awaiter(this, void 0, void 0, function* () {
929
- // perform registerShutdownTask
930
- for (const task of tasks) {
931
- yield task.call(this);
932
- }
933
- });
934
- if (this._shutdownTask) {
935
- const tasks = this._shutdownTask;
936
- this._shutdownTask = [];
937
- yield performTasks(tasks);
938
- }
939
- });
940
- }
941
- /**
942
- *
943
- * @method browseSingleNode
944
- * @param nodeId {NodeId|String} : the nodeid of the element to browse
945
- * @param browseDescription
946
- * @param browseDescription.browseDirection {BrowseDirection} :
947
- * @param browseDescription.referenceTypeId {String|NodeId}
948
- * @param [session]
949
- * @return {BrowseResult}
950
- */
951
- browseSingleNode(nodeId, browseDescription, context) {
952
- const browseResult = {
953
- continuationPoint: undefined,
954
- references: null,
955
- statusCode: node_opcua_status_code_1.StatusCodes.Good
956
- };
957
- if (!browseDescription || browseDescription.browseDirection === node_opcua_data_model_1.BrowseDirection.Invalid) {
958
- browseResult.statusCode = node_opcua_status_code_1.StatusCodes.BadBrowseDirectionInvalid;
959
- return new node_opcua_service_browse_1.BrowseResult(browseResult);
960
- }
961
- browseDescription.browseDirection = (0, adjust_browse_direction_1.adjustBrowseDirection)(browseDescription.browseDirection, node_opcua_data_model_1.BrowseDirection.Forward);
962
- /* istanbul ignore next */
963
- if (typeof nodeId === "number") {
964
- throw new Error("Not Implemented");
965
- }
966
- if (typeof nodeId === "string") {
967
- const node = this.findNode(this.resolveNodeId(nodeId));
968
- if (node) {
969
- nodeId = node.nodeId;
970
- }
971
- }
972
- // check if referenceTypeId is correct
973
- if (browseDescription.referenceTypeId instanceof node_opcua_nodeid_1.NodeId) {
974
- if (browseDescription.referenceTypeId.value === 0) {
975
- browseDescription.referenceTypeId = null;
976
- }
977
- else {
978
- const rf = this.findNode(browseDescription.referenceTypeId);
979
- if (!rf || !(rf instanceof ua_reference_type_impl_1.UAReferenceTypeImpl)) {
980
- browseResult.statusCode = node_opcua_status_code_1.StatusCodes.BadReferenceTypeIdInvalid;
981
- return new node_opcua_service_browse_1.BrowseResult(browseResult);
982
- }
983
- }
984
- }
985
- const obj = this.findNode(nodeId);
986
- if (!obj) {
987
- // Object Not Found
988
- browseResult.statusCode = node_opcua_status_code_1.StatusCodes.BadNodeIdUnknown;
989
- // xx console.log("xxxxxx browsing ",nodeId.toString() , " not found" );
990
- }
991
- else {
992
- browseResult.statusCode = node_opcua_status_code_1.StatusCodes.Good;
993
- browseResult.references = obj.browseNode(browseDescription, context);
994
- }
995
- return new node_opcua_service_browse_1.BrowseResult(browseResult);
996
- }
997
- /**
998
- * @param folder
999
- * @private
1000
- */
1001
- _coerceFolder(folder) {
1002
- folder = this._coerceNode(folder);
1003
- /* istanbul ignore next */
1004
- if (folder && !_isFolder(this, folder)) {
1005
- throw new Error("Parent folder must be of FolderType " + folder.typeDefinition.toString());
1006
- }
1007
- return folder;
1008
- }
1009
- /**
1010
- *
1011
- * @param view
1012
- * @param modelChange
1013
- * @private
1014
- */
1015
- _collectModelChange(view, modelChange) {
1016
- // xx console.log("in _collectModelChange", modelChange.verb, verbFlags.get(modelChange.verb).toString());
1017
- this._modelChanges.push(modelChange);
1018
- }
1019
- /**
1020
- *
1021
- * walk up the hierarchy of objects until a view is found
1022
- * objects may belong to multiples views.
1023
- * Note: this method doesn't return the main view => Server object.
1024
- * @method extractRootViews
1025
- * @param node {BaseNode}
1026
- * @return {BaseNode[]}
1027
- */
1028
- /**
1029
- *
1030
- * @param node
1031
- * @private
1032
- */
1033
- extractRootViews(node) {
1034
- (0, node_opcua_assert_1.assert)(node.nodeClass === node_opcua_data_model_1.NodeClass.Object || node.nodeClass === node_opcua_data_model_1.NodeClass.Variable);
1035
- const visitedMap = {};
1036
- const q = new Dequeue();
1037
- q.push(node);
1038
- const objectsFolder = this.rootFolder.objects;
1039
- (0, node_opcua_assert_1.assert)(objectsFolder instanceof ua_object_impl_1.UAObjectImpl);
1040
- const results = [];
1041
- while (q.length) {
1042
- node = q.shift();
1043
- const references = node.findReferencesEx("HierarchicalReferences", node_opcua_data_model_1.BrowseDirection.Inverse);
1044
- const parentNodes = references.map((r) => reference_impl_1.ReferenceImpl.resolveReferenceNode(this, r));
1045
- for (const parent of parentNodes) {
1046
- if ((0, node_opcua_nodeid_1.sameNodeId)(parent.nodeId, objectsFolder.nodeId)) {
1047
- continue; // nothing to do
1048
- }
1049
- if (parent.nodeClass === node_opcua_data_model_1.NodeClass.View) {
1050
- results.push(parent);
1051
- }
1052
- else {
1053
- const key = parent.nodeId.toString();
1054
- if (Object.prototype.hasOwnProperty.call(visitedMap, key)) {
1055
- continue;
1056
- }
1057
- visitedMap[key] = parent;
1058
- q.push(parent);
1059
- }
1060
- }
1061
- }
1062
- return results;
1063
- }
1064
- /**
1065
- *
1066
- * @param func
1067
- * @private
1068
- */
1069
- modelChangeTransaction(func) {
1070
- this._modelChangeTransactionCounter = this._modelChangeTransactionCounter || 0;
1071
- function beginModelChange() {
1072
- /* jshint validthis:true */
1073
- (0, node_opcua_assert_1.assert)(this);
1074
- this._modelChanges = this._modelChanges || [];
1075
- (0, node_opcua_assert_1.assert)(this._modelChangeTransactionCounter >= 0);
1076
- this._modelChangeTransactionCounter += 1;
1077
- }
1078
- function endModelChange() {
1079
- /* jshint validthis:true */
1080
- this._modelChangeTransactionCounter -= 1;
1081
- if (this._modelChangeTransactionCounter === 0) {
1082
- if (this._modelChanges.length === 0) {
1083
- return; // nothing to do
1084
- }
1085
- // xx console.log( "xx dealing with ",this._modelChanges.length);
1086
- // increase version number of participating nodes
1087
- // https://github.com/you-dont-need/You-Dont-Need-Lodash-Underscore
1088
- // const nodeIds = _.uniq(this._modelChanges.map((c: any) => c.affected));
1089
- const nodeIds = [...new Set(this._modelChanges.map((c) => c.affected))];
1090
- const nodes = nodeIds.map((nodeId) => this.findNode(nodeId));
1091
- nodes.forEach(_increase_version_number);
1092
- // raise events
1093
- if (this.rootFolder.objects.server) {
1094
- const eventTypeNode = this.findEventType("GeneralModelChangeEventType");
1095
- if (eventTypeNode) {
1096
- // xx console.log("xx raising event on server object");
1097
- this.rootFolder.objects.server.raiseEvent(eventTypeNode, {
1098
- // Part 5 - 6.4.32 GeneralModelChangeEventType
1099
- changes: {
1100
- dataType: node_opcua_variant_1.DataType.ExtensionObject,
1101
- arrayType: node_opcua_variant_1.VariantArrayType.Array,
1102
- value: this._modelChanges
1103
- }
1104
- });
1105
- }
1106
- }
1107
- this._modelChanges = [];
1108
- // _notifyModelChange(this);
1109
- }
1110
- }
1111
- beginModelChange.call(this);
1112
- try {
1113
- func();
1114
- }
1115
- catch (err) {
1116
- errorLog("modelChangeTransaction", err === null || err === void 0 ? void 0 : err.message);
1117
- throw err;
1118
- }
1119
- finally {
1120
- endModelChange.call(this);
1121
- }
1122
- }
1123
- /**
1124
- * normalize the ReferenceType field of the Reference Object
1125
- * @param params.referenceType {String|nodeId}
1126
- * @param params.isForward {Boolean} default value: true;
1127
- * @return {Object} a new reference object with the normalized name { referenceType: <value>, isForward: <flag>}
1128
- */
1129
- normalizeReferenceType(params) {
1130
- if (params instanceof reference_impl_1.ReferenceImpl) {
1131
- // a reference has already been normalized
1132
- return params;
1133
- }
1134
- // ----------------------------------------------- handle is forward
1135
- (0, node_opcua_assert_1.assert)(params.isForward === undefined || typeof params.isForward === "boolean");
1136
- params.isForward = utils.isNullOrUndefined(params.isForward) ? true : !!params.isForward;
1137
- // referenceType = Organizes , isForward = true => referenceType = Organizes , isForward = true
1138
- // referenceType = Organizes , isForward = false => referenceType = Organizes , isForward = false
1139
- // referenceType = OrganizedBy , isForward = true => referenceType = Organizes , isForward = **false**
1140
- // referenceType = OrganizedBy , isForward = false => referenceType = Organizes , isForward = **true**
1141
- // ----------------------------------------------- handle referenceType
1142
- if (params.referenceType instanceof ua_reference_type_impl_1.UAReferenceTypeImpl) {
1143
- params.referenceType = params.referenceType;
1144
- params.referenceType = params.referenceType.nodeId;
1145
- }
1146
- else if (typeof params.referenceType === "string") {
1147
- const inv = this.findReferenceTypeFromInverseName(params.referenceType);
1148
- if (inv) {
1149
- params.referenceType = inv.nodeId;
1150
- params._referenceType = inv;
1151
- params.isForward = !params.isForward;
1152
- }
1153
- else {
1154
- params.referenceType = (0, node_opcua_nodeid_1.resolveNodeId)(params.referenceType);
1155
- const refType = this.findReferenceType(params.referenceType);
1156
- if (refType) {
1157
- params._referenceType = refType;
1158
- }
1159
- }
1160
- }
1161
- (0, node_opcua_assert_1.assert)(params.referenceType instanceof node_opcua_nodeid_1.NodeId);
1162
- // ----------- now resolve target NodeId;
1163
- if (params.nodeId instanceof base_node_impl_1.BaseNodeImpl) {
1164
- (0, node_opcua_assert_1.assert)(!Object.prototype.hasOwnProperty.call(params, "node"));
1165
- params.node = params.nodeId;
1166
- params.nodeId = params.node.nodeId;
1167
- }
1168
- else {
1169
- let _nodeId = params.nodeId;
1170
- (0, node_opcua_assert_1.assert)(!!_nodeId, "missing 'nodeId' in reference");
1171
- if (_nodeId && _nodeId.nodeId) {
1172
- _nodeId = _nodeId.nodeId;
1173
- }
1174
- _nodeId = (0, node_opcua_nodeid_1.resolveNodeId)(_nodeId);
1175
- params.nodeId = _nodeId;
1176
- }
1177
- return new reference_impl_1.ReferenceImpl(params);
1178
- }
1179
- normalizeReferenceTypes(references) {
1180
- if (!references || references.length === 0) {
1181
- return [];
1182
- }
1183
- return references.map((el) => this.normalizeReferenceType(el));
1184
- }
1185
- // -- Historical Node -----------------------------------------------------------------------------------------
1186
- /**
1187
- *
1188
- * @param node
1189
- * @param options
1190
- */
1191
- installHistoricalDataNode(node, options) {
1192
- address_space_historical_data_node_1.AddressSpace_installHistoricalDataNode.call(this, node, options);
1193
- }
1194
- // -- Alarms & Conditions -----------------------------------------------------------------------------------------
1195
- /**
1196
- *
1197
- */
1198
- installAlarmsAndConditionsService() {
1199
- alarms_and_conditions_1.UAConditionImpl.install_condition_refresh_handle(this);
1200
- alarms_and_conditions_1.UAAcknowledgeableConditionImpl.install_method_handle_on_type(this);
1201
- }
1202
- // -- internal stuff -----------------------------------------------------------------------------------------------
1203
- _coerceNode(node) {
1204
- function hasTypeDefinition(node1) {
1205
- return (node1.nodeClass === node_opcua_data_model_1.NodeClass.Variable ||
1206
- node1.nodeClass === node_opcua_data_model_1.NodeClass.Object ||
1207
- node1.nodeClass === node_opcua_data_model_1.NodeClass.Method);
1208
- }
1209
- // coerce to BaseNode object
1210
- if (node instanceof base_node_impl_1.BaseNodeImpl) {
1211
- return node;
1212
- }
1213
- // it's a node id like
1214
- // coerce parent folder to an object
1215
- const returnValue = this.findNode((0, node_opcua_nodeid_1.resolveNodeId)(node));
1216
- /*
1217
- if (!hasTypeDefinition(node as BaseNode)) {
1218
- node = this.findNode(node.nodeId) || node;
1219
- if (!node || !hasTypeDefinition(node)) {
1220
- return null;
1221
- }
1222
- }
1223
- */
1224
- return returnValue;
1225
- }
1226
- _coerce_DataType(dataType) {
1227
- if (dataType instanceof node_opcua_nodeid_1.NodeId) {
1228
- // xx assert(self.findDataType(dataType));
1229
- return dataType;
1230
- }
1231
- return this._coerce_Type(dataType, node_opcua_constants_1.DataTypeIds, "DataTypeIds", AddressSpace.prototype.findDataType);
1232
- }
1233
- _coerceTypeDefinition(typeDefinition) {
1234
- if (typeof typeDefinition === "string") {
1235
- // coerce parent folder to an node
1236
- const typeDefinitionNode = this.findNode(typeDefinition);
1237
- typeDefinition = typeDefinitionNode.nodeId;
1238
- }
1239
- // xx console.log("typeDefinition = ",typeDefinition);
1240
- (0, node_opcua_assert_1.assert)(typeDefinition instanceof node_opcua_nodeid_1.NodeId);
1241
- return typeDefinition;
1242
- }
1243
- _coerceType(baseType, topMostBaseType, nodeClass) {
1244
- (0, node_opcua_assert_1.assert)(typeof topMostBaseType === "string");
1245
- const topMostBaseTypeNode = this.findNode(topMostBaseType);
1246
- /* istanbul ignore next */
1247
- if (!topMostBaseTypeNode) {
1248
- throw new Error("Cannot find topMostBaseTypeNode " + topMostBaseType.toString());
1249
- }
1250
- (0, node_opcua_assert_1.assert)(topMostBaseTypeNode instanceof base_node_impl_1.BaseNodeImpl);
1251
- (0, node_opcua_assert_1.assert)(topMostBaseTypeNode.nodeClass === nodeClass);
1252
- if (!baseType) {
1253
- return topMostBaseTypeNode;
1254
- }
1255
- (0, node_opcua_assert_1.assert)(typeof baseType === "string" || baseType instanceof base_node_impl_1.BaseNodeImpl || baseType instanceof node_opcua_nodeid_1.NodeId);
1256
- let baseTypeNode;
1257
- if (baseType instanceof base_node_impl_1.BaseNodeImpl) {
1258
- baseTypeNode = baseType;
1259
- }
1260
- else {
1261
- baseTypeNode = this.findNode(baseType);
1262
- }
1263
- /* istanbul ignore next*/
1264
- if (!baseTypeNode) {
1265
- throw new Error("Cannot find ObjectType or VariableType for " + baseType.toString());
1266
- }
1267
- /* istanbul ignore next */
1268
- if (!baseTypeNode.isSubtypeOf) {
1269
- throw new Error("Cannot find ObjectType or VariableType for " + baseType.toString());
1270
- }
1271
- /* istanbul ignore next */
1272
- if (!baseTypeNode.isSubtypeOf(topMostBaseTypeNode)) {
1273
- throw new Error("wrong type ");
1274
- }
1275
- return baseTypeNode;
1276
- }
1277
- _coerce_VariableTypeIds(dataType) {
1278
- return this._coerce_Type(dataType, node_opcua_constants_1.VariableTypeIds, "VariableTypeIds", AddressSpace.prototype.findVariableType);
1279
- }
1280
- _register(node) {
1281
- (0, node_opcua_assert_1.assert)(node.nodeId instanceof node_opcua_nodeid_1.NodeId);
1282
- const namespace = this.getNamespace(node.nodeId.namespace);
1283
- namespace._register(node);
1284
- }
1285
- deleteNode(nodeOrNodeId) {
1286
- _getNamespace(this, nodeOrNodeId).deleteNode(nodeOrNodeId);
1287
- }
1288
- isEnumeration(dataType) {
1289
- // DataType must be one of Enumeration
1290
- const dataTypeNode = this.findDataType(dataType);
1291
- if (!dataTypeNode) {
1292
- throw new Error(" Cannot find DataType " + dataType.toString() + " in standard address Space");
1293
- }
1294
- const enumerationNode = this.findDataType("Enumeration");
1295
- if (!enumerationNode) {
1296
- throw new Error(" Cannot find 'Enumeration' DataType in standard address Space");
1297
- }
1298
- return dataTypeNode.isSubtypeOf(enumerationNode);
1299
- }
1300
- _coerce_Type(dataType, typeMap, typeMapName, finderMethod) {
1301
- if (dataType instanceof base_node_impl_1.BaseNodeImpl) {
1302
- dataType = dataType.nodeId;
1303
- }
1304
- (0, node_opcua_assert_1.assert)(typeMap !== null && typeof typeMap === "object");
1305
- let nodeId;
1306
- if (typeof dataType === "string") {
1307
- const namespace0 = this.getDefaultNamespace();
1308
- // resolve dataType
1309
- nodeId = namespace0.resolveAlias(dataType);
1310
- if (!nodeId) {
1311
- // dataType was not found in the aliases database
1312
- if (typeMap[dataType]) {
1313
- nodeId = (0, node_opcua_nodeid_1.makeNodeId)(typeMap[dataType], 0);
1314
- return nodeId;
1315
- }
1316
- else {
1317
- nodeId = (0, node_opcua_nodeid_1.resolveNodeId)(dataType);
1318
- }
1319
- }
1320
- }
1321
- else if (typeof dataType === "number") {
1322
- nodeId = (0, node_opcua_nodeid_1.makeNodeId)(dataType, 0);
1323
- }
1324
- else {
1325
- nodeId = (0, node_opcua_nodeid_1.resolveNodeId)(dataType);
1326
- }
1327
- /* istanbul ignore next */
1328
- if (nodeId == null || !(nodeId instanceof node_opcua_nodeid_1.NodeId)) {
1329
- throw new Error("Expecting valid nodeId ");
1330
- }
1331
- const el = finderMethod.call(this, nodeId);
1332
- if (!el) {
1333
- // verify that node Id exists in standard type map typeMap
1334
- const find = Object.values(typeMap).filter((a) => a === nodeId.value);
1335
- /* istanbul ignore next */
1336
- if (find.length !== 1) {
1337
- throw new Error(" cannot find " + dataType.toString() + " in typeMap " + typeMapName + " L = " + find.length);
1338
- }
1339
- }
1340
- return nodeId;
1341
- }
1342
- _findReferenceType(refType, namespaceIndex) {
1343
- if (refType instanceof node_opcua_nodeid_1.NodeId) {
1344
- return _find_by_node_id(this, refType, namespaceIndex);
1345
- }
1346
- const [namespace, browseName] = _extract_namespace_and_browse_name_as_string(this, refType, namespaceIndex);
1347
- return namespace.findReferenceType(browseName);
1348
- }
1349
- }
1350
- exports.AddressSpace = AddressSpace;
1351
- AddressSpace.isNonEmptyQualifiedName = namespace_impl_2.isNonEmptyQualifiedName;
1352
- AddressSpace.registry = new node_opcua_object_registry_1.ObjectRegistry();
1353
- function _getNamespace(addressSpace, nodeOrNodId) {
1354
- const nodeId = nodeOrNodId instanceof base_node_impl_1.BaseNodeImpl ? nodeOrNodId.nodeId : nodeOrNodId;
1355
- return addressSpace.getNamespace(nodeId.namespace);
1356
- }
1357
- function _find_by_node_id(addressSpace, nodeId, namespaceIndex) {
1358
- const obj = addressSpace.findNode(nodeId);
1359
- return obj;
1360
- }
1361
- /**
1362
- * return true if nodeId is a UAFolder
1363
- * @method _isFolder
1364
- * @param addressSpace
1365
- * @param folder
1366
- * @return {Boolean}
1367
- * @private
1368
- */
1369
- function _isFolder(addressSpace, folder) {
1370
- const folderType = addressSpace.findObjectType("FolderType");
1371
- (0, node_opcua_assert_1.assert)(folder instanceof base_node_impl_1.BaseNodeImpl);
1372
- (0, node_opcua_assert_1.assert)(folder.typeDefinitionObj);
1373
- return folder.typeDefinitionObj.isSubtypeOf(folderType);
1374
- }
1375
- function _increase_version_number(node) {
1376
- if (node && node.nodeVersion) {
1377
- const previousValue = parseInt(node.nodeVersion.readValue().value.value, 10);
1378
- node.nodeVersion.setValueFromSource({
1379
- dataType: node_opcua_variant_1.DataType.String,
1380
- value: (previousValue + 1).toString()
1381
- });
1382
- // xx console.log("xxx increasing version number of node ", node.browseName.toString(),previousValue);
1383
- }
1384
- }
1385
- //# sourceMappingURL=address_space.js.map