useremail.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. #!/usr/bin/env php
  2. <?php
  3. /*
  4. * StatusNet - a distributed open-source microblogging tool
  5. * Copyright (C) 2008, 2009, StatusNet, Inc.
  6. *
  7. * This program is free software: you can redistribute it and/or modify
  8. * it under the terms of the GNU Affero General Public License as published by
  9. * the Free Software Foundation, either version 3 of the License, or
  10. * (at your option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU Affero General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Affero General Public License
  18. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  19. */
  20. define('INSTALLDIR', realpath(dirname(__FILE__) . '/..'));
  21. $shortoptions = 'i:n:e:';
  22. $longoptions = array('id=', 'nickname=', 'email=');
  23. $helptext = <<<END_OF_USEREMAIL_HELP
  24. useremail.php [options]
  25. Queries a user's registered email address, or queries the users with a given registered email.
  26. -i --id id of the user to query
  27. -n --nickname nickname of the user to query
  28. -e --email email address to query
  29. END_OF_USEREMAIL_HELP;
  30. require_once INSTALLDIR.'/scripts/commandline.inc';
  31. if (have_option('i', 'id')) {
  32. $id = get_option_value('i', 'id');
  33. $user = User::getKV('id', $id);
  34. if (empty($user)) {
  35. print "Can't find user with ID $id\n";
  36. exit(1);
  37. }
  38. } else if (have_option('n', 'nickname')) {
  39. $nickname = get_option_value('n', 'nickname');
  40. $user = User::getKV('nickname', $nickname);
  41. if (empty($user)) {
  42. print "Can't find user with nickname '$nickname'\n";
  43. exit(1);
  44. }
  45. }
  46. if (!empty($user)) {
  47. if (empty($user->email)) {
  48. // Check for unconfirmed emails
  49. $unconfirmed_email = new Confirm_address();
  50. $unconfirmed_email->user_id = $user->id;
  51. $unconfirmed_email->address_type = 'email';
  52. $unconfirmed_email->find(true);
  53. if (empty($unconfirmed_email->address)) {
  54. print "No email registered for user '$user->nickname'\n";
  55. } else {
  56. print "Unconfirmed Adress: $unconfirmed_email->address\n";
  57. }
  58. } else {
  59. print "$user->email\n";
  60. }
  61. exit(0);
  62. }
  63. if (have_option('e', 'email')) {
  64. $user = new User();
  65. $user->email = get_option_value('e', 'email');
  66. $user->find(false);
  67. if (!$user->fetch()) {
  68. // Check unconfirmed emails
  69. $unconfirmed_email = new Confirm_address();
  70. $unconfirmed_email->address = $user->email;
  71. $unconfirmed_email->address_type = 'email';
  72. $unconfirmed_email->find(true);
  73. if (empty($unconfirmed_email->user_id)) {
  74. print "No users with email $user->email\n";
  75. } else {
  76. $user=User::getKV('id', $unconfirmed_email->user_id);
  77. print "Unconfirmed Address: $user->id $user->nickname\n";
  78. }
  79. exit(0);
  80. }
  81. do {
  82. print "$user->id $user->nickname\n";
  83. } while ($user->fetch());
  84. } else {
  85. print "You must provide either an ID, email, or a nickname.\n";
  86. exit(1);
  87. }