diff --git a/src/SKIT.FlurlHttpClient.Wechat.Work/Extensions/WechatWorkClientExecuteCgibinUserExtensions.cs b/src/SKIT.FlurlHttpClient.Wechat.Work/Extensions/WechatWorkClientExecuteCgibinUserExtensions.cs index 9cac3e71..48a330ea 100644 --- a/src/SKIT.FlurlHttpClient.Wechat.Work/Extensions/WechatWorkClientExecuteCgibinUserExtensions.cs +++ b/src/SKIT.FlurlHttpClient.Wechat.Work/Extensions/WechatWorkClientExecuteCgibinUserExtensions.cs @@ -354,5 +354,27 @@ namespace SKIT.FlurlHttpClient.Wechat.Work return await client.SendRequestWithJsonAsync(flurlReq, cancellationToken: cancellationToken); } #endregion + + /// + /// 异步调用 [GET] /cgi-bin/user/list_selected_ticket_user 接口。 + /// REF: https://work.weixin.qq.com/api/doc/90001/90143/94894 + /// + /// + /// + /// + /// + public static async Task ExecuteCgibinUserListSelectedTicketUserAsync(this WechatWorkClient client, Models.CgibinUserListSelectedTicketUserRequest 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.Get, "cgi-bin", "user", "list_selected_ticket_user") + .SetQueryParam("access_token", request.AccessToken) + .SetQueryParam("selected_ticket", request.SelectedTicket); + + return await client.SendRequestWithJsonAsync(flurlReq, cancellationToken: cancellationToken); + } + } } diff --git a/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinUser/CgibinUserListSelectedTicketUserRequest.cs b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinUser/CgibinUserListSelectedTicketUserRequest.cs new file mode 100644 index 00000000..1aad5ba7 --- /dev/null +++ b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinUser/CgibinUserListSelectedTicketUserRequest.cs @@ -0,0 +1,18 @@ +using System; +using System.Collections.Generic; + +namespace SKIT.FlurlHttpClient.Wechat.Work.Models +{ + /// + /// 表示 [GET] /cgi-bin/user/list_selected_ticket_user 接口的请求。 + /// + public class CgibinUserListSelectedTicketUserRequest : WechatWorkRequest + { + /// + /// 获取或设置选人 JSAPI 返回的 SelectedTicket。 + /// + [Newtonsoft.Json.JsonIgnore] + [System.Text.Json.Serialization.JsonIgnore] + public string SelectedTicket { get; set; } = string.Empty; + } +} diff --git a/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinUser/CgibinUserListSelectedTicketUserResponse.cs b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinUser/CgibinUserListSelectedTicketUserResponse.cs new file mode 100644 index 00000000..c2018395 --- /dev/null +++ b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinUser/CgibinUserListSelectedTicketUserResponse.cs @@ -0,0 +1,39 @@ +using System; +using System.Collections.Generic; + +namespace SKIT.FlurlHttpClient.Wechat.Work.Models +{ + /// + /// 表示 [GET] /cgi-bin/user/list_selected_ticket_user 接口的响应。 + /// + public class CgibinUserListSelectedTicketUserResponse : WechatWorkResponse + { + /// + /// 获取或设置选人用户的 OpenUserId。 + /// + [Newtonsoft.Json.JsonProperty("operator_open_userid")] + [System.Text.Json.Serialization.JsonPropertyName("operator_open_userid")] + public string OperatorOpenUserId { get; set; } = default!; + + /// + /// 获取或设置应用可见范围内用户 OpenUserId 列表。 + /// + [Newtonsoft.Json.JsonProperty("open_userid_list")] + [System.Text.Json.Serialization.JsonPropertyName("open_userid_list")] + public string[] OpenUserIdList { get; set; } = default!; + + /// + /// 获取或设置未授权应用的用户 OpenUserId 列表。 + /// + [Newtonsoft.Json.JsonProperty("unauth_open_userid_list")] + [System.Text.Json.Serialization.JsonPropertyName("unauth_open_userid_list")] + public string[]? UnauthOpenUserIdList { get; set; } + + /// + /// 获取或设置用户选择的总人数。 + /// + [Newtonsoft.Json.JsonProperty("total")] + [System.Text.Json.Serialization.JsonPropertyName("total")] + public int TotalCount { get; set; } + } +}