using System;

    using Microsoft.Xrm.Sdk;

    using Microsoft.Crm.Sdk.Messages;

    using Microsoft.Xrm.Sdk.Query;

/// <summary>

    /// 电子邮件

    /// </summary>

    public class EmailHelper

    {

        public static readonly string entityName = "email";

        public Guid emailId = Guid.Empty;

        public IOrganizationService service;

/// <summary>

        /// 创建电子邮件

        /// </summary>

        public void Create()

        {

            Entity en = new Entity();

            en["subject"] = "电子邮件測试";

            en["activityId"] = Guid.NewGuid();

            emailId = service.Create(en);

        }

/// <summary>

        /// 异步发送电子邮件

        /// </summary>

        /// <param name="query">查询的条件</param>

        public void BackgroundSendEmail(QueryBase query)

        {

            BackgroundSendEmailRequest request = new BackgroundSendEmailRequest();

            request.Query = query;

            BackgroundSendEmailResponse response = (BackgroundSendEmailResponse)service.Execute(request);

            EntityCollection entityCollection = response.EntityCollection;

            bool[] hasAttachments = response.HasAttachments;

        }

/// <summary>

        /// 检查是否应该将传入电子邮件提升到 Microsoft Dynamics CRM 系统

        /// </summary>

        /// <param name="messageId">消息id</param>

        /// <param name="subject">主题</param>

        public void CheckPromoteEmail(string messageId,string subject)

        {

            CheckPromoteEmailRequest request = new CheckPromoteEmailRequest();

            request.MessageId = messageId;

            request.Subject = subject;

            CheckIncomingEmailResponse response = (CheckIncomingEmailResponse)service.Execute(request);

            int reasonCode = response.ReasonCode;

            bool shouldDeliver = response.ShouldDeliver;

        }

/// <summary>

        /// 发送批量电子邮件

        /// </summary>

        /// <param name="query">查询的条件</param>

        /// <param name="templateId">模版id</param>

        public void SendBulkMail(QueryBase query,Guid templateId)

        {

            WhoAmIRequest emailSenderRequest = new WhoAmIRequest();

            WhoAmIResponse emailSenderResponse = service.Execute(emailSenderRequest) as WhoAmIResponse;

            SendBulkMailRequest request = new SendBulkMailRequest();

            request.Query = query;

            request.Sender = new EntityReference() { LogicalName = "systemuser", Id = emailSenderResponse.UserId };

            request.RequestId = Guid.Empty;

            request.RegardingType = "systemuser";

            request.TemplateId = templateId;

            SendBulkMailResponse response = (SendBulkMailResponse)service.Execute(request);

        }

/// <summary>

        /// 使用模板发送电子邮件

        /// </summary>

        /// <param name="userId">发送人。用户id</param>

        /// <param name="contractId">接收人,联系人id</param>

        /// <param name="templateId">模版id</param>

        public void SendEmailFromTemplate(Guid userId, Guid contractId, Guid templateId)


        {

            Entity fromEn = new Entity() { LogicalName = "systemuser",Id = userId };

            Entity toEn = new Entity() { LogicalName = "contract", Id = contractId };

            Entity emailEn = new Entity() { LogicalName = entityName };

            emailEn["from"] = new Entity[] { fromEn };

            emailEn["to"] = new Entity[] { toEn };

            emailEn["subject"] = "电子邮件发送測试";

            emailEn["directioncode"] = true;

            SendEmailFromTemplateRequest request = new SendEmailFromTemplateRequest();

            request.Target = emailEn;

            request.TemplateId = templateId;

            request.RegardingId = contractId;

            request.RegardingType = "contract";

            SendEmailFromTemplateResponse response = (SendEmailFromTemplateResponse)service.Execute(request);

            Guid id = response.Id;

        }

/// <summary>

        /// 发送电子邮件

        /// </summary>

        public void SendEmail()

        {

            SendEmailRequest request = new SendEmailRequest();

            request.EmailId = emailId;

            request.IssueSend = true;

            request.TrackingToken = "";

            SendEmailResponse response = (SendEmailResponse)service.Execute(request);

            string subject = response.Subject;

        }

/// <summary>

        /// 获取用于对存储在 Microsoft Dynamics CRM 数据库中的用户或队列的电子邮件凭据进行加密或解密的密钥

        /// </summary>

        public void GetDecryptionKey()

        {

            GetDecryptionKeyRequest request = new GetDecryptionKeyRequest();

            GetDecryptionKeyResponse response = (GetDecryptionKeyResponse)service.Execute(request);

            string key = response.Key;

        }

/// <summary>

        /// 删除电子邮件

        /// </summary>

        public void Delete()

        {

            service.Delete(entityName, emailId);

        }

    }

crm操作电子邮件的更多相关文章

  1. crm操作业务部门

    using System;     using System.Linq;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messag ...

  2. crm操作货币实体

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messages; /// <summary> ...

  3. crm操作权限

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Xrm.Sdk.Query;     using System.Colle ...

  4. crm操作知识库文章实体

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messages;     using Microsoft ...

  5. crm操作观点

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messages; /// <summary> ...

  6. crm操作安全角色

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messages;     using System.Co ...

  7. crm操作产品实体

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messages; /// <summary> ...

  8. crm操作销售订单实体

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Xrm.Sdk.Query;     using Microsoft.Cr ...

  9. crm操作约会实体

    using System;     using Microsoft.Xrm.Sdk;     using Microsoft.Crm.Sdk.Messages;     using Microsoft ...

随机推荐

  1. 二分求幂 - A^B(王道*)

    题目描述: 求A^B的最后三位数表示的整数,说明:A^B的含义是“A的B次方” 输入: 输入数据包含多个测试实例,每个实例占一行,由两个正整数A和B组成(1<=A,B<=10000),如果 ...

  2. javascript 递归函数调用(recursive funciton call)

    所谓的递归函数调用,就是自己调用自己的函数. var timerHandler = null; function a(){ console.log(123); timerHandler = setTi ...

  3. Mycat探索之旅(4)----Mycat的自增长主键和返回生成主键ID的实现

    说明:MyCAT自增长主键和返回生成主键ID的实现 1) mysql本身对非自增长主键,使用last_insert_id()是不会返回结果的,只会返回0:这里做一个简单的测试 创建测试表 ------ ...

  4. Ubuntu(Debian)的aptitude与apt-get的区别和联系

    Ubuntu(Debian)的aptitude与apt-get的区别和联系 aptitude 与 apt-get 一样,是 Debian 及其衍生系统中功能极其强大的包管理工具.与 apt-get 不 ...

  5. Java: 获取当前执行位置的文件名/类名/方法名/行号

    在 JAVA 程序有时需要获取当前代码位置, 于是就利用 Thread.currentThread().getStackTrace() 写了下面这个工具类, 用来获取当前执行位置处代码的文件名/类名/ ...

  6. JavaScript | 对象与属性

    ———————————————————————————————————————————— 对象:JavaScript是基于原型的语言,没有Class,所以将函数作为类 - - - - - - - - ...

  7. JDK自带监控工具 jps、jinfo、jstat、jmap、jconsole

    分类: JVM 2010-10-04 11:05 587人阅读 评论(0) 收藏 举报 工具jdkjava远程连接unixstring 常用有五个命令行工具: jinfo: 可以输出并修改运行时的ja ...

  8. php中在局部作用域内访问全局变量

    php中,由于作用域的限制,导致变量的访问限制: 1.局部作用域内不能访问全局变量 2.全局作用域内不能访问局部变量 对于第一种情况,如下代码将不能正常运行: <?php //局部作用域(函数内 ...

  9. mysql select *... where id in (select 字符串 from ... )查询结果问题?

    SQL中的写法为 ); 查询结果为: id TypeName 1 新手 2 手机 在MYSQL中 ); 查询结果为: id TypeName 1 新手 少了一条数据. 其中 查询结果为 Newcard ...

  10. 【Linux指标】内存篇

    1:内存使用率 指标名称 指标含义 单位 采集方式(Linux) 采集方式(Windows) AGT.可用内存 GB 通过/proc/meminfo得到MemAvailable;若/proc/memi ...