1109 lines
33 KiB
PHP
1109 lines
33 KiB
PHP
<?php
|
|
/*
|
|
$Id$
|
|
|
|
This code is part of LDAP Account Manager (http://www.sourceforge.net/projects/lam)
|
|
Copyright (C) 2003 - 2004 Roland Gruber
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
|
|
*/
|
|
|
|
/**
|
|
* This file includes functions to manage the configuration files.
|
|
*
|
|
* @package configuration
|
|
* @author Roland Gruber
|
|
*/
|
|
|
|
/** Used to print messages. */
|
|
include_once("status.inc");
|
|
/** Used to get module information. */
|
|
include_once("modules.inc");
|
|
|
|
/**
|
|
* Sets language settings for automatic translation
|
|
*/
|
|
function setlanguage() {
|
|
if ($_SESSION['language']) {
|
|
$language = explode(":", $_SESSION['language']);
|
|
putenv("LANG=" . $language[0]); // e.g. LANG=de_DE
|
|
setlocale(LC_ALL, $language[0]); // set LC_ALL to de_DE
|
|
$locdir = substr(__FILE__, 0, strlen(__FILE__) - 15) . "/locale"; // set path to translations
|
|
bindtextdomain("messages", $locdir);
|
|
textdomain("messages");
|
|
}
|
|
else echo _("Language not defined in session!");
|
|
}
|
|
|
|
/**
|
|
* Returns an array of string with all available configuration profiles (without .conf)
|
|
*
|
|
* @return array profile names
|
|
*/
|
|
function getConfigProfiles() {
|
|
$dir = dir(substr(__FILE__, 0, strlen(__FILE__) - 15) . "/config");
|
|
$ret = array();
|
|
$pos = 0;
|
|
while ($entry = $dir->read()){
|
|
$ext = substr($entry, strlen($entry)-5, 5);
|
|
$name = substr($entry, 0, strlen($entry)-5);
|
|
// check if extension is right, add to profile list
|
|
if ($ext == ".conf") {
|
|
$ret[$pos] = $name;
|
|
$pos ++;
|
|
}
|
|
}
|
|
sort($ret);
|
|
return $ret;
|
|
}
|
|
|
|
/**
|
|
* Prints a meta refresh page
|
|
*
|
|
* @param string $page the URL of the target page
|
|
*/
|
|
function metaRefresh($page) {
|
|
echo $_SESSION['header'];
|
|
echo "<meta http-equiv=\"refresh\" content=\"0; URL=" . $page . "\">\n";
|
|
echo "<title></title>\n";
|
|
echo "</head>\n";
|
|
echo "<body>\n";
|
|
// print link if refresh does not work
|
|
echo "<p>\n";
|
|
echo "<a href=\"" . $page . "\">" . _("Click here if you are not directed to the next page.") . "</a>\n";
|
|
echo "</p>\n";
|
|
echo "</body>\n";
|
|
echo "</html>\n";
|
|
}
|
|
|
|
|
|
/**
|
|
* This class manages .conf files.
|
|
*
|
|
* @package configuration
|
|
*/
|
|
class Config {
|
|
|
|
/** Server address (e.g. ldap://127.0.0.1:389) */
|
|
var $ServerURL;
|
|
|
|
/** Array of string: users with admin rights */
|
|
var $Admins;
|
|
|
|
/** Password to edit preferences */
|
|
var $Passwd;
|
|
|
|
/** LDAP suffix for users */
|
|
var $usersuffix;
|
|
|
|
/** LDAP suffix for groups */
|
|
var $groupsuffix;
|
|
|
|
/** LDAP suffix for Samba hosts */
|
|
var $hostsuffix;
|
|
|
|
/** LDAP suffix for Samba 3 domains */
|
|
var $domainsuffix;
|
|
|
|
/** Minimum UID number for users */
|
|
var $MinUID;
|
|
/** Maximum UID number for users */
|
|
var $MaxUID;
|
|
/** Minimum GID number for groups */
|
|
var $MinGID;
|
|
/** Maximum GID number for groups */
|
|
var $MaxGID;
|
|
/** Minimum UID number for Samba hosts */
|
|
var $MinMachine;
|
|
/** Maximum UID number for Samba hosts */
|
|
var $MaxMachine;
|
|
|
|
/** Attributes that are shown in the user list */
|
|
var $userlistAttributes;
|
|
/** Attributes that are shown in the group list */
|
|
var $grouplistAttributes;
|
|
/** Attributes that are shown in the host list */
|
|
var $hostlistAttributes;
|
|
|
|
/** Maximum number of rows shown in user/group/host lists */
|
|
var $maxlistentries;
|
|
|
|
/** Default language */
|
|
var $defaultLanguage;
|
|
|
|
/** module settings */
|
|
var $moduleSettings = array();
|
|
|
|
/**
|
|
* Path to external lamdaemon script on server where it is executed
|
|
*
|
|
* This is used for managing quota and home directories.
|
|
* optional setting, may not be defined
|
|
*/
|
|
var $scriptPath;
|
|
|
|
/**
|
|
* Server where lamdaemon script is executed
|
|
*
|
|
* This is used for managing quota and home directories.
|
|
* optional setting, may not be defined
|
|
*/
|
|
var $scriptServer;
|
|
|
|
/** LDAP cache timeout */
|
|
var $cachetimeout;
|
|
|
|
/** Password hash algorithm */
|
|
var $pwdhash;
|
|
|
|
/**
|
|
* Account modules
|
|
* TODO add default modules for LAM <0.5
|
|
*/
|
|
var $usermodules = "um1,um2,um3";
|
|
var $groupmodules = "gm1,gm2,gm3";
|
|
var $hostmodules = "hm1,hm2,hm3";
|
|
|
|
/** Name of configuration file */
|
|
var $file;
|
|
|
|
/** List of all settings in config file */
|
|
var $settings = array("ServerURL", "Passwd", "Admins", "usersuffix", "groupsuffix", "hostsuffix",
|
|
"domainsuffix", "MinUID", "MaxUID", "MinGID", "MaxGID", "MinMachine", "MaxMachine",
|
|
"userlistAttributes", "grouplistAttributes", "hostlistAttributes", "maxlistentries",
|
|
"defaultLanguage", "scriptPath", "scriptServer", "cachetimeout", "pwdhash",
|
|
"usermodules", "groupmodules", "hostmodules", "modules");
|
|
|
|
|
|
/**
|
|
* Loads preferences from config file
|
|
*
|
|
* @param $file Index number in config file array
|
|
*/
|
|
function Config($file = 0) {
|
|
// load first profile if none is given
|
|
if (!is_string($file)) {
|
|
$profiles = getConfigProfiles();
|
|
$file = $profiles[0];
|
|
}
|
|
$this->file = $file;
|
|
$this->reload();
|
|
}
|
|
|
|
/**
|
|
* Reloads preferences from config file
|
|
*
|
|
* @return boolean true if file was readable
|
|
*/
|
|
function reload() {
|
|
$conffile = substr(__FILE__, 0, strlen(__FILE__) - 15) . "/config/" . $this->file . ".conf";
|
|
if (is_file($conffile) == True) {
|
|
$file = @fopen($conffile, "r");
|
|
if (!$file) return false; // abort if file is not readable
|
|
while (!feof($file)) {
|
|
$line = fgets($file, 1024);
|
|
$line = trim($line); // remove spaces at the beginning and end
|
|
if (($line == "")||($line[0] == "#")) continue; // ignore comments and empty lines
|
|
// search keywords
|
|
for ($i = 0; $i < sizeof($this->settings); $i++) {
|
|
$keyword = $this->settings[$i];
|
|
$keylen = strlen($keyword);
|
|
if (strtolower(substr($line, 0, $keylen + 2)) == strtolower($keyword . ": ")) {
|
|
// module settings
|
|
if (strtolower(substr($line, 0, $keylen + 2)) == "modules: ") {
|
|
$option = substr($line, $keylen + 2, strlen($line) - $keylen - 2);
|
|
$pos = strpos($option, ":");
|
|
$this->moduleSettings[substr($option, 0, $pos)] = substr($option, $pos + 2, strlen($option) - $pos - 2);
|
|
}
|
|
// general settings
|
|
else {
|
|
$this->$keyword = substr($line, $keylen + 2, strlen($line) - $keylen - 2);
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
fclose($file);
|
|
}
|
|
return true;
|
|
}
|
|
|
|
/** Saves preferences to config file */
|
|
function save() {
|
|
$conffile = substr(__FILE__, 0, strlen(__FILE__) - 15) . "/config/" . $this->file . ".conf";
|
|
if (is_file($conffile) == True) {
|
|
$file = fopen($conffile, "r");
|
|
$file_array = array();
|
|
// read config file
|
|
while (!feof($file)) {
|
|
array_push($file_array, fgets($file, 1024));
|
|
}
|
|
fclose($file);
|
|
// generate new configuration file
|
|
$saved = array(); // includes all settings which have been saved
|
|
$mod_saved = array(); // includes all module settings which have been saved
|
|
for ($i = 0; $i < sizeof($file_array); $i++) {
|
|
$line = trim($file_array[$i]);
|
|
if (($line == "")||($line[0] == "#")) continue; // ignore comments and empty lines
|
|
// search for keywords
|
|
for ($k = 0; $k < sizeof($this->settings); $k++) {
|
|
$keyword = $this->settings[$k];
|
|
$keylen = strlen($keyword);
|
|
if (strtolower(substr($line, 0, $keylen + 1)) == strtolower($keyword . ":")) {
|
|
// module settings
|
|
if (strtolower(substr($line, 0, $keylen + 2)) == "modules: ") {
|
|
$option = substr($line, $keylen + 2, strlen($line) - $keylen - 2);
|
|
$pos = strpos($option, ":");
|
|
$name = substr($option, 0, $pos);
|
|
$file_array[$i] = "modules: " . $name . ": " . $this->moduleSettings[$name] . "\n";
|
|
$mod_saved[] = $name; // mark keyword as saved
|
|
}
|
|
// general settings
|
|
else {
|
|
$file_array[$i] = $keyword . ": " . $this->$keyword . "\n";
|
|
$saved[] = $keyword; // mark keyword as saved
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
// check if we have to add new entries (e.g. if user upgraded LAM and has an old config file)
|
|
if (!in_array("ServerURL", $saved)) array_push($file_array, "\n\n# server address (e.g. ldap://localhost:389 or ldaps://localhost:636)\n" . "serverURL: " . $this->ServerURL . "\n");
|
|
if (!in_array("Passwd", $saved)) array_push($file_array, "\n\n# password to change these preferences via webfrontend\n" . "passwd: " . $this->Passwd . "\n");
|
|
if (!in_array("Admins", $saved)) 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 . "\n");
|
|
if (!in_array("usersuffix", $saved)) array_push($file_array, "\n\n# suffix of users\n" .
|
|
"# e.g. ou=People,dc=yourdomain,dc=org\n" . "usersuffix: " . $this->usersuffix . "\n");
|
|
if (!in_array("groupsuffix", $saved)) array_push($file_array, "\n\n# suffix of groups\n" .
|
|
"# e.g. ou=Groups,dc=yourdomain,dc=org\n" . "groupsuffix: " . $this->groupsuffix . "\n");
|
|
if (!in_array("hostsuffix", $saved)) array_push($file_array, "\n\n# suffix of Samba hosts\n" .
|
|
"# e.g. ou=machines,dc=yourdomain,dc=org\n" . "hostsuffix: " . $this->hostsuffix . "\n");
|
|
if (!in_array("domainsuffix", $saved)) array_push($file_array, "\n\n# suffix of Samba 3 domains\n" .
|
|
"# e.g. ou=domains,dc=yourdomain,dc=org\n" . "domainsuffix: " . $this->domainsuffix . "\n");
|
|
if (!in_array("MinUID", $saved)) array_push($file_array, "\n\n# minimum UID number\n" . "minUID: " . $this->MinUID . "\n");
|
|
if (!in_array("MaxUID", $saved)) array_push($file_array, "\n\n# maximum UID number\n" . "maxUID: " . $this->MaxUID . "\n");
|
|
if (!in_array("MinGID", $saved)) array_push($file_array, "\n\n# minimum GID number\n" . "minGID: " . $this->MinGID . "\n");
|
|
if (!in_array("MaxGID", $saved)) array_push($file_array, "\n\n# maximum GID number\n" . "maxGID: " . $this->MaxGID . "\n");
|
|
if (!in_array("MinMachine", $saved)) array_push($file_array, "\n\n# minimum UID number for Samba hosts\n" . "minMachine: " . $this->MinMachine . "\n");
|
|
if (!in_array("MaxMachine", $saved)) array_push($file_array, "\n\n# maximum UID number for Samba hosts\n" . "maxMachine: " . $this->MaxMachine . "\n");
|
|
if (!in_array("userlistAttributes", $saved)) 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 . "\n");
|
|
if (!in_array("grouplistAttributes", $saved)) 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 . "\n");
|
|
if (!in_array("hostlistAttributes", $saved)) 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 . "\n");
|
|
if (!in_array("maxlistentries", $saved)) array_push($file_array, "\n\n# maximum number of rows to show in user/group/host lists\n" . "maxlistentries: " . $this->maxlistentries . "\n");
|
|
if (!in_array("defaultLanguage", $saved)) array_push($file_array, "\n\n# default language (a line from config/language)\n" . "defaultLanguage: " . $this->defaultLanguage . "\n");
|
|
if (!in_array("scriptPath", $saved)) array_push($file_array, "\n\n# Path to external Script\n" . "scriptPath: " . $this->scriptPath . "\n");
|
|
if (!in_array("scriptServer", $saved)) array_push($file_array, "\n\n# Server of external Script\n" . "scriptServer: " . $this->scriptServer . "\n");
|
|
if (!in_array("cachetimeout", $saved)) array_push($file_array, "\n\n# Number of minutes LAM caches LDAP searches.\n" . "cacheTimeout: " . $this->cachetimeout . "\n");
|
|
if (!in_array("pwdhash", $saved)) array_push($file_array, "\n\n# Password hash algorithm (CRYPT/MD5/SMD5/SHA/SSHA/PLAIN).\n" . "pwdhash: " . $this->pwdhash . "\n");
|
|
if (!in_array("usermodules", $saved)) array_push($file_array, "\n\n# List of used user modules\n" . "usermodules: " . $this->usermodules . "\n");
|
|
if (!in_array("groupmodules", $saved)) array_push($file_array, "\n\n# List of used group modules\n" . "groupmodules: " . $this->groupmodules . "\n");
|
|
if (!in_array("hostmodules", $saved)) array_push($file_array, "\n\n# List of used host modules\n" . "hostmodules: " . $this->hostmodules . "\n");
|
|
// check if all module settings were added
|
|
$m_settings = array_keys($this->moduleSettings);
|
|
for ($i = 0; $i < sizeof($m_settings); $i++) {
|
|
if (!in_array($m_settings[$i], $mod_saved)) {
|
|
array_push($file_array, "modules: " . $m_settings[$i] . ": " . $this->moduleSettings[$m_settings[$i]] . "\n");
|
|
}
|
|
}
|
|
$file = fopen($conffile, "w");
|
|
if ($file) {
|
|
for ($i = 0; $i < sizeof($file_array); $i++) fputs($file, $file_array[$i]);
|
|
fclose($file);
|
|
@chmod ($conffile, 0600);
|
|
}
|
|
else {
|
|
StatusMessage("ERROR", "", _("Cannot open config file!") . " (" . $conffile . ")");
|
|
exit;
|
|
}
|
|
}
|
|
}
|
|
|
|
/** Prints current preferences */
|
|
function printconf() {
|
|
echo "<b>" . _("Server address") . ": </b>" . $this->ServerURL . "<br>\n";
|
|
echo "<b>" . _("Password hash type") . ": </b>" . $this->pwdhash . "<br>\n";
|
|
echo "<b>" . _("Cache timeout") . ": </b>" . $this->cachetimeout . "<br>\n";
|
|
echo "<b>" . _("UserSuffix") . ": </b>" . $this->usersuffix . "<br>\n";
|
|
echo "<b>" . _("GroupSuffix") . ": </b>" . $this->groupsuffix . "<br>\n";
|
|
echo "<b>" . _("HostSuffix") . ": </b>" . $this->hostsuffix . "<br>\n";
|
|
echo "<b>" . _("DomainSuffix") . ": </b>" . $this->domainsuffix . "<br>\n";
|
|
echo "<b>" . _("Minimum UID number") . ": </b>" . $this->MinUID . "<br>\n";
|
|
echo "<b>" . _("Maximum UID number") . ": </b>" . $this->MaxUID . "<br>\n";
|
|
echo "<b>" . _("Minimum GID number") . ": </b>" . $this->MinGID . "<br>\n";
|
|
echo "<b>" . _("Maximum GID number") . ": </b>" . $this->MaxGID . "<br>\n";
|
|
echo "<b>" . _("Minimum Machine number") . ": </b>" . $this->MinMachine . "<br>\n";
|
|
echo "<b>" . _("Maximum Machine number") . ": </b>" . $this->MaxMachine . "<br>\n";
|
|
echo "<b>" . _("Attributes in User List") . ": </b>" . $this->userlistAttributes . "<br>\n";
|
|
echo "<b>" . _("Attributes in Group List") . ": </b>" . $this->grouplistAttributes . "<br>\n";
|
|
echo "<b>" . _("Attributes in Host List") . ": </b>" . $this->hostlistAttributes . "<br>\n";
|
|
echo "<b>" . _("Maximum list entries") . ": </b>" . $this->maxlistentries . "<br>\n";
|
|
echo "<b>" . _("Default language") . ": </b>" . $this->defaultLanguage . "<br>\n";
|
|
echo "<b>" . _("Path to external script") . ": </b>" . $this->scriptPath . "<br>\n";
|
|
echo "<b>" . _("Server of external script") . ": </b>" . $this->scriptServer . "<br>\n";
|
|
echo "<b>" . _("List of valid users") . ": </b>" . $this->Admins . "<br>\n";
|
|
echo "<b>" . _("User modules") . ": </b>" . $this->usermodules . "<br>\n";
|
|
echo "<b>" . _("Group modules") . ": </b>" . $this->groupmodules . "<br>\n";
|
|
echo "<b>" . _("Host modules") . ": </b>" . $this->hostmodules . "<br><br>\n";
|
|
echo "<b>" . _("Module settings") . ": </b><br>\n";
|
|
echo "<ul>\n";
|
|
$names = array_keys($this->moduleSettings);
|
|
for ($i = 0; $i < sizeof($names); $i++) echo "<li>" . $names[$i] . " :" . $this->moduleSettings[$names[$i]] . "</li>\n";
|
|
echo "</ul>\n";
|
|
}
|
|
|
|
// functions to read/write preferences
|
|
|
|
/**
|
|
* Returns the server address as string
|
|
*
|
|
* @return server address
|
|
*/
|
|
function get_ServerURL() {
|
|
return $this->ServerURL;
|
|
}
|
|
|
|
/**
|
|
* Sets the server address
|
|
*
|
|
* @param $value new server address
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_ServerURL($value) {
|
|
if (is_string($value)) $this->ServerURL = $value;
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns an array of string with all admin names
|
|
*
|
|
* @return the admin names
|
|
*/
|
|
function get_Admins() {
|
|
return explode(";", $this->Admins);
|
|
}
|
|
|
|
/**
|
|
* Returns all admin users seperated by semicolons
|
|
*
|
|
* @return the admin string
|
|
*/
|
|
function get_Adminstring() {
|
|
return $this->Admins;
|
|
}
|
|
|
|
/**
|
|
* Sets the admin string
|
|
*
|
|
* @param $value new admin string that contains all admin users seperated by semicolons
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_Adminstring($value) {
|
|
if (is_string($value) &&
|
|
eregi("^[a-z0-9\\-]+=[a-z0-9\\-]+(,[a-z0-9\\-]+=[a-z0-9 \\-]+)+(;[a-z0-9\\-]+=[a-z0-9\\-]+(,[a-z0-9\\-]+=[a-z0-9 \\-]+)+)*$", $value)) {
|
|
$this->Admins = $value;
|
|
}
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the password to access the preferences wizard
|
|
*
|
|
* @return the password
|
|
*/
|
|
function get_Passwd() {
|
|
return $this->Passwd;
|
|
}
|
|
|
|
/**
|
|
* Sets the preferences wizard password
|
|
*
|
|
* @param $value new password
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_Passwd($value) {
|
|
if (is_string($value)) $this->Passwd = $value;
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the LDAP suffix where users are saved
|
|
*
|
|
* @return the user suffix
|
|
*/
|
|
function get_UserSuffix() {
|
|
return $this->usersuffix;
|
|
}
|
|
|
|
/**
|
|
* Sets the LDAP suffix where users are saved
|
|
*
|
|
* @param $value new user suffix
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_UserSuffix($value) {
|
|
if (is_string($value) && (eregi("^(([a-z0-9 \\-])*=([a-z0-9 \\-])*)(,([a-z0-9 \\-])*=([a-z0-9 \\-])*)*$", $value))) {
|
|
$this->usersuffix = $value;
|
|
}
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* returns the LDAP suffix where groups are saved
|
|
*
|
|
* @return the group suffix
|
|
*/
|
|
function get_GroupSuffix() {
|
|
return $this->groupsuffix;
|
|
}
|
|
|
|
/**
|
|
* Sets the LDAP suffix where groups are saved
|
|
*
|
|
* @param $value new group suffix
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_GroupSuffix($value) {
|
|
if (is_string($value) && (eregi("^(([a-z0-9 \\-])*=([a-z0-9 \\-])*)(,([a-z0-9 \\-])*=([a-z0-9 \\-])*)*$", $value))) {
|
|
$this->groupsuffix = $value;
|
|
}
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* returns the LDAP suffix where hosts are saved
|
|
*
|
|
* @return the host suffix
|
|
*/
|
|
function get_HostSuffix() {
|
|
return $this->hostsuffix;
|
|
}
|
|
|
|
/**
|
|
* Sets the LDAP suffix where hosts are saved
|
|
*
|
|
* @param $value new host suffix
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_HostSuffix($value) {
|
|
if (! $value) $this->hostsuffix = "";
|
|
elseif (is_string($value) && (eregi("^(([a-z0-9 \\-])*=([a-z0-9 \\-])*)(,([a-z0-9 \\-])*=([a-z0-9 \\-])*)*$", $value))) {
|
|
$this->hostsuffix = $value;
|
|
}
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the LDAP suffix where domains are saved
|
|
*
|
|
* @return the domain suffix
|
|
*/
|
|
function get_DomainSuffix() {
|
|
return $this->domainsuffix;
|
|
}
|
|
|
|
/**
|
|
* Sets the LDAP suffix where domains are saved
|
|
*
|
|
* @param $value new domain suffix
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_DomainSuffix($value) {
|
|
if (!$value) $this->domainsuffix = "";
|
|
elseif (is_string($value) && (eregi("^(([a-z0-9 \\-])*=([a-z0-9 \\-])*)(,([a-z0-9 \\-])*=([a-z0-9 \\-])*)*$", $value))) {
|
|
$this->domainsuffix = $value;
|
|
}
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the minimum UID to use when creating new users
|
|
*
|
|
* @return the minimum UID number
|
|
*/
|
|
function get_minUID() {
|
|
return $this->MinUID;
|
|
}
|
|
|
|
/**
|
|
* Sets the minimum UID to use when creating new users
|
|
*
|
|
* @param $value new minimum UID number
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_minUID($value) {
|
|
if (is_numeric($value)) $this->MinUID = $value;
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the maximum UID to use when creating new users
|
|
*
|
|
* @return the maximum UID number
|
|
*/
|
|
function get_maxUID() {
|
|
return $this->MaxUID;
|
|
}
|
|
|
|
/**
|
|
* Sets the maximum UID to use when creating new users
|
|
*
|
|
* @param $value new maximum UID number
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_maxUID($value) {
|
|
if (is_numeric($value)) $this->MaxUID = $value;
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the minimum GID to use when creating new groups
|
|
*
|
|
* @return the minimum GID number
|
|
*/
|
|
function get_minGID() {
|
|
return $this->MinGID;
|
|
}
|
|
|
|
/**
|
|
* Sets the minimum GID to use when creating new groups
|
|
*
|
|
* @param $value new minimum GID number
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_minGID($value) {
|
|
if (is_numeric($value)) $this->MinGID = $value;
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the maximum GID to use when creating new groups
|
|
*
|
|
* @return the maximum GID number
|
|
*/
|
|
function get_maxGID() {
|
|
return $this->MaxGID;
|
|
}
|
|
|
|
/**
|
|
* Sets the maximum GID to use when creating new groups
|
|
*
|
|
* @param $value new maximum GID number
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_maxGID($value) {
|
|
if (is_numeric($value)) $this->MaxGID = $value;
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the minimum UID to use when creating new Samba hosts
|
|
*
|
|
* @return the minimum UID number
|
|
*/
|
|
function get_minMachine() {
|
|
return $this->MinMachine;
|
|
}
|
|
|
|
/**
|
|
* Sets the minimum UID to use when creating new Samba hosts
|
|
*
|
|
* @param $value new minimum UID number
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_minMachine($value) {
|
|
if (! $value && ($this->hostsuffix == "")) $this->MinMachine = "";
|
|
elseif (is_numeric($value)) $this->MinMachine = $value;
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the maximum UID to use when creating new Samba hosts
|
|
*
|
|
* @return the maximum UID number
|
|
*/
|
|
function get_maxMachine() {
|
|
return $this->MaxMachine;
|
|
}
|
|
|
|
/**
|
|
* Sets the maximum UID to use when creating new Samba hosts
|
|
*
|
|
* @param $value new maximum UID number
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_maxMachine($value) {
|
|
if (! $value && ($this->hostsuffix == "")) $this->MaxMachine = "";
|
|
elseif (is_numeric($value)) $this->MaxMachine = $value;
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the list of attributes to show in user list
|
|
*
|
|
* @return the attribute list
|
|
*/
|
|
function get_userlistAttributes() {
|
|
return $this->userlistAttributes;
|
|
}
|
|
|
|
/**
|
|
* Sets the list of attributes to show in user list
|
|
*
|
|
* @param $value new attribute string
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_userlistAttributes($value) {
|
|
if (is_string($value) && eregi("^((#[^:;]+)|([^:;]*:[^:;]+))(;((#[^:;]+)|([^:;]*:[^:;]+)))*$", $value)) {
|
|
$this->userlistAttributes = $value;
|
|
}
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the list of attributes to show in group list
|
|
*
|
|
* @return the attribute list
|
|
*/
|
|
function get_grouplistAttributes() {
|
|
return $this->grouplistAttributes;
|
|
}
|
|
|
|
/**
|
|
* Sets the list of attributes to show in group list
|
|
*
|
|
* @param $value new attribute string
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_grouplistAttributes($value) {
|
|
if (is_string($value) && eregi("^((#[^:;]+)|([^:;]*:[^:;]+))(;((#[^:;]+)|([^:;]*:[^:;]+)))*$", $value)) {
|
|
$this->grouplistAttributes = $value;
|
|
}
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the list of attributes to show in host list
|
|
*
|
|
* @return the attribute list
|
|
*/
|
|
function get_hostlistAttributes() {
|
|
return $this->hostlistAttributes;
|
|
}
|
|
|
|
/**
|
|
* Sets the list of attributes to show in host list
|
|
*
|
|
* @param $value new attribute string
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_hostlistAttributes($value) {
|
|
if (! $value && ($this->hostsuffix == "")) $this->hostlistAttributes = "";
|
|
elseif (is_string($value) && eregi("^((#[^:;]+)|([^:;]*:[^:;]+))(;((#[^:;]+)|([^:;]*:[^:;]+)))*$", $value)) {
|
|
$this->hostlistAttributes = $value;
|
|
}
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the maximum number of rows in user/group/host lists
|
|
*
|
|
* @return maximum number
|
|
*/
|
|
function get_MaxListEntries() {
|
|
return $this->maxlistentries;
|
|
}
|
|
|
|
/**
|
|
* Sets the maximum number of rows in user/group/host lists
|
|
*
|
|
* @param $value new attribute string
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_MaxListEntries ($value) {
|
|
if (is_numeric($value)) $this->maxlistentries = $value;
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the default language string
|
|
*
|
|
* @return default language
|
|
*/
|
|
function get_defaultLanguage() {
|
|
return $this->defaultLanguage;
|
|
}
|
|
|
|
/**
|
|
* Sets the default language string
|
|
*
|
|
* @param $value new default language
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_defaultLanguage($value) {
|
|
if (is_string($value)) $this->defaultLanguage = $value;
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the path to the external script
|
|
*
|
|
* @return script path
|
|
*/
|
|
function get_scriptPath() {
|
|
return $this->scriptPath;
|
|
}
|
|
|
|
/**
|
|
* Sets the path to the external script
|
|
*
|
|
* @param $value new script path
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_scriptPath($value) {
|
|
if (!$value) $this->scriptPath = ""; // optional parameter
|
|
elseif (is_string($value) && eregi("^/([a-z0-9_\\-])+(/([a-z0-9_\\.\\-])+)+$", $value)) $this->scriptPath = $value;
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the server of the external script
|
|
*
|
|
* @return script server
|
|
*/
|
|
function get_scriptServer() {
|
|
return $this->scriptServer;
|
|
}
|
|
|
|
/**
|
|
* Sets the server of the external script
|
|
*
|
|
* @param $value new script server
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_scriptServer($value) {
|
|
if (!$value) $this->scriptServer = ""; // optional parameter
|
|
elseif (is_string($value) && eregi("^[a-z0-9\\-]+(\\.[a-z0-9\\-]+)*$", $value)) {
|
|
$this->scriptServer = $value;
|
|
}
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the LDAP cache timeout in minutes
|
|
*
|
|
* @return cache time
|
|
*/
|
|
function get_cacheTimeout() {
|
|
if (isset($this->cachetimeout)) return $this->cachetimeout;
|
|
else return 5;
|
|
}
|
|
|
|
/**
|
|
* Returns the LDAP cache timeout in seconds
|
|
*
|
|
* @return cache time
|
|
*/
|
|
function get_cacheTimeoutSec() {
|
|
return $this->cachetimeout * 60;
|
|
}
|
|
|
|
/**
|
|
* Sets the LDAP cache timeout in minutes (0,1,2,5,10,15)
|
|
*
|
|
* @param $value new cache timeout
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_cacheTimeout($value) {
|
|
if (is_numeric($value) && ($value > -1)) {
|
|
$this->cachetimeout = $value;
|
|
}
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns the password hash type
|
|
*
|
|
* @return password hash
|
|
*/
|
|
function get_pwdhash() {
|
|
if ($this->pwdhash) return strtoupper($this->pwdhash);
|
|
else return "SSHA";
|
|
}
|
|
|
|
/**
|
|
* Sets the password hash type (CRYPT/SHA/SSHA/MD5/SMD5)
|
|
*
|
|
* @param $value new password hash algorithm
|
|
* @return true if $value has correct format
|
|
*/
|
|
function set_pwdhash($value) {
|
|
if (is_string($value) && eregi("^(crypt|sha|ssha|md5|smd5|plain)$", $value)) {
|
|
$this->pwdhash = $value;
|
|
}
|
|
else return false;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns an array of all selected user modules
|
|
*
|
|
* @return user modules
|
|
*/
|
|
function get_UserModules() {
|
|
$modules = explode(",", $this->usermodules);
|
|
$available = getAvailableModules('user');
|
|
// only return available modules
|
|
$ret = array();
|
|
for ($i = 0; $i < sizeof($modules); $i++) {
|
|
if (in_array($modules[$i], $available)) $ret[] = $modules[$i];
|
|
}
|
|
return $ret;
|
|
}
|
|
|
|
/**
|
|
* Sets the selected user modules
|
|
*
|
|
* @param $modules array with module names (not aliases!)
|
|
* @return true if $modules has correct format
|
|
*/
|
|
function set_UserModules($modules) {
|
|
if (! is_array($modules)) return false;
|
|
// check module names
|
|
$available = getAvailableModules('user');
|
|
for ($i = 0; $i < sizeof($modules); $i++) {
|
|
if (! in_array($modules[$i], $available)) return false;
|
|
}
|
|
// TODO: check depends/conflicts
|
|
$this->usermodules = implode(",", $modules);
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns an array of all selected group modules
|
|
*
|
|
* @return group modules
|
|
*/
|
|
function get_GroupModules() {
|
|
$modules = explode(",", $this->groupmodules);
|
|
$available = getAvailableModules('group');
|
|
// only return available modules
|
|
$ret = array();
|
|
for ($i = 0; $i < sizeof($modules); $i++) {
|
|
if (in_array($modules[$i], $available)) $ret[] = $modules[$i];
|
|
}
|
|
return $ret;
|
|
}
|
|
|
|
/**
|
|
* Sets the selected group modules
|
|
*
|
|
* @param $modules array with module names (not aliases!)
|
|
* @return true if $modules has correct format
|
|
*/
|
|
function set_GroupModules($modules) {
|
|
if (! is_array($modules)) return false;
|
|
// check module names
|
|
$available = getAvailableModules('group');
|
|
for ($i = 0; $i < sizeof($modules); $i++) {
|
|
if (! in_array($modules[$i], $available)) return false;
|
|
}
|
|
// TODO: check depends/conflicts
|
|
$this->groupmodules = implode(",", $modules);
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns an array of all selected host modules
|
|
*
|
|
* @return host modules
|
|
*/
|
|
function get_HostModules() {
|
|
$modules = explode(",", $this->hostmodules);
|
|
$available = getAvailableModules('host');
|
|
// only return available modules
|
|
$ret = array();
|
|
for ($i = 0; $i < sizeof($modules); $i++) {
|
|
if (in_array($modules[$i], $available)) $ret[] = $modules[$i];
|
|
}
|
|
return $ret;
|
|
}
|
|
|
|
/**
|
|
* Sets the selected host modules
|
|
*
|
|
* @param $modules array with module names (not aliases!)
|
|
* @return true if $modules has correct format
|
|
*/
|
|
function set_HostModules($modules) {
|
|
if (! is_array($modules)) return false;
|
|
// check module names
|
|
$available = getAvailableModules('host');
|
|
for ($i = 0; $i < sizeof($modules); $i++) {
|
|
if (! in_array($modules[$i], $available)) return false;
|
|
}
|
|
// TODO: check depends/conflicts
|
|
$this->hostmodules = implode(",", $modules);
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Sets the settings for the account modules.
|
|
*
|
|
* @param array $settings list of module setting array(name => value)
|
|
* @return true if $settings has correct format
|
|
*/
|
|
function set_moduleSettings($settings) {
|
|
if (!is_array($settings)) return false;
|
|
$this->moduleSettings = $settings;
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Returns a list of saved module settings
|
|
*
|
|
* @return array list of settings: array(name => value)
|
|
*/
|
|
function get_moduleSettings() {
|
|
return $this->moduleSettings;
|
|
}
|
|
|
|
}
|
|
|
|
|
|
/**
|
|
* This class manages config.cfg.
|
|
*
|
|
* @package configuration
|
|
*/
|
|
class CfgMain {
|
|
|
|
/** Default profile */
|
|
var $default;
|
|
|
|
/** Password to change config.cfg */
|
|
var $password;
|
|
|
|
/**
|
|
* Loads preferences from config file
|
|
*/
|
|
function CfgMain() {
|
|
$this->reload();
|
|
}
|
|
|
|
/**
|
|
* Reloads preferences from config file config.cfg
|
|
*
|
|
* @return boolean true if file was readable
|
|
*/
|
|
function reload() {
|
|
$conffile = substr(__FILE__, 0, strlen(__FILE__) - 15) . "/config/config.cfg";
|
|
if (is_file($conffile) == True) {
|
|
$file = @fopen($conffile, "r");
|
|
if (!$file) return false; // abort if file is not readable
|
|
while (!feof($file)) {
|
|
$line = fgets($file, 1024);
|
|
$line = trim($line); // remove spaces at the beginning and end
|
|
if (($line == "")||($line[0] == "#")) continue; // ignore comments
|
|
// search keywords
|
|
if (substr($line, 0, 10) == "password: ") {
|
|
$this->password = substr($line, 10, strlen($line)-10);
|
|
continue;
|
|
}
|
|
if (substr($line, 0, 9) == "default: ") {
|
|
$this->default = substr($line, 9, strlen($line)-9);
|
|
continue;
|
|
}
|
|
}
|
|
fclose($file);
|
|
}
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Saves preferences to config file config.cfg
|
|
*/
|
|
function save() {
|
|
$conffile = substr(__FILE__, 0, strlen(__FILE__) - 15) . "/config/config.cfg";
|
|
if (is_file($conffile) == True) {
|
|
// booleans to check if value was already saved
|
|
$save_password = $save_default = False;
|
|
$file = fopen($conffile, "r");
|
|
$file_array = array();
|
|
// read config file
|
|
while (!feof($file)) {
|
|
array_push($file_array, fgets($file, 1024));
|
|
}
|
|
fclose($file);
|
|
// generate new configuration file
|
|
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, 10) == "password: ") {
|
|
$file_array[$i] = "password: " . $this->password . "\n";
|
|
$save_password = True;
|
|
continue;
|
|
}
|
|
if (substr($file_array[$i], 0, 9) == "default: ") {
|
|
$file_array[$i] = "default: " . $this->default . "\n";
|
|
$save_default = True;
|
|
continue;
|
|
}
|
|
}
|
|
}
|
|
// check if we have to add new entries (e.g. if user upgraded LAM and has an old config file)
|
|
if (!$save_password == True) array_push($file_array, "\n\n# password to add/delete/rename configuration profiles\n" . "password: " . $this->password);
|
|
if (!$save_default == True) array_push($file_array, "\n\n# default profile, without \".conf\"\n" . "default: " . $this->default);
|
|
$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;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
?>
|