diff mbox series

[5/5] procd: add api wrapper

Message ID 20201202145233.10463-6-fe@dev.tdt.de
State Superseded
Headers show
Series ubus: extend the service object with a restart method | expand

Commit Message

Florian Eckert Dec. 2, 2020, 2:52 p.m. UTC
This commit add a wrapper for procd services, to add a callback script
if the "service.restart" trigger event was fired.

Example:

service_trigger() {
	procd_add_trigger
	procd_add service_trigger "service.restart" "firewall" <script>
	procd_close_trigger
}

If the firewall was restart, then the stored script gets executed.

Signed-off-by: Florian Eckert <fe@dev.tdt.de>
---
 package/system/procd/files/procd.sh | 23 +++++++++++++++++++++++
 1 file changed, 23 insertions(+)

Comments

John Crispin Dec. 2, 2020, 6:24 p.m. UTC | #1
can we augment we augment the procd_add_trigger/procd_close_trigger into 
the helper such as reload_trigger() does ?

     John

On 02.12.20 15:52, Florian Eckert wrote:
> This commit add a wrapper for procd services, to add a callback script
> if the "service.restart" trigger event was fired.
>
> Example:
>
> service_trigger() {
> 	procd_add_trigger
> 	procd_add service_trigger "service.restart" "firewall" <script>
> 	procd_close_trigger
> }
>
> If the firewall was restart, then the stored script gets executed.
>
> Signed-off-by: Florian Eckert <fe@dev.tdt.de>
> ---
>   package/system/procd/files/procd.sh | 23 +++++++++++++++++++++++
>   1 file changed, 23 insertions(+)
>
> diff --git a/package/system/procd/files/procd.sh b/package/system/procd/files/procd.sh
> index d86b7219da..9076ddba5d 100644
> --- a/package/system/procd/files/procd.sh
> +++ b/package/system/procd/files/procd.sh
> @@ -329,6 +329,28 @@ _procd_add_config_trigger() {
>   	json_close_array
>   }
>   
> +_procd_add_service_trigger() {
> +	json_add_array
> +	_procd_add_array_data "$1"
> +	shift
> +
> +	json_add_array
> +	_procd_add_array_data "if"
> +
> +	json_add_array
> +	_procd_add_array_data "eq" "service" "$1"
> +	shift
> +	json_close_array
> +
> +	json_add_array
> +	_procd_add_array_data "run_script" "$@"
> +	json_close_array
> +
> +	json_close_array
> +	_procd_add_timeout
> +	json_close_array
> +}
> +
>   _procd_add_raw_trigger() {
>   	json_add_array
>   	_procd_add_array_data "$1"
> @@ -559,6 +581,7 @@ _procd_wrapper \
>   	procd_add_instance \
>   	procd_add_raw_trigger \
>   	procd_add_config_trigger \
> +	procd_add_service_trigger \
>   	procd_add_interface_trigger \
>   	procd_add_reload_trigger \
>   	procd_add_reload_interface_trigger \
diff mbox series

Patch

diff --git a/package/system/procd/files/procd.sh b/package/system/procd/files/procd.sh
index d86b7219da..9076ddba5d 100644
--- a/package/system/procd/files/procd.sh
+++ b/package/system/procd/files/procd.sh
@@ -329,6 +329,28 @@  _procd_add_config_trigger() {
 	json_close_array
 }
 
+_procd_add_service_trigger() {
+	json_add_array
+	_procd_add_array_data "$1"
+	shift
+
+	json_add_array
+	_procd_add_array_data "if"
+
+	json_add_array
+	_procd_add_array_data "eq" "service" "$1"
+	shift
+	json_close_array
+
+	json_add_array
+	_procd_add_array_data "run_script" "$@"
+	json_close_array
+
+	json_close_array
+	_procd_add_timeout
+	json_close_array
+}
+
 _procd_add_raw_trigger() {
 	json_add_array
 	_procd_add_array_data "$1"
@@ -559,6 +581,7 @@  _procd_wrapper \
 	procd_add_instance \
 	procd_add_raw_trigger \
 	procd_add_config_trigger \
+	procd_add_service_trigger \
 	procd_add_interface_trigger \
 	procd_add_reload_trigger \
 	procd_add_reload_interface_trigger \