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

/modules/Users/Login.php

https://github.com/jacknicole/sugarcrm_dev
PHP | 218 lines | 147 code | 23 blank | 48 comment | 35 complexity | 18a89cfecf8e050a14f2586b05081548 MD5 | raw file
  1. <?php
  2. if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
  3. /*********************************************************************************
  4. * SugarCRM Community Edition is a customer relationship management program developed by
  5. * SugarCRM, Inc. Copyright (C) 2004-2011 SugarCRM Inc.
  6. *
  7. * This program is free software; you can redistribute it and/or modify it under
  8. * the terms of the GNU Affero General Public License version 3 as published by the
  9. * Free Software Foundation with the addition of the following permission added
  10. * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
  11. * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
  12. * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
  13. *
  14. * This program is distributed in the hope that it will be useful, but WITHOUT
  15. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  16. * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
  17. * details.
  18. *
  19. * You should have received a copy of the GNU Affero General Public License along with
  20. * this program; if not, see http://www.gnu.org/licenses or write to the Free
  21. * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
  22. * 02110-1301 USA.
  23. *
  24. * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
  25. * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
  26. *
  27. * The interactive user interfaces in modified source and object code versions
  28. * of this program must display Appropriate Legal Notices, as required under
  29. * Section 5 of the GNU Affero General Public License version 3.
  30. *
  31. * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
  32. * these Appropriate Legal Notices must retain the display of the "Powered by
  33. * SugarCRM" logo. If the display of the logo is not reasonably feasible for
  34. * technical reasons, the Appropriate Legal Notices must display the words
  35. * "Powered by SugarCRM".
  36. ********************************************************************************/
  37. /*********************************************************************************
  38. * Description: TODO: To be written.
  39. * Portions created by SugarCRM are Copyright (C) SugarCRM, Inc.
  40. * All Rights Reserved.
  41. * Contributor(s): ______________________________________..
  42. ********************************************************************************/
  43. if(isset($_SESSION['authenticated_user_id'])) {
  44. ob_clean();
  45. header("Location: index.php?module=Home&action=index");
  46. sugar_cleanup(true);
  47. return;
  48. }
  49. global $current_language, $mod_strings, $app_strings;
  50. if(isset($_REQUEST['login_language'])){
  51. $lang = $_REQUEST['login_language'];
  52. $_REQUEST['ck_login_language_20'] = $lang;
  53. $current_language = $lang;
  54. $_SESSION['authenticated_user_language'] = $lang;
  55. $mod_strings = return_module_language($lang, "Users");
  56. $app_strings = return_application_language($lang);
  57. }
  58. $sugar_smarty = new Sugar_Smarty();
  59. echo '<link rel="stylesheet" type="text/css" media="all" href="'.getJSPath('modules/Users/login.css').'">';
  60. echo '<script type="text/javascript" src="'.getJSPath('modules/Users/login.js').'"></script>';
  61. global $app_language, $sugar_config;
  62. //we don't want the parent module's string file, but rather the string file specifc to this subpanel
  63. global $current_language;
  64. // Get the login page image
  65. if ( sugar_is_file('custom/include/images/sugar_md.png') ) {
  66. $login_image = '<IMG src="custom/include/images/sugar_md.png" alt="Sugar" width="340" height="25">';
  67. }
  68. else {
  69. $login_image = '<IMG src="include/images/sugar_md_open.png" alt="Sugar" width="340" height="25" style="margin: 5px 0;">';
  70. }
  71. $sugar_smarty->assign('LOGIN_IMAGE',$login_image);
  72. // See if any messages were passed along to display to the user.
  73. if(isset($_COOKIE['loginErrorMessage'])) {
  74. if ( !isset($_REQUEST['loginErrorMessage']) ) {
  75. $_REQUEST['loginErrorMessage'] = $_COOKIE['loginErrorMessage'];
  76. }
  77. SugarApplication::setCookie('loginErrorMessage', '', time()-42000, '/');
  78. }
  79. if(isset($_REQUEST['loginErrorMessage'])) {
  80. if (isset($mod_strings[$_REQUEST['loginErrorMessage']])) {
  81. echo "<p align='center' class='error' > ". $mod_strings[$_REQUEST['loginErrorMessage']]. "</p>";
  82. } else if (isset($app_strings[$_REQUEST['loginErrorMessage']])) {
  83. echo "<p align='center' class='error' > ". $app_strings[$_REQUEST['loginErrorMessage']]. "</p>";
  84. }
  85. }
  86. $query = "SELECT count(id) as total from users WHERE status='Active' AND deleted=0 AND is_group=0 AND portal_only=0";
  87. if (isset($_GET['login_module']))
  88. $sugar_smarty->assign('LOGIN_MODULE', $_GET['login_module']);
  89. if (isset($_GET['login_action']))
  90. $sugar_smarty->assign('LOGIN_ACTION', $_GET['login_action']);
  91. if (isset($_GET['login_record']))
  92. $sugar_smarty->assign('LOGIN_RECORD', $_GET['login_record']);
  93. // Retrieve username from the session if possible.
  94. if(isset($_SESSION["login_user_name"])) {
  95. if (isset($_REQUEST['default_user_name']))
  96. $login_user_name = $_REQUEST['default_user_name'];
  97. else
  98. $login_user_name = $_SESSION['login_user_name'];
  99. } else {
  100. if(isset($_REQUEST['default_user_name'])) {
  101. $login_user_name = $_REQUEST['default_user_name'];
  102. } elseif(isset($_REQUEST['ck_login_id_20'])) {
  103. $login_user_name = get_user_name($_REQUEST['ck_login_id_20']);
  104. } else {
  105. $login_user_name = $sugar_config['default_user_name'];
  106. }
  107. $_SESSION['login_user_name'] = $login_user_name;
  108. }
  109. $sugar_smarty->assign('LOGIN_USER_NAME', $login_user_name);
  110. $mod_strings['VLD_ERROR'] = $GLOBALS['app_strings']["\x4c\x4f\x47\x49\x4e\x5f\x4c\x4f\x47\x4f\x5f\x45\x52\x52\x4f\x52"];
  111. // Retrieve password from the session if possible.
  112. if(isset($_SESSION["login_password"])) {
  113. $login_password = $_SESSION['login_password'];
  114. } else {
  115. $login_password = $sugar_config['default_password'];
  116. $_SESSION['login_password'] = $login_password;
  117. }
  118. $sugar_smarty->assign('LOGIN_PASSWORD', $login_password);
  119. if(isset($_SESSION["login_error"])) {
  120. $sugar_smarty->assign('LOGIN_ERROR', $_SESSION['login_error']);
  121. }
  122. if(isset($_SESSION["waiting_error"])) {
  123. $sugar_smarty->assign('WAITING_ERROR', $_SESSION['waiting_error']);
  124. }
  125. if (isset($_REQUEST['ck_login_language_20'])) {
  126. $display_language = $_REQUEST['ck_login_language_20'];
  127. } else {
  128. $display_language = $sugar_config['default_language'];
  129. }
  130. if (empty($GLOBALS['sugar_config']['passwordsetting']['forgotpasswordON']))
  131. $sugar_smarty->assign('DISPLAY_FORGOT_PASSWORD_FEATURE','none');
  132. $the_languages = get_languages();
  133. if ( count($the_languages) > 1 )
  134. $sugar_smarty->assign('SELECT_LANGUAGE', get_select_options_with_id($the_languages, $display_language));
  135. $the_themes = SugarThemeRegistry::availableThemes();
  136. if ( !empty($logindisplay) )
  137. $sugar_smarty->assign('LOGIN_DISPLAY', $logindisplay);;
  138. // RECAPTCHA
  139. $admin = new Administration();
  140. $admin->retrieveSettings('captcha');
  141. $captcha_privatekey = "";
  142. $captcha_publickey="";
  143. $captcha_js = "";
  144. $Captcha='';
  145. // if the admin set the captcha stuff, assign javascript and div
  146. if(isset($admin->settings['captcha_on'])&& $admin->settings['captcha_on']=='1' && !empty($admin->settings['captcha_private_key']) && !empty($admin->settings['captcha_public_key'])){
  147. $captcha_privatekey = $admin->settings['captcha_private_key'];
  148. $captcha_publickey = $admin->settings['captcha_public_key'];
  149. $captcha_js .="<script type='text/javascript' src='" . getJSPath('include/javascript/sugar_grp1_yui.js') . "'></script><script type='text/javascript' src='" . getJSPath('include/javascript/sugar_grp_yui2.js') . "'></script>
  150. <script type='text/javascript' src='http://api.recaptcha.net/js/recaptcha_ajax.js'></script>
  151. <script>
  152. function initCaptcha(){
  153. Recaptcha.create('$captcha_publickey' ,'captchaImage',{theme:'custom'});
  154. }
  155. window.onload=initCaptcha;
  156. var handleFailure=handleSuccess;
  157. var handleSuccess = function(o){
  158. if(o.responseText!==undefined && o.responseText =='Success'){
  159. generatepwd();
  160. Recaptcha.reload();
  161. }
  162. else{
  163. if(o.responseText!='')
  164. document.getElementById('generate_success').innerHTML =o.responseText;
  165. Recaptcha.reload();
  166. }
  167. }
  168. var callback2 ={ success:handleSuccess, failure: handleFailure };
  169. function validateAndSubmit(){
  170. var form = document.getElementById('form');
  171. var url = '&to_pdf=1&module=Home&action=index&entryPoint=Changenewpassword&recaptcha_challenge_field='+Recaptcha.get_challenge()+'&recaptcha_response_field='+ Recaptcha.get_response();
  172. YAHOO.util.Connect.asyncRequest('POST','index.php',callback2,url);
  173. }</script>";
  174. $Captcha.="<tr>
  175. <td scope='row' width='20%'>".$mod_strings['LBL_RECAPTCHA_INSTRUCTION'].":</td>
  176. <td width='70%'><input type='text' size='26' id='recaptcha_response_field' value=''></td>
  177. </tr>
  178. <tr>
  179. <td colspan='2'><div style='margin-left:2px'class='x-sqs-list' id='recaptcha_image'></div></td>
  180. </tr>
  181. <tr>
  182. <td colspan='2' align='right'><a href='javascript:Recaptcha.reload()'>".$mod_strings['LBL_RECAPTCHA_NEW_CAPTCHA']."</a>&nbsp;&nbsp;
  183. <a class='recaptcha_only_if_image' href='javascript:Recaptcha.switch_type(\"audio\")'>".$mod_strings['LBL_RECAPTCHA_SOUND']."</a>
  184. <a class='recaptcha_only_if_audio' href='javascript:Recaptcha.switch_type(\"image\")'> ".$mod_strings['LBL_RECAPTCHA_IMAGE']."</a>
  185. </td>
  186. </tr>";
  187. $sugar_smarty->assign('CAPTCHA', $Captcha);
  188. echo $captcha_js;
  189. }else{
  190. echo "<script>
  191. function validateAndSubmit(){generatepwd();}
  192. </script>";
  193. }
  194. $sugar_smarty->display('modules/Users/login.tpl'); ?>