index 259e10430917b74aa82d4f6a25d36fddf14938a1..553bdef897dd05cc3c310e2162e882864fd6f6e2 100644 (file)
{
var $governmentmode = FALSE;
var $sambaidmapping = FALSE;
- var $strict = TRUE;
- var $account_expiration =FALSE;
var $header_image = "images/ldapserver.png";
var $cyrusunixstyle = FALSE;
var $mail_settings = array("vacationdir" => "/etc/gosa/vacation",
"vacationdir_active" => FALSE);
- var $generic_settings = array( "wws_ou" => "ou=winstations",
+ var $generic_settings = array( "enableCopyPaste" => false,
+ "enableDNS" => false,
+ "enableDHCP" => false,
+ "wws_ou" => "ou=winstations",
"wws_ou_active" => FALSE,
"snapshot_active" => FALSE,
"snapshot_base" => "ou=snapshots,%base%",
- "snapshot_ldap_base" => "%base%",
- "snapshot_user" => "cn=ldapadmin,%base%",
+ "snapshot_user" => "%admin%",
"snapshot_password" => "",
"snapshot_server" => "%connection%");
var $samba_settings = array( "samba_sid" => "0-815-4711",
"samba_sid_active" => FALSE,
"samba_rid" => 1000,
+ "smbhash" => 'SMBHASH',
"samba_rid_active" => FALSE);
- var $attributes = array("strict","governmentmode","sambaidmapping","account_expiration","cyrusunixstyle","mail");
+ var $sambaDomain_found = FALSE;
+ var $use_netatalk = FALSE;
+ var $enableFAI_management = FALSE;
+
+ var $timezone = "Europe/Berlin";
+ var $timezones = array();
+
+ var $attributes = array("governmentmode","sambaidmapping","cyrusunixstyle","mail","use_netatalk","enableFAI_management","timezone");
+ var $called = FALSE;
function Step_Config2()
{
foreach($tmp['name'] as $name){
$this->mail_methods[$name] = $name;
}
+
+ /* Look for samba password generation method */
+ if(file_exists("/usr/bin/mkntpasswd")){
+ $pwdhash = "/usr/bin/mkntpasswd";
+ } elseif (preg_match("/^Usage: mkntpwd /", shell_exec ("mkntpwd 2>&1"))){
+ $pwdhash= "mkntpwd";
+ } else {
+ $pwdhash= 'perl -MCrypt::SmbHash -e "print join(q[:], ntlmgen \$ARGV[0]), $/;"';
+ }
+
+ $this->timezones = _get_tz_zones();
+ $this->samba_settings['smbhash'] = $pwdhash;
}
function execute()
{
+ /* On first call check for rid/sid base */
+ $cv = $this->parent->captured_values;
+ $ldap = new LDAP($cv['admin'],
+ $cv['password'],
+ $cv['connection'],
+ FALSE,
+ $cv['tls']);
+
+ $ldap->cd($cv['base']);
+ $ldap->search("(objectClass=sambaDomain)",array("dn"));
+ if($ldap->count()){
+ $this->sambaDomain_found =TRUE;
+ }else{
+ $this->sambaDomain_found =FALSE;
+ }
+
+ if(!$this->called){
+ if(!$this->sambaDomain_found){
+ $this->samba_settings['samba_sid_active'] = TRUE;
+ $this->samba_settings['samba_rid_active'] = TRUE;
+ }
+
+ /* Check if we can enable netatalk plugin */
+ $tmp = $ldap->get_objectclasses();
+ if(is_array($tmp) && isset($tmp['apple-user'])) {
+ $this->use_netatalk = TRUE;
+ }
+
+ /* Check the FAI schema is used */
+ if(is_array($tmp) && isset($tmp['FAIclass'])){
+# $this->enableFAI_management = TRUE;
+ }
+
+ if(is_array($tmp) && isset($tmp['dhcpClass'])){
+ $this->generic_settings['enableDHCP'] = TRUE;
+ }
+
+ if(is_array($tmp) && isset($tmp['dNSZone'])){
+ $this->generic_settings['enableDNS'] = TRUE;
+ }
+
+ $this->called = TRUE;
+ }
+
/* Update snapshot values, with already collected values */
foreach($this->generic_settings as $key => $value){
- foreach(array("snapshot_ldap_base","snapshot_base","snapshot_user","snapshot_server") as $attr){
+ foreach(array("snapshot_base","snapshot_user","snapshot_server") as $attr){
foreach($this->parent->captured_values as $replace_name => $replace_value){
if(is_string($replace_value)) {
$this->generic_settings[$attr] = preg_replace("/%".$replace_name."%/",$replace_value,$this->generic_settings[$attr]);
}
$smarty = get_smarty();
+ $smarty->assign("sambaDomain_found",$this->sambaDomain_found);
$smarty->assign("generic_settings",$this->generic_settings);
$smarty->assign("mail_settings",$this->mail_settings);
$smarty->assign("mail_methods",$this->mail_methods);
foreach($this->attributes as $attr){
$smarty->assign($attr,$this->$attr);
}
+ $smarty->assign("timezone" ,$this->timezone);
+ $smarty->assign("timezones" ,$this->timezones);
return($smarty -> fetch (get_template_path("../setup/setup_config2.tpl")));
}
{
if(isset($_POST['step6_posted'])){
+ if(isset($_POST['timezone']) && isset($this->timezones['TIMEZONES'][$_POST['timezone']])){
+ $this->timezone = $_POST['timezone'];
+ }
+
/* Get attributes */
foreach($this->attributes as $attr){
if(isset($_POST[$attr])){
- $this->$attr = validate($_POST[$attr]);
+ $this->$attr = validate(get_post($attr));
}
}
if(isset($_POST['vacationdir_active'])){
$this->mail_settings['vacationdir_active'] = TRUE;
if(isset($_POST['vacationdir'])){
- $this->mail_settings['vacationdir'] = $_POST['vacationdir'];
+ $this->mail_settings['vacationdir'] = get_post('vacationdir');
}
}else{
$this->mail_settings['vacationdir_active'] = FALSE;
}
+ if(isset($_POST['enableCopyPaste'])){
+ $this->generic_settings['enableCopyPaste'] = get_post('enableCopyPaste');
+ }
+ if(isset($_POST['enableDNS'])){
+ $this->generic_settings['enableDNS'] = get_post('enableDNS');
+ }
+ if(isset($_POST['enableDHCP'])){
+ $this->generic_settings['enableDHCP'] = get_post('enableDHCP');
+ }
+
if(isset($_POST['wws_ou_active'])){
$this->generic_settings['wws_ou_active'] = TRUE;
if(isset($_POST['wws_ou'])){
- $this->generic_settings['wws_ou'] = $_POST['wws_ou'];
+ $this->generic_settings['wws_ou'] = get_post('wws_ou');
}
}else{
$this->generic_settings['wws_ou_active'] = FALSE;
if(isset($_POST['snapshot_active'])){
$this->generic_settings['snapshot_active'] = TRUE;
if(isset($_POST['snapshot_base'])){
- $this->generic_settings['snapshot_base'] = $_POST['snapshot_base'];
+ $this->generic_settings['snapshot_base'] = get_post('snapshot_base');
}
if(isset($_POST['snapshot_user'])){
- $this->generic_settings['snapshot_user'] = $_POST['snapshot_user'];
+ $this->generic_settings['snapshot_user'] = get_post('snapshot_user');
}
if(isset($_POST['snapshot_password'])){
- $this->generic_settings['snapshot_password'] = $_POST['snapshot_password'];
+ $this->generic_settings['snapshot_password'] = get_post('snapshot_password');
}
if(isset($_POST['snapshot_server'])){
- $this->generic_settings['snapshot_server'] = $_POST['snapshot_server'];
- }
- if(isset($_POST['snapshot_ldap_base'])){
- $this->generic_settings['snapshot_ldap_base'] = $_POST['snapshot_ldap_base'];
+ $this->generic_settings['snapshot_server'] = get_post('snapshot_server');
}
}else{
$this->generic_settings['snapshot_active'] = FALSE;
if(isset($_POST['samba_sid_active'])){
$this->samba_settings['samba_sid_active'] = TRUE;
if(isset($_POST['samba_sid'])){
- $this->samba_settings['samba_sid'] = $_POST['samba_sid'];
+ $this->samba_settings['samba_sid'] = get_post('samba_sid');
}
}else{
$this->samba_settings['samba_sid_active'] = FALSE;
if(isset($_POST['samba_rid_active'])){
$this->samba_settings['samba_rid_active'] = TRUE;
if(isset($_POST['samba_rid'])){
- $this->samba_settings['samba_rid'] = $_POST['samba_rid'];
+ $this->samba_settings['samba_rid'] = get_post('samba_rid');
}
}else{
$this->samba_settings['samba_rid_active'] = FALSE;
}
+ if(isset($_POST['smbhash'])){
+ $this->samba_settings['smbhash'] = get_post('smbhash');
+ }
+ if(!$this->sambaDomain_found){
+ $this->samba_settings['samba_sid_active'] = TRUE;
+ $this->samba_settings['samba_rid_active'] = TRUE;
+ }
}
$tmp = $this->check();