Office.Mailbox interface
Предоставляет доступ к объектной модели надстройки Microsoft Outlook.
Ключевые свойства:
diagnostics
: предоставляет диагностические сведения для надстройки Outlook.item
: предоставляет методы и свойства для доступа к сообщению или встрече в надстройке Outlook.userProfile
: предоставляет сведения о пользователе в надстройке Outlook.
Комментарии
Минимальный уровень разрешений: ограниченный
Применимый режим Outlook: Compose или чтение
Примеры
Office.onReady(() => {
document.addEventListener('DOMContentLoaded', () => {
// Get a reference to the mailbox and use it to add an event handler.
const mailbox = Office.context.mailbox;
mailbox.addHandlerAsync(Office.EventType.ItemChanged, loadNewItem, (result) => {
if (result.status === Office.AsyncResultStatus.Failed) {
// Handle error.
}
});
});
});
function loadNewItem(eventArgs) {
const item = Office.context.mailbox.item;
// Check that item isn't null.
if (item !== null) {
// Work with item. For example, define and call a function that
// loads the properties of the newly selected item.
loadProps(item);
}
}
Свойства
diagnostics | Предоставляет надстройке Outlook диагностические сведения. Содержит следующие элементы.
Дополнительные сведения см. в разделе Office.Diagnostics. |
ews |
Получает URL-адрес конечной точки веб-служб Exchange (EWS) для этой учетной записи электронной почты. |
item | Элемент почтового ящика. В зависимости от контекста, в котором была открыта надстройка, тип элемента может отличаться. Если вы хотите видеть IntelliSense только для определенного типа или режима, приведите этот элемент к одному из следующих элементов: MessageCompose, MessageRead, AppointmentCompose, AppointmentRead Важно!
|
user |
Сведения о пользователе, связанном с почтовым ящиком. Сюда входят тип учетной записи, отображаемое имя, адрес электронной почты и часовой пояс. Дополнительные сведения см. в разделе Office.UserProfile. |
Методы
convert |
Получает словарь, содержащий сведения о локальном времени клиента. Часовой пояс, используемый клиентом Outlook, зависит от платформы. Outlook в Windows (классической версии) и на Mac использует часовой пояс клиентского компьютера. Outlook в Интернете и новый Outlook в Windows используют часовой пояс, заданный в Центре Администратор Exchange (EAC). Значения даты и времени должны обрабатываться таким образом, чтобы значения, отображаемые в интерфейсе пользователя, всегда согласовывались с часовым поясом, ожидаемым пользователем. В Outlook для Windows (классическая версия) и на Mac метод возвращает объект словаря со значениями, |
convert |
Метод |
display |
Отображает имеющуюся встречу из календаря. Метод В Outlook для Mac этот метод можно использовать для отображения одной встречи, которая не является частью повторяющегося ряда, или master встречи повторяющегося ряда. Однако вы не можете отобразить экземпляр ряда, так как не удается получить доступ к свойствам (включая идентификатор элемента) экземпляров повторяющегося ряда. В Outlook в Интернете и outlook в Windows этот метод открывает указанную форму только в том случае, если текст формы меньше или равен 32 КБ символов. Если указанный идентификатор элемента не идентифицирует существующую встречу, на клиентском компьютере или устройстве откроется пустая панель, и сообщение об ошибке не возвращается. |
display |
Отображает имеющееся сообщение. Метод В Outlook в Интернете и outlook в Windows этот метод открывает указанную форму только в том случае, если текст формы меньше или равен 32 КБ символов. Если указанный идентификатор элемента не идентифицирует существующее сообщение, сообщение не будет отображаться на клиентском компьютере и сообщение об ошибке не возвращается. |
display |
Отображает форму для создания новой встречи в календаре. Метод В Outlook в Интернете и новом Outlook в Windows этот метод всегда отображает форму с полем участников. Если вы не укажете участников в качестве входных аргументов, метод отображает форму с кнопкой Сохранить . Если вы укажете участников, форма будет включать участников и кнопку Отправить. Если в Outlook в Windows (классической) и на Mac указать участников или ресурсы в Если параметры превышают указанные ограничения размера или если указано неизвестное имя параметра, вызывается исключение. |
get |
Получает строку, содержащую маркер, используемый для получения вложения или элемента с Exchange Server. Метод Маркер возвращается в виде строки в свойстве |
get |
Возвращает значение true, если текущий почтовый ящик управляется Microsoft Intune. |
get |
Возвращает значение true, если политика управления мобильными приложениями (MAM) организации Intune позволяет надстройке получать доступ к данным из указанного расположения. |
get |
Возвращает значение true, если политика Intune управления мобильными приложениями (MAM) организации позволяет надстройке сохранять данные в указанном расположении. |
get |
Получает маркер, идентифицирующий пользователя и надстройку Office. Маркер возвращается в виде строки в свойстве |
make |
Выполняет асинхронный запрос к службе веб-служб Exchange (EWS) на сервере Exchange Server, на котором размещен почтовый ящик пользователя. Метод |
Сведения о свойстве
diagnostics
Предоставляет надстройке Outlook диагностические сведения.
Содержит следующие элементы.
hostName
(string) — строка, представляющая имя приложения Office. Это должно быть одно из следующих значений:Outlook
,newOutlookWindows
,OutlookWebApp
,OutlookIOS
илиOutlookAndroid
. Примечание. Значение "Outlook" возвращается для Outlook в Windows (классической) и на Mac.hostVersion
(строка): строка, представляющая версию приложения Office или Exchange Server (например, "15.0.468.0"). Если почтовая надстройка работает в Outlook в Windows (классической), на Mac или на мобильных устройствах,hostVersion
свойство возвращает версию клиента Outlook. В Outlook в Интернете и новом Outlook в Windows свойство возвращает версию Exchange Server.OWAView
(MailboxEnums.OWAView
или строка): перечисление (или строковый литерал), представляющее текущее представление Outlook в Интернете. Если приложение не Outlook в Интернете, доступ к этому свойству приведет к неопределенному значению. Outlook в Интернете имеет три представления (OneColumn
- отображаются, когда экран узкий,TwoColumns
- отображаются, когда экран шире, иThreeColumns
- отображаются при ширине экрана), которые соответствуют ширине экрана и окна, а также количеству отображаемых столбцов.
Дополнительные сведения см. в разделе Office.Diagnostics.
diagnostics: Diagnostics;
Значение свойства
Комментарии
Минимальный уровень разрешений: чтение элемента
Применимый режим Outlook: Compose или чтение
Начиная с набора обязательных для почтового ящика 1.5, вы также можете использовать свойство Office.context.диагностика для получения аналогичных сведений.
Примеры
// Link to full sample: https://raw.githubusercontent.com/OfficeDev/office-js-snippets/prod/samples/outlook/90-other-item-apis/get-diagnostic-information.yaml
// This function gets a mailbox's diagnostic information, such as Outlook client and version, and logs it to the console.
const diagnostics = Office.context.mailbox.diagnostics;
console.log(`Client application: ${diagnostics.hostName}`);
console.log(`Client version: ${diagnostics.hostVersion}`);
switch (diagnostics.OWAView) {
case undefined:
console.log("Current view (Outlook on the web only): Not applicable. An Outlook desktop client is in use.");
break;
case Office.MailboxEnums.OWAView.OneColumnNarrow:
console.log("Current view (Outlook on the web only): Viewed from an older generation mobile phone");
break;
case Office.MailboxEnums.OWAView.OneColumn:
console.log("Current view (Outlook on the web only): Viewed from a newer generation mobile phone");
break;
case Office.MailboxEnums.OWAView.TwoColumns:
console.log("Current view (Outlook on the web only): Viewed from a tablet");
break;
case Office.MailboxEnums.OWAView.ThreeColumns:
console.log("Current view (Outlook on the web only): Viewed from a desktop computer");
break;
}
ewsUrl
Получает URL-адрес конечной точки веб-служб Exchange (EWS) для этой учетной записи электронной почты.
ewsUrl: string;
Значение свойства
string
Комментарии
[ Набор API: Почтовый ящик 1.1 ]
Минимальный уровень разрешений: чтение элемента
Применимый режим Outlook: Compose или чтение
Важно!
Для вызова элемента в режиме чтения приложение должно иметь разрешение на чтение элемента , указанное в манифесте
ewsUrl
.В режиме создания необходимо вызвать
saveAsync
метод , прежде чем использоватьewsUrl
элемент . Для вызоваsaveAsync
метода приложение должно иметь разрешения на чтение и запись элементов.Это свойство не поддерживается в Outlook для Android или iOS. Дополнительные сведения о поддерживаемых API в Outlook Mobile см. в статье API JavaScript Для Outlook, поддерживаемые в Outlook на мобильных устройствах.
Удаленная служба может использовать значение
ewsUrl
, чтобы выполнять вызовы EWS для почтового ящика пользователя. Например, можно создать удаленную службу для получения вложений из выбранного элемента.
Примеры
// Link to full sample: https://raw.githubusercontent.com/OfficeDev/office-js-snippets/prod/samples/outlook/85-tokens-and-service-calls/ids-and-urls.yaml
// Get the EWS URL and EWS item ID.
console.log("EWS URL: " + Office.context.mailbox.ewsUrl);
const ewsId = Office.context.mailbox.item.itemId;
console.log("EWS item ID: " + Office.context.mailbox.item.itemId);
// Convert the EWS item ID to a REST-formatted ID.
const restId = Office.context.mailbox.convertToRestId(ewsId, Office.MailboxEnums.RestVersion.v2_0);
console.log("REST item ID: " + restId);
// Convert the REST-formatted ID back to an EWS-formatted ID.
const ewsId2 = Office.context.mailbox.convertToEwsId(restId, Office.MailboxEnums.RestVersion.v2_0);
console.log("EWS ID (from REST ID): " + ewsId2);
item
Элемент почтового ящика. В зависимости от контекста, в котором была открыта надстройка, тип элемента может отличаться. Если вы хотите видеть IntelliSense только для определенного типа или режима, приведите этот элемент к одному из следующих элементов:
MessageCompose, MessageRead, AppointmentCompose, AppointmentRead
Важно!
При вызове
Office.context.mailbox.item
сообщения обратите внимание, что область чтения в клиенте Outlook должна быть включена. Инструкции по настройке области чтения см. в статье Использование и настройка области чтения для предварительного просмотра сообщений.item
Может иметь значение NULL, если надстройка поддерживает закрепление области задач. Дополнительные сведения об обработке см. в разделе Реализация закрепляемой области задач в Outlook.
item?: Item & ItemCompose & ItemRead & Message & MessageCompose & MessageRead & Appointment & AppointmentCompose & AppointmentRead;
Значение свойства
userProfile
Сведения о пользователе, связанном с почтовым ящиком. Сюда входят тип учетной записи, отображаемое имя, адрес электронной почты и часовой пояс.
Дополнительные сведения см. в разделе Office.UserProfile.
userProfile: UserProfile;
Значение свойства
Сведения о методе
convertToLocalClientTime(timeValue)
Получает словарь, содержащий сведения о локальном времени клиента.
Часовой пояс, используемый клиентом Outlook, зависит от платформы. Outlook в Windows (классической версии) и на Mac использует часовой пояс клиентского компьютера. Outlook в Интернете и новый Outlook в Windows используют часовой пояс, заданный в Центре Администратор Exchange (EAC). Значения даты и времени должны обрабатываться таким образом, чтобы значения, отображаемые в интерфейсе пользователя, всегда согласовывались с часовым поясом, ожидаемым пользователем.
В Outlook для Windows (классическая версия) и на Mac метод возвращает объект словаря со значениями, convertToLocalClientTime
заданными часовой поясом клиентского компьютера. В Outlook в Интернете и новом Outlook для Windows метод возвращает объект словаря со значениями часового пояса, convertToLocalClientTime
указанного в EAC.
convertToLocalClientTime(timeValue: Date): LocalClientTime;
Параметры
- timeValue
-
Date
Объект Date
.
Возвращаемое значение
Комментарии
Минимальный уровень разрешений: чтение элемента
Применимый режим Outlook: Compose или чтение
convertToUtcClientTime(input)
Date
Получает объект из словаря, содержащего сведения о времени.
Метод convertToUtcClientTime
преобразует словарь, содержащий локальную дату и время, в Date
объект с правильными значениями для локальной даты и времени.
convertToUtcClientTime(input: LocalClientTime): Date;
Параметры
- input
- Office.LocalClientTime
Значение локального времени для преобразования.
Возвращаемое значение
Date
Объект Date со временем в формате UTC.
Комментарии
Минимальный уровень разрешений: чтение элемента
Применимый режим Outlook: Compose или чтение
Примеры
// Represents 3:37 PM PDT on Monday, August 26, 2019.
const input = {
date: 26,
hours: 15,
milliseconds: 2,
minutes: 37,
month: 7,
seconds: 2,
timezoneOffset: -420,
year: 2019
};
// result should be a Date object.
const result = Office.context.mailbox.convertToUtcClientTime(input);
// Output should be "2019-08-26T22:37:02.002Z".
console.log(result.toISOString());
displayAppointmentForm(itemId)
Отображает имеющуюся встречу из календаря.
Метод displayAppointmentForm
открывает существующую встречу в календаре в новом окне на рабочем столе.
В Outlook для Mac этот метод можно использовать для отображения одной встречи, которая не является частью повторяющегося ряда, или master встречи повторяющегося ряда. Однако вы не можете отобразить экземпляр ряда, так как не удается получить доступ к свойствам (включая идентификатор элемента) экземпляров повторяющегося ряда.
В Outlook в Интернете и outlook в Windows этот метод открывает указанную форму только в том случае, если текст формы меньше или равен 32 КБ символов.
Если указанный идентификатор элемента не идентифицирует существующую встречу, на клиентском компьютере или устройстве откроется пустая панель, и сообщение об ошибке не возвращается.
displayAppointmentForm(itemId: string): void;
Параметры
- itemId
-
string
Идентификатор веб-служб Exchange для существующей встречи в календаре.
Возвращаемое значение
void
Комментарии
[ Набор API: Почтовый ящик 1.1 ]
Минимальный уровень разрешений: чтение элемента
Применимый режим Outlook: Compose или чтение
Важно! Этот метод не поддерживается в Outlook для Android или iOS. Дополнительные сведения о поддерживаемых API в Outlook Mobile см. в статье API JavaScript Для Outlook, поддерживаемые в Outlook на мобильных устройствах.
Примеры
// Link to full sample: https://raw.githubusercontent.com/OfficeDev/office-js-snippets/prod/samples/outlook/55-display-items/display-existing-appointment.yaml
const itemId = $("#itemId").val();
Office.context.mailbox.displayAppointmentForm(itemId);
displayMessageForm(itemId)
Отображает имеющееся сообщение.
Метод displayMessageForm
открывает существующее сообщение в новом окне на рабочем столе.
В Outlook в Интернете и outlook в Windows этот метод открывает указанную форму только в том случае, если текст формы меньше или равен 32 КБ символов.
Если указанный идентификатор элемента не идентифицирует существующее сообщение, сообщение не будет отображаться на клиентском компьютере и сообщение об ошибке не возвращается.
displayMessageForm(itemId: string): void;
Параметры
- itemId
-
string
Идентификатор веб-служб Exchange для существующего сообщения.
Возвращаемое значение
void
Комментарии
[ Набор API: Почтовый ящик 1.1 ]
Минимальный уровень разрешений: чтение элемента
Применимый режим Outlook: Compose или чтение
Важно!
Этот метод не поддерживается в Outlook для Android или в iOS. Дополнительные сведения о поддерживаемых API в Outlook Mobile см. в статье API JavaScript Для Outlook, поддерживаемые в Outlook на мобильных устройствах.
Не используйте
displayMessageForm
с itemId, который представляет встречу. Используйте методdisplayAppointmentForm
, чтобы отобразить сведения о существующей встрече, а методdisplayNewAppointmentForm
— для отображения формы создания встречи.
Примеры
// Link to full sample: https://raw.githubusercontent.com/OfficeDev/office-js-snippets/prod/samples/outlook/55-display-items/display-existing-message.yaml
const itemId = $("#itemId").val();
Office.context.mailbox.displayMessageForm(itemId);
displayNewAppointmentForm(parameters)
Отображает форму для создания новой встречи в календаре.
Метод displayNewAppointmentForm
открывает форму, в которой пользователь может создать встречу или собрание. Если параметры заданы, поля формы встречи автоматически заполняются их содержимым.
В Outlook в Интернете и новом Outlook в Windows этот метод всегда отображает форму с полем участников. Если вы не укажете участников в качестве входных аргументов, метод отображает форму с кнопкой Сохранить . Если вы укажете участников, форма будет включать участников и кнопку Отправить.
Если в Outlook в Windows (классической) и на Mac указать участников или ресурсы в requiredAttendees
параметре , optionalAttendees
или resources
, этот метод отображает форму собрания с кнопкой Отправить . Если не указать получателей, этот метод отобразит форму встречи с кнопкой Сохранить и закрыть.
Если параметры превышают указанные ограничения размера или если указано неизвестное имя параметра, вызывается исключение.
displayNewAppointmentForm(parameters: AppointmentForm): void;
Параметры
- parameters
- Office.AppointmentForm
Объект AppointmentForm
, описывающий новое назначение. Все свойства являются необязательными.
Возвращаемое значение
void
Комментарии
[ Набор API: Почтовый ящик 1.1 ]
Минимальный уровень разрешений: чтение элемента
Применимый режим Outlook: чтение
Важно! Этот метод не поддерживается в Outlook для Android или iOS. Дополнительные сведения о поддерживаемых API в Outlook Mobile см. в статье API JavaScript Для Outlook, поддерживаемые в Outlook на мобильных устройствах.
Примеры
// Link to full sample: https://raw.githubusercontent.com/OfficeDev/office-js-snippets/prod/samples/outlook/55-display-items/display-new-appointment.yaml
const start = new Date();
const end = new Date();
end.setHours(start.getHours() + 1);
Office.context.mailbox.displayNewAppointmentForm({
requiredAttendees: ["bob@contoso.com"],
optionalAttendees: ["sam@contoso.com"],
start: start,
end: end,
location: "Home",
subject: "meeting",
resources: ["projector@contoso.com"],
body: "Hello World!"
});
getCallbackTokenAsync(callback, userContext)
Получает строку, содержащую маркер, используемый для получения вложения или элемента с Exchange Server.
Метод getCallbackTokenAsync
совершает асинхронный вызов, чтобы получить непрозрачный токен с сервера Exchange Server, на котором размещен почтовый ящик пользователя. Время существования маркера обратного вызова составляет 5 минут.
Маркер возвращается в виде строки в свойстве asyncResult.value
.
getCallbackTokenAsync(callback: (asyncResult: Office.AsyncResult<string>) => void, userContext?: any): void;
Параметры
- callback
-
(asyncResult: Office.AsyncResult<string>) => void
После завершения метода функция, переданная в параметре обратного вызова, вызывается с одним параметром типа Office.AsyncResult
. Маркер возвращается в виде строки в свойстве asyncResult.value
. При наличии ошибки свойства asyncResult.error
и asyncResult.diagnostics
могут предоставлять дополнительные сведения.
- userContext
-
any
Необязательный параметр. Данные о состоянии, передаваемые в асинхронный метод.
Возвращаемое значение
void
Комментарии
[ Набор API: все поддерживают режим чтения; В почтовом ящике 1.3 появилась поддержка режима Compose ]
Минимальный уровень разрешений: чтение элемента
Применимый режим Outlook: Compose или чтение
Важно!
В октябре 2024 г. устаревшие удостоверения пользователя Exchange и маркеры обратного вызова будут отключены по умолчанию для всех клиентов Exchange Online. Это часть инициативы Майкрософт по обеспечению безопасности в будущем, которая предоставляет организациям средства, необходимые для реагирования на текущую среду угроз. Маркеры удостоверений пользователей Exchange по-прежнему будут работать в локальной среде Exchange. Проверка подлинности вложенных приложений — это рекомендуемый подход к токенам в будущем. Дополнительные сведения см. в записи блога и на странице часто задаваемых вопросов.
Во внешнюю систему можно передать как маркер, так и идентификатор вложения или идентификатор элемента. Эта система использует маркер в качестве маркера авторизации носителя для вызова операции GetAttachment веб-служб Exchange (EWS) или GetItem для возврата вложения или элемента. Например, можно создать удаленную службу для получения вложений из выбранного элемента.
getCallbackTokenAsync
Для вызова метода в режиме чтения требуется минимальный уровень разрешений для чтения элемента.getCallbackTokenAsync
Вызов метода в режиме создания требует сохранения элемента. ДляsaveAsync
метода требуется минимальный уровень разрешений для чтения и записи элемента.Этот метод не поддерживается в Outlook для Android или в iOS. Операции EWS не поддерживаются в надстройках, работающих в Outlook на мобильных клиентах. Дополнительные сведения о поддерживаемых API в Outlook Mobile см. в статье API JavaScript Для Outlook, поддерживаемые в Outlook на мобильных устройствах.
Этот метод не поддерживается, если вы загружаете надстройку в почтовый ящик Outlook.com или Gmail.
Инструкции по сценариям делегирования или общего доступа см. в статье Общие папки и общие почтовые ящики .
Ошибки:
HTTPRequestFailure
: сбой запроса. Просмотрите объект диагностики для кода ошибки HTTP.InternalServerError
: сервер Exchange Server вернул ошибку. Для получения дополнительных сведений просмотрите объект диагностики.NetworkError
: пользователь больше не подключен к сети. Проверьте сетевое подключение и повторите попытку.
getIsIdentityManaged()
Возвращает значение true, если текущий почтовый ящик управляется Microsoft Intune.
getIsIdentityManaged(): boolean;
Возвращаемое значение
boolean
Значение true, если текущий почтовый ящик управляется Microsoft Intune.
Комментарии
Минимальный уровень разрешений: чтение элемента
Применимый режим Outlook: Compose, чтение
Важно! Этот метод поддерживается только в Outlook для Android и iOS, начиная с версии 4.2443.0.To дополнительные сведения об API, поддерживаемых в Outlook на мобильных устройствах, см. в статье API JavaScript, поддерживаемые в Outlook на мобильных устройствах.
Ошибки:
-
MAMServiceNotAvailable
: клиенту не удается получить политику управления мобильными приложениями (MAM).
getIsOpenFromLocationAllowed(openLocation)
Возвращает значение true, если политика управления мобильными приложениями (MAM) организации Intune позволяет надстройке получать доступ к данным из указанного расположения.
getIsOpenFromLocationAllowed(openLocation: MailboxEnums.OpenLocation): boolean;
Параметры
- openLocation
- Office.MailboxEnums.OpenLocation
Расположение, из которого надстройка пытается получить доступ к данным.
Возвращаемое значение
boolean
Значение true, если политика MAM Intune организации позволяет надстройке получать доступ к данным из указанного расположения.
Комментарии
Минимальный уровень разрешений: чтение элемента
Применимый режим Outlook: Compose, чтение
Важно! Этот метод поддерживается только в Outlook для Android и iOS, начиная с версии 4.2443.0. Дополнительные сведения об API, поддерживаемых в Outlook на мобильных устройствах, см. в статье API JavaScript, поддерживаемые в Outlook на мобильных устройствах.
Ошибки:
InvalidOpenLocationInput
: недопустимое значение указанного расположения.MAMServiceNotAvailable
: клиенту не удается получить политику MAM.
getIsSaveToLocationAllowed(saveLocation)
Возвращает значение true, если политика Intune управления мобильными приложениями (MAM) организации позволяет надстройке сохранять данные в указанном расположении.
getIsSaveToLocationAllowed(saveLocation: MailboxEnums.SaveLocation): boolean;
Параметры
- saveLocation
- Office.MailboxEnums.SaveLocation
Расположение, в котором надстройка пытается сохранить данные.
Возвращаемое значение
boolean
Значение true, если политика MAM Intune организации позволяет надстройке сохранять данные в указанном расположении.
Комментарии
Минимальный уровень разрешений: чтение элемента
Применимый режим Outlook: Compose, чтение
Важно! Этот метод поддерживается только в Outlook для Android и iOS, начиная с версии 4.2443.0. Дополнительные сведения об API, поддерживаемых в Outlook на мобильных устройствах, см. в статье API JavaScript, поддерживаемые в Outlook на мобильных устройствах.
Ошибки:
InvalidSaveLocationInput
: недопустимое значение указанного расположения.MAMServiceNotAvailable
: клиенту не удается получить политику MAM.
getUserIdentityTokenAsync(callback, userContext)
Получает маркер, идентифицирующий пользователя и надстройку Office.
Маркер возвращается в виде строки в свойстве asyncResult.value
.
getUserIdentityTokenAsync(callback: (asyncResult: Office.AsyncResult<string>) => void, userContext?: any): void;
Параметры
- callback
-
(asyncResult: Office.AsyncResult<string>) => void
После завершения метода функция, переданная в параметре обратного вызова, вызывается с одним параметром типа Office.AsyncResult
. Маркер возвращается в виде строки в свойстве asyncResult.value
. При наличии ошибки свойства asyncResult.error
и asyncResult.diagnostics
могут предоставлять дополнительные сведения.
- userContext
-
any
Необязательный параметр. Данные о состоянии, передаваемые в асинхронный метод.
Возвращаемое значение
void
Комментарии
Минимальный уровень разрешений: чтение элемента
Применимый режим Outlook: Compose или чтение
Важно!
В октябре 2024 г. устаревшие удостоверения пользователя Exchange и маркеры обратного вызова будут отключены по умолчанию для всех клиентов Exchange Online. Это часть инициативы Майкрософт по обеспечению безопасности в будущем, которая предоставляет организациям средства, необходимые для реагирования на текущую среду угроз. Маркеры удостоверений пользователей Exchange по-прежнему будут работать в локальной среде Exchange. Проверка подлинности вложенных приложений — это рекомендуемый подход к токенам в будущем. Дополнительные сведения см. в записи блога и на странице часто задаваемых вопросов.
Метод
getUserIdentityTokenAsync
возвращает маркер, который можно использовать для идентификации и проверки подлинности надстройки и пользователя во внешней системе.Этот метод не поддерживается, если вы загружаете надстройку в почтовый ящик Outlook.com или Gmail.
Ошибки:
HTTPRequestFailure
: сбой запроса. Просмотрите объект диагностики для кода ошибки HTTP.InternalServerError
: сервер Exchange Server вернул ошибку. Для получения дополнительных сведений просмотрите объект диагностики.NetworkError
: пользователь больше не подключен к сети. Проверьте сетевое подключение и повторите попытку.
Примеры
// Link to full sample: https://raw.githubusercontent.com/OfficeDev/office-js-snippets/prod/samples/outlook/85-tokens-and-service-calls/user-identity-token.yaml
Office.context.mailbox.getUserIdentityTokenAsync((result) => {
if (result.status === Office.AsyncResultStatus.Failed) {
console.error(`Token retrieval failed with message: ${result.error.message}`)
return;
}
console.log(result.value);
});
makeEwsRequestAsync(data, callback, userContext)
Выполняет асинхронный запрос к службе веб-служб Exchange (EWS) на сервере Exchange Server, на котором размещен почтовый ящик пользователя.
Метод makeEwsRequestAsync
отправляет запрос EWS от имени надстройки в Exchange.
makeEwsRequestAsync(data: any, callback: (asyncResult: Office.AsyncResult<string>) => void, userContext?: any): void;
Параметры
- data
-
any
Запрос EWS.
- callback
-
(asyncResult: Office.AsyncResult<string>) => void
После завершения метода функция, переданная в callback
параметре, вызывается с одним параметром Office.AsyncResult
, asyncResult
который является объектом . XML-ответ запроса EWS предоставляется в виде строки в свойстве asyncResult.value
. В Outlook в Интернете в Windows (новой и классической версии (начиная с версии 2303, сборки 16225.10000)) и в Mac (начиная с версии 16.73 (23042601)), если размер ответа превышает 5 МБ, в свойстве asyncResult.error
возвращается сообщение об ошибке. В более ранних версиях Outlook в Windows (классической) и на Mac возвращается сообщение об ошибке, если размер ответа превышает 1 МБ.
- userContext
-
any
Необязательный параметр. Данные о состоянии, передаваемые в асинхронный метод.
Возвращаемое значение
void
Комментарии
[ Набор API: Почтовый ящик 1.1 ]
Минимальный уровень разрешений: чтение и запись почтового ящика
Применимый режим Outlook: Compose или чтение
Важно!
В октябре 2024 г. устаревшие удостоверения пользователя Exchange и маркеры обратного вызова будут отключены по умолчанию для всех клиентов Exchange Online. Это часть инициативы Майкрософт по обеспечению безопасности в будущем, которая предоставляет организациям средства, необходимые для реагирования на текущую среду угроз. Маркеры удостоверений пользователей Exchange по-прежнему будут работать в локальной среде Exchange. Проверка подлинности вложенных приложений — это рекомендуемый подход к токенам в будущем. Дополнительные сведения см. в записи блога и на странице часто задаваемых вопросов.
Чтобы включить
makeEwsRequestAsync
метод для выполнения запросов EWS, администратор сервера должен задать значениеOAuthAuthentication
true
в каталоге EWS сервера клиентского доступа .Для использования метода надстройка должна иметь разрешение на чтение и запись почтового ящика
makeEwsRequestAsync
. Сведения об использовании разрешения на чтение и запись почтового ящика и операциях EWS, которые можно вызвать с помощьюmakeEwsRequestAsync
метода , см . в разделе Указание разрешений для доступа почтовой надстройки к почтовому ящику пользователя.Если надстройке требуется доступ к элементам, связанным с папкой, или в ее XML-запросе должна быть указана кодировка UTF-8 (
\<?xml version="1.0" encoding="utf-8"?\>
), она должна использовать Microsoft Graph или REST API для доступа к почтовому ящику пользователя.Этот метод не поддерживается в Outlook для Android или в iOS. Дополнительные сведения о поддерживаемых API в Outlook Mobile см. в статье API JavaScript Для Outlook, поддерживаемые в Outlook на мобильных устройствах.
Этот метод не поддерживается при загрузке надстройки в почтовый ящик Gmail.
При использовании
makeEwsRequestAsync
метода в надстройках, работающих в Outlook версий, предшествующих версии 15.0.4535.1004, необходимо задать значение кодировки ISO-8859-1 (<?xml version="1.0" encoding="iso-8859-1"?>
). Чтобы определить версию клиента Outlook, используйтеmailbox.diagnostics.hostVersion
свойство . Вам не нужно задавать значение кодирования, когда надстройка работает в Outlook в Интернете или новом Outlook в Windows. Чтобы определить клиент Outlook, в котором выполняется надстройка, используйтеmailbox.diagnostics.hostName
свойство .
Примеры
function getSubjectRequest(id) {
// Return a GetItem operation request for the subject of the specified item.
const request =
'<?xml version="1.0" encoding="utf-8"?>' +
'<soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"' +
' xmlns:xsd="http://www.w3.org/2001/XMLSchema"' +
' xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"' +
' xmlns:t="http://schemas.microsoft.com/exchange/services/2006/types">' +
' <soap:Header>' +
' <RequestServerVersion Version="Exchange2016" xmlns="http://schemas.microsoft.com/exchange/services/2006/types" soap:mustUnderstand="0" />' +
' </soap:Header>' +
' <soap:Body>' +
' <GetItem xmlns="http://schemas.microsoft.com/exchange/services/2006/messages">' +
' <ItemShape>' +
' <t:BaseShape>IdOnly</t:BaseShape>' +
' <t:AdditionalProperties>' +
' <t:FieldURI FieldURI="item:Subject"/>' +
' </t:AdditionalProperties>' +
' </ItemShape>' +
' <ItemIds><t:ItemId Id="' + id + '"/></ItemIds>' +
' </GetItem>' +
' </soap:Body>' +
'</soap:Envelope>';
return request;
}
function sendRequest() {
// Create a local variable that contains the mailbox.
Office.context.mailbox.makeEwsRequestAsync(
getSubjectRequest(mailbox.item.itemId), callback);
}
function callback(asyncResult) {
const result = asyncResult.value;
const context = asyncResult.asyncContext;
// Process the returned response here.
}
// Link to full sample: https://raw.githubusercontent.com/OfficeDev/office-js-snippets/prod/samples/outlook/85-tokens-and-service-calls/get-icaluid-as-attendee.yaml
const ewsId = Office.context.mailbox.item.itemId;
const request = `<soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:m="http://schemas.microsoft.com/exchange/services/2006/messages" xmlns:t="http://schemas.microsoft.com/exchange/services/2006/types" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Header><t:RequestServerVersion Version="Exchange2013" /></soap:Header>
<soap:Body>
<m:GetItem>
<m:ItemShape>
<t:BaseShape>AllProperties</t:BaseShape>
</m:ItemShape >
<m:ItemIds>
<t:ItemId Id="${ewsId}" />
</m:ItemIds>
</m:GetItem>
</soap:Body>
</soap:Envelope>`;
Office.context.mailbox.makeEwsRequestAsync(request, (result) => {
if (result.status === Office.AsyncResultStatus.Failed) {
console.error(result.error.message);
return;
}
console.log(getUID(result.value));
});
...
const request = '<soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:m="http://schemas.microsoft.com/exchange/services/2006/messages" xmlns:t="http://schemas.microsoft.com/exchange/services/2006/types" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">'+
' <soap:Header><t:RequestServerVersion Version="Exchange2010" /></soap:Header>'+
' <soap:Body>'+
' <m:CreateItem MessageDisposition="SendAndSaveCopy">'+
' <m:SavedItemFolderId><t:DistinguishedFolderId Id="sentitems" /></m:SavedItemFolderId>'+
' <m:Items>'+
' <t:Message>'+
' <t:Subject>Hello, Outlook!</t:Subject>'+
' <t:Body BodyType="HTML">This message was sent from a ScriptLab code sample, used from ' + Office.context.mailbox.diagnostics.hostName + ', version ' + Office.context.mailbox.diagnostics.hostVersion + '!</t:Body>'+
' <t:ToRecipients>'+
' <t:Mailbox><t:EmailAddress>' + Office.context.mailbox.userProfile.emailAddress + '</t:EmailAddress></t:Mailbox>'+
' </t:ToRecipients>'+
' </t:Message>'+
' </m:Items>'+
' </m:CreateItem>'+
' </soap:Body>'+
'</soap:Envelope>';
Office.context.mailbox.makeEwsRequestAsync(request, (result) => {
console.log(result);
});
Office Add-ins