// Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。 // // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。 // // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任! namespace Admin.NET.Plugin.DingTalk; public class DingTalkCreateAndDeliverInput { /// /// 卡片创建者的userId /// public string? userId { get; set; } /// /// 卡片内容模板ID /// [Required] public string cardTemplateId { get; set; } /// /// 外部卡片实例Id /// [Required] public string outTrackId { get; set; } /// /// 卡片回调的类型:STREAM:stream模式 HTTP:http模式 /// public string? callbackType { get; set; } /// /// 卡片回调HTTP模式时的路由 Key,用于查询注册的 callbackUrl。 /// public string? callbackRouteKey { get; set; } /// /// 卡片数据 /// [Required] public DingTalk_CardData cardData { get; set; } /// /// 用户的私有数据 /// public PrivateData? crivateData { get; set; } /// /// 动态数据源配置 /// public OpenDynamicDataConfig? openDynamicDataConfig { get; set; } /// /// IM单聊酷应用场域信息 /// public OpenSpaceModel? imSingleOpenSpaceModel { get; set; } /// /// IM群聊场域信息。 /// public OpenSpaceModel? imGroupOpenSpaceModel { get; set; } /// /// IM机器人单聊场域信息。 /// public OpenSpaceModel? imRobotOpenSpaceModel { get; set; } /// /// 协作场域信息 /// public OpenSpaceModel? coFeedOpenSpaceModel { get; set; } /// /// 吊顶场域信息 /// public OpenSpaceModel? topOpenSpaceModel { get; set; } /// /// 表示场域及其场域id /// /// /// 其格式为dtv1.card//spaceType1.spaceId1;spaceType2.spaceId2_1;spaceType2.spaceId2_2;spaceType3.spaceId3 /// [Required] public string openSpaceId { get; set; } /// /// 单聊酷应用场域投放参数。 /// public DingTalkOpenDeliverModel? imSingleOpenDeliverModel { get; set; } /// /// 群聊投放参数。 /// public DingTalkOpenDeliverModel? imGroupOpenDeliverModel { get; set; } /// /// IM机器人单聊投放参数。 /// public DingTalkOpenDeliverModel? imRobotOpenDeliverModel { get; set; } /// /// 吊顶投放参数。 /// public DingTalkOpenDeliverModel? topOpenDeliverModel { get; set; } /// /// 协作投放参数。 /// public DingTalkOpenDeliverModel? coFeedOpenDeliverModel { get; set; } /// /// 文档投放参数 /// public DingTalkOpenDeliverModel? docOpenDeliverModel { get; set; } /// /// 用户userId类型:1(默认):userId模式 2:unionId模式 /// public int UserIdType { get; set; } } public class DingTalk_CardData { public DingTalk_CardParamMap cardParamMap { get; set; } } /// /// 卡片模板内容替换参数 /// public class DingTalk_CardParamMap { /// /// 片模板内容替换参数 /// [Newtonsoft.Json.JsonProperty("sys_full_json_obj")] [System.Text.Json.Serialization.JsonPropertyName("sys_full_json_obj")] public string sysFullJsonObj { get; set; } } public class PrivateData { public Dictionary key { get; set; } = new Dictionary(); } public class OpenDynamicDataConfig { /// /// 动态数据源配置列表。 /// public List? dynamicDataSourceConfigs { get; set; } } public class DynamicDataSourceConfig { /// /// 数据源的唯一 ID, 调用方指定。 /// public string? dynamicDataSourceId { get; set; } /// /// 回调数据源时回传的固定参数。 示例 /// public Dictionary? constParams { get; set; } /// /// 数据源拉取配置。 /// public PullConfig? pullConfig { get; set; } } public class PullConfig { /// /// 拉取策略,可选值:NONE:不拉取,无动态数据 INTERVAL:间隔拉取ONCE:只拉取一次 /// public string pullStrategy { get; set; } /// /// 拉取的间隔时间。 /// public int interval { get; set; } /// /// 拉取的间隔时间的单位, 可选值:SECONDS:秒 MINUTES:分钟 HOURS:小时 DAYS:天 /// public string timeUnit { get; set; } } public class OpenSpaceModel { /// /// 吊顶场域属性,通过增加spaeType使卡片支持吊顶场域。 /// public string? spaceType { get; set; } /// /// 卡片标题。 /// public string? title { get; set; } /// /// 酷应用编码。 /// public string? coolAppCode { get; set; } /// /// 是否支持转发, 默认false。 /// public bool? supportForward { get; set; } /// /// 支持国际化的LastMessage。 /// public Dictionary? lastMessageI18n { get; set; } /// /// 支持卡片消息可被搜索字段。 /// public SearchSupport? searchSupport { get; set; } /// /// 通知信息。 /// public Notification? notification { get; set; } } public class SearchSupport { /// /// 类型的icon,供搜索展示使用。 /// public string searchIcon { get; set; } /// /// 卡片类型名。 /// public string searchTypeName { get; set; } /// /// 供消息展示与搜索的字段。 /// public string searchDesc { get; set; } } public class Notification { /// /// 供消息展示与搜索的字段。 /// public string alertContent { get; set; } /// /// 是否关闭推送通知:true:关闭 false:不关闭 /// public bool notificationOff { get; set; } } public class DingTalkOpenDeliverModel { /// /// 用于发送卡片的机器人编码。 /// public string robotCode { get; set; } /// /// 消息@人。格式:{"key":"value"}。key:用户的userId value:用户名 /// public Dictionary atUserIds { get; set; } /// /// 指定接收人的userId。 /// public List recipients { get; set; } /// /// 扩展字段,示例如下:{"key":"value"} /// public Dictionary extension { get; set; } /// /// IM机器人单聊若未设置其他投放属性,需设置spaeType为IM_ROBOT。 /// public string spaceType { get; set; } /// /// 过期时间戳。若使用topOpenDeliverModel对象,则该字段必填。 /// public long expiredTimeMillis { get; set; } /// /// 可以查看该吊顶卡片的userId。 /// public List userIds { get; set; } /// /// 可以查看该吊顶卡片的设备:android|ios|win|mac。 /// public List platforms { get; set; } /// /// 业务标识。 /// public string bizTag { get; set; } /// /// 协作场域下的排序时间。 /// public long gmtTimeLine { get; set; } /// /// 员工userId信息 /// public string userId { get; set; } }