useremail.php 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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', dirname(__DIR__));
  21. define('PUBLICDIR', INSTALLDIR . DIRECTORY_SEPARATOR . 'public');
  22. $shortoptions = 'i:n:e:';
  23. $longoptions = array('id=', 'nickname=', 'email=');
  24. $helptext = <<<END_OF_USEREMAIL_HELP
  25. useremail.php [options]
  26. Queries a user's registered email address, or queries the users with a given registered email.
  27. -i --id id of the user to query
  28. -n --nickname nickname of the user to query
  29. -e --email email address to query
  30. END_OF_USEREMAIL_HELP;
  31. require_once INSTALLDIR.'/scripts/commandline.inc';
  32. if (have_option('i', 'id')) {
  33. $id = get_option_value('i', 'id');
  34. $user = User::getKV('id', $id);
  35. if (empty($user)) {
  36. print "Can't find user with ID $id\n";
  37. exit(1);
  38. }
  39. } else if (have_option('n', 'nickname')) {
  40. $nickname = get_option_value('n', 'nickname');
  41. $user = User::getKV('nickname', $nickname);
  42. if (empty($user)) {
  43. print "Can't find user with nickname '$nickname'\n";
  44. exit(1);
  45. }
  46. }
  47. if (!empty($user)) {
  48. if (empty($user->email)) {
  49. // Check for unconfirmed emails
  50. $unconfirmed_email = new Confirm_address();
  51. $unconfirmed_email->user_id = $user->id;
  52. $unconfirmed_email->address_type = 'email';
  53. $unconfirmed_email->find(true);
  54. if (empty($unconfirmed_email->address)) {
  55. print "No email registered for user '$user->nickname'\n";
  56. } else {
  57. print "Unconfirmed Adress: $unconfirmed_email->address\n";
  58. }
  59. } else {
  60. print "$user->email\n";
  61. }
  62. exit(0);
  63. }
  64. if (have_option('e', 'email')) {
  65. $user = new User();
  66. $user->email = get_option_value('e', 'email');
  67. $user->find(false);
  68. if (!$user->fetch()) {
  69. // Check unconfirmed emails
  70. $unconfirmed_email = new Confirm_address();
  71. $unconfirmed_email->address = $user->email;
  72. $unconfirmed_email->address_type = 'email';
  73. $unconfirmed_email->find(true);
  74. if (empty($unconfirmed_email->user_id)) {
  75. print "No users with email $user->email\n";
  76. } else {
  77. $user=User::getKV('id', $unconfirmed_email->user_id);
  78. print "Unconfirmed Address: $user->id $user->nickname\n";
  79. }
  80. exit(0);
  81. }
  82. do {
  83. print "$user->id $user->nickname\n";
  84. } while ($user->fetch());
  85. } else {
  86. print "You must provide either an ID, email, or a nickname.\n";
  87. exit(1);
  88. }