Работа с сообщениями с использованием Microsoft Graph

Aspose.Email for Java предоставляет широкий набор API для управления сообщениями через Microsoft Graph. Вы можете перечислять, получать, создавать, обновлять, перемещать, копировать и удалять сообщения, а также работать с пагинацией и вложениями. Приведённые ниже образцы кода являются примерами самых распространённых операций.

Список сообщений

Вы можете получать сообщения из конкретной папки, например Входящие, и получать их полное содержимое:

GraphMessageInfoCollection messageInfoColl = client.listMessages(GraphKnownFolders.Inbox);
for (GraphMessageInfo messageInfo : messageInfoColl) {
    MapiMessage message = client.fetchMessage(messageInfo.getItemId());
}

Список сообщений по дате отправки

Чтобы сортировать сообщения по дате отправки в порядке возрастания, можно использовать OrderBy функция GraphQueryBuilder:

// create orderby messages query 'ASC'
GraphQueryBuilder builder = new GraphQueryBuilder();
builder.getSentDate().orderBy(true);
MailQuery query = builder.getQuery();

GraphMessagePageInfo pageInfo = client.listMessages(GraphKnownFolders.Inbox, new PageInfo(10), query);

Получить сообщение

Получив ссылку на сообщение, вы можете получить его полное содержимое:

GraphMessageInfo messageInfo = messageInfoColl.get(0);
MapiMessage fetchedMessage = client.fetchMessage(messageInfo.getItemId());

Обновить сообщение

После получения сообщения вы можете изменить его содержимое и обновить его на сервере:

fetchedMessage.setSubject("Update message");
MapiMessage updatedMessage = client.updateMessage(fetchedMessage);

Пагинация в списке сообщений

При работе с большими почтовыми ящиками можно использовать постраничный вывод для получения сообщений порциями. Ниже приведён пример, демонстрирующий список непрочитанных сообщений постранично по два элемента:

// send ping test messages
for (int i = 0; i < 5; i++) {
    MailMessage eml = new MailMessage(user.EMail, user.EMail, "ping" + i, "test body");
    client.send(MapiMessage.fromMailMessage(eml));
}
// waiting for inbox
Thread.sleep(10000);

// paging option
int itemsPerPage = 2;
// create unread messages filter
GraphQueryBuilder builder = new GraphQueryBuilder();
builder.isRead().equals(false);
MailQuery query = builder.getQuery();

// list messages
GraphMessagePageInfo pageInfo = client.listMessages(GraphKnownFolders.Inbox, new PageInfo(itemsPerPage), query);
GraphMessageInfoCollection messages = pageInfo.getItems();
while (!pageInfo.getLastPage())
{
    pageInfo = client.listMessages(GraphKnownFolders.Inbox, pageInfo.getNextPage(), query);
    // add next page items to common collection
    messages.addRange(pageInfo.getItems());
}

// set messages state as read
for (GraphMessageInfo message : messages) {
    client.setRead(message.getItemId());
}

Создать сообщение

Вы можете создавать новые сообщения с темой, телом и свойствами:

MapiMessage message = new MapiMessage();
message.setSubject("Subject");
message.setBody("Body");
message.setProperty(KnownPropertyList.DISPLAY_TO, "to@host.com");
message.setProperty(KnownPropertyList.SENDER_NAME, "from");
message.setProperty(KnownPropertyList.SENT_REPRESENTING_EMAIL_ADDRESS, "from@host.com");

MapiMessage createdMessage = client.createMessage(GraphKnownFolders.Inbox, message);

Отправить сообщение

Вы можете отправить сообщение напрямую:

client.send(message);

Или отправьте черновик сообщения после создания его в папке Черновики:

MapiMessage draftMessage = client.createMessage(GraphKnownFolders.Drafts, message);
client.send(draftMessage.getItemId());

Копировать и перемещать сообщения

Сообщения можно копировать или перемещать между папками:

MapiMessage copiedMessage = client.copyMessage(GraphKnownFolders.Inbox, draftMessage.getItemId());
MapiMessage movedMessage = client.moveMessage(GraphKnownFolders.Inbox, draftMessage.getItemId());

Управление вложениями

Чтобы перечислить и удалить вложения из сообщения, используйте следующий пример кода:

MapiAttachmentCollection attachments = client.listAttachments(fetchedMessage.getItemId());
for (MapiAttachment att : attachments) {
    client.deleteAttachment(att.getItemId());
}

Удалить сообщение

Наконец, вы можете удалить сообщение навсегда:

client.delete(message.getItemId());