/// <summary> /// Adds specified address to the end of the collection. /// </summary> /// <param name="value">Address to add.</param> /// <exception cref="ArgumentNullException">Is raised when <b>value</b> is null reference value.</exception> public void Add(Mail_t_Mailbox value) { if(value == null){ throw new ArgumentNullException("value"); } m_pList.Add(value); m_IsModified = true; }
/// <summary> /// Inserts a address into the collection at the specified location. /// </summary> /// <param name="index">The location in the collection where you want to add the item.</param> /// <param name="value">Address to insert.</param> /// <exception cref="ArgumentOutOfRangeException">Is raised when <b>index</b> is out of range.</exception> /// <exception cref="ArgumentNullException">Is raised when <b>value</b> is null reference.</exception> public void Insert(int index,Mail_t_Mailbox value) { if(index < 0 || index > m_pList.Count){ throw new ArgumentOutOfRangeException("index"); } if(value == null){ throw new ArgumentNullException("value"); } m_pList.Insert(index,value); m_IsModified = true; }
/// <summary> /// Default constructor. /// </summary> /// <param name="fieldName">Header field name. For example: "Sender".</param> /// <param name="mailbox">Mailbox value.</param> /// <exception cref="ArgumentNullException">Is raised when <b>filedName</b> or <b>mailbox</b> is null reference.</exception> /// <exception cref="ArgumentException">Is raised when any of the arguments has invalid value.</exception> public Mail_h_Mailbox(string fieldName,Mail_t_Mailbox mailbox) { if(fieldName == null){ throw new ArgumentNullException("fieldName"); } if(fieldName == string.Empty){ throw new ArgumentException("Argument 'fieldName' value must be specified."); } if(mailbox == null){ throw new ArgumentNullException("mailbox"); } m_Name = fieldName; m_pAddress = mailbox; }
/// <summary> /// Constructs ENVELOPE address structure. /// </summary> /// <param name="address">Mailbox address.</param> /// <param name="wordEncoder">Unicode words encoder.</param> /// <returns></returns> private static string ConstructAddress(Mail_t_Mailbox address,MIME_Encoding_EncodedWord wordEncoder) { /* An address structure is a parenthesized list that describes an electronic mail address. The fields of an address structure are in the following order: personal name, [SMTP] at-domain-list (source route), mailbox name, and host name. */ // NOTE: all header fields and parameters must in ENCODED form !!! StringBuilder retVal = new StringBuilder(); retVal.Append("("); // personal name if(address.DisplayName != null){ retVal.Append(TextUtils.QuoteString(wordEncoder.Encode(RemoveCrlf(address.DisplayName)))); } else{ retVal.Append("NIL"); } // source route, always NIL (not used nowdays) retVal.Append(" NIL"); // mailbox name retVal.Append(" " + TextUtils.QuoteString(wordEncoder.Encode(RemoveCrlf(address.LocalPart)))); // host name if(address.Domain != null){ retVal.Append(" " + TextUtils.QuoteString(wordEncoder.Encode(RemoveCrlf(address.Domain)))); } else{ retVal.Append(" NIL"); } retVal.Append(")"); return retVal.ToString(); }
/// <summary> /// Constructs ENVELOPE addresses structure. /// </summary> /// <param name="mailboxes">Mailboxes.</param> /// <param name="wordEncoder">Unicode words encoder.</param> /// <returns></returns> private static string ConstructAddresses(Mail_t_Mailbox[] mailboxes,MIME_Encoding_EncodedWord wordEncoder) { StringBuilder retVal = new StringBuilder(); retVal.Append("("); foreach(Mail_t_Mailbox address in mailboxes){ retVal.Append(ConstructAddress(address,wordEncoder)); } retVal.Append(")"); return retVal.ToString(); }
/// <summary> /// Removes specified item from the collection. /// </summary> /// <param name="value">Address to remove.</param> /// <exception cref="ArgumentNullException">Is raised when <b>value</b> is null reference value.</exception> public void Remove(Mail_t_Mailbox value) { if(value == null){ throw new ArgumentNullException("value"); } m_pList.Remove(value); }
/// <summary> /// Creates mail message. /// </summary> /// <param name="from">From: address.</param> /// <param name="to">To: address.</param> /// <param name="cc">Cc: address. Value null means not used.</param> /// <param name="bcc">bcc: address. Value null means not used.</param> /// <param name="subject">Message subject.</param> /// <param name="text">Message body text.</param> /// <param name="html">Message HTML text. Value null means not used.</param> /// <param name="attachments">Message attachments. Value null means not used.</param> /// <returns>Returns created mail message.</returns> public static Mail_Message Create(Mail_t_Mailbox from,Mail_t_Address[] to,Mail_t_Address[] cc,Mail_t_Address[] bcc,string subject,string text,string html,Mail_t_Attachment[] attachments) { // Create header. Mail_Message msg = new Mail_Message(); msg.MimeVersion = "1.0"; msg.MessageID = MIME_Utils.CreateMessageID(); msg.Date = DateTime.Now; if(from != null){ msg.From = new Mail_t_MailboxList(); msg.From.Add(from); } if(to != null){ msg.To = new Mail_t_AddressList(); foreach(Mail_t_Address address in to){ msg.To.Add(address); } } msg.Subject = subject; // Create message without attachments. if(attachments == null || attachments.Length == 0){ // text/plain if(string.IsNullOrEmpty(html)){ MIME_b_Text text_plain = new MIME_b_Text(MIME_MediaTypes.Text.plain); msg.Body = text_plain; text_plain.SetText(MIME_TransferEncodings.QuotedPrintable,Encoding.UTF8,text); } // multipart/alternative // text/plain // text/html else{ MIME_b_MultipartAlternative multipartAlternative = new MIME_b_MultipartAlternative(); msg.Body = multipartAlternative; multipartAlternative.BodyParts.Add(MIME_Entity.CreateEntity_Text_Plain(MIME_TransferEncodings.QuotedPrintable,Encoding.UTF8,text)); multipartAlternative.BodyParts.Add(MIME_Entity.CreateEntity_Text_Html(MIME_TransferEncodings.QuotedPrintable,Encoding.UTF8,html)); } } // Create message with attachments. else{ // multipart/mixed // text/plain // application/octet-stream if(string.IsNullOrEmpty(html)){ MIME_b_MultipartMixed multipartMixed = new MIME_b_MultipartMixed(); msg.Body = multipartMixed; multipartMixed.BodyParts.Add(MIME_Entity.CreateEntity_Text_Plain(MIME_TransferEncodings.QuotedPrintable,Encoding.UTF8,text)); // Add attachments. foreach(Mail_t_Attachment attachment in attachments){ try{ multipartMixed.BodyParts.Add(MIME_Entity.CreateEntity_Attachment(attachment.Name,attachment.GetStream())); } finally{ attachment.CloseStream(); } } } // multipart/mixed // multipart/alternative // text/plain // text/html // application/octet-stream else{ MIME_b_MultipartMixed multipartMixed = new MIME_b_MultipartMixed(); msg.Body = multipartMixed; MIME_Entity entity_multipart_alternative = new MIME_Entity(); MIME_b_MultipartAlternative multipartAlternative = new MIME_b_MultipartAlternative(); entity_multipart_alternative.Body = multipartAlternative; multipartMixed.BodyParts.Add(entity_multipart_alternative); multipartAlternative.BodyParts.Add(MIME_Entity.CreateEntity_Text_Plain(MIME_TransferEncodings.QuotedPrintable,Encoding.UTF8,text)); multipartAlternative.BodyParts.Add(MIME_Entity.CreateEntity_Text_Html(MIME_TransferEncodings.QuotedPrintable,Encoding.UTF8,html)); // Add attachments. foreach(Mail_t_Attachment attachment in attachments){ try{ multipartMixed.BodyParts.Add(MIME_Entity.CreateEntity_Attachment(attachment.Name,attachment.GetStream())); } finally{ attachment.CloseStream(); } } } } return msg; }
/// <summary> /// Creates mail message. /// </summary> /// <param name="signerCert">Signer certificate,</param> /// <param name="from">From: address.</param> /// <param name="to">To: address.</param> /// <param name="cc">Cc: address. Value null means not used.</param> /// <param name="bcc">bcc: address. Value null means not used.</param> /// <param name="subject">Message subject.</param> /// <param name="text">Message body text.</param> /// <param name="html">Message HTML text. Value null means not used.</param> /// <param name="attachments">Message attachments. Value null means not used.</param> /// <returns>Returns created mail message.</returns> /// <exception cref="ArgumentNullException">Is raised when <b>signerCert</b> is null reference.</exception> public static Mail_Message Create_MultipartSigned(X509Certificate2 signerCert,Mail_t_Mailbox from,Mail_t_Address[] to,Mail_t_Address[] cc,Mail_t_Address[] bcc,string subject,string text,string html,Mail_t_Attachment[] attachments) { if(signerCert == null){ throw new ArgumentNullException("signerCert"); } // Create header. Mail_Message msg = new Mail_Message(); msg.MimeVersion = "1.0"; msg.MessageID = MIME_Utils.CreateMessageID(); msg.Date = DateTime.Now; if(from != null){ msg.From = new Mail_t_MailboxList(); msg.From.Add(from); } if(to != null){ msg.To = new Mail_t_AddressList(); foreach(Mail_t_Address address in to){ msg.To.Add(address); } } msg.Subject = subject; // Create message without attachments. if(attachments == null || attachments.Length == 0){ // multipart/signed // text/plain // application/pkcs7-signature MIME library adds this when message saved out. if(string.IsNullOrEmpty(html)){ MIME_b_MultipartSigned multipartSigned = new MIME_b_MultipartSigned(); msg.Body = multipartSigned; multipartSigned.SetCertificate(signerCert); multipartSigned.BodyParts.Add(MIME_Entity.CreateEntity_Text_Plain(MIME_TransferEncodings.QuotedPrintable,Encoding.UTF8,text)); } // multipart/signed // multipart/alternative // text/plain // text/html // application/pkcs7-signature MIME library adds this when message saved out. else{ MIME_b_MultipartSigned multipartSigned = new MIME_b_MultipartSigned(); msg.Body = multipartSigned; multipartSigned.SetCertificate(signerCert); MIME_Entity entity_multipart_alternative = new MIME_Entity(); MIME_b_MultipartAlternative multipartAlternative = new MIME_b_MultipartAlternative(); entity_multipart_alternative.Body = multipartAlternative; multipartSigned.BodyParts.Add(entity_multipart_alternative); multipartAlternative.BodyParts.Add(MIME_Entity.CreateEntity_Text_Plain(MIME_TransferEncodings.QuotedPrintable,Encoding.UTF8,text)); multipartAlternative.BodyParts.Add(MIME_Entity.CreateEntity_Text_Html(MIME_TransferEncodings.QuotedPrintable,Encoding.UTF8,html)); } } // Create message with attachments. else{ // multipart/signed // multipart/mixed // text/plain // application/octet-stream // application/pkcs7-signature MIME library adds this when message saved out. if(string.IsNullOrEmpty(html)){ MIME_b_MultipartSigned multipartSigned = new MIME_b_MultipartSigned(); msg.Body = multipartSigned; multipartSigned.SetCertificate(signerCert); MIME_Entity entity_multipart_mixed = new MIME_Entity(); MIME_b_MultipartMixed multipartMixed = new MIME_b_MultipartMixed(); entity_multipart_mixed.Body = multipartMixed; multipartSigned.BodyParts.Add(entity_multipart_mixed); multipartMixed.BodyParts.Add(MIME_Entity.CreateEntity_Text_Plain(MIME_TransferEncodings.QuotedPrintable,Encoding.UTF8,text)); // Add attachments. foreach(Mail_t_Attachment attachment in attachments){ try{ multipartMixed.BodyParts.Add(MIME_Entity.CreateEntity_Attachment(attachment.Name,attachment.GetStream())); } finally{ attachment.CloseStream(); } } } // multipart/signed // multipart/mixed // multipart/alternative // text/plain // text/html // application/octet-stream // application/pkcs7-signature MIME library adds this when message saved out. else{ MIME_b_MultipartSigned multipartSigned = new MIME_b_MultipartSigned(); msg.Body = multipartSigned; multipartSigned.SetCertificate(signerCert); MIME_Entity entity_multipart_mixed = new MIME_Entity(); MIME_b_MultipartMixed multipartMixed = new MIME_b_MultipartMixed(); entity_multipart_mixed.Body = multipartMixed; multipartSigned.BodyParts.Add(entity_multipart_mixed); MIME_Entity entity_multipart_alternative = new MIME_Entity(); MIME_b_MultipartAlternative multipartAlternative = new MIME_b_MultipartAlternative(); entity_multipart_alternative.Body = multipartAlternative; multipartMixed.BodyParts.Add(entity_multipart_alternative); multipartAlternative.BodyParts.Add(MIME_Entity.CreateEntity_Text_Plain(MIME_TransferEncodings.QuotedPrintable,Encoding.UTF8,text)); multipartAlternative.BodyParts.Add(MIME_Entity.CreateEntity_Text_Html(MIME_TransferEncodings.QuotedPrintable,Encoding.UTF8,html)); // Add attachments. foreach(Mail_t_Attachment attachment in attachments){ try{ multipartMixed.BodyParts.Add(MIME_Entity.CreateEntity_Attachment(attachment.Name,attachment.GetStream())); } finally{ attachment.CloseStream(); } } } } return msg; }
public void TestMethod1() { try { Mime mime = Mime.Parse(@"C:\Users\sanghyuk\Desktop\messages\[사내] 신규 모바일 FPS _Gunpie Adventure_ OPEN!!!.eml"); Mail_Message message = Mail_Message.ParseFromFile(@"C:\Users\sanghyuk\Desktop\messages\[사내] 신규 모바일 FPS _Gunpie Adventure_ OPEN!!!.eml"); Guid guid = Guid.NewGuid(); string messageID = string.Format("<{0}@AutoGenerated.com>", guid.ToString().Split('-', '_')); message.MessageID = messageID; message.To.Clear(); Mail_t_Mailbox address = new Mail_t_Mailbox(string.Empty, "*****@*****.**"); message.To.Add(address); SMTP_Client client = new SMTP_Client(); SMTP_Client.QuickSendSmartHost("mail.nexon.co.kr", 25, false, message); } catch (Exception ex) { Assert.Fail(ex.Message); } }