From e8cc4a5f56dc5e75dd4dabb05f4e32048edafc1b Mon Sep 17 00:00:00 2001 From: Fu Diwei Date: Tue, 25 Oct 2022 19:21:12 +0800 Subject: [PATCH] =?UTF-8?q?feat(work):=20=E6=96=B0=E5=A2=9E=20OA=20?= =?UTF-8?q?=E5=AF=BC=E5=87=BA=E6=B1=87=E6=8A=A5=E6=96=87=E6=A1=A3=E6=8E=A5?= =?UTF-8?q?=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...chatWorkClientExecuteCgibinOAExtensions.cs | 42 ++++++++++++++++++- .../CgibinOAJournalExportDocumentRequest.cs | 22 ++++++++++ .../CgibinOAJournalExportDocumentResponse.cs | 15 +++++++ ...OAJournalGetExportDocumentResultRequest.cs | 15 +++++++ ...AJournalGetExportDocumentResultResponse.cs | 22 ++++++++++ .../CgibinOAJournalExportDocumentRequest.json | 4 ++ ...CgibinOAJournalExportDocumentResponse.json | 5 +++ ...JournalGetExportDocumentResultRequest.json | 3 ++ ...ournalGetExportDocumentResultResponse.json | 6 +++ 9 files changed, 133 insertions(+), 1 deletion(-) create mode 100644 src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalExportDocumentRequest.cs create mode 100644 src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalExportDocumentResponse.cs create mode 100644 src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultRequest.cs create mode 100644 src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultResponse.cs create mode 100644 test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalExportDocumentRequest.json create mode 100644 test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalExportDocumentResponse.json create mode 100644 test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultRequest.json create mode 100644 test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultResponse.json diff --git a/src/SKIT.FlurlHttpClient.Wechat.Work/Extensions/WechatWorkClientExecuteCgibinOAExtensions.cs b/src/SKIT.FlurlHttpClient.Wechat.Work/Extensions/WechatWorkClientExecuteCgibinOAExtensions.cs index f5e2a43f..6e75a88c 100644 --- a/src/SKIT.FlurlHttpClient.Wechat.Work/Extensions/WechatWorkClientExecuteCgibinOAExtensions.cs +++ b/src/SKIT.FlurlHttpClient.Wechat.Work/Extensions/WechatWorkClientExecuteCgibinOAExtensions.cs @@ -1,4 +1,4 @@ -using System; +using System; using System.Net.Http; using System.Threading; using System.Threading.Tasks; @@ -240,6 +240,46 @@ namespace SKIT.FlurlHttpClient.Wechat.Work return await client.SendRequestWithJsonAsync(flurlReq, data: request, cancellationToken: cancellationToken); } + + /// + /// 异步调用 [POST] /cgi-bin/oa/journal/export_doc 接口。 + /// REF: https://developer.work.weixin.qq.com/document/path/96108 + /// + /// + /// + /// + /// + public static async Task ExecuteCgibinOAJournalExportDocumentAsync(this WechatWorkClient client, Models.CgibinOAJournalExportDocumentRequest 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", "oa", "journal", "export_doc") + .SetQueryParam("access_token", request.AccessToken); + + return await client.SendRequestWithJsonAsync(flurlReq, data: request, cancellationToken: cancellationToken); + } + + /// + /// 异步调用 [POST] /cgi-bin/oa/journal/get_export_doc_result 接口。 + /// REF: https://developer.work.weixin.qq.com/document/path/96108 + /// + /// + /// + /// + /// + public static async Task ExecuteCgibinOAJournalGetExportDocumentResultAsync(this WechatWorkClient client, Models.CgibinOAJournalGetExportDocumentResultRequest 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", "oa", "journal", "get_export_doc_result") + .SetQueryParam("access_token", request.AccessToken); + + return await client.SendRequestWithJsonAsync(flurlReq, data: request, cancellationToken: cancellationToken); + } #endregion #region MeetingRoom diff --git a/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalExportDocumentRequest.cs b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalExportDocumentRequest.cs new file mode 100644 index 00000000..589442a2 --- /dev/null +++ b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalExportDocumentRequest.cs @@ -0,0 +1,22 @@ +namespace SKIT.FlurlHttpClient.Wechat.Work.Models +{ + /// + /// 表示 [POST] /cgi-bin/oa/journal/export_doc 接口的请求。 + /// + public class CgibinOAJournalExportDocumentRequest : WechatWorkRequest + { + /// + /// 获取或设置汇报 UUID。 + /// + [Newtonsoft.Json.JsonProperty("journaluuid")] + [System.Text.Json.Serialization.JsonPropertyName("journaluuid")] + public string JournalId { get; set; } = string.Empty; + + /// + /// 获取或设置文档 ID。 + /// + [Newtonsoft.Json.JsonProperty("docid")] + [System.Text.Json.Serialization.JsonPropertyName("docid")] + public string DocumentId { get; set; } = string.Empty; + } +} diff --git a/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalExportDocumentResponse.cs b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalExportDocumentResponse.cs new file mode 100644 index 00000000..d71f71f6 --- /dev/null +++ b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalExportDocumentResponse.cs @@ -0,0 +1,15 @@ +namespace SKIT.FlurlHttpClient.Wechat.Work.Models +{ + /// + /// 表示 [POST] /cgi-bin/oa/journal/export_doc 接口的响应。 + /// + public class CgibinOAJournalExportDocumentResponse : WechatWorkResponse + { + /// + /// 获取或设置导出任务 ID。 + /// + [Newtonsoft.Json.JsonProperty("jobid")] + [System.Text.Json.Serialization.JsonPropertyName("jobid")] + public string JobId { get; set; } = default!; + } +} diff --git a/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultRequest.cs b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultRequest.cs new file mode 100644 index 00000000..d7ec9f74 --- /dev/null +++ b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultRequest.cs @@ -0,0 +1,15 @@ +namespace SKIT.FlurlHttpClient.Wechat.Work.Models +{ + /// + /// 表示 [POST] /cgi-bin/oa/journal/get_export_doc_result 接口的请求。 + /// + public class CgibinOAJournalGetExportDocumentResultRequest : WechatWorkRequest + { + /// + /// 获取或设置导出任务 ID。 + /// + [Newtonsoft.Json.JsonProperty("jobid")] + [System.Text.Json.Serialization.JsonPropertyName("jobid")] + public string JobId { get; set; } = string.Empty; + } +} diff --git a/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultResponse.cs b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultResponse.cs new file mode 100644 index 00000000..9b831ada --- /dev/null +++ b/src/SKIT.FlurlHttpClient.Wechat.Work/Models/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultResponse.cs @@ -0,0 +1,22 @@ +namespace SKIT.FlurlHttpClient.Wechat.Work.Models +{ + /// + /// 表示 [POST] /cgi-bin/oa/journal/get_export_doc_result 接口的响应。 + /// + public class CgibinOAJournalGetExportDocumentResultResponse : WechatWorkResponse + { + /// + /// 获取或设置任务状态。 + /// + [Newtonsoft.Json.JsonProperty("status")] + [System.Text.Json.Serialization.JsonPropertyName("status")] + public int Status { get; set; } + + /// + /// 获取或设置文档临时下载链接。 + /// + [Newtonsoft.Json.JsonProperty("url")] + [System.Text.Json.Serialization.JsonPropertyName("url")] + public string? Url { get; set; } + } +} diff --git a/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalExportDocumentRequest.json b/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalExportDocumentRequest.json new file mode 100644 index 00000000..a48b69ca --- /dev/null +++ b/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalExportDocumentRequest.json @@ -0,0 +1,4 @@ +{ + "journaluuid": "JOURNAL_UUID", + "docid": "DOCID" +} diff --git a/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalExportDocumentResponse.json b/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalExportDocumentResponse.json new file mode 100644 index 00000000..3ae7240d --- /dev/null +++ b/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalExportDocumentResponse.json @@ -0,0 +1,5 @@ +{ + "errcode": 0, + "errmsg": "ok", + "jobid": "JOBID" +} diff --git a/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultRequest.json b/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultRequest.json new file mode 100644 index 00000000..ea8ec7e8 --- /dev/null +++ b/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultRequest.json @@ -0,0 +1,3 @@ +{ + "jobid": "JOBID" +} diff --git a/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultResponse.json b/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultResponse.json new file mode 100644 index 00000000..3df4a187 --- /dev/null +++ b/test/SKIT.FlurlHttpClient.Wechat.Work.UnitTests/ModelSamples/CgibinOA/Journal/CgibinOAJournalGetExportDocumentResultResponse.json @@ -0,0 +1,6 @@ +{ + "errcode": 0, + "errmsg": "ok", + "status": 2, + "url": "URL" +}