summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: e7f157b)
raw | patch | inline | side by side (parent: e7f157b)
author | opensides <opensides@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Thu, 27 Mar 2008 21:39:22 +0000 (21:39 +0000) | ||
committer | opensides <opensides@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Thu, 27 Mar 2008 21:39:22 +0000 (21:39 +0000) |
git-svn-id: https://oss.gonicus.de/repositories/gosa/branches/2.5-plugins@10040 594d385d-05f5-0310-b6e9-bd551577e9d8
vhost-apache2/gen_locale.sh | [new file with mode: 0755] | patch | blob |
vhost-apache2/plugin.dsc | [new file with mode: 0644] | patch | blob |
vhost-apache2/systems/apache2/class_servApacheEditVhost.inc | [new file with mode: 0644] | patch | blob |
vhost-apache2/systems/apache2/class_servApacheVhost.inc | [new file with mode: 0644] | patch | blob |
vhost-apache2/systems/apache2/functions_apache.inc | [new file with mode: 0644] | patch | blob |
vhost-apache2/systems/apache2/servApacheVhost.tpl | [new file with mode: 0644] | patch | blob |
vhost-apache2/systems/apache2/servApacheVhostEdit.tpl | [new file with mode: 0644] | patch | blob |
diff --git a/vhost-apache2/gen_locale.sh b/vhost-apache2/gen_locale.sh
--- /dev/null
@@ -0,0 +1,169 @@
+#!/bin/sh
+
+generate_po() {
+ ORIG=`pwd`
+ TEMPDIR="/tmp/gosa-locale"
+ TRUE=`which true`
+
+ echo
+ echo "Creating temporary directory..."
+ [ -d $TEMPDIR ] && rm -rf $TEMPDIR
+ mkdir $TEMPDIR
+
+ echo "Creating copy of GOsa..."
+ tar c . | tar x -C $TEMPDIR
+
+ echo "Converting .tpl files..."
+ pushd . &> /dev/null
+ cd $TEMPDIR
+
+ for template in $(find . -name '*.tpl'); do
+ echo "* converting .tpl files: $(basename $template)"
+ sed -e 's/{t}/<?php $t= _("/g;s!{/t}!");?>!g' $template > $template.new
+ mv $template.new $template
+ done
+
+ for class in $(find . -name 'class_*.inc'); do
+ echo "* converting class_*.inc files: $(basename $class)"
+ sed -e 's/\($pl[DH][^=]*\)= *"\([^"]*\)";$/\1= _("\2");/g' $class > $class.new
+ mv $class.new $class
+ done
+
+ echo "Extracting languages..."
+ rm locale/messages.po
+ find . -name '*.[ctpi][ophn][nlpc]' | xgettext -f - --keyword=must -d Domain -L PHP -n -o locale/messages.po
+
+ echo "Merging po files with existing ones"
+ error=0
+ for f in locale/??/LC_MESSAGES; do
+ echo -n "* merging $f/messages.po: "
+ [ -f $f/messages.po ] && msgmerge $f/messages.po locale/messages.po --output-file=$f/messages.po.new &> /dev/null
+
+ # Do an extra check for dummy dir 'locale/en/LC_MESSAGES'
+ if [ $? -ne 0 ]; then
+ [ "$f" == "locale/en/LC_MESSAGES" ] && $TRUE
+ fi
+
+ if [ $? -eq 0 ]; then
+ echo "done";
+ else
+ echo "failed";
+ error=1
+ fi
+
+ done
+
+ echo "Copying new po files, making backups..."
+ find . -name messages.po | while read f; do
+
+ if [ -f $ORIG/$f ]; then
+ mv $ORIG/$f $ORIG/$f.orig
+ else
+ continue
+ fi
+
+ echo $f | grep -q "locale/messages.po"
+ if [ $? -ne 0 ]; then
+ echo "* replaced $ORIG/$f"
+ cp $f.new $ORIG/$f
+ else
+ cp $f $ORIG/$f
+ fi
+
+ done
+
+ rm -rf $TEMPDIR
+
+ echo
+ error=0
+ if [ $error -eq 0 ]; then
+ if [ $ASSUME_Y -eq 1 ]; then
+ find $ORIG/ -type f -name 'messages.po.orig' -exec rm -f {} \;
+ else
+ read -p "Do you want to erase the message.po.orig files? (y/n)" -n1 ans
+
+ if [ "$ans" == "y" -o "$ans" == "Y" ]; then
+ find $ORIG/ -type f -name 'messages.po.orig' -exec rm -f {} \;
+ fi
+ fi
+
+ else
+ echo "There were errors during the transition. Please fix!"
+ exit 1
+ fi
+
+cat <<-EOF
+
+---------------------------------------------------------------------
+
+Now edit all files that have been replaced above (i.e. using kbabel
+or gtranslator) and mail the changes to gosa@oss.gonicus.de to be
+included in the next release.
+
+To see the changes you've made in GOsa, run "msgfmt messages.po" on
+your freshly edited files and restart your apache after that. Set
+the webbrowser to the language you've edited and go back to the
+login screen.
+
+---------------------------------------------------------------------
+
+EOF
+
+ popd &> /dev/null
+}
+
+compile_po()
+{
+ po='messages.po'
+ mo='messages.mo'
+
+ echo "Compiling po files..."
+ for f in locale/??/LC_MESSAGES; do
+
+ if [ -f $f/$po ]; then
+ echo "* compiling $f/$po"
+ msgfmt $f/$po -o $f/$mo
+ else
+ echo "! skipped $f/$po - does not exist"
+ error=1
+ continue
+ fi
+
+ done
+}
+
+#
+# MAIN
+#
+GENERATE=0
+COMPILE=0
+ASSUME_Y=0
+while getopts ":cgyh" opt
+do
+ case $opt in
+ c) COMPILE=1
+ ;;
+ g) GENERATE=1;
+ ;;
+ y) ASSUME_Y=1;
+ ;;
+ h|--help)
+ echo "Usage: $(basename $0) [-c] [-g] [-y]"
+ echo " -c compile existing po files into mo files"
+ echo " -g extract strings from GOsa and generate po files"
+ echo " -y assume yes"
+ exit 1
+ ;;
+ esac
+done
+shift $(($OPTIND - 1))
+
+# Default to generate
+if [ $GENERATE -eq 0 -a $COMPILE -eq 0 ]; then
+ GENERATE=1
+fi
+
+[ $GENERATE -eq 1 ] && generate_po
+[ $COMPILE -eq 1 ] && compile_po
+
+# vim:tabstop=2:expandtab:shiftwidth=2:syntax:ruler:
diff --git a/vhost-apache2/plugin.dsc b/vhost-apache2/plugin.dsc
--- /dev/null
+++ b/vhost-apache2/plugin.dsc
@@ -0,0 +1,5 @@
+[gosa-plugin]
+name = apache2
+description = "Apache2 vhost management module"
+version = 2.5
+author = "Alejandro Escanero <aescanero@gmail.com>"
diff --git a/vhost-apache2/systems/apache2/class_servApacheEditVhost.inc b/vhost-apache2/systems/apache2/class_servApacheEditVhost.inc
--- /dev/null
@@ -0,0 +1,454 @@
+<?php
+
+class servapacheVhostEdit extends plugin
+{
+ /* attribute list for save action */
+ var $ignore_account= TRUE;
+
+ var $attributes = array("apacheServerName","apacheDocumentRoot","apacheServerAlias",
+ "apacheServerAdmin","apacheScriptAlias","apacheSuexecUid","apacheSuexecGid");
+
+ var $objectclasses = array("whatever");
+
+
+ var $apacheServerName = "";
+ var $apacheDocumentRoot = "";
+ var $apacheServerAdmin = "";
+ var $apacheSuexecUid = "";
+ var $apacheSuexecGid = "";
+
+ var $apacheServerAlias = array();
+ var $apacheScriptAlias = array();
+
+ var $OldApacheServerName = ""; // To detect changes made with this edit
+ var $InitialApacheServerName = "";
+
+ var $Records = array();
+
+ var $dialog = false;
+
+ var $isNew = true;
+ var $cn;
+ var $VhostObject = array();
+
+ function servapacheVhostEdit ($config, $dn= NULL,$attrs = array())
+ {
+ plugin::plugin ($config, $dn);
+
+ if(!count($attrs)){
+ $this->OldApacheServerName = "";
+ $this->isNew = true;
+
+ $this->InitialApacheServerName = "";//$attrs['InitialApacheServerName'];
+ }else{
+ $this->VhostObject = $attrs;
+
+ $this->OldApacheServerName = $attrs['apacheServerName'];
+
+ $this->InitialApacheServerName = $attrs['InitialApacheServerName'];
+
+ $this->isNew = false;
+
+ foreach($this->attributes as $value){
+ if(isset($attrs[$value])){
+ $this->$value = $attrs[$value];
+ }
+ }
+
+ if(!isset($attrs['apacheServerAlias'])) $this->apacheServerAlias = array();
+ if(!isset($attrs['apacheScriptAlias'])) $this->apacheScriptAlias = array();
+
+ }
+ }
+
+ /* Transports the given Arraykey one position up*/
+ function ArrayUp($atr,$attrs)
+ {
+ $ret = $attrs;
+ $pos = $atr ;
+ $cn = count($attrs);
+ if(!(($pos == -1)||($pos == 1)||($pos >$cn))){
+ $before = array_slice($attrs,0,($pos-2));
+ $mitte = array_reverse(array_slice($attrs,($pos-2),2));
+ $unten = array_slice($attrs,$pos);
+ $ret = array();
+ $ret = $this->combineArrays($before,$mitte,$unten);
+ }
+ return($ret);
+ }
+
+
+ /* Transports the given Arraykey one position down*/
+ function ArrayDown($atr,$attrs)
+ {
+ $ret = $attrs;
+ $pos = $atr ;
+ $cn = count($attrs);
+ if(!(($pos == -1)||($pos == $cn))){
+ $before = array_slice($attrs,0,($pos-1));
+ $mitte = array_reverse(array_slice($attrs,($pos-1),2));
+ $unten = array_slice($attrs,($pos+1));
+ $ret = array();
+ $ret = $this->combineArrays($before,$mitte,$unten);
+ }
+ return($ret);
+ }
+
+ /* Combine new array */
+ function combineArrays($ar0,$ar1,$ar2)
+ {
+ $ret = array();
+ if(is_array($ar0))
+ foreach($ar0 as $ar => $a){
+ $ret[]=$a;
+ }
+ if(is_array($ar1))
+ foreach($ar1 as $ar => $a){
+ $ret[]=$a;
+ }
+ if(is_array($ar2))
+ foreach($ar2 as $ar => $a){
+ $ret[]=$a;
+ }
+ return($ret);
+ }
+
+ function getpos($atr,$attrs)
+ {
+ $i = 0;
+ foreach($attrs as $attr => $name) {
+ $i++;
+ if($attr == $atr){
+ return($i);
+ }
+ }
+ return(-1);
+ }
+
+
+ function execute()
+ {
+ /* Call parent execute */
+ plugin::execute();
+
+
+ /* Fill templating stuff */
+ $smarty= get_smarty();
+ $display= "";
+
+ /* Open Vhost Entry Edit Dialog
+ */
+ if(!count($this->VhostObject)){
+ $smarty->assign("AllowVhostEdit" , false);
+ }else{
+ $smarty->assign("AllowVhostEdit" , true);
+ if(isset($_POST['EditVhostEntries'])){
+ $this->dialog= new apacheVhostEditEntries($this->config,$this->dn,$this->VhostObject);
+ }
+ }
+
+ /* Save Vhost Entry Edit Dialog
+ */
+ if(isset($_POST['SaveVhostEntryChanges'])){
+ $this->dialog->save_object();
+ if(count($this->dialog->check())){
+ $msgs = $this->dialog->check();
+ foreach($msgs as $msg){
+ print_red($msg);
+ }
+ }else{
+ $this->dialog->save();
+ $this->dialog = false;
+ }
+ }
+
+ /* Cancel Vhost Entrie Edit Dialog
+ */
+ if(isset($_POST['CancelVhostEntryChanges'])){
+ $this->dialog = false;
+ }
+
+ /* Display any type of open dialogs
+ */
+ if($this->dialog){
+ $this->dialog->save_object();
+ return($this->dialog->execute());
+ }
+
+ $once =true;
+ foreach($_POST as $name => $value){
+ if((preg_match("/^SAup_/",$name)) && ($once)){
+ $once = false;
+
+ $id = preg_replace("/^SAup_/","",$name);
+ $id = preg_replace("/_.*$/","",$id);
+ $id = base64_decode($id);
+
+ $this->apacheServerAlias = $this->ArrayUp(($id+1),$this->apacheServerAlias);
+ }
+ if((preg_match("/^SAdown_/",$name)) && ($once)){
+ $once = false;
+
+ $id = preg_replace("/^SAdown_/","",$name);
+ $id = preg_replace("/_.*$/","",$id);
+ $id = base64_decode($id);
+
+ $this->apacheServerAlias = $this->ArrayDown(($id+1),$this->apacheServerAlias);
+ }
+ if((preg_match("/^SAdel_/",$name)) && ($once)){
+ $once = false;
+
+ $id = preg_replace("/^SAdel_/","",$name);
+ $id = preg_replace("/_.*$/","",$id);
+ $id = base64_decode($id);
+
+ unset($this->apacheServerAlias[$id]);
+
+ $tmp =array();
+ foreach($this->apacheServerAlias as $entry){
+ $tmp[] = $entry;
+ }
+
+ $this->apacheServerAlias = $tmp;
+ }
+
+ if((preg_match("/^SCup_/",$name)) && ($once)){
+ $once = false;
+
+ $id = preg_replace("/^SCup_/","",$name);
+ $id = preg_replace("/_.*$/","",$id);
+ $id = base64_decode($id);
+
+ $this->apacheScriptAlias = $this->ArrayUp(($id+1),$this->apacheScriptAlias);
+ }
+ if((preg_match("/^SCdown_/",$name)) && ($once)){
+ $once = false;
+
+ $id = preg_replace("/^SCdown_/","",$name);
+ $id = preg_replace("/_.*$/","",$id);
+ $id = base64_decode($id);
+
+ $this->apacheScriptAlias = $this->ArrayDown(($id+1),$this->apacheScriptAlias);
+ }
+ if((preg_match("/^SCdel_/",$name)) && ($once)){
+ $once = false;
+
+ $id = preg_replace("/^SCdel_/","",$name);
+ $id = preg_replace("/_.*$/","",$id);
+ $id = base64_decode($id);
+
+ unset($this->apacheScriptAlias[$id]);
+
+ $tmp =array();
+ foreach($this->apacheScriptAlias as $entry){
+ $tmp[] = $entry;
+ }
+
+ $this->apacheScriptAlias = $tmp;
+ }
+
+ }
+
+ if((isset($_POST['AddSARecord'])) && (!empty($_POST['StrSAAlias'])) && (!empty($_POST['StrSADir']))){
+ $this->apacheServerAlias[] = trim($_POST['StrSAAlias']." ".$_POST['StrSADir']);
+ }
+
+ if((isset($_POST['AddSCRecord'])) && (!empty($_POST['StrSCAlias'])) && (!empty($_POST['StrSCDir']))){
+ $this->apacheScriptAlias[] = trim($_POST['StrSCAlias']." ".$_POST['StrSCDir']);
+ }
+
+ /* Handle Post events */
+ $once = true;
+ foreach($_POST as $name => $value){
+
+ /* Delete vhosts if requested */
+ if((preg_match("/RemoveRecord_/",$name))&&($once)){
+ $once = false;
+ $id= preg_replace("/RemoveRecord_/","",$name);
+ unset($this->Records[$id]);
+ }
+ }
+
+ /* Add new Vhostrecord */
+ /* if(isset($_POST['AddNewRecord'])){
+ $this->Records[] = array("type"=>"aRecord","value"=>"");
+ }*/
+
+ /* Fill in values */
+ foreach($this->attributes as $name){
+ $smarty->assign($name,$this->$name);
+ }
+
+ /* Set apacheServerNames without server suffix */
+ $smarty->assign("apacheServerName",$this->apacheServerName);
+
+ $div = new DivSelectBox("apacheServerAlias");
+ $div->setHeight(120);
+ $recs = $this->apacheServerAlias;
+
+ $oneup = "<input name='SAup_%s' type='image' src='images/sort_up.png' title='"._("Up")."' class='center'> ";
+ $onedown = "<input name='SAdown_%s' type='image' src='images/sort_down.png' title='"._("Down")."' class='center'> ";
+ $onedel = "<img src='images/empty.png' width='20' class='center'>
+ <input name='SAdel_%s' type='image' src='images/edittrash.png' title='"._("Delete")."' class='center'>";
+ foreach($recs as $key => $rec){
+ $div ->AddEntry(array(
+ array("string"=>$rec),
+/* array("string"=>$key,
+ "attach"=>"style='width:20px;'"),*/
+ array("string"=>str_replace("%s",base64_encode($key),$oneup.$onedown.$onedel),
+ "attach"=>"style='width:70px;border-right:0px;'")
+ ));
+ }
+
+ $smarty->assign("NotNew", false);
+
+ $smarty->assign("apacheServerAlias", $div->DrawList());
+
+ $div = new DivSelectBox("apacheScriptAlias");
+ $div->setHeight(120);
+ $recs = $this->apacheScriptAlias;
+
+ $oneup = "<input name='SCup_%s' type='image' src='images/sort_up.png' title='"._("Up")."' class='center'> ";
+ $onedown = "<input name='SCdown_%s' type='image' src='images/sort_down.png' title='"._("Down")."' class='center'> ";
+ $onedel = "<img src='images/empty.png' width='20' class='center'>
+ <input name='SCdel_%s' type='image' src='images/edittrash.png' title='"._("Delete")."' class='center'>";
+
+ foreach($recs as $key => $rec){
+ $div ->AddEntry(array(
+ array("string"=>$rec),
+/* array("string"=>$key,
+ "attach"=>"style='width:20px;'"),*/
+ array("string"=>str_replace("%s",base64_encode($key),$oneup.$onedown.$onedel),
+ "attach"=>"style='width:70px;border-right:0px;'")
+ ));
+ }
+
+ $smarty->assign("NotNew", false);
+
+ $smarty->assign("apacheScriptAlias", $div->DrawList());
+
+ /* Display template */
+ $display.= $smarty->fetch(get_template_path('servApacheVhostEdit.tpl', TRUE));
+ return($display);
+ }
+
+ function remove_from_parent()
+ {
+ }
+
+ /* Save data to object */
+ function save_object()
+ {
+ //plugin::save_object();
+ foreach($this->attributes as $attr){
+ if(isset($_POST[$attr])){
+ $this->$attr = $_POST[$attr];
+ }
+ }
+
+ }
+
+
+ /* Check supplied data */
+ function check()
+ {
+ /* Call common method to give check the hook */
+ $message= plugin::check();
+
+ /* Check if apacheServerName is already in use */
+ $usedVhosts = $this->getUsedServerNames();
+ if(($this->isNew == true)||($this->apacheServerName != $this->InitialApacheServerName)){
+/* if((isset($usedVhosts[$this->apacheServerName]))&&($this->apacheServerName != $this->InitialApacheServerName)){
+ $message[] =_("This apacheServerName is already in use");
+ }
+*/
+ }
+
+ if(!GetVhostsDomain($this->apacheServerName) || empty($this->apacheServerName)){
+ $message[] =sprintf(_("Please choose a valid Virtual Host Name."));
+ }
+
+ if(!is_path($this->apacheDocumentRoot) || empty($this->apacheDocumentRoot)){
+ $message[] = _("Please choose a valid Path as Virtual Host Document Root.");
+ }
+
+ if(!is_email($this->apacheServerAdmin) || empty($this->apacheServerAdmin)){
+ $message[] = _("Please choose a valid Email Account as Admin Mail address.");
+ }
+
+ if($this->apacheServerName != strtolower($this->apacheServerName)){
+ $message[] = _("Only lowercase strings are allowed as Virtual Host Name.");
+ }
+
+ if($this->apacheDocumentRoot != strtolower($this->apacheDocumentRoot)){
+ $message[] = _("Only lowercase strings are allowed as Virtual Host Document Root.");
+ }
+
+ if($this->apacheServerAdmin != strtolower($this->apacheServerAdmin)){
+ $message[] = _("Only lowercase strings are allowed as Admin Mail address.");
+ }
+
+ foreach($this->apacheServerAlias as $key => $line){
+ $apacheServerAlias_ar=split(" ",$line);
+ $url=$apacheServerAlias_ar[0];
+ if(!is_path($url)){
+ $message[] = sprintf(_("Please choose a valid Path as URL Alias Path in line: %s"),$line);
+ }
+ }
+
+ foreach($this->apacheScriptAlias as $key => $line){
+ $apacheScriptAlias_ar=split(" ",$line);
+ $url=$apacheScriptAlias_ar[0];
+ if(!is_path($url)){
+ $message[] = sprintf(_("Please choose a valid Path as URL Alias Path in line: %s"),$line);
+ }
+ }
+
+ return ($message);
+ }
+
+ /* This funtion returns all used apacheServerNames */
+ function getUsedServerNames()
+ {
+ $ret = array();
+ $ldap = $this->config->get_ldap_link();
+ $ldap->cd($this->config->current['BASE']);
+ $ldap->search("(&(objectClass=apacheConfig)(apacheServerName=*))",array("apacheServerName"));
+ while($attr = $ldap->fetch()){
+ $ret[$attr['apacheServerName'][0]]="";
+ }
+ return($ret);
+ }
+
+ /* Save to LDAP */
+ function save()
+ {
+ $ret =array();
+ foreach($this->attributes as $name){
+ $ret[$name] = $this->$name;
+ }
+
+ /* Create SA records
+ */
+ foreach($this->apacheServerAlias as $key => $rec){
+ $rec['value']= $key." ".$rec['value'];
+ $this->Records [] = $rec;
+ }
+
+ /* Create SC records
+ */
+ foreach($this->apacheScriptAlias as $key => $rec){
+ $rec['value']= $key." ".$rec['value'];
+ $this->Records [] = $rec;
+ }
+
+ $ret['RECORDS'] = $this->Records;
+
+ $ret['InitialApacheServerName'] = $this->InitialApacheServerName;
+
+ return($ret);
+ }
+
+}
+
+?>
diff --git a/vhost-apache2/systems/apache2/class_servApacheVhost.inc b/vhost-apache2/systems/apache2/class_servApacheVhost.inc
--- /dev/null
@@ -0,0 +1,272 @@
+<?php
+
+class servapache extends plugin
+{
+ /* attribute list for save action */
+ var $ignore_account = FALSE;
+ var $attributes = array();
+ var $objectclasses = array("whatever");
+
+ var $RecordTypes = array();
+ var $Vhosts = array();
+ var $dialog = NULL;
+
+ var $orig_dn = "";
+
+ var $APACHEinitially_was_account;
+
+
+ function servapache ($config, $dn= NULL, $parent= NULL)
+ {
+ plugin::plugin ($config, $dn, $parent);
+
+ $this->orig_dn = $dn;
+
+ /* Get all vhost Informations
+ */
+ $this->Vhosts = getVhostEntries($config,$dn);
+
+ /* If there is at least one entry in this -> types, we have apache vhosts enabled
+ */
+ if(count($this->Vhosts) == 0){
+ $this->is_account = false;
+ }else{
+ $this->is_account = true;
+ }
+ $this->APACHEinitially_was_account = $this->is_account;
+ }
+
+
+ function execute()
+ {
+ /* Call parent execute
+ */
+ plugin::execute();
+
+ /* Fill templating stuff
+ */
+ $smarty= get_smarty();
+ $display= "";
+
+ /* Do we need to flip is_account state?
+ */
+ if (isset($_POST['modify_state'])){
+
+ /* Only change account state if allowed */
+ if($this->is_account && $this->acl == "#all#"){
+ $this->is_account= !$this->is_account;
+ $this->is_modified = true;
+ }elseif(!$this->is_account && chkacl($this->acl,"create") == ""){
+ $this->is_account= !$this->is_account;
+ $this->is_modified = true;
+ }
+ }
+
+ if ($this->is_account){
+ $display= $this->show_header(_("Remove Apache service"),
+ _("This server has Apache features enabled. You can disable them by clicking below."));
+ } else {
+ $display= $this->show_header(_("Add Apache service"),
+ _("This server has Apache features disabled. You can enable them by clicking below."));
+ return ($display);
+ }
+
+ /* Edited or Added vhost
+ */
+ if((isset($_POST['SaveVhostChanges'])) && is_object($this->dialog)){
+ $this->dialog->save_object();
+
+ /* Check for errors
+ */
+ if(count($this->dialog->check())){
+ foreach($this->dialog->check() as $msgs){
+ print_red($msgs);
+ }
+ }else{
+ /* add new/edited vhost
+ */
+ $ret = $this->dialog->save();
+ if(!$this->dialog->isNew){
+ unset($this->Vhosts[$this->dialog->OldApacheServerName]);
+ }
+ $this->Vhosts[$ret['apacheServerName']] = $ret;
+ $this->dialog = NULL;
+ }
+ }
+
+ /* Cancel vhost edit / new
+ */
+ if(isset($_POST['CancelVhostChanges'])){
+ $this->dialog = NULL;
+ }
+
+ /* Add empty new vhost
+ */
+ if(isset($_POST['AddVhost']) && chkacl($this->acl,"servapache") == ""){
+ $this->dialog = new servapacheVhostEdit($this->config,$this->dn);
+ }
+
+ /* Check for edit vhost request
+ */
+ $once = false;
+ foreach( $_POST as $name => $value){
+ //user_error(print_r($this->Vhosts,true));
+ /* check all post for edit request
+ */
+ if(preg_match("/^editVhost_/",$name)&&!$once && chkacl($this->acl,"servapache") == ""){
+ $once =true;
+ $tmp = preg_replace("/^editVhost_/","",$name);
+ $tmp = base64_decode(preg_replace("/_.*$/","",$tmp));
+ $this->dialog= new servapacheVhostEdit($this->config,$this->dn,$this->Vhosts[$tmp]);
+ }
+
+ /* check posts for delete vhost
+ */
+ if(preg_match("/^delVhost_/",$name)&&!$once && chkacl($this->acl,"servapache") == ""){
+
+ $once =true;
+ $tmp = preg_replace("/^delVhost_/","",$name);
+ $tmp = base64_decode(preg_replace("/_.*$/","",$tmp));
+
+ /* Initiate deletion
+ */
+ $this->RemoveVhost($tmp);
+ }
+ }
+
+ /* Show dialog
+ */
+ if($this->dialog!= NULL){
+ $this->dialog->save_object();
+ $this->dialog->parent = $this;
+ return($this->dialog->execute());
+ }
+
+ /* Create Listbox with existing Vhosts
+ */
+ $VhostList = new divSelectBox("apacheConfigs");
+ $VhostList -> SetHeight(254);
+
+ /* Add entries to divlist
+ */
+ $editImg = "<input type='image' src='images/edit.png' name='editVhost_%s'>
+ <input type='image' src='images/edittrash.png' name='delVhost_%s'>";
+ foreach($this->Vhosts as $vhost => $values ){
+ $VhostList->AddEntry(array(
+ array("string" => $vhost),
+ array("string" => str_replace("%s",base64_encode($vhost),$editImg))
+ ));
+ }
+
+ $smarty->assign("servapacheACL",chkacl($this->acl,"servapache"));
+
+ /* Display template
+ */
+ $smarty->assign("VhostList",$VhostList->DrawList());
+ $display.= $smarty->fetch(get_template_path('servApacheVhost.tpl', TRUE));
+ return($display);
+ }
+
+
+ /* Delete specified vhost
+ */
+ function RemoveVhost($id)
+ {
+ unset($this->Vhosts[$id]);
+ return(true);
+ }
+
+
+ /* This function returns all used Vhostnames
+ */
+ function getUsedServerNames()
+ {
+ $ret = array();
+ $ldap = $this->config->get_ldap_link();
+ $ldap->cd($this->config->current['BASE']);
+ $ldap->search("(&(objectClass=apacheConfig)(apacheServerName=*))",array("apacheServerName"));
+ while($attr = $ldap->fetch()){
+ $ret[$attr['apacheServerName'][0]][] = $attr['dn'];
+ }
+ return($ret);
+ }
+
+
+ /* Remove apache service
+ */
+ function remove_from_parent()
+ {
+ if($this->APACHEinitially_was_account){
+ $bool = true;
+ foreach($this->Vhosts as $key => $vhost){
+ $bool= $bool & $this->RemoveVhost($key);
+ }
+
+ if($bool){
+ $this->save();
+ }
+ return($bool);
+ }
+ }
+
+
+ /* Save to LDAP */
+ function save()
+ {
+ $ldap = $this->config->get_ldap_link();
+ $ldap->cd($this->config->current['BASE']);
+
+ /* Get differences
+ */
+
+ $old_dn = $this->orig_dn;
+ if($old_dn == "new"){
+ $old_dn = $this->dn;
+ }
+
+ $tmp = getVhostEntriesDiff($this->config,$this->Vhosts,$old_dn);
+
+ /* Updated vhost entries if reverser or forward name has changed
+ * Must be done before moving entries, else the given dn is invalid
+ */
+ if(isset($tmp['vhostUpdates'])){
+ foreach($tmp['vhostUpdates'] as $dn => $attrs){
+ $ldap->cd($dn);
+ $ldap->modify($attrs);
+ show_ldap_error("Vhost:".$ldap->get_error(), _("Updating Apache service failed"));
+ }
+ }
+
+ /* Delete apache vhost
+ */
+ foreach($tmp['del'] as $dn => $del){
+ $ldap->cd($dn);
+ $ldap->rmdir_recursive($dn);
+ show_ldap_error($ldap->get_error(), _("Removing Apache entries failed"));
+ }
+
+ /* move follwoing entries
+ */
+ foreach($tmp['move'] as $src => $dst){
+ $this->recursive_move($src,$dst);
+ }
+
+ /* Add || Update new apache entries
+ */
+ foreach($tmp['add'] as $dn => $attrs){
+ $ldap->cd($dn);
+// user_error(print_r($dn,true));
+ $ldap->cat($dn, array('dn'));
+ if(count($ldap->fetch())){
+ $ldap->cd($dn);
+ $ldap->modify ($attrs);
+ }else{
+ $ldap->cd($dn);
+ $ldap->add($attrs);
+ }
+ show_ldap_error($ldap->get_error(), _("Saving apache entries failed"));
+ }
+ }
+}
+// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
+?>
diff --git a/vhost-apache2/systems/apache2/functions_apache.inc b/vhost-apache2/systems/apache2/functions_apache.inc
--- /dev/null
@@ -0,0 +1,257 @@
+<?php
+
+
+/* This function returns the vhost entries specified for given host
+ */
+function getVhostEntries($config,$HostDn,$silent = false)
+{
+
+ $ldap = $config->get_ldap_link();
+ $ldap->cd($config->current['BASE']);
+
+ /* Get host entry */
+ $ldap->cat($HostDn);
+ $host_attr = $ldap->fetch();
+
+ /* Create template for all fetched vhosts Data
+ */
+ $VhostBase = array();
+ $VhostBase['exists'] = false;
+ //$VhostBase['RECORDS'] = array();
+ $VhostBase['apacheServerName'] = array();
+ $VhostBase['apacheConfig'] = array();
+
+ $Vhosts = array();
+
+ /* Get & Parse all vhosts entries
+ */
+ $ldap->ls("(&(objectClass=apacheConfig)(apacheServerName=*))",$HostDn,array("*"));
+ $tmp_res = array();
+ while($attrs = $ldap->fetch()) {
+ $tmp_res[] = $attrs;
+ }
+
+ /* Parse fetched vhosts
+ */
+ foreach($tmp_res as $attrs){
+
+ $apacheServerName = $attrs['apacheServerName'][0];
+ $apacheDocumentRoot = $attrs['apacheDocumentRoot'][0];
+ $apacheServerAdmin = $attrs['apacheServerAdmin'][0];
+ $Vhosts[$apacheServerName] = $VhostBase;
+ $Vhosts[$apacheServerName]['exists'] = true;
+
+ /* Set basic attributes
+ */
+ if(isset($attrs["apacheConfig"][0])){
+ $Vhosts[$apacheServerName]["apacheConfig"] = $attrs["apacheConfig"][0];
+ }
+
+ /* Set initial vhosts name, to be able to detect if this entry was renamed
+ */
+ $Vhosts[$apacheServerName]['InitialApacheServerName'] = $apacheServerName;
+ $Vhosts[$apacheServerName]['apacheServerName'] = $apacheServerName;
+ $Vhosts[$apacheServerName]['apacheDocumentRoot'] = $apacheDocumentRoot;
+ $Vhosts[$apacheServerName]['apacheServerAdmin'] = $apacheServerAdmin;
+
+
+ if (isset($attrs['apacheServerAlias'])){
+ for($i = 0 ; $i < $attrs['apacheServerAlias']['count']; $i ++){
+ $Vhosts[$apacheServerName]['apacheServerAlias'][] = $attrs['apacheServerAlias'][$i];
+ }
+ }
+
+ if (isset($attrs['apacheScriptAlias'])){
+ for($i = 0 ; $i < $attrs['apacheScriptAlias']['count']; $i ++){
+ $Vhosts[$apacheServerName]['apacheScriptAlias'][] = $attrs['apacheScriptAlias'][$i];
+ }
+ }
+
+ }
+ return($Vhosts);
+}
+
+
+/* This function compares two apache vhosts objects and returns an
+ * array with following indexes
+ * - delete, for vhost entries which must be deleted (only if vhost entries is removed)
+ * - rename, if a dn must be renamed, for example, the apacheServerName has changed
+ * - add, if there is a new vhost entries created
+ */
+function getVhostEntriesDiff($config,$newVhosts,$HostDn)
+{
+ $oldVhosts = getVhostEntries($config,$HostDn,true);
+
+ $move = array();
+ $add = array();
+ $del = array();
+
+ /* Generate a template for vhosts with default values
+ */
+ $zoneBase = array();
+ $zoneBase['objectClass'] = array("top","apacheConfig");
+ $zoneBase['apacheServerName'] = "";
+
+ /* Contains all renamed apacheServerNames
+ * For vhosts entry udpdates
+ */
+ $PrePareVhostEntries = array();
+
+ /* Walk through all vhosts and detect renamed/added/deleted vhosts ...
+ */
+ foreach($newVhosts as $name => $zone){
+
+ /* This vhosts was renamed
+ */
+ if((!empty($zone['InitialApacheServerName'])) && ($zone['InitialApacheServerName'] != $zone['apacheServerName'])){
+
+ /* Move old vhosts to new position
+ */
+ $oldDn = "apacheServerName=".$zone['InitialApacheServerName'].",".$HostDn;
+ $newDn = "apacheServerName=".$zone['apacheServerName'].",".$HostDn;
+ $PrePareVhostEntries[$zone['InitialApacheServerName']] = $zone['apacheServerName'];
+ $move [$oldDn] = $newDn;
+ }
+
+ /* Get old vhosts if available
+ */
+ $oldVhost=array();
+ if(isset($oldVhosts[$zone['InitialApacheServerName']])){
+ if(!empty($oldVhosts[$zone['InitialApacheServerName']])){
+ $oldVhost = $oldVhosts[$zone['InitialApacheServerName']];
+ }
+ }
+
+ /* Create vhosts entry and put it in our add queue
+ */
+ $newDn = "apacheServerName=".$zone['apacheServerName'].",".$HostDn;
+ $obj = $zoneBase;
+ $obj['apacheServerName'] = $zone['apacheServerName'];
+ $obj['apacheDocumentRoot'] = $zone['apacheDocumentRoot'];
+ $obj['apacheServerAdmin'] = $zone['apacheServerAdmin'];
+
+ if(!empty($zone['apacheServerAlias'])) {
+
+ foreach($zone['apacheServerAlias'] as $rec){
+ $obj['apacheServerAlias'][] = $rec;
+ }
+ }
+
+ if(!empty($zone['apacheScriptAlias'])) {
+ foreach($zone['apacheScriptAlias'] as $rec){
+ $obj['apacheScriptAlias'][] = $rec;
+ }
+ }
+
+ /* Append udpated Vhost Entry to our add queue
+ */
+ $add[$newDn] = $obj;
+
+ /* Remove currently managed vhosts from oldVhosts.
+ * this gives us the ability to detect removed vhosts
+ */
+ if(isset($oldVhosts[$zone['InitialApacheServerName']])){
+ unset($oldVhosts[$zone['InitialApacheServerName']]);
+ }
+ }
+
+ /* The rest of our oldVhosts must be deleted
+ * because they are no longer available in newVhosts anymore.
+ */
+ foreach($oldVhosts as $zone) {
+ $oldDn = "apacheServerName=".$zone['InitialApacheServerName'].",".$HostDn;
+ $del[$oldDn] = "";
+ }
+
+ /* Check for entries which must be updated
+ */
+ $zoneUpdates = array();
+ $udpate = array();
+ if(count($PrePareVhostEntries)){
+ $ldap = $config->get_ldap_link();
+ foreach($PrePareVhostEntries as $FromVhostName => $ToVhostName){
+ $ldap->cd($HostDn);
+ $ldap->search("(&(objectClass=apacheConfig)(apacheServerName=".$FromVhostName."))",array("apacheServerName"));
+ while($attrs = $ldap->fetch()){
+ $zoneUpdates[$attrs['dn']] = array("apacheServerName"=>$ToVhostName);
+ }
+ }
+ }
+
+ $ret = array("del" => $del , "move" => $move , "add" => $add,"vhostUpdates"=>$zoneUpdates);
+// user_error(print_r($ret,true));
+ return($ret);
+}
+
+/* returns the dn for a specified zone
+ */
+function getVhostDN($config,$apacheServerNameMix)
+{
+ $ret = "";
+ if(!strstr($apacheServerNameMix, '/')) {
+ print_red(sprintf(_("Undefined vhost name '%s'. Vhost name must look like this 'www.example.com or example.com'."),$apacheServerNameMix));
+ return($ret);
+ }
+
+ $apacheServerNameIndex = split("/",$apacheServerNameMix);
+ $apacheServerName = $apacheServerNameIndex[1];
+ $nameServer = strtolower($apacheServerNameIndex[0]);
+ $ldap = $config->get_ldap_link();
+
+ /* search for the nameserver */
+ $ldap-> cd($config->current['BASE']);
+ $ldap->search("(&(objectClass=goServer)(cn=".$nameServer."))",array("cn"));
+ if($ldap->count()){
+ $attr = $ldap->fetch();
+ } else {
+ return($ret);
+ }
+
+ $ldap-> cd($attr['dn']);
+ $ldap->search("(&(objectClass=apacheConfig)(apacheServerName=".$apacheServerName."))",array("apacheServerName"));
+ if($ldap->count()){
+ $attr = $ldap->fetch();
+ return($attr['dn']);
+ }
+
+ return($ret);
+}
+
+
+/* returns all available vhosts
+ * array[reverseName] = apacheServerName;
+ */
+function getAvailableVhosts($config)
+{
+ $ret = array();
+ $ldap = $config->get_ldap_link();
+ $ldap->cd ($config->current['BASE']);
+
+ /* Search for vhosts ...
+ */
+ $ldap->search("(&(objectClass=apacheConfig)(apacheServerName=*))",array("apacheServerName"));
+
+ $ForwardVhosts = array();
+ $zones = array();
+
+ while($at = $ldap->fetch()){
+ $ForwardVhosts[$at['dn']] = $at;
+ }
+
+ foreach($ForwardVhosts as $dn => $obj){
+
+ if(preg_match("/".$dn."/",$Rdn)){
+ $zones[$Robj['apacheServerName'][0]] =$obj['apacheServerName'][0];
+ }
+ }
+ return($zones);
+}
+
+/* Simple is domain check, it checks if the given string looks like "string.string.string"
+ or string.string */
+function GetVhostsDomain($str)
+{
+ return(preg_match("/[^\.\/]+\.[^\.\/]+$/",$str));
+}
+
+?>
diff --git a/vhost-apache2/systems/apache2/servApacheVhost.tpl b/vhost-apache2/systems/apache2/servApacheVhost.tpl
--- /dev/null
@@ -0,0 +1,14 @@
+<h2>{t}Apache VHosts{/t}</h2>
+<table summary="" width="100%">
+<tr>
+ <td style="width:100%;vertical-align:top;">
+ {$VhostList}
+ <input type="submit" name="AddVhost" value="{t}Add{/t}" {$servapacheACL}>
+ </td>
+</tr>
+</table>
+<script language="JavaScript" type="text/javascript">
+ <!-- // First input field on page
+ document.mainform.AddVhost.focus();
+ -->
+</script>
diff --git a/vhost-apache2/systems/apache2/servApacheVhostEdit.tpl b/vhost-apache2/systems/apache2/servApacheVhostEdit.tpl
--- /dev/null
@@ -0,0 +1,120 @@
+<h2>{t}Generic{/t}</h2>
+<table summary="" width="100%">
+ <tr>
+ <td style="width:50%;vertical-align:top;border-right:1px solid #b0b0b0;">
+ <table summary="">
+ <tr>
+ <td>{t}Virtual Host Name{/t}{$must}
+ </td>
+ <td><input type="text" name="apacheServerName" value="{$apacheServerName}" {if $NotNew} disabled {/if}>
+ </td>
+ </tr>
+ <tr>
+ <td>{t}Virtual Host Document Root{/t}{$must}
+ </td>
+ <td><input type="text" name="apacheDocumentRoot" value="{$apacheDocumentRoot}">
+ </td>
+ </tr>
+ <tr>
+ <td>{t}Admin Mail address{/t}{$must}
+ </td>
+ <td><input type="text" name="apacheServerAdmin" value="{$apacheServerAdmin}">
+ </td>
+ </tr>
+ </table>
+ </td>
+ <td style="vertical-align:top;">
+ <table summary="" width="100%">
+ <tr>
+ <td style="vertical-align:top;width:100%;border-right:1px solid #b0b0b0;">
+ <h2>{t}Server Alias{/t}</h2>
+ <table width="100%">
+ <tr>
+ <td>
+ {$apacheServerAlias}
+ </td>
+ </tr>
+ <tr>
+ <td>
+ <table width="100%">
+ <tr>
+ <td style="vertical-align:top;width:30%;">
+ <h2>{t}URL Alias{/t}</h2>
+ </td>
+ <td>
+ <h2>{t}Directory Path{/t}</h2>
+ </td>
+ </tr>
+ <tr>
+ <td style="vertical-align:top;width:30%;">
+ <input type="text" name="StrSAAlias" value="">
+ </td>
+ <td>
+ <input type="text" name="StrSADir" value="">
+ <input type="submit" name="AddSARecord" value="{t}Add{/t}">
+ </td>
+ </tr>
+ </table>
+ </td>
+ </tr>
+ </table>
+ </td>
+ </tr>
+ </table>
+ </td>
+ </tr>
+</table>
+
+<p class="seperator"> </p>
+<br>
+
+<table summary="" width="100%">
+ <tr>
+ <td style="vertical-align:top;width:50%;border-right:1px solid #b0b0b0;">
+ <h2>{t}Script Alias{/t}</h2>
+ <table width="100%">
+ <tr>
+ <td>
+ {$apacheScriptAlias}
+ </td>
+ </tr>
+ <tr>
+ <td>
+ <table width="100%">
+ <tr>
+ <td style="vertical-align:top;width:30%;">
+ <h2>{t}Alias Directory{/t}</h2>
+ </td>
+ <td>
+ <h2>{t}Script Directory{/t}</h2>
+ </td>
+ </tr>
+ <tr>
+ <td style="vertical-align:top;width:30%;">
+ <input type="text" name="StrSCAlias" value="">
+ </td>
+ <td>
+ <input type="text" name="StrSCDir" value="">
+ <input type="submit" name="AddSCRecord" value="{t}Add{/t}">
+ </td>
+ </tr>
+ </table>
+ </td>
+ </tr>
+ </table>
+ </td>
+ <td style="vertical-align:top;">
+ </td>
+ </tr>
+</table>
+<div style="text-align:right;" align="right">
+ <p>
+ <input type="submit" name="SaveVhostChanges" value="{t}Save{/t}">
+ <input type="submit" name="CancelVhostChanges" value="{t}Cancel{/t}">
+ </p>
+</div>
+<script language="JavaScript" type="text/javascript">
+ <!-- // First input field on page
+ document.mainform.apacheServerName.focus();
+ -->
+</script>