1// Code generated by smithy-go-codegen DO NOT EDIT.
2
3package workspaces
4
5import (
6	"context"
7	awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware"
8	"github.com/aws/aws-sdk-go-v2/aws/signer/v4"
9	"github.com/aws/aws-sdk-go-v2/service/workspaces/types"
10	"github.com/aws/smithy-go/middleware"
11	smithyhttp "github.com/aws/smithy-go/transport/http"
12)
13
14// Registers the specified directory. This operation is asynchronous and returns
15// before the WorkSpace directory is registered. If this is the first time you are
16// registering a directory, you will need to create the workspaces_DefaultRole role
17// before you can register a directory. For more information, see  Creating the
18// workspaces_DefaultRole Role
19// (https://docs.aws.amazon.com/workspaces/latest/adminguide/workspaces-access-control.html#create-default-role).
20func (c *Client) RegisterWorkspaceDirectory(ctx context.Context, params *RegisterWorkspaceDirectoryInput, optFns ...func(*Options)) (*RegisterWorkspaceDirectoryOutput, error) {
21	if params == nil {
22		params = &RegisterWorkspaceDirectoryInput{}
23	}
24
25	result, metadata, err := c.invokeOperation(ctx, "RegisterWorkspaceDirectory", params, optFns, addOperationRegisterWorkspaceDirectoryMiddlewares)
26	if err != nil {
27		return nil, err
28	}
29
30	out := result.(*RegisterWorkspaceDirectoryOutput)
31	out.ResultMetadata = metadata
32	return out, nil
33}
34
35type RegisterWorkspaceDirectoryInput struct {
36
37	// The identifier of the directory. You cannot register a directory if it does not
38	// have a status of Active. If the directory does not have a status of Active, you
39	// will receive an InvalidResourceStateException error. If you have already
40	// registered the maximum number of directories that you can register with Amazon
41	// WorkSpaces, you will receive a ResourceLimitExceededException error. Deregister
42	// directories that you are not using for WorkSpaces, and try again.
43	//
44	// This member is required.
45	DirectoryId *string
46
47	// Indicates whether Amazon WorkDocs is enabled or disabled. If you have enabled
48	// this parameter and WorkDocs is not available in the Region, you will receive an
49	// OperationNotSupportedException error. Set EnableWorkDocs to disabled, and try
50	// again.
51	//
52	// This member is required.
53	EnableWorkDocs *bool
54
55	// Indicates whether self-service capabilities are enabled or disabled.
56	EnableSelfService *bool
57
58	// The identifiers of the subnets for your virtual private cloud (VPC). Make sure
59	// that the subnets are in supported Availability Zones. The subnets must also be
60	// in separate Availability Zones. If these conditions are not met, you will
61	// receive an OperationNotSupportedException error.
62	SubnetIds []string
63
64	// The tags associated with the directory.
65	Tags []types.Tag
66
67	// Indicates whether your WorkSpace directory is dedicated or shared. To use Bring
68	// Your Own License (BYOL) images, this value must be set to DEDICATED and your AWS
69	// account must be enabled for BYOL. If your account has not been enabled for BYOL,
70	// you will receive an InvalidParameterValuesException error. For more information
71	// about BYOL images, see Bring Your Own Windows Desktop Images
72	// (https://docs.aws.amazon.com/workspaces/latest/adminguide/byol-windows-images.html).
73	Tenancy types.Tenancy
74}
75
76type RegisterWorkspaceDirectoryOutput struct {
77	// Metadata pertaining to the operation's result.
78	ResultMetadata middleware.Metadata
79}
80
81func addOperationRegisterWorkspaceDirectoryMiddlewares(stack *middleware.Stack, options Options) (err error) {
82	err = stack.Serialize.Add(&awsAwsjson11_serializeOpRegisterWorkspaceDirectory{}, middleware.After)
83	if err != nil {
84		return err
85	}
86	err = stack.Deserialize.Add(&awsAwsjson11_deserializeOpRegisterWorkspaceDirectory{}, middleware.After)
87	if err != nil {
88		return err
89	}
90	if err = addSetLoggerMiddleware(stack, options); err != nil {
91		return err
92	}
93	if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil {
94		return err
95	}
96	if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil {
97		return err
98	}
99	if err = addResolveEndpointMiddleware(stack, options); err != nil {
100		return err
101	}
102	if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil {
103		return err
104	}
105	if err = addRetryMiddlewares(stack, options); err != nil {
106		return err
107	}
108	if err = addHTTPSignerV4Middleware(stack, options); err != nil {
109		return err
110	}
111	if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil {
112		return err
113	}
114	if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil {
115		return err
116	}
117	if err = addClientUserAgent(stack); err != nil {
118		return err
119	}
120	if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
121		return err
122	}
123	if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
124		return err
125	}
126	if err = addOpRegisterWorkspaceDirectoryValidationMiddleware(stack); err != nil {
127		return err
128	}
129	if err = stack.Initialize.Add(newServiceMetadataMiddleware_opRegisterWorkspaceDirectory(options.Region), middleware.Before); err != nil {
130		return err
131	}
132	if err = addRequestIDRetrieverMiddleware(stack); err != nil {
133		return err
134	}
135	if err = addResponseErrorMiddleware(stack); err != nil {
136		return err
137	}
138	if err = addRequestResponseLogging(stack, options); err != nil {
139		return err
140	}
141	return nil
142}
143
144func newServiceMetadataMiddleware_opRegisterWorkspaceDirectory(region string) *awsmiddleware.RegisterServiceMetadata {
145	return &awsmiddleware.RegisterServiceMetadata{
146		Region:        region,
147		ServiceID:     ServiceID,
148		SigningName:   "workspaces",
149		OperationName: "RegisterWorkspaceDirectory",
150	}
151}
152