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,417 +1,420 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.UAAlarmConditionImpl = void 0;
4
- /**
5
- * @module node-opcua-address-space.AlarmsAndConditions
6
- */
7
- const lodash_1 = require("lodash");
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_nodeid_1 = require("node-opcua-nodeid");
11
- const node_opcua_status_code_1 = require("node-opcua-status-code");
12
- const node_opcua_variant_1 = require("node-opcua-variant");
13
- const ua_two_state_variable_1 = require("../state_machine/ua_two_state_variable");
14
- const ua_shelving_state_machine_ex_1 = require("../state_machine/ua_shelving_state_machine_ex");
15
- const condition_info_impl_1 = require("./condition_info_impl");
16
- const ua_acknowledgeable_condition_impl_1 = require("./ua_acknowledgeable_condition_impl");
17
- function _update_suppressedOrShelved(alarmNode) {
18
- alarmNode.suppressedOrShelved.setValueFromSource({
19
- dataType: node_opcua_variant_1.DataType.Boolean,
20
- value: alarmNode.isSuppressedOrShelved()
21
- });
22
- }
23
- class UAAlarmConditionImpl extends ua_acknowledgeable_condition_impl_1.UAAcknowledgeableConditionImpl {
24
- static instantiate(namespace, alarmConditionTypeId, options, data) {
25
- const addressSpace = namespace.addressSpace;
26
- // xx assert(Object.prototype.hasOwnProperty.call(options,"conditionOf")); // must provide a conditionOf
27
- (0, node_opcua_assert_1.assert)(Object.prototype.hasOwnProperty.call(options, "inputNode")); // must provide a inputNode
28
- const alarmConditionType = addressSpace.findEventType(alarmConditionTypeId);
29
- /* istanbul ignore next */
30
- if (!alarmConditionType) {
31
- throw new Error(" cannot find Alarm Condition Type for " + alarmConditionTypeId);
32
- }
33
- const alarmConditionTypeBase = addressSpace.findEventType("AlarmConditionType");
34
- /* istanbul ignore next */
35
- if (!alarmConditionTypeBase) {
36
- throw new Error("cannot find AlarmConditionType");
37
- }
38
- options.optionals = options.optionals || [];
39
- if (Object.prototype.hasOwnProperty.call(options, "maxTimeShelved")) {
40
- options.optionals.push("MaxTimeShelved");
41
- (0, node_opcua_assert_1.assert)(isFinite(options.maxTimeShelved));
42
- }
43
- (0, node_opcua_assert_1.assert)(alarmConditionTypeBase === alarmConditionType || alarmConditionType.isSupertypeOf(alarmConditionTypeBase));
44
- const alarmNode = ua_acknowledgeable_condition_impl_1.UAAcknowledgeableConditionImpl.instantiate(namespace, alarmConditionTypeId, options, data);
45
- Object.setPrototypeOf(alarmNode, UAAlarmConditionImpl.prototype);
46
- // ----------------------- Install Alarm specifics
47
- //
48
- // Specs 1.03:
49
- // ActiveState/Id when set to TRUE indicates that the situation the Condition is representing
50
- // currently exists. When a Condition instance is in the inactive state (ActiveState/Id when set to
51
- // FALSE) it is representing a situation that has returned to a normal state. The transitions of
52
- // Conditions to the inactive and Active states are triggered by Server specific actions. Sub-
53
- // Types of the AlarmConditionType specified later in this document will have sub-state models
54
- // that further define the Active state. Recommended state names are described in Annex A.
55
- // install activeState - Mandatory
56
- /**
57
- * @property activeState
58
- * @type {UATwoStateVariable}
59
- */
60
- (0, ua_two_state_variable_1._install_TwoStateVariable_machinery)(alarmNode.activeState, {
61
- falseState: "Inactive",
62
- trueState: "Active"
63
- });
64
- alarmNode.currentBranch().setActiveState(false);
65
- // Specs 1.03:
66
- /**
67
- *
68
- * SuppressState is used internally by a Server to automatically suppress Alarms due to system
69
- * specific reasons. For example a system may be configured to suppress Alarms that are
70
- * associated with machinery that is shutdown, such as a low level Alarm for a tank that is
71
- * currently not in use.
72
- *
73
- * @property suppressedState
74
- * @type UATwoStateVariable
75
- */
76
- if (alarmNode.suppressedState) {
77
- // install activeState - Optional
78
- (0, ua_two_state_variable_1._install_TwoStateVariable_machinery)(alarmNode.suppressedState, {
79
- falseState: "Unsuppressed",
80
- trueState: "Suppressed"
81
- });
82
- }
83
- // Specs 1.03:
84
- /**
85
- * ShelvingState suggests whether an Alarm shall (temporarily) be prevented from being
86
- * displayed to the user. It is quite often used to block nuisance Alarms.
87
- *
88
- * @property shelvingState
89
- * @type ShelvingStateMachine
90
- */
91
- if (alarmNode.shelvingState) {
92
- ua_shelving_state_machine_ex_1.UAShelvedStateMachineExImpl.promote(alarmNode.shelvingState);
93
- }
94
- // SuppressedOrShelved : Mandatory
95
- // install suppressedOrShelved automatic detection
96
- /**
97
- * The SuppressedState and the ShelvingState together result in the SuppressedOrShelved status of the
98
- * Condition. When an Alarm is in one of the states, the SuppressedOrShelved property will be set TRUE
99
- * and this Alarm is then typically not displayed by the Client. State transitions associated with the
100
- * Alarm do occur, but they are not typically displayed by the Clients as long as the Alarm remains in
101
- * either the Suppressed or Shelved state.
102
- * The dataType is Boolean.
103
- * @property suppressedState
104
- * @type UAVariable
105
- *
106
- */
107
- if (alarmNode.suppressedState) {
108
- alarmNode.suppressedState.on("value_changed", (newDataValue) => {
109
- _update_suppressedOrShelved(alarmNode);
110
- });
111
- }
112
- if (alarmNode.shelvingState) {
113
- alarmNode.shelvingState.currentState.on("value_changed", (newDataValue) => {
114
- _update_suppressedOrShelved(alarmNode);
115
- });
116
- }
117
- _update_suppressedOrShelved(alarmNode);
118
- /**
119
- * The optional Property MaxTimeShelved is used to set the maximum time that an Alarm Condition may be shelved.
120
- * The value is expressed as duration. Systems can use this Property to prevent permanent Shelving of an Alarm.
121
- * If this Property is present it will be an upper limit on the duration passed into a TimedShelve Method call.
122
- * If a value that exceeds the value of this property is passed to the TimedShelve Method,
123
- * than a BadShelvingTimeOutOfRange error code is returned on the call. If this Property is present it will
124
- * also be enforced for the OneShotShelved state, in that an Alarm Condition will transition to the Unshelved
125
- * state from the OneShotShelved state if the duration specified in this Property expires following a
126
- * OneShotShelve operation without a change of any of the other items associated with the Condition.
127
- *
128
- * @property maxTimeShelved
129
- * @type {UAVariable}
130
- */
131
- if (alarmNode.maxTimeShelved) {
132
- options.maxTimeShelved = options.maxTimeShelved || 60.0 * 1000; // 60 seconds
133
- alarmNode.maxTimeShelved.setValueFromSource({
134
- dataType: "Duration",
135
- value: options.maxTimeShelved
136
- });
137
- }
138
- // ---------- install inputNode
139
- (0, node_opcua_assert_1.assert)(options.inputNode, " must provide options.inputNode (NodeId or BaseNode object)");
140
- alarmNode.installInputNodeMonitoring(options.inputNode);
141
- (0, node_opcua_assert_1.assert)(alarmNode instanceof ua_acknowledgeable_condition_impl_1.UAAcknowledgeableConditionImpl);
142
- (0, node_opcua_assert_1.assert)(alarmNode instanceof UAAlarmConditionImpl);
143
- return alarmNode;
144
- }
145
- dispose() {
146
- if (this.shelvingState) {
147
- (0, ua_shelving_state_machine_ex_1._clear_timer_if_any)(this.shelvingState);
148
- }
149
- super.dispose();
150
- }
151
- activateAlarm() {
152
- // will set acknowledgeable to false and retain to true
153
- const branch = this.currentBranch();
154
- branch.setRetain(true);
155
- branch.setActiveState(true);
156
- branch.setAckedState(false);
157
- }
158
- deactivateAlarm(retain) {
159
- const branch = this.currentBranch();
160
- branch.setRetain(retain === undefined ? true : retain);
161
- branch.setActiveState(false);
162
- }
163
- /**
164
- * @deprecated use deactivateAlarm instead (with no s after de-activate)
165
- */
166
- desactivateAlarm() {
167
- this.deactivateAlarm();
168
- }
169
- isSuppressedOrShelved() {
170
- let suppressed = false;
171
- if (this.suppressedState) {
172
- suppressed = this.suppressedState.id.readValue().value.value;
173
- }
174
- let shelved = false;
175
- if (this.shelvingState) {
176
- const shelvedValue = this.shelvingState.currentState.readValue().value.value;
177
- if (shelvedValue && shelvedValue.text !== "Unshelved") {
178
- shelved = true;
179
- }
180
- // console.log("shelved = shelved",shelvedValue,shelved);
181
- }
182
- // xx console.log(" isSuppressedOrShelved ",suppressed,shelved);
183
- return suppressed || shelved;
184
- }
185
- getSuppressedOrShelved() {
186
- return this.suppressedOrShelved.readValue().value.value;
187
- }
188
- /**
189
- *
190
- * note: duration must be greater than 10ms and lesser than 2**31 ms
191
- */
192
- setMaxTimeShelved(duration) {
193
- var _a;
194
- if (duration < 10 || duration >= Math.pow(2, 31)) {
195
- throw new Error(" Invalid maxTimeShelved duration: " + duration + " must be [10,2**31] ");
196
- }
197
- (_a = this.maxTimeShelved) === null || _a === void 0 ? void 0 : _a.setValueFromSource({
198
- dataType: "Duration",
199
- value: duration
200
- });
201
- }
202
- /**
203
- * note: return a Duration
204
- */
205
- getMaxTimeShelved() {
206
- if (!this.maxTimeShelved) {
207
- // if maxTimeShelved is not provided we assume MaxDuration
208
- (0, node_opcua_assert_1.assert)(UAAlarmConditionImpl.MaxDuration <= 2147483648, "MaxDuration cannot be greater than 2**31");
209
- return UAAlarmConditionImpl.MaxDuration;
210
- }
211
- const dataValue = this.maxTimeShelved.readValue();
212
- (0, node_opcua_assert_1.assert)(dataValue.value.dataType === node_opcua_variant_1.DataType.Double); // Double <= Duration
213
- return dataValue.value.value;
214
- }
215
- /**
216
- * @method getInputNodeNode
217
- * @return {BaseNode} return the node in the address space pointed by the inputNode value
218
- *
219
- * Note: please note the difference between alarm.inputNode
220
- * * alarm.inputNode is a UAVariable property of the alarm object holding the nodeid of the input
221
- * node in its value.
222
- * * getInputNodeNode() is the UAVariable that contains the value that affects the state of the alarm and
223
- * whose node id is stored in alarm.inputNode
224
- */
225
- getInputNodeNode() {
226
- const nodeId = this.inputNode.readValue().value.value;
227
- (0, node_opcua_assert_1.assert)(nodeId instanceof node_opcua_nodeid_1.NodeId || nodeId === null);
228
- return this.addressSpace.findNode(nodeId);
229
- }
230
- /**
231
- * @method getInputNodeValue
232
- * @return {*}
233
- */
234
- getInputNodeValue() {
235
- const node = this.getInputNodeNode();
236
- if (!node) {
237
- return null;
238
- }
239
- (0, node_opcua_assert_1.assert)(node.nodeClass === node_opcua_data_model_1.NodeClass.Variable);
240
- return node.readValue().value.value;
241
- }
242
- updateState() {
243
- const node = this.getInputNodeNode();
244
- const dataValue = node.readValue();
245
- this._onInputDataValueChange(dataValue);
246
- }
247
- _onInputDataValueChange(newValue) {
248
- // xx console.log("class=",this.constructor.name,this.browseName.toString());
249
- // xx throw new Error("_onInputDataValueChange must be overridden");
250
- }
251
- /**
252
- * @method installInputNodeMonitoring
253
- * install mechanism that listen to input node datavalue changes so that alarm status
254
- * can be automatically updated appropriatly.
255
- * @param inputNode {BaseNode}
256
- * @return {void}
257
- * @protected
258
- */
259
- installInputNodeMonitoring(inputNode) {
260
- /**
261
- *
262
- * The InputNode Property provides the NodeId of the Variable the Value of which is used as
263
- * primary input in the calculation of the Alarm state. If this Variable is not in the Address Space,
264
- * a Null NodeId shall be provided. In some systems, an Alarm may be calculated based on
265
- * multiple Variables Values; it is up to the system to determine which Variable’s NodeId is used.
266
- * dataType is DataType.NodeId
267
- * @property inputNode
268
- * @type UAVariable
269
- */
270
- (0, node_opcua_assert_1.assert)(this.inputNode.nodeClass === node_opcua_data_model_1.NodeClass.Variable);
271
- const addressSpace = this.addressSpace;
272
- (0, node_opcua_assert_1.assert)(inputNode, " must provide options.inputNode (NodeId or BaseNode object)");
273
- if (inputNode instanceof node_opcua_nodeid_1.NodeId) {
274
- this.inputNode.setValueFromSource({
275
- dataType: node_opcua_variant_1.DataType.NodeId,
276
- value: inputNode
277
- });
278
- }
279
- else {
280
- this.inputNode.setValueFromSource({
281
- dataType: "NodeId",
282
- value: inputNode.nodeId
283
- });
284
- const _node = addressSpace._coerceNode(inputNode);
285
- if (_node === null) {
286
- // tslint:disable-next-line:no-console
287
- console.log(" cannot find nodeId ", inputNode);
288
- }
289
- else {
290
- (0, node_opcua_assert_1.assert)(_node, "Expecting a valid input node");
291
- this.inputNode.setValueFromSource({
292
- dataType: node_opcua_variant_1.DataType.NodeId,
293
- value: _node.nodeId
294
- });
295
- }
296
- const inputNode2 = this.getInputNodeNode();
297
- if (!inputNode2 || inputNode2 === null) {
298
- throw new Error("Invalid input node");
299
- }
300
- inputNode2.on("value_changed", (newDataValue /*, oldDataValue */) => {
301
- if (!this.getEnabledState()) {
302
- // disabled alarms shall ignored input node value change event
303
- // (alarm shall be reevaluated when EnabledState goes back to true)
304
- return;
305
- }
306
- this._onInputDataValueChange(newDataValue);
307
- });
308
- }
309
- }
310
- getCurrentConditionInfo() {
311
- const oldSeverity = this.currentBranch().getSeverity();
312
- const oldQuality = this.currentBranch().getQuality();
313
- const oldMessage = this.currentBranch().getMessage();
314
- const oldRetain = this.currentBranch().getRetain();
315
- const oldConditionInfo = new condition_info_impl_1.ConditionInfoImpl({
316
- message: oldMessage,
317
- quality: oldQuality,
318
- retain: oldRetain,
319
- severity: oldSeverity
320
- });
321
- return oldConditionInfo;
322
- }
323
- /***
324
- * @method _calculateConditionInfo
325
- * @param stateData {Object} the new calculated state of the alarm
326
- * @param isActive {Boolean}
327
- * @param value {Number} the new value of the limit alarm
328
- * @param oldCondition {ConditionInfo} given for information purpose
329
- * @param oldCondition.severity
330
- * @param oldCondition.quality
331
- * @param oldCondition.message
332
- * @param oldCondition.retain
333
- * @return {ConditionInfo} the new condition info
334
- *
335
- * this method need to be overridden by the instantiate to allow custom message and severity
336
- * to be set based on specific context of the alarm.
337
- *
338
- * @example
339
- *
340
- *
341
- * var myAlarm = addressSpace.instantiateExclusiveLimitAlarm({...});
342
- * myAlarm._calculateConditionInfo = function(stateName,value,oldCondition) {
343
- * var percent = Math.ceil(value * 100);
344
- * return new ConditionInfo({
345
- * message: "Tank is almost " + percent + "% full",
346
- * severity: 100,
347
- * quality: StatusCodes.Good
348
- * });
349
- * };
350
- *
351
- */
352
- _calculateConditionInfo(stateData, isActive, value, oldCondition) {
353
- if (!stateData) {
354
- return new condition_info_impl_1.ConditionInfoImpl({
355
- message: "Back to normal",
356
- quality: node_opcua_status_code_1.StatusCodes.Good,
357
- retain: true,
358
- severity: 0
359
- });
360
- }
361
- else {
362
- return new condition_info_impl_1.ConditionInfoImpl({
363
- message: "Condition value is " + value + " and state is " + stateData,
364
- quality: node_opcua_status_code_1.StatusCodes.Good,
365
- retain: true,
366
- severity: 150
367
- });
368
- }
369
- }
370
- _signalInitialCondition() {
371
- this.currentBranch().setActiveState(false);
372
- this.currentBranch().setAckedState(true);
373
- }
374
- _signalNewCondition(stateName, isActive, value) {
375
- // xx if(stateName === null) {
376
- // xx alarm.currentBranch().setActiveState(false);
377
- // xx alarm.currentBranch().setAckedState(true);
378
- // xx return;
379
- // xx }
380
- // disabled alarm shall not generate new condition events
381
- (0, node_opcua_assert_1.assert)(this.getEnabledState() === true);
382
- // xx assert(isActive !== alarm.activeState.getValue());
383
- const oldConditionInfo = this.getCurrentConditionInfo();
384
- const newConditionInfo = this._calculateConditionInfo(stateName, !!isActive, value, oldConditionInfo);
385
- // detect potential internal bugs due to misused of _signalNewCondition
386
- if ((0, lodash_1.isEqual)(oldConditionInfo, newConditionInfo)) {
387
- // tslint:disable-next-line:no-console
388
- console.log(oldConditionInfo);
389
- throw new Error("condition values have not change, shall we really raise an event ? alarm " + this.browseName.toString());
390
- }
391
- (0, node_opcua_assert_1.assert)(!(0, lodash_1.isEqual)(oldConditionInfo, newConditionInfo), "condition values have not change, shall we really raise an event ?");
392
- if (isActive) {
393
- this.currentBranch().setActiveState(true);
394
- this.currentBranch().setAckedState(false);
395
- this.raiseNewCondition(newConditionInfo);
396
- }
397
- else {
398
- if (this.currentBranch().getAckedState() === false) {
399
- // prior state need acknowledgement
400
- // note : TODO : timestamp of branch and new state of current branch must be identical
401
- if (this.currentBranch().getRetain()) {
402
- // we need to create a new branch so the previous state could be acknowledged
403
- const newBranch = this.createBranch();
404
- (0, node_opcua_assert_1.assert)(!(0, node_opcua_nodeid_1.sameNodeId)(newBranch.getBranchId(), node_opcua_nodeid_1.NodeId.nullNodeId));
405
- // also raised a new Event for the new branch as branchId has changed
406
- this.raiseNewBranchState(newBranch);
407
- }
408
- }
409
- this.currentBranch().setActiveState(false);
410
- this.currentBranch().setAckedState(true);
411
- this.raiseNewCondition(newConditionInfo);
412
- }
413
- }
414
- }
415
- exports.UAAlarmConditionImpl = UAAlarmConditionImpl;
416
- UAAlarmConditionImpl.MaxDuration = Math.pow(2, 31);
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.UAAlarmConditionImpl = void 0;
4
+ /**
5
+ * @module node-opcua-address-space.AlarmsAndConditions
6
+ */
7
+ const lodash_1 = require("lodash");
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_nodeid_1 = require("node-opcua-nodeid");
11
+ const node_opcua_status_code_1 = require("node-opcua-status-code");
12
+ const node_opcua_variant_1 = require("node-opcua-variant");
13
+ const ua_two_state_variable_1 = require("../state_machine/ua_two_state_variable");
14
+ const ua_shelving_state_machine_ex_1 = require("../state_machine/ua_shelving_state_machine_ex");
15
+ const condition_info_impl_1 = require("./condition_info_impl");
16
+ const ua_acknowledgeable_condition_impl_1 = require("./ua_acknowledgeable_condition_impl");
17
+ function _update_suppressedOrShelved(alarmNode) {
18
+ alarmNode.suppressedOrShelved.setValueFromSource({
19
+ dataType: node_opcua_variant_1.DataType.Boolean,
20
+ value: alarmNode.isSuppressedOrShelved()
21
+ });
22
+ }
23
+ class UAAlarmConditionImpl extends ua_acknowledgeable_condition_impl_1.UAAcknowledgeableConditionImpl {
24
+ static instantiate(namespace, alarmConditionTypeId, options, data) {
25
+ const addressSpace = namespace.addressSpace;
26
+ // xx assert(Object.prototype.hasOwnProperty.call(options,"conditionOf")); // must provide a conditionOf
27
+ (0, node_opcua_assert_1.assert)(Object.prototype.hasOwnProperty.call(options, "inputNode")); // must provide a inputNode
28
+ const alarmConditionType = addressSpace.findEventType(alarmConditionTypeId);
29
+ /* istanbul ignore next */
30
+ if (!alarmConditionType) {
31
+ throw new Error(" cannot find Alarm Condition Type for " + alarmConditionTypeId);
32
+ }
33
+ const alarmConditionTypeBase = addressSpace.findEventType("AlarmConditionType");
34
+ /* istanbul ignore next */
35
+ if (!alarmConditionTypeBase) {
36
+ throw new Error("cannot find AlarmConditionType");
37
+ }
38
+ options.optionals = options.optionals || [];
39
+ if (Object.prototype.hasOwnProperty.call(options, "maxTimeShelved")) {
40
+ options.optionals.push("MaxTimeShelved");
41
+ (0, node_opcua_assert_1.assert)(isFinite(options.maxTimeShelved));
42
+ }
43
+ (0, node_opcua_assert_1.assert)(alarmConditionTypeBase === alarmConditionType || alarmConditionType.isSupertypeOf(alarmConditionTypeBase));
44
+ const alarmNode = ua_acknowledgeable_condition_impl_1.UAAcknowledgeableConditionImpl.instantiate(namespace, alarmConditionTypeId, options, data);
45
+ Object.setPrototypeOf(alarmNode, UAAlarmConditionImpl.prototype);
46
+ // ----------------------- Install Alarm specifics
47
+ //
48
+ // Specs 1.03:
49
+ // ActiveState/Id when set to TRUE indicates that the situation the Condition is representing
50
+ // currently exists. When a Condition instance is in the inactive state (ActiveState/Id when set to
51
+ // FALSE) it is representing a situation that has returned to a normal state. The transitions of
52
+ // Conditions to the inactive and Active states are triggered by Server specific actions. Sub-
53
+ // Types of the AlarmConditionType specified later in this document will have sub-state models
54
+ // that further define the Active state. Recommended state names are described in Annex A.
55
+ // install activeState - Mandatory
56
+ /**
57
+ * @property activeState
58
+ * @type {UATwoStateVariable}
59
+ */
60
+ (0, ua_two_state_variable_1._install_TwoStateVariable_machinery)(alarmNode.activeState, {
61
+ falseState: "Inactive",
62
+ trueState: "Active"
63
+ });
64
+ alarmNode.currentBranch().setActiveState(false);
65
+ // Specs 1.03:
66
+ /**
67
+ *
68
+ * SuppressState is used internally by a Server to automatically suppress Alarms due to system
69
+ * specific reasons. For example a system may be configured to suppress Alarms that are
70
+ * associated with machinery that is shutdown, such as a low level Alarm for a tank that is
71
+ * currently not in use.
72
+ *
73
+ * @property suppressedState
74
+ * @type UATwoStateVariable
75
+ */
76
+ if (alarmNode.suppressedState) {
77
+ // install activeState - Optional
78
+ (0, ua_two_state_variable_1._install_TwoStateVariable_machinery)(alarmNode.suppressedState, {
79
+ falseState: "Unsuppressed",
80
+ trueState: "Suppressed"
81
+ });
82
+ }
83
+ // Specs 1.03:
84
+ /**
85
+ * ShelvingState suggests whether an Alarm shall (temporarily) be prevented from being
86
+ * displayed to the user. It is quite often used to block nuisance Alarms.
87
+ *
88
+ * @property shelvingState
89
+ * @type ShelvingStateMachine
90
+ */
91
+ if (alarmNode.shelvingState) {
92
+ ua_shelving_state_machine_ex_1.UAShelvedStateMachineExImpl.promote(alarmNode.shelvingState);
93
+ }
94
+ // SuppressedOrShelved : Mandatory
95
+ // install suppressedOrShelved automatic detection
96
+ /**
97
+ * The SuppressedState and the ShelvingState together result in the SuppressedOrShelved status of the
98
+ * Condition. When an Alarm is in one of the states, the SuppressedOrShelved property will be set TRUE
99
+ * and this Alarm is then typically not displayed by the Client. State transitions associated with the
100
+ * Alarm do occur, but they are not typically displayed by the Clients as long as the Alarm remains in
101
+ * either the Suppressed or Shelved state.
102
+ * The dataType is Boolean.
103
+ * @property suppressedState
104
+ * @type UAVariable
105
+ *
106
+ */
107
+ if (alarmNode.suppressedState) {
108
+ alarmNode.suppressedState.on("value_changed", (newDataValue) => {
109
+ _update_suppressedOrShelved(alarmNode);
110
+ });
111
+ }
112
+ if (alarmNode.shelvingState) {
113
+ alarmNode.shelvingState.currentState.on("value_changed", (newDataValue) => {
114
+ _update_suppressedOrShelved(alarmNode);
115
+ });
116
+ }
117
+ _update_suppressedOrShelved(alarmNode);
118
+ /**
119
+ * The optional Property MaxTimeShelved is used to set the maximum time that an Alarm Condition may be shelved.
120
+ * The value is expressed as duration. Systems can use this Property to prevent permanent Shelving of an Alarm.
121
+ * If this Property is present it will be an upper limit on the duration passed into a TimedShelve Method call.
122
+ * If a value that exceeds the value of this property is passed to the TimedShelve Method,
123
+ * than a BadShelvingTimeOutOfRange error code is returned on the call. If this Property is present it will
124
+ * also be enforced for the OneShotShelved state, in that an Alarm Condition will transition to the Unshelved
125
+ * state from the OneShotShelved state if the duration specified in this Property expires following a
126
+ * OneShotShelve operation without a change of any of the other items associated with the Condition.
127
+ *
128
+ * @property maxTimeShelved
129
+ * @type {UAVariable}
130
+ */
131
+ if (alarmNode.maxTimeShelved) {
132
+ options.maxTimeShelved = options.maxTimeShelved || 60.0 * 1000; // 60 seconds
133
+ alarmNode.maxTimeShelved.setValueFromSource({
134
+ dataType: "Duration",
135
+ value: options.maxTimeShelved
136
+ });
137
+ }
138
+ // ---------- install inputNode
139
+ (0, node_opcua_assert_1.assert)(options.inputNode, " must provide options.inputNode (NodeId or BaseNode object)");
140
+ alarmNode.installInputNodeMonitoring(options.inputNode);
141
+ (0, node_opcua_assert_1.assert)(alarmNode instanceof ua_acknowledgeable_condition_impl_1.UAAcknowledgeableConditionImpl);
142
+ (0, node_opcua_assert_1.assert)(alarmNode instanceof UAAlarmConditionImpl);
143
+ return alarmNode;
144
+ }
145
+ dispose() {
146
+ if (this.shelvingState) {
147
+ (0, ua_shelving_state_machine_ex_1._clear_timer_if_any)(this.shelvingState);
148
+ }
149
+ super.dispose();
150
+ }
151
+ activateAlarm() {
152
+ // will set acknowledgeable to false and retain to true
153
+ const branch = this.currentBranch();
154
+ if (!branch) {
155
+ return;
156
+ }
157
+ branch.setRetain(true);
158
+ branch.setActiveState(true);
159
+ branch.setAckedState(false);
160
+ }
161
+ deactivateAlarm(retain) {
162
+ const branch = this.currentBranch();
163
+ branch.setRetain(retain === undefined ? true : retain);
164
+ branch.setActiveState(false);
165
+ }
166
+ /**
167
+ * @deprecated use deactivateAlarm instead (with no s after de-activate)
168
+ */
169
+ desactivateAlarm() {
170
+ this.deactivateAlarm();
171
+ }
172
+ isSuppressedOrShelved() {
173
+ let suppressed = false;
174
+ if (this.suppressedState) {
175
+ suppressed = this.suppressedState.id.readValue().value.value;
176
+ }
177
+ let shelved = false;
178
+ if (this.shelvingState) {
179
+ const shelvedValue = this.shelvingState.currentState.readValue().value.value;
180
+ if (shelvedValue && shelvedValue.text !== "Unshelved") {
181
+ shelved = true;
182
+ }
183
+ // console.log("shelved = shelved",shelvedValue,shelved);
184
+ }
185
+ // xx console.log(" isSuppressedOrShelved ",suppressed,shelved);
186
+ return suppressed || shelved;
187
+ }
188
+ getSuppressedOrShelved() {
189
+ return this.suppressedOrShelved.readValue().value.value;
190
+ }
191
+ /**
192
+ *
193
+ * note: duration must be greater than 10ms and lesser than 2**31 ms
194
+ */
195
+ setMaxTimeShelved(duration) {
196
+ var _a;
197
+ if (duration < 10 || duration >= Math.pow(2, 31)) {
198
+ throw new Error(" Invalid maxTimeShelved duration: " + duration + " must be [10,2**31] ");
199
+ }
200
+ (_a = this.maxTimeShelved) === null || _a === void 0 ? void 0 : _a.setValueFromSource({
201
+ dataType: "Duration",
202
+ value: duration
203
+ });
204
+ }
205
+ /**
206
+ * note: return a Duration
207
+ */
208
+ getMaxTimeShelved() {
209
+ if (!this.maxTimeShelved) {
210
+ // if maxTimeShelved is not provided we assume MaxDuration
211
+ (0, node_opcua_assert_1.assert)(UAAlarmConditionImpl.MaxDuration <= 2147483648, "MaxDuration cannot be greater than 2**31");
212
+ return UAAlarmConditionImpl.MaxDuration;
213
+ }
214
+ const dataValue = this.maxTimeShelved.readValue();
215
+ (0, node_opcua_assert_1.assert)(dataValue.value.dataType === node_opcua_variant_1.DataType.Double); // Double <= Duration
216
+ return dataValue.value.value;
217
+ }
218
+ /**
219
+ * @method getInputNodeNode
220
+ * @return {BaseNode} return the node in the address space pointed by the inputNode value
221
+ *
222
+ * Note: please note the difference between alarm.inputNode
223
+ * * alarm.inputNode is a UAVariable property of the alarm object holding the nodeid of the input
224
+ * node in its value.
225
+ * * getInputNodeNode() is the UAVariable that contains the value that affects the state of the alarm and
226
+ * whose node id is stored in alarm.inputNode
227
+ */
228
+ getInputNodeNode() {
229
+ const nodeId = this.inputNode.readValue().value.value;
230
+ (0, node_opcua_assert_1.assert)(nodeId instanceof node_opcua_nodeid_1.NodeId || nodeId === null);
231
+ return this.addressSpace.findNode(nodeId);
232
+ }
233
+ /**
234
+ * @method getInputNodeValue
235
+ * @return {*}
236
+ */
237
+ getInputNodeValue() {
238
+ const node = this.getInputNodeNode();
239
+ if (!node) {
240
+ return null;
241
+ }
242
+ (0, node_opcua_assert_1.assert)(node.nodeClass === node_opcua_data_model_1.NodeClass.Variable);
243
+ return node.readValue().value.value;
244
+ }
245
+ updateState() {
246
+ const node = this.getInputNodeNode();
247
+ const dataValue = node.readValue();
248
+ this._onInputDataValueChange(dataValue);
249
+ }
250
+ _onInputDataValueChange(newValue) {
251
+ // xx console.log("class=",this.constructor.name,this.browseName.toString());
252
+ // xx throw new Error("_onInputDataValueChange must be overridden");
253
+ }
254
+ /**
255
+ * @method installInputNodeMonitoring
256
+ * install mechanism that listen to input node datavalue changes so that alarm status
257
+ * can be automatically updated appropriatly.
258
+ * @param inputNode {BaseNode}
259
+ * @return {void}
260
+ * @protected
261
+ */
262
+ installInputNodeMonitoring(inputNode) {
263
+ /**
264
+ *
265
+ * The InputNode Property provides the NodeId of the Variable the Value of which is used as
266
+ * primary input in the calculation of the Alarm state. If this Variable is not in the Address Space,
267
+ * a Null NodeId shall be provided. In some systems, an Alarm may be calculated based on
268
+ * multiple Variables Values; it is up to the system to determine which Variable’s NodeId is used.
269
+ * dataType is DataType.NodeId
270
+ * @property inputNode
271
+ * @type UAVariable
272
+ */
273
+ (0, node_opcua_assert_1.assert)(this.inputNode.nodeClass === node_opcua_data_model_1.NodeClass.Variable);
274
+ const addressSpace = this.addressSpace;
275
+ (0, node_opcua_assert_1.assert)(inputNode, " must provide options.inputNode (NodeId or BaseNode object)");
276
+ if (inputNode instanceof node_opcua_nodeid_1.NodeId) {
277
+ this.inputNode.setValueFromSource({
278
+ dataType: node_opcua_variant_1.DataType.NodeId,
279
+ value: inputNode
280
+ });
281
+ }
282
+ else {
283
+ this.inputNode.setValueFromSource({
284
+ dataType: "NodeId",
285
+ value: inputNode.nodeId
286
+ });
287
+ const _node = addressSpace._coerceNode(inputNode);
288
+ if (_node === null) {
289
+ // tslint:disable-next-line:no-console
290
+ console.log(" cannot find nodeId ", inputNode);
291
+ }
292
+ else {
293
+ (0, node_opcua_assert_1.assert)(_node, "Expecting a valid input node");
294
+ this.inputNode.setValueFromSource({
295
+ dataType: node_opcua_variant_1.DataType.NodeId,
296
+ value: _node.nodeId
297
+ });
298
+ }
299
+ const inputNode2 = this.getInputNodeNode();
300
+ if (!inputNode2 || inputNode2 === null) {
301
+ throw new Error("Invalid input node");
302
+ }
303
+ inputNode2.on("value_changed", (newDataValue /*, oldDataValue */) => {
304
+ if (!this.getEnabledState()) {
305
+ // disabled alarms shall ignored input node value change event
306
+ // (alarm shall be reevaluated when EnabledState goes back to true)
307
+ return;
308
+ }
309
+ this._onInputDataValueChange(newDataValue);
310
+ });
311
+ }
312
+ }
313
+ getCurrentConditionInfo() {
314
+ const oldSeverity = this.currentBranch().getSeverity();
315
+ const oldQuality = this.currentBranch().getQuality();
316
+ const oldMessage = this.currentBranch().getMessage();
317
+ const oldRetain = this.currentBranch().getRetain();
318
+ const oldConditionInfo = new condition_info_impl_1.ConditionInfoImpl({
319
+ message: oldMessage,
320
+ quality: oldQuality,
321
+ retain: oldRetain,
322
+ severity: oldSeverity
323
+ });
324
+ return oldConditionInfo;
325
+ }
326
+ /***
327
+ * @method _calculateConditionInfo
328
+ * @param stateData {Object} the new calculated state of the alarm
329
+ * @param isActive {Boolean}
330
+ * @param value {Number} the new value of the limit alarm
331
+ * @param oldCondition {ConditionInfo} given for information purpose
332
+ * @param oldCondition.severity
333
+ * @param oldCondition.quality
334
+ * @param oldCondition.message
335
+ * @param oldCondition.retain
336
+ * @return {ConditionInfo} the new condition info
337
+ *
338
+ * this method need to be overridden by the instantiate to allow custom message and severity
339
+ * to be set based on specific context of the alarm.
340
+ *
341
+ * @example
342
+ *
343
+ *
344
+ * var myAlarm = addressSpace.instantiateExclusiveLimitAlarm({...});
345
+ * myAlarm._calculateConditionInfo = function(stateName,value,oldCondition) {
346
+ * var percent = Math.ceil(value * 100);
347
+ * return new ConditionInfo({
348
+ * message: "Tank is almost " + percent + "% full",
349
+ * severity: 100,
350
+ * quality: StatusCodes.Good
351
+ * });
352
+ * };
353
+ *
354
+ */
355
+ _calculateConditionInfo(stateData, isActive, value, oldCondition) {
356
+ if (!stateData) {
357
+ return new condition_info_impl_1.ConditionInfoImpl({
358
+ message: "Back to normal",
359
+ quality: node_opcua_status_code_1.StatusCodes.Good,
360
+ retain: true,
361
+ severity: 0
362
+ });
363
+ }
364
+ else {
365
+ return new condition_info_impl_1.ConditionInfoImpl({
366
+ message: "Condition is " + value + " and state is " + stateData,
367
+ quality: node_opcua_status_code_1.StatusCodes.Good,
368
+ retain: true,
369
+ severity: 150
370
+ });
371
+ }
372
+ }
373
+ _signalInitialCondition() {
374
+ this.currentBranch().setActiveState(false);
375
+ this.currentBranch().setAckedState(true);
376
+ }
377
+ _signalNewCondition(stateName, isActive, value) {
378
+ // xx if(stateName === null) {
379
+ // xx alarm.currentBranch().setActiveState(false);
380
+ // xx alarm.currentBranch().setAckedState(true);
381
+ // xx return;
382
+ // xx }
383
+ // disabled alarm shall not generate new condition events
384
+ (0, node_opcua_assert_1.assert)(this.getEnabledState() === true);
385
+ // xx assert(isActive !== alarm.activeState.getValue());
386
+ const oldConditionInfo = this.getCurrentConditionInfo();
387
+ const newConditionInfo = this._calculateConditionInfo(stateName, !!isActive, value, oldConditionInfo);
388
+ // detect potential internal bugs due to misused of _signalNewCondition
389
+ if ((0, lodash_1.isEqual)(oldConditionInfo, newConditionInfo)) {
390
+ // tslint:disable-next-line:no-console
391
+ console.log(oldConditionInfo);
392
+ throw new Error("condition values have not change, shall we really raise an event ? alarm " + this.browseName.toString());
393
+ }
394
+ (0, node_opcua_assert_1.assert)(!(0, lodash_1.isEqual)(oldConditionInfo, newConditionInfo), "condition values have not change, shall we really raise an event ?");
395
+ if (isActive) {
396
+ this.currentBranch().setActiveState(true);
397
+ this.currentBranch().setAckedState(false);
398
+ this.raiseNewCondition(newConditionInfo);
399
+ }
400
+ else {
401
+ if (this.currentBranch().getAckedState() === false) {
402
+ // prior state need acknowledgement
403
+ // note : TODO : timestamp of branch and new state of current branch must be identical
404
+ if (this.currentBranch().getRetain()) {
405
+ // we need to create a new branch so the previous state could be acknowledged
406
+ const newBranch = this.createBranch();
407
+ (0, node_opcua_assert_1.assert)(!(0, node_opcua_nodeid_1.sameNodeId)(newBranch.getBranchId(), node_opcua_nodeid_1.NodeId.nullNodeId));
408
+ // also raised a new Event for the new branch as branchId has changed
409
+ this.raiseNewBranchState(newBranch);
410
+ }
411
+ }
412
+ this.currentBranch().setActiveState(false);
413
+ this.currentBranch().setAckedState(true);
414
+ this.raiseNewCondition(newConditionInfo);
415
+ }
416
+ }
417
+ }
418
+ exports.UAAlarmConditionImpl = UAAlarmConditionImpl;
419
+ UAAlarmConditionImpl.MaxDuration = Math.pow(2, 31);
417
420
  //# sourceMappingURL=ua_alarm_condition_impl.js.map