Есть ли способ получить полный доступ к SuiteCRM через фоновый вход через API?
Например, мы используем LDAP на отдельном сайте, и я хочу передать аутентифицированных пользователей в suitecrm в фоновом режиме, а затем предоставить SuiteCrm доступ к указанному пользователю без необходимости входа в систему во второй раз.
Мне удалось заставить API работать и «входить в систему» пользователя и возвращать session_id, однако он по-прежнему направляет меня на страницу входа. Если я попытаюсь принудительно перенаправить, я получу ошибку err_to_many_redirects.
РЕДАКТИРОВАТЬ:
Я не верю, что проблема возникает из-за сценария API, а из-за использования возвращенных данных для завершения необходимых данных сеанса, которые мне еще не удалось сгенерировать.
Код ниже получен из http://support.sugarcrm.com/Documentation/Sugar_Developer/Sugar_Developer_Guide_6.5/Application_Framework/Web_Services/Examples/REST/PHP/Logging_In/
<?php
error_reporting(E_ALL);
ini_set('display_errors',1);
require_once('./shield_secureaccess.php');
$url = "http://{site_location}/service/v4_1/rest.php";
session_start();
$username = $_SESSION['SHIELD_user'];
session_write_close();
if(isset($username)){
$password = shield_secureaccess($username);}
else{require 'shield_session.php';}
//function to make cURL request
function call($method, $parameters, $url)
{
ob_start();
$curl_request = curl_init();
curl_setopt($curl_request, CURLOPT_URL, $url);
curl_setopt($curl_request, CURLOPT_POST, 1);
curl_setopt($curl_request, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_0);
curl_setopt($curl_request, CURLOPT_HEADER, 1);
curl_setopt($curl_request, CURLOPT_SSL_VERIFYPEER, 0);
curl_setopt($curl_request, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($curl_request, CURLOPT_FOLLOWLOCATION, 0);
$jsonEncodedData = json_encode($parameters);
$post = array(
"method" => $method,
"input_type" => "JSON",
"response_type" => "JSON",
"rest_data" => $jsonEncodedData
);
curl_setopt($curl_request, CURLOPT_POSTFIELDS, $post);
$result = curl_exec($curl_request);
curl_close($curl_request);
$result = explode("\r\n\r\n", $result, 2);
$response = json_decode($result[1]);
ob_end_flush();
return $response;
}
//login ------------------------------
$login_parameters = array(
"user_auth" => array(
"user_name" => $username,
"password" => md5($password),
"version" => "1"
),
"application_name" => "RestTest",
"name_value_list" => array(),
);
$login_result = call("login", $login_parameters, $url);
echo "<pre>";
// print_r($_SESSION);
print_r($login_result);
// print_r($current_user);
print_r($_SESSION);
echo "</pre>";
//get session id
$session_id = $login_result->id;
// header("Location: http://{site_location}/index.php?module=Home&action=inde");
// header("Location: http://{site_location}/index.php?MSID=$session_id");
?>