]>
git.ipfire.org Git - people/ms/network.git/blob - functions.service
6b5b73c9aea14f53c4cb4cb9955cba61ab877733
2 ###############################################################################
4 # IPFire.org - A linux based firewall #
5 # Copyright (C) 2010 Michael Tremer & Christian Schmidt #
7 # This program is free software: you can redistribute it and/or modify #
8 # it under the terms of the GNU General Public License as published by #
9 # the Free Software Foundation, either version 3 of the License, or #
10 # (at your option) any later version. #
12 # This program is distributed in the hope that it will be useful, #
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of #
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
15 # GNU General Public License for more details. #
17 # You should have received a copy of the GNU General Public License #
18 # along with this program. If not, see <http://www.gnu.org/licenses/>. #
20 ###############################################################################
22 function service_start
() {
26 systemctl start
${name}
28 # Check, if the service was successfully started and
29 # return a proper exit code.
30 service_is_active
${name}
33 log INFO
"Started service '${name}', code=${ret}."
38 function service_stop
() {
42 systemctl stop
${name}
45 function service_restart
() {
49 systemctl restart
${name}
52 function service_reload
() {
56 if service_status
${name}; then
57 systemctl reload
${name}
60 log WARNING
"Cannot reload service '${name}' which is currently not running."
64 function service_status
() {
68 systemctl status
${name} >/dev
/null
2>&1
72 # This function calls the "enable" command from systemd,
73 # to mark services to be automatically started during
75 function service_enable
() {
79 systemctl
enable "${name}" >/dev
/null
2>&1
82 # This function calls the "disable" command of systemd,
83 # to drop the autostart ability of the service during the
85 function service_disable
() {
89 systemctl disable
"${name}" >/dev
/null
2>&1
92 # This function uses the systemd command "is-enabled" to check,
93 # if a service has been enabled or not.
94 function service_is_enabled
() {
98 systemctl is-enabled
"${name}" >/dev
/null
2>&1
102 function service_is_active
() {
106 systemctl is-active
${name}.service
>/dev
/null
2>&1
110 function service_get_exitcode
() {
114 local output
=$
(systemctl show
${name} --property="ExecMainStatus")
115 cli_get_val
"${output}"