diff --git a/src/SKIT.FlurlHttpClient.Wechat.Work/Extensions/WechatWorkClientExecuteCgibinExmailExtensions.cs b/src/SKIT.FlurlHttpClient.Wechat.Work/Extensions/WechatWorkClientExecuteCgibinExmailExtensions.cs index 6394b02d..25f37d38 100644 --- a/src/SKIT.FlurlHttpClient.Wechat.Work/Extensions/WechatWorkClientExecuteCgibinExmailExtensions.cs +++ b/src/SKIT.FlurlHttpClient.Wechat.Work/Extensions/WechatWorkClientExecuteCgibinExmailExtensions.cs @@ -285,5 +285,27 @@ namespace SKIT.FlurlHttpClient.Wechat.Work return await client.SendRequestWithJsonAsync(flurlReq, data: request, cancellationToken: cancellationToken); } #endregion + + #region Mail + /// + /// 异步调用 [POST] /cgi-bin/exmail/mail/get_newcount 接口。 + /// REF: https://developer.work.weixin.qq.com/document/path/95514 + /// + /// + /// + /// + /// + public static async Task ExecuteCgibinExmailMailGetNewCountAsync(this WechatWorkClient client, Models.CgibinExmailMailGetNewCountRequest request, CancellationToken cancellationToken = default) + { + if (client is null) throw new ArgumentNullException(nameof(client)); + if (request is null) throw new ArgumentNullException(nameof(request)); + + IFlurlRequest flurlReq = client + .CreateRequest(request, HttpMethod.Post, "cgi-bin", "exmail", "mail", "get_newcount") + .SetQueryParam("access_token", request.AccessToken); + + return await client.SendRequestWithJsonAsync(flurlReq, data: request, cancellationToken: cancellationToken); + } + #endregion } } diff --git a/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinExmail/Mail/CgibinExmailMailGetNewCountRequest.cs b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinExmail/Mail/CgibinExmailMailGetNewCountRequest.cs new file mode 100644 index 00000000..0698d898 --- /dev/null +++ b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinExmail/Mail/CgibinExmailMailGetNewCountRequest.cs @@ -0,0 +1,15 @@ +namespace SKIT.FlurlHttpClient.Wechat.Work.Models +{ + /// + /// 表示 [POST] /cgi-bin/exmail/mail/get_newcount 接口的请求。 + /// + public class CgibinExmailMailGetNewCountRequest : WechatWorkRequest + { + /// + /// 获取或设置成员账号。 + /// + [Newtonsoft.Json.JsonProperty("userid")] + [System.Text.Json.Serialization.JsonPropertyName("userid")] + public string UserId { get; set; } = string.Empty; + } +} diff --git a/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinExmail/Mail/CgibinExmailMailGetNewCountResponse.cs b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinExmail/Mail/CgibinExmailMailGetNewCountResponse.cs new file mode 100644 index 00000000..267b46b6 --- /dev/null +++ b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinExmail/Mail/CgibinExmailMailGetNewCountResponse.cs @@ -0,0 +1,15 @@ +namespace SKIT.FlurlHttpClient.Wechat.Work.Models +{ + /// + /// 表示 [POST] /cgi-bin/exmail/mail/get_newcount 接口的响应。 + /// + public class CgibinExmailMailGetNewCountResponse : WechatWorkResponse + { + /// + /// 获取或设置新邮件数。 + /// + [Newtonsoft.Json.JsonProperty("count")] + [System.Text.Json.Serialization.JsonPropertyName("count")] + public int NewCount { get; set; } + } +} diff --git a/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinExmail/Mail/CgibinExmailMailGetNewCountRequest.json b/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinExmail/Mail/CgibinExmailMailGetNewCountRequest.json new file mode 100644 index 00000000..294a2828 --- /dev/null +++ b/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinExmail/Mail/CgibinExmailMailGetNewCountRequest.json @@ -0,0 +1,3 @@ +{ + "userid": "member" +} diff --git a/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinExmail/Mail/CgibinExmailMailGetNewCountResponse.json b/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinExmail/Mail/CgibinExmailMailGetNewCountResponse.json new file mode 100644 index 00000000..66d6b2b3 --- /dev/null +++ b/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinExmail/Mail/CgibinExmailMailGetNewCountResponse.json @@ -0,0 +1,5 @@ +{ + "errcode": 0, + "errmsg": "ok", + "count": 1 +}