DotNetCore.SKIT.FlurlHttpCl.../docs/WechatWork/Basic_Extensions.md

59 lines
2.0 KiB
Markdown
Raw Normal View History

2023-03-02 19:36:47 +08:00
## 如何自定义额外的 API 接口?
2021-07-27 20:26:41 +08:00
---
如果有某些接口本库尚未支持,你可按照下面的示例自行扩展:
```csharp
/* 继承 WechatWorkRequest 实现自定义请求类 */
public class MyFakeRequest : WechatWorkRequest
{
[Newtonsoft.Json.JsonProperty("my_fake_props")]
[System.Text.Json.Serialization.JsonPropertyName("my_fake_props")]
public string MyFakeProps { get; set; }
}
/* 继承 WechatWorkResponse 实现自定义响应类 */
public class MyFakeResponse : WechatWorkResponse
{
[Newtonsoft.Json.JsonProperty("my_fake_props")]
[System.Text.Json.Serialization.JsonPropertyName("my_fake_props")]
public string MyFakeProps { get; set; }
}
/* 扩展 WechatWorkClient 方法 */
public static class MyFakeClientExtensions
{
public static async Task<MyFakeResponse> ExecuteMyFakeAsync(this WechatWorkClient client, MyFakeRequest 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
2024-02-07 11:22:05 +08:00
.CreateFlurlRequest(request, HttpMethod.Post, "my-fake-url")
2021-07-27 20:26:41 +08:00
.SetQueryParam("access_token", request.AccessToken);
2024-02-07 11:22:05 +08:00
return await client.SendFlurlRequestAsJsonAsync<MyFakeResponse>(flurlReq, request, cancellationToken);
2021-07-27 20:26:41 +08:00
}
}
```
2021-11-25 21:15:54 +08:00
同样地,你也可自行扩展回调通知事件模型:
2021-07-27 20:26:41 +08:00
```csharp
/* 继承 WechatWorkEvent 实现自定义的 JSON 格式的回调通知事件 */
2024-02-07 11:22:05 +08:00
public class MyFakeEvent : WechatWorkEvent
2021-07-27 20:26:41 +08:00
{
[Newtonsoft.Json.JsonProperty("my_fake_props")]
[System.Text.Json.Serialization.JsonPropertyName("my_fake_props")]
public string MyFakeProps { get; set; }
}
/* 继承 WechatWorkEvent 实现自定义的 XML 格式的回调通知事件 */
2024-02-07 11:22:05 +08:00
public class MyFakeEvent : WechatWorkEvent
2021-07-27 20:26:41 +08:00
{
[System.Xml.Serialization.XmlElement("my_fake_props")]
public string MyFakeProps { get; set; }
}
```