Visual FoxPro
Visual FoxPro
Office365 Send Email from Shared Mailbox
See more Office365 Examples
Demonstrates how to send email from a shared mailbox, from smtp.office365.com using OAuth2 authentication.Chilkat Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loJsonToken
LOCAL loMailman
LOCAL loEmail
lnSuccess = 0
* This example requires the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.
* An Office365 OAuth2 access token must first be obtained prior
* to running this code.
* Getting the OAuth2 access token for the 1st time requires the O365 account owner's
* interactive authorizaition via a web browser. Afterwards, the access token
* can be repeatedly refreshed automatically.
* See the following examples for getting and refreshing an OAuth2 access token
* Get Office365 SMTP/IMAP/POP3 OAuth2 Access Token
* Refresh Office365 SMTP/IMAP/POP3 OAuth2 Access Token
* First get our previously obtained OAuth2 access token.
loJsonToken = CreateObject('Chilkat.JsonObject')
lnSuccess = loJsonToken.LoadFile("qa_data/tokens/office365.json")
loMailman = CreateObject('Chilkat.MailMan')
loMailman.SmtpHost = "smtp.office365.com"
loMailman.SmtpPort = 587
loMailman.StartTLS = 1
* In case of shared mailbox access using OAuth, the application needs to obtain the access token on behalf of a user
* but replace the SMTP username with the email address of the shared mailbox.
* Login using the shared mailbox email address for the username, and the access token for the password.
* See Office 365 SASL XOAUTH2 format
* Use your Office365 email address for the SmtpUsername.
loMailman.SmtpUsername = "SHARED_MAILBOX_EMAIL_ADDRESS"
loMailman.OAuth2AccessToken = loJsonToken.StringOf("access_token")
* Create a new email object
loEmail = CreateObject('Chilkat.Email')
loEmail.Subject = "This is a test"
loEmail.Body = "This is a test"
loEmail.From = "MY_NAME <SHARED_MAILBOX_EMAIL_ADDRESS>"
lnSuccess = loEmail.AddTo("John Doe","somebody@example.com")
* Call SendEmail to connect to the SMTP server and send.
* The connection (i.e. session) to the SMTP server remains
* open so that subsequent SendEmail calls may use the
* same connection.
lnSuccess = loMailman.SendEmail(loEmail)
IF (lnSuccess <> 1) THEN
? loMailman.LastErrorText
RELEASE loJsonToken
RELEASE loMailman
RELEASE loEmail
CANCEL
ENDIF
lnSuccess = loMailman.CloseSmtpConnection()
IF (lnSuccess <> 1) THEN
? "Connection to SMTP server not closed cleanly."
ENDIF
? "Mail Sent!"
RELEASE loJsonToken
RELEASE loMailman
RELEASE loEmail