Send Email from an Application using Microsoft Graph and Microsoft 365 shared mailbox without an logged in user.
Log into Exchange Admin center and create a shared mailbox.
data:image/s3,"s3://crabby-images/74c91/74c91a38255ba23ecd6c81ad08d9e549cb9e681c" alt=""
Create an Enterprise Application
data:image/s3,"s3://crabby-images/84e27/84e27d24f95c1d96e967c351c59f0bbec8c29f7b" alt=""
data:image/s3,"s3://crabby-images/1d020/1d020e7a098331e91e7bbba40dc6149c797d09eb" alt=""
data:image/s3,"s3://crabby-images/85c0b/85c0b92ba1e87aee88b0fac66f521344eb2f5cf9" alt=""
Choose Microsoft Graph
data:image/s3,"s3://crabby-images/4eaa1/4eaa133bffbcf6f21f1f4b08bb8e6358778f34dc" alt=""
Choose Application
data:image/s3,"s3://crabby-images/adfc0/adfc033873801c96770518937efab4332eae6039" alt=""
Add Mail.Send Permission
data:image/s3,"s3://crabby-images/fd58d/fd58d8a6c2bf39c00bb48f9a33f97d87877cc5bb" alt=""
Grant Admin Consent
data:image/s3,"s3://crabby-images/13f2a/13f2a290aafb59880e8daeaa535f7410e1115f29" alt=""
Grant Admin Consent Confirmation
data:image/s3,"s3://crabby-images/6d150/6d150e07353f3096417df1404c256a8bf59a9622" alt=""
Grant is successful
data:image/s3,"s3://crabby-images/b2098/b2098e49fef105ae63604af96ce1e4cf6da8237a" alt=""
Create a Secret
data:image/s3,"s3://crabby-images/dc0a0/dc0a07210f615d3f2804ece49cb4c6bff6d3dda3" alt=""
Copy the secret and keep in a notepad
data:image/s3,"s3://crabby-images/3f813/3f813f5b69c26ea70e30af48ad17c455bd1b3d81" alt=""
Collect your Client ID – Application (Client) ID
data:image/s3,"s3://crabby-images/74eba/74ebaaecdca5939afc5f5ac81250774b202acf76" alt=""
There are two steps – Take Token – then use the token to send email.
data:image/s3,"s3://crabby-images/61c13/61c1389668394dc49ef00d5f0156ec731a773e89" alt=""
Use Postman to get Token.
grant_type | client_credentials |
client_id | 538cfed0-656d-4195-ae15-700467d946dc |
client_secret | Cns8Q~M3WdNSgesDxrfb0i4_rBd0iCPrJg_kodjY |
scope | https://graph.microsoft.com/.default |
Download Postman 64 Bit and install on Windows or Mac
data:image/s3,"s3://crabby-images/a0d08/a0d08a106049830409f3e46b6c62aeca3baab0b8" alt=""
Copy the Access Token – Take it without double quotes
data:image/s3,"s3://crabby-images/76bb4/76bb4de810ab87cbd134a086e3464a2745136e8e" alt=""
Now lets POST on graph url to send some test emails. Put this as Headers
Authorization | Bearer REPLACE-WITH-TOKEN-VALUE-WITHOUT-QUOTES |
Content-Type | application/json |
data:image/s3,"s3://crabby-images/24d2c/24d2c61f82220b706372d1b613930b941311ebc6" alt=""
{ "message": { "subject": "Sending from Graph", "body": { "contentType": "Text", "content": "Sending from Graph using PostMan" }, "toRecipients": [ { "emailAddress": { "address": "sathesh@azure365prox.com" } } ], "ccRecipients": [ { "emailAddress": { "address": "info@azure365pro.com" } } ] }, "saveToSentItems": "false" }
data:image/s3,"s3://crabby-images/cb2f9/cb2f9af904d5732b26d555a67e4e9ad62639cee7" alt=""
data:image/s3,"s3://crabby-images/fb410/fb410380011c8b9b2992c96c1d97e284624ddd21" alt=""
Email is generated
data:image/s3,"s3://crabby-images/daeae/daeae48c944313969c996b9ed843527b50d763f7" alt=""
If the scope of permission is wide. In Enterprise scenario you can harden it using New-ApplicationAccessPolicy which i have explained in this article to reach attachments using Graph. Access Specific Office 365 Mailbox using Microsoft Graph – Azure365Pro.com
This still sends mail as the authenticated user or is it coming from noreply@