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 178 179 180 181 182 183 184 185
|
// 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/aws/signer/v4"
"github.com/aws/aws-sdk-go-v2/service/storagegateway/types"
"github.com/aws/smithy-go/middleware"
smithyhttp "github.com/aws/smithy-go/transport/http"
)
// Gets a description of a Server Message Block (SMB) file share settings from a
// file gateway. This operation is only supported for file gateways.
func (c *Client) DescribeSMBSettings(ctx context.Context, params *DescribeSMBSettingsInput, optFns ...func(*Options)) (*DescribeSMBSettingsOutput, error) {
if params == nil {
params = &DescribeSMBSettingsInput{}
}
result, metadata, err := c.invokeOperation(ctx, "DescribeSMBSettings", params, optFns, c.addOperationDescribeSMBSettingsMiddlewares)
if err != nil {
return nil, err
}
out := result.(*DescribeSMBSettingsOutput)
out.ResultMetadata = metadata
return out, nil
}
type DescribeSMBSettingsInput 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
noSmithyDocumentSerde
}
type DescribeSMBSettingsOutput struct {
// Indicates the status of a gateway that is a member of the Active Directory
// domain.
// - ACCESS_DENIED : Indicates that the JoinDomain operation failed due to an
// authentication error.
// - DETACHED : Indicates that gateway is not joined to a domain.
// - JOINED : Indicates that the gateway has successfully joined a domain.
// - JOINING : Indicates that a JoinDomain operation is in progress.
// - NETWORK_ERROR : Indicates that JoinDomain operation failed due to a network
// or connectivity error.
// - TIMEOUT : Indicates that the JoinDomain operation failed because the
// operation didn't complete within the allotted time.
// - UNKNOWN_ERROR : Indicates that the JoinDomain operation failed due to
// another type of error.
ActiveDirectoryStatus types.ActiveDirectoryStatus
// The name of the domain that the gateway is joined to.
DomainName *string
// The shares on this gateway appear when listing shares. Only supported for S3
// File Gateways.
FileSharesVisible *bool
// 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
// This value is true if a password for the guest user smbguest is set, otherwise
// false . Only supported for S3 File Gateways. Valid Values: true | false
SMBGuestPasswordSet *bool
// A list of Active Directory users and groups that have special permissions for
// SMB file shares on the gateway.
SMBLocalGroups *types.SMBLocalGroups
// The type of security strategy that was specified for file gateway.
// - ClientSpecified : If you use 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. Only
// supported for S3 File Gateways.
// - MandatorySigning : If you use 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 use this option, file gateway only allows
// connections from SMBv3 clients that have encryption enabled. This option is
// highly recommended for environments that handle sensitive data. This option
// works with SMB clients on Microsoft Windows 8, Windows Server 2012 or newer.
SMBSecurityStrategy types.SMBSecurityStrategy
// Metadata pertaining to the operation's result.
ResultMetadata middleware.Metadata
noSmithyDocumentSerde
}
func (c *Client) addOperationDescribeSMBSettingsMiddlewares(stack *middleware.Stack, options Options) (err error) {
if err := stack.Serialize.Add(&setOperationInputMiddleware{}, middleware.After); err != nil {
return err
}
err = stack.Serialize.Add(&awsAwsjson11_serializeOpDescribeSMBSettings{}, middleware.After)
if err != nil {
return err
}
err = stack.Deserialize.Add(&awsAwsjson11_deserializeOpDescribeSMBSettings{}, middleware.After)
if err != nil {
return err
}
if err := addProtocolFinalizerMiddlewares(stack, options, "DescribeSMBSettings"); 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 = 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 = awsmiddleware.AddRawResponseToMetadata(stack); err != nil {
return err
}
if err = awsmiddleware.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 = addOpDescribeSMBSettingsValidationMiddleware(stack); err != nil {
return err
}
if err = stack.Initialize.Add(newServiceMetadataMiddleware_opDescribeSMBSettings(options.Region), middleware.Before); err != nil {
return err
}
if err = awsmiddleware.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_opDescribeSMBSettings(region string) *awsmiddleware.RegisterServiceMetadata {
return &awsmiddleware.RegisterServiceMetadata{
Region: region,
ServiceID: ServiceID,
OperationName: "DescribeSMBSettings",
}
}
|