-
Notifications
You must be signed in to change notification settings - Fork 82
/
subscription.go
133 lines (108 loc) · 6.08 KB
/
subscription.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
// Copyright (c) 2016, 2018, 2023, Oracle and/or its affiliates. All rights reserved.
// This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
// Code generated. DO NOT EDIT.
// Notifications API
//
// Use the Notifications API to broadcast messages to distributed components by topic, using a publish-subscribe pattern.
// For information about managing topics, subscriptions, and messages, see Notifications Overview (https://docs.cloud.oracle.com/iaas/Content/Notification/Concepts/notificationoverview.htm).
//
package ons
import (
"fmt"
"github.com/oracle/oci-go-sdk/v65/common"
"strings"
)
// Subscription The subscription's configuration. For general information about subscriptions, see
// Notifications Overview (https://docs.cloud.oracle.com/iaas/Content/Notification/Concepts/notificationoverview.htm).
type Subscription struct {
// The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the subscription.
Id *string `mandatory:"true" json:"id"`
// The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the associated topic.
TopicId *string `mandatory:"true" json:"topicId"`
// The protocol used for the subscription.
// Allowed values:
// * `CUSTOM_HTTPS`
// * `EMAIL`
// * `HTTPS` (deprecated; for PagerDuty endpoints, use `PAGERDUTY`)
// * `ORACLE_FUNCTIONS`
// * `PAGERDUTY`
// * `SLACK`
// * `SMS`
// For information about subscription protocols, see
// To create a subscription (https://docs.cloud.oracle.com/iaas/Content/Notification/Tasks/managingtopicsandsubscriptions.htm#createSub).
Protocol *string `mandatory:"true" json:"protocol"`
// A locator that corresponds to the subscription protocol.
// For example, an email address for a subscription that uses the `EMAIL` protocol, or a URL for a subscription that uses an HTTP-based protocol.
Endpoint *string `mandatory:"true" json:"endpoint"`
// The lifecycle state of the subscription. The status of a new subscription is PENDING; when confirmed, the subscription status changes to ACTIVE.
LifecycleState SubscriptionLifecycleStateEnum `mandatory:"true" json:"lifecycleState"`
// The OCID (https://docs.cloud.oracle.com/iaas/Content/General/Concepts/identifiers.htm) of the compartment for the subscription.
CompartmentId *string `mandatory:"true" json:"compartmentId"`
// The time when this suscription was created.
CreatedTime *int64 `mandatory:"false" json:"createdTime"`
// The delivery policy of the subscription. Stored as a JSON string.
DeliverPolicy *string `mandatory:"false" json:"deliverPolicy"`
// For optimistic concurrency control. See `if-match`.
Etag *string `mandatory:"false" json:"etag"`
// Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags (https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm).
// Example: `{"Department": "Finance"}`
FreeformTags map[string]string `mandatory:"false" json:"freeformTags"`
// Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags (https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm).
// Example: `{"Operations": {"CostCenter": "42"}}`
DefinedTags map[string]map[string]interface{} `mandatory:"false" json:"definedTags"`
}
func (m Subscription) String() string {
return common.PointerString(m)
}
// ValidateEnumValue returns an error when providing an unsupported enum value
// This function is being called during constructing API request process
// Not recommended for calling this function directly
func (m Subscription) ValidateEnumValue() (bool, error) {
errMessage := []string{}
if _, ok := GetMappingSubscriptionLifecycleStateEnum(string(m.LifecycleState)); !ok && m.LifecycleState != "" {
errMessage = append(errMessage, fmt.Sprintf("unsupported enum value for LifecycleState: %s. Supported values are: %s.", m.LifecycleState, strings.Join(GetSubscriptionLifecycleStateEnumStringValues(), ",")))
}
if len(errMessage) > 0 {
return true, fmt.Errorf(strings.Join(errMessage, "\n"))
}
return false, nil
}
// SubscriptionLifecycleStateEnum Enum with underlying type: string
type SubscriptionLifecycleStateEnum string
// Set of constants representing the allowable values for SubscriptionLifecycleStateEnum
const (
SubscriptionLifecycleStatePending SubscriptionLifecycleStateEnum = "PENDING"
SubscriptionLifecycleStateActive SubscriptionLifecycleStateEnum = "ACTIVE"
SubscriptionLifecycleStateDeleted SubscriptionLifecycleStateEnum = "DELETED"
)
var mappingSubscriptionLifecycleStateEnum = map[string]SubscriptionLifecycleStateEnum{
"PENDING": SubscriptionLifecycleStatePending,
"ACTIVE": SubscriptionLifecycleStateActive,
"DELETED": SubscriptionLifecycleStateDeleted,
}
var mappingSubscriptionLifecycleStateEnumLowerCase = map[string]SubscriptionLifecycleStateEnum{
"pending": SubscriptionLifecycleStatePending,
"active": SubscriptionLifecycleStateActive,
"deleted": SubscriptionLifecycleStateDeleted,
}
// GetSubscriptionLifecycleStateEnumValues Enumerates the set of values for SubscriptionLifecycleStateEnum
func GetSubscriptionLifecycleStateEnumValues() []SubscriptionLifecycleStateEnum {
values := make([]SubscriptionLifecycleStateEnum, 0)
for _, v := range mappingSubscriptionLifecycleStateEnum {
values = append(values, v)
}
return values
}
// GetSubscriptionLifecycleStateEnumStringValues Enumerates the set of values in String for SubscriptionLifecycleStateEnum
func GetSubscriptionLifecycleStateEnumStringValues() []string {
return []string{
"PENDING",
"ACTIVE",
"DELETED",
}
}
// GetMappingSubscriptionLifecycleStateEnum performs case Insensitive comparison on enum value and return the desired enum
func GetMappingSubscriptionLifecycleStateEnum(val string) (SubscriptionLifecycleStateEnum, bool) {
enum, ok := mappingSubscriptionLifecycleStateEnumLowerCase[strings.ToLower(val)]
return enum, ok
}