aboutsummaryrefslogtreecommitdiffstats
path: root/packages/squidGuard/squidguard_configurator.inc
diff options
context:
space:
mode:
Diffstat (limited to 'packages/squidGuard/squidguard_configurator.inc')
-rw-r--r--packages/squidGuard/squidguard_configurator.inc49
1 files changed, 36 insertions, 13 deletions
diff --git a/packages/squidGuard/squidguard_configurator.inc b/packages/squidGuard/squidguard_configurator.inc
index e300f29f..e32169a1 100644
--- a/packages/squidGuard/squidguard_configurator.inc
+++ b/packages/squidGuard/squidguard_configurator.inc
@@ -1,8 +1,8 @@
<?php
# ------------------------------------------------------------------------------
-# squidguard_configurator.inc
-# (C) 2006, 2007 Serg Dvoriancev
-/* Redistribution and use in source and binary forms, with or without
+/* squidguard_configurator.inc
+ (C)2006 Serg Dvoriancev
+ Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:
1. Redistributions of source code must retain the above copyright notice,
@@ -221,6 +221,7 @@ define('SQUIDGUARD_WORKDIR_DEF', '/usr/local/etc/squidGuard');
define('SQUIDGUARD_BINPATH_DEF', '/usr/local/bin');
define('SQUIDGUARD_DBHOME_DEF', '/var/db/squidGuard');
define('BLK_LOCALFILE', '/tmp/sg_blacklists.tar');
+define('DB_REBUILD_SH', '/tmp/squidGuard_db_rebuild.sh');
# ------------------------------------------------------------------------------
// debug options
@@ -598,9 +599,12 @@ function sg_reconfigure_user_db() {
set_file_access($dbhome, OWNER_NAME, 0755);
// 5. rebuild user db
- //$dst_names
+ // $dst_names; create array of names
+ $db_names = Array();
foreach($dst_names as $dname)
- sg_full_rebuild_db($dname);
+ $db_names[] = $dname;
+# sg_full_rebuild_db($dname);
+ sg_full_rebuild_db($db_names);
} else
sg_addlog("sg_reconfigure_user_db: stopped - destinations list empty");
@@ -670,21 +674,40 @@ function sg_full_rebuild_db($dblist='') {
// rebuild squidGuard DB (without waite)
if (file_exists($sg_cfgfile)) {
+
+ // rebuild via sh script
+ $sh_scr = Array();
+ $sh_scr[] = "#!/bin/sh";
+ $sh_scr[] = "cd /var/db/squidGuard";
+
if (empty($dblist)) {
// full rebuild
$cmd = $squidguard_config[FLD_BINPATH] . '/squidGuard -c $sg_cfgfile -C all';
- mwexec_bg($cmd);
+# mwexec_bg($cmd); // by sh script
+ $sh_scr[] = $cmd;
sg_addlog("sg_rebuild_db: start full rebuild db");
} else {
// partually rebuild
- $cmd_domains = $squidguard_config[FLD_BINPATH] . "/squidGuard -c $sg_cfgfile -C $dblist/domains";
- $cmd_urls = $squidguard_config[FLD_BINPATH] . "/squidGuard -c $sg_cfgfile -C $dblist/urls";
- mwexec_bg($cmd_domains);
- mwexec_bg($cmd_urls);
- sg_addlog("sg_rebuild_db: start rebuild DB '$dblist'");
+ if (is_array($dblist))
+ foreach($dblist as $dbl) {
+ $sh_scr[] = $squidguard_config[FLD_BINPATH] . "/squidGuard -c $sg_cfgfile -C $dbl/domains";
+ $sh_scr[] = $squidguard_config[FLD_BINPATH] . "/squidGuard -c $sg_cfgfile -C $dbl/urls";
+ sg_addlog("sg_rebuild_db: start rebuild DB '$dbl'");
+ }
}
// update .diff files
-# mwexec_bg($squidguard_config[FLD_BINPATH] . '/squidGuard -c $sg_cfgfile -u')*/)
+# mwexec_bg($squidguard_config[FLD_BINPATH] . '/squidGuard -c $sg_cfgfile -u')*/) // by sh script
+
+ // change db owner's after rebuild
+ $sh_scr[] = "chown -R -v " . OWNER_NAME . " " . $squidguard_config[FLD_DBHOME];
+
+ // restart squid for take effects
+ $sh_scr[] = "/usr/local/sbin/squid -k reconfigure";
+
+ // store & exec ssh
+ $sh_scr = implode("\n", $sh_scr);
+ file_put_contents(DB_REBUILD_SH, $sh_scr);
+ mwexec_bg(DB_REBUILD_SH);
} else {
sg_addlog("sg_rebuild_db: error, config file '$sg_cfgfile' not found");
}
@@ -1561,4 +1584,4 @@ function check_name ($name) {
return $err;
}
-?>
+?> \ No newline at end of file