aboutsummaryrefslogtreecommitdiffstats
path: root/config/bacula-client/bacula-client.inc
diff options
context:
space:
mode:
authorMárcio Carlos <marcioc.antao@gmail.com>2012-06-27 17:26:55 -0300
committerMárcio Carlos <marcioc.antao@gmail.com>2012-06-27 17:27:13 -0300
commit9cefde0b754650de9bc33630c1256f4ad18313e3 (patch)
treed943ff02b7c220504dd9646b022fbc82dd8f4923 /config/bacula-client/bacula-client.inc
parent0519e22f746b21880aa461e273573060d3f9becf (diff)
downloadpfsense-packages-9cefde0b754650de9bc33630c1256f4ad18313e3.tar.gz
pfsense-packages-9cefde0b754650de9bc33630c1256f4ad18313e3.tar.bz2
pfsense-packages-9cefde0b754650de9bc33630c1256f4ad18313e3.zip
add package bacula-client
For Backup with a bacula 5 a pfsense 2
Diffstat (limited to 'config/bacula-client/bacula-client.inc')
-rw-r--r--config/bacula-client/bacula-client.inc182
1 files changed, 182 insertions, 0 deletions
diff --git a/config/bacula-client/bacula-client.inc b/config/bacula-client/bacula-client.inc
new file mode 100644
index 00000000..7cb27b1f
--- /dev/null
+++ b/config/bacula-client/bacula-client.inc
@@ -0,0 +1,182 @@
+<?php
+
+* ========================================================================== */
+/*
+ bacula-client.inc
+ part of pfSense (http://www.pfSense.com)
+ Copyright (C) 2012 Marcio Carlos
+ All rights reserved.
+
+ Based on m0n0wall (http://m0n0.ch/wall)
+ Copyright (C) 2003-2006 Manuel Kasper <mk@neon1.net>.
+ All rights reserved.
+ */
+/* ========================================================================== */
+/*
+ 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,
+ this list of conditions and the following disclaimer.
+
+ 2. Redistributions in binary form must reproduce the above copyright
+ notice, this list of conditions and the following disclaimer in the
+ documentation and/or other materials provided with the distribution.
+
+ THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
+ INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
+ AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
+ AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
+ OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ POSSIBILITY OF SUCH DAMAGE.
+ */
+/* ========================================================================== */
+ require_once("config.inc");
+ require_once("util.inc");
+
+function restart_bacula-client(){
+ //backup /usr/local/etc/bacula-fd.conf before any change
+ $etc_bacula-client=" /usr/local/etc/bacula-fd.conf";
+ $pfsense_version=preg_replace("/\s/","",file_get_contents("/etc/version"));
+ if (!file_exists('/root/'.$pfsense_version.'.bacula-fd.backup')){
+ copy ($etc_bacula-client,'/root/'.$pfsense_version.'.bacula-fd.backup');
+ }
+
+ //patch /usr/local/etc/bacula-fd.conf if need
+ $sshd_file=file($etc_bacula-client);
+ $sshd_new_file="";
+ foreach ($sshd_file as $line){
+ if (preg_match('/sshconf .= "Port/',$line)){
+ $sshd_new_file.= $line;
+ $sshd_new_file.= "\t".'if(file_exists("/etc/ssh/sshd_extra")){$sshconf.=file_get_contents("/etc/ssh/sshd_extra");}'."\n";
+ }
+ elseif(!preg_match('/sshd_extra/',$line)){
+ $sshd_new_file.= $line;
+ }
+ }
+ file_put_contents($etc_sshd,$sshd_new_file,LOCK_EX);
+ mwexec_bg($etc_sshd);
+ }
+
+function bacula-client_custom_php_install_command(){
+ global $g, $config;
+ conf_mount_rw();
+ $fd = fopen("/usr/local/etc/rc.d/bacula-fd", "w");
+ if(!$fd) {
+ log_error("Could not open /usr/local/etc/rc.d/bacula-fd for writing.");
+ return;
+ }
+
+ // Ensure svscan.sh has a+rx
+ exec("chmod a+rx /usr/local/etc/rc.d/bacula-fd");
+
+ $bacula-fd = <<<EOD
+#!/bin/sh
+#
+# $FreeBSD: ports/sysutils/bacula-server/files/bacula-fd.in,v 1.7 2012/01/14 08:56:57 dougb Exp $
+#
+# PROVIDE: bacula_fd
+# REQUIRE: DAEMON
+# KEYWORD: shutdown
+#
+# Add the following lines to /etc/rc.conf.local or /etc/rc.conf
+# to enable this service:
+#
+# bacula_fd_enable (bool): Set to NO by default.
+# Set it to YES to enable bacula_fd.
+# bacula_fd_flags (params): Set params used to start bacula_fd.
+#
+
+. /etc/rc.subr
+
+name="bacula_fd"
+rcvar=bacula_fd_enable
+command=/usr/local/sbin/bacula-fd
+
+load_rc_config $name
+
+: ${bacula_fd_enable="YES"}
+: ${bacula_fd_flags=" -u root -g wheel -v -c /usr/local/etc/bacula-fd.conf"}
+: ${bacula_fd_pidfile="/var/run/bacula-fd.9102.pid"}
+
+pidfile="${bacula_fd_pidfile}"
+
+run_rc_command "$1"
+
+EOD;
+
+ fwrite($fd, $bacula-fd);
+ fclose($fd);
+ conf_mount_ro();
+ }
+
+function bacula-client_custom_php_deinstall_command(){
+ global $g, $config;
+
+ conf_mount_rw();
+
+ // 1. Delete our config file
+ unlink_if_exists("/usr/local/etc/bacula-fd.conf");
+
+ // 2. Re-run sshd config generation script
+ exec("/usr/local/etc/rc.d/bacula-fd stop");
+
+ conf_mount_ro();
+ }
+
+function bacula-client_custom_php_write_config(){
+ global $g, $config;
+ $fd = fopen("/usr/local/etc/bacula-fd.conf", "w");
+ if(!$fd) {
+ log_error("Could not open /usr/local/etc/bacula-fd.conf for writing.");
+ return;
+ }
+ if (is_array($config['installedpackages']['bacula-client']['config'])){
+ // Mount Read-write
+ conf_mount_rw();
+ // Make Head
+ $baculaclient_conf .= <<<EOD
+ #
+ # Default Bacula File Daemon Configuration file
+ #
+ # For Bacula release 5.2.6 (21 February 2012) -- pfsense 2.0.x
+ #
+ # There is not much to change here except perhaps the
+ #
+ # List Directors who are permitted to contact this File daemon
+ #
+ EOD;
+ // Read config
+ foreach ($config['installedpackages']['bacula-client']['config'] as $baculaclient){
+ foreach ($baculaclient['row'] as $bc){
+ // create Director
+ if $bc['type'] < 2
+ $baculaclient_conf .= "Director { \n\t Name = $bc['director']-dir #$bc['description']\n\t Password = ".'"'.$bc['password'].'"'."\n}\n";
+ if $bc['type'] > 0
+ $baculaclient_conf .= "Director { \n\t Name = $bc['director']-mon #$bc['description']\n\t Password = ".'"'.$bc['password'].'"'."\n\t Monitor = yes\n}\n";
+ if $bc['type'] = 1
+ $LocalDirector = $bc['director']
+ }
+ }
+ // create Messages
+ $baculaclient_conf .= "Messages { \n\t Name = Standard \n\t director = ".$LocalDirector."-dir = all, !skipped, !restored\n\t \n}\n";
+ // create FielDaemon
+
+ $port = $config['installedpackages']['bacula-client']['config'][0]['port'];
+ $dir = $config['installedpackages']['bacula-client']['config'][0]['dir'];
+ $jobs = $config['installedpackages']['bacula-client']['config'][0]['jobs']
+ $baculaclient_conf .= "FileDaemon { \n\t Name = $filedaemon-fd #\n\t FDport = $port\n\t WorkingDirectory = $dir\n\t Maximun Concurrent Jobs = $jobs\n \n}\n";
+ fwrite($fd, $baculaclient_conf);
+ fclose($fd);
+ }
+}
+
+ // Mount Read-only
+ conf_mount_ro();
+
+
+ ?> \ No newline at end of file