إدارة عناصر Outlook عبر عميل Aspose.Email Graph
إدارة أحداث التقويم
توفر Aspose.Email واجهات برمجة تطبيقات للوصول إلى أحداث التقويم وإدارتها والتفاعل معها. لهذا الغرض، تقدم الطرق التالية في IGraphClient واجهة:
- ListCalendars() - يسترجع مجموعة من معلومات التقويم.
- ListCalendarItems(string id) - يسترجع مجموعة من عناصر التقويم المرتبطة بمعرف التقويم المحدد.
- FetchCalendarItem(string id) - يسترجع عنصر تقويم معين بناءً على المعرف المقدم.
- CreateCalendarItem(string calId, MapiCalendar mapiCalendar) - ينشئ عنصر تقويم جديد في التقويم المحدد.
- UpdateCalendarItem(MapiCalendar mapiCalendar) - يُحدّث عنصر تقويم موجود.
- UpdateCalendarItem(MapiCalendar mapiCalendar, UpdateSettings updateSettings) - يُحدّث عنصر تقويم موجود باستخدام إعدادات التحديث المحددة.
يعرض المثال البرمجي التالي كيفية التفاعل مع أحداث التقويم في عميل Microsoft Graph API باستخدام الطرق التي توفرها Aspose.Email:
// List Calendars
CalendarInfoCollection calendars = graphClient.ListCalendars();
// List Calendar Items
MapiCalendarCollection calendarItems = graphClient.ListCalendarItems("calendarId");
// Fetch Calendar Item
MapiCalendar calendarItem = graphClient.FetchCalendarItem("calendarItemId");
// Create Calendar Item
MapiCalendar newCalendarItem = new MapiCalendar(
location: "Conference Room",
summary: "Team Meeting",
description: "Discuss project status and updates.",
startDate: startDate,
endDate: endDate
);
MapiCalendar createdCalendarItem = graphClient.CreateCalendarItem("calendarId", newCalendarItem);
// Update Calendar Item
createdCalendarItem.Location = "Zoom Meeting";
MapiCalendar updatedCalendarItem = graphClient.UpdateCalendarItem(createdCalendarItem);
إدارة فئات الرسائل
لإدارة الفئات باستخدام MS Graph من خلال Aspose.Email لـ .NET، استخدم الطرق التالية وجرب مثال الشيفرة أدناه:
// create a custom category with Orange color
var category = client.CreateCategory("My custom category", CategoryPreset.Preset1);
// fetch a category
var fetchedCategory = client.FetchCategory(category.Id);
// update category (change color to brown)
fetchedCategory.Preset = CategoryPreset.Preset2;
var updatedCategory = client.UpdateCategory(fetchedCategory);
// list available categories
var categories = client.ListCategories();
foreach (var cat in categories)
{
Console.WriteLine(cat.DisplayName);
}
// delete a category
client.Delete(fetchedCategory.Id);
إدارة جهات الاتصال
توفر Aspose.Email واجهات برمجة تطبيقات للوصول إلى عناصر جهات الاتصال وإدارتها والتفاعل معها. لهذا الغرض، تقدم الطرق التالية في IGraphClient واجهة:
- ListContacts(string id) - يسترجع مجموعة من جهات اتصال MAPI المرتبطة بمعرف المجلد المحدد.
- FetchContact(string id) - يسترجع جهة اتصال معينة بناءً على معرف العنصر المقدم.
- CreateContact(string folderId, MapiContact contact) - ينشئ جهة اتصال جديدة في المجلد المحدد.
- UpdateContact(MapiContact contact) - يُحدّث جهة اتصال موجودة.
يعرض المثال البرمجي التالي كيفية التفاعل مع جهات الاتصال في عميل Microsoft Graph API باستخدام الطرق التي توفرها Aspose.Email:
// List Contacts
MapiContactCollection contacts = graphClient.ListContacts("contactFolderId");
// Fetch Contact
MapiContact contact = graphClient.FetchContact("contactId");
// Create Contact
MapiContact newContact = new MapiContact("Jane Smith", "jane.smith@example.com", "XYZ Corporation", "777-888-999");
MapiContact createdContact = graphClient.CreateContact("contactFolderId", newContact);
// Update Contact
createdContact.Telephones.PrimaryTelephoneNumber = "888-888-999";
MapiContact updatedContact = graphClient.UpdateContact(createdContact);
إدارة التجاوزات
إدارة التجاوزات باستخدام MS Graph من خلال Aspose.Email لـ .NET، استخدم الطرق التالية:
// Create an user's override
var userOverride = client.CreateOrUpdateOverride
(new MailAddress("JohnBrown@someorg.com", "JohnBrown"), ClassificationType.Focused);
// list the overrides
var overrides = client.ListOverrides();
// update override
userOverride.Sender.DisplayName = "John Brown";
var updatedOverride = client.UpdateOverride(userOverride);
// delete override
client.Delete(updatedOverride.Id);
إدارة قواعد البريد الوارد
إدارة القواعد باستخدام MS Graph من خلال Aspose.Email لـ .NET، استخدم الطرق التالية:
// Create a rule
var rule = PrepareRule("user@someorg.com", "User");
var createdRule = client.CreateRule(rule);
// List all rules defined for Inbox
var rules = client.ListRules();
// Fetch a rule
var fetchedRule = client.FetchRule(createdRule.RuleId);
// Update a rule
fetchedRule.DisplayName = "Renamed rule";
fetchedRule.IsEnabled = false;
var updatedRule = client.UpdateRule(createdRule);
// Delete a rule
client.Delete(updatedRule.RuleId);
InboxRule PrepareRule(string email, string displayName)
{
var rule = new InboxRule()
{
DisplayName = "My rule",
Priority = 1,
IsEnabled = true,
Conditions = new RulePredicates(),
Actions = new RuleActions()
};
rule.Conditions.ContainsSenderStrings = new StringCollection { displayName };
rule.Actions.ForwardToRecipients = new MailAddressCollection
{ new MailAddress(email, displayName, true) };
rule.Actions.StopProcessingRules = true;
return rule;
}
إدارة دفاتر OneNote
إدارة دفاتر الملاحظات باستخدام MS Graph من خلال Aspose.Email لـ .NET، استخدم الطرق التالية:
// create a OneNote notebook
var newNotebook = new Notebook()
{
DisplayName = "My Notebook"
};
var createdNotebook = client.CreateNotebook(newNotebook);
// fetch a notebook
var fetchedNotebook = client.FetchNotebook(createdNotebook.Id);
// list the notebooks
var notebooks = client.ListNotebooks();
إدارة المهام في Microsoft Graph
يوفر Aspose.Email للمطورين واجهات برمجية للوصول إلى مهام المستخدمين وقوائم المهام وإدارتها والتفاعل معها باستخدام الطرق التالية في الـ IGraphClient واجهة:
- ListTaskLists() - يسترجع مجموعة من معلومات قوائم المهام.
- GetTaskList(string id) - يسترجع قائمة مهام معينة بناءً على المعرف المقدم.
- DeleteTaskList(string id) - يحذف قائمة المهام المحددة. -ListTasks(string id) - يسترجع مجموعة من المهام المرتبطة بمعرف قائمة المهام المحدد.
- FetchTask(string id) - يسترجع مهمة معينة بناءً على المعرف المقدم.
- CreateTask(MapiTask task, string taskListUri) - ينشئ مهمة جديدة في قائمة المهام المحددة.
- UpdateTask(MapiTask task) - يُحدّث مهمة موجودة بالمعلومات المقدمة.
- UpdateTask(MapiTask task, UpdateSettings updateSettings) - يُحدّث مهمة موجودة بإعدادات تحديث محددة.
يُظهر المثال التالي كيفية إدارة قوائم المهام:
// List Task Lists
var taskLists = graphClient.ListTaskLists();
foreach (var tList in taskLists)
{
Console.WriteLine($"Task List: {tList.DisplayName}");
}
// Get Task List
var taskList = graphClient.GetTaskList("taskListId");
// Delete Task List
graphClient.DeleteTaskList("taskListId");
يُظهر المثال التالي كيفية إدارة المهام:
// List Tasks in a Task List
MapiTaskCollection tasks = graphClient.ListTasks("taskListId");
// Fetch Task
MapiTask task = graphClient.FetchTask("taskId");
// Create Task
var newTask = new MapiTask
{
Subject = "New Task",
DueDate = new DateTime(2023, 12, 31),
Status = MapiTaskStatus.NotStarted
};
MapiTask createdTask = graphClient.CreateTask(newTask, "taskListUri");
// Update Task
createdTask.Subject = "Updated Task Subject";
MapiTask updatedTask = graphClient.UpdateTask(createdTask);
// Update Task with UpdateSettings
var updateSettings = new UpdateSettings { SkipAttachments = true };
MapiTask updatedTaskWithSettings = graphClient.UpdateTask(createdTask, updateSettings);