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