reload(); } // reloads preferences from ../config/lam.conf function reload() { $conffile = substr(__FILE__, 0, strlen(__FILE__) - 15) . "/config/lam.conf"; if (is_file($conffile) == True) { $file = fopen($conffile, "r"); while (!feof($file)) { $line = fgets($file, 1024); if (($line == "\n")||($line[0] == "#")) continue; // ignore comments // search keywords if (substr($line, 0, 11) == "serverURL: ") { $this->ServerURL = chop(substr($line, 11, strlen($line)-11)); continue; } if (substr($line, 0, 8) == "passwd: ") { $this->Passwd = chop(substr($line, 8, strlen($line)-8)); continue; } if (substr($line, 0, 8) == "admins: ") { $adminstr = chop(substr($line, 8, strlen($line)-8)); $this->Adminstring = $adminstr; $this->Admins = explode(";", $adminstr); continue; } if (substr($line, 0, 12) == "usersuffix: ") { $this->Suff_users = chop(substr($line, 12, strlen($line)-12)); continue; } if (substr($line, 0, 13) == "groupsuffix: ") { $this->Suff_groups = chop(substr($line, 13, strlen($line)-13)); continue; } if (substr($line, 0, 12) == "hostsuffix: ") { $this->Suff_hosts = chop(substr($line, 12, strlen($line)-12)); continue; } if (substr($line, 0, 8) == "minUID: ") { $this->MinUID = chop(substr($line, 8, strlen($line)-8)); continue; } if (substr($line, 0, 8) == "maxUID: ") { $this->MaxUID = chop(substr($line, 8, strlen($line)-8)); continue; } if (substr($line, 0, 8) == "minGID: ") { $this->MinGID = chop(substr($line, 8, strlen($line)-8)); continue; } if (substr($line, 0, 8) == "maxGID: ") { $this->MaxGID = chop(substr($line, 8, strlen($line)-8)); continue; } if (substr($line, 0, 12) == "minMachine: ") { $this->MinMachine = chop(substr($line, 12, strlen($line)-12)); continue; } if (substr($line, 0, 12) == "maxMachine: ") { $this->MaxMachine = chop(substr($line, 12, strlen($line)-12)); continue; } if (substr($line, 0, 20) == "userlistAttributes: ") { $this->userlistAttributes = chop(substr($line, 20, strlen($line)-20)); continue; } if (substr($line, 0, 21) == "grouplistAttributes: ") { $this->grouplistAttributes = chop(substr($line, 21, strlen($line)-21)); continue; } if (substr($line, 0, 20) == "hostlistAttributes: ") { $this->hostlistAttributes = chop(substr($line, 20, strlen($line)-20)); continue; } if (substr($line, 0, 16) == "maxlistentries: ") { $this->maxlistentries = chop(substr($line, 16, strlen($line)-16)); continue; } if (substr($line, 0, 17) == "defaultLanguage: ") { $this->defaultLanguage = chop(substr($line, 17, strlen($line)-17)); continue; } if (substr($line, 0, 12) == "scriptPath: ") { $this->scriptPath = chop(substr($line, 12, strlen($line)-12)); continue; } if (substr($line, 0, 14) == "scriptServer: ") { $this->scriptServer = chop(substr($line, 14, strlen($line)-14)); continue; } if (substr($line, 0, 8) == "samba3: ") { $this->samba3 = chop(substr($line, 8, strlen($line)-8)); continue; } if (substr($line, 0, 11) == "domainSID: ") { $this->domainSID = chop(substr($line, 11, strlen($line)-11)); continue; } } fclose($file); } else { StatusMessage("ERROR", "", _("Unable to load lam.conf!") . " (" . $conffile . ")"); } } // saves preferences to ../config/lam.conf function save() { $conffile = substr(__FILE__, 0, strlen(__FILE__) - 15) . "/config/lam.conf"; if (is_file($conffile) == True) { // booleans to check if value was already saved $save_serverURL = $save_passwd = $save_admins = $save_suffusr = $save_suffgrp = $save_suffhst = $save_minUID = $save_maxUID = $save_minGID = $save_maxGID = $save_minMach = $save_maxMach = $save_usrlstatrr = $save_grplstatrr = $save_hstlstatrr = $save_maxlstent = $save_deflang = $save_scriptPath = $save_scriptServer = $save_samba3 = $save_domainSID = False; $file = fopen($conffile, "r"); $file_array = array(); // read lam.conf while (!feof($file)) { array_push($file_array, fgets($file, 1024)); } fclose($file); // generate new lam.conf for ($i = 0; $i < sizeof($file_array); $i++) { if (($file_array[$i] == "\n")||($file_array[$i][0] == "#")) continue; // ignore comments // search for keywords if (substr($file_array[$i], 0, 11) == "serverURL: ") { $file_array[$i] = "serverURL: " . $this->ServerURL . "\n"; $save_serverURL = True; continue; } if (substr($file_array[$i], 0, 8) == "passwd: ") { $file_array[$i] = "passwd: " . $this->Passwd . "\n"; $save_passwd = True; continue; } if (substr($file_array[$i], 0, 8) == "admins: ") { $file_array[$i] = "admins: " . implode(";", $this->Admins) . "\n"; $save_admins = True; continue; } if (substr($file_array[$i], 0, 12) == "usersuffix: ") { $file_array[$i] = "usersuffix: " . $this->Suff_users . "\n"; $save_suffusr = True; continue; } if (substr($file_array[$i], 0, 13) == "groupsuffix: ") { $file_array[$i] = "groupsuffix: " . $this->Suff_groups . "\n"; $save_suffgrp = True; continue; } if (substr($file_array[$i], 0, 12) == "hostsuffix: ") { $file_array[$i] = "hostsuffix: " . $this->Suff_hosts . "\n"; $save_suffhst = True; continue; } if (substr($file_array[$i], 0, 8) == "minUID: ") { $file_array[$i] = "minUID: " . $this->MinUID . "\n"; $save_minUID = True; continue; } if (substr($file_array[$i], 0, 8) == "maxUID: ") { $file_array[$i] = "maxUID: " . $this->MaxUID . "\n"; $save_maxUID = True; continue; } if (substr($file_array[$i], 0, 8) == "minGID: ") { $file_array[$i] = "minGID: " . $this->MinGID . "\n"; $save_minGID = True; continue; } if (substr($file_array[$i], 0, 8) == "maxGID: ") { $file_array[$i] = "maxGID: " . $this->MaxGID . "\n"; $save_maxGID = True; continue; } if (substr($file_array[$i], 0, 12) == "minMachine: ") { $file_array[$i] = "minMachine: " . $this->MinMachine . "\n"; $save_minMach = True; continue; } if (substr($file_array[$i], 0, 12) == "maxMachine: ") { $file_array[$i] = "maxMachine: " . $this->MaxMachine . "\n"; $save_maxMach = True; continue; } if (substr($file_array[$i], 0, 20) == "userlistAttributes: ") { $file_array[$i] = "userlistAttributes: " . $this->userlistAttributes . "\n"; $save_usrlstattr = True; continue; } if (substr($file_array[$i], 0, 21) == "grouplistAttributes: ") { $file_array[$i] = "grouplistAttributes: " . $this->grouplistAttributes . "\n"; $save_grplstattr = True; continue; } if (substr($file_array[$i], 0, 20) == "hostlistAttributes: ") { $file_array[$i] = "hostlistAttributes: " . $this->hostlistAttributes . "\n"; $save_hstlstattr = True; continue; } if (substr($file_array[$i], 0, 16) == "maxlistentries: ") { $file_array[$i] = "maxlistentries: " . $this->maxlistentries . "\n"; $save_maxlstent = True; continue; } if (substr($file_array[$i], 0, 17) == "defaultLanguage: ") { $file_array[$i] = "defaultLanguage: " . $this->defaultLanguage . "\n"; $save_deflang = True; continue; } if (substr($file_array[$i], 0, 12) == "scriptPath: ") { $file_array[$i] = "scriptPath: " . $this->scriptPath . "\n"; $save_scriptPath = True; continue; } if (substr($file_array[$i], 0, 14) == "scriptServer: ") { $file_array[$i] = "scriptServer: " . $this->scriptServer . "\n"; $save_scriptServer = True; continue; } if (substr($file_array[$i], 0, 8) == "samba3: ") { $file_array[$i] = "samba3: " . $this->samba3 . "\n"; $save_samba3 = True; continue; } if (substr($file_array[$i], 0, 11) == "domainSID: ") { $file_array[$i] = "domainSID: " . $this->domainSID . "\n"; $save_domainSID = True; continue; } } // check if we have to add new entries (e.g. if user upgraded LAM and has an old lam.conf) if (!$save_serverURL == True) array_push($file_array, "\n\n# server address (e.g. ldap://localhost:389 or ldaps://localhost:636)\n" . "serverURL: " . $this->ServerURL); if (!$save_passwd == True) array_push($file_array, "\n\n# password to change these preferences via webfrontend\n" . "passwd: " . $this->Passwd); if (!$save_admins == True) array_push($file_array, "\n\n# list of users who are allowed to use LDAP Account Manager\n" . "# names have to be seperated by semicolons\n" . "# e.g. admins: cn=admin,dc=yourdomain,dc=org;cn=root,dc=yourdomain,dc=org\n" . "admins: " . $this->Admins); if (!$save_suffusr == True) array_push($file_array, "\n\n# suffix of users\n" . "# e.g. ou=People,dc=yourdomain,dc=org\n" . "usersuffix: " . $this->Suff_users); if (!$save_suffgrp == True) array_push($file_array, "\n\n# suffix of groups\n" . "# e.g. ou=Groups,dc=yourdomain,dc=org\n" . "groupsuffix: " . $this->Suff_groups); if (!$save_suffhst == True) array_push($file_array, "\n\n# suffix of Samba hosts\n" . "# e.g. ou=machines,dc=yourdomain,dc=org\n" . "hostsuffix: " . $this->Suff_hosts); if (!$save_minUID == True) array_push($file_array, "\n\n# minimum UID number\n" . "minUID: " . $this->MinUID); if (!$save_maxUID == True) array_push($file_array, "\n\n# maximum UID number\n" . "maxUID: " . $this->MaxUID); if (!$save_minGID == True) array_push($file_array, "\n\n# minimum GID number\n" . "minGID: " . $this->MinGID); if (!$save_maxGID == True) array_push($file_array, "\n\n# maximum GID number\n" . "maxGID: " . $this->MaxGID); if (!$save_minMach == True) array_push($file_array, "\n\n# minimum UID number for Samba hosts\n" . "minMachine: " . $this->MinMachine); if (!$save_maxMach == True) array_push($file_array, "\n\n# maximum UID number for Samba hosts\n" . "maxMachine: " . $this->MaxMachine); if (!$save_usrlstattr == True) array_push($file_array, "\n\n# list of attributes to show in user list\n# entries can either be predefined values (e.g. '#cn' or '#uid')" . "\n# or individual ones (e.g. 'uid:User ID' or 'host:Host Name')\n# values have to be seperated by semicolons\n" . "userlistAttributes: " . $this->userlistAttributes); if (!$save_grplstattr == True) array_push($file_array, "\n\n# list of attributes to show in group list\n# entries can either be predefined values (e.g. '#cn' or '#gidNumber')" . "\n# or individual ones (e.g. 'cn:Group Name')\n# values have to be seperated by semicolons\n" . "grouplistAttributes: " . $this->grouplistAttributes); if (!$save_hstlstattr == True) array_push($file_array, "\n\n# list of attributes to show in host list\n# entries can either be predefined values (e.g. '#cn' or '#uid')" . "\n# or individual ones (e.g. 'cn:Host Name')\n# values have to be seperated by semicolons\n" . "hostlistAttributes: " . $this->hostlistAttributes); if (!$save_maxlstent == True) array_push($file_array, "\n\n# maximum number of rows to show in user/group/host lists\n" . "maxlistentries: " . $this->maxlistentries); if (!$save_deflang == True) array_push($file_array, "\n\n# default language (a line from language.conf)\n" . "defaultLanguage: " . $this->defaultLanguage); if (!$save_scriptPath == True) array_push($file_array, "\n\n# Path to external Script\n" . "scriptPath: " . $this->scriptPath); if (!$save_scriptServer == True) array_push($file_array, "\n\n# Server of external Script\n" . "scriptServer: " . $this->scriptServer); if (!$save_samba3 == True) array_push($file_array, "\n\n# Set to \"yes\" only if you use the new Samba 3.x schema.\n" . "samba3: " . $this->samba3); if (!$save_domainSID == True) array_push($file_array, "\n\n# Samba 3 domain SID. Set only if you use the new Samba 3.x schema.\n" . "domainSID: " . $this->domainSID); $file = fopen($conffile, "w"); if ($file) { for ($i = 0; $i < sizeof($file_array); $i++) fputs($file, $file_array[$i]); fclose($file); } else { StatusMessage("ERROR", "", _("Cannot open config file!") . " (" . $conffile . ")"); exit; } } } // prints current preferences function printconf() { echo _("ServerURL: ") . $this->ServerURL . "
"; echo _("Samba3: ") . $this->samba3 . "
"; echo _("Domain SID: ") . $this->domainSID . "
"; echo _("UserSuffix: ") . $this->Suff_users . "
"; echo _("GroupSuffix: ") . $this->Suff_groups . "
"; echo _("HostSuffix: ") . $this->Suff_hosts . "
"; echo _("minUID: ") . $this->MinUID . "
"; echo _("maxUID: ") . $this->MaxUID . "
"; echo _("minGID: ") . $this->MinGID . "
"; echo _("maxGID: ") . $this->MaxGID . "
"; echo _("minMachine: ") . $this->MinMachine . "
"; echo _("maxMachine: ") . $this->MaxMachine . "
"; echo _("userlistAttributes: ") . $this->userlistAttributes . "
"; echo _("grouplistAttributes: ") . $this->grouplistAttributes . "
"; echo _("hostlistAttributes: ") . $this->hostlistAttributes . "
"; echo _("maxlistentries: ") . $this->maxlistentries . "
"; echo _("defaultLanguage: ") . $this->defaultLanguage . "
"; echo _("scriptPath: ") . $this->scriptPath . "
"; echo _("scriptServer: ") . $this->scriptServer . "
"; echo _("Admins: ") . $this->Adminstring; } // functions to read/write preferences // returns the server address as string function get_ServerURL() { return $this->ServerURL; } // sets the server address function set_ServerURL($value) { if (is_string($value)) $this->ServerURL = $value; else StatusMessage("WARN", "", _("Config->set_ServerURL failed!") . " (" . $value . ")"); } // returns an array of string with all admin names function get_Admins() { return $this->Admins; } // needs an array of string containing all admin users function set_Admins($value) { if (is_array($value)) { // check if $value is array of strings $b = true; for($i = 0; $i < sizeof($value); $i++){ if (is_string($value[$i]) == false) { $b = false; break; } } if ($b) $this->Admins = $value; } else StatusMessage("WARN", "", _("Config->set_Admins failed!") . " (" . $value . ")"); } // returns all admin users seperated by semicolons function get_Adminstring() { return $this->Adminstring; } // needs a string that contains all admin users seperated by semicolons function set_Adminstring($value) { if (is_string($value) && ereg("^([a-zA-Z0-9]|-)+=([a-zA-Z0-9]|-)+(,([a-zA-Z0-9]|-)+=([a-zA-Z0-9]|-)+)+(;([a-zA-Z0-9]|-)+=([a-zA-Z0-9]|-)+(,([a-zA-Z0-9]|-)+=([a-zA-Z0-9]|-)+)+)*$", $value)) { $this->Adminstring = $value; $this->Admins = explode(";", $value); } else StatusMessage("WARN", "", _("Config->set_Adminstring failed!") . " (" . $value . ")"); } // returns the password to access the preferences wizard function get_Passwd() { return $this->Passwd; } // sets the preferences wizard password function set_Passwd($value) { if (is_string($value)) $this->Passwd = $value; else StatusMessage("WARN", "", _("Config->set_Passwd failed!") . " (" . $value . ")"); } // returns the LDAP suffix where users are saved function get_UserSuffix() { return $this->Suff_users; } // sets the LDAP suffix where users are saved function set_UserSuffix($value) { if (is_string($value) && (eregi("^(([a-z]|-|[0-9])*=([a-z]|-|[0-9])*)(,([a-z]|-|[0-9])*=([a-z]|-|[0-9])*)*$", $value))) { $this->Suff_users = $value; } else StatusMessage("WARN", "", _("Config->set_UserSuffix failed!") . " (" . $value . ")"); } // returns the LDAP suffix where groups are saved function get_GroupSuffix() { return $this->Suff_groups; } // sets the LDAP suffix where groups are saved function set_GroupSuffix($value) { if (is_string($value) && (eregi("^(([a-z]|-|[0-9])*=([a-z]|-|[0-9])*)(,([a-z]|-|[0-9])*=([a-z]|-|[0-9])*)*$", $value))) { $this->Suff_groups = $value; } else StatusMessage("WARN", "", _("Config->set_GroupSuffix failed!") . " (" . $value . ")"); } // returns the LDAP suffix where hosts are saved function get_HostSuffix() { return $this->Suff_hosts; } // sets the LDAP suffix where hosts are saved function set_HostSuffix($value) { if (is_string($value) && (eregi("^(([a-z]|-|[0-9])*=([a-z]|-|[0-9])*)(,([a-z]|-|[0-9])*=([a-z]|-|[0-9])*)*$", $value))) { $this->Suff_hosts = $value; } else StatusMessage("WARN", "", _("Config->set_HostSuffix failed!") . " (" . $value . ")"); } // returns the minimum UID to use when creating new users function get_minUID() { return $this->MinUID; } // sets the minimum UID to use when creating new users function set_minUID($value) { if (is_numeric($value)) $this->MinUID = $value; else StatusMessage("WARN", "", _("Config->set_minUID failed!") . " (" . $value . ")"); } // returns the maximum UID to use when creating new users function get_maxUID() { return $this->MaxUID; } // sets the maximum UID to use when creating new users function set_maxUID($value) { if (is_numeric($value)) $this->MaxUID = $value; else StatusMessage("WARN", "", _("Config->set_maxUID failed!") . " (" . $value . ")"); } // returns the minimum GID to use when creating new groups function get_minGID() { return $this->MinGID; } // sets the minimum GID to use when creating new groups function set_minGID($value) { if (is_numeric($value)) $this->MinGID = $value; else StatusMessage("WARN", "", _("Config->set_minGID failed!") . " (" . $value . ")"); } // returns the maximum GID to use when creating new groups function get_maxGID() { return $this->MaxGID; } // sets the maximum GID to use when creating new groups function set_maxGID($value) { if (is_numeric($value)) $this->MaxGID = $value; else StatusMessage("WARN", "", _("Config->set_maxGID failed!") . " (" . $value . ")"); } // returns the minimum UID to use when creating new Samba hosts function get_minMachine() { return $this->MinMachine; } // sets the minimum UID to use when creating new Samba hosts function set_minMachine($value) { if (is_numeric($value)) $this->MinMachine = $value; else StatusMessage("WARN", "", _("Config->set_minMachine failed!") . " (" . $value . ")"); } // returns the maximum UID to use when creating new Samba hosts function get_maxMachine() { return $this->MaxMachine; } // sets the maximum UID to use when creating new Samba hosts function set_maxMachine($value) { if (is_numeric($value)) $this->MaxMachine = $value; else StatusMessage("WARN", "", _("Config->set_maxMachine failed!") . " (" . $value . ")"); } // returns the list of attributes to show in user list function get_userlistAttributes() { return $this->userlistAttributes; } // sets the list of attributes to show in user list function set_userlistAttributes($value) { if (is_string($value) && eregi("^((#[a-z]*)|([a-z]*:[a-z*]))(;((#[a-z]*)|([a-z]*:[a-z]*)))*$", $value)) { $this->userlistAttributes = $value; } else StatusMessage("WARN", "", _("Config->set_userlistAttributes failed!") . " (" . $value . ")"); } // returns the list of attributes to show in group list function get_grouplistAttributes() { return $this->grouplistAttributes; } // sets the list of attributes to show in group list function set_grouplistAttributes($value) { if (is_string($value) && eregi("^((#[a-z]*)|([a-z]*:[a-z*]))(;((#[a-z]*)|([a-z]*:[a-z]*)))*$", $value)) { $this->grouplistAttributes = $value; } else StatusMessage("WARN", "", _("Config->set_grouplistAttributes failed!") . " (" . $value . ")"); } // returns the list of attributes to show in host list function get_hostlistAttributes() { return $this->hostlistAttributes; } // sets the list of attributes to show in host list function set_hostlistAttributes($value) { if (is_string($value) && eregi("^((#[a-z]*)|([a-z]*:[a-z*]))(;((#[a-z]*)|([a-z]*:[a-z]*)))*$", $value)) { $this->hostlistAttributes = $value; } else StatusMessage("WARN", "", _("Config->set_hostlistAttributes failed!") . " (" . $value . ")"); } // returns the maximum number of rows in user/group/host lists function get_MaxListEntries() { return $this->maxlistentries; } // sets the maximum number of rows in user/group/host lists function set_MaxListEntries ($value) { if (is_numeric($value)) $this->maxlistentries = $value; else StatusMessage("WARN", "", _("Config->set_MaxListEntries failed!") . $value); } // returns the default language string function get_defaultLanguage() { return $this->defaultLanguage; } // sets the default language string function set_defaultLanguage($value) { if (is_string($value)) $this->defaultLanguage = $value; else StatusMessage("WARN", "", _("Config->set_defaultLanguage failed!") . " (" . $value . ")"); } // returns the path to the external script function get_scriptPath() { return $this->scriptPath; } // sets the path to the external script function set_scriptPath($value) { if (!$value) $value = ""; // optional parameter if (is_string($value) && eregi("^()|(/([a-z]|[0-9]|-|_|/)*)$", $value)) $this->scriptPath = $value; else StatusMessage("WARN", "", _("Config->set_scriptPath failed!") . " (" . $value . ")"); } // returns the server of the external script function get_scriptServer() { return $this->scriptServer; } // sets the server of the external script function set_scriptServer($value) { if (!$value) $value = ""; // optional parameter if (is_string($value) && (eregi("^[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}$", $value) || $value == "")) { $this->scriptServer = $value; } else StatusMessage("WARN", "", _("Config->set_scriptServer failed!") . " (" . $value . ")"); } // returns "yes" if Samba 3.x schema is used, otherwise "no" function get_samba3() { return $this->samba3; } // set Samba version: "yes" means 3.x schema, "no" means 2.2.x schema function set_samba3($value) { if (is_string($value) && eregi("^(yes|no)$", $value)) { $this->samba3 = $value; } else StatusMessage("WARN", "", _("Config->set_samba3 failed!") . " (" . $value . ")"); } // returns the Samba domain SID (Samba 3 only) function get_domainSID() { return $this->domainSID; } // sets the Samba domain SID (Samba 3 only) function set_domainSID($value) { if (!$value) { // optional parameter $value = ""; $this->domainSID = $value; } elseif (is_string($value) && eregi("^S-[0-9]-[0-9]-[0-9]{2,2}-[0-9]{10,10}-[0-9]{10,10}-[0-9]{10,10}$", $value)) { $this->domainSID = $value; } else StatusMessage("WARN", "", _("Config->set_domainSID failed!") . " (" . $value . ")"); } } ?>