node-opcua-address-space 2.74.0 → 2.76.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (361) 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 -257
  9. package/dist/source/helpers/argument_list.js.map +1 -1
  10. package/dist/source/helpers/call_helpers.d.ts +6 -6
  11. package/dist/source/helpers/call_helpers.js +70 -70
  12. package/dist/source/helpers/coerce_enum_value.d.ts +6 -6
  13. package/dist/source/helpers/coerce_enum_value.js +33 -33
  14. package/dist/source/helpers/dump_tools.d.ts +14 -14
  15. package/dist/source/helpers/dump_tools.js +78 -78
  16. package/dist/source/helpers/ensure_secure_access.d.ts +9 -9
  17. package/dist/source/helpers/ensure_secure_access.js +76 -76
  18. package/dist/source/helpers/make_optionals_map.d.ts +21 -21
  19. package/dist/source/helpers/make_optionals_map.js +29 -29
  20. package/dist/source/helpers/multiform_func.d.ts +11 -11
  21. package/dist/source/helpers/multiform_func.js +75 -73
  22. package/dist/source/helpers/multiform_func.js.map +1 -1
  23. package/dist/source/helpers/resolve_opaque_on_address_space.d.ts +3 -3
  24. package/dist/source/helpers/resolve_opaque_on_address_space.js +36 -36
  25. package/dist/source/index.d.ts +56 -58
  26. package/dist/source/index.js +83 -87
  27. package/dist/source/index.js.map +1 -1
  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 -199
  31. package/dist/source/interfaces/alarms_and_conditions/condition_snapshot.js +2 -9
  32. package/dist/source/interfaces/alarms_and_conditions/condition_snapshot.js.map +1 -1
  33. package/dist/source/interfaces/alarms_and_conditions/deviation_stuff.d.ts +12 -14
  34. package/dist/source/interfaces/alarms_and_conditions/deviation_stuff.js +2 -2
  35. package/dist/source/interfaces/alarms_and_conditions/install_setpoint_options.d.ts +10 -6
  36. package/dist/source/interfaces/alarms_and_conditions/install_setpoint_options.js +2 -2
  37. package/dist/source/interfaces/alarms_and_conditions/instantiate_alarm_condition_options.d.ts +7 -7
  38. package/dist/source/interfaces/alarms_and_conditions/instantiate_alarm_condition_options.js +2 -2
  39. package/dist/source/interfaces/alarms_and_conditions/instantiate_condition_options.d.ts +7 -7
  40. package/dist/source/interfaces/alarms_and_conditions/instantiate_condition_options.js +2 -2
  41. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_deviation_alarm_options.d.ts +4 -0
  42. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_deviation_alarm_options.js +3 -0
  43. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_deviation_alarm_options.js.map +1 -0
  44. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_limit_alarm_options.d.ts +4 -4
  45. package/dist/source/interfaces/alarms_and_conditions/instantiate_exclusive_limit_alarm_options.js +2 -2
  46. package/dist/source/interfaces/alarms_and_conditions/instantiate_limit_alarm_options.d.ts +9 -9
  47. package/dist/source/interfaces/alarms_and_conditions/instantiate_limit_alarm_options.js +2 -2
  48. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_deviation_alarm_options.d.ts +4 -0
  49. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_deviation_alarm_options.js +3 -0
  50. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_deviation_alarm_options.js.map +1 -0
  51. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_limit_alarm_options.d.ts +4 -0
  52. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_limit_alarm_options.js +3 -0
  53. package/dist/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_limit_alarm_options.js.map +1 -0
  54. package/dist/source/interfaces/alarms_and_conditions/instantiate_off_normal_alarm_options.d.ts +20 -5
  55. package/dist/source/interfaces/alarms_and_conditions/instantiate_off_normal_alarm_options.js +2 -2
  56. package/dist/source/interfaces/alarms_and_conditions/ua_acknowledgeable_condition_ex.d.ts +23 -23
  57. package/dist/source/interfaces/alarms_and_conditions/ua_acknowledgeable_condition_ex.js +2 -2
  58. package/dist/source/interfaces/alarms_and_conditions/ua_alarm_condition_ex.d.ts +32 -32
  59. package/dist/source/interfaces/alarms_and_conditions/ua_alarm_condition_ex.js +2 -2
  60. package/dist/source/interfaces/alarms_and_conditions/ua_certificate_expiration_alarm_ex.d.ts +19 -15
  61. package/dist/source/interfaces/alarms_and_conditions/ua_certificate_expiration_alarm_ex.js +2 -2
  62. package/dist/source/interfaces/alarms_and_conditions/ua_condition_ex.d.ts +42 -42
  63. package/dist/source/interfaces/alarms_and_conditions/ua_condition_ex.js +2 -2
  64. package/dist/source/interfaces/alarms_and_conditions/ua_discrete_alarm_ex.d.ts +7 -7
  65. package/dist/source/interfaces/alarms_and_conditions/ua_discrete_alarm_ex.js +25 -25
  66. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_deviation_alarm_ex.d.ts +5 -5
  67. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_deviation_alarm_ex.js +2 -2
  68. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_limit_alarm_ex.d.ts +20 -20
  69. package/dist/source/interfaces/alarms_and_conditions/ua_exclusive_limit_alarm_ex.js +2 -2
  70. package/dist/source/interfaces/alarms_and_conditions/ua_limit_alarm_ex.d.ts +26 -26
  71. package/dist/source/interfaces/alarms_and_conditions/ua_limit_alarm_ex.js +2 -2
  72. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_deviation_alarm_ex.d.ts +8 -10
  73. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_deviation_alarm_ex.js +2 -2
  74. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_limit_alarm_ex.d.ts +10 -10
  75. package/dist/source/interfaces/alarms_and_conditions/ua_non_exclusive_limit_alarm_ex.js +2 -2
  76. package/dist/source/interfaces/data_access/ua_multistate_discrete_ex.d.ts +21 -21
  77. package/dist/source/interfaces/data_access/ua_multistate_discrete_ex.js +2 -2
  78. package/dist/source/interfaces/data_access/ua_multistate_value_discrete_ex.d.ts +24 -24
  79. package/dist/source/interfaces/data_access/ua_multistate_value_discrete_ex.js +2 -2
  80. package/dist/source/interfaces/data_access/ua_two_state_discrete_ex.d.ts +12 -12
  81. package/dist/source/interfaces/data_access/ua_two_state_discrete_ex.js +2 -2
  82. package/dist/source/interfaces/data_access/ua_y_array_item_ex.d.ts +8 -8
  83. package/dist/source/interfaces/data_access/ua_y_array_item_ex.js +2 -2
  84. package/dist/source/interfaces/state_machine/ua_exclusive_limit_state_machine_type_ex.d.ts +12 -12
  85. package/dist/source/interfaces/state_machine/ua_exclusive_limit_state_machine_type_ex.js +2 -2
  86. package/dist/source/interfaces/state_machine/ua_finite_state_machine_type.d.ts +49 -49
  87. package/dist/source/interfaces/state_machine/ua_finite_state_machine_type.js +2 -2
  88. package/dist/source/interfaces/state_machine/ua_program_state_machine_type.d.ts +11 -11
  89. package/dist/source/interfaces/state_machine/ua_program_state_machine_type.js +2 -2
  90. package/dist/source/interfaces/state_machine/ua_shelved_state_machine_ex.d.ts +30 -30
  91. package/dist/source/interfaces/state_machine/ua_shelved_state_machine_ex.js +2 -2
  92. package/dist/source/interfaces/state_machine/ua_state_machine_type.d.ts +222 -222
  93. package/dist/source/interfaces/state_machine/ua_state_machine_type.js +2 -2
  94. package/dist/source/interfaces/state_machine/ua_transition_ex.d.ts +6 -6
  95. package/dist/source/interfaces/state_machine/ua_transition_ex.js +2 -2
  96. package/dist/source/interfaces/ua_subscription_diagnostics_variable_ex.d.ts +8 -8
  97. package/dist/source/interfaces/ua_subscription_diagnostics_variable_ex.js +2 -2
  98. package/dist/source/loader/decode_xml_extension_object.d.ts +6 -6
  99. package/dist/source/loader/decode_xml_extension_object.js +71 -71
  100. package/dist/source/loader/ensure_datatype_extracted.d.ts +5 -5
  101. package/dist/source/loader/ensure_datatype_extracted.js +45 -45
  102. package/dist/source/loader/generateAddressSpaceRaw.d.ts +10 -10
  103. package/dist/source/loader/generateAddressSpaceRaw.js +45 -45
  104. package/dist/source/loader/load_nodeset2.d.ts +16 -16
  105. package/dist/source/loader/load_nodeset2.js +1461 -1461
  106. package/dist/source/loader/make_semver_compatible.d.ts +6 -6
  107. package/dist/source/loader/make_semver_compatible.js +25 -25
  108. package/dist/source/loader/make_xml_extension_object_parser.d.ts +28 -28
  109. package/dist/source/loader/make_xml_extension_object_parser.js +325 -325
  110. package/dist/source/loader/namespace_post_step.d.ts +10 -6
  111. package/dist/source/loader/namespace_post_step.js +61 -47
  112. package/dist/source/loader/namespace_post_step.js.map +1 -1
  113. package/dist/source/loader/register_node_promoter.d.ts +2 -3
  114. package/dist/source/loader/register_node_promoter.js +9 -9
  115. package/dist/source/loader/register_node_promoter.js.map +1 -1
  116. package/dist/source/namespace.d.ts +6 -6
  117. package/dist/source/namespace.js +2 -2
  118. package/dist/source/namespace_alarm_and_condition.d.ts +32 -24
  119. package/dist/source/namespace_alarm_and_condition.js +2 -2
  120. package/dist/source/namespace_data_access.d.ts +42 -42
  121. package/dist/source/namespace_data_access.js +2 -2
  122. package/dist/source/namespace_machine_state.d.ts +7 -7
  123. package/dist/source/namespace_machine_state.js +2 -2
  124. package/dist/source/pseudo_session.d.ts +55 -55
  125. package/dist/source/pseudo_session.js +203 -203
  126. package/dist/source/session_context.d.ts +111 -111
  127. package/dist/source/session_context.js +265 -265
  128. package/dist/source/set_namespace_meta_data.d.ts +2 -2
  129. package/dist/source/set_namespace_meta_data.js +59 -59
  130. package/dist/source/ua_root_folder.d.ts +9 -9
  131. package/dist/source/ua_root_folder.js +2 -2
  132. package/dist/source/ua_two_state_variable_ex.d.ts +23 -23
  133. package/dist/source/ua_two_state_variable_ex.js +2 -2
  134. package/dist/source/xml_writer.d.ts +9 -9
  135. package/dist/source/xml_writer.js +2 -2
  136. package/dist/src/address_space.d.ts +392 -392
  137. package/dist/src/address_space.js +1392 -1387
  138. package/dist/src/address_space.js.map +1 -1
  139. package/dist/src/address_space_change_event_tools.d.ts +6 -6
  140. package/dist/src/address_space_change_event_tools.js +149 -149
  141. package/dist/src/address_space_private.d.ts +43 -43
  142. package/dist/src/address_space_private.js +2 -2
  143. package/dist/src/alarms_and_conditions/condition.d.ts +5 -5
  144. package/dist/src/alarms_and_conditions/condition.js +78 -78
  145. package/dist/src/alarms_and_conditions/condition_info_impl.d.ts +26 -26
  146. package/dist/src/alarms_and_conditions/condition_info_impl.js +54 -54
  147. package/dist/src/alarms_and_conditions/condition_snapshot_impl.d.ts +222 -231
  148. package/dist/src/alarms_and_conditions/condition_snapshot_impl.js +657 -666
  149. package/dist/src/alarms_and_conditions/condition_snapshot_impl.js.map +1 -1
  150. package/dist/src/alarms_and_conditions/deviation_alarm_helper.d.ts +9 -8
  151. package/dist/src/alarms_and_conditions/deviation_alarm_helper.js +61 -46
  152. package/dist/src/alarms_and_conditions/deviation_alarm_helper.js.map +1 -1
  153. package/dist/src/alarms_and_conditions/index.d.ts +16 -18
  154. package/dist/src/alarms_and_conditions/index.js +32 -34
  155. package/dist/src/alarms_and_conditions/index.js.map +1 -1
  156. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_impl.d.ts +44 -44
  157. package/dist/src/alarms_and_conditions/ua_acknowledgeable_condition_impl.js +244 -244
  158. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.d.ts +93 -93
  159. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.js +419 -416
  160. package/dist/src/alarms_and_conditions/ua_alarm_condition_impl.js.map +1 -1
  161. package/dist/src/alarms_and_conditions/ua_base_event_impl.d.ts +26 -26
  162. package/dist/src/alarms_and_conditions/ua_base_event_impl.js +38 -38
  163. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.d.ts +44 -36
  164. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.js +183 -118
  165. package/dist/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.js.map +1 -1
  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 -1024
  168. package/dist/src/alarms_and_conditions/ua_condition_impl.js.map +1 -1
  169. package/dist/src/alarms_and_conditions/ua_discrete_alarm_impl.d.ts +14 -14
  170. package/dist/src/alarms_and_conditions/ua_discrete_alarm_impl.js +34 -34
  171. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.d.ts +24 -26
  172. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.js +56 -56
  173. package/dist/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.js.map +1 -1
  174. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm_impl.d.ts +11 -11
  175. package/dist/src/alarms_and_conditions/ua_exclusive_level_alarm_impl.js +11 -11
  176. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.d.ts +23 -23
  177. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.js +86 -86
  178. package/dist/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.js.map +1 -1
  179. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm_impl.d.ts +11 -11
  180. package/dist/src/alarms_and_conditions/ua_exclusive_rate_of_change_alarm_impl.js +7 -7
  181. package/dist/src/alarms_and_conditions/ua_limit_alarm_impl.d.ts +79 -79
  182. package/dist/src/alarms_and_conditions/ua_limit_alarm_impl.js +250 -250
  183. package/dist/src/alarms_and_conditions/ua_limit_alarm_impl.js.map +1 -1
  184. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.d.ts +24 -24
  185. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.js +50 -50
  186. package/dist/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.js.map +1 -1
  187. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.d.ts +19 -19
  188. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.js +162 -162
  189. package/dist/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.js.map +1 -1
  190. package/dist/src/alarms_and_conditions/ua_off_normal_alarm_impl.d.ts +46 -46
  191. package/dist/src/alarms_and_conditions/ua_off_normal_alarm_impl.js +166 -161
  192. package/dist/src/alarms_and_conditions/ua_off_normal_alarm_impl.js.map +1 -1
  193. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.d.ts +18 -18
  194. package/dist/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.js +17 -17
  195. package/dist/src/apply_condition_refresh.d.ts +6 -6
  196. package/dist/src/apply_condition_refresh.js +27 -27
  197. package/dist/src/base_node_impl.d.ts +281 -281
  198. package/dist/src/base_node_impl.js +1395 -1395
  199. package/dist/src/base_node_private.d.ts +61 -61
  200. package/dist/src/base_node_private.js +705 -705
  201. package/dist/src/data_access/add_dataItem_stuff.d.ts +11 -11
  202. package/dist/src/data_access/add_dataItem_stuff.js +61 -61
  203. package/dist/src/data_access/check_variant_compatibility_ua_analog_item.d.ts +1 -1
  204. package/dist/src/data_access/check_variant_compatibility_ua_analog_item.js +34 -34
  205. package/dist/src/data_access/ua_multistate_discrete_impl.d.ts +32 -32
  206. package/dist/src/data_access/ua_multistate_discrete_impl.js +130 -130
  207. package/dist/src/data_access/ua_multistate_value_discrete_impl.d.ts +51 -51
  208. package/dist/src/data_access/ua_multistate_value_discrete_impl.js +249 -249
  209. package/dist/src/data_access/ua_two_state_discrete_impl.d.ts +25 -25
  210. package/dist/src/data_access/ua_two_state_discrete_impl.js +153 -153
  211. package/dist/src/event_data.d.ts +34 -29
  212. package/dist/src/event_data.js +64 -95
  213. package/dist/src/event_data.js.map +1 -1
  214. package/dist/src/extension_object_array_node.d.ts +61 -61
  215. package/dist/src/extension_object_array_node.js +276 -276
  216. package/dist/src/historical_access/address_space_historical_data_node.d.ts +26 -26
  217. package/dist/src/historical_access/address_space_historical_data_node.js +630 -630
  218. package/dist/src/index_current.d.ts +43 -44
  219. package/dist/src/index_current.js +74 -75
  220. package/dist/src/index_current.js.map +1 -1
  221. package/dist/src/namespace_impl.d.ts +461 -458
  222. package/dist/src/namespace_impl.js +1732 -1732
  223. package/dist/src/namespace_impl.js.map +1 -1
  224. package/dist/src/namespace_private.d.ts +21 -21
  225. package/dist/src/namespace_private.js +32 -32
  226. package/dist/src/nodeid_manager.d.ts +36 -36
  227. package/dist/src/nodeid_manager.js +197 -197
  228. package/dist/src/nodeset_tools/adjust_namespace_array.d.ts +2 -2
  229. package/dist/src/nodeset_tools/adjust_namespace_array.js +13 -13
  230. package/dist/src/nodeset_tools/construct_namespace_dependency.d.ts +2 -2
  231. package/dist/src/nodeset_tools/construct_namespace_dependency.js +83 -83
  232. package/dist/src/nodeset_tools/nodeset_to_xml.d.ts +2 -2
  233. package/dist/src/nodeset_tools/nodeset_to_xml.js +1155 -1155
  234. package/dist/src/nodeset_tools/typedictionary_to_xml.d.ts +2 -2
  235. package/dist/src/nodeset_tools/typedictionary_to_xml.js +154 -154
  236. package/dist/src/reference_impl.d.ts +43 -43
  237. package/dist/src/reference_impl.js +139 -139
  238. package/dist/src/role_permissions.d.ts +2 -2
  239. package/dist/src/role_permissions.js +10 -10
  240. package/dist/src/state_machine/finite_state_machine.d.ts +67 -67
  241. package/dist/src/state_machine/finite_state_machine.js +353 -353
  242. package/dist/src/state_machine/ua_shelving_state_machine_ex.d.ts +38 -38
  243. package/dist/src/state_machine/ua_shelving_state_machine_ex.js +250 -250
  244. package/dist/src/state_machine/ua_two_state_variable.d.ts +61 -61
  245. package/dist/src/state_machine/ua_two_state_variable.js +331 -331
  246. package/dist/src/state_machine/ua_two_state_variable.js.map +1 -1
  247. package/dist/src/tool_isSupertypeOf.d.ts +17 -17
  248. package/dist/src/tool_isSupertypeOf.js +108 -108
  249. package/dist/src/ua_condition_type.d.ts +8 -8
  250. package/dist/src/ua_condition_type.js +2 -2
  251. package/dist/src/ua_data_type_impl.d.ts +93 -93
  252. package/dist/src/ua_data_type_impl.js +371 -371
  253. package/dist/src/ua_method_impl.d.ts +41 -41
  254. package/dist/src/ua_method_impl.js +208 -208
  255. package/dist/src/ua_object_impl.d.ts +35 -35
  256. package/dist/src/ua_object_impl.js +161 -162
  257. package/dist/src/ua_object_impl.js.map +1 -1
  258. package/dist/src/ua_object_type_impl.d.ts +48 -48
  259. package/dist/src/ua_object_type_impl.js +124 -124
  260. package/dist/src/ua_reference_type_impl.d.ts +43 -43
  261. package/dist/src/ua_reference_type_impl.js +139 -139
  262. package/dist/src/ua_variable_impl.d.ts +351 -351
  263. package/dist/src/ua_variable_impl.js +1604 -1604
  264. package/dist/src/ua_variable_impl_ext_obj.d.ts +17 -17
  265. package/dist/src/ua_variable_impl_ext_obj.js +437 -437
  266. package/dist/src/ua_variable_type_impl.d.ts +62 -62
  267. package/dist/src/ua_variable_type_impl.js +570 -570
  268. package/dist/src/ua_view_impl.d.ts +19 -19
  269. package/dist/src/ua_view_impl.js +43 -43
  270. package/distHelpers/add_event_generator_object.d.ts +3 -3
  271. package/distHelpers/add_event_generator_object.js +64 -65
  272. package/distHelpers/add_event_generator_object.js.map +1 -1
  273. package/distHelpers/alarms_and_conditions_demo.d.ts +9 -9
  274. package/distHelpers/alarms_and_conditions_demo.js +115 -114
  275. package/distHelpers/alarms_and_conditions_demo.js.map +1 -1
  276. package/distHelpers/assertHasMatchingReference.d.ts +19 -19
  277. package/distHelpers/assertHasMatchingReference.js +40 -40
  278. package/distHelpers/boiler_system.d.ts +113 -113
  279. package/distHelpers/boiler_system.js +395 -395
  280. package/distHelpers/create_minimalist_address_space_nodeset.d.ts +5 -5
  281. package/distHelpers/create_minimalist_address_space_nodeset.js +171 -171
  282. package/distHelpers/date_utils.d.ts +3 -3
  283. package/distHelpers/date_utils.js +9 -9
  284. package/distHelpers/dump_statemachine.js +127 -127
  285. package/distHelpers/get_address_space_fixture.d.ts +1 -1
  286. package/distHelpers/get_address_space_fixture.js +30 -30
  287. package/distHelpers/get_mini_address_space.d.ts +7 -7
  288. package/distHelpers/get_mini_address_space.js +36 -36
  289. package/distHelpers/index.d.ts +12 -12
  290. package/distHelpers/index.js +28 -28
  291. package/distHelpers/mock_session.d.ts +14 -14
  292. package/distHelpers/mock_session.js +25 -25
  293. package/distNodeJS/generate_address_space.d.ts +4 -4
  294. package/distNodeJS/generate_address_space.js +41 -41
  295. package/distNodeJS/index.d.ts +1 -1
  296. package/distNodeJS/index.js +17 -17
  297. package/generate.js +1 -1
  298. package/package.json +36 -37
  299. package/source/helpers/argument_list.ts +2 -0
  300. package/source/helpers/multiform_func.ts +5 -3
  301. package/source/index.ts +0 -2
  302. package/source/interfaces/alarms_and_conditions/condition_snapshot.ts +12 -30
  303. package/source/interfaces/alarms_and_conditions/deviation_stuff.ts +8 -6
  304. package/source/interfaces/alarms_and_conditions/install_setpoint_options.ts +9 -0
  305. package/source/interfaces/alarms_and_conditions/instantiate_exclusive_deviation_alarm_options.ts +4 -0
  306. package/source/interfaces/alarms_and_conditions/instantiate_limit_alarm_options.ts +2 -2
  307. package/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_deviation_alarm_options.ts +4 -0
  308. package/source/interfaces/alarms_and_conditions/instantiate_non_exclusive_limit_alarm_options.ts +4 -0
  309. package/source/interfaces/alarms_and_conditions/instantiate_off_normal_alarm_options.ts +16 -1
  310. package/source/interfaces/alarms_and_conditions/ua_certificate_expiration_alarm_ex.ts +5 -0
  311. package/source/interfaces/alarms_and_conditions/ua_exclusive_deviation_alarm_ex.ts +1 -0
  312. package/source/interfaces/alarms_and_conditions/ua_non_exclusive_deviation_alarm_ex.ts +1 -2
  313. package/source/loader/namespace_post_step.ts +26 -3
  314. package/source/loader/register_node_promoter.ts +5 -4
  315. package/source/namespace_alarm_and_condition.ts +48 -23
  316. package/src/address_space.ts +22 -16
  317. package/src/alarms_and_conditions/condition.ts +1 -1
  318. package/src/alarms_and_conditions/condition_snapshot_impl.ts +95 -102
  319. package/src/alarms_and_conditions/deviation_alarm_helper.ts +33 -18
  320. package/src/alarms_and_conditions/index.ts +0 -2
  321. package/src/alarms_and_conditions/ua_alarm_condition_impl.ts +4 -1
  322. package/src/alarms_and_conditions/ua_certificate_expiration_alarm_impl.ts +106 -49
  323. package/src/alarms_and_conditions/ua_condition_impl.ts +9 -6
  324. package/src/alarms_and_conditions/ua_exclusive_deviation_alarm_impl.ts +5 -6
  325. package/src/alarms_and_conditions/ua_exclusive_limit_alarm_impl.ts +1 -1
  326. package/src/alarms_and_conditions/ua_limit_alarm_impl.ts +6 -8
  327. package/src/alarms_and_conditions/ua_non_exclusive_deviation_alarm_impl.ts +5 -3
  328. package/src/alarms_and_conditions/ua_non_exclusive_limit_alarm_impl.ts +3 -3
  329. package/src/alarms_and_conditions/ua_off_normal_alarm_impl.ts +30 -26
  330. package/src/alarms_and_conditions/ua_system_off_normal_alarm_impl.ts +1 -1
  331. package/src/event_data.ts +47 -77
  332. package/src/index_current.ts +0 -1
  333. package/src/namespace_impl.ts +47 -26
  334. package/src/state_machine/ua_two_state_variable.ts +2 -3
  335. package/src/ua_object_impl.ts +1 -2
  336. package/test_helpers/add_event_generator_object.ts +0 -1
  337. package/test_helpers/alarms_and_conditions_demo.ts +4 -1
  338. package/dist/source/helpers/check_event_clause.d.ts +0 -17
  339. package/dist/source/helpers/check_event_clause.js +0 -53
  340. package/dist/source/helpers/check_event_clause.js.map +0 -1
  341. package/dist/src/alarms_and_conditions/check_where_clause.d.ts +0 -4
  342. package/dist/src/alarms_and_conditions/check_where_clause.js +0 -110
  343. package/dist/src/alarms_and_conditions/check_where_clause.js.map +0 -1
  344. package/dist/src/alarms_and_conditions/condition_info.d.ts +0 -27
  345. package/dist/src/alarms_and_conditions/condition_info.js +0 -55
  346. package/dist/src/alarms_and_conditions/condition_info.js.map +0 -1
  347. package/dist/src/alarms_and_conditions/condition_snapshot.d.ts +0 -233
  348. package/dist/src/alarms_and_conditions/condition_snapshot.js +0 -667
  349. package/dist/src/alarms_and_conditions/condition_snapshot.js.map +0 -1
  350. package/dist/src/alarms_and_conditions/extract_event_fields.d.ts +0 -10
  351. package/dist/src/alarms_and_conditions/extract_event_fields.js +0 -90
  352. package/dist/src/alarms_and_conditions/extract_event_fields.js.map +0 -1
  353. package/dist/src/data_access/ua_multistate_value_discrete.d.ts +0 -51
  354. package/dist/src/data_access/ua_multistate_value_discrete.js +0 -250
  355. package/dist/src/data_access/ua_multistate_value_discrete.js.map +0 -1
  356. package/dist/src/data_access/ua_two_state_discrete.d.ts +0 -25
  357. package/dist/src/data_access/ua_two_state_discrete.js +0 -154
  358. package/dist/src/data_access/ua_two_state_discrete.js.map +0 -1
  359. package/source/helpers/check_event_clause.ts +0 -55
  360. package/src/alarms_and_conditions/check_where_clause.ts +0 -147
  361. package/src/alarms_and_conditions/extract_event_fields.ts +0 -103
@@ -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