Quản lý Google Calendar bằng Gmail Client
Thêm, Chỉnh sửa và Xóa Lịch Gmail
Aspose.Email cho phép các ứng dụng quản lý các lịch Gmail bằng cách sử dụng IGmailClient cung cấp các tính năng như thêm, xóa và cập nhật lịch Gmail. Lớp client này trả về một danh sách các đối tượng kiểu ExtendedCalendar chứa thông tin về các mục lịch Gmail. IGmailClient lớp cung cấp các hàm sau cho lịch:
- CreateCalendar Nó có thể được dùng để chèn lịch mới
- ListCalendars Nó có thể được dùng để lấy danh sách tất cả các lịch của một client
- DeleteCalendar Nó có thể được dùng để xóa một lịch
- FetchCalendar Nó có thể được dùng để lấy lịch cụ thể của một khách hàng
- UpdateCalendar Hàm này được dùng để chèn lại lịch đã chỉnh sửa của một client
Để Truy cập các lịch, GoogleTestUser được khởi tạo bằng thông tin đăng nhập tài khoản gmail. GoogleOAuthHelper được sử dụng để lấy token truy cập cho người dùng, sau đó token này được dùng để khởi tạo IGmailClient.
Chèn, Lấy và Cập nhật Lịch Gmail
Đối với việc chèn một lịch, khởi tạo một đối tượng kiểu Calendar và chèn nó bằng cách sử dụng CreateCalendar() hàm. CreateCalendar() trả về id của lịch mới được chèn. Id này có thể được dùng để lấy lịch từ máy chủ. Đoạn mã sau cho bạn thấy cách chèn, lấy và cập nhật lịch.
Xóa Lịch Google Cụ thể
Để xóa một lịch cụ thể, chúng ta cần lấy danh sách tất cả các lịch của một khách hàng và sau đó xóa theo yêu cầu. ListCalendars() trả về danh sách của ExtendedCalendar chứa các lịch Gmail. Đoạn mã sau cho bạn thấy cách xóa một lịch cụ thể.
Kiểm soát Truy cập Lịch
Aspose.Email cung cấp quyền kiểm soát đầy đủ đối với việc truy cập các mục lịch. ListAccessRules() hàm được công khai bởi IGmailClient trong đó trả về danh sách của AccessControlRule. Thông tin quy tắc cá nhân có thể được lấy, chỉnh sửa và lưu lại cho lịch của một khách hàng. IGmailClient chứa các hàm sau để quản lý các quy tắc kiểm soát truy cập.
- ListAccessRules Hàm này cung cấp danh sách AccessControlRule
- CreateAccessRule Hàm này tạo một quy tắc truy cập mới cho lịch.
- UpdateAccessRule Hàm này được dùng để cập nhật một quy tắc truy cập.
- FetchAccessRule Nó có thể được dùng để lấy quy tắc truy cập cụ thể cho lịch của một khách hàng
- DeleteAccessRule Hàm này được dùng để xóa một quy tắc truy cập.
Đoạn mã dưới đây cho bạn thấy cách sử dụng các hàm để quản lý các quy tắc truy cập:
Cài đặt Client Lịch và Thông tin Màu
Aspose.Email hỗ trợ truy cập cài đặt Khách hàng bằng cách sử dụng IGmailClient.GetSettings(). Nó trả về danh sách các thiết lập như dưới đây:
- dateFieldOrder
- displayAllTimezones
- hideInvitations
- format24HourTime
- defaultCalendarMode
- defaultEventLength
- locale
- remindOnRespondedEventsOnly
- alternateCalendar
- userLocation
- hideWeekends
- showDeclinedEvents
- weekStart
- weather
- customCalendarMode
- timezoneLabel
- timezone
- useKeyboardShortcuts
- quốc gia
Tương tự, thông tin màu cho khách hàng cũng có thể được lấy bằng cách sử dụng IGmailClient.GetColors(). Đối tượng thông tin màu này trả về danh sách các màu tiền cảnh, màu nền và ngày giờ cập nhật.
Truy cập Cài đặt Khách hàng
Đoạn mã dưới đây cho bạn thấy cách các hàm có thể được sử dụng để truy cập các thiết lập của client:
Truy cập Thông tin Màu
Đoạn mã dưới đây cho bạn thấy cách các hàm có thể được sử dụng để truy cập các cài đặt màu của client.
Quản lý Cuộc hẹn Lịch Google
Aspose.Email cung cấp các tính năng để làm việc với Cuộc hẹn trong lịch Google. Các tác vụ sau có thể được thực hiện trên các cuộc hẹn trong lịch Google:
- Thêm các cuộc hẹn.
- Lấy danh sách các cuộc hẹn.
- Lấy thông tin cuộc hẹn cụ thể.
- Cập nhật một cuộc hẹn.
- Di chuyển cuộc hẹn từ lịch này sang lịch khác.
- Xóa cuộc hẹn.
IGmailClient cung cấp các hàm như CreateAppointment, FetchAppointment, UpdateAppointment, ListAppointments, MoveAppointment và DeleteAppointment.
Thêm Cuộc hẹn vào Google Calendar
Mẫu mã dưới đây minh họa tính năng thêm một cuộc hẹn vào lịch. Để thực hiện, làm theo các bước:
- Tạo và chèn một lịch.
- Lấy danh sách các cuộc hẹn từ một lịch mới.
- Tạo một cuộc hẹn.
- Chèn một cuộc hẹn.
Lấy và Cập nhật Cuộc hẹn Lịch Google
Ở đây việc lấy và cập nhật lịch được minh họa như sau:
- Lấy cuộc hẹn cụ thể.
- Sửa đổi cuộc hẹn.
- Cập nhật cuộc hẹn trong lịch.
Giả sử rằng một lịch có id "calendarId" và một cuộc hẹn có id duy nhất "AppointmentUniqueId" đã được trích xuất. Đoạn mã sau cho bạn thấy cách lấy và cập nhật một cuộc hẹn.
Di chuyển và Xóa Cuộc hẹn trong Lịch Google
Cuộc hẹn có thể được di chuyển bằng cách cung cấp lịch nguồn, lịch đích và id duy nhất của cuộc hẹn trong lịch nguồn. Đoạn mã sau cho bạn thấy cách di chuyển và xóa một cuộc hẹn.
Truy vấn FreeBusy cho Lịch Google
Aspose.Email cung cấp cơ chế truy vấn để kiểm tra xem một cuộc hẹn có đến hạn hay không theo tiêu chí. Lớp FreebusyQuery được cung cấp cho mục đích này, cho phép chuẩn bị một truy vấn cho một lịch cụ thể.
Ví dụ mã này trình bày tính năng truy vấn lịch. Các tác vụ sau được thực hiện trong mẫu này:
- Tạo và chèn một lịch
- Tạo một cuộc hẹn
- Chèn cuộc hẹn
- Chuẩn bị một FreeBusyQuery
- Lấy FreebusyResponse
// For complete examples and data files, please go to https://github.com/aspose-email/Aspose.Email-for-.NET
// Use the GoogleUser and GoogleOAuthHelper classes below to receive an access token
using (IGmailClient client = GmailClient.GetInstance(accessToken, user.Email))
{
// Initialize calendar item
Aspose.Email.Clients.Google.Calendar calendar1 = new Aspose.Email.Clients.Google.Calendar("summary - " + Guid.NewGuid().ToString(), null, null, "Europe/Kiev");
// Insert calendar and get back id of newly inserted calendar and Fetch the same calendar using calendar id
string id = client.CreateCalendar(calendar1);
Aspose.Email.Clients.Google.Calendar cal1 = client.FetchCalendar(id);
string calendarId1 = cal1.Id;
try
{
// Get list of appointments in newly inserted calendar. It should be zero
Appointment[] appointments = client.ListAppointments(calendarId1);
if (appointments.Length != 0)
{
Console.WriteLine("Wrong number of appointments");
return;
}
// Create a new appointment and Calculate appointment start and finish time
DateTime startDate = DateTime.Now;
DateTime endDate = startDate.AddHours(1);
// Create attendees list for appointment
MailAddressCollection attendees = new MailAddressCollection();
attendees.Add("user1@domain.com");
attendees.Add("user2@domain.com");
// Create appointment
Appointment app1 = new Appointment("Location - " + Guid.NewGuid().ToString(), startDate, endDate, "user2@domain.com", attendees);
app1.Summary = "Summary - " + Guid.NewGuid().ToString();
app1.Description = "Description - " + Guid.NewGuid().ToString();
app1.StartTimeZone = "Europe/Kiev";
app1.EndTimeZone = "Europe/Kiev";
// Insert the newly created appointment and get back the same in case of successful insertion
Appointment app2 = client.CreateAppointment(calendarId1, app1);
// Create Freebusy query by setting min/max timeand time zone
FreebusyQuery query = new FreebusyQuery();
query.TimeMin = DateTime.Now.AddDays(-1);
query.TimeMax = DateTime.Now.AddDays(1);
query.TimeZone = "Europe/Kiev";
// Set calendar item to search and Get the reponse of query containing
query.Items.Add(cal1.Id);
FreebusyResponse resp = client.GetFreebusyInfo(query);
// Delete the appointment
client.DeleteAppointment(calendarId1, app2.UniqueId);
}
finally
{
// Delete the calendar
client.DeleteCalendar(cal1.Id);
}
}