#!/usr/bin/php5 -q
<?php
/***************************************************************************
- * Copyright (C) 2003-2010 Polytechnique.org *
+ * Copyright (C) 2003-2011 Polytechnique.org *
* http://opensource.polytechnique.org/ *
* *
* This program is free software; you can redistribute it and/or modify *
/* Updates the l_userid parameter for newer user accounts. */
$res = XDB::iterator(
- "SELECT g.g_account_name, a.uid
+ "SELECT g.g_account_name, s.uid
FROM gapps_accounts AS g
- LEFT JOIN aliases as a ON (a.alias = g.g_account_name AND a.type = 'a_vie')
- WHERE (g.l_userid IS NULL OR g.l_userid <= 0) AND a.uid IS NOT NULL");
+ LEFT JOIN email_source_account AS s ON (s.email = g.g_account_name AND s.type = 'forlife')
+ WHERE (g.l_userid IS NULL OR g.l_userid <= 0) AND s.uid IS NOT NULL");
while ($account = $res->next()) {
XDB::execute(
"UPDATE gapps_accounts
SET l_userid = {?}
WHERE g_account_name = {?}",
- $account['id'], $account['g_account_name']);
+ $account['uid'], $account['g_account_name']);
}
/* Emits a warning for GApps accounts without local uid. */
$res = XDB::iterator(
"SELECT g.g_account_name
FROM gapps_accounts AS g
- LEFT JOIN aliases as a ON (a.alias = g.g_account_name AND a.type = 'a_vie')
- WHERE (g.l_userid IS NULL OR g.l_userid <= 0) AND a.uid IS NULL");
+ LEFT JOIN email_source_account AS s ON (s.email = g.g_account_name AND s.type = 'forlife')
+ WHERE (g.l_userid IS NULL OR g.l_userid <= 0) AND s.uid IS NULL");
while ($account = $res->next()) {
if (!preg_match("/^admin-/", $account['g_account_name'])) {
printf("Warning: GApps account '%s' has no local uid.\n", $account['g_account_name']);
/* Updates the l_userid parameter for newer nicknames. */
$res = XDB::iterator(
- "SELECT g.g_account_name, a.uid
+ "SELECT g.g_account_name, s.uid
FROM gapps_nicknames AS g
- LEFT JOIN aliases AS a ON (a.alias = g.g_account_name AND a.type = 'a_vie')
- WHERE (g.l_userid IS NULL or g.l_userid <= 0) AND a.uid IS NOT NULL
+ LEFT JOIN email_source_account AS s ON (s.email = g.g_account_name AND s.type = 'forlife')
+ WHERE (g.l_userid IS NULL or g.l_userid <= 0) AND s.uid IS NOT NULL
GROUP BY g_account_name");
while ($nickname = $res->next()) {
XDB::execute(
"UPDATE gapps_nicknames
SET l_userid = {?}
WHERE g_account_name = {?}",
- $nickname['id'], $nickname['g_account_name']);
+ $nickname['uid'], $nickname['g_account_name']);
}
/* Emits a warning for nicknames without local uid. */
$res = XDB::iterator(
"SELECT g.g_account_name
FROM gapps_nicknames AS g
- LEFT JOIN aliases as a ON (a.alias = g.g_account_name AND a.type = 'a_vie')
- WHERE (g.l_userid IS NULL OR g.l_userid <= 0) AND a.uid IS NULL");
+ LEFT JOIN email_source_account AS s ON (s.email = g.g_account_name AND s.type = 'forlife')
+ WHERE (g.l_userid IS NULL OR g.l_userid <= 0) AND s.uid IS NULL");
while ($nickname = $res->next()) {
if (!preg_match("/^admin-/", $nickname['g_account_name'])) {
printf("Warning: Nickname '%s' has no local uid.\n", $nickname['g_account_name']);
/* Checks that all nicknames have been synchronized to GoogleApps. Creates the
missing ones. */
$res = XDB::iterator(
- "SELECT g.l_userid AS id, f.alias AS username, a.alias AS nickname
+ "SELECT g.l_userid AS id, s1.email AS username, s2.email AS nickname
FROM gapps_accounts AS g
- INNER JOIN aliases AS f ON (f.uid = g.l_userid AND f.type = 'a_vie')
- INNER JOIN aliases AS a ON (a.uid = g.l_userid AND a.type = 'alias')
- LEFT JOIN gapps_nicknames AS n ON (n.l_userid = g.l_userid AND n.g_nickname = a.alias)
+ INNER JOIN email_source_account AS s1 ON (s1.uid = g.l_userid AND s1.type = 'forlife')
+ INNER JOIN email_source_account AS s2 ON (s2.uid = g.l_userid AND s2.type = 'alias')
+ LEFT JOIN gapps_nicknames AS n ON (n.l_userid = g.l_userid AND n.g_nickname = s2.email)
WHERE g.g_status = 'active' AND n.g_nickname IS NULL AND g.l_userid IS NOT NULL");
while ($nickname = $res->next()) {
// Checks that the requested nickname doesn't look like a regular forlife;
"INSERT INTO gapps_queue
SET q_recipient_id = {?}, p_entry_date = NOW(), p_notbefore_date = NOW(),
p_priority = 'offline', j_type = 'n_create', j_parameters = {?}",
- $nickname['id'],
+ $nickname['uid'],
json_encode($nickname));
}
}
$res = XDB::iterator(
"SELECT g.l_userid AS id, g.g_nickname AS nickname
FROM gapps_nicknames AS g
- LEFT JOIN aliases AS a ON (a.uid = g.l_userid AND a.type = 'alias' AND a.alias = g.g_nickname)
- WHERE g.l_userid IS NOT NULL AND a.alias IS NULL");
+ LEFT JOIN email_source_account AS s ON (s.uid = g.l_userid AND s.type = 'alias' AND s.email = g.g_nickname)
+ WHERE g.l_userid IS NOT NULL AND s.email IS NULL");
while ($nickname = $res->next()) {
XDB::execute(
"INSERT INTO gapps_queue
SET q_recipient_id = {?}, p_entry_date = NOW(), p_notbefore_date = NOW(),
p_priority = 'offline', j_type = 'n_delete', j_parameters = {?}",
- $nickname['id'],
+ $nickname['uid'],
json_encode($nickname));
}