Outlook rest api V2.0 - PullRequest
       9

Outlook rest api V2.0

0 голосов
/ 04 октября 2018

Я создал веб-приложение, которое использует outlook rest api V2.0.Я могу аутентифицировать пользователя и получать почтовые сообщения в календаре.Проблема в том, что когда я хочу отправить письмо, я получаю http ошибку 400.

Мой файл outlook.php

<?php



 class OutlookService 
 {
    private static $outlookApiUrl = "https://outlook.office.com/api/v2.0";
    		
	public static function stuurEmail($access_token, $user_email, $data) 
			{
			
			
			$getMessagesUrl = self::$outlookApiUrl."/Me/sendmail?".http_build_query($data);

			return self::makeApiCall($access_token, $user_email, "POST", $getMessagesUrl);
			
			}	
	 
	 
	 
	 
	 public static function sendMail ($access_token,$user_email)
			{
				$sentMessagesParameters = '{"Message":{"Subject":"Meet for lunch?","Body":{"ContentType":"Text","Content":"The new cafeteria is open."},"ToRecipients":[{"EmailAddress":{"Address":"danny.herremans@rkg.vlaanderen"}}]},"SaveToSentItems":"true"}';
			
			
			

			$json=json_encode($sentMessagesParameters, true);

			 $getMessagesUrl = self::$outlookApiUrl."/me/sendmail?".http_build_query($sentMessagesParameters);


			return self::makeApiCall($access_token, $user_email, "POST",$getMessageUrl,$json);

			} 
	 
	 
	 public static function getPhoto($access_token) 
			{
			  $getUserParameters = array (
				// Only return the user's display name and email address
				"\$select" => "Photo"
			  );

			  $getUserUrl = self::$outlookApiUrl."/Me?".http_build_query($getUserParameters);

			  return self::makeApiCall($access_token, "", "GET", $getUserUrl);
		 
		 
		 
			}
	 
	 public static function getUser($access_token) 
			{
			  $getUserParameters = array 
				(
				// Only return the user's display name and email address
				"\$select" => "DisplayName,EmailAddress,Alias"
			  );

			  $getUserUrl = self::$outlookApiUrl."/Me?".http_build_query($getUserParameters);

			  return self::makeApiCall($access_token, "", "GET", $getUserUrl);
			}

    public static function getMessages($access_token, $user_email) 
			{
			  $getMessagesParameters = array (
				// Only return Subject, ReceivedDateTime, and From fields
				"\$select" => "Subject,ReceivedDateTime,From",
				// Sort by ReceivedDateTime, newest first
				"\$orderby" => "ReceivedDateTime DESC",
				// Return at most 10 results
				"\$top" => "10"
			  );

			  $getMessagesUrl = self::$outlookApiUrl."/Me/MailFolders/Inbox/Messages?".http_build_query($getMessagesParameters);

			  return self::makeApiCall($access_token, $user_email, "GET", $getMessagesUrl);
			}
    
    public static function getEvents($access_token, $user_email) 
			{
			  $getEventsParameters = array (
				// Only return Subject, Start, and End fields
				"\$select" => "Subject,Start,End",
				// Sort by Start, oldest first
				"\$orderby" => "Start/DateTime",
				// Return at most 10 results
				"\$top" => "10"
			  );

			  $getEventsUrl = self::$outlookApiUrl."/Me/Events?".http_build_query($getEventsParameters);

			  return self::makeApiCall($access_token, $user_email, "GET", $getEventsUrl);
			}
    
    public static function getContacts($access_token, $user_email) 
			{
			  $getContactsParameters = array (
				// Only return GivenName, Surname, and EmailAddresses fields
				"\$select" => "GivenName,Surname,EmailAddresses",
				// Sort by GivenName, A-Z
				"\$orderby" => "GivenName",
				// Return at most 10 results
				"\$top" => "10"
			  );

			  $getContactsUrl = self::$outlookApiUrl."/Me/Contacts?".http_build_query($getContactsParameters);

			  return self::makeApiCall($access_token, $user_email, "GET", $getContactsUrl);
			}
    
    public static function makeApiCall($access_token, $user_email, $method, $url, $payload = NULL) 
			{
			  // Generate the list of headers to always send.
			  $headers = array(
				"User-Agent: php-tutorial/1.0",         // Sending a User-Agent header is a best practice.
				"Authorization: Bearer ".$access_token, // Always need our auth token!
				"Accept: application/json",             // Always accept JSON response.
				"client-request-id: ".self::makeGuid(), // Stamp each new request with a new GUID.
				"return-client-request-id: true",       // Tell the server to include our request-id GUID in the response.
				"X-AnchorMailbox: ".$user_email         // Provider user's email to optimize routing of API call
			  );

			  $curl = curl_init($url);

			  switch(strtoupper($method)) {
				case "GET":
				  // Nothing to do, GET is the default and needs no
				  // extra headers.
				  error_log("Doing GET");
				  break;
				case "POST":
				  error_log("Doing POST");
				  // Add a Content-Type header (IMPORTANT!)
				  $headers[] = "Content-Type: application/json";
				  curl_setopt($curl, CURLOPT_POST, true);
				  curl_setopt($curl, CURLOPT_POSTFIELDS, $payload);
				  break;
				case "PATCH":
				  error_log("Doing PATCH");
				  // Add a Content-Type header (IMPORTANT!)
				  $headers[] = "Content-Type: application/json";
				  curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "PATCH");
				  curl_setopt($curl, CURLOPT_POSTFIELDS, $payload);
				  break;
				case "DELETE":
				  error_log("Doing DELETE");
				  curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "DELETE");
				  break;
				default:
				  error_log("INVALID METHOD: ".$method);
				  exit;
			  }

			  curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
			  curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
			  $response = curl_exec($curl);
			  error_log("curl_exec done.");

			  $httpCode = curl_getinfo($curl, CURLINFO_HTTP_CODE);
			  error_log("Request returned status ".$httpCode);

			  if ($httpCode >= 400) {
				return array('errorNumber' => $httpCode,
							 'error' => 'Request returned HTTP error '.$httpCode);
			  }

			  $curl_errno = curl_errno($curl);
			  $curl_err = curl_error($curl);

			  if ($curl_errno) {
				$msg = $curl_errno.": ".$curl_err;
				error_log("CURL returned an error: ".$msg);
				curl_close($curl);
				return array('errorNumber' => $curl_errno,
							 'error' => $msg);
			  }
			  else {
				error_log("Response: ".$response);
				curl_close($curl);
				return json_decode($response, true);
			  }
			}
    
    // This function generates a random GUID.
    public static function makeGuid()
			{
				if (function_exists('com_create_guid')) {
				  error_log("Using 'com_create_guid'.");
				  return strtolower(trim(com_create_guid(), '{}'));
				}
				else {
				  error_log("Using custom GUID code.");
				  $charid = strtolower(md5(uniqid(rand(), true)));
				  $hyphen = chr(45);
				  $uuid = substr($charid, 0, 8).$hyphen
						 .substr($charid, 8, 4).$hyphen
						 .substr($charid, 12, 4).$hyphen
						 .substr($charid, 16, 4).$hyphen
						 .substr($charid, 20, 12);

				  return $uuid;
				}
			}
  }
?>

Так что в моем файле home.php у меня есть следующий код для отправки почты

if(isset($_POST['mailing']))
{				
    @extract($_POST);

      $arr = '{
      "Message": {
      "Subject": "Meet for lunch?",
      "Body": {
        "ContentType": "Text",
        "Content": "The new cafeteria is open."
      },
      "ToRecipients": [
        {
        "EmailAddress": {
          "Address": "xxxxxxxxx@xxxx.xxx"
        }
        }
      ]
      },
      "SaveToSentItems": "true"
    }';
    $data=json_encode($arr, true);

    $message = OutlookService::stuurEmail(oAuthService::getAccessToken($redirectUri), $_SESSION['user_email'], $data);

    print_r($message);



    echo"
      <div class='alert alert-success'>
      <a href='#' title='Sluit deze melding'
      class='close' data-dismiss='alert' aria-label='close'>&times;
      </a>

      <br>".$_SESSION['access_token']."<br>".$_SESSION['user_email']."<br>$data<br>


      </div>

      ";

}

Когда я отправляю письмо, я получаю следующую ошибку:

Предупреждение: http_build_query (): параметр 1 должен быть массивом или объектом.Неверное значение, указанное в /var/www/vhosts/rkgvlaande05001/test/outlook.php в строке 14 Array ([errorNumber] => 400 [error] => Запрос возвращенной ошибки HTTP 400)

Любая идея, что нетпрямо в коде или у кого-нибудь есть рабочий пример для outlook rest api V2.0?

Thx

1 Ответ

0 голосов
/ 04 октября 2018

Я проверил ваш код, и содержание sentMessagesParameters верное.Однако я обнаружил, что в этом сообщении упоминается: «вам нужно разрешение« отправлять почту от имени пользователя »для O365 Exchange Online в Azure AD, если вы хотите отправить почтовое сообщение с помощью REST API».Пожалуйста, перейдите по следующей ссылке:

Outlook Rest Api отправка почты Запрос возвращен статус 400

...