node-opcua-address-space 2.76.0 → 2.77.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 (291) hide show
  1. package/dist/source/address_space_ts.d.ts +118 -118
  2. package/dist/source/address_space_ts.js +17 -17
  3. package/dist/source/continuation_points/continuation_point_manager.d.ts +32 -32
  4. package/dist/source/continuation_points/continuation_point_manager.js +195 -195
  5. package/dist/source/helpers/adjust_browse_direction.d.ts +5 -5
  6. package/dist/source/helpers/adjust_browse_direction.js +11 -11
  7. package/dist/source/helpers/argument_list.d.ts +33 -33
  8. package/dist/source/helpers/argument_list.js +258 -258
  9. package/dist/source/helpers/call_helpers.d.ts +6 -6
  10. package/dist/source/helpers/call_helpers.js +70 -70
  11. package/dist/source/helpers/check_event_clause.d.ts +17 -0
  12. package/dist/source/helpers/check_event_clause.js +53 -0
  13. package/dist/source/helpers/check_event_clause.js.map +1 -0
  14. package/dist/source/helpers/coerce_enum_value.d.ts +6 -6
  15. package/dist/source/helpers/coerce_enum_value.js +33 -33
  16. package/dist/source/helpers/dump_tools.d.ts +14 -14
  17. package/dist/source/helpers/dump_tools.js +78 -78
  18. package/dist/source/helpers/ensure_secure_access.d.ts +9 -9
  19. package/dist/source/helpers/ensure_secure_access.js +76 -76
  20. package/dist/source/helpers/make_optionals_map.d.ts +21 -21
  21. package/dist/source/helpers/make_optionals_map.js +29 -29
  22. package/dist/source/helpers/multiform_func.d.ts +11 -11
  23. package/dist/source/helpers/multiform_func.js +75 -75
  24. package/dist/source/helpers/resolve_opaque_on_address_space.d.ts +3 -3
  25. package/dist/source/helpers/resolve_opaque_on_address_space.js +36 -36
  26. package/dist/source/index.d.ts +56 -56
  27. package/dist/source/index.js +83 -83
  28. package/dist/source/interfaces/alarms_and_conditions/condition_info_i.d.ts +19 -19
  29. package/dist/source/interfaces/alarms_and_conditions/condition_info_i.js +2 -2
  30. package/dist/source/interfaces/alarms_and_conditions/condition_snapshot.d.ts +193 -193
  31. package/dist/source/interfaces/alarms_and_conditions/condition_snapshot.js +2 -2
  32. package/dist/source/interfaces/alarms_and_conditions/deviation_stuff.d.ts +12 -12
  33. package/dist/source/interfaces/alarms_and_conditions/deviation_stuff.js +2 -2
  34. package/dist/source/interfaces/alarms_and_conditions/install_setpoint_options.d.ts +10 -10
  35. package/dist/source/interfaces/alarms_and_conditions/install_setpoint_options.js +2 -2
  36. package/dist/source/interfaces/alarms_and_conditions/instantiate_alarm_condition_options.d.ts +7 -7
  37. package/dist/source/interfaces/alarms_and_conditions/instantiate_alarm_condition_options.js +2 -2
  38. package/dist/source/interfaces/alarms_and_conditions/instantiate_condition_options.d.ts +7 -7
  39. package/dist/source/interfaces/alarms_and_conditions/instantiate_condition_options.js +2 -2
  40. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_deviation_alarm_options.d.ts +4 -4
  41. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_deviation_alarm_options.js +2 -2
  42. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_limit_alarm_options.d.ts +4 -4
  43. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_limit_alarm_options.js +2 -2
  44. package/dist/source/interfaces/alarms_and_conditions/instantiate_limit_alarm_options.d.ts +9 -9
  45. package/dist/source/interfaces/alarms_and_conditions/instantiate_limit_alarm_options.js +2 -2
  46. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_deviation_alarm_options.d.ts +4 -4
  47. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_deviation_alarm_options.js +2 -2
  48. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_limit_alarm_options.d.ts +4 -4
  49. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_limit_alarm_options.js +2 -2
  50. package/dist/source/interfaces/alarms_and_conditions/instantiate_off_normal_alarm_options.d.ts +20 -20
  51. package/dist/source/interfaces/alarms_and_conditions/instantiate_off_normal_alarm_options.js +2 -2
  52. package/dist/source/interfaces/alarms_and_conditions/ua_acknowledgeable_condition_ex.d.ts +23 -23
  53. package/dist/source/interfaces/alarms_and_conditions/ua_acknowledgeable_condition_ex.js +2 -2
  54. package/dist/source/interfaces/alarms_and_conditions/ua_alarm_condition_ex.d.ts +32 -32
  55. package/dist/source/interfaces/alarms_and_conditions/ua_alarm_condition_ex.js +2 -2
  56. package/dist/source/interfaces/alarms_and_conditions/ua_certificate_expiration_alarm_ex.d.ts +19 -19
  57. package/dist/source/interfaces/alarms_and_conditions/ua_certificate_expiration_alarm_ex.js +2 -2
  58. package/dist/source/interfaces/alarms_and_conditions/ua_condition_ex.d.ts +42 -42
  59. package/dist/source/interfaces/alarms_and_conditions/ua_condition_ex.js +2 -2
  60. package/dist/source/interfaces/alarms_and_conditions/ua_discrete_alarm_ex.d.ts +7 -7
  61. package/dist/source/interfaces/alarms_and_conditions/ua_discrete_alarm_ex.js +25 -25
  62. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_deviation_alarm_ex.d.ts +5 -5
  63. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_deviation_alarm_ex.js +2 -2
  64. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_limit_alarm_ex.d.ts +20 -20
  65. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_limit_alarm_ex.js +2 -2
  66. package/dist/source/interfaces/alarms_and_conditions/ua_limit_alarm_ex.d.ts +26 -26
  67. package/dist/source/interfaces/alarms_and_conditions/ua_limit_alarm_ex.js +2 -2
  68. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_deviation_alarm_ex.d.ts +8 -8
  69. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_deviation_alarm_ex.js +2 -2
  70. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_limit_alarm_ex.d.ts +10 -10
  71. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_limit_alarm_ex.js +2 -2
  72. package/dist/source/interfaces/data_access/ua_multistate_discrete_ex.d.ts +21 -21
  73. package/dist/source/interfaces/data_access/ua_multistate_discrete_ex.js +2 -2
  74. package/dist/source/interfaces/data_access/ua_multistate_value_discrete_ex.d.ts +24 -24
  75. package/dist/source/interfaces/data_access/ua_multistate_value_discrete_ex.js +2 -2
  76. package/dist/source/interfaces/data_access/ua_two_state_discrete_ex.d.ts +12 -12
  77. package/dist/source/interfaces/data_access/ua_two_state_discrete_ex.js +2 -2
  78. package/dist/source/interfaces/data_access/ua_y_array_item_ex.d.ts +8 -8
  79. package/dist/source/interfaces/data_access/ua_y_array_item_ex.js +2 -2
  80. package/dist/source/interfaces/state_machine/ua_exclusive_limit_state_machine_type_ex.d.ts +12 -12
  81. package/dist/source/interfaces/state_machine/ua_exclusive_limit_state_machine_type_ex.js +2 -2
  82. package/dist/source/interfaces/state_machine/ua_finite_state_machine_type.d.ts +49 -49
  83. package/dist/source/interfaces/state_machine/ua_finite_state_machine_type.js +2 -2
  84. package/dist/source/interfaces/state_machine/ua_program_state_machine_type.d.ts +11 -11
  85. package/dist/source/interfaces/state_machine/ua_program_state_machine_type.js +2 -2
  86. package/dist/source/interfaces/state_machine/ua_shelved_state_machine_ex.d.ts +30 -30
  87. package/dist/source/interfaces/state_machine/ua_shelved_state_machine_ex.js +2 -2
  88. package/dist/source/interfaces/state_machine/ua_state_machine_type.d.ts +222 -222
  89. package/dist/source/interfaces/state_machine/ua_state_machine_type.js +2 -2
  90. package/dist/source/interfaces/state_machine/ua_transition_ex.d.ts +6 -6
  91. package/dist/source/interfaces/state_machine/ua_transition_ex.js +2 -2
  92. package/dist/source/interfaces/ua_subscription_diagnostics_variable_ex.d.ts +8 -8
  93. package/dist/source/interfaces/ua_subscription_diagnostics_variable_ex.js +2 -2
  94. package/dist/source/loader/decode_xml_extension_object.d.ts +6 -6
  95. package/dist/source/loader/decode_xml_extension_object.js +71 -71
  96. package/dist/source/loader/ensure_datatype_extracted.d.ts +5 -5
  97. package/dist/source/loader/ensure_datatype_extracted.js +45 -45
  98. package/dist/source/loader/generateAddressSpaceRaw.d.ts +10 -10
  99. package/dist/source/loader/generateAddressSpaceRaw.js +45 -45
  100. package/dist/source/loader/load_nodeset2.d.ts +16 -16
  101. package/dist/source/loader/load_nodeset2.js +1461 -1461
  102. package/dist/source/loader/make_semver_compatible.d.ts +6 -6
  103. package/dist/source/loader/make_semver_compatible.js +25 -25
  104. package/dist/source/loader/make_xml_extension_object_parser.d.ts +28 -28
  105. package/dist/source/loader/make_xml_extension_object_parser.js +325 -325
  106. package/dist/source/loader/namespace_post_step.d.ts +10 -10
  107. package/dist/source/loader/namespace_post_step.js +61 -61
  108. package/dist/source/loader/register_node_promoter.d.ts +2 -2
  109. package/dist/source/loader/register_node_promoter.js +9 -9
  110. package/dist/source/namespace.d.ts +6 -6
  111. package/dist/source/namespace.js +2 -2
  112. package/dist/source/namespace_alarm_and_condition.d.ts +32 -32
  113. package/dist/source/namespace_alarm_and_condition.js +2 -2
  114. package/dist/source/namespace_data_access.d.ts +42 -42
  115. package/dist/source/namespace_data_access.js +2 -2
  116. package/dist/source/namespace_machine_state.d.ts +7 -7
  117. package/dist/source/namespace_machine_state.js +2 -2
  118. package/dist/source/pseudo_session.d.ts +55 -55
  119. package/dist/source/pseudo_session.js +203 -203
  120. package/dist/source/session_context.d.ts +111 -111
  121. package/dist/source/session_context.js +265 -265
  122. package/dist/source/set_namespace_meta_data.d.ts +2 -2
  123. package/dist/source/set_namespace_meta_data.js +59 -59
  124. package/dist/source/ua_root_folder.d.ts +9 -9
  125. package/dist/source/ua_root_folder.js +2 -2
  126. package/dist/source/ua_two_state_variable_ex.d.ts +23 -23
  127. package/dist/source/ua_two_state_variable_ex.js +2 -2
  128. package/dist/source/xml_writer.d.ts +9 -9
  129. package/dist/source/xml_writer.js +2 -2
  130. package/dist/src/address_space.d.ts +392 -392
  131. package/dist/src/address_space.js +1392 -1392
  132. package/dist/src/address_space_change_event_tools.d.ts +6 -6
  133. package/dist/src/address_space_change_event_tools.js +149 -149
  134. package/dist/src/address_space_private.d.ts +43 -43
  135. package/dist/src/address_space_private.js +2 -2
  136. package/dist/src/alarms_and_conditions/check_where_clause.d.ts +4 -0
  137. package/dist/src/alarms_and_conditions/check_where_clause.js +110 -0
  138. package/dist/src/alarms_and_conditions/check_where_clause.js.map +1 -0
  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.d.ts +27 -0
  142. package/dist/src/alarms_and_conditions/condition_info.js +55 -0
  143. package/dist/src/alarms_and_conditions/condition_info.js.map +1 -0
  144. package/dist/src/alarms_and_conditions/condition_info_impl.d.ts +26 -26
  145. package/dist/src/alarms_and_conditions/condition_info_impl.js +54 -54
  146. package/dist/src/alarms_and_conditions/condition_snapshot.d.ts +233 -0
  147. package/dist/src/alarms_and_conditions/condition_snapshot.js +667 -0
  148. package/dist/src/alarms_and_conditions/condition_snapshot.js.map +1 -0
  149. package/dist/src/alarms_and_conditions/condition_snapshot_impl.d.ts +222 -222
  150. package/dist/src/alarms_and_conditions/condition_snapshot_impl.js +657 -657
  151. package/dist/src/alarms_and_conditions/deviation_alarm_helper.d.ts +9 -9
  152. package/dist/src/alarms_and_conditions/deviation_alarm_helper.js +61 -61
  153. package/dist/src/alarms_and_conditions/extract_event_fields.d.ts +10 -0
  154. package/dist/src/alarms_and_conditions/extract_event_fields.js +90 -0
  155. package/dist/src/alarms_and_conditions/extract_event_fields.js.map +1 -0
  156. package/dist/src/alarms_and_conditions/index.d.ts +16 -16
  157. package/dist/src/alarms_and_conditions/index.js +32 -32
  158. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_impl.d.ts +44 -44
  159. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_impl.js +244 -244
  160. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.d.ts +93 -93
  161. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.js +419 -419
  162. package/dist/src/alarms_and_conditions/ua_base_event_impl.d.ts +26 -26
  163. package/dist/src/alarms_and_conditions/ua_base_event_impl.js +38 -38
  164. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.d.ts +44 -44
  165. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.js +183 -183
  166. package/dist/src/alarms_and_conditions/ua_condition_impl.d.ts +153 -153
  167. package/dist/src/alarms_and_conditions/ua_condition_impl.js +1028 -1028
  168. package/dist/src/alarms_and_conditions/ua_discrete_alarm_impl.d.ts +14 -14
  169. package/dist/src/alarms_and_conditions/ua_discrete_alarm_impl.js +34 -34
  170. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.d.ts +24 -24
  171. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.js +56 -56
  172. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm_impl.d.ts +11 -11
  173. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm_impl.js +11 -11
  174. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.d.ts +23 -23
  175. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.js +86 -86
  176. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm_impl.d.ts +11 -11
  177. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm_impl.js +7 -7
  178. package/dist/src/alarms_and_conditions/ua_limit_alarm_impl.d.ts +79 -79
  179. package/dist/src/alarms_and_conditions/ua_limit_alarm_impl.js +250 -250
  180. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.d.ts +24 -24
  181. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.js +50 -50
  182. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.d.ts +19 -19
  183. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.js +162 -162
  184. package/dist/src/alarms_and_conditions/ua_off_normal_alarm_impl.d.ts +46 -46
  185. package/dist/src/alarms_and_conditions/ua_off_normal_alarm_impl.js +166 -166
  186. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.d.ts +18 -18
  187. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.js +17 -17
  188. package/dist/src/apply_condition_refresh.d.ts +6 -6
  189. package/dist/src/apply_condition_refresh.js +27 -27
  190. package/dist/src/base_node_impl.d.ts +281 -281
  191. package/dist/src/base_node_impl.js +1395 -1395
  192. package/dist/src/base_node_private.d.ts +61 -61
  193. package/dist/src/base_node_private.js +705 -705
  194. package/dist/src/data_access/add_dataItem_stuff.d.ts +11 -11
  195. package/dist/src/data_access/add_dataItem_stuff.js +61 -61
  196. package/dist/src/data_access/check_variant_compatibility_ua_analog_item.d.ts +1 -1
  197. package/dist/src/data_access/check_variant_compatibility_ua_analog_item.js +34 -34
  198. package/dist/src/data_access/ua_multistate_discrete_impl.d.ts +32 -32
  199. package/dist/src/data_access/ua_multistate_discrete_impl.js +130 -130
  200. package/dist/src/data_access/ua_multistate_value_discrete.d.ts +51 -0
  201. package/dist/src/data_access/ua_multistate_value_discrete.js +250 -0
  202. package/dist/src/data_access/ua_multistate_value_discrete.js.map +1 -0
  203. package/dist/src/data_access/ua_multistate_value_discrete_impl.d.ts +51 -51
  204. package/dist/src/data_access/ua_multistate_value_discrete_impl.js +249 -249
  205. package/dist/src/data_access/ua_two_state_discrete.d.ts +25 -0
  206. package/dist/src/data_access/ua_two_state_discrete.js +154 -0
  207. package/dist/src/data_access/ua_two_state_discrete.js.map +1 -0
  208. package/dist/src/data_access/ua_two_state_discrete_impl.d.ts +25 -25
  209. package/dist/src/data_access/ua_two_state_discrete_impl.js +153 -153
  210. package/dist/src/event_data.d.ts +34 -34
  211. package/dist/src/event_data.js +64 -64
  212. package/dist/src/extension_object_array_node.d.ts +61 -61
  213. package/dist/src/extension_object_array_node.js +276 -276
  214. package/dist/src/historical_access/address_space_historical_data_node.d.ts +26 -26
  215. package/dist/src/historical_access/address_space_historical_data_node.js +630 -630
  216. package/dist/src/index_current.d.ts +43 -43
  217. package/dist/src/index_current.js +74 -74
  218. package/dist/src/namespace_impl.d.ts +461 -461
  219. package/dist/src/namespace_impl.js +1732 -1732
  220. package/dist/src/namespace_private.d.ts +21 -21
  221. package/dist/src/namespace_private.js +32 -32
  222. package/dist/src/nodeid_manager.d.ts +36 -36
  223. package/dist/src/nodeid_manager.js +197 -197
  224. package/dist/src/nodeset_tools/adjust_namespace_array.d.ts +2 -2
  225. package/dist/src/nodeset_tools/adjust_namespace_array.js +13 -13
  226. package/dist/src/nodeset_tools/construct_namespace_dependency.d.ts +2 -2
  227. package/dist/src/nodeset_tools/construct_namespace_dependency.js +83 -83
  228. package/dist/src/nodeset_tools/nodeset_to_xml.d.ts +2 -2
  229. package/dist/src/nodeset_tools/nodeset_to_xml.js +1155 -1155
  230. package/dist/src/nodeset_tools/typedictionary_to_xml.d.ts +2 -2
  231. package/dist/src/nodeset_tools/typedictionary_to_xml.js +154 -154
  232. package/dist/src/reference_impl.d.ts +43 -43
  233. package/dist/src/reference_impl.js +139 -139
  234. package/dist/src/role_permissions.d.ts +2 -2
  235. package/dist/src/role_permissions.js +10 -10
  236. package/dist/src/state_machine/finite_state_machine.d.ts +67 -67
  237. package/dist/src/state_machine/finite_state_machine.js +353 -353
  238. package/dist/src/state_machine/ua_shelving_state_machine_ex.d.ts +38 -38
  239. package/dist/src/state_machine/ua_shelving_state_machine_ex.js +250 -250
  240. package/dist/src/state_machine/ua_two_state_variable.d.ts +61 -61
  241. package/dist/src/state_machine/ua_two_state_variable.js +331 -331
  242. package/dist/src/tool_isSupertypeOf.d.ts +17 -17
  243. package/dist/src/tool_isSupertypeOf.js +108 -108
  244. package/dist/src/ua_condition_type.d.ts +8 -8
  245. package/dist/src/ua_condition_type.js +2 -2
  246. package/dist/src/ua_data_type_impl.d.ts +93 -93
  247. package/dist/src/ua_data_type_impl.js +371 -371
  248. package/dist/src/ua_method_impl.d.ts +41 -41
  249. package/dist/src/ua_method_impl.js +208 -208
  250. package/dist/src/ua_object_impl.d.ts +35 -35
  251. package/dist/src/ua_object_impl.js +161 -161
  252. package/dist/src/ua_object_type_impl.d.ts +48 -48
  253. package/dist/src/ua_object_type_impl.js +124 -124
  254. package/dist/src/ua_reference_type_impl.d.ts +43 -43
  255. package/dist/src/ua_reference_type_impl.js +139 -139
  256. package/dist/src/ua_variable_impl.d.ts +351 -351
  257. package/dist/src/ua_variable_impl.js +1604 -1604
  258. package/dist/src/ua_variable_impl.js.map +1 -1
  259. package/dist/src/ua_variable_impl_ext_obj.d.ts +17 -17
  260. package/dist/src/ua_variable_impl_ext_obj.js +437 -437
  261. package/dist/src/ua_variable_type_impl.d.ts +62 -62
  262. package/dist/src/ua_variable_type_impl.js +570 -570
  263. package/dist/src/ua_view_impl.d.ts +19 -19
  264. package/dist/src/ua_view_impl.js +43 -43
  265. package/distHelpers/add_event_generator_object.d.ts +3 -3
  266. package/distHelpers/add_event_generator_object.js +64 -64
  267. package/distHelpers/alarms_and_conditions_demo.d.ts +9 -9
  268. package/distHelpers/alarms_and_conditions_demo.js +115 -115
  269. package/distHelpers/assertHasMatchingReference.d.ts +19 -19
  270. package/distHelpers/assertHasMatchingReference.js +40 -40
  271. package/distHelpers/boiler_system.d.ts +113 -113
  272. package/distHelpers/boiler_system.js +395 -395
  273. package/distHelpers/create_minimalist_address_space_nodeset.d.ts +5 -5
  274. package/distHelpers/create_minimalist_address_space_nodeset.js +171 -171
  275. package/distHelpers/date_utils.d.ts +3 -3
  276. package/distHelpers/date_utils.js +9 -9
  277. package/distHelpers/dump_statemachine.js +127 -127
  278. package/distHelpers/get_address_space_fixture.d.ts +1 -1
  279. package/distHelpers/get_address_space_fixture.js +30 -30
  280. package/distHelpers/get_mini_address_space.d.ts +7 -7
  281. package/distHelpers/get_mini_address_space.js +36 -36
  282. package/distHelpers/index.d.ts +12 -12
  283. package/distHelpers/index.js +28 -28
  284. package/distHelpers/mock_session.d.ts +14 -14
  285. package/distHelpers/mock_session.js +25 -25
  286. package/distNodeJS/generate_address_space.d.ts +4 -4
  287. package/distNodeJS/generate_address_space.js +41 -41
  288. package/distNodeJS/index.d.ts +1 -1
  289. package/distNodeJS/index.js +17 -17
  290. package/package.json +42 -40
  291. package/src/ua_variable_impl.ts +3 -2
@@ -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.isSupertypeOf(addressSpace.findReferenceType("References"));
95
- flowTo.isSupertypeOf(addressSpace.findReferenceType("NonHierarchicalReferences"));
96
- hotFlowTo.isSupertypeOf(addressSpace.findReferenceType("References"));
97
- hotFlowTo.isSupertypeOf(addressSpace.findReferenceType("NonHierarchicalReferences"));
98
- hotFlowTo.isSupertypeOf(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.isSupertypeOf(addressSpace.findReferenceType("References"));
95
+ flowTo.isSupertypeOf(addressSpace.findReferenceType("NonHierarchicalReferences"));
96
+ hotFlowTo.isSupertypeOf(addressSpace.findReferenceType("References"));
97
+ hotFlowTo.isSupertypeOf(addressSpace.findReferenceType("NonHierarchicalReferences"));
98
+ hotFlowTo.isSupertypeOf(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