}
return array(
- 'googleapps' => $this->make_hook('index', AUTH_MDP),
- 'admin/googleapps' => $this->make_hook('admin', AUTH_MDP, 'admin'),
- 'admin/googleapps/job' => $this->make_hook('admin_job', AUTH_MDP, 'admin'),
- 'admin/googleapps/user' => $this->make_hook('admin_user', AUTH_MDP, 'admin'),
+ 'googleapps' => $this->make_hook('index', AUTH_PASSWD, 'gapps'),
+ 'admin/googleapps' => $this->make_hook('admin', AUTH_PASSWD, 'admin'),
+ 'admin/googleapps/job' => $this->make_hook('admin_job', AUTH_PASSWD, 'admin'),
+ 'admin/googleapps/user' => $this->make_hook('admin_user', AUTH_PASSWD, 'admin'),
);
}
- function handler_index(&$page, $action = null)
+ function handler_index($page, $action = null)
{
- require_once("emails.inc.php");
- require_once("googleapps.inc.php");
+ require_once 'emails.inc.php';
+ require_once 'googleapps.inc.php';
$page->changeTpl('googleapps/index.tpl');
- $page->addJsLink('password.js');
$page->setTitle('Compte Google Apps');
$user = S::user();
$account = new GoogleAppsAccount($user);
// Fills up the 'is Google Apps redirection active' variable.
- $page->assign('redirect_active', false);
- $page->assign('redirect_unique', true);
+ $redirect_active = false;
+ $redirect_unique = true;
+ $gapps_email = '';
if ($account->active()) {
$redirect = new Redirect($user);
- $page->assign('redirect_unique', !$redirect->other_active('googleapps'));
-
- $storage = new EmailStorage($user, 'googleapps');
- $page->assign('redirect_active', $storage->active);
+ foreach ($redirect->emails as $email) {
+ if ($email->type == 'googleapps') {
+ $gapps_email = $email->email;
+ $redirect_active = $email->active;
+ $redirect_unique = !$redirect->other_active($email->email);
+ }
+ }
}
+ $page->assign('redirect_active', $redirect_active);
+ $page->assign('redirect_unique', $redirect_unique);
// Updates the Google Apps account as required.
if ($action) {
if ($account->pending_update_suspension) {
$page->trigWarning("Ton compte est déjà en cours de désactivation.");
} else {
- if ($redirect->modify_one_email('googleapps', false) == SUCCESS) {
+ if (!$redirect_active || $redirect->modify_one_email($gapps_email, false) == SUCCESS) {
$account->suspend();
$page->trigSuccess("Ton compte Google Apps est dorénavant désactivé.");
} else {
$page->assign('account', $account);
}
- function handler_admin(&$page, $action = null) {
- require_once("googleapps.inc.php");
+ function handler_admin($page, $action = null) {
+ require_once 'googleapps.inc.php';
$page->changeTpl('googleapps/admin.tpl');
$page->setTitle('Administration Google Apps');
$page->assign('googleapps_admin', GoogleAppsAccount::is_administrator(S::v('uid')));
// Retrieves latest pending administrative requests from the gappsd queue.
$res = XDB::iterator(
- "SELECT q_id, q_recipient_id, a.alias, j_type, j_parameters,
+ "SELECT q_id, q_recipient_id, s.email AS alias, j_type, j_parameters,
UNIX_TIMESTAMP(q.p_entry_date) AS p_entry_date
FROM gapps_queue AS q
- LEFT JOIN aliases AS a ON (a.uid = q_recipient_id AND a.type = 'a_vie')
+ LEFT JOIN email_source_account AS s ON (s.uid = q.q_recipient_id AND s.type = 'forlife')
WHERE p_status IN ('idle', 'active', 'softfail') AND
p_admin_request IS TRUE
ORDER BY p_entry_date");
// Retrieves latest failed requests from the gappsd queue.
$res = XDB::iterator(
- "SELECT q.q_id, q.q_recipient_id, a.alias, q.j_type, q.r_result,
+ "SELECT q.q_id, q.q_recipient_id, s.email AS alias, q.j_type, q.r_result,
UNIX_TIMESTAMP(q.p_entry_date) AS p_entry_date
FROM gapps_queue AS q
- LEFT JOIN aliases AS a ON (a.uid = q.q_recipient_id AND a.type = 'a_vie')
+ LEFT JOIN email_source_account AS s ON (s.uid = q.q_recipient_id AND s.type = 'forlife')
WHERE q.p_status = 'hardfail'
ORDER BY p_entry_date DESC
LIMIT 20");
$page->assign('failed_requests', $res);
}
- function handler_admin_job(&$page, $job = null) {
- require_once("googleapps.inc.php");
+ function handler_admin_job($page, $job = null) {
+ require_once 'googleapps.inc.php';
$page->changeTpl('googleapps/admin.job.tpl');
$page->setTitle('Administration Google Apps');
$page->assign('googleapps_admin', GoogleAppsAccount::is_administrator(S::v('uid')));
if ($job) {
$res = XDB::query(
- "SELECT q.*, ao.alias AS q_owner, ar.alias AS q_recipient
+ "SELECT q.*, so.email AS q_owner, sr.email AS q_recipient
FROM gapps_queue AS q
- LEFT JOIN aliases AS ao ON (ao.uid = q.q_owner_id AND ao.type = 'a_vie')
- LEFT JOIN aliases AS ar ON (ar.uid = q.q_recipient_id AND ar.type = 'a_vie')
+ LEFT JOIN email_source_account AS so ON (so.uid = q.q_owner_id AND so.type = 'forlife')
+ LEFT JOIN email_source_account AS sr ON (sr.uid = q.q_recipient_id AND sr.type = 'forlife')
WHERE q_id = {?}", $job);
$sql_job = $res->fetchOneAssoc();
$sql_job['decoded_parameters'] = var_export(json_decode($sql_job['j_parameters'], true), true);
}
}
- function handler_admin_user(&$page, $user = null) {
- require_once("emails.inc.php");
- require_once("googleapps.inc.php");
+ function handler_admin_user($page, $user = null) {
+ require_once 'emails.inc.php';
+ require_once 'googleapps.inc.php';
$page->changeTpl('googleapps/admin.user.tpl');
$page->setTitle('Administration Google Apps');
$page->assign('googleapps_admin', GoogleAppsAccount::is_administrator(S::v('uid')));
if ($user) {
$account = new GoogleAppsAccount($user);
- $storage = new EmailStorage($user, 'googleapps');
// Apply requested actions.
if (Post::has('suspend') && $account->active() && !$account->pending_update_suspension) {
// Displays basic account information.
$page->assign('account', $account);
$page->assign('admin_account', GoogleAppsAccount::is_administrator($user->id()));
- $page->assign('googleapps_storage', $storage->active);
+ $page->assign('googleapps_storage', Email::is_active_storage($user, 'googleapps'));
$page->assign('user', $user->id());
// Retrieves user's pending requests.