diff --git a/civicrm/CRM/Utils/System/WordPress.php b/civicrm/CRM/Utils/System/WordPress.php index 446668e10f9b2c4e20556d5af0c75906555e7542..a20be3e8d23514d5804a30598366575786c599b2 100644 --- a/civicrm/CRM/Utils/System/WordPress.php +++ b/civicrm/CRM/Utils/System/WordPress.php @@ -326,13 +326,22 @@ class CRM_Utils_System_WordPress extends CRM_Utils_System_Base { } /** - * FIXME: Do something - * - * @param \obj $user + * @param \string $user * * @return bool */ public function loadUser($user) { + $userdata = get_user_by('login', $user); + if (!$userdata->data->ID) { + return FALSE; + } + $uid = $userdata->data->ID; + wp_set_current_user($uid); + $contactID = CRM_Core_BAO_UFMatch::getContactId($uid); + // lets store contact id and user id in session + $session = CRM_Core_Session::singleton(); + $session->set('ufID', $uid); + $session->set('userID', $contactID); return TRUE; } diff --git a/civicrm/bin/cli.class.php b/civicrm/bin/cli.class.php index a051135620f7c0e863bb042a5b174776d72ee010..dbcc5e9caf01268e28dc77b6e38b980b31863dbb 100644 --- a/civicrm/bin/cli.class.php +++ b/civicrm/bin/cli.class.php @@ -269,7 +269,7 @@ class civicrm_cli { $this->_log(ts("Failed to login as %1. Wrong username or password.", array('1' => $this->_user))); return FALSE; } - if (!$cms->loadUser($this->_user)) { + if (($this->_config->userFramework == 'Joomla' && !$cms->loadUser($this->_user, $this->_password)) || !$cms->loadUser($this->_user)) { $this->_log(ts("Failed to login as %1", array('1' => $this->_user))); return FALSE; }