PageRenderTime 39ms CodeModel.GetById 14ms RepoModel.GetById 0ms app.codeStats 0ms

/tests/SugarTestUserUtilities.php

https://bitbucket.org/cviolette/sugarcrm
PHP | 96 lines | 51 code | 11 blank | 34 comment | 6 complexity | 0c869b458fc2e709c38db6c089593c3d MD5 | raw file
Possible License(s): LGPL-2.1, MPL-2.0-no-copyleft-exception, BSD-3-Clause
  1. <?php
  2. /*********************************************************************************
  3. * SugarCRM Community Edition is a customer relationship management program developed by
  4. * SugarCRM, Inc. Copyright (C) 2004-2012 SugarCRM Inc.
  5. *
  6. * This program is free software; you can redistribute it and/or modify it under
  7. * the terms of the GNU Affero General Public License version 3 as published by the
  8. * Free Software Foundation with the addition of the following permission added
  9. * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
  10. * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
  11. * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
  12. *
  13. * This program is distributed in the hope that it will be useful, but WITHOUT
  14. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  15. * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
  16. * details.
  17. *
  18. * You should have received a copy of the GNU Affero General Public License along with
  19. * this program; if not, see http://www.gnu.org/licenses or write to the Free
  20. * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
  21. * 02110-1301 USA.
  22. *
  23. * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
  24. * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
  25. *
  26. * The interactive user interfaces in modified source and object code versions
  27. * of this program must display Appropriate Legal Notices, as required under
  28. * Section 5 of the GNU Affero General Public License version 3.
  29. *
  30. * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
  31. * these Appropriate Legal Notices must retain the display of the "Powered by
  32. * SugarCRM" logo. If the display of the logo is not reasonably feasible for
  33. * technical reasons, the Appropriate Legal Notices must display the words
  34. * "Powered by SugarCRM".
  35. ********************************************************************************/
  36. require_once 'modules/Users/User.php';
  37. class SugarTestUserUtilities
  38. {
  39. private static $_createdUsers = array();
  40. private function __construct() {}
  41. public function __destruct()
  42. {
  43. self::removeAllCreatedAnonymousUsers();
  44. }
  45. public static function createAnonymousUser($save = true, $is_admin=0)
  46. {
  47. if (isset($_REQUEST['action'])) {
  48. unset($_REQUEST['action']);
  49. }
  50. $time = mt_rand();
  51. $userId = 'SugarUser';
  52. $user = new User();
  53. $user->user_name = $userId . $time;
  54. $user->user_hash = md5($userId.$time);
  55. $user->first_name = $userId;
  56. $user->last_name = $time;
  57. $user->status='Active';
  58. if ($is_admin) {
  59. $user->is_admin = 1;
  60. }
  61. if ( $save ) {
  62. $user->save();
  63. }
  64. $user->fill_in_additional_detail_fields();
  65. self::$_createdUsers[] = $user;
  66. return $user;
  67. }
  68. public static function removeAllCreatedAnonymousUsers()
  69. {
  70. $user_ids = self::getCreatedUserIds();
  71. if ( count($user_ids) > 0 ) {
  72. $GLOBALS['db']->query('DELETE FROM users WHERE id IN (\'' . implode("', '", $user_ids) . '\')');
  73. $GLOBALS['db']->query('DELETE FROM user_preferences WHERE assigned_user_id IN (\'' . implode("', '", $user_ids) . '\')');
  74. }
  75. self::$_createdUsers = array();
  76. }
  77. public static function getCreatedUserIds()
  78. {
  79. $user_ids = array();
  80. foreach (self::$_createdUsers as $user)
  81. if ( is_object($user) && $user instanceOf User )
  82. $user_ids[] = $user->id;
  83. return $user_ids;
  84. }
  85. }