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 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166
|
// Code generated by smithy-go-codegen DO NOT EDIT.
package lightsail
import (
"context"
awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware"
"github.com/aws/aws-sdk-go-v2/aws/signer/v4"
"github.com/aws/aws-sdk-go-v2/service/lightsail/types"
"github.com/aws/smithy-go/middleware"
smithyhttp "github.com/aws/smithy-go/transport/http"
)
// Creates an email or SMS text message contact method. A contact method is used to
// send you notifications about your Amazon Lightsail resources. You can add one
// email address and one mobile phone number contact method in each Amazon Web
// Services Region. However, SMS text messaging is not supported in some Amazon Web
// Services Regions, and SMS text messages cannot be sent to some
// countries/regions. For more information, see Notifications in Amazon Lightsail
// (https://lightsail.aws.amazon.com/ls/docs/en_us/articles/amazon-lightsail-notifications).
func (c *Client) CreateContactMethod(ctx context.Context, params *CreateContactMethodInput, optFns ...func(*Options)) (*CreateContactMethodOutput, error) {
if params == nil {
params = &CreateContactMethodInput{}
}
result, metadata, err := c.invokeOperation(ctx, "CreateContactMethod", params, optFns, c.addOperationCreateContactMethodMiddlewares)
if err != nil {
return nil, err
}
out := result.(*CreateContactMethodOutput)
out.ResultMetadata = metadata
return out, nil
}
type CreateContactMethodInput struct {
// The destination of the contact method, such as an email address or a mobile
// phone number. Use the E.164 format when specifying a mobile phone number. E.164
// is a standard for the phone number structure used for international
// telecommunication. Phone numbers that follow this format can have a maximum of
// 15 digits, and they are prefixed with the plus character (+) and the country
// code. For example, a U.S. phone number in E.164 format would be specified as
// +1XXX5550100. For more information, see E.164
// (https://en.wikipedia.org/wiki/E.164) on Wikipedia.
//
// This member is required.
ContactEndpoint *string
// The protocol of the contact method, such as Email or SMS (text messaging). The
// SMS protocol is supported only in the following Amazon Web Services Regions.
//
// *
// US East (N. Virginia) (us-east-1)
//
// * US West (Oregon) (us-west-2)
//
// * Europe
// (Ireland) (eu-west-1)
//
// * Asia Pacific (Tokyo) (ap-northeast-1)
//
// * Asia Pacific
// (Singapore) (ap-southeast-1)
//
// * Asia Pacific (Sydney) (ap-southeast-2)
//
// For a
// list of countries/regions where SMS text messages can be sent, and the latest
// Amazon Web Services Regions where SMS text messaging is supported, see Supported
// Regions and Countries
// (https://docs.aws.amazon.com/sns/latest/dg/sns-supported-regions-countries.html)
// in the Amazon SNS Developer Guide. For more information about notifications in
// Amazon Lightsail, see Notifications in Amazon Lightsail
// (https://lightsail.aws.amazon.com/ls/docs/en_us/articles/amazon-lightsail-notifications).
//
// This member is required.
Protocol types.ContactProtocol
noSmithyDocumentSerde
}
type CreateContactMethodOutput struct {
// An array of objects that describe the result of the action, such as the status
// of the request, the timestamp of the request, and the resources affected by the
// request.
Operations []types.Operation
// Metadata pertaining to the operation's result.
ResultMetadata middleware.Metadata
noSmithyDocumentSerde
}
func (c *Client) addOperationCreateContactMethodMiddlewares(stack *middleware.Stack, options Options) (err error) {
err = stack.Serialize.Add(&awsAwsjson11_serializeOpCreateContactMethod{}, middleware.After)
if err != nil {
return err
}
err = stack.Deserialize.Add(&awsAwsjson11_deserializeOpCreateContactMethod{}, middleware.After)
if err != nil {
return err
}
if err = addSetLoggerMiddleware(stack, options); err != nil {
return err
}
if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil {
return err
}
if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil {
return err
}
if err = addResolveEndpointMiddleware(stack, options); err != nil {
return err
}
if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil {
return err
}
if err = addRetryMiddlewares(stack, options); err != nil {
return err
}
if err = addHTTPSignerV4Middleware(stack, options); err != nil {
return err
}
if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil {
return err
}
if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil {
return err
}
if err = addClientUserAgent(stack); err != nil {
return err
}
if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
return err
}
if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
return err
}
if err = addOpCreateContactMethodValidationMiddleware(stack); err != nil {
return err
}
if err = stack.Initialize.Add(newServiceMetadataMiddleware_opCreateContactMethod(options.Region), middleware.Before); err != nil {
return err
}
if err = addRequestIDRetrieverMiddleware(stack); err != nil {
return err
}
if err = addResponseErrorMiddleware(stack); err != nil {
return err
}
if err = addRequestResponseLogging(stack, options); err != nil {
return err
}
return nil
}
func newServiceMetadataMiddleware_opCreateContactMethod(region string) *awsmiddleware.RegisterServiceMetadata {
return &awsmiddleware.RegisterServiceMetadata{
Region: region,
ServiceID: ServiceID,
SigningName: "lightsail",
OperationName: "CreateContactMethod",
}
}
|