[OpenWrt-Devel] new functionality for service shell function

Petr Štetiar ynezz at true.cz
Wed Jun 3 06:16:58 EDT 2020


Stan Grishin <stangri at melmac.net> [2020-04-13 04:16:25]:

Hi,

> I've been using something similar on my system and propose the following
> patch (first submission to the list, be gentle ;)):

no worries, just read https://openwrt.org/submitting-patches and try again :-)

Commit subject should be "base-files: ..." and mail "Subject: [PATCH]
base-files: ...", easily done with `git format-patch -s1 ...`, then `git
send-email` and you're done.

Please add as well some proper commit description.

Thanks.

-- ynezz

> diff --git a/package/base-files/files/etc/profile
> b/package/base-files/files/etc/profile
> index 0beff1608f..e8350cfd6a 100644
> --- a/package/base-files/files/etc/profile
> +++ b/package/base-files/files/etc/profile
> @@ -38,3 +38,24 @@ in order to prevent unauthorized SSH logins.
>  --------------------------------------------------
>  EOF
>  fi
> +
> +service() {
> +        if [ "$1" = "list-enabled" ]; then
> +                for F in /etc/init.d/* ; do
> +                        $F enabled && echo "$F enabled"
> +                done;
> +        elif [ "$1" = "list-disabled" ]; then
> +                for F in /etc/init.d/* ; do
> +                        $F enabled || echo "$F disabled"
> +                done;
> +        elif [ -f "/etc/init.d/$1" ]; then
> +                /etc/init.d/$@
> +        else
> +                echo "Usage: service list-disabled|list-enabled|<service>
> [command]"
> +                if [ -n "$1" ]; then
> +                        echo "service "'"'"$1"'"'" not found, the
> following services are available:"
> +                        ls "/etc/init.d"
> +                fi
> +                return 1
> +        fi
> +}
> diff --git a/package/base-files/files/etc/rc.common
> b/package/base-files/files/etc/rc.common
> index 7c11544405..c44614d757 100755
> --- a/package/base-files/files/etc/rc.common
> +++ b/package/base-files/files/etc/rc.common
> @@ -67,13 +67,14 @@ help() {
>  Syntax: $initscript [command]
> 
>  Available commands:
> - start Start the service
> - stop Stop the service
> - restart Restart the service
> - reload Reload configuration files (or restart if service does not
> implement reload)
> - enable Enable service autostart
> - disable Disable service autostart
> - enabled Check if service is started on boot
> + start Start the service
> + stop Stop the service
> + restart Restart the service
> + reload Reload configuration files (or restart if service does not
> implement reload)
> + enable Enable service autostart
> + disable Disable service autostart
> + enabled Check if service is started on boot
> + status-ubus Show ubus info for the service
>  $EXTRA_HELP
>  EOF
>  }
> @@ -165,6 +166,13 @@ ${EXTRA_HELP}"
>   }
>  }
> 
> -ALL_COMMANDS="start stop reload restart boot shutdown enable disable
> enabled depends ${EXTRA_COMMANDS}"
> -list_contains ALL_COMMANDS "$action" || action=help
> +status_ubus() {
> + name="$(basename "${initscript}")"
> + /bin/ubus call service list "{'name': '$name'}"
> + return 0
> +}
> +
> +ALL_COMMANDS="start stop reload restart boot shutdown enable disable
> enabled depends status-ubus ${EXTRA_COMMANDS}"
> +list_contains ALL_COMMANDS "$action" && action="${action/-/_}" ||
> action=help
>  $action "$@"
> +

_______________________________________________
openwrt-devel mailing list
openwrt-devel at lists.openwrt.org
https://lists.openwrt.org/mailman/listinfo/openwrt-devel



More information about the openwrt-devel mailing list