node-opcua-address-space 2.97.0 → 2.98.1

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 (342) 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 +91 -91
  4. package/dist/source/continuation_points/continuation_point_manager.js +200 -200
  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 +33 -33
  8. package/dist/source/helpers/argument_list.js +254 -254
  9. package/dist/source/helpers/call_helpers.d.ts +6 -6
  10. package/dist/source/helpers/call_helpers.js +71 -71
  11. package/dist/source/helpers/coerce_enum_value.d.ts +6 -6
  12. package/dist/source/helpers/coerce_enum_value.js +33 -33
  13. package/dist/source/helpers/dump_tools.d.ts +14 -14
  14. package/dist/source/helpers/dump_tools.js +78 -78
  15. package/dist/source/helpers/ensure_secure_access.d.ts +9 -9
  16. package/dist/source/helpers/ensure_secure_access.js +76 -76
  17. package/dist/source/helpers/make_optionals_map.d.ts +21 -21
  18. package/dist/source/helpers/make_optionals_map.js +29 -29
  19. package/dist/source/helpers/multiform_func.d.ts +11 -11
  20. package/dist/source/helpers/multiform_func.js +75 -75
  21. package/dist/source/helpers/resolve_opaque_on_address_space.d.ts +3 -3
  22. package/dist/source/helpers/resolve_opaque_on_address_space.js +36 -36
  23. package/dist/source/index.d.ts +61 -61
  24. package/dist/source/index.js +89 -89
  25. package/dist/source/interfaces/alarms_and_conditions/condition_info_i.d.ts +19 -19
  26. package/dist/source/interfaces/alarms_and_conditions/condition_info_i.js +2 -2
  27. package/dist/source/interfaces/alarms_and_conditions/condition_snapshot.d.ts +193 -193
  28. package/dist/source/interfaces/alarms_and_conditions/condition_snapshot.js +2 -2
  29. package/dist/source/interfaces/alarms_and_conditions/deviation_stuff.d.ts +12 -12
  30. package/dist/source/interfaces/alarms_and_conditions/deviation_stuff.js +2 -2
  31. package/dist/source/interfaces/alarms_and_conditions/install_setpoint_options.d.ts +10 -10
  32. package/dist/source/interfaces/alarms_and_conditions/install_setpoint_options.js +2 -2
  33. package/dist/source/interfaces/alarms_and_conditions/instantiate_alarm_condition_options.d.ts +7 -7
  34. package/dist/source/interfaces/alarms_and_conditions/instantiate_alarm_condition_options.js +2 -2
  35. package/dist/source/interfaces/alarms_and_conditions/instantiate_condition_options.d.ts +7 -7
  36. package/dist/source/interfaces/alarms_and_conditions/instantiate_condition_options.js +2 -2
  37. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_deviation_alarm_options.d.ts +4 -4
  38. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_deviation_alarm_options.js +2 -2
  39. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_limit_alarm_options.d.ts +4 -4
  40. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_limit_alarm_options.js +2 -2
  41. package/dist/source/interfaces/alarms_and_conditions/instantiate_limit_alarm_options.d.ts +9 -9
  42. package/dist/source/interfaces/alarms_and_conditions/instantiate_limit_alarm_options.js +2 -2
  43. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_deviation_alarm_options.d.ts +4 -4
  44. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_deviation_alarm_options.js +2 -2
  45. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_limit_alarm_options.d.ts +4 -4
  46. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_limit_alarm_options.js +2 -2
  47. package/dist/source/interfaces/alarms_and_conditions/instantiate_off_normal_alarm_options.d.ts +20 -20
  48. package/dist/source/interfaces/alarms_and_conditions/instantiate_off_normal_alarm_options.js +2 -2
  49. package/dist/source/interfaces/alarms_and_conditions/ua_acknowledgeable_condition_ex.d.ts +23 -23
  50. package/dist/source/interfaces/alarms_and_conditions/ua_acknowledgeable_condition_ex.js +2 -2
  51. package/dist/source/interfaces/alarms_and_conditions/ua_alarm_condition_ex.d.ts +32 -32
  52. package/dist/source/interfaces/alarms_and_conditions/ua_alarm_condition_ex.js +2 -2
  53. package/dist/source/interfaces/alarms_and_conditions/ua_certificate_expiration_alarm_ex.d.ts +19 -19
  54. package/dist/source/interfaces/alarms_and_conditions/ua_certificate_expiration_alarm_ex.js +2 -2
  55. package/dist/source/interfaces/alarms_and_conditions/ua_condition_ex.d.ts +45 -42
  56. package/dist/source/interfaces/alarms_and_conditions/ua_condition_ex.js +2 -2
  57. package/dist/source/interfaces/alarms_and_conditions/ua_discrete_alarm_ex.d.ts +7 -7
  58. package/dist/source/interfaces/alarms_and_conditions/ua_discrete_alarm_ex.js +25 -25
  59. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_deviation_alarm_ex.d.ts +5 -5
  60. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_deviation_alarm_ex.js +2 -2
  61. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_limit_alarm_ex.d.ts +20 -20
  62. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_limit_alarm_ex.js +2 -2
  63. package/dist/source/interfaces/alarms_and_conditions/ua_limit_alarm_ex.d.ts +26 -26
  64. package/dist/source/interfaces/alarms_and_conditions/ua_limit_alarm_ex.js +2 -2
  65. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_deviation_alarm_ex.d.ts +8 -8
  66. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_deviation_alarm_ex.js +2 -2
  67. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_limit_alarm_ex.d.ts +10 -10
  68. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_limit_alarm_ex.js +2 -2
  69. package/dist/source/interfaces/data_access/ua_multistate_discrete_ex.d.ts +21 -21
  70. package/dist/source/interfaces/data_access/ua_multistate_discrete_ex.js +2 -2
  71. package/dist/source/interfaces/data_access/ua_multistate_value_discrete_ex.d.ts +24 -24
  72. package/dist/source/interfaces/data_access/ua_multistate_value_discrete_ex.js +2 -2
  73. package/dist/source/interfaces/data_access/ua_two_state_discrete_ex.d.ts +12 -12
  74. package/dist/source/interfaces/data_access/ua_two_state_discrete_ex.js +2 -2
  75. package/dist/source/interfaces/data_access/ua_y_array_item_ex.d.ts +8 -8
  76. package/dist/source/interfaces/data_access/ua_y_array_item_ex.js +2 -2
  77. package/dist/source/interfaces/extension_object_constructor.d.ts +10 -10
  78. package/dist/source/interfaces/extension_object_constructor.js +2 -2
  79. package/dist/source/interfaces/nodeset_loader_options.d.ts +4 -4
  80. package/dist/source/interfaces/nodeset_loader_options.js +2 -2
  81. package/dist/source/interfaces/state_machine/ua_exclusive_limit_state_machine_type_ex.d.ts +12 -12
  82. package/dist/source/interfaces/state_machine/ua_exclusive_limit_state_machine_type_ex.js +2 -2
  83. package/dist/source/interfaces/state_machine/ua_finite_state_machine_type.d.ts +49 -49
  84. package/dist/source/interfaces/state_machine/ua_finite_state_machine_type.js +2 -2
  85. package/dist/source/interfaces/state_machine/ua_program_state_machine_type.d.ts +11 -11
  86. package/dist/source/interfaces/state_machine/ua_program_state_machine_type.js +2 -2
  87. package/dist/source/interfaces/state_machine/ua_shelved_state_machine_ex.d.ts +30 -30
  88. package/dist/source/interfaces/state_machine/ua_shelved_state_machine_ex.js +2 -2
  89. package/dist/source/interfaces/state_machine/ua_state_machine_type.d.ts +234 -234
  90. package/dist/source/interfaces/state_machine/ua_state_machine_type.js +2 -2
  91. package/dist/source/interfaces/state_machine/ua_transition_ex.d.ts +6 -6
  92. package/dist/source/interfaces/state_machine/ua_transition_ex.js +2 -2
  93. package/dist/source/interfaces/ua_subscription_diagnostics_variable_ex.d.ts +8 -8
  94. package/dist/source/interfaces/ua_subscription_diagnostics_variable_ex.js +2 -2
  95. package/dist/source/loader/decode_xml_extension_object.d.ts +6 -6
  96. package/dist/source/loader/decode_xml_extension_object.js +71 -71
  97. package/dist/source/loader/ensure_datatype_extracted.d.ts +5 -5
  98. package/dist/source/loader/ensure_datatype_extracted.js +70 -70
  99. package/dist/source/loader/generateAddressSpaceRaw.d.ts +11 -11
  100. package/dist/source/loader/generateAddressSpaceRaw.js +45 -45
  101. package/dist/source/loader/load_nodeset2.d.ts +17 -17
  102. package/dist/source/loader/load_nodeset2.js +1483 -1483
  103. package/dist/source/loader/make_semver_compatible.d.ts +6 -6
  104. package/dist/source/loader/make_semver_compatible.js +25 -25
  105. package/dist/source/loader/make_xml_extension_object_parser.d.ts +28 -28
  106. package/dist/source/loader/make_xml_extension_object_parser.js +326 -326
  107. package/dist/source/loader/namespace_post_step.d.ts +10 -10
  108. package/dist/source/loader/namespace_post_step.js +61 -61
  109. package/dist/source/loader/register_node_promoter.d.ts +2 -2
  110. package/dist/source/loader/register_node_promoter.js +9 -9
  111. package/dist/source/namespace.d.ts +6 -6
  112. package/dist/source/namespace.js +2 -2
  113. package/dist/source/namespace_alarm_and_condition.d.ts +32 -32
  114. package/dist/source/namespace_alarm_and_condition.js +2 -2
  115. package/dist/source/namespace_data_access.d.ts +42 -42
  116. package/dist/source/namespace_data_access.js +2 -2
  117. package/dist/source/namespace_machine_state.d.ts +8 -8
  118. package/dist/source/namespace_machine_state.js +2 -2
  119. package/dist/source/pseudo_session.d.ts +72 -72
  120. package/dist/source/pseudo_session.js +254 -254
  121. package/dist/source/session_context.d.ts +111 -111
  122. package/dist/source/session_context.js +264 -264
  123. package/dist/source/session_context.js.map +1 -1
  124. package/dist/source/set_namespace_meta_data.d.ts +2 -2
  125. package/dist/source/set_namespace_meta_data.js +59 -59
  126. package/dist/source/ua_root_folder.d.ts +9 -9
  127. package/dist/source/ua_root_folder.js +2 -2
  128. package/dist/source/ua_two_state_variable_ex.d.ts +23 -23
  129. package/dist/source/ua_two_state_variable_ex.js +2 -2
  130. package/dist/source/xml_writer.d.ts +18 -18
  131. package/dist/source/xml_writer.js +2 -2
  132. package/dist/src/address_space.d.ts +387 -387
  133. package/dist/src/address_space.js +1385 -1385
  134. package/dist/src/address_space.js.map +1 -1
  135. package/dist/src/address_space_change_event_tools.d.ts +6 -6
  136. package/dist/src/address_space_change_event_tools.js +152 -152
  137. package/dist/src/address_space_private.d.ts +43 -43
  138. package/dist/src/address_space_private.js +2 -2
  139. package/dist/src/alarms_and_conditions/condition.d.ts +5 -5
  140. package/dist/src/alarms_and_conditions/condition.js +78 -78
  141. package/dist/src/alarms_and_conditions/condition_info_impl.d.ts +26 -26
  142. package/dist/src/alarms_and_conditions/condition_info_impl.js +54 -54
  143. package/dist/src/alarms_and_conditions/condition_snapshot_impl.d.ts +222 -222
  144. package/dist/src/alarms_and_conditions/condition_snapshot_impl.js +657 -657
  145. package/dist/src/alarms_and_conditions/condition_snapshot_impl.js.map +1 -1
  146. package/dist/src/alarms_and_conditions/deviation_alarm_helper.d.ts +9 -9
  147. package/dist/src/alarms_and_conditions/deviation_alarm_helper.js +60 -60
  148. package/dist/src/alarms_and_conditions/index.d.ts +16 -16
  149. package/dist/src/alarms_and_conditions/index.js +32 -32
  150. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_impl.d.ts +44 -44
  151. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_impl.js +244 -244
  152. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.d.ts +93 -93
  153. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.js +418 -418
  154. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.js.map +1 -1
  155. package/dist/src/alarms_and_conditions/ua_base_event_impl.d.ts +26 -26
  156. package/dist/src/alarms_and_conditions/ua_base_event_impl.js +38 -38
  157. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.d.ts +44 -44
  158. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.js +183 -183
  159. package/dist/src/alarms_and_conditions/ua_condition_impl.d.ts +155 -153
  160. package/dist/src/alarms_and_conditions/ua_condition_impl.js +1028 -1028
  161. package/dist/src/alarms_and_conditions/ua_condition_impl.js.map +1 -1
  162. package/dist/src/alarms_and_conditions/ua_discrete_alarm_impl.d.ts +14 -14
  163. package/dist/src/alarms_and_conditions/ua_discrete_alarm_impl.js +34 -34
  164. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.d.ts +24 -24
  165. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.js +56 -56
  166. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm_impl.d.ts +11 -11
  167. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm_impl.js +11 -11
  168. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.d.ts +23 -23
  169. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.js +86 -86
  170. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm_impl.d.ts +11 -11
  171. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm_impl.js +7 -7
  172. package/dist/src/alarms_and_conditions/ua_limit_alarm_impl.d.ts +79 -79
  173. package/dist/src/alarms_and_conditions/ua_limit_alarm_impl.js +250 -250
  174. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.d.ts +24 -24
  175. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.js +50 -50
  176. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.d.ts +19 -19
  177. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.js +162 -162
  178. package/dist/src/alarms_and_conditions/ua_off_normal_alarm_impl.d.ts +46 -46
  179. package/dist/src/alarms_and_conditions/ua_off_normal_alarm_impl.js +165 -165
  180. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.d.ts +18 -18
  181. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.js +17 -17
  182. package/dist/src/apply_condition_refresh.d.ts +6 -6
  183. package/dist/src/apply_condition_refresh.js +27 -27
  184. package/dist/src/base_node_impl.d.ts +284 -284
  185. package/dist/src/base_node_impl.js +1454 -1454
  186. package/dist/src/base_node_private.d.ts +81 -81
  187. package/dist/src/base_node_private.js +832 -803
  188. package/dist/src/base_node_private.js.map +1 -1
  189. package/dist/src/check_value_rank_compatibility.d.ts +15 -15
  190. package/dist/src/check_value_rank_compatibility.js +81 -81
  191. package/dist/src/data_access/add_dataItem_stuff.d.ts +11 -11
  192. package/dist/src/data_access/add_dataItem_stuff.js +61 -61
  193. package/dist/src/data_access/check_variant_compatibility_ua_analog_item.d.ts +1 -1
  194. package/dist/src/data_access/check_variant_compatibility_ua_analog_item.js +34 -34
  195. package/dist/src/data_access/ua_multistate_discrete_impl.d.ts +32 -32
  196. package/dist/src/data_access/ua_multistate_discrete_impl.js +130 -130
  197. package/dist/src/data_access/ua_multistate_value_discrete_impl.d.ts +52 -52
  198. package/dist/src/data_access/ua_multistate_value_discrete_impl.js +253 -253
  199. package/dist/src/data_access/ua_two_state_discrete_impl.d.ts +25 -25
  200. package/dist/src/data_access/ua_two_state_discrete_impl.js +155 -155
  201. package/dist/src/event_data.d.ts +34 -34
  202. package/dist/src/event_data.js +64 -64
  203. package/dist/src/extension_object_array_node.d.ts +23 -23
  204. package/dist/src/extension_object_array_node.js +248 -248
  205. package/dist/src/historical_access/address_space_historical_data_node.d.ts +26 -26
  206. package/dist/src/historical_access/address_space_historical_data_node.js +652 -652
  207. package/dist/src/idx_iterator.d.ts +8 -8
  208. package/dist/src/idx_iterator.js +50 -50
  209. package/dist/src/index_current.d.ts +46 -46
  210. package/dist/src/index_current.js +77 -77
  211. package/dist/src/namespace_impl.d.ts +456 -456
  212. package/dist/src/namespace_impl.js +1762 -1762
  213. package/dist/src/namespace_impl.js.map +1 -1
  214. package/dist/src/namespace_private.d.ts +23 -23
  215. package/dist/src/namespace_private.js +32 -32
  216. package/dist/src/nodeid_manager.d.ts +37 -37
  217. package/dist/src/nodeid_manager.js +183 -183
  218. package/dist/src/nodeset_tools/adjust_namespace_array.d.ts +2 -2
  219. package/dist/src/nodeset_tools/adjust_namespace_array.js +13 -13
  220. package/dist/src/nodeset_tools/construct_namespace_dependency.d.ts +18 -18
  221. package/dist/src/nodeset_tools/construct_namespace_dependency.js +140 -140
  222. package/dist/src/nodeset_tools/dump_to_bsd.d.ts +2 -2
  223. package/dist/src/nodeset_tools/dump_to_bsd.js +164 -164
  224. package/dist/src/nodeset_tools/nodeset_to_xml.d.ts +10 -10
  225. package/dist/src/nodeset_tools/nodeset_to_xml.js +1287 -1287
  226. package/dist/src/private_namespace.d.ts +5 -5
  227. package/dist/src/private_namespace.js +19 -19
  228. package/dist/src/reference_impl.d.ts +43 -43
  229. package/dist/src/reference_impl.js +139 -139
  230. package/dist/src/role_permissions.d.ts +2 -2
  231. package/dist/src/role_permissions.js +10 -10
  232. package/dist/src/state_machine/finite_state_machine.d.ts +81 -81
  233. package/dist/src/state_machine/finite_state_machine.js +388 -388
  234. package/dist/src/state_machine/ua_shelving_state_machine_ex.d.ts +38 -38
  235. package/dist/src/state_machine/ua_shelving_state_machine_ex.js +250 -250
  236. package/dist/src/state_machine/ua_two_state_variable.d.ts +61 -61
  237. package/dist/src/state_machine/ua_two_state_variable.js +331 -331
  238. package/dist/src/tool_isSubtypeOf.d.ts +18 -18
  239. package/dist/src/tool_isSubtypeOf.js +124 -124
  240. package/dist/src/ua_condition_type.d.ts +8 -8
  241. package/dist/src/ua_condition_type.js +2 -2
  242. package/dist/src/ua_data_type_impl.d.ts +89 -89
  243. package/dist/src/ua_data_type_impl.js +368 -368
  244. package/dist/src/ua_method_impl.d.ts +42 -42
  245. package/dist/src/ua_method_impl.js +217 -217
  246. package/dist/src/ua_object_impl.d.ts +35 -35
  247. package/dist/src/ua_object_impl.js +168 -168
  248. package/dist/src/ua_object_type_impl.d.ts +50 -50
  249. package/dist/src/ua_object_type_impl.js +126 -126
  250. package/dist/src/ua_reference_type_impl.d.ts +45 -45
  251. package/dist/src/ua_reference_type_impl.js +141 -141
  252. package/dist/src/ua_variable_impl.d.ts +380 -380
  253. package/dist/src/ua_variable_impl.js +1738 -1738
  254. package/dist/src/ua_variable_impl_ext_obj.d.ts +23 -23
  255. package/dist/src/ua_variable_impl_ext_obj.js +670 -670
  256. package/dist/src/ua_variable_type_impl.d.ts +74 -74
  257. package/dist/src/ua_variable_type_impl.js +597 -581
  258. package/dist/src/ua_variable_type_impl.js.map +1 -1
  259. package/dist/src/ua_view_impl.d.ts +19 -19
  260. package/dist/src/ua_view_impl.js +43 -43
  261. package/dist/tsconfig_common.tsbuildinfo +1 -0
  262. package/distHelpers/add_event_generator_object.d.ts +3 -3
  263. package/distHelpers/add_event_generator_object.js +64 -64
  264. package/distHelpers/alarms_and_conditions_demo.d.ts +9 -9
  265. package/distHelpers/alarms_and_conditions_demo.js +115 -115
  266. package/distHelpers/assertHasMatchingReference.d.ts +19 -19
  267. package/distHelpers/assertHasMatchingReference.js +40 -40
  268. package/distHelpers/boiler_system.d.ts +113 -113
  269. package/distHelpers/boiler_system.js +395 -395
  270. package/distHelpers/create_minimalist_address_space_nodeset.d.ts +5 -5
  271. package/distHelpers/create_minimalist_address_space_nodeset.js +171 -171
  272. package/distHelpers/date_utils.d.ts +3 -3
  273. package/distHelpers/date_utils.js +9 -9
  274. package/distHelpers/dump_statemachine.js +127 -127
  275. package/distHelpers/get_address_space_fixture.d.ts +1 -1
  276. package/distHelpers/get_address_space_fixture.js +30 -30
  277. package/distHelpers/get_mini_address_space.d.ts +7 -7
  278. package/distHelpers/get_mini_address_space.js +36 -36
  279. package/distHelpers/index.d.ts +12 -12
  280. package/distHelpers/index.js +28 -28
  281. package/distHelpers/mock_session.d.ts +10 -10
  282. package/distHelpers/mock_session.js +25 -25
  283. package/distNodeJS/generate_address_space.d.ts +6 -6
  284. package/distNodeJS/generate_address_space.js +52 -52
  285. package/distNodeJS/index.d.ts +1 -1
  286. package/distNodeJS/index.js +17 -17
  287. package/package.json +51 -40
  288. package/source/interfaces/alarms_and_conditions/ua_condition_ex.ts +4 -3
  289. package/src/alarms_and_conditions/ua_condition_impl.ts +14 -9
  290. package/src/base_node_private.ts +73 -28
  291. package/src/ua_variable_type_impl.ts +35 -17
  292. package/.mocharc.yml +0 -12
  293. package/dist/src/tool_isSupertypeOf.d.ts +0 -18
  294. package/dist/src/tool_isSupertypeOf.js +0 -125
  295. package/dist/src/tool_isSupertypeOf.js.map +0 -1
  296. package/generate.js +0 -1
  297. package/source_nodejs/generate_address_space.ts +0 -60
  298. package/source_nodejs/index.ts +0 -1
  299. package/test_helpers/add_event_generator_object.ts +0 -71
  300. package/test_helpers/alarms_and_conditions_demo.ts +0 -151
  301. package/test_helpers/assertHasMatchingReference.ts +0 -43
  302. package/test_helpers/boiler_system.ts +0 -610
  303. package/test_helpers/create_minimalist_address_space_nodeset.ts +0 -208
  304. package/test_helpers/date_utils.ts +0 -5
  305. package/test_helpers/dump_statemachine.ts +0 -155
  306. package/test_helpers/get_address_space_fixture.ts +0 -30
  307. package/test_helpers/get_mini_address_space.ts +0 -42
  308. package/test_helpers/index.ts +0 -12
  309. package/test_helpers/mock_session.ts +0 -34
  310. package/test_helpers/test_fixtures/dataType_in_separateNamespace.xml +0 -150
  311. package/test_helpers/test_fixtures/dataType_in_separateNamespace_basic.xml +0 -57
  312. package/test_helpers/test_fixtures/dataType_in_separateNamespace_mix.xml +0 -136
  313. package/test_helpers/test_fixtures/dataType_issue.xml +0 -80
  314. package/test_helpers/test_fixtures/dataType_withEnumeration.xml +0 -82
  315. package/test_helpers/test_fixtures/dataType_with_isOptionSet.xml +0 -194
  316. package/test_helpers/test_fixtures/dataType_with_qualifiedname.xml +0 -71
  317. package/test_helpers/test_fixtures/dataType_with_recursive_structure.xml +0 -155
  318. package/test_helpers/test_fixtures/dataType_with_structures.xml +0 -605
  319. package/test_helpers/test_fixtures/dataType_with_union.xml +0 -90
  320. package/test_helpers/test_fixtures/datatype_as_per_1.04.xml +0 -118
  321. package/test_helpers/test_fixtures/datatype_with_allow_subtype.xml +0 -104
  322. package/test_helpers/test_fixtures/eurange_issue.xml +0 -74
  323. package/test_helpers/test_fixtures/example_issue1096.xml +0 -267
  324. package/test_helpers/test_fixtures/fixture_empty_nodeset2.xml +0 -106
  325. package/test_helpers/test_fixtures/fixture_simple_statemachine_nodeset2.xml +0 -1305
  326. package/test_helpers/test_fixtures/fixuture_nodeset_objects_with_some_methods.xml +0 -370
  327. package/test_helpers/test_fixtures/issue_1132_variable_with_nodeid_value.xml +0 -68
  328. package/test_helpers/test_fixtures/issue_846.xml +0 -3172
  329. package/test_helpers/test_fixtures/issue_899_variable_with_nodeid_value.xml +0 -33
  330. package/test_helpers/test_fixtures/mini.Node.Set2.xml +0 -4736
  331. package/test_helpers/test_fixtures/mini.nodeset.withVariousVariables.xml +0 -196
  332. package/test_helpers/test_fixtures/minimalist_nodeset_with_models.xml +0 -8
  333. package/test_helpers/test_fixtures/minimalist_nodeset_with_models_more_complex.xml +0 -20
  334. package/test_helpers/test_fixtures/nodeset_no_aliases.xml +0 -30
  335. package/test_helpers/test_fixtures/nodeset_no_aliases_with_aliases.xml +0 -31
  336. package/test_helpers/test_fixtures/nodeset_with_analog_items.xml +0 -45
  337. package/test_helpers/test_fixtures/nodeset_with_guid.xml +0 -1442
  338. package/test_helpers/test_fixtures/nodeset_with_int64_values.xml +0 -31
  339. package/test_helpers/test_fixtures/nodeset_with_special_char.xml +0 -34
  340. package/test_helpers/test_fixtures/nodeset_with_utf8_special_characters.xml +0 -20
  341. package/test_helpers/test_fixtures/variable_with_value.xml +0 -143
  342. package/test_helpers/test_fixtures/variabletype_with_value.xml +0 -324
@@ -1,396 +1,396 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.makeBoiler = exports.createBoilerType = void 0;
4
- /* eslint-disable max-statements */
5
- /**
6
- * @module node-opcua-address-space
7
- */
8
- const node_opcua_assert_1 = require("node-opcua-assert");
9
- const node_opcua_data_model_1 = require("node-opcua-data-model");
10
- const node_opcua_status_code_1 = require("node-opcua-status-code");
11
- const node_opcua_utils_1 = require("node-opcua-utils");
12
- const __1 = require("..");
13
- function MygetExecutableFlag(method, toState, methodName) {
14
- const stateMachineW = (0, __1.promoteToStateMachine)(method.parent);
15
- return stateMachineW.isValidTransition(toState);
16
- }
17
- function implementProgramStateMachine(programStateMachine) {
18
- function installMethod(methodName, toState) {
19
- let method = programStateMachine.getMethodByName(methodName);
20
- if (!method) {
21
- // 'method' has ModellingRule=OptionalPlaceholder and should be created from the type definition
22
- let methodToClone = programStateMachine.typeDefinitionObj.getMethodByName(methodName);
23
- if (!methodToClone) {
24
- methodToClone = programStateMachine.typeDefinitionObj.subtypeOfObj.getMethodByName(methodName);
25
- }
26
- methodToClone.clone({
27
- namespace: programStateMachine.namespace,
28
- componentOf: programStateMachine
29
- });
30
- method = programStateMachine.getMethodByName(methodName);
31
- (0, node_opcua_assert_1.assert)(method !== null, "Method clone should cause parent object to be extended");
32
- }
33
- (0, node_opcua_assert_1.assert)(method.nodeClass === node_opcua_data_model_1.NodeClass.Method);
34
- method._getExecutableFlag = function ( /* sessionContext: SessionContext */) {
35
- // must use a function here to capture 'this'
36
- return MygetExecutableFlag(this, toState, methodName);
37
- };
38
- method.bindMethod(function (inputArguments, context, callback) {
39
- const stateMachineW = this.parent;
40
- stateMachineW.setState(toState);
41
- callback(null, {
42
- outputArguments: [],
43
- statusCode: node_opcua_status_code_1.StatusCodes.Good
44
- });
45
- });
46
- (0, node_opcua_assert_1.assert)(programStateMachine.getMethodByName(methodName) !== null, "Method " + methodName + " should be added to parent object (checked with getMethodByName)");
47
- const lc_name = (0, node_opcua_utils_1.lowerFirstLetter)(methodName);
48
- }
49
- installMethod("Halt", "Halted");
50
- installMethod("Reset", "Ready");
51
- installMethod("Start", "Running");
52
- installMethod("Suspend", "Suspended");
53
- installMethod("Resume", "Running");
54
- }
55
- function addRelation(srcNode, referenceType, targetNode) {
56
- (0, node_opcua_assert_1.assert)(srcNode, "expecting srcNode !== null");
57
- (0, node_opcua_assert_1.assert)(targetNode, "expecting targetNode !== null");
58
- if (typeof referenceType === "string") {
59
- const nodes = srcNode.findReferencesAsObject(referenceType, true);
60
- (0, node_opcua_assert_1.assert)(nodes.length === 1);
61
- referenceType = nodes[0];
62
- }
63
- srcNode.addReference({ referenceType: referenceType.nodeId, nodeId: targetNode });
64
- }
65
- function createBoilerType(namespace) {
66
- // istanbul ignore next
67
- if (namespace.findObjectType("BoilerType")) {
68
- console.warn("createBoilerType has already been called");
69
- return namespace.findObjectType("BoilerType");
70
- }
71
- // --------------------------------------------------------
72
- // referenceTypes
73
- // --------------------------------------------------------
74
- // create new reference Type FlowTo HotFlowTo & SignalTo
75
- const flowTo = namespace.addReferenceType({
76
- browseName: "FlowTo",
77
- description: "a reference that indicates a flow between two objects",
78
- inverseName: "FlowFrom",
79
- subtypeOf: "NonHierarchicalReferences"
80
- });
81
- const hotFlowTo = namespace.addReferenceType({
82
- browseName: "HotFlowTo",
83
- description: "a reference that indicates a high temperature flow between two objects",
84
- inverseName: "HotFlowFrom",
85
- subtypeOf: flowTo
86
- });
87
- const signalTo = namespace.addReferenceType({
88
- browseName: "SignalTo",
89
- description: "a reference that indicates an electrical signal between two variables",
90
- inverseName: "SignalFrom",
91
- subtypeOf: "NonHierarchicalReferences"
92
- });
93
- const addressSpace = namespace.addressSpace;
94
- flowTo.isSubtypeOf(addressSpace.findReferenceType("References"));
95
- flowTo.isSubtypeOf(addressSpace.findReferenceType("NonHierarchicalReferences"));
96
- hotFlowTo.isSubtypeOf(addressSpace.findReferenceType("References"));
97
- hotFlowTo.isSubtypeOf(addressSpace.findReferenceType("NonHierarchicalReferences"));
98
- hotFlowTo.isSubtypeOf(addressSpace.findReferenceType("FlowTo", namespace.index));
99
- const NonHierarchicalReferences = addressSpace.findReferenceType("NonHierarchicalReferences");
100
- // --------------------------------------------------------
101
- // EventTypes
102
- // --------------------------------------------------------
103
- const boilerHaltedEventType = namespace.addEventType({
104
- browseName: "BoilerHaltedEventType",
105
- subtypeOf: "TransitionEventType"
106
- });
107
- // --------------------------------------------------------
108
- // CustomControllerType
109
- // --------------------------------------------------------
110
- const customControllerType = namespace.addObjectType({
111
- browseName: "CustomControllerType",
112
- description: "a custom PID controller with 3 inputs"
113
- });
114
- const input1 = namespace.addVariable({
115
- browseName: "Input1",
116
- dataType: "Double",
117
- description: "a reference that indicates an electrical signal between two variables",
118
- modellingRule: "Mandatory",
119
- propertyOf: customControllerType
120
- });
121
- const input2 = namespace.addVariable({
122
- browseName: "Input2",
123
- dataType: "Double",
124
- modellingRule: "Mandatory",
125
- propertyOf: customControllerType
126
- });
127
- const input3 = namespace.addVariable({
128
- browseName: "Input3",
129
- dataType: "Double",
130
- modellingRule: "Mandatory",
131
- propertyOf: customControllerType
132
- });
133
- const controlOut = namespace.addVariable({
134
- browseName: "ControlOut",
135
- dataType: "Double",
136
- modellingRule: "Mandatory",
137
- propertyOf: customControllerType
138
- });
139
- const description = namespace.addVariable({
140
- browseName: "Description",
141
- dataType: "LocalizedText",
142
- modellingRule: "Mandatory",
143
- propertyOf: customControllerType
144
- });
145
- // --------------------------------------------------------
146
- // GenericSensorType
147
- // --------------------------------------------------------
148
- const genericSensorType = namespace.addObjectType({
149
- browseName: "GenericSensorType"
150
- });
151
- namespace.addAnalogDataItem({
152
- browseName: "Output",
153
- componentOf: genericSensorType,
154
- dataType: "Double",
155
- engineeringUnitsRange: { low: -100, high: 200 },
156
- modellingRule: "Mandatory"
157
- });
158
- genericSensorType.install_extra_properties();
159
- genericSensorType.getComponentByName("Output");
160
- (0, node_opcua_assert_1.assert)(genericSensorType.getComponentByName("Output").modellingRule === "Mandatory");
161
- // --------------------------------------------------------
162
- // GenericSensorType <---- GenericControllerType
163
- // --------------------------------------------------------
164
- const genericControllerType = namespace.addObjectType({
165
- browseName: "GenericControllerType"
166
- });
167
- namespace.addVariable({
168
- browseName: "ControlOut",
169
- dataType: "Double",
170
- modellingRule: "Mandatory",
171
- propertyOf: genericControllerType
172
- });
173
- namespace.addVariable({
174
- browseName: "Measurement",
175
- dataType: "Double",
176
- modellingRule: "Mandatory",
177
- propertyOf: genericControllerType
178
- });
179
- namespace.addVariable({
180
- browseName: "SetPoint",
181
- dataType: "Double",
182
- modellingRule: "Mandatory",
183
- propertyOf: genericControllerType
184
- });
185
- // --------------------------------------------------------------------------------
186
- // GenericSensorType <---- GenericControllerType <--- FlowControllerType
187
- // --------------------------------------------------------------------------------
188
- const flowControllerType = namespace.addObjectType({
189
- browseName: "FlowControllerType",
190
- subtypeOf: genericControllerType
191
- });
192
- // --------------------------------------------------------------------------------
193
- // GenericSensorType <---- GenericControllerType <--- LevelControllerType
194
- // --------------------------------------------------------------------------------
195
- const levelControllerType = namespace.addObjectType({
196
- browseName: "LevelControllerType",
197
- subtypeOf: genericControllerType
198
- });
199
- // --------------------------------------------------------------------------------
200
- // GenericSensorType <---- FlowTransmitterType
201
- // --------------------------------------------------------------------------------
202
- const flowTransmitterType = namespace.addObjectType({
203
- browseName: "FlowTransmitterType",
204
- subtypeOf: genericSensorType
205
- });
206
- // --------------------------------------------------------------------------------
207
- // GenericSensorType <---- LevelIndicatorType
208
- // --------------------------------------------------------------------------------
209
- const levelIndicatorType = namespace.addObjectType({
210
- browseName: "LevelIndicatorType",
211
- subtypeOf: genericSensorType
212
- });
213
- // --------------------------------------------------------------------------------
214
- // GenericActuatorType
215
- // --------------------------------------------------------------------------------
216
- const genericActuatorType = namespace.addObjectType({
217
- browseName: "GenericActuatorType"
218
- });
219
- namespace.addAnalogDataItem({
220
- browseName: "Input",
221
- componentOf: genericActuatorType,
222
- dataType: "Double",
223
- engineeringUnitsRange: { low: -100, high: 200 },
224
- modellingRule: "Mandatory"
225
- });
226
- // --------------------------------------------------------------------------------
227
- // GenericActuatorType <---- ValveType
228
- // --------------------------------------------------------------------------------
229
- const valveType = namespace.addObjectType({
230
- browseName: "ValveType",
231
- subtypeOf: genericActuatorType
232
- });
233
- // --------------------------------------------------------------------------------
234
- // FolderType <---- BoilerInputPipeType
235
- // --------------------------------------------------------------------------------
236
- const boilerInputPipeType = namespace.addObjectType({
237
- browseName: "BoilerInputPipeType",
238
- subtypeOf: "FolderType"
239
- });
240
- const ftx1 = flowTransmitterType.instantiate({
241
- browseName: "FlowTransmitter",
242
- componentOf: boilerInputPipeType,
243
- modellingRule: "Mandatory",
244
- notifierOf: boilerInputPipeType
245
- });
246
- (0, node_opcua_assert_1.assert)(ftx1.output.browseName.toString() === `${namespace.index}:Output`);
247
- const valve1 = valveType.instantiate({
248
- browseName: "Valve",
249
- componentOf: boilerInputPipeType,
250
- modellingRule: "Mandatory"
251
- });
252
- // --------------------------------------------------------------------------------
253
- // FolderType <---- BoilerOutputPipeType
254
- // --------------------------------------------------------------------------------
255
- const boilerOutputPipeType = namespace.addObjectType({
256
- browseName: "BoilerOutputPipeType",
257
- subtypeOf: "FolderType"
258
- });
259
- const ftx2 = flowTransmitterType.instantiate({
260
- browseName: "FlowTransmitter",
261
- componentOf: boilerOutputPipeType,
262
- modellingRule: "Mandatory",
263
- notifierOf: boilerOutputPipeType
264
- });
265
- ftx2.getComponentByName("Output").browseName.toString();
266
- // --------------------------------)------------------------------------------------
267
- // FolderType <---- BoilerDrumType
268
- // --------------------------------------------------------------------------------
269
- const boilerDrumType = namespace.addObjectType({
270
- browseName: "BoilerDrumType",
271
- subtypeOf: "FolderType"
272
- });
273
- const levelIndicator = levelIndicatorType.instantiate({
274
- browseName: "LevelIndicator",
275
- componentOf: boilerDrumType,
276
- modellingRule: "Mandatory",
277
- notifierOf: boilerDrumType
278
- });
279
- const programFiniteStateMachineType = addressSpace.findObjectType("ProgramStateMachineType");
280
- // --------------------------------------------------------
281
- // define boiler State Machine
282
- // --------------------------------------------------------
283
- const boilerStateMachineType = namespace.addObjectType({
284
- browseName: "BoilerStateMachineType",
285
- postInstantiateFunc: implementProgramStateMachine,
286
- subtypeOf: programFiniteStateMachineType
287
- });
288
- // programStateMachineType has Optional placeHolder for method "Halt", "Reset","Start","Suspend","Resume")
289
- function addMethod(baseType, objectType, methodName) {
290
- (0, node_opcua_assert_1.assert)(!objectType.getMethodByName(methodName));
291
- const method = baseType.getMethodByName(methodName);
292
- const m = method.clone({
293
- namespace,
294
- componentOf: objectType,
295
- modellingRule: "Mandatory"
296
- });
297
- (0, node_opcua_assert_1.assert)(objectType.getMethodByName(methodName));
298
- (0, node_opcua_assert_1.assert)(objectType.getMethodByName(methodName).modellingRule === "Mandatory");
299
- }
300
- addMethod(programFiniteStateMachineType, boilerStateMachineType, "Halt");
301
- addMethod(programFiniteStateMachineType, boilerStateMachineType, "Reset");
302
- addMethod(programFiniteStateMachineType, boilerStateMachineType, "Start");
303
- addMethod(programFiniteStateMachineType, boilerStateMachineType, "Suspend");
304
- addMethod(programFiniteStateMachineType, boilerStateMachineType, "Resume");
305
- // --------------------------------------------------------------------------------
306
- // BoilerType
307
- // --------------------------------------------------------------------------------
308
- const boilerType = namespace.addObjectType({
309
- browseName: "BoilerType",
310
- eventNotifier: 0x1
311
- });
312
- // BoilerType.CustomController (CustomControllerType)
313
- const customController = customControllerType.instantiate({
314
- browseName: "CustomController",
315
- componentOf: boilerType,
316
- modellingRule: "Mandatory"
317
- });
318
- // BoilerType.FlowController (FlowController)
319
- const flowController = flowControllerType.instantiate({
320
- browseName: "FlowController",
321
- componentOf: boilerType,
322
- modellingRule: "Mandatory"
323
- });
324
- // BoilerType.LevelController (LevelControllerType)
325
- const levelController = levelControllerType.instantiate({
326
- browseName: "LevelController",
327
- componentOf: boilerType,
328
- modellingRule: "Mandatory"
329
- });
330
- // BoilerType.LevelIndicator (BoilerInputPipeType)
331
- const inputPipe = boilerInputPipeType.instantiate({
332
- browseName: "InputPipe",
333
- componentOf: boilerType,
334
- modellingRule: "Mandatory",
335
- notifierOf: boilerType
336
- });
337
- // BoilerType.BoilerDrum (BoilerDrumType)
338
- const boilerDrum = boilerDrumType.instantiate({
339
- browseName: "BoilerDrum",
340
- componentOf: boilerType,
341
- modellingRule: "Mandatory",
342
- notifierOf: boilerType
343
- });
344
- // BoilerType.OutputPipe (BoilerOutputPipeType)
345
- const outputPipe = boilerOutputPipeType.instantiate({
346
- browseName: "OutputPipe",
347
- componentOf: boilerType,
348
- modellingRule: "Mandatory",
349
- notifierOf: boilerType
350
- });
351
- // BoilerType.Simulation (BoilerStateMachineType)
352
- const simulation = boilerStateMachineType.instantiate({
353
- browseName: "Simulation",
354
- componentOf: boilerType,
355
- eventSourceOf: boilerType,
356
- modellingRule: "Mandatory"
357
- });
358
- addRelation(inputPipe, flowTo, boilerDrum);
359
- addRelation(boilerDrum, hotFlowTo, outputPipe);
360
- (0, node_opcua_assert_1.assert)(boilerType.inputPipe.flowTransmitter);
361
- (0, node_opcua_assert_1.assert)(boilerType.inputPipe.flowTransmitter.output);
362
- (0, node_opcua_assert_1.assert)(boilerType.flowController.measurement);
363
- addRelation(boilerType.inputPipe.flowTransmitter.output, signalTo, boilerType.flowController.measurement);
364
- addRelation(boilerType.inputPipe.flowTransmitter.output, signalTo, boilerType.customController.input2);
365
- addRelation(boilerType.flowController.controlOut, signalTo, boilerType.inputPipe.valve.input);
366
- // indicates that the level controller gets its measurement from the drum's level indicator.
367
- addRelation(boilerType.boilerDrum.levelIndicator.output, signalTo, boilerType.levelController.measurement);
368
- addRelation(boilerType.outputPipe.flowTransmitter.output, signalTo, boilerType.customController.input3);
369
- addRelation(boilerType.levelController.controlOut, signalTo, boilerType.customController.input1);
370
- addRelation(boilerType.customController.controlOut, signalTo, boilerType.flowController.setPoint);
371
- return boilerType;
372
- }
373
- exports.createBoilerType = createBoilerType;
374
- function makeBoiler(addressSpace, options) {
375
- const namespace = addressSpace.getOwnNamespace();
376
- (0, node_opcua_assert_1.assert)(options);
377
- let boilerType;
378
- boilerType = namespace.findObjectType("BoilerType");
379
- // istanbul ignore next
380
- if (!boilerType) {
381
- createBoilerType(namespace);
382
- boilerType = namespace.findObjectType("BoilerType");
383
- }
384
- // now instantiate boiler
385
- const boiler1 = boilerType.instantiate({
386
- browseName: options.browseName,
387
- organizedBy: addressSpace.rootFolder.objects
388
- });
389
- (0, __1.promoteToStateMachine)(boiler1.simulation);
390
- const boilerStateMachine = boiler1.simulation;
391
- const readyState = boilerStateMachine.getStateByName("Ready");
392
- boilerStateMachine.setState(readyState);
393
- return boiler1;
394
- }
395
- exports.makeBoiler = makeBoiler;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.makeBoiler = exports.createBoilerType = void 0;
4
+ /* eslint-disable max-statements */
5
+ /**
6
+ * @module node-opcua-address-space
7
+ */
8
+ const node_opcua_assert_1 = require("node-opcua-assert");
9
+ const node_opcua_data_model_1 = require("node-opcua-data-model");
10
+ const node_opcua_status_code_1 = require("node-opcua-status-code");
11
+ const node_opcua_utils_1 = require("node-opcua-utils");
12
+ const __1 = require("..");
13
+ function MygetExecutableFlag(method, toState, methodName) {
14
+ const stateMachineW = (0, __1.promoteToStateMachine)(method.parent);
15
+ return stateMachineW.isValidTransition(toState);
16
+ }
17
+ function implementProgramStateMachine(programStateMachine) {
18
+ function installMethod(methodName, toState) {
19
+ let method = programStateMachine.getMethodByName(methodName);
20
+ if (!method) {
21
+ // 'method' has ModellingRule=OptionalPlaceholder and should be created from the type definition
22
+ let methodToClone = programStateMachine.typeDefinitionObj.getMethodByName(methodName);
23
+ if (!methodToClone) {
24
+ methodToClone = programStateMachine.typeDefinitionObj.subtypeOfObj.getMethodByName(methodName);
25
+ }
26
+ methodToClone.clone({
27
+ namespace: programStateMachine.namespace,
28
+ componentOf: programStateMachine
29
+ });
30
+ method = programStateMachine.getMethodByName(methodName);
31
+ (0, node_opcua_assert_1.assert)(method !== null, "Method clone should cause parent object to be extended");
32
+ }
33
+ (0, node_opcua_assert_1.assert)(method.nodeClass === node_opcua_data_model_1.NodeClass.Method);
34
+ method._getExecutableFlag = function ( /* sessionContext: SessionContext */) {
35
+ // must use a function here to capture 'this'
36
+ return MygetExecutableFlag(this, toState, methodName);
37
+ };
38
+ method.bindMethod(function (inputArguments, context, callback) {
39
+ const stateMachineW = this.parent;
40
+ stateMachineW.setState(toState);
41
+ callback(null, {
42
+ outputArguments: [],
43
+ statusCode: node_opcua_status_code_1.StatusCodes.Good
44
+ });
45
+ });
46
+ (0, node_opcua_assert_1.assert)(programStateMachine.getMethodByName(methodName) !== null, "Method " + methodName + " should be added to parent object (checked with getMethodByName)");
47
+ const lc_name = (0, node_opcua_utils_1.lowerFirstLetter)(methodName);
48
+ }
49
+ installMethod("Halt", "Halted");
50
+ installMethod("Reset", "Ready");
51
+ installMethod("Start", "Running");
52
+ installMethod("Suspend", "Suspended");
53
+ installMethod("Resume", "Running");
54
+ }
55
+ function addRelation(srcNode, referenceType, targetNode) {
56
+ (0, node_opcua_assert_1.assert)(srcNode, "expecting srcNode !== null");
57
+ (0, node_opcua_assert_1.assert)(targetNode, "expecting targetNode !== null");
58
+ if (typeof referenceType === "string") {
59
+ const nodes = srcNode.findReferencesAsObject(referenceType, true);
60
+ (0, node_opcua_assert_1.assert)(nodes.length === 1);
61
+ referenceType = nodes[0];
62
+ }
63
+ srcNode.addReference({ referenceType: referenceType.nodeId, nodeId: targetNode });
64
+ }
65
+ function createBoilerType(namespace) {
66
+ // istanbul ignore next
67
+ if (namespace.findObjectType("BoilerType")) {
68
+ console.warn("createBoilerType has already been called");
69
+ return namespace.findObjectType("BoilerType");
70
+ }
71
+ // --------------------------------------------------------
72
+ // referenceTypes
73
+ // --------------------------------------------------------
74
+ // create new reference Type FlowTo HotFlowTo & SignalTo
75
+ const flowTo = namespace.addReferenceType({
76
+ browseName: "FlowTo",
77
+ description: "a reference that indicates a flow between two objects",
78
+ inverseName: "FlowFrom",
79
+ subtypeOf: "NonHierarchicalReferences"
80
+ });
81
+ const hotFlowTo = namespace.addReferenceType({
82
+ browseName: "HotFlowTo",
83
+ description: "a reference that indicates a high temperature flow between two objects",
84
+ inverseName: "HotFlowFrom",
85
+ subtypeOf: flowTo
86
+ });
87
+ const signalTo = namespace.addReferenceType({
88
+ browseName: "SignalTo",
89
+ description: "a reference that indicates an electrical signal between two variables",
90
+ inverseName: "SignalFrom",
91
+ subtypeOf: "NonHierarchicalReferences"
92
+ });
93
+ const addressSpace = namespace.addressSpace;
94
+ flowTo.isSubtypeOf(addressSpace.findReferenceType("References"));
95
+ flowTo.isSubtypeOf(addressSpace.findReferenceType("NonHierarchicalReferences"));
96
+ hotFlowTo.isSubtypeOf(addressSpace.findReferenceType("References"));
97
+ hotFlowTo.isSubtypeOf(addressSpace.findReferenceType("NonHierarchicalReferences"));
98
+ hotFlowTo.isSubtypeOf(addressSpace.findReferenceType("FlowTo", namespace.index));
99
+ const NonHierarchicalReferences = addressSpace.findReferenceType("NonHierarchicalReferences");
100
+ // --------------------------------------------------------
101
+ // EventTypes
102
+ // --------------------------------------------------------
103
+ const boilerHaltedEventType = namespace.addEventType({
104
+ browseName: "BoilerHaltedEventType",
105
+ subtypeOf: "TransitionEventType"
106
+ });
107
+ // --------------------------------------------------------
108
+ // CustomControllerType
109
+ // --------------------------------------------------------
110
+ const customControllerType = namespace.addObjectType({
111
+ browseName: "CustomControllerType",
112
+ description: "a custom PID controller with 3 inputs"
113
+ });
114
+ const input1 = namespace.addVariable({
115
+ browseName: "Input1",
116
+ dataType: "Double",
117
+ description: "a reference that indicates an electrical signal between two variables",
118
+ modellingRule: "Mandatory",
119
+ propertyOf: customControllerType
120
+ });
121
+ const input2 = namespace.addVariable({
122
+ browseName: "Input2",
123
+ dataType: "Double",
124
+ modellingRule: "Mandatory",
125
+ propertyOf: customControllerType
126
+ });
127
+ const input3 = namespace.addVariable({
128
+ browseName: "Input3",
129
+ dataType: "Double",
130
+ modellingRule: "Mandatory",
131
+ propertyOf: customControllerType
132
+ });
133
+ const controlOut = namespace.addVariable({
134
+ browseName: "ControlOut",
135
+ dataType: "Double",
136
+ modellingRule: "Mandatory",
137
+ propertyOf: customControllerType
138
+ });
139
+ const description = namespace.addVariable({
140
+ browseName: "Description",
141
+ dataType: "LocalizedText",
142
+ modellingRule: "Mandatory",
143
+ propertyOf: customControllerType
144
+ });
145
+ // --------------------------------------------------------
146
+ // GenericSensorType
147
+ // --------------------------------------------------------
148
+ const genericSensorType = namespace.addObjectType({
149
+ browseName: "GenericSensorType"
150
+ });
151
+ namespace.addAnalogDataItem({
152
+ browseName: "Output",
153
+ componentOf: genericSensorType,
154
+ dataType: "Double",
155
+ engineeringUnitsRange: { low: -100, high: 200 },
156
+ modellingRule: "Mandatory"
157
+ });
158
+ genericSensorType.install_extra_properties();
159
+ genericSensorType.getComponentByName("Output");
160
+ (0, node_opcua_assert_1.assert)(genericSensorType.getComponentByName("Output").modellingRule === "Mandatory");
161
+ // --------------------------------------------------------
162
+ // GenericSensorType <---- GenericControllerType
163
+ // --------------------------------------------------------
164
+ const genericControllerType = namespace.addObjectType({
165
+ browseName: "GenericControllerType"
166
+ });
167
+ namespace.addVariable({
168
+ browseName: "ControlOut",
169
+ dataType: "Double",
170
+ modellingRule: "Mandatory",
171
+ propertyOf: genericControllerType
172
+ });
173
+ namespace.addVariable({
174
+ browseName: "Measurement",
175
+ dataType: "Double",
176
+ modellingRule: "Mandatory",
177
+ propertyOf: genericControllerType
178
+ });
179
+ namespace.addVariable({
180
+ browseName: "SetPoint",
181
+ dataType: "Double",
182
+ modellingRule: "Mandatory",
183
+ propertyOf: genericControllerType
184
+ });
185
+ // --------------------------------------------------------------------------------
186
+ // GenericSensorType <---- GenericControllerType <--- FlowControllerType
187
+ // --------------------------------------------------------------------------------
188
+ const flowControllerType = namespace.addObjectType({
189
+ browseName: "FlowControllerType",
190
+ subtypeOf: genericControllerType
191
+ });
192
+ // --------------------------------------------------------------------------------
193
+ // GenericSensorType <---- GenericControllerType <--- LevelControllerType
194
+ // --------------------------------------------------------------------------------
195
+ const levelControllerType = namespace.addObjectType({
196
+ browseName: "LevelControllerType",
197
+ subtypeOf: genericControllerType
198
+ });
199
+ // --------------------------------------------------------------------------------
200
+ // GenericSensorType <---- FlowTransmitterType
201
+ // --------------------------------------------------------------------------------
202
+ const flowTransmitterType = namespace.addObjectType({
203
+ browseName: "FlowTransmitterType",
204
+ subtypeOf: genericSensorType
205
+ });
206
+ // --------------------------------------------------------------------------------
207
+ // GenericSensorType <---- LevelIndicatorType
208
+ // --------------------------------------------------------------------------------
209
+ const levelIndicatorType = namespace.addObjectType({
210
+ browseName: "LevelIndicatorType",
211
+ subtypeOf: genericSensorType
212
+ });
213
+ // --------------------------------------------------------------------------------
214
+ // GenericActuatorType
215
+ // --------------------------------------------------------------------------------
216
+ const genericActuatorType = namespace.addObjectType({
217
+ browseName: "GenericActuatorType"
218
+ });
219
+ namespace.addAnalogDataItem({
220
+ browseName: "Input",
221
+ componentOf: genericActuatorType,
222
+ dataType: "Double",
223
+ engineeringUnitsRange: { low: -100, high: 200 },
224
+ modellingRule: "Mandatory"
225
+ });
226
+ // --------------------------------------------------------------------------------
227
+ // GenericActuatorType <---- ValveType
228
+ // --------------------------------------------------------------------------------
229
+ const valveType = namespace.addObjectType({
230
+ browseName: "ValveType",
231
+ subtypeOf: genericActuatorType
232
+ });
233
+ // --------------------------------------------------------------------------------
234
+ // FolderType <---- BoilerInputPipeType
235
+ // --------------------------------------------------------------------------------
236
+ const boilerInputPipeType = namespace.addObjectType({
237
+ browseName: "BoilerInputPipeType",
238
+ subtypeOf: "FolderType"
239
+ });
240
+ const ftx1 = flowTransmitterType.instantiate({
241
+ browseName: "FlowTransmitter",
242
+ componentOf: boilerInputPipeType,
243
+ modellingRule: "Mandatory",
244
+ notifierOf: boilerInputPipeType
245
+ });
246
+ (0, node_opcua_assert_1.assert)(ftx1.output.browseName.toString() === `${namespace.index}:Output`);
247
+ const valve1 = valveType.instantiate({
248
+ browseName: "Valve",
249
+ componentOf: boilerInputPipeType,
250
+ modellingRule: "Mandatory"
251
+ });
252
+ // --------------------------------------------------------------------------------
253
+ // FolderType <---- BoilerOutputPipeType
254
+ // --------------------------------------------------------------------------------
255
+ const boilerOutputPipeType = namespace.addObjectType({
256
+ browseName: "BoilerOutputPipeType",
257
+ subtypeOf: "FolderType"
258
+ });
259
+ const ftx2 = flowTransmitterType.instantiate({
260
+ browseName: "FlowTransmitter",
261
+ componentOf: boilerOutputPipeType,
262
+ modellingRule: "Mandatory",
263
+ notifierOf: boilerOutputPipeType
264
+ });
265
+ ftx2.getComponentByName("Output").browseName.toString();
266
+ // --------------------------------)------------------------------------------------
267
+ // FolderType <---- BoilerDrumType
268
+ // --------------------------------------------------------------------------------
269
+ const boilerDrumType = namespace.addObjectType({
270
+ browseName: "BoilerDrumType",
271
+ subtypeOf: "FolderType"
272
+ });
273
+ const levelIndicator = levelIndicatorType.instantiate({
274
+ browseName: "LevelIndicator",
275
+ componentOf: boilerDrumType,
276
+ modellingRule: "Mandatory",
277
+ notifierOf: boilerDrumType
278
+ });
279
+ const programFiniteStateMachineType = addressSpace.findObjectType("ProgramStateMachineType");
280
+ // --------------------------------------------------------
281
+ // define boiler State Machine
282
+ // --------------------------------------------------------
283
+ const boilerStateMachineType = namespace.addObjectType({
284
+ browseName: "BoilerStateMachineType",
285
+ postInstantiateFunc: implementProgramStateMachine,
286
+ subtypeOf: programFiniteStateMachineType
287
+ });
288
+ // programStateMachineType has Optional placeHolder for method "Halt", "Reset","Start","Suspend","Resume")
289
+ function addMethod(baseType, objectType, methodName) {
290
+ (0, node_opcua_assert_1.assert)(!objectType.getMethodByName(methodName));
291
+ const method = baseType.getMethodByName(methodName);
292
+ const m = method.clone({
293
+ namespace,
294
+ componentOf: objectType,
295
+ modellingRule: "Mandatory"
296
+ });
297
+ (0, node_opcua_assert_1.assert)(objectType.getMethodByName(methodName));
298
+ (0, node_opcua_assert_1.assert)(objectType.getMethodByName(methodName).modellingRule === "Mandatory");
299
+ }
300
+ addMethod(programFiniteStateMachineType, boilerStateMachineType, "Halt");
301
+ addMethod(programFiniteStateMachineType, boilerStateMachineType, "Reset");
302
+ addMethod(programFiniteStateMachineType, boilerStateMachineType, "Start");
303
+ addMethod(programFiniteStateMachineType, boilerStateMachineType, "Suspend");
304
+ addMethod(programFiniteStateMachineType, boilerStateMachineType, "Resume");
305
+ // --------------------------------------------------------------------------------
306
+ // BoilerType
307
+ // --------------------------------------------------------------------------------
308
+ const boilerType = namespace.addObjectType({
309
+ browseName: "BoilerType",
310
+ eventNotifier: 0x1
311
+ });
312
+ // BoilerType.CustomController (CustomControllerType)
313
+ const customController = customControllerType.instantiate({
314
+ browseName: "CustomController",
315
+ componentOf: boilerType,
316
+ modellingRule: "Mandatory"
317
+ });
318
+ // BoilerType.FlowController (FlowController)
319
+ const flowController = flowControllerType.instantiate({
320
+ browseName: "FlowController",
321
+ componentOf: boilerType,
322
+ modellingRule: "Mandatory"
323
+ });
324
+ // BoilerType.LevelController (LevelControllerType)
325
+ const levelController = levelControllerType.instantiate({
326
+ browseName: "LevelController",
327
+ componentOf: boilerType,
328
+ modellingRule: "Mandatory"
329
+ });
330
+ // BoilerType.LevelIndicator (BoilerInputPipeType)
331
+ const inputPipe = boilerInputPipeType.instantiate({
332
+ browseName: "InputPipe",
333
+ componentOf: boilerType,
334
+ modellingRule: "Mandatory",
335
+ notifierOf: boilerType
336
+ });
337
+ // BoilerType.BoilerDrum (BoilerDrumType)
338
+ const boilerDrum = boilerDrumType.instantiate({
339
+ browseName: "BoilerDrum",
340
+ componentOf: boilerType,
341
+ modellingRule: "Mandatory",
342
+ notifierOf: boilerType
343
+ });
344
+ // BoilerType.OutputPipe (BoilerOutputPipeType)
345
+ const outputPipe = boilerOutputPipeType.instantiate({
346
+ browseName: "OutputPipe",
347
+ componentOf: boilerType,
348
+ modellingRule: "Mandatory",
349
+ notifierOf: boilerType
350
+ });
351
+ // BoilerType.Simulation (BoilerStateMachineType)
352
+ const simulation = boilerStateMachineType.instantiate({
353
+ browseName: "Simulation",
354
+ componentOf: boilerType,
355
+ eventSourceOf: boilerType,
356
+ modellingRule: "Mandatory"
357
+ });
358
+ addRelation(inputPipe, flowTo, boilerDrum);
359
+ addRelation(boilerDrum, hotFlowTo, outputPipe);
360
+ (0, node_opcua_assert_1.assert)(boilerType.inputPipe.flowTransmitter);
361
+ (0, node_opcua_assert_1.assert)(boilerType.inputPipe.flowTransmitter.output);
362
+ (0, node_opcua_assert_1.assert)(boilerType.flowController.measurement);
363
+ addRelation(boilerType.inputPipe.flowTransmitter.output, signalTo, boilerType.flowController.measurement);
364
+ addRelation(boilerType.inputPipe.flowTransmitter.output, signalTo, boilerType.customController.input2);
365
+ addRelation(boilerType.flowController.controlOut, signalTo, boilerType.inputPipe.valve.input);
366
+ // indicates that the level controller gets its measurement from the drum's level indicator.
367
+ addRelation(boilerType.boilerDrum.levelIndicator.output, signalTo, boilerType.levelController.measurement);
368
+ addRelation(boilerType.outputPipe.flowTransmitter.output, signalTo, boilerType.customController.input3);
369
+ addRelation(boilerType.levelController.controlOut, signalTo, boilerType.customController.input1);
370
+ addRelation(boilerType.customController.controlOut, signalTo, boilerType.flowController.setPoint);
371
+ return boilerType;
372
+ }
373
+ exports.createBoilerType = createBoilerType;
374
+ function makeBoiler(addressSpace, options) {
375
+ const namespace = addressSpace.getOwnNamespace();
376
+ (0, node_opcua_assert_1.assert)(options);
377
+ let boilerType;
378
+ boilerType = namespace.findObjectType("BoilerType");
379
+ // istanbul ignore next
380
+ if (!boilerType) {
381
+ createBoilerType(namespace);
382
+ boilerType = namespace.findObjectType("BoilerType");
383
+ }
384
+ // now instantiate boiler
385
+ const boiler1 = boilerType.instantiate({
386
+ browseName: options.browseName,
387
+ organizedBy: addressSpace.rootFolder.objects
388
+ });
389
+ (0, __1.promoteToStateMachine)(boiler1.simulation);
390
+ const boilerStateMachine = boiler1.simulation;
391
+ const readyState = boilerStateMachine.getStateByName("Ready");
392
+ boilerStateMachine.setState(readyState);
393
+ return boiler1;
394
+ }
395
+ exports.makeBoiler = makeBoiler;
396
396
  //# sourceMappingURL=boiler_system.js.map