From c7b4e4a81d7f38c0f1f927f6804ef281c4f67dcd Mon Sep 17 00:00:00 2001 From: Tarik Gasmi Date: Tue, 31 Jul 2007 07:29:53 +0000 Subject: Actualized LDAP SiteManagement Code - Web Interface, DHCP Generationscript git-svn-id: http://svn.openslx.org/svn/openslx/trunk@1284 95ad53e4-c205-0410-b2fa-d234c58c8868 --- ldap-site-mngmt/webinterface/rbs/rbservice.dwt | 14 +- ldap-site-mngmt/webinterface/rbs/rbservice.php | 26 +-- .../webinterface/rbs/rbservice_change.php | 212 ++++++++------------- 3 files changed, 99 insertions(+), 153 deletions(-) (limited to 'ldap-site-mngmt/webinterface/rbs') diff --git a/ldap-site-mngmt/webinterface/rbs/rbservice.dwt b/ldap-site-mngmt/webinterface/rbs/rbservice.dwt index 601372cd..e738d990 100644 --- a/ldap-site-mngmt/webinterface/rbs/rbservice.dwt +++ b/ldap-site-mngmt/webinterface/rbs/rbservice.dwt @@ -57,27 +57,27 @@   -   +     TFTP Server:   - - + + Hostname: {TFTP}  [IP: {TFTPIP}] TFTP Root - + - {TFTP} + ändern: - - + PXE Path diff --git a/ldap-site-mngmt/webinterface/rbs/rbservice.php b/ldap-site-mngmt/webinterface/rbs/rbservice.php index f3c5db7e..b6b7162d 100644 --- a/ldap-site-mngmt/webinterface/rbs/rbservice.php +++ b/ldap-site-mngmt/webinterface/rbs/rbservice.php @@ -75,9 +75,8 @@ $name = array_slice($expcn,1); $rbscn = implode('_',$name); # Server Hostnamen holen -$tftpserver = get_hostname_from_ip($rbs_data['tftpserverip'],$auDN); -$nfsserver = get_hostname_from_ip($rbs_data['nfsserverip'],$auDN); -$nbdserver = get_hostname_from_ip($rbs_data['nbdserverip'],$auDN); +$tftpserver = get_hostname_from_ip($rbs_data['tftpserverip']); +#print_r($tftpserver); $template->assign(array("RBSDN" => $rbs_data['dn'], "RBSCN" => $rbscn, @@ -127,21 +126,14 @@ $hostorgroup = $exp[0]; $hosts_array = get_hosts($auDN,array("dn","hostname","ipaddress")); $template->define_dynamic("TftpHosts", "Webseite"); -$template->define_dynamic("NfsHosts", "Webseite"); -$template->define_dynamic("NbdHosts", "Webseite"); foreach ($hosts_array as $item){ - $template->assign(array("HDN" => $item['dn'], - "HN" => $item['hostname'], - "IP" => $item['ipaddress'])); - $template->parse("TFTPHOSTS_LIST", ".TftpHosts"); - $template->assign(array("HDN" => $item['dn'], - "HN" => $item['hostname'], - "IP" => $item['ipaddress'])); - $template->parse("NFSHOSTS_LIST", ".NfsHosts"); - $template->assign(array("HDN" => $item['dn'], - "HN" => $item['hostname'], - "IP" => $item['ipaddress'])); - $template->parse("NBDHOSTS_LIST", ".NbdHosts"); + if ($item['ipaddress'] != "" && $item['hostname'] != $tftpserver['hostname']){ + $hostip = explode("_",$item['ipaddress']); + $template->assign(array("HDN" => $item['dn'], + "HN" => $item['hostname'], + "IP" => $hostip[0])); + $template->parse("TFTPHOSTS_LIST", ".TftpHosts"); + } } ################################################ diff --git a/ldap-site-mngmt/webinterface/rbs/rbservice_change.php b/ldap-site-mngmt/webinterface/rbs/rbservice_change.php index 5f82ac26..f7557dfb 100644 --- a/ldap-site-mngmt/webinterface/rbs/rbservice_change.php +++ b/ldap-site-mngmt/webinterface/rbs/rbservice_change.php @@ -9,28 +9,27 @@ $oldrbsoffer = $_POST['oldrbsoffer']; $tftpserverip = $_POST['tftpserverip']; $oldtftpserverip = $_POST['oldtftpserverip']; -$nfsserverip = $_POST['nfsserverip']; -$oldnfsserverip = $_POST['oldnfsserverip']; -$nbdserverip = $_POST['nbdserverip']; -$oldnbdserverip = $_POST['oldnbdserverip']; +#$nfsserverip = $_POST['nfsserverip']; +#$oldnfsserverip = $_POST['oldnfsserverip']; +#$nbdserverip = $_POST['nbdserverip']; +#$oldnbdserverip = $_POST['oldnbdserverip']; $tftpserver = $_POST['tftpserver']; -$nfsserver = $_POST['nfsserver']; -$nbdserver = $_POST['nbdserver']; +#$nfsserver = $_POST['nfsserver']; +#$nbdserver = $_POST['nbdserver']; $oldtftpserverdn = $_POST['oldtftpserverdn']; -$oldnfsserverdn = $_POST['oldnfsserverdn']; -$oldnbdserverdn = $_POST['oldnbdserverdn']; +#$oldnfsserverdn = $_POST['oldnfsserverdn']; +#$oldnbdserverdn = $_POST['oldnbdserverdn']; + +$initbootfile = $_POST['initbootfile']; +$oldinitbootfile = $_POST['oldinitbootfile']; $delfsuri = $_POST['delfsuri']; $addfsuri = $_POST['addfsuri']; - $fstype = $_POST['fstype']; $fsip = $_POST['fsip']; $fspath = $_POST['fspath']; -$initbootfile = $_POST['initbootfile']; -$oldinitbootfile = $_POST['oldinitbootfile']; - $host_array = get_hosts($auDN,array("dn","hostname","ipaddress")); $rbsDN = $_POST['rbsdn']; @@ -133,12 +132,15 @@ if ( $rbsoffer != "none" && $rbsoffer != $oldrbsoffer ){ ##################################### -# Server ändern über IP Feld +# TFTP Server ändern +# über IP Feld +/*if ( $tftpserverip == $oldtftpserverip ){ + # $mesg = "keine Aenderung
"; +} -if ( $tftpserverip != "" && $tftpserverip != $oldtftpserverip ){ - - if ($syntax->check_ip_syntax($tftpserverip)){ +if ( $tftpserverip != "" && $oldtftpserverip == "" ){ + if ($syntax->check_ip_syntax($tftpserverip)){ $tftpserverip = htmlentities($tftpserverip); $mesg .= "Suche nach dem Rechner mit IP ".$tftpserverip." :
"; @@ -147,11 +149,11 @@ if ( $tftpserverip != "" && $tftpserverip != $oldtftpserverip ){ $hostip = $hostipexp[0]; if ($tftpserverip == $hostip){ $entrytftp ['tftpserverip'] = $tftpserverip; - if (ldap_mod_replace($ds,$rbsDN,$entrytftp)){ + if (ldap_mod_add($ds,$rbsDN,$entrytftp)){ adjust_dhcpnextserver($tftpserverip, $rbsDN); - $mesg .= "Treffer: Rechner ".$host['hostname']."
TFTP Server erfolgreich geändert
"; + $mesg .= "Treffer: Rechner ".$host['hostname']."
TFTP Server erfolgreich eingetragen
"; }else{ - $mesg .= "Fehler beim ändern des TFTP Servers!
"; + $mesg .= "Fehler beim Eintragen des TFTP Servers!
"; } break; }else{ @@ -164,64 +166,26 @@ if ( $tftpserverip != "" && $tftpserverip != $oldtftpserverip ){ } } -####################################### -# Fileserver URI anlegen - -if ( $addfsuri[1] != "" ){ - # tests: ipsyntax, und spezifische URI-Syntax-Checks... - if( $syntax->check_ip_syntax($addfsuri[1]) ){ - - $newfsuri = $addfsuri[0]."://".$addfsuri[1].$addfsuri[2]; - echo "FS URI ".$newfsuri." anlegen
"; - - $entryfsadd ['fileserveruri'] = $newfsuri; - if(ldap_mod_add($ds,$rbsDN,$entryfsadd)){ - $mesg = "FS URI erfolgreich eingetragen

"; - }else{ - $mesg = "Fehler beim eintragen der FS URI

"; - } - } - else{echo "Falsche IP Syntax

";} -} - -##################################### -# Fileserver URIs löschen -if ( count($delfsuri) != 0 ){ - echo "Fileserver URI löschen
"; - - $i = 0; - foreach ($delfsuri as $fsuri){ - $entry['fileserveruri'][$i] = $fsuri; - $i++; - } - #print_r($entry); echo "

"; - - if ($result = ldap_mod_del($ds,$rbsDN,$entry)){ - $mesg = "Zu löschende Fileserver URIs erfolgreich gelöscht

"; - }else{ - $mesg = "Fehler beim löschen der Fileserver URIs

"; - } -} - -if ( $nfsserverip != "" && $nfsserverip != $oldnfsserverip ){ +if ( $tftpserverip != "" && $tftpserverip != $oldtftpserverip ){ - if ($syntax->check_ip_syntax($nfsserverip)){ - $nfsserverip = htmlentities($nfsserverip); + if ($syntax->check_ip_syntax($tftpserverip)){ + $tftpserverip = htmlentities($tftpserverip); - $mesg .= "Suche nach dem Rechner mit IP ".$nfsserverip." :
"; + $mesg .= "Suche nach dem Rechner mit IP ".$tftpserverip." :
"; foreach ($host_array as $host){ $hostipexp = explode('_',$host['ipaddress']); $hostip = $hostipexp[0]; - if ($nfsserverip == $hostip){ - $entrytnfs ['nfsserverip'] = $nfsserverip; - if (ldap_mod_replace($ds,$rbsDN,$entrytnfs)){ - $mesg .= "Treffer: Rechner ".$host['hostname']."
NFS Server erfolgreich geändert
"; + if ($tftpserverip == $hostip){ + $entrytftp ['tftpserverip'] = $tftpserverip; + if (ldap_mod_replace($ds,$rbsDN,$entrytftp)){ + adjust_dhcpnextserver($tftpserverip, $rbsDN); + $mesg .= "Treffer: Rechner ".$host['hostname']."
TFTP Server erfolgreich geändert
"; }else{ - $mesg .= "Fehler beim ändern des NFS Servers!
"; + $mesg .= "Fehler beim ändern des TFTP Servers!
"; } break; }else{ - $mesg .= "Rechner ".$host['hostname'].": keine Übereinstimmung mit eingegebener IP ".$nfsserverip."!
"; + $mesg .= "Rechner ".$host['hostname'].": keine Übereinstimmung mit eingegebener IP ".$tftpserverip."!
"; } } } @@ -230,78 +194,29 @@ if ( $nfsserverip != "" && $nfsserverip != $oldnfsserverip ){ } } -if ( $nbdserverip != "" && $nbdserverip != $oldnbdserverip ){ - - if ($syntax->check_ip_syntax($nbdserverip)){ - $nbdserverip = htmlentities($nbdserverip); - - $mesg .= "Suche nach dem Rechner mit IP ".$nbdserverip." :
"; - foreach ($host_array as $host){ - $hostipexp = explode('_',$host['ipaddress']); - $hostip = $hostipexp[0]; - if ($nbdserverip == $hostip){ - $entrytnbd ['nbdserverip'] = $nbdserverip; - if (ldap_mod_replace($ds,$rbsDN,$entrytnbd)){ - $mesg .= "Treffer: Rechner ".$host['hostname']."
NBD Server erfolgreich geändert
"; - }else{ - $mesg .= "Fehler beim ändern des NBD Servers!
"; - } - break; - }else{ - $mesg .= "Rechner ".$host['hostname'].": keine Übereinstimmung mit eingegebener IP ".$nbdserverip."!
"; - } - } - } - else{ - $mesg .= "Falsche IP Syntax!
"; +if ( $tftpserverip == "" && $oldtftpserverip != "" ){ + $entrytftp ['tftpserverip'] = array(); + if (ldap_mod_del($ds,$rbsDN,$entrytftp)){ + adjust_dhcpnextserver($tftpserverip, $rbsDN); + $mesg .= "Treffer: Rechner ".$host['hostname']."
TFTP Server erfolgreich gelöscht
"; + }else{ + $mesg .= "Fehler beim löschen des TFTP Servers!
"; } -} - -##################################### -# Server ändern über Hostname +}*/ +#über Selectbox an verfügbaren alternativen Rechnern mit IPs if ($tftpserver != "none" && $tftpserver != $oldtftpserverdn){ - $host = get_host_ip($tftpserver); $hostipexp = explode('_',$host['ipaddress']); - $hostip = $hostipexp[0]; - $entrytftp ['tftpserverip'] = $hostip; + $entrytftp ['tftpserverip'] = $hostipexp[0]; if (ldap_mod_replace($ds,$rbsDN,$entrytftp)){ - adjust_dhcpnextserver($tftpserverip, $rbsDN); + adjust_dhcpnextserver($hostipexp[0], $rbsDN); $mesg .= "TFTP Server erfolgreich geändert
"; }else{ $mesg .= "Fehler beim ändern des TFTP Servers!
"; - } - + } } -if ($nfsserver != "none" && $nfsserver != $oldnfsserverdn){ - - $host = get_host_ip($nfsserver); - $hostipexp = explode('_',$host['ipaddress']); - $hostip = $hostipexp[0]; - $entrynfs ['nfsserverip'] = $hostip; - if (ldap_mod_replace($ds,$rbsDN,$entrynfs)){ - $mesg .= "NFS Server erfolgreich geändert
"; - }else{ - $mesg .= "Fehler beim ändern des NFS Servers!
"; - } - -} - -if ($nbdserver != "none" && $nbdserver != $oldnbdserverdn){ - - $host = get_host_ip($nbdserver); - $hostipexp = explode('_',$host['ipaddress']); - $hostip = $hostipexp[0]; - $entrytnbd ['nbdserverip'] = $hostip; - if (ldap_mod_replace($ds,$rbsDN,$entrytnbd)){ - $mesg .= "NBD Server erfolgreich geändert
"; - }else{ - $mesg .= "Fehler beim ändern des NBD Servers!
"; - } - -} ##################################### # Init Boot File @@ -344,6 +259,45 @@ if ( $initbootfile != "" && $initbootfile != $oldinitbootfile ){ } +####################################### +# Fileserver URI anlegen + +if ( $addfsuri[1] != "" ){ + # tests: ipsyntax, und spezifische URI-Syntax-Checks... + if( $syntax->check_ip_syntax($addfsuri[1]) ){ + + $newfsuri = $addfsuri[0]."://".$addfsuri[1].$addfsuri[2]; + echo "FS URI ".$newfsuri." anlegen
"; + + $entryfsadd ['fileserveruri'] = $newfsuri; + if(ldap_mod_add($ds,$rbsDN,$entryfsadd)){ + $mesg = "FS URI erfolgreich eingetragen

"; + }else{ + $mesg = "Fehler beim eintragen der FS URI

"; + } + } + else{echo "Falsche IP Syntax

";} +} + +##################################### +# Fileserver URIs löschen + +if ( count($delfsuri) != 0 ){ + echo "Fileserver URI löschen
"; + + $i = 0; + foreach ($delfsuri as $fsuri){ + $entry['fileserveruri'][$i] = $fsuri; + $i++; + } + #print_r($entry); echo "

"; + + if ($result = ldap_mod_del($ds,$rbsDN,$entry)){ + $mesg = "Zu löschende Fileserver URIs erfolgreich gelöscht

"; + }else{ + $mesg = "Fehler beim löschen der Fileserver URIs

"; + } +} ##################################### -- cgit v1.2.3-55-g7522