summaryrefslogtreecommitdiff
path: root/scripts/useremail.php
diff options
context:
space:
mode:
authorEvan Prodromou <evan@status.net>2009-12-12 16:15:47 -0500
committerEvan Prodromou <evan@status.net>2009-12-12 16:15:47 -0500
commitcc063aedccd614d6e486d88921c7752ec5750551 (patch)
tree603d7055f5b25fbff886c520ecddaee0e998ffd7 /scripts/useremail.php
parentb42b2e1d05867b2dd4cdb3e1b7e278c63001d355 (diff)
parent78a649ca0af3ffbf1fd23d5ae9e84def7befa79e (diff)
Merge branch '0.9.x' of git@gitorious.org:statusnet/mainline into 0.9.x
Diffstat (limited to 'scripts/useremail.php')
-rwxr-xr-xscripts/useremail.php77
1 files changed, 77 insertions, 0 deletions
diff --git a/scripts/useremail.php b/scripts/useremail.php
new file mode 100755
index 000000000..6676a87c8
--- /dev/null
+++ b/scripts/useremail.php
@@ -0,0 +1,77 @@
+#!/usr/bin/env php
+<?php
+/*
+ * StatusNet - a distributed open-source microblogging tool
+ * Copyright (C) 2008, 2009, StatusNet, Inc.
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation, either version 3 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 Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+define('INSTALLDIR', realpath(dirname(__FILE__) . '/..'));
+
+$shortoptions = 'i:n:e:';
+$longoptions = array('id=', 'nickname=', 'email=');
+
+$helptext = <<<END_OF_USEREMAIL_HELP
+useremail.php [options]
+Queries a user's registered email address, or queries the users with a given registered email.
+
+ -i --id id of the user to query
+ -n --nickname nickname of the user to query
+ -e --email email address to query
+
+END_OF_USEREMAIL_HELP;
+
+require_once INSTALLDIR.'/scripts/commandline.inc';
+
+if (have_option('i', 'id')) {
+ $id = get_option_value('i', 'id');
+ $user = User::staticGet('id', $id);
+ if (empty($user)) {
+ print "Can't find user with ID $id\n";
+ exit(1);
+ }
+} else if (have_option('n', 'nickname')) {
+ $nickname = get_option_value('n', 'nickname');
+ $user = User::staticGet('nickname', $nickname);
+ if (empty($user)) {
+ print "Can't find user with nickname '$nickname'\n";
+ exit(1);
+ }
+}
+
+if (!empty($user)) {
+ if (empty($user->email)) {
+ print "No email registered for user '$user->nickname'\n";
+ } else {
+ print "$user->email\n";
+ }
+ exit(0);
+}
+
+if (have_option('e', 'email')) {
+ $user = new User();
+ $user->email = get_option_value('e', 'email');
+ $user->find(false);
+ if (!$user->fetch()) {
+ print "No users with email $user->email\n";
+ exit(0);
+ }
+ do {
+ print "$user->id $user->nickname\n";
+ } while ($user->fetch());
+} else {
+ print "You must provide either an ID, email, or a nickname.\n";
+ exit(1);
+}