Commit ff49930e authored by Franco Fichtner's avatar Franco Fichtner

inc: tidy up util.inc

parent ecd61f25
...@@ -67,58 +67,63 @@ function killbyname($procname) ...@@ -67,58 +67,63 @@ function killbyname($procname)
} }
} }
function is_subsystem_dirty($subsystem = "") { function is_subsystem_dirty($subsystem = '')
global $g; {
if ($subsystem == '') {
if ($subsystem == "")
return false; return false;
}
if (file_exists("{$g['varrun_path']}/{$subsystem}.dirty")) if (file_exists("/var/run/{$subsystem}.dirty")) {
return true; return true;
}
return false; return false;
} }
function mark_subsystem_dirty($subsystem = "") { function mark_subsystem_dirty($subsystem = '')
global $g; {
if (!file_put_contents("/var/run/{$subsystem}.dirty", 'DIRTY')) {
if (!file_put_contents("{$g['varrun_path']}/{$subsystem}.dirty", "DIRTY"))
log_error(sprintf(gettext("WARNING: Could not mark subsystem: %s dirty"), $subsystem)); log_error(sprintf(gettext("WARNING: Could not mark subsystem: %s dirty"), $subsystem));
}
} }
function clear_subsystem_dirty($subsystem = "") { function clear_subsystem_dirty($subsystem = '')
global $g; {
@unlink("/var/run/{$subsystem}.dirty");
@unlink("{$g['varrun_path']}/{$subsystem}.dirty");
} }
/* lock configuration file */ /* lock configuration file */
function lock($lock, $op = LOCK_SH) { function lock($lock, $op = LOCK_SH)
global $g, $cfglckkeyconsumers; {
if (!$lock) if (!$lock) {
die(gettext("WARNING: You must give a name as parameter to lock() function.")); die(gettext("WARNING: You must give a name as parameter to lock() function."));
}
if (!file_exists("{/tmp/{$lock}.lock")) { if (!file_exists("{/tmp/{$lock}.lock")) {
@touch("/tmp/{$lock}.lock"); @touch("/tmp/{$lock}.lock");
@chmod("/tmp/{$lock}.lock", 0666); @chmod("/tmp/{$lock}.lock", 0666);
} }
$cfglckkeyconsumers++;
if ($fp = fopen("/tmp/{$lock}.lock", "w")) { if ($fp = fopen("/tmp/{$lock}.lock", "w")) {
if (flock($fp, $op)) if (flock($fp, $op)) {
return $fp; return $fp;
else } else {
fclose($fp); fclose($fp);
}
} }
} }
function try_lock($lock, $timeout = 5) { function try_lock($lock, $timeout = 5)
global $g, $cfglckkeyconsumers; {
if (!$lock) if (!$lock) {
die(gettext("WARNING: You must give a name as parameter to try_lock() function.")); die(gettext("WARNING: You must give a name as parameter to try_lock() function."));
}
if (!file_exists("/tmp/{$lock}.lock")) { if (!file_exists("/tmp/{$lock}.lock")) {
@touch("/tmp/{$lock}.lock"); @touch("/tmp/{$lock}.lock");
@chmod("/tmp/{$lock}.lock", 0666); @chmod("/tmp/{$lock}.lock", 0666);
} }
$cfglckkeyconsumers++;
if ($fp = fopen("/tmp/{$lock}.lock", "w")) { if ($fp = fopen("/tmp/{$lock}.lock", "w")) {
$trycounter = 0; $trycounter = 0;
while(!flock($fp, LOCK_EX | LOCK_NB)) { while(!flock($fp, LOCK_EX | LOCK_NB)) {
...@@ -137,17 +142,15 @@ function try_lock($lock, $timeout = 5) { ...@@ -137,17 +142,15 @@ function try_lock($lock, $timeout = 5) {
} }
/* unlock configuration file */ /* unlock configuration file */
function unlock($cfglckkey = 0) { function unlock($cfglckkey = 0)
global $g, $cfglckkeyconsumers; {
flock($cfglckkey, LOCK_UN); flock($cfglckkey, LOCK_UN);
fclose($cfglckkey); fclose($cfglckkey);
return;
} }
/* unlock forcefully configuration file */ /* unlock forcefully configuration file */
function unlock_force($lock) { function unlock_force($lock)
global $g; {
@unlink("/tmp/{$lock}.lock"); @unlink("/tmp/{$lock}.lock");
} }
...@@ -1044,8 +1047,6 @@ function get_interface_list($mode = "active", $keyby = "physical", $vfaces = "") ...@@ -1044,8 +1047,6 @@ function get_interface_list($mode = "active", $keyby = "physical", $vfaces = "")
******/ ******/
function log_error($error) function log_error($error)
{ {
global $g;
$page = $_SERVER['SCRIPT_NAME']; $page = $_SERVER['SCRIPT_NAME'];
if (empty($page)) { if (empty($page)) {
$files = get_included_files(); $files = get_included_files();
...@@ -1087,9 +1088,8 @@ function mwexecf($format, $args = array(), $mute = false, $clearsigmask = false) ...@@ -1087,9 +1088,8 @@ function mwexecf($format, $args = array(), $mute = false, $clearsigmask = false)
} }
/* wrapper for exec() */ /* wrapper for exec() */
function mwexec($command, $mute = false, $clearsigmask = false) { function mwexec($command, $mute = false, $clearsigmask = false)
global $g; {
$oarr = array(); $oarr = array();
$retval = 0; $retval = 0;
...@@ -1112,9 +1112,8 @@ function mwexec($command, $mute = false, $clearsigmask = false) { ...@@ -1112,9 +1112,8 @@ function mwexec($command, $mute = false, $clearsigmask = false) {
} }
/* wrapper for exec() in background */ /* wrapper for exec() in background */
function mwexec_bg($command, $clearsigmask = false) { function mwexec_bg($command, $clearsigmask = false)
global $g; {
if ($clearsigmask) { if ($clearsigmask) {
$oldset = array(); $oldset = array();
pcntl_sigprocmask(SIG_SETMASK, array(), $oldset); pcntl_sigprocmask(SIG_SETMASK, array(), $oldset);
...@@ -1372,10 +1371,9 @@ function format_bytes($bytes) { ...@@ -1372,10 +1371,9 @@ function format_bytes($bytes) {
} }
} }
function update_filter_reload_status($text) { function update_filter_reload_status($text)
global $g; {
file_put_contents('/var/run/filter_reload_status', $text);
file_put_contents("{$g['varrun_path']}/filter_reload_status", $text);
} }
/****** util/return_dir_as_array /****** util/return_dir_as_array
...@@ -1404,28 +1402,12 @@ function return_dir_as_array($dir, $filter_regex = '') { ...@@ -1404,28 +1402,12 @@ function return_dir_as_array($dir, $filter_regex = '') {
return $dir_array; return $dir_array;
} }
function run_plugins($directory) {
global $config, $g;
/* process packager manager custom rules */
$files = return_dir_as_array($directory);
if (is_array($files)) {
foreach ($files as $file) {
if (stristr($file, ".sh") == true)
mwexec($directory . $file . " start");
else if (!is_dir($directory . "/" . $file) && stristr($file,".inc"))
require_once($directory . "/" . $file);
}
}
}
/* /*
* safe_mkdir($path, $mode = 0755) * safe_mkdir($path, $mode = 0755)
* create directory if it doesn't already exist and isn't a file! * create directory if it doesn't already exist and isn't a file!
*/ */
function safe_mkdir($path, $mode=0755) { function safe_mkdir($path, $mode= 0755)
global $g; {
if (!is_file($path) && !is_dir($path)) { if (!is_file($path) && !is_dir($path)) {
return @mkdir($path, $mode, true); return @mkdir($path, $mode, true);
} else { } else {
...@@ -1557,8 +1539,9 @@ function unmute_kernel_msgs() ...@@ -1557,8 +1539,9 @@ function unmute_kernel_msgs()
exec('/sbin/conscontrol mute off'); exec('/sbin/conscontrol mute off');
} }
function is_interface_vlan_mismatch() { function is_interface_vlan_mismatch()
global $config, $g; {
global $config;
if (is_array($config['vlans']['vlan'])) { if (is_array($config['vlans']['vlan'])) {
foreach ($config['vlans']['vlan'] as $vlan) { foreach ($config['vlans']['vlan'] as $vlan) {
...@@ -1570,8 +1553,9 @@ function is_interface_vlan_mismatch() { ...@@ -1570,8 +1553,9 @@ function is_interface_vlan_mismatch() {
return false; return false;
} }
function is_interface_mismatch() { function is_interface_mismatch()
global $config, $g; {
global $config;
$do_assign = false; $do_assign = false;
$i = 0; $i = 0;
...@@ -1605,9 +1589,9 @@ function is_interface_mismatch() { ...@@ -1605,9 +1589,9 @@ function is_interface_mismatch() {
} }
/* sync carp entries to other firewalls */ /* sync carp entries to other firewalls */
function carp_sync_client() { function carp_sync_client()
global $g; {
send_event("filter sync"); send_event('filter sync');
} }
/****f* util/isAjax /****f* util/isAjax
...@@ -1874,8 +1858,6 @@ function array_exclude($needle, $haystack) { ...@@ -1874,8 +1858,6 @@ function array_exclude($needle, $haystack) {
function get_current_theme() function get_current_theme()
{ {
global $config, $g;
$theme = 'opnsense'; $theme = 'opnsense';
if (isset($config['theme']) && is_dir('/usr/local/www/themes/' . $config['theme'])) { if (isset($config['theme']) && is_dir('/usr/local/www/themes/' . $config['theme'])) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment