"") { eval("\$rc={$aservice['custom_php_service_status_command']};"); return $rc; } if (empty($aservice['executable'])) { return false; } if (is_process_running($aservice['executable'])) { return true; } return false; } } } if (is_process_running($service)) { return true; } return false; } function get_services() { global $config; if (is_array($config['installedpackages']['service'])) { $services = $config['installedpackages']['service']; } else { $services = array(); } /* * Add services that are in the base. */ if (is_radvd_enabled()) { $pconfig = array(); $pconfig['name'] = "radvd"; $pconfig['description'] = gettext("Router Advertisement Daemon"); $services[] = $pconfig; } if (isset($config['dnsmasq']['enable'])) { $pconfig = array(); $pconfig['name'] = "dnsmasq"; $pconfig['description'] = gettext("DNS Forwarder"); $services[] = $pconfig; } if (isset($config['unbound']['enable'])) { $pconfig = array(); $pconfig['name'] = "unbound"; $pconfig['description'] = gettext("DNS Resolver"); $services[] = $pconfig; } $pconfig = array(); $pconfig['name'] = "ntpd"; $pconfig['description'] = gettext("NTP clock sync"); $services[] = $pconfig; $pconfig = array(); $pconfig['name'] = "syslogd"; $pconfig['description'] = gettext("System Logger Daemon"); $services[] = $pconfig; if (is_array($config['captiveportal'])) { foreach ($config['captiveportal'] as $zone => $setting) { if (isset($setting['enable'])) { $pconfig = array(); $pconfig['name'] = "captiveportal"; $pconfig['zone'] = $zone; $pconfig['description'] = gettext("Captive Portal") . ": " . htmlspecialchars($setting['zone']); $services[] = $pconfig; } } } $iflist = array(); $ifdescrs = get_configured_interface_list(); foreach ($ifdescrs as $if) { $oc = $config['interfaces'][$if]; if ($oc['if'] && (!link_interface_to_bridge($if))) { $iflist[$if] = $if; } } if (isset($config['dhcrelay']['enable'])) { $pconfig = array(); $pconfig['name'] = "dhcrelay"; $pconfig['description'] = gettext("DHCP Relay"); $services[] = $pconfig; } if (isset($config['dhcrelay6']['enable'])) { $pconfig = array(); $pconfig['name'] = "dhcrelay6"; $pconfig['description'] = gettext("DHCPv6 Relay"); $services[] = $pconfig; } if (is_dhcp_server_enabled()) { $pconfig = array(); $pconfig['name'] = "dhcpd"; $pconfig['description'] = gettext("DHCP Service"); $services[] = $pconfig; } $gateways_arr = return_gateways_array(); if (is_array($gateways_arr)) { $pconfig = array(); $pconfig['name'] = "dpinger"; $pconfig['description'] = gettext("Gateway Monitoring Daemon"); $services[] = $pconfig; } if (isset($config['snmpd']['enable'])) { $pconfig = array(); $pconfig['name'] = "bsnmpd"; $pconfig['description'] = gettext("SNMP Service"); $services[] = $pconfig; } if (is_array($config['igmpproxy']['igmpentry']) && (count($config['igmpproxy']['igmpentry']) > 0)) { $pconfig = array(); $pconfig['name'] = "igmpproxy"; $pconfig['description'] = gettext("IGMP proxy"); $services[] = $pconfig; } if (isset($config['installedpackages']['miniupnpd']) && $config['installedpackages']['miniupnpd']['config'][0]['enable']) { $pconfig = array(); $pconfig['name'] = "miniupnpd"; $pconfig['description'] = gettext("UPnP Service"); $services[] = $pconfig; } if (ipsec_enabled()) { $pconfig = array(); $pconfig['name'] = "ipsec"; $pconfig['description'] = gettext("IPsec VPN"); $services[] = $pconfig; } if (isset($config['system']['enablesshd'])) { $pconfig = array(); $pconfig['name'] = "sshd"; $pconfig['description'] = gettext("Secure Shell Daemon"); $services[] = $pconfig; } foreach (array('server', 'client') as $mode) { if (is_array($config['openvpn']["openvpn-{$mode}"])) { foreach ($config['openvpn']["openvpn-{$mode}"] as $id => $setting) { if (!isset($setting['disable'])) { $pconfig = array(); $pconfig['name'] = "openvpn"; $pconfig['mode'] = $mode; $pconfig['id'] = $id; $pconfig['vpnid'] = $setting['vpnid']; $pconfig['description'] = gettext("OpenVPN") . " " . $mode . ": " . htmlspecialchars($setting['description']); $services[] = $pconfig; } } } } if (count($config['load_balancer']['virtual_server']) && count($config['load_balancer']['lbpool'])) { $pconfig = array(); $pconfig['name'] = "relayd"; $pconfig['description'] = gettext("Server load balancing daemon"); $services[] = $pconfig; } return $services; } function find_service_by_name($name) { $services = get_services(); foreach ($services as $service) { if ($service["name"] == $name) { return $service; } } return array(); } function find_service_by_openvpn_vpnid($vpnid) { $services = get_services(); foreach ($services as $service) { if (($service["name"] == "openvpn") && isset($service["vpnid"]) && ($service["vpnid"] == $vpnid)) { return $service; } } return array(); } function find_service_by_cp_zone($zone) { $services = get_services(); foreach ($services as $service) { if (($service["name"] == "captiveportal") && isset($service["zone"]) && ($service["zone"] == $zone)) { return $service; } } return array(); } function service_name_compare($a, $b) { if (strtolower($a['name']) == strtolower($b['name'])) { return 0; } return (strtolower($a['name']) < strtolower($b['name'])) ? -1 : 1; } function service_dispname_compare($a, $b) { if (strtolower($a['dispname']) == strtolower($b['dispname'])) { return 0; } return (strtolower($a['name']) < strtolower($b['name'])) ? -1 : 1; } function get_pkg_descr($package_name) { global $config; if (is_array($config['installedpackages']['package'])) { foreach ($config['installedpackages']['package'] as $pkg) { if ($pkg['name'] == $package_name) { return $pkg['descr']; } } } return gettext("Not available."); } function get_service_status($service) { global $g; switch ($service['name']) { case "openvpn": $running = is_pid_running("{$g['varrun_path']}/openvpn_{$service['mode']}{$service['vpnid']}.pid"); break; case "captiveportal": $running = is_pid_running("{$g['varrun_path']}/nginx-{$service['zone']}-CaptivePortal.pid"); if (isset($config['captiveportal'][$service['zone']]['httpslogin'])) { $running = $running && is_pid_running("{$g['varrun_path']}/nginx-{$service['zone']}-CaptivePortal-SSL.pid"); } break; case "vhosts-http": $running = is_pid_running("{$g['varrun_path']}/vhosts-http.pid"); break; case "dhcrelay6": $running = is_pid_running("{$g['varrun_path']}/dhcrelay6.pid"); break; case 'ipsec': $running = is_pid_running("{$g['varrun_path']}/charon.pid"); break; default: $running = is_service_running($service['name']); } return $running; } function get_service_status_icon($service, $withtext = true, $smallicon = false, $withthumbs = false, $title = "service_state") { $output = ""; if (get_service_status($service)) { $statustext = gettext("Running"); $text_class = "text-success"; $fa_class = "fa fa-check-circle"; $fa_class_thumbs = "fa fa-thumbs-o-up"; $Thumbs_UpDown = "Thumbs up"; } else { if (is_service_enabled($service['name'])) { $statustext = gettext("Stopped"); $text_class = "text-danger"; $fa_class = "fa fa-times-circle"; } else { $statustext = gettext("Disabled"); $text_class = "text-warning"; $fa_class = "fa fa-ban"; } $fa_class_thumbs = "fa fa-thumbs-o-down"; $Thumbs_UpDown = "Thumbs down"; } $fa_size = ($smallicon) ? "fa-1x" : "fa-lg"; if ($title == "state") { $title = $statustext; } elseif ($title == "service_state") { $title = sprintf(gettext('%1$s Service is %2$s'), $service["name"], $statustext); } elseif ($title == "description_state") { $title = sprintf(gettext('%1$s Service is %2$s'), $service["description"], $statustext); } elseif ($title == "description_service_state") { $title = sprintf(gettext('%1$s, %2$s Service is %3$s'), $service["description"], $service["name"], $statustext); } $spacer = ($withthumbs || $withtext) ? " " : ""; $output = "{$statustext}{$spacer}"; $spacer = ($withtext) ? " " : ""; if ($withthumbs) { $output .= "{$spacer}"; } if ($withtext) { $output .= "" . $statustext . ""; } return $output; } function get_service_control_links($service, $addname = false) { global $g; $output = ""; $stitle = ($addname) ? $service['name'] . " " : ""; switch ($service['name']) { case "openvpn": $link = ''; break; case "captiveportal": $link = ''; break; default: $link = ''; } if (get_service_status($service)) { switch ($service['name']) { case "openvpn": $output .= ''; break; case "captiveportal": $output .= ''; break; default: $output .= ''; } $output .= "\n"; switch ($service['name']) { case "openvpn": $output .= ''; break; case "captiveportal": $output .= ''; break; default: $output .= ''; } $output .= ""; } else { $service_enabled = is_service_enabled($service['name']); if ($service['name'] == 'openvpn' || $service['name'] == 'captiveportal' || $service_enabled) { $output .= sprintf($link, sprintf(gettext("Start %sService"), $stitle), 'startservice'); $output .= ' '; } } return $output; } function service_control_start($name, $extras) { global $g; switch ($name) { case 'radvd': services_radvd_configure(); break; case 'captiveportal': $zone = htmlspecialchars($extras['zone']); captiveportal_init_webgui_zonename($zone); break; case 'ntpd': system_ntp_configure(); break; case 'dpinger': setup_gateways_monitor(); break; case 'bsnmpd': services_snmpd_configure(); break; case 'dhcrelay': services_dhcrelay_configure(); break; case 'dhcrelay6': services_dhcrelay6_configure(); break; case 'dnsmasq': services_dnsmasq_configure(); break; case 'unbound': services_unbound_configure(); break; case 'dhcpd': services_dhcpd_configure(); break; case 'igmpproxy': services_igmpproxy_configure(); break; case 'miniupnpd': upnp_action('start'); break; case 'ipsec': vpn_ipsec_force_reload(); break; case 'sshd': send_event("service restart sshd"); break; case 'openvpn': $vpnmode = isset($extras['vpnmode']) ? htmlspecialchars($extras['vpnmode']) : htmlspecialchars($extras['mode']); if (($vpnmode == "server") || ($vpnmode == "client")) { $id = isset($extras['vpnid']) ? htmlspecialchars($extras['vpnid']) : htmlspecialchars($extras['id']); $configfile = "{$g['varetc_path']}/openvpn/{$vpnmode}{$id}.conf"; if (file_exists($configfile)) { openvpn_restart_by_vpnid($vpnmode, $id); } } break; case 'relayd': relayd_configure(); filter_configure(); break; case 'syslogd': system_syslogd_start(); break; default: start_service($name); break; } return sprintf(gettext("%s has been started."), htmlspecialchars($name)); } function service_control_stop($name, $extras) { global $g; switch ($name) { case 'radvd': killbypid("{$g['varrun_path']}/radvd.pid"); break; case 'captiveportal': $zone = htmlspecialchars($extras['zone']); killbypid("{$g['varrun_path']}/nginx-{$zone}-CaptivePortal.pid"); killbypid("{$g['varrun_path']}/nginx-{$zone}-CaptivePortal-SSL.pid"); break; case 'ntpd': killbyname("ntpd"); break; case 'openntpd': killbyname("openntpd"); break; case 'dpinger': stop_dpinger(); break; case 'bsnmpd': killbypid("{$g['varrun_path']}/snmpd.pid"); break; case 'choparp': killbyname("choparp"); break; case 'dhcpd': killbyname("dhcpd"); break; case 'dhcrelay': killbypid("{$g['varrun_path']}/dhcrelay.pid"); break; case 'dhcrelay6': killbypid("{$g['varrun_path']}/dhcrelay6.pid"); break; case 'dnsmasq': killbypid("{$g['varrun_path']}/dnsmasq.pid"); break; case 'unbound': killbypid("{$g['varrun_path']}/unbound.pid"); break; case 'igmpproxy': killbyname("igmpproxy"); break; case 'miniupnpd': upnp_action('stop'); break; case 'sshd': killbyname("sshd"); break; case 'ipsec': exec("/usr/local/sbin/ipsec stop"); break; case 'openvpn': $vpnmode = htmlspecialchars($extras['vpnmode']); if (($vpnmode == "server") or ($vpnmode == "client")) { $id = htmlspecialchars($extras['id']); $pidfile = "{$g['varrun_path']}/openvpn_{$vpnmode}{$id}.pid"; killbypid($pidfile); } break; case 'relayd': sigkillbyname("relayd", "TERM"); break; case 'syslogd': if (isvalidpid("{$g['varrun_path']}/syslog.pid")) { sigkillbypid("{$g['varrun_path']}/syslog.pid", "TERM"); usleep(100000); } if (isvalidpid("{$g['varrun_path']}/syslog.pid")) { sigkillbypid("{$g['varrun_path']}/syslog.pid", "KILL"); usleep(100000); } break; default: stop_service($name); break; } return sprintf(gettext("%s has been stopped."), htmlspecialchars($name)); } function service_control_restart($name, $extras) { global $g; switch ($name) { case 'radvd': services_radvd_configure(); break; case 'captiveportal': $zone = htmlspecialchars($extras['zone']); killbypid("{$g['varrun_path']}/nginx-{$zone}-CaptivePortal.pid"); killbypid("{$g['varrun_path']}/nginx-{$zone}-CaptivePortal-SSL.pid"); captiveportal_init_webgui_zonename($zone); break; case 'ntpd': case 'openntpd': system_ntp_configure(); break; case 'dpinger': setup_gateways_monitor(); break; case 'bsnmpd': services_snmpd_configure(); break; case 'dhcrelay': services_dhcrelay_configure(); break; case 'dhcrelay6': services_dhcrelay6_configure(); break; case 'dnsmasq': services_dnsmasq_configure(); break; case 'unbound': services_unbound_configure(); break; case 'dhcpd': services_dhcpd_configure(); break; case 'igmpproxy': services_igmpproxy_configure(); break; case 'miniupnpd': upnp_action('restart'); break; case 'ipsec': vpn_ipsec_force_reload(); break; case 'sshd': send_event("service restart sshd"); break; case 'openvpn': $vpnmode = htmlspecialchars($extras['vpnmode']); if ($vpnmode == "server" || $vpnmode == "client") { $id = htmlspecialchars($extras['id']); $configfile = "{$g['varetc_path']}/openvpn/{$vpnmode}{$id}.conf"; if (file_exists($configfile)) { openvpn_restart_by_vpnid($vpnmode, $id); } } break; case 'relayd': relayd_configure(true); filter_configure(); break; case 'syslogd': system_syslogd_start(); break; default: restart_service($name); break; } return sprintf(gettext("%s has been restarted."), htmlspecialchars($name)); } ?>