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 167 168 169 170 171 172 173 174 175 176 177
|
// Code generated by smithy-go-codegen DO NOT EDIT.
package storagegateway
import (
"context"
"fmt"
awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware"
"github.com/aws/aws-sdk-go-v2/service/storagegateway/types"
"github.com/aws/smithy-go/middleware"
smithyhttp "github.com/aws/smithy-go/transport/http"
)
// Updates the SMB security strategy level for an Amazon S3 file gateway. This
// action is only supported for Amazon S3 file gateways.
//
// For information about configuring this setting using the Amazon Web Services
// console, see [Setting a security level for your gateway]in the Amazon S3 File Gateway User Guide.
//
// A higher security strategy level can affect performance of the gateway.
//
// [Setting a security level for your gateway]: https://docs.aws.amazon.com/filegateway/latest/files3/security-strategy.html
func (c *Client) UpdateSMBSecurityStrategy(ctx context.Context, params *UpdateSMBSecurityStrategyInput, optFns ...func(*Options)) (*UpdateSMBSecurityStrategyOutput, error) {
if params == nil {
params = &UpdateSMBSecurityStrategyInput{}
}
result, metadata, err := c.invokeOperation(ctx, "UpdateSMBSecurityStrategy", params, optFns, c.addOperationUpdateSMBSecurityStrategyMiddlewares)
if err != nil {
return nil, err
}
out := result.(*UpdateSMBSecurityStrategyOutput)
out.ResultMetadata = metadata
return out, nil
}
type UpdateSMBSecurityStrategyInput struct {
// The Amazon Resource Name (ARN) of the gateway. Use the ListGateways operation to return a
// list of gateways for your account and Amazon Web Services Region.
//
// This member is required.
GatewayARN *string
// Specifies the type of security strategy.
//
// ClientSpecified : If you choose this option, requests are established based on
// what is negotiated by the client. This option is recommended when you want to
// maximize compatibility across different clients in your environment. Supported
// only for S3 File Gateway.
//
// MandatorySigning : If you choose this option, File Gateway only allows
// connections from SMBv2 or SMBv3 clients that have signing enabled. This option
// works with SMB clients on Microsoft Windows Vista, Windows Server 2008 or newer.
//
// MandatoryEncryption : If you choose this option, File Gateway only allows
// connections from SMBv3 clients that have encryption enabled. This option is
// recommended for environments that handle sensitive data. This option works with
// SMB clients on Microsoft Windows 8, Windows Server 2012 or newer.
//
// MandatoryEncryptionNoAes128 : If you choose this option, File Gateway only
// allows connections from SMBv3 clients that use 256-bit AES encryption
// algorithms. 128-bit algorithms are not allowed. This option is recommended for
// environments that handle sensitive data. It works with SMB clients on Microsoft
// Windows 8, Windows Server 2012, or later.
//
// This member is required.
SMBSecurityStrategy types.SMBSecurityStrategy
noSmithyDocumentSerde
}
type UpdateSMBSecurityStrategyOutput struct {
// The Amazon Resource Name (ARN) of the gateway. Use the ListGateways operation to return a
// list of gateways for your account and Amazon Web Services Region.
GatewayARN *string
// Metadata pertaining to the operation's result.
ResultMetadata middleware.Metadata
noSmithyDocumentSerde
}
func (c *Client) addOperationUpdateSMBSecurityStrategyMiddlewares(stack *middleware.Stack, options Options) (err error) {
if err := stack.Serialize.Add(&setOperationInputMiddleware{}, middleware.After); err != nil {
return err
}
err = stack.Serialize.Add(&awsAwsjson11_serializeOpUpdateSMBSecurityStrategy{}, middleware.After)
if err != nil {
return err
}
err = stack.Deserialize.Add(&awsAwsjson11_deserializeOpUpdateSMBSecurityStrategy{}, middleware.After)
if err != nil {
return err
}
if err := addProtocolFinalizerMiddlewares(stack, options, "UpdateSMBSecurityStrategy"); err != nil {
return fmt.Errorf("add protocol finalizers: %v", err)
}
if err = addlegacyEndpointContextSetter(stack, options); err != nil {
return err
}
if err = addSetLoggerMiddleware(stack, options); err != nil {
return err
}
if err = addClientRequestID(stack); err != nil {
return err
}
if err = addComputeContentLength(stack); err != nil {
return err
}
if err = addResolveEndpointMiddleware(stack, options); err != nil {
return err
}
if err = addComputePayloadSHA256(stack); err != nil {
return err
}
if err = addRetry(stack, options); err != nil {
return err
}
if err = addRawResponseToMetadata(stack); err != nil {
return err
}
if err = addRecordResponseTiming(stack); err != nil {
return err
}
if err = addClientUserAgent(stack, options); err != nil {
return err
}
if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
return err
}
if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
return err
}
if err = addSetLegacyContextSigningOptionsMiddleware(stack); err != nil {
return err
}
if err = addTimeOffsetBuild(stack, c); err != nil {
return err
}
if err = addUserAgentRetryMode(stack, options); err != nil {
return err
}
if err = addOpUpdateSMBSecurityStrategyValidationMiddleware(stack); err != nil {
return err
}
if err = stack.Initialize.Add(newServiceMetadataMiddleware_opUpdateSMBSecurityStrategy(options.Region), middleware.Before); err != nil {
return err
}
if err = addRecursionDetection(stack); 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
}
if err = addDisableHTTPSMiddleware(stack, options); err != nil {
return err
}
return nil
}
func newServiceMetadataMiddleware_opUpdateSMBSecurityStrategy(region string) *awsmiddleware.RegisterServiceMetadata {
return &awsmiddleware.RegisterServiceMetadata{
Region: region,
ServiceID: ServiceID,
OperationName: "UpdateSMBSecurityStrategy",
}
}
|