-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* refactor: use interface in logger in Messages.cs * chore: disable CS1570 in GetDeliveryReportResponse.cs * feat: implement Webhooks create delete update list get * fix: remove ClientSecret from ToString of ClientCredentials.cs
- Loading branch information
Showing
10 changed files
with
549 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
using System.Text; | ||
|
||
namespace Sinch.Conversation.Webhooks | ||
{ | ||
/// <summary> | ||
/// Optional. Used for OAuth2 authentication. | ||
/// </summary> | ||
public sealed class ClientCredentials | ||
{ | ||
/// <summary> | ||
/// The Client ID that will be used in the OAuth2 Client Credentials flow. | ||
/// </summary> | ||
#if NET7_0_OR_GREATER | ||
public required string ClientId { get; set; } | ||
#else | ||
public string ClientId { get; set; } | ||
#endif | ||
|
||
|
||
/// <summary> | ||
/// The Client Secret that will be used in the OAuth2 Client Credentials flow. | ||
/// </summary> | ||
#if NET7_0_OR_GREATER | ||
public required string ClientSecret { get; set; } | ||
#else | ||
public string ClientSecret { get; set; } | ||
#endif | ||
|
||
|
||
/// <summary> | ||
/// The endpoint that will be used in the OAuth2 Client Credentials flow. Expected to return a JSON with an access | ||
/// token and `expires_in` value (in seconds). The `expires_in` value, which must be a minimum of | ||
/// 30 seconds and a maximum of 3600 seconds, is how long Sinch will save the access token before asking for a new one. | ||
/// </summary> | ||
#if NET7_0_OR_GREATER | ||
public required string Endpoint { get; set; } | ||
#else | ||
public string Endpoint { get; set; } | ||
#endif | ||
|
||
|
||
/// <summary> | ||
/// Returns the string presentation of the object | ||
/// </summary> | ||
/// <returns>String presentation of the object</returns> | ||
public override string ToString() | ||
{ | ||
var sb = new StringBuilder(); | ||
sb.Append("class ClientCredentials {\n"); | ||
sb.Append(" ClientId: ").Append(ClientId).Append("\n"); | ||
sb.Append(" Endpoint: ").Append(Endpoint).Append("\n"); | ||
sb.Append("}\n"); | ||
return sb.ToString(); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,145 @@ | ||
using System.Collections.Generic; | ||
using System.Text; | ||
using Sinch.Core; | ||
|
||
namespace Sinch.Conversation.Webhooks | ||
{ | ||
/// <summary> | ||
/// Represents a destination for receiving callbacks from the Conversation API. | ||
/// </summary> | ||
public class Webhook : PropertyMaskQuery | ||
{ | ||
private WebhookTargetType _targetType; | ||
private string _appId; | ||
private ClientCredentials _clientCredentials; | ||
private string _id; | ||
private string _secret; | ||
private string _target; | ||
private List<WebhookTrigger> _triggers; | ||
|
||
/// <summary> | ||
/// Gets or sets the target type. | ||
/// </summary> | ||
public WebhookTargetType TargetType | ||
{ | ||
get => _targetType; | ||
set | ||
{ | ||
SetFields.Add(nameof(TargetType)); | ||
_targetType = value; | ||
} | ||
} | ||
|
||
/// <summary> | ||
/// The app that this webhook belongs to. | ||
/// </summary> | ||
#if NET7_0_OR_GREATER | ||
public required string AppId | ||
#else | ||
public string AppId | ||
#endif | ||
{ | ||
get => _appId; | ||
set | ||
{ | ||
SetFields.Add(nameof(AppId)); | ||
_appId = value; | ||
} | ||
} | ||
|
||
/// <summary> | ||
/// Gets or sets the client credentials. | ||
/// </summary> | ||
public ClientCredentials ClientCredentials | ||
{ | ||
get => _clientCredentials; | ||
set | ||
{ | ||
SetFields.Add(nameof(ClientCredentials)); | ||
_clientCredentials = value; | ||
} | ||
} | ||
|
||
/// <summary> | ||
/// Gets or sets the ID of the webhook. | ||
/// </summary> | ||
public string Id | ||
{ | ||
get => _id; | ||
set | ||
{ | ||
SetFields.Add(nameof(Id)); | ||
_id = value; | ||
} | ||
} | ||
|
||
/// <summary> | ||
/// Optional secret to be used to sign contents of webhooks sent by the Conversation API. | ||
/// You can then use the secret to verify the signature. | ||
/// </summary> | ||
public string Secret | ||
{ | ||
get => _secret; | ||
set | ||
{ | ||
SetFields.Add(nameof(Secret)); | ||
_secret = value; | ||
} | ||
} | ||
|
||
/// <summary> | ||
/// Gets or sets the target URL where events should be sent to. | ||
/// Maximum URL length is 742. The conversation-api.*.sinch.com subdomains are forbidden. | ||
/// </summary> | ||
#if NET7_0_OR_GREATER | ||
public required string Target | ||
#else | ||
public string Target | ||
#endif | ||
{ | ||
get => _target; | ||
set | ||
{ | ||
SetFields.Add(nameof(Target)); | ||
_target = value; | ||
} | ||
} | ||
|
||
/// <summary> | ||
/// An array of triggers that should trigger the webhook and result in an event being sent to the target URL. | ||
/// Refer to the list of [Webhook Triggers](https://developers.sinch.com/docs/conversation/callbacks#webhook-triggers) | ||
/// for a complete list. | ||
/// </summary> | ||
#if NET7_0_OR_GREATER | ||
public required List<WebhookTrigger> Triggers | ||
#else | ||
public List<WebhookTrigger> Triggers | ||
#endif | ||
{ | ||
get => _triggers; | ||
set | ||
{ | ||
SetFields.Add(nameof(Triggers)); | ||
_triggers = value; | ||
} | ||
} | ||
|
||
/// <summary> | ||
/// Returns the string presentation of the object. | ||
/// </summary> | ||
/// <returns>String presentation of the object.</returns> | ||
public override string ToString() | ||
{ | ||
var sb = new StringBuilder(); | ||
sb.Append("class Webhook {\n"); | ||
sb.Append(" AppId: ").Append(AppId).Append("\n"); | ||
sb.Append(" ClientCredentials: ").Append(ClientCredentials).Append("\n"); | ||
sb.Append(" Id: ").Append(Id).Append("\n"); | ||
sb.Append(" Target: ").Append(Target).Append("\n"); | ||
sb.Append(" TargetType: ").Append(TargetType).Append("\n"); | ||
sb.Append(" Triggers: ").Append(Triggers).Append("\n"); | ||
sb.Append("}\n"); | ||
return sb.ToString(); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
using System.Text.Json.Serialization; | ||
using Sinch.Core; | ||
|
||
namespace Sinch.Conversation.Webhooks | ||
{ | ||
/// <summary> | ||
/// Defines WebhookTargetType | ||
/// </summary> | ||
[JsonConverter(typeof(EnumRecordJsonConverter<WebhookTargetType>))] | ||
public record WebhookTargetType(string Value) : EnumRecord(Value) | ||
{ | ||
public static readonly WebhookTargetType Dismiss = new("DISMISS"); | ||
public static readonly WebhookTargetType Http = new("HTTP"); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,55 @@ | ||
using System.Text.Json.Serialization; | ||
using Sinch.Core; | ||
|
||
namespace Sinch.Conversation.Webhooks | ||
{ | ||
/// <summary> | ||
/// - `UNSPECIFIED_TRIGGER`: Using this value will cause errors. - `MESSAGE_DELIVERY`: Subscribe to | ||
/// delivery receipts for a message sent. - `MESSAGE_SUBMIT`: Subscribe to message submission notifications. | ||
/// - `EVENT_DELIVERY`: Subscribe to delivery receipts for a event sent. - `MESSAGE_INBOUND`: | ||
/// Subscribe to inbound messages from end users on the underlying channels. - `SMART_CONVERSATION`: These | ||
/// triggers allow you to subscribe to payloads that provide machine learning analyses of inbound messages from end | ||
/// users on the underlying channels - `MESSAGE_INBOUND_SMART_CONVERSATION_REDACTION`: These triggers allow | ||
/// you to subscribe to payloads that deliver redacted versions of inbound messages - `EVENT_INBOUND`: | ||
/// Subscribe to inbound events from end users on the underlying channels. - `CONVERSATION_START`: Subscribe | ||
/// to an event that is triggered when a new conversation has been started. - `CONVERSATION_STOP`: Subscribe | ||
/// to an event that is triggered when an active conversation has been stopped. - `CONTACT_CREATE`: Subscribe | ||
/// to an event that is triggered when a new contact has been created. - `CONTACT_DELETE`: Subscribe to an | ||
/// event that is triggered when a contact has been deleted. - `CONTACT_MERGE`: Subscribe to an event that is | ||
/// triggered when two contacts are merged. - `CONTACT_UPDATE`: Subscribe to an event that is triggered when | ||
/// a contact is updated. - `UNSUPPORTED`: Subscribe to callbacks that are not natively supported by the | ||
/// Conversation API. - `OPT_IN`: Subscribe to opt_ins. - `OPT_OUT`: Subscribe to opt_outs. - | ||
/// `CAPABILITY`: Subscribe to see get capability results. - `CHANNEL_EVENT`: Subscribe to channel | ||
/// event notifications. - `CONVERSATION_DELETE`: Subscribe to get an event when a conversation is deleted. - | ||
/// `CONTACT_IDENTITIES_DUPLICATION`: Subscribe to get an event when contact identity duplications are found | ||
/// during message or event processing. - `SMART_CONVERSATIONS`: Subscribe to smart conversations callback | ||
/// </summary> | ||
[JsonConverter(typeof(EnumRecordJsonConverter<WebhookTrigger>))] | ||
public record WebhookTrigger(string Value) : EnumRecord(Value) | ||
{ | ||
public static readonly WebhookTrigger UnspecifiedTrigger = new("UNSPECIFIED_TRIGGER"); | ||
public static readonly WebhookTrigger MessageDelivery = new("MESSAGE_DELIVERY"); | ||
public static readonly WebhookTrigger MessageSubmit = new("MESSAGE_SUBMIT"); | ||
public static readonly WebhookTrigger EventDelivery = new("EVENT_DELIVERY"); | ||
public static readonly WebhookTrigger MessageInbound = new("MESSAGE_INBOUND"); | ||
public static readonly WebhookTrigger SmartConversation = new("SMART_CONVERSATION"); | ||
|
||
public static readonly WebhookTrigger MessageInboundSmartConversationRedaction = | ||
new("MESSAGE_INBOUND_SMART_CONVERSATION_REDACTION"); | ||
|
||
public static readonly WebhookTrigger EventInbound = new("EVENT_INBOUND"); | ||
public static readonly WebhookTrigger ConversationStart = new("CONVERSATION_START"); | ||
public static readonly WebhookTrigger ConversationStop = new("CONVERSATION_STOP"); | ||
public static readonly WebhookTrigger ContactCreate = new("CONTACT_CREATE"); | ||
public static readonly WebhookTrigger ContactDelete = new("CONTACT_DELETE"); | ||
public static readonly WebhookTrigger ContactMerge = new("CONTACT_MERGE"); | ||
public static readonly WebhookTrigger ContactUpdate = new("CONTACT_UPDATE"); | ||
public static readonly WebhookTrigger Unsupported = new("UNSUPPORTED"); | ||
public static readonly WebhookTrigger OptIn = new("OPT_IN"); | ||
public static readonly WebhookTrigger OptOut = new("OPT_OUT"); | ||
public static readonly WebhookTrigger Capability = new("CAPABILITY"); | ||
public static readonly WebhookTrigger ChannelEvent = new("CHANNEL_EVENT"); | ||
public static readonly WebhookTrigger ConversationDelete = new("CONVERSATION_DELETE"); | ||
public static readonly WebhookTrigger ContactIdentitiesDuplication = new("CONTACT_IDENTITIES_DUPLICATION"); | ||
} | ||
} |
Oops, something went wrong.