- base
- .makeApiCall(parameters, [callback])
- .getUser(parameters, [callback])
- .setTraceFunc(traceFunc)
- .setFiddlerEnabled(enabled)
- .apiEndpoint() ⇒
string
- .setApiEndpoint(newEndPoint)
- .anchorMailbox() ⇒
string
- .setAnchorMailbox(newAnchor)
- .preferredTimeZone() ⇒
string
- .setPreferredTimeZone(preferredTimeZone)
Used to do the actual send of a REST request to the REST endpoint.
Kind: static method of base
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.url | string |
The full URL of the API endpoint |
parameters.token | string |
The access token for authentication |
[parameters.user.email] | string |
The user's SMTP email address, used to set the X-AnchorMailbox header. |
[parameters.user.timezone] | string |
The user's time zone, used to set the outlook.timezone Prefer header. |
[parameters.method] | string |
Used to specify the HTTP method. Default is 'GET'. |
[parameters.query] | object |
An object containing key/value pairs. The pairs will be serialized into a query string. |
[parameters.payload] | object |
A JSON-serializable object representing the request body. |
[parameters.headers] | object |
A JSON-serializable object representing custom headers to send with the request. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Used to get information about a user.
Kind: static method of base
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.odataParams] | object |
An object containing key/value pairs representing OData query parameters. See Use OData query parameters for details. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// Set up oData parameters
var queryParams = {
'$select': 'DisplayName, EmailAddress',
};
outlook.base.getUser({token: token, odataParams: queryParams},
function(error, result) {
if (error) {
console.log('getUser returned an error: ' + error);
}
else if (result) {
console.log('User name:', result.DisplayName);
console.log('User email:', result.EmailAddress);
}
});
Used to provide a tracing function.
Kind: static method of base
Param | Type | Description |
---|---|---|
traceFunc | function |
A function that takes a string parameter. The string parameter contains the text to add to the trace. |
Used to enable network sniffing with Fiddler.
Kind: static method of base
Param | Type | Description |
---|---|---|
enabled | boolean |
true to enable default Fiddler proxy and disable SSL verification. false to disable proxy and enable SSL verification. |
Gets the API endpoint URL.
Kind: static method of base
Sets the API endpoint URL. If not called, the default of https://outlook.office.com/api/v1.0
is used.
Kind: static method of base
Param | Type | Description |
---|---|---|
newEndPoint | string |
The API endpoint URL to use. |
Gets the default anchor mailbox address.
Kind: static method of base
Sets the default anchor mailbox address.
Kind: static method of base
Param | Type | Description |
---|---|---|
newAnchor | string |
The SMTP address to send in the X-Anchor-Mailbox header. |
Gets the default preferred time zone.
Kind: static method of base
Sets the default preferred time zone.
Kind: static method of base
Param | Type | Description |
---|---|---|
preferredTimeZone | string |
The time zone in which the server should return date time values. |
- mail
- .getMessages(parameters, [callback])
- .getMessage(parameters, [callback])
- .getMessageAttachments(parameters, [callback])
- .createMessage(parameters, [callback])
- .updateMessage(parameters, [callback])
- .deleteMessage(parameters, [callback])
- .sendNewMessage(parameters, [callback])
- .sendDraftMessage(parameters, [callback])
- .syncMessages(parameters, [callback])
- .replyToMessage(parameters, [callback])
- .replyToAllMessage(parameters, [callback])
Used to get messages from a folder.
Kind: static method of mail
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.folderId] | string |
The folder id. If absent, the API calls the /User/Messages endpoint. Valid values of this parameter are: - The Id property of a MailFolder entity - Inbox - Drafts - SentItems - DeletedItems |
[parameters.odataParams] | object |
An object containing key/value pairs representing OData query parameters. See Use OData query parameters for details. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// Set up oData parameters
var queryParams = {
'$select': 'Subject,ReceivedDateTime,From',
'$orderby': 'ReceivedDateTime desc',
'$top': 20
};
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.mail.getMessages({token: token, folderId: 'Inbox', odataParams: queryParams, user: userInfo},
function(error, result){
if (error) {
console.log('getMessages returned an error: ' + error);
}
else if (result) {
console.log('getMessages returned ' + result.value.length + ' messages.');
result.value.forEach(function(message) {
console.log(' Subject:', message.Subject);
console.log(' Received:', message.ReceivedDateTime.toString());
console.log(' From:', message.From ? message.From.EmailAddress.Name : 'EMPTY');
});
}
});
Used to get a specific message.
Kind: static method of mail
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.messageId | string |
The Id of the message. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.odataParams] | object |
An object containing key/value pairs representing OData query parameters. See Use OData query parameters for details. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// The Id property of the message to retrieve. This could be
// from a previous call to getMessages
var msgId = 'AAMkADVhYTYwNzk...';
// Set up oData parameters
var queryParams = {
'$select': 'Subject,ReceivedDateTime,From'
};
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.mail.getMessage({token: token, messageId: msgId, odataParams: queryParams, user: userInfo},
function(error, result){
if (error) {
console.log('getMessage returned an error: ' + error);
}
else if (result) {
console.log(' Subject:', result.Subject);
console.log(' Received:', result.ReceivedDateTime.toString());
console.log(' From:', result.From ? result.From.EmailAddress.Name : 'EMPTY');
}
});
Get all attachments from a message
Kind: static method of mail
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.messageId | string |
The Id of the message. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.odataParams] | object |
An object containing key/value pairs representing OData query parameters. See Use OData query parameters for details. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// The Id property of the message to retrieve. This could be
// from a previous call to getMessages
var msgId = 'AAMkADVhYTYwNzk...';
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.mail.getMessageAttachments({token: token, messageId: msgId, user: userInfo},
function(error, result){
if (error) {
console.log('getMessageAttachments returned an error: ' + error);
}
else if (result) {
console.log(JSON.stringify(result, null, 2));
}
});
Create a new message
Kind: static method of mail
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.message | object |
The JSON-serializable message |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.folderId] | string |
The folder id. If absent, the API calls the /User/Messages endpoint. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
var newMsg = {
Subject: 'Did you see last night\'s game?',
Importance: 'Low',
Body: {
ContentType: 'HTML',
Content: 'They were <b>awesome</b>!'
},
ToRecipients: [
{
EmailAddress: {
Address: '[email protected]'
}
}
]
};
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.mail.createMessage({token: token, message: newMsg, user: userInfo},
function(error, result){
if (error) {
console.log('createMessage returned an error: ' + error);
}
else if (result) {
console.log(JSON.stringify(result, null, 2));
}
});
Update a specific message.
Kind: static method of mail
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.messageId | string |
The Id of the message. |
parameters.update | object |
The JSON-serializable update payload |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.odataParams] | object |
An object containing key/value pairs representing OData query parameters. See Use OData query parameters for details. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// The Id property of the message to update. This could be
// from a previous call to getMessages
var msgId = 'AAMkADVhYTYwNzk...';
// Mark the message unread
var update = {
IsRead: false,
};
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.mail.updateMessage({token: token, messageId: msgId, update: update, user: userInfo},
function(error, result){
if (error) {
console.log('updateMessage returned an error: ' + error);
}
else if (result) {
console.log(JSON.stringify(result, null, 2));
}
});
Delete a specific message.
Kind: static method of mail
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.messageId | string |
The Id of the message. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// The Id property of the message to delete. This could be
// from a previous call to getMessages
var msgId = 'AAMkADVhYTYwNzk...';
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.mail.deleteMessage({token: token, messageId: msgId, user: userInfo},
function(error, result){
if (error) {
console.log('deleteMessage returned an error: ' + error);
}
else if (result) {
console.log('SUCCESS');
}
});
Sends a new message
Kind: static method of mail
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.message | object |
The JSON-serializable message |
[parameters.saveToSentItems] | boolean |
Set to false to bypass saving a copy to the Sent Items folder. Default is true. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
var newMsg = {
Subject: 'Did you see last night\'s game?',
Importance: 'Low',
Body: {
ContentType: 'HTML',
Content: 'They were <b>awesome</b>!'
},
ToRecipients: [
{
EmailAddress: {
Address: '[email protected]'
}
}
]
};
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.mail.sendNewMessage({token: token, message: newMsg, user: userInfo},
function(error, result){
if (error) {
console.log('sendNewMessage returned an error: ' + error);
}
else if (result) {
console.log(JSON.stringify(result, null, 2));
}
});
Sends a draft message.
Kind: static method of mail
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.messageId | string |
The Id of the message. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// The Id property of the message to send. This could be
// from a previous call to getMessages
var msgId = 'AAMkADVhYTYwNzk...';
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.mail.sendDraftMessage({token: token, messageId: msgId, user: userInfo},
function(error, result){
if (error) {
console.log('sendDraftMessage returned an error: ' + error);
}
else if (result) {
console.log('SUCCESS');
}
});
Syncs messages in a folder.
Kind: static method of mail
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
[parameters.pageSize] | Number |
The maximum number of results to return in each call. Defaults to 50. |
[parameters.skipToken] | string |
The value to pass in the skipToken query parameter in the API call. |
[parameters.deltaToken] | string |
The value to pass in the deltaToken query parameter in the API call. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.folderId] | string |
The folder id. If absent, the API calls the /User/Messages endpoint. Valid values of this parameter are: - The Id property of a MailFolder entity - Inbox - Drafts - SentItems - DeletedItems |
[parameters.odataParams] | object |
An object containing key/value pairs representing OData query parameters. See Use OData query parameters for details. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the beta endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/beta');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
var syncMsgParams = {
'$select': 'Subject,ReceivedDateTime,From,BodyPreview,IsRead',
'$orderby': 'ReceivedDateTime desc'
};
var apiOptions = {
token: token,
folderId: 'Inbox',
odataParams: syncMsgParams,
user: userinfo,
pageSize: 20
};
outlook.mail.syncMessages(apiOptions, function(error, messages) {
if (error) {
console.log('syncMessages returned an error:', error);
} else {
// Do something with the messages.value array
// Then get the @odata.deltaLink
var delta = messages['@odata.deltaLink'];
// Handle deltaLink value appropriately:
// In general, if the deltaLink has a $skiptoken, that means there are more
// "pages" in the sync results, you should call syncMessages again, passing
// the $skiptoken value in the apiOptions.skipToken. If on the other hand,
// the deltaLink has a $deltatoken, that means the sync is complete, and you should
// store the $deltatoken value for future syncs.
//
// The one exception to this rule is on the initial sync (when you call with no skip or delta tokens).
// In this case you always get a $deltatoken back, even if there are more results. In this case, you should
// immediately call syncMessages again, passing the $deltatoken value in apiOptions.deltaToken.
}
}
Reply to sender
Kind: static method of mail
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.messageId | string |
The ID of the message to reply to. |
parameters.comment | string |
The comment to include. Can be an empty string. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
var comment = "Sounds great! See you tomorrow.";
var messageId = "AAMkAGE0Mz8DmAAA=";
outlook.mail.replyToMessage({token: token, comment: comment, messageId: messageId},
function(error, result){
if (error) {
console.log('replyToMessage returned an error: ' + error);
}
else if (result) {
console.log(JSON.stringify(result, null, 2));
}
});
Reply to all
Kind: static method of mail
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.messageId | string |
The ID of the message to reply to. |
parameters.comment | string |
The comment to include. Can be an empty string. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
var comment = "Sounds great! See you tomorrow.";
var messageId = "AAMkAGE0Mz8DmAAA=";
outlook.mail.replyToAllMessage({token: token, comment: comment, messageId: messageId},
function(error, result){
if (error) {
console.log('replyToMessage returned an error: ' + error);
}
else if (result) {
console.log(JSON.stringify(result, null, 2));
}
});
Used to get events from a calendar.
Kind: static method of calendar
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.calendarId] | string |
The calendar id. If absent, the API calls the /User/Events endpoint. |
[parameters.odataParams] | object |
An object containing key/value pairs representing OData query parameters. See Use OData query parameters for details. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// Set up oData parameters
var queryParams = {
'$select': 'Subject,Start,End',
'$orderby': 'Start/DateTime desc',
'$top': 20
};
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.calendar.getEvents({token: token, folderId: 'Inbox', odataParams: queryParams, user: userInfo},
function(error, result){
if (error) {
console.log('getEvents returned an error: ' + error);
}
else if (result) {
console.log('getEvents returned ' + result.value.length + ' events.');
result.value.forEach(function(event) {
console.log(' Subject:', event.Subject);
console.log(' Start:', event.Start.DateTime.toString());
console.log(' End:', event.End.DateTime.toString());
});
}
});
Syncs events of a calendar.
Kind: static method of calendar
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.startDateTime | string |
The start time and date for the calendar view in ISO 8601 format without a timezone designator. Time zone is assumed to be UTC unless the Prefer: outlook.timezone header is sent in the request. |
parameters.endDateTime | string |
The end time and date for the calendar view in ISO 8601 format without a timezone designator. Time zone is assumed to be UTC unless the Prefer: outlook.timezone header is sent in the request. |
[parameters.skipToken] | string |
The value to pass in the skipToken query parameter in the API call. |
[parameters.deltaToken] | string |
The value to pass in the deltaToken query parameter in the API call. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.calendarId] | string |
The calendar id. If absent, the API calls the /User/calendarview endpoint. Valid values of this parameter are: - The Id property of a Calendar entity - Primary , the primary calendar is used. It is used by default if no Id is specified |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the 2.0 version of the api
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
// You have to specify a time window
var startDateTime = "2017-01-01";
var endDateTime = "2017-12-31";
var apiOptions = {
token: token,
calendarId: 'calendar_id', // If none specified, the Primary calendar will be used
user: userinfo,
startDateTime: startDateTime,
endDateTime: endDateTime
};
outlook.calendar.syncEvents(apiOptions, function(error, events) {
if (error) {
console.log('syncEvents returned an error:', error);
} else {
// Do something with the events.value array
// Then get the @odata.deltaLink
var delta = messages['@odata.deltaLink'];
// Handle deltaLink value appropriately:
// In general, if the deltaLink has a $skiptoken, that means there are more
// "pages" in the sync results, you should call syncEvents again, passing
// the $skiptoken value in the apiOptions.skipToken. If on the other hand,
// the deltaLink has a $deltatoken, that means the sync is complete, and you should
// store the $deltatoken value for future syncs.
//
// The one exception to this rule is on the initial sync (when you call with no skip or delta tokens).
// In this case you always get a $deltatoken back, even if there are more results. In this case, you should
// immediately call syncMessages again, passing the $deltatoken value in apiOptions.deltaToken.
}
}
Used to get a specific event.
Kind: static method of calendar
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.eventId | string |
The Id of the event. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.odataParams] | object |
An object containing key/value pairs representing OData query parameters. See Use OData query parameters for details. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// The Id property of the event to retrieve. This could be
// from a previous call to getEvents
var eventId = 'AAMkADVhYTYwNzk...';
// Set up oData parameters
var queryParams = {
'$select': 'Subject,Start,End'
};
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.calendar.getEvent({token: token, eventId: eventId, odataParams: queryParams, user: userInfo},
function(error, result){
if (error) {
console.log('getEvent returned an error: ' + error);
}
else if (result) {
console.log(' Subject:', result.Subject);
console.log(' Start:', result.Start.DateTime.toString());
console.log(' End:', result.End.DateTime.toString());
}
});
Create a new event
Kind: static method of calendar
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.event | object |
The JSON-serializable event |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.calendarId] | string |
The calendar id. If absent, the API calls the /User/Events endpoint. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
var newEvent = {
"Subject": "Discuss the Calendar REST API",
"Body": {
"ContentType": "HTML",
"Content": "I think it will meet our requirements!"
},
"Start": {
"DateTime": "2016-02-03T18:00:00",
"TimeZone": "Eastern Standard Time"
},
"End": {
"DateTime": "2016-02-03T19:00:00",
"TimeZone": "Eastern Standard Time"
},
"Attendees": [
{
"EmailAddress": {
"Address": "[email protected]",
"Name": "Allie Bellew"
},
"Type": "Required"
}
]
};
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.calendar.createEvent({token: token, event: newEvent, user: userInfo},
function(error, result){
if (error) {
console.log('createEvent returned an error: ' + error);
}
else if (result) {
console.log(JSON.stringify(result, null, 2));
}
});
Update a specific event.
Kind: static method of calendar
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.eventId | string |
The Id of the event. |
parameters.update | object |
The JSON-serializable update payload |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.odataParams] | object |
An object containing key/value pairs representing OData query parameters. See Use OData query parameters for details. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// The Id property of the event to update. This could be
// from a previous call to getEvents
var eventId = 'AAMkADVhYTYwNzk...';
// Update the location
var update = {
Location: {
DisplayName: 'Conference Room 2'
}
};
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.calendar.updateEvent({token: token, eventId: eventId, update: update, user: userInfo},
function(error, result){
if (error) {
console.log('updateEvent returned an error: ' + error);
}
else if (result) {
console.log(JSON.stringify(result, null, 2));
}
});
Delete a specific event.
Kind: static method of calendar
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.eventId | string |
The Id of the event. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// The Id property of the event to delete. This could be
// from a previous call to getEvents
var eventId = 'AAMkADVhYTYwNzk...';
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.calendar.deleteEvent({token: token, eventId: eventId, user: userInfo},
function(error, result){
if (error) {
console.log('deleteEvent returned an error: ' + error);
}
else if (result) {
console.log('SUCCESS');
}
});
Used to get contacts from a contact folder.
Kind: static method of contacts
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.contactFolderId] | string |
The contact folder id. If absent, the API calls the /User/Contacts endpoint. |
[parameters.odataParams] | object |
An object containing key/value pairs representing OData query parameters. See Use OData query parameters for details. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// Set up oData parameters
var queryParams = {
'$select': 'GivenName,Surname,EmailAddresses',
'$orderby': 'CreatedDateTime desc',
'$top': 20
};
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.contacts.getContacts({token: token, odataParams: queryParams, user: userInfo},
function(error, result){
if (error) {
console.log('getContacts returned an error: ' + error);
}
else if (result) {
console.log('getContacts returned ' + result.value.length + ' contacts.');
result.value.forEach(function(contact) {
console.log(' GivenName:', contact.GivenName);
console.log(' Surname:', contact.Surname);
console.log(' Email Address:', contact.EmailAddresses[0] ? contact.EmailAddresses[0].Address : "NONE");
});
}
});
Used to get a specific contact.
Kind: static method of contacts
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.contactId | string |
The Id of the contact. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.odataParams] | object |
An object containing key/value pairs representing OData query parameters. See Use OData query parameters for details. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// The Id property of the contact to retrieve. This could be
// from a previous call to getContacts
var contactId = 'AAMkADVhYTYwNzk...';
// Set up oData parameters
var queryParams = {
'$select': 'GivenName,Surname,EmailAddresses'
};
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.contacts.getContact({token: token, contactId: contactId, odataParams: queryParams, user: userInfo},
function(error, result){
if (error) {
console.log('getContact returned an error: ' + error);
}
else if (result) {
console.log(' GivenName:', result.GivenName);
console.log(' Surname:', result.Surname);
console.log(' Email Address:', result.EmailAddresses[0] ? result.EmailAddresses[0].Address : "NONE");
}
});
Create a new contact
Kind: static method of contacts
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.contact | object |
The JSON-serializable contact |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.contactFolderId] | string |
The contact folder id. If absent, the API calls the /User/Contacts endpoint. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
var newContact = {
"GivenName": "Pavel",
"Surname": "Bansky",
"EmailAddresses": [
{
"Address": "[email protected]",
"Name": "Pavel Bansky"
}
],
"BusinessPhones": [
"+1 732 555 0102"
]
};
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.contacts.createContact({token: token, contact: newContact, user: userInfo},
function(error, result){
if (error) {
console.log('createContact returned an error: ' + error);
}
else if (result) {
console.log(JSON.stringify(result, null, 2));
}
});
Update a specific contact.
Kind: static method of contacts
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.contactId | string |
The Id of the contact. |
parameters.update | object |
The JSON-serializable update payload |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[parameters.odataParams] | object |
An object containing key/value pairs representing OData query parameters. See Use OData query parameters for details. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// The Id property of the contact to update. This could be
// from a previous call to getContacts
var contactId = 'AAMkADVhYTYwNzk...';
// Change the mobile number
var update = {
MobilePhone1: '425-555-1212',
};
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.contacts.updateContact({token: token, contactId: contactId, update: update, user: userInfo},
function(error, result){
if (error) {
console.log('updateContact returned an error: ' + error);
}
else if (result) {
console.log(JSON.stringify(result, null, 2));
}
});
Delete a specific contact.
Kind: static method of contacts
Param | Type | Description |
---|---|---|
parameters | object |
An object containing all of the relevant parameters. Possible values: |
parameters.token | string |
The access token. |
parameters.contactId | string |
The Id of the contact. |
[parameters.useMe] | boolean |
If true, use the /Me segment instead of the /Users/<email> segment. This parameter defaults to false and is ignored if the parameters.user.email parameter isn't provided (the /Me segment is always used in this case). |
[parameters.user.email] | string |
The SMTP address of the user. If absent, the /Me segment is used in the API URL. |
[parameters.user.timezone] | string |
The timezone of the user. |
[callback] | function |
A callback function that is called when the function completes. It should have the signature function (error, result) . |
Example
var outlook = require('node-outlook');
// Set the API endpoint to use the v2.0 endpoint
outlook.base.setApiEndpoint('https://outlook.office.com/api/v2.0');
// This is the oAuth token
var token = 'eyJ0eXAiOiJKV1Q...';
// The Id property of the contact to delete. This could be
// from a previous call to getContacts
var contactId = 'AAMkADVhYTYwNzk...';
// Pass the user's email address
var userInfo = {
email: '[email protected]'
};
outlook.contacts.deleteContact({token: token, contactId: contactId, user: userInfo},
function(error, result){
if (error) {
console.log('deleteContact returned an error: ' + error);
}
else if (result) {
console.log('SUCCESS');
}
});