openhab-scripting 4.47.0 → 5.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (281) hide show
  1. checksums.yaml +4 -4
  2. data/lib/openhab/core/actions/audio.rb +47 -0
  3. data/lib/openhab/core/actions/ephemeris.rb +39 -0
  4. data/lib/openhab/core/actions/exec.rb +51 -0
  5. data/lib/openhab/core/actions/http.rb +80 -0
  6. data/lib/openhab/core/actions/ping.rb +30 -0
  7. data/lib/openhab/core/actions/transformation.rb +32 -0
  8. data/lib/openhab/core/actions/voice.rb +36 -0
  9. data/lib/openhab/core/actions.rb +82 -0
  10. data/lib/openhab/core/dependency_tracking.rb +34 -0
  11. data/lib/openhab/core/dto/item_channel_link.rb +33 -0
  12. data/lib/openhab/core/dto/thing.rb +27 -0
  13. data/lib/openhab/core/dto.rb +11 -0
  14. data/lib/openhab/core/entity_lookup.rb +152 -70
  15. data/lib/openhab/core/events/abstract_event.rb +18 -0
  16. data/lib/openhab/core/events/abstract_item_registry_event.rb +36 -0
  17. data/lib/openhab/core/events/abstract_thing_registry_event.rb +40 -0
  18. data/lib/openhab/core/events/item_command_event.rb +78 -0
  19. data/lib/openhab/core/events/item_event.rb +22 -0
  20. data/lib/openhab/core/events/item_state_changed_event.rb +75 -0
  21. data/lib/openhab/core/events/item_state_event.rb +79 -0
  22. data/lib/openhab/core/events/thing_status_info_event.rb +55 -0
  23. data/lib/openhab/core/events.rb +10 -0
  24. data/lib/openhab/core/items/accepted_data_types.rb +29 -0
  25. data/lib/openhab/core/items/color_item.rb +52 -0
  26. data/lib/openhab/core/items/contact_item.rb +52 -0
  27. data/lib/openhab/core/items/date_time_item.rb +59 -0
  28. data/lib/openhab/core/items/dimmer_item.rb +148 -0
  29. data/lib/openhab/core/items/generic_item.rb +292 -0
  30. data/lib/openhab/core/items/group_item.rb +176 -0
  31. data/lib/openhab/{dsl → core}/items/image_item.rb +35 -29
  32. data/lib/openhab/core/items/item.rb +273 -0
  33. data/lib/openhab/core/items/location_item.rb +34 -0
  34. data/lib/openhab/core/items/metadata/hash.rb +433 -0
  35. data/lib/openhab/core/items/metadata/namespace_hash.rb +475 -0
  36. data/lib/openhab/core/items/metadata/provider.rb +48 -0
  37. data/lib/openhab/core/items/metadata.rb +11 -0
  38. data/lib/openhab/core/items/number_item.rb +62 -0
  39. data/lib/openhab/core/items/numeric_item.rb +22 -0
  40. data/lib/openhab/core/items/persistence.rb +416 -0
  41. data/lib/openhab/core/items/player_item.rb +66 -0
  42. data/lib/openhab/core/items/provider.rb +44 -0
  43. data/lib/openhab/core/items/proxy.rb +136 -0
  44. data/lib/openhab/core/items/registry.rb +86 -0
  45. data/lib/openhab/core/items/rollershutter_item.rb +68 -0
  46. data/lib/openhab/core/items/semantics/enumerable.rb +177 -0
  47. data/lib/openhab/core/items/semantics.rb +473 -0
  48. data/lib/openhab/core/items/state_storage.rb +53 -0
  49. data/lib/openhab/core/items/string_item.rb +28 -0
  50. data/lib/openhab/core/items/switch_item.rb +78 -0
  51. data/lib/openhab/core/items.rb +108 -0
  52. data/lib/openhab/{dsl → core}/lazy_array.rb +9 -3
  53. data/lib/openhab/core/profile_factory.rb +132 -0
  54. data/lib/openhab/core/provider.rb +230 -0
  55. data/lib/openhab/core/proxy.rb +130 -0
  56. data/lib/openhab/core/registry.rb +40 -0
  57. data/lib/openhab/core/rules/module.rb +26 -0
  58. data/lib/openhab/core/rules/provider.rb +25 -0
  59. data/lib/openhab/core/rules/registry.rb +76 -0
  60. data/lib/openhab/core/rules/rule.rb +150 -0
  61. data/lib/openhab/core/rules.rb +25 -0
  62. data/lib/openhab/core/script_handling.rb +78 -20
  63. data/lib/openhab/core/things/channel.rb +48 -0
  64. data/lib/openhab/core/things/channel_uid.rb +51 -0
  65. data/lib/openhab/core/things/item_channel_link.rb +33 -0
  66. data/lib/openhab/core/things/links/provider.rb +78 -0
  67. data/lib/openhab/core/things/profile_callback.rb +52 -0
  68. data/lib/openhab/core/things/provider.rb +29 -0
  69. data/lib/openhab/core/things/proxy.rb +87 -0
  70. data/lib/openhab/core/things/registry.rb +73 -0
  71. data/lib/openhab/core/things/thing.rb +194 -0
  72. data/lib/openhab/core/things.rb +22 -0
  73. data/lib/openhab/core/timer.rb +148 -0
  74. data/lib/openhab/{dsl → core}/types/comparable_type.rb +5 -3
  75. data/lib/openhab/{dsl → core}/types/date_time_type.rb +55 -127
  76. data/lib/openhab/{dsl → core}/types/decimal_type.rb +50 -48
  77. data/lib/openhab/{dsl → core}/types/hsb_type.rb +35 -83
  78. data/lib/openhab/core/types/increase_decrease_type.rb +34 -0
  79. data/lib/openhab/core/types/next_previous_type.rb +34 -0
  80. data/lib/openhab/{dsl → core}/types/numeric_type.rb +20 -7
  81. data/lib/openhab/core/types/on_off_type.rb +46 -0
  82. data/lib/openhab/core/types/open_closed_type.rb +41 -0
  83. data/lib/openhab/{dsl → core}/types/percent_type.rb +19 -20
  84. data/lib/openhab/core/types/play_pause_type.rb +38 -0
  85. data/lib/openhab/core/types/point_type.rb +117 -0
  86. data/lib/openhab/core/types/quantity_type.rb +325 -0
  87. data/lib/openhab/core/types/raw_type.rb +26 -0
  88. data/lib/openhab/core/types/refresh_type.rb +27 -0
  89. data/lib/openhab/core/types/rewind_fastforward_type.rb +38 -0
  90. data/lib/openhab/core/types/stop_move_type.rb +34 -0
  91. data/lib/openhab/{dsl → core}/types/string_type.rb +17 -28
  92. data/lib/openhab/{dsl → core}/types/type.rb +42 -40
  93. data/lib/openhab/core/types/un_def_type.rb +38 -0
  94. data/lib/openhab/core/types/up_down_type.rb +50 -0
  95. data/lib/openhab/core/types.rb +82 -0
  96. data/lib/openhab/{dsl → core}/uid.rb +4 -23
  97. data/lib/openhab/core/value_cache.rb +188 -0
  98. data/lib/openhab/core.rb +98 -0
  99. data/lib/openhab/core_ext/between.rb +32 -0
  100. data/lib/openhab/core_ext/ephemeris.rb +53 -0
  101. data/lib/openhab/core_ext/java/class.rb +34 -0
  102. data/lib/openhab/core_ext/java/duration.rb +142 -0
  103. data/lib/openhab/core_ext/java/list.rb +436 -0
  104. data/lib/openhab/core_ext/java/local_date.rb +104 -0
  105. data/lib/openhab/core_ext/java/local_time.rb +118 -0
  106. data/lib/openhab/core_ext/java/map.rb +66 -0
  107. data/lib/openhab/core_ext/java/month.rb +71 -0
  108. data/lib/openhab/core_ext/java/month_day.rb +119 -0
  109. data/lib/openhab/core_ext/java/period.rb +103 -0
  110. data/lib/openhab/core_ext/java/temporal_amount.rb +34 -0
  111. data/lib/openhab/core_ext/java/time.rb +62 -0
  112. data/lib/openhab/core_ext/java/unit.rb +15 -0
  113. data/lib/openhab/core_ext/java/zoned_date_time.rb +213 -0
  114. data/lib/openhab/core_ext/ruby/array.rb +21 -0
  115. data/lib/openhab/core_ext/ruby/date.rb +96 -0
  116. data/lib/openhab/core_ext/ruby/date_time.rb +55 -0
  117. data/lib/openhab/core_ext/ruby/module.rb +15 -0
  118. data/lib/openhab/core_ext/ruby/numeric.rb +195 -0
  119. data/lib/openhab/core_ext/ruby/range.rb +70 -0
  120. data/lib/openhab/core_ext/ruby/symbol.rb +7 -0
  121. data/lib/openhab/core_ext/ruby/time.rb +108 -0
  122. data/lib/openhab/core_ext.rb +18 -0
  123. data/lib/openhab/dsl/debouncer.rb +259 -0
  124. data/lib/openhab/dsl/events/watch_event.rb +18 -0
  125. data/lib/openhab/dsl/events.rb +9 -0
  126. data/lib/openhab/dsl/gems.rb +1 -1
  127. data/lib/openhab/dsl/items/builder.rb +578 -0
  128. data/lib/openhab/dsl/items/ensure.rb +73 -82
  129. data/lib/openhab/dsl/items/timed_command.rb +214 -159
  130. data/lib/openhab/dsl/rules/automation_rule.rb +126 -115
  131. data/lib/openhab/dsl/rules/builder.rb +1935 -0
  132. data/lib/openhab/dsl/rules/guard.rb +51 -114
  133. data/lib/openhab/dsl/rules/name_inference.rb +66 -25
  134. data/lib/openhab/dsl/rules/property.rb +48 -75
  135. data/lib/openhab/dsl/rules/rule_triggers.rb +22 -27
  136. data/lib/openhab/dsl/rules/terse.rb +58 -14
  137. data/lib/openhab/dsl/rules/triggers/changed.rb +48 -94
  138. data/lib/openhab/dsl/rules/triggers/channel.rb +9 -40
  139. data/lib/openhab/dsl/rules/triggers/command.rb +14 -63
  140. data/lib/openhab/dsl/rules/triggers/conditions/duration.rb +34 -69
  141. data/lib/openhab/dsl/rules/triggers/conditions/proc.rb +6 -14
  142. data/lib/openhab/dsl/rules/triggers/cron/cron.rb +48 -82
  143. data/lib/openhab/dsl/rules/triggers/cron/cron_handler.rb +30 -47
  144. data/lib/openhab/dsl/rules/triggers/trigger.rb +7 -28
  145. data/lib/openhab/dsl/rules/triggers/updated.rb +21 -45
  146. data/lib/openhab/dsl/rules/triggers/watch/watch_handler.rb +257 -102
  147. data/lib/openhab/dsl/rules/triggers.rb +12 -0
  148. data/lib/openhab/dsl/rules.rb +8 -0
  149. data/lib/openhab/dsl/things/builder.rb +299 -0
  150. data/lib/openhab/{core → dsl}/thread_local.rb +27 -17
  151. data/lib/openhab/dsl/timer_manager.rb +204 -0
  152. data/lib/openhab/dsl/version.rb +9 -0
  153. data/lib/openhab/dsl.rb +979 -0
  154. data/lib/openhab/log.rb +355 -0
  155. data/lib/openhab/osgi.rb +68 -0
  156. data/lib/openhab/rspec/configuration.rb +56 -0
  157. data/lib/openhab/rspec/example_group.rb +132 -0
  158. data/lib/openhab/rspec/helpers.rb +458 -0
  159. data/lib/openhab/rspec/hooks.rb +113 -0
  160. data/lib/openhab/rspec/jruby.rb +46 -0
  161. data/lib/openhab/rspec/karaf.rb +851 -0
  162. data/lib/openhab/rspec/mocks/bundle_install_support.rb +25 -0
  163. data/lib/openhab/rspec/mocks/bundle_resolver.rb +30 -0
  164. data/lib/openhab/rspec/mocks/event_admin.rb +146 -0
  165. data/lib/openhab/rspec/mocks/instance_method_stasher.rb +22 -0
  166. data/lib/openhab/rspec/mocks/persistence_service.rb +155 -0
  167. data/lib/openhab/rspec/mocks/safe_caller.rb +40 -0
  168. data/lib/openhab/rspec/mocks/space.rb +23 -0
  169. data/lib/openhab/rspec/mocks/synchronous_executor.rb +63 -0
  170. data/lib/openhab/rspec/mocks/thing_handler.rb +76 -0
  171. data/lib/openhab/rspec/mocks/timer.rb +134 -0
  172. data/lib/openhab/rspec/openhab/core/actions.rb +38 -0
  173. data/lib/openhab/rspec/openhab/core/items/proxy.rb +15 -0
  174. data/lib/openhab/rspec/openhab/core/things/proxy.rb +27 -0
  175. data/lib/openhab/rspec/shell.rb +31 -0
  176. data/lib/openhab/rspec/suspend_rules.rb +50 -0
  177. data/lib/openhab/rspec.rb +26 -0
  178. data/lib/openhab/yard/base_helper.rb +19 -0
  179. data/lib/openhab/yard/cli/stats.rb +23 -0
  180. data/lib/openhab/yard/code_objects/group_object.rb +23 -0
  181. data/lib/openhab/yard/code_objects/java/base.rb +31 -0
  182. data/lib/openhab/yard/code_objects/java/class_object.rb +11 -0
  183. data/lib/openhab/yard/code_objects/java/field_object.rb +15 -0
  184. data/lib/openhab/yard/code_objects/java/interface_object.rb +15 -0
  185. data/lib/openhab/yard/code_objects/java/package_object.rb +11 -0
  186. data/lib/openhab/yard/code_objects/java/proxy.rb +23 -0
  187. data/lib/openhab/yard/coderay.rb +17 -0
  188. data/lib/openhab/yard/handlers/jruby/base.rb +58 -0
  189. data/lib/openhab/yard/handlers/jruby/class_handler.rb +18 -0
  190. data/lib/openhab/yard/handlers/jruby/constant_handler.rb +18 -0
  191. data/lib/openhab/yard/handlers/jruby/java_import_handler.rb +30 -0
  192. data/lib/openhab/yard/handlers/jruby/mixin_handler.rb +23 -0
  193. data/lib/openhab/yard/html_helper.rb +78 -0
  194. data/lib/openhab/yard/markdown_helper.rb +148 -0
  195. data/lib/openhab/yard/tags/constant_directive.rb +20 -0
  196. data/lib/openhab/yard/tags/group_directive.rb +24 -0
  197. data/lib/openhab/yard/tags/library.rb +3 -0
  198. data/lib/openhab/yard.rb +38 -0
  199. metadata +475 -106
  200. data/lib/openhab/core/item_proxy.rb +0 -29
  201. data/lib/openhab/core/load_path.rb +0 -19
  202. data/lib/openhab/core/openhab_setup.rb +0 -29
  203. data/lib/openhab/core/osgi.rb +0 -58
  204. data/lib/openhab/core/services.rb +0 -24
  205. data/lib/openhab/dsl/actions.rb +0 -114
  206. data/lib/openhab/dsl/between.rb +0 -25
  207. data/lib/openhab/dsl/channel.rb +0 -43
  208. data/lib/openhab/dsl/dsl.rb +0 -59
  209. data/lib/openhab/dsl/group.rb +0 -54
  210. data/lib/openhab/dsl/imports.rb +0 -21
  211. data/lib/openhab/dsl/items/color_item.rb +0 -76
  212. data/lib/openhab/dsl/items/comparable_item.rb +0 -62
  213. data/lib/openhab/dsl/items/contact_item.rb +0 -41
  214. data/lib/openhab/dsl/items/date_time_item.rb +0 -65
  215. data/lib/openhab/dsl/items/dimmer_item.rb +0 -65
  216. data/lib/openhab/dsl/items/generic_item.rb +0 -229
  217. data/lib/openhab/dsl/items/group_item.rb +0 -127
  218. data/lib/openhab/dsl/items/item_equality.rb +0 -59
  219. data/lib/openhab/dsl/items/item_registry.rb +0 -54
  220. data/lib/openhab/dsl/items/items.rb +0 -109
  221. data/lib/openhab/dsl/items/location_item.rb +0 -59
  222. data/lib/openhab/dsl/items/metadata.rb +0 -326
  223. data/lib/openhab/dsl/items/number_item.rb +0 -17
  224. data/lib/openhab/dsl/items/numeric_item.rb +0 -87
  225. data/lib/openhab/dsl/items/persistence.rb +0 -307
  226. data/lib/openhab/dsl/items/player_item.rb +0 -58
  227. data/lib/openhab/dsl/items/rollershutter_item.rb +0 -51
  228. data/lib/openhab/dsl/items/semantics/enumerable.rb +0 -91
  229. data/lib/openhab/dsl/items/semantics.rb +0 -227
  230. data/lib/openhab/dsl/items/string_item.rb +0 -51
  231. data/lib/openhab/dsl/items/switch_item.rb +0 -70
  232. data/lib/openhab/dsl/monkey_patch/actions/actions.rb +0 -4
  233. data/lib/openhab/dsl/monkey_patch/actions/script_thing_actions.rb +0 -39
  234. data/lib/openhab/dsl/monkey_patch/events/events.rb +0 -7
  235. data/lib/openhab/dsl/monkey_patch/events/item_command.rb +0 -85
  236. data/lib/openhab/dsl/monkey_patch/events/item_event.rb +0 -28
  237. data/lib/openhab/dsl/monkey_patch/events/item_state.rb +0 -61
  238. data/lib/openhab/dsl/monkey_patch/events/item_state_changed.rb +0 -60
  239. data/lib/openhab/dsl/monkey_patch/events/thing_status_info.rb +0 -33
  240. data/lib/openhab/dsl/monkey_patch/java/java.rb +0 -4
  241. data/lib/openhab/dsl/monkey_patch/java/local_time.rb +0 -44
  242. data/lib/openhab/dsl/monkey_patch/java/time_extensions.rb +0 -50
  243. data/lib/openhab/dsl/monkey_patch/java/zoned_date_time.rb +0 -45
  244. data/lib/openhab/dsl/monkey_patch/ruby/number.rb +0 -104
  245. data/lib/openhab/dsl/monkey_patch/ruby/ruby.rb +0 -6
  246. data/lib/openhab/dsl/monkey_patch/ruby/string.rb +0 -47
  247. data/lib/openhab/dsl/monkey_patch/ruby/time.rb +0 -61
  248. data/lib/openhab/dsl/openhab.rb +0 -30
  249. data/lib/openhab/dsl/persistence.rb +0 -27
  250. data/lib/openhab/dsl/rules/item_event.rb +0 -19
  251. data/lib/openhab/dsl/rules/rule.rb +0 -160
  252. data/lib/openhab/dsl/rules/rule_config.rb +0 -147
  253. data/lib/openhab/dsl/rules/triggers/generic.rb +0 -31
  254. data/lib/openhab/dsl/rules/triggers/triggers.rb +0 -11
  255. data/lib/openhab/dsl/rules/triggers/watch/watch.rb +0 -81
  256. data/lib/openhab/dsl/states.rb +0 -89
  257. data/lib/openhab/dsl/things.rb +0 -147
  258. data/lib/openhab/dsl/time/month_day.rb +0 -180
  259. data/lib/openhab/dsl/time/time_of_day.rb +0 -235
  260. data/lib/openhab/dsl/timers/manager.rb +0 -119
  261. data/lib/openhab/dsl/timers/reentrant_timer.rb +0 -38
  262. data/lib/openhab/dsl/timers/timer.rb +0 -132
  263. data/lib/openhab/dsl/timers.rb +0 -77
  264. data/lib/openhab/dsl/types/increase_decrease_type.rb +0 -23
  265. data/lib/openhab/dsl/types/next_previous_type.rb +0 -23
  266. data/lib/openhab/dsl/types/on_off_type.rb +0 -28
  267. data/lib/openhab/dsl/types/open_closed_type.rb +0 -29
  268. data/lib/openhab/dsl/types/play_pause_type.rb +0 -27
  269. data/lib/openhab/dsl/types/point_type.rb +0 -180
  270. data/lib/openhab/dsl/types/quantity_type.rb +0 -265
  271. data/lib/openhab/dsl/types/refresh_type.rb +0 -18
  272. data/lib/openhab/dsl/types/rewind_fastforward_type.rb +0 -33
  273. data/lib/openhab/dsl/types/stop_move_type.rb +0 -23
  274. data/lib/openhab/dsl/types/types.rb +0 -83
  275. data/lib/openhab/dsl/types/un_def_type.rb +0 -22
  276. data/lib/openhab/dsl/types/up_down_type.rb +0 -32
  277. data/lib/openhab/dsl/units.rb +0 -45
  278. data/lib/openhab/log/configuration.rb +0 -21
  279. data/lib/openhab/log/logger.rb +0 -282
  280. data/lib/openhab/version.rb +0 -9
  281. data/lib/openhab.rb +0 -38
@@ -0,0 +1,38 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "type"
4
+
5
+ module OpenHAB
6
+ module Core
7
+ module Types
8
+ UnDefType = org.openhab.core.types.UnDefType
9
+
10
+ # There are situations when item states do not have any defined value.
11
+ # This might be because they have not been initialized yet (never
12
+ # received an state update so far) or because their state is ambiguous
13
+ # (e.g. a group item with members whose states do not match will be
14
+ # {NULL}).
15
+ class UnDefType # rubocop:disable Lint/EmptyClass
16
+ # @!parse include State
17
+
18
+ # @!constant NULL
19
+ # Null State
20
+ # @!constant UNDEF
21
+ # Undef State
22
+
23
+ # @!method null?
24
+ # Check if `self` == {NULL}
25
+ # @return [true,false]
26
+
27
+ # @!method undef?
28
+ # Check if `self` == {UNDEF}
29
+ # @return [true,false]
30
+ end
31
+ end
32
+ end
33
+ end
34
+
35
+ # @!parse
36
+ # UnDefType = OpenHAB::Core::Types::UnDefType
37
+ # NULL = OpenHAB::Core::Types::UnDefType::NULL
38
+ # UNDEF = OpenHAB::Core::Types::UnDefType::UNDEF
@@ -0,0 +1,50 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative "type"
4
+
5
+ module OpenHAB
6
+ module Core
7
+ module Types
8
+ UpDownType = org.openhab.core.library.types.UpDownType
9
+
10
+ #
11
+ # Implements the {UP} and {DOWN} commands.
12
+ #
13
+ # Also, {PercentType} can be converted to {UpDownType}
14
+ # for more semantic comparisons. `0` is {UP}, `100` is
15
+ # {DOWN}, and anything in-between is neither.
16
+ #
17
+ class UpDownType
18
+ # @!parse include Command, State
19
+
20
+ # @!constant UP
21
+ # Up Command/State
22
+ # @!constant DOWN
23
+ # Down Command/State
24
+
25
+ # @!method up?
26
+ # Check if `self == UP`
27
+ # @return [true,false]
28
+
29
+ # @!method down?
30
+ # Check if `self == DOWN`
31
+ # @return [true,false]
32
+
33
+ #
34
+ # Invert the type
35
+ #
36
+ # @return [UpDownType] {UP} if {down?}, {DOWN} if {up?}
37
+ #
38
+ def !
39
+ return UP if down?
40
+ return DOWN if up?
41
+ end
42
+ end
43
+ end
44
+ end
45
+ end
46
+
47
+ # @!parse
48
+ # UpDownType = OpenHAB::Core::Types::UpDownType
49
+ # UP = OpenHAB::Core::Types::UpDownType::UP
50
+ # DOWN = OpenHAB::Core::Types::UpDownType::DOWN
@@ -0,0 +1,82 @@
1
+ # frozen_string_literal: true
2
+
3
+ Dir[File.expand_path("types/*.rb", __dir__)].sort.each do |f|
4
+ require f
5
+ end
6
+
7
+ module OpenHAB
8
+ module Core
9
+ #
10
+ # Contains the core types that openHAB uses as {State}s for items, and
11
+ # {Command}s to be sent to control them.
12
+ #
13
+ # Types are the specific data types that commands and states are. They can be
14
+ # sent to items, be the current state of an item, or be the `command`, `state`,
15
+ # and `was` field of various
16
+ # {group::OpenHAB::DSL::Rules::BuilderDSL::Triggers triggers}.
17
+ # Some types have additional useful methods.
18
+ #
19
+ module Types
20
+ # Hash taking a Enum value, and returning two symbols of
21
+ # predicates to be defined for it. the first is the "command" form,
22
+ # which should be defined on ItemCommandEvent, and on the Type itself.
23
+ # the second is "state" form, which should be defined on the applicable
24
+ # Item, and on the Type itself.
25
+ # @!visibility private
26
+ PREDICATE_ALIASES = Hash.new { |_h, k| [:"#{k.downcase}?"] * 2 }
27
+ .merge({
28
+ "PLAY" => %i[play? playing?],
29
+ "PAUSE" => %i[pause? paused?],
30
+ "REWIND" => %i[rewind? rewinding?],
31
+ "FASTFORWARD" => %i[fast_forward? fast_forwarding?]
32
+ }).freeze
33
+
34
+ # Hash taking a Enum value, and returning an array of symbols
35
+ # of the command to define for it
36
+ # @!visibility private
37
+ COMMAND_ALIASES = Hash.new { |_h, k| k.downcase.to_sym }
38
+ .merge({
39
+ "FASTFORWARD" => :fast_forward
40
+ }).freeze
41
+
42
+ constants.map { |c| const_get(c) }
43
+ .grep(Module)
44
+ .select { |k| k < java.lang.Enum }
45
+ .each do |klass|
46
+ # make sure == from Type is inherited
47
+ klass.remove_method(:==)
48
+
49
+ # dynamically define predicate methods
50
+ klass.values.each do |value| # rubocop:disable Style/HashEachMethods this isn't a Ruby hash
51
+ # include all the aliases that we define for items both command and
52
+ # state aliases (since types can be interrogated as an incoming
53
+ # command, or as the state of an item)
54
+ command = :"#{Types::COMMAND_ALIASES[value.to_s]}?"
55
+ states = Types::PREDICATE_ALIASES[value.to_s]
56
+
57
+ ([command] | states).each do |method|
58
+ logger.trace("Defining #{klass}##{method} for #{value}")
59
+ klass.class_eval <<~RUBY, __FILE__, __LINE__ + 1
60
+ def #{method} # def on?
61
+ as(#{value.class.java_class.simple_name}).equal?(#{value}) # as(OnOffType).equal?(ON)
62
+ end # end
63
+ RUBY
64
+ end
65
+
66
+ method = states.last
67
+ Events::ItemState.class_eval <<~RUBY, __FILE__, __LINE__ + 1
68
+ def #{method} # def on?
69
+ item_state.as(#{value.class.java_class.simple_name}).equal?(#{value}) # item_state.as(OnOffType).equal?(ON)
70
+ end # end
71
+ RUBY
72
+
73
+ Events::ItemStateChangedEvent.class_eval <<~RUBY, __FILE__, __LINE__ + 1
74
+ def was_#{method} # def was_on?
75
+ old_item_state.as(#{value.class.java_class.simple_name}).equal?(#{value}) # old_item_state.as(OnOffType).equal?(ON)
76
+ end # end
77
+ RUBY
78
+ end
79
+ end
80
+ end
81
+ end
82
+ end
@@ -1,16 +1,15 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module OpenHAB
4
- module DSL
4
+ module Core
5
5
  java_import org.openhab.core.common.AbstractUID
6
- java_import org.openhab.core.thing.ThingTypeUID
7
6
 
8
- # Adds methods to core OpenHAB AbstractUID to make it more natural in Ruby
7
+ # Adds methods to core openHAB AbstractUID to make it more natural in Ruby
9
8
  class AbstractUID
10
9
  # implicit conversion to string
11
- alias to_str to_s
10
+ alias_method :to_str, :to_s
12
11
  # inspect result is just the string representation
13
- alias inspect to_s
12
+ alias_method :inspect, :to_s
14
13
 
15
14
  # compares if equal to `other`, including string conversion
16
15
  # @return [true, false]
@@ -21,24 +20,6 @@ module OpenHAB
21
20
  end
22
21
  end
23
22
 
24
- # Adds methods to core OpenHAB ThingUID to make it more natural in Ruby
25
- class ThingUID
26
- # Returns the id of the binding this thing belongs to
27
- # @return [String]
28
- def binding_id
29
- get_segment(0)
30
- end
31
- end
32
-
33
- # Adds methods to core OpenHAB ThingTypeUID to make it more natural in Ruby
34
- class ThingTypeUID
35
- # Returns the id of the binding this thing type belongs to
36
- # @return [String]
37
- def binding_id
38
- get_segment(0)
39
- end
40
- end
41
-
42
23
  # have to remove == from all descendant classes so that they'll inherit
43
24
  # the new implementation
44
25
  [org.openhab.core.items.MetadataKey,
@@ -0,0 +1,188 @@
1
+ # frozen_string_literal: true
2
+
3
+ OpenHAB::Core.import_preset("cache")
4
+ unless defined?($sharedCache)
5
+ $sharedCache = nil
6
+ return
7
+ end
8
+
9
+ module OpenHAB
10
+ module Core
11
+ # @interface
12
+ java_import org.openhab.core.automation.module.script.rulesupport.shared.ValueCache
13
+
14
+ #
15
+ # ValueCache is the interface used to access a
16
+ # {OpenHAB::DSL.shared_cache shared cache} available between scripts and/or
17
+ # rule executions.
18
+ #
19
+ # While ValueCache looks somewhat like a Hash, it does not support
20
+ # iteration of the contained elements. So it's limited to strictly storing,
21
+ # fetching, or removing known elements.
22
+ #
23
+ # Shared caches are _not_ persisted between openHAB restarts. And in fact,
24
+ # if all scripts are unloaded that reference a particular key, that key is
25
+ # removed.
26
+ #
27
+ # @note Only the {OpenHAB::DSL.shared_cache sharedCache} is exposed in Ruby.
28
+ # For a private cache, simply use an instance variable. See
29
+ # {file:docs/ruby-basics.md#variables Instance Variables}.
30
+ #
31
+ # @note Because every script or UI rule gets it own JRuby engine instance,
32
+ # you cannot rely on being able to access Ruby objects between them. Only
33
+ # objects that implement a Java interface that's part of Java or openHAB
34
+ # Core (such as Hash implements {java.util.Map}, or other basic
35
+ # datatypes) can be reliably stored and accessed from the shared cache.
36
+ # Likewise, you can use the cache to access data from other scripting
37
+ # languages, but they'll be all but useless in Ruby. It's best to stick
38
+ # to simple data types. If you're having troubles, serializing to_json
39
+ # before storing may help.
40
+ #
41
+ # @see https://www.openhab.org/docs/configuration/jsr223.html#cache-preset openHAB Cache Preset
42
+ #
43
+ # @example
44
+ # shared_cache.compute_if_absent(:execution_count) { 0 }
45
+ # shared_cache[:execution_count] += 1
46
+ #
47
+ module ValueCache
48
+ # @see https://docs.ruby-lang.org/en/master/Hash.html#method-i-5B-5D Hash#[]
49
+ def [](key)
50
+ get(key.to_s)
51
+ end
52
+
53
+ #
54
+ # Compute and store new value for key if the key is absent. This method is atomic.
55
+ #
56
+ # @param [String] key
57
+ # @yieldreturn [Object] new value
58
+ # @return [Object] new value or current value
59
+ #
60
+ def compute_if_absent(key, &block)
61
+ get(key.to_s, &block)
62
+ end
63
+
64
+ # @see https://docs.ruby-lang.org/en/master/Hash.html#method-i-5B-5D-3D Hash#[]=
65
+ def []=(key, value)
66
+ put(key.to_s, value)
67
+ end
68
+ alias_method :store, :[]
69
+
70
+ # @see https://docs.ruby-lang.org/en/master/Hash.html#method-i-delete Hash#delete
71
+ def delete(key)
72
+ key = key.to_s
73
+ if block_given?
74
+ fetch(key) do
75
+ return yield(key)
76
+ end
77
+ end
78
+ remove(key)
79
+ end
80
+
81
+ # @see https://docs.ruby-lang.org/en/master/Hash.html#method-i-fetch Hash#fetch
82
+ #
83
+ # @example
84
+ # shared_cache.fetch(:key_from_another_script) # raises NoKeyError
85
+ #
86
+ def fetch(key, *default_value)
87
+ if default_value.length > 1
88
+ raise ArgumentError,
89
+ "wrong number of arguments (given #{default_value.length + 1}, expected 0..1)"
90
+ end
91
+
92
+ key = key.to_s
93
+ if default_value.empty?
94
+ if block_given?
95
+ get(key) do
96
+ return yield(key)
97
+ end
98
+ else
99
+ get(key) do
100
+ raise KeyError.new("key not found: #{key.inspect}", key: key)
101
+ end
102
+ end
103
+ else
104
+ get(key) { return default_value.first }
105
+ end
106
+ end
107
+
108
+ # @see https://docs.ruby-lang.org/en/master/Hash.html#method-i-assoc Hash#assoc
109
+ def assoc(key)
110
+ [key, fetch(key) do
111
+ # return nil directly, without storing a value to the cache
112
+ return nil
113
+ end]
114
+ end
115
+
116
+ # @see https://docs.ruby-lang.org/en/master/Hash.html#method-i-dig Hash#dig
117
+ def dig(key, *identifiers)
118
+ r = fetch(key) { return nil }
119
+ r&.dig(*identifiers)
120
+ end
121
+
122
+ # @see https://docs.ruby-lang.org/en/master/Hash.html#method-i-fetch_values Hash#fetch_values
123
+ def fetch_values(*keys, &block)
124
+ result = []
125
+ keys.each do |key|
126
+ if block
127
+ result << fetch(key, &block)
128
+ else
129
+ has_value = true
130
+ value = fetch(key) { has_value = false }
131
+ result << value if has_value
132
+ end
133
+ end
134
+ result
135
+ end
136
+
137
+ # @see https://docs.ruby-lang.org/en/master/Hash.html#method-i-key-3F Hash#key?
138
+ def key?(key)
139
+ !!fetch(key) { return false }
140
+ end
141
+ alias_method :has_key?, :key?
142
+ alias_method :include?, :key?
143
+ alias_method :member?, :key?
144
+
145
+ # @see https://docs.ruby-lang.org/en/master/Hash.html#method-i-merge-21 Hash#merge!
146
+ def merge!(*other_hashes)
147
+ other_hashes.each do |hash|
148
+ hash.each do |(k, v)|
149
+ k = k.to_s
150
+ if block_given?
151
+ dup = true
152
+ old_value = fetch(k) do
153
+ dup = false
154
+ end
155
+ self[k] = dup ? yield(k, old_value, v) : v
156
+ else
157
+ self[k] = v
158
+ end
159
+ end
160
+ end
161
+ self
162
+ end
163
+ alias_method :update, :merge!
164
+
165
+ # @see https://docs.ruby-lang.org/en/master/Hash.html#method-i-slice Hash#slice
166
+ def slice(*keys)
167
+ result = {}
168
+ keys.each do |k|
169
+ k = k.to_s
170
+ result[k] = self[k] if key?(k)
171
+ end
172
+ result
173
+ end
174
+
175
+ # @see https://docs.ruby-lang.org/en/master/Hash.html#method-i-to_proc Hash#to_proc
176
+ def to_proc
177
+ @to_proc ||= ->(k) { self[k] }
178
+ end
179
+
180
+ # @see https://docs.ruby-lang.org/en/master/Hash.html#method-i-values_at Hash#values_at
181
+ def values_at(*keys)
182
+ keys.map do |k|
183
+ self[k]
184
+ end
185
+ end
186
+ end
187
+ end
188
+ end
@@ -0,0 +1,98 @@
1
+ # frozen_string_literal: true
2
+
3
+ module OpenHAB
4
+ # Contains classes and modules that wrap actual openHAB objects
5
+ module Core
6
+ # The openHAB Version. >= 3.4.0 is required.
7
+ # @return [String]
8
+ VERSION = org.openhab.core.OpenHAB.version.freeze
9
+
10
+ raise "`openhab-scripting` requires openHAB >= 3.4.0" unless Gem::Version.new(VERSION) >= Gem::Version.new("3.4.0")
11
+
12
+ # @return [Integer] Number of seconds to wait between checks for automation manager
13
+ CHECK_DELAY = 10
14
+ private_constant :CHECK_DELAY
15
+ class << self
16
+ #
17
+ # Wait until openHAB engine ready to process
18
+ #
19
+ # @return [void]
20
+ #
21
+ # @!visibility private
22
+ def wait_till_openhab_ready
23
+ logger.trace("Checking readiness of openHAB")
24
+ until automation_manager
25
+ logger.trace("Automation manager not loaded, checking again in #{CHECK_DELAY} seconds.")
26
+ sleep CHECK_DELAY
27
+ end
28
+ logger.trace "Automation manager instantiated, openHAB ready for rule processing."
29
+ end
30
+
31
+ #
32
+ # @!attribute [r] config_folder
33
+ # @return [Pathname] The configuration folder path.
34
+ #
35
+ def config_folder
36
+ Pathname.new(org.openhab.core.OpenHAB.config_folder)
37
+ end
38
+
39
+ #
40
+ # @!attribute [r] automation_manager
41
+ # @return [org.openhab.core.automation.module.script.rulesupport.shared.ScriptedAutomationManager]
42
+ # The openHAB Automation manager.
43
+ #
44
+ def automation_manager
45
+ $se.get("automationManager")
46
+ end
47
+
48
+ #
49
+ # Imports a specific script extension preset into the global namespace
50
+ #
51
+ # @param [String] preset
52
+ # @return [void]
53
+ #
54
+ def import_preset(preset)
55
+ import_scope_values($se.import_preset(preset))
56
+ end
57
+
58
+ #
59
+ # Imports all default script extension presets into the global namespace
60
+ #
61
+ # @!visibility private
62
+ # @return [void]
63
+ #
64
+ def import_default_presets
65
+ $se.default_presets.each { |preset| import_preset(preset) }
66
+ end
67
+
68
+ #
69
+ # Imports concrete scope values into the global namespace
70
+ #
71
+ # @param [java.util.Map<String, Object>] scope_values
72
+ # @!visibility private
73
+ # @return [void]
74
+ #
75
+ def import_scope_values(scope_values)
76
+ scope_values.for_each do |key, value|
77
+ # convert Java classes to Ruby classes
78
+ value = value.ruby_class if value.is_a?(java.lang.Class) # rubocop:disable Lint/UselessAssignment
79
+ # variables are globals; constants go into the global namespace
80
+ key = case key[0]
81
+ when "a".."z" then "$#{key}"
82
+ when "A".."Z" then "::#{key}"
83
+ end
84
+ eval("#{key} = value unless defined?(#{key})", nil, __FILE__, __LINE__) # rubocop:disable Security/Eval
85
+ end
86
+ end
87
+ end
88
+
89
+ import_default_presets unless defined?($ir)
90
+ end
91
+ end
92
+
93
+ # several classes rely on this, so force it to load earlier
94
+ require_relative "core/provider"
95
+
96
+ Dir[File.expand_path("core/**/*.rb", __dir__)].sort.each do |f|
97
+ require f
98
+ end
@@ -0,0 +1,32 @@
1
+ # frozen_string_literal: true
2
+
3
+ module OpenHAB
4
+ module CoreExt
5
+ # Extensions that apply to both Date and Time classes
6
+ module Between
7
+ #
8
+ # Checks whether the the object falls between the given range.
9
+ #
10
+ # @overload between?(min, max)
11
+ # @param [Object] min The minimum value to check, inclusive
12
+ # @param [Object] max The maximum value to check, inclusive
13
+ # @return [true,false]
14
+ #
15
+ # @overload between?(range)
16
+ # @param [Range] range A range to check
17
+ # @return [true,false]
18
+ #
19
+ def between?(min, max = nil)
20
+ range = if max
21
+ Range.new(min, max, false)
22
+ else
23
+ raise ArgumentError, "Expecting a range when given a single argument" unless min.is_a?(Range)
24
+
25
+ min
26
+ end
27
+
28
+ OpenHAB::DSL.between(range).cover?(self)
29
+ end
30
+ end
31
+ end
32
+ end
@@ -0,0 +1,53 @@
1
+ # frozen_string_literal: true
2
+
3
+ module OpenHAB
4
+ module CoreExt
5
+ #
6
+ # Forwards ephemeris helper methods to `#to_zoned_date_time` provided by
7
+ # the mixed-in class.
8
+ #
9
+ # @note openHAB's built-in holiday definitions are based on _bank_
10
+ # holidays, so may give some unexpected results. For example, 2022-12-25
11
+ # is _not_ Christmas in England because it lands on a Sunday that year,
12
+ # so Christmas is considered to be 2022-12-26. See
13
+ # [the source](https://github.com/svendiedrichsen/jollyday/tree/master/src/main/resources/holidays)
14
+ # for exact definitions. You can always provide your own holiday
15
+ # definitions with {OpenHAB::DSL.holiday_file holiday_file} or
16
+ # {OpenHAB::DSL.holiday_file! holiday_file!}.
17
+ #
18
+ # @see https://www.openhab.org/docs/configuration/actions.html#ephemeris Ephemeris Action
19
+ # @see Core::Actions::Ephemeris.holiday_name Ephemeris.holiday_name
20
+ #
21
+ module Ephemeris
22
+ # (see Java::ZonedDateTime#holiday)
23
+ def holiday(holiday_file = nil)
24
+ to_zoned_date_time.holiday(holiday_file)
25
+ end
26
+
27
+ # (see Java::ZonedDateTime#holiday?)
28
+ def holiday?(holiday_file = nil)
29
+ to_zoned_date_time.holiday?(holiday_file)
30
+ end
31
+
32
+ # (see Java::ZonedDateTime#next_holiday)
33
+ def next_holiday(holiday_file = nil)
34
+ to_zoned_date_time.next_holiday(holiday_file)
35
+ end
36
+
37
+ # (see Java::ZonedDateTime#weekend?)
38
+ def weekend?
39
+ to_zoned_date_time.weekend?
40
+ end
41
+
42
+ # (see Java::ZonedDateTime#in_dayset?)
43
+ def in_dayset?(set)
44
+ to_zoned_date_time.in_dayset?(set)
45
+ end
46
+
47
+ # (see Java::ZonedDateTime#days_until)
48
+ def days_until(holiday, holiday_file = nil)
49
+ to_zoned_date_time.days_until(holiday, holiday_file)
50
+ end
51
+ end
52
+ end
53
+ end
@@ -0,0 +1,34 @@
1
+ # frozen_string_literal: true
2
+
3
+ module OpenHAB
4
+ module CoreExt
5
+ module Java
6
+ Class = java.lang.Class
7
+
8
+ # Extensions to Class
9
+ class Class
10
+ #
11
+ # `self`, all superclasses and interfaces, recursively.
12
+ #
13
+ # @return [Array<Class>]
14
+ #
15
+ def ancestors
16
+ ([self] +
17
+ Array(superclass&.ancestors) +
18
+ interfaces.flat_map(&:ancestors)).uniq
19
+ end
20
+
21
+ #
22
+ # `self`, all superclasses and interfaces, recursively.
23
+ #
24
+ # @return [Array<java.lang.reflect.Type>]
25
+ #
26
+ def generic_ancestors
27
+ ancestors.flat_map do |klass|
28
+ Array(klass.generic_superclass) + klass.generic_interfaces
29
+ end.uniq
30
+ end
31
+ end
32
+ end
33
+ end
34
+ end