Вы можете отправлять запросы о встрече по почте в Outlook, используя стандарт iCal (RFC 5545)
Таким образом нельзя отправлять задачи. Вы можете отправлять «Встречи», но они отображаются в Outlook как вложения .ics, которые необходимо принимать «вслепую».
Запросы на собрания отображаются в Outlook с красивым предварительным просмотром и могут быть приняты или отклонены. Отправляющая программа может изменить или отменить встречу после ее отправки.
Создать действительный элемент iCal очень просто с помощью библиотеки DDay.iCal .Net
Код ниже представляет собой полный рабочий пример. Он создает строку с действительным запросом на собрание iCal и отправляет ее по почте.
Код создает письмо с:
- текстовое тело для простых почтовых клиентов
- HTML тело для рассылки в современных почтовых клиентах
- Запрос на собрание iCal как AlternateView (будет отображаться в Outlook)
- Запрос на собрание iCal как вложение (можно использовать в почтовых клиентах, отличных от Outlook)
В коде показано, как добавить:
- текст описания в формате HTML, выглядит лучше в Outlook
- Приоритет, видимость (общедоступный / частный / конфиденциальный)
- дополнительный органайзер (будет отображаться в Outlook вместо отправителя почты)
- необязательные участники
- дополнительная сигнализация
- необязательные вложения к собранию. будет отображаться в календаре Outlook
Некоторые важные детали:
- отправитель почты (или необязательный органайзер) и получатель почты должны отличаться, чтобы эта функция работала в Outlook
- МЕТОД в .ics и МЕТОД в Mime.ContentType должны совпадать
- Встреча должна быть в будущем, чтобы эта работа стала перспективной.
- часть .ics должна быть последней частью alternateView в сообщении MIME.
Точные сведения о том, как Outlook интерпретирует файлы .ics, подробно описаны в [MS-OXCICAL]: алгоритм преобразования iCalendar в объект встречи
Мы будем использовать эти сборки:
using System;
using System.IO;
using System.Net.Mail;
using DDay.iCal;
using DDay.iCal.Serialization.iCalendar;
Для DDay.iCal достаточно загрузить двоичные файлы DDay.iCal. Если вы хотите добавить некоторые функции, лучше всего взглянуть на исходники DDay.iCal, потому что документация устарела, а источники содержат довольно полные тесты, которые проверяют все его функции.
const string filepath = @"C:\temp\ical.test.ics";
// use PUBLISH for appointments
// use REQUEST for meeting requests
const string METHOD = "REQUEST";
// Properties of the meeting request
// keep guid in sending program to modify or cancel the request later
Guid uid = Guid.Parse("2B127C67-73B3-43C5-A804-5666C2CA23C9");
string VisBetreff = "This is the subject of the meeting request";
string TerminVerantwortlicherEmail = "[email protected]";
string bodyPlainText = "This is the simple iCal plain text msg";
string bodyHtml = "This is the simple <b>iCal HTML message</b>";
string location = "Meeting room 101";
// 1: High
// 5: Normal
// 9: low
int priority = 1;
//=====================================
MailMessage message = new MailMessage();
message.From = new MailAddress("[email protected]");
message.To.Add(new MailAddress(TerminVerantwortlicherEmail));
message.Subject = "[VIS-Termin] " + VisBetreff;
// Plain Text Version
message.Body = bodyPlainText;
// HTML Version
string htmlBody = bodyHtml;
AlternateView HTMLV = AlternateView.CreateAlternateViewFromString(htmlBody,
new System.Net.Mime.ContentType("text/html"));
// iCal
IICalendar iCal = new iCalendar();
iCal.Method = METHOD;
iCal.ProductID = "My Metting Product";
// Create an event and attach it to the iCalendar.
Event evt = iCal.Create<Event>();
evt.UID = uid.ToString();
evt.Class = "PUBLIC";
// Needed by Outlook
evt.Created = new iCalDateTime(DateTime.Now);
evt.DTStamp = new iCalDateTime(DateTime.Now);
evt.Transparency = TransparencyType.Transparent;
// Set the event start / end times
evt.Start = new iCalDateTime(2014, 10, 3, 8, 0, 0);
evt.End = new iCalDateTime(2014, 10, 3, 8, 15, 0);
evt.Location = location;
//var organizer = new Organizer("[email protected]");
//evt.Organizer = organizer;
// Set the longer description of the event, plain text
evt.Description = bodyPlainText;
// Event description HTML text
// X-ALT-DESC;FMTTYPE=text/html
var prop = new CalendarProperty("X-ALT-DESC");
prop.AddParameter("FMTTYPE", "text/html");
prop.AddValue(bodyHtml);
evt.AddProperty(prop);
// Set the one-line summary of the event
evt.Summary = VisBetreff;
evt.Priority = priority;
//--- attendes are optional
IAttendee at = new Attendee("mailto:[email protected]");
at.ParticipationStatus = "NEEDS-ACTION";
at.RSVP = true;
at.Role = "REQ-PARTICIPANT";
evt.Attendees.Add(at);
// Let’s also add an alarm on this event so we can be reminded of it later.
Alarm alarm = new Alarm();
// Display the alarm somewhere on the screen.
alarm.Action = AlarmAction.Display;
// This is the text that will be displayed for the alarm.
alarm.Summary = "Upcoming meeting: " + VisBetreff;
// The alarm is set to occur 30 minutes before the event
alarm.Trigger = new Trigger(TimeSpan.FromMinutes(-30));
//--- Attachments
string filename = "Test.docx";
// Add an attachment to this event
IAttachment attachment = new DDay.iCal.Attachment();
attachment.Data = ReadBinary(@"C:\temp\Test.docx");
attachment.Parameters.Add("X-FILENAME", filename);
evt.Attachments.Add(attachment);
iCalendarSerializer serializer = new iCalendarSerializer();
serializer.Serialize(iCal, filepath);
// the .ics File as a string
string iCalStr = serializer.SerializeToString(iCal);
// .ics as AlternateView (used by Outlook)
// text/calendar part: method=REQUEST
System.Net.Mime.ContentType calendarType =
new System.Net.Mime.ContentType("text/calendar");
calendarType.Parameters.Add("method", METHOD);
AlternateView ICSview =
AlternateView.CreateAlternateViewFromString(iCalStr, calendarType);
// Compose
message.AlternateViews.Add(HTMLV);
message.AlternateViews.Add(ICSview); // must be the last part
// .ics as Attachment (used by mail clients other than Outlook)
Byte[] bytes = System.Text.Encoding.ASCII.GetBytes(iCalStr);
var ms = new System.IO.MemoryStream(bytes);
var a = new System.Net.Mail.Attachment(ms,
"VIS-Termin.ics", "text/calendar");
message.Attachments.Add(a);
// Send Mail
SmtpClient client = new SmtpClient();
client.Send(message);
Вот функция ReadBinary ():
private static byte[] ReadBinary(string fileName)
{
byte[] binaryData = null;
using (FileStream reader = new FileStream(fileName,
FileMode.Open, FileAccess.Read))
{
binaryData = new byte[reader.Length];
reader.Read(binaryData, 0, (int)reader.Length);
}
return binaryData;
}
Проще всего настроить SmtpClient в файле конфигурации следующим образом:
<configuration>
...
<system.net>
<mailSettings>
<smtp>
<network host="mysmtp.server.com" port="25" userName="mySmtpUserName" password="myPassword" />
</smtp>
</mailSettings>
</system.net>
...
person
DrKoch
schedule
04.10.2014