Now using accounts and acl classes

This commit is contained in:
Miles Lott 2001-03-10 12:26:54 +00:00
parent 5e0ab90cb2
commit 11b69ed7af

View File

@ -11,8 +11,13 @@
/* $Id$ */ /* $Id$ */
$phpgw_info["flags"] = array("noheader" => True, "nonavbar" => True, $phpgw_info["flags"] = array(
"currentapp" => "home", "noapi" => True); "noheader" => True,
"nonavbar" => True,
"currentapp"=> "home",
"noapi" => True
);
include("../header.inc.php"); include("../header.inc.php");
include("./inc/functions.inc.php"); include("./inc/functions.inc.php");
@ -29,6 +34,7 @@
$phpgw_info["server"]["auth_type"] = "ldap"; $phpgw_info["server"]["auth_type"] = "ldap";
$acct = CreateObject("phpgwapi.accounts"); $acct = CreateObject("phpgwapi.accounts");
$applications = CreateObject("phpgwapi.applications");
$phpgw_setup->db->query("select config_name,config_value from phpgw_config where config_name like 'ldap%'",__LINE__,__FILE__); $phpgw_setup->db->query("select config_name,config_value from phpgw_config where config_name like 'ldap%'",__LINE__,__FILE__);
while ($phpgw_setup->db->next_record()) { while ($phpgw_setup->db->next_record()) {
@ -60,8 +66,8 @@
if (! $phpgw_info["server"]["global_denied_users"][$info[$i]["uid"][0]]) { if (! $phpgw_info["server"]["global_denied_users"][$info[$i]["uid"][0]]) {
$account_info[$i]["account_id"] = $info[$i]["uidnumber"][0]; $account_info[$i]["account_id"] = $info[$i]["uidnumber"][0];
$account_info[$i]["account_lid"] = $info[$i]["uid"][0]; $account_info[$i]["account_lid"] = $info[$i]["uid"][0];
$account_info[$i]["account_lastname"] = $info[$i]["givenname"][0]; $account_info[$i]["account_firstname"] = $info[$i]["givenname"][0];
$account_info[$i]["account_firstname"] = $info[$i]["sn"][0]; $account_info[$i]["account_lastname"] = $info[$i]["sn"][0];
} }
} }
@ -81,66 +87,57 @@
} }
if (! $error) { if (! $error) {
// This section is being modified to use the accounts and acl classes soon // Create the 'Default' group
// Create a default group
$defaultgroupid = mt_rand (100, 600000); $defaultgroupid = mt_rand (100, 600000);
$sql = "insert into phpgw_accounts";
$sql .= "(account_id, account_lid, account_type, account_pwd, account_firstname, account_lastname, account_lastpwd_change, account_status)";
$sql .= "values (".$defaultgroupid.", 'Default', 'g', '".md5($passwd)."', 'Default', 'Group', ".time().", 'A')";
$phpgw_setup->db->query($sql);
// Give the group access to apps
while ($app = each($s_apps)) {
$sql = "DELETE FROM phpgw_acl WHERE acl_appname='".$app[1]."' AND acl_location='run' AND acl_account="
. $defaultgroupid;
$phpgw_setup->db->query($sql ,__LINE__,__FILE__);
$sql = "INSERT INTO phpgw_acl (acl_appname, acl_location, acl_account, acl_rights)" $acct = CreateObject('phpgwapi.accounts',$defaultgroupid);
. " VALUES('".$app[1]."','run',".$defaultgroupid.",1)"; $acct->db = $phpgw_setup->db;
$phpgw_setup->db->query($sql ,__LINE__,__FILE__);
// Check if the group account is already there
// Since the id above is random, this will fail on a reload
$acct_exist = $acct->exists($defaultgroupid);
if(!$acct_exist && $defaultgroupid) {
$acct->create('g','Default',$passwd,'Default','Group','A',$defaultgroupid);
} }
$acl = CreateObject('phpgwapi.acl',$defaultgroupid);
$acl->db = $phpgw_setup->db;
$acl->read_repository();
while ($app = each($s_apps)) {
$acl->add($app[1],'run',1);
}
$acl->save_repository();
while ($account = each($account_info)) { while ($account = each($account_info)) {
// do some checks before we try to import the data // do some checks before we try to import the data
if (!empty($account[1]["account_id"]) && !empty($account[1]["account_lid"])) if (!empty($account[1]["account_id"]) && !empty($account[1]["account_lid"]))
/* // This is where each new user was given app rights, instead of per the group $accounts = CreateObject("phpgwapi.accounts",$account[1]["account_id"]);
@reset($s_apps); $accounts->db = $phpgw_setup->db;
while ($app = each($s_apps)) {
$sql = "DELETE FROM phpgw_acl WHERE acl_appname='".$app[1]."' AND acl_location='run' AND acl_account="
. $account[1]["account_id"];
$phpgw_setup->db->query($sql ,__LINE__,__FILE__);
$sql = "INSERT INTO phpgw_acl (acl_appname, acl_location, acl_account, acl_rights)" $acl = CreateObject("phpgwapi.acl",intval($account[1]["account_id"]));
. " VALUES('".$app[1]."','run',".$account[1]["account_id"].",1)"; $acl->db = $phpgw_setup->db;
$phpgw_setup->db->query($sql ,__LINE__,__FILE__); $acl->read_repository();
} */
// Cleanup admin permissions // Only give them admin if we asked for them to have it
$sql = "DELETE FROM phpgw_acl WHERE acl_appname='admin' AND acl_location='run' AND acl_account="
. $account[1]["account_id"];
$phpgw_setup->db->query($sql ,__LINE__,__FILE__);
// Give the user admin only if we asked for them to have it
for ($a=0;$a<count($admins);$a++) { for ($a=0;$a<count($admins);$a++) {
if ($admins[$a] == $account[1]["account_id"]) { if ($admins[$a] == $account[1]["account_id"]) {
$sql = "INSERT INTO phpgw_acl (acl_appname, acl_location, acl_account, acl_rights)" $acl->add('admin','run',1);
. " VALUES('admin','run',".$account[1]["account_id"].",1)";
$phpgw_setup->db->query($sql ,__LINE__,__FILE__);
} }
} }
// Actually create the account // Check if the account is already there
$phpgw_setup->db->query("SELECT account_id FROM phpgw_accounts WHERE account_id=" . $account[1]["account_id"] $acct_exist = $accounts->exists($account[1]["account_id"]);
. " AND account_lid='" . $account[1]["account_lid"] . "'");
if(!$phpgw_setup->db->num_rows() && $account[1]["account_lid"]) { if(!$acct_exist && $account[1]["account_id"]) {
$phpgw_setup->db->query("INSERT INTO phpgw_accounts (account_id,account_lid,account_pwd,account_type," $accounts->create('u', $account[1]["account_lid"], 'x',
. "account_status,account_lastpwd_change) VALUES (" . $account[1]["account_id"] . ",'" $account[1]["account_firstname"], $account[1]["account_lastname"],
. $account[1]["account_lid"] . "','x','u','A',".time().")",__LINE__,__FILE__); 'A',$account[1]["account_id"]
);
} }
// Now make them a member of the default group // Now make them a member of the 'Default' group
$sql = "INSERT INTO phpgw_acl (acl_appname, acl_location, acl_account, acl_rights)" $acl->add("phpgw_group",$defaultgroupid,1);
. " VALUES('phpgw_group',".$defaultgroupid.",".$account[1]["account_id"].",'1')"; $acl->save_repository();
$phpgw_setup->db->query($sql);
} }
$setup_complete = True; $setup_complete = True;
} }