IF (ab.alias IS NULL, NULL, CONCAT(ab.alias, \'@' . $globals->mail->domain . '\')) AS bestalias,
IF (ab.alias IS NULL, NULL, CONCAT(ab.alias, \'@' . $globals->mail->domain2 . '\')) AS bestalias_alternate,
a.email, a.full_name, a.directory_name, a.display_name, a.sex = \'female\' AS gender,
- IF(a.state = \'active\', at.perms, \'\') AS perms,
+ IF(a.state = \'active\', CONCAT(at.perms, \',\', IF(a.user_perms IS NULL, \'\', a.user_perms)), \'\') AS perms,
a.email_format, a.is_admin, a.state, a.type, a.skin,
FIND_IN_SET(\'watch\', a.flags) AS watch, a.comment,
a.weak_password IS NOT NULL AS weak_access, g.g_account_name IS NOT NULL AS googleapps,
if ($is_admin) {
$flags->addFlag(PERMS_ADMIN);
}
+
+ // Access to private directory implies access to 'less'-private version.
+ if ($flags->hasFlag('directory_private')) {
+ $flags->addFlag('directory_ax');
+ }
return $flags;
}
protected function startSessionAs($user, $level)
{
+ // The user must have 'groups' permission to access X.net
+ if (!$user->checkPerms('groups')) {
+ return false;
+ }
if ($level == AUTH_SUID) {
S::set('auth', AUTH_MDP);
}
- $res = XDB::query("SELECT a.uid, a.hruid, a.display_name, a.full_name,
- a.sex = 'female' AS femme,
- a.email_format, a.token,
- at.perms, a.is_admin
- FROM accounts AS a
- INNER JOIN account_types AS at ON (at.type = a.type)
- WHERE a.uid = {?} AND a.state = 'active'
- LIMIT 1", $user->id());
- $sess = $res->fetchOneAssoc();
- $_SESSION = array_merge($_SESSION, $sess);
- $this->makePerms(S::s('perms'), S::user()->is_admin);
+
+ S::set('uid', $user->uid);
+ S::set('hruid', $user->hruid);
+
+ // XXX: Transition code, should not be in session anymore
+ S::set('display_name', $user->display_name);
+ S::set('full_name', $user->full_name);
+ S::set('femme', $user->isFemale());
+ S::set('email_format', $user->email_format);
+ S::set('token', $user->token);
+ S::set('perms', $user->perms);
+ S::set('is_admin', $user->is_admin);
+
+
+ $this->makePerms($user->perms, $user->is_admin);
S::kill('challenge');
S::kill('loginX');
S::kill('may_update');
if (!$this->startSUID($user)) {
return false;
}
- S::set('perms', User::makePerms('user'));
+ S::set('perms', User::makePerms(PERMS_USER));
return true;
}
-ALTER TABLE accounts ADD COLUMN directory_name VARCHAR(255) DEFAULT NULL AFTER full_name;
+ALTER TABLE accounts ADD COLUMN directory_name VARCHAR(255) DEFAULT NULL AFTER full_name,
+ ADD COLUMN user_perms SET('groups', 'mail', 'directory_ax', 'directory_private',
+ 'edit_directory', 'forums', 'lists', 'payment')
+ DEFAULT NULL
+ COMMENT "Extra permissions for the account in addition to those specified by the account type"
+ AFTER type;
UPDATE accounts AS a
SET a.directory_name = (SELECT pd.directory_name
FROM profile_display AS pd