{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.WorkSpaces.CreateConnectionAlias -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Creates the specified connection alias for use with cross-Region -- redirection. For more information, see -- . module Amazonka.WorkSpaces.CreateConnectionAlias ( -- * Creating a Request CreateConnectionAlias (..), newCreateConnectionAlias, -- * Request Lenses createConnectionAlias_tags, createConnectionAlias_connectionString, -- * Destructuring the Response CreateConnectionAliasResponse (..), newCreateConnectionAliasResponse, -- * Response Lenses createConnectionAliasResponse_aliasId, createConnectionAliasResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response import Amazonka.WorkSpaces.Types -- | /See:/ 'newCreateConnectionAlias' smart constructor. data CreateConnectionAlias = CreateConnectionAlias' { -- | The tags to associate with the connection alias. tags :: Prelude.Maybe [Tag], -- | A connection string in the form of a fully qualified domain name (FQDN), -- such as @www.example.com@. -- -- After you create a connection string, it is always associated to your -- Amazon Web Services account. You cannot recreate the same connection -- string with a different account, even if you delete all instances of it -- from the original account. The connection string is globally reserved -- for your account. connectionString :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateConnectionAlias' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'tags', 'createConnectionAlias_tags' - The tags to associate with the connection alias. -- -- 'connectionString', 'createConnectionAlias_connectionString' - A connection string in the form of a fully qualified domain name (FQDN), -- such as @www.example.com@. -- -- After you create a connection string, it is always associated to your -- Amazon Web Services account. You cannot recreate the same connection -- string with a different account, even if you delete all instances of it -- from the original account. The connection string is globally reserved -- for your account. newCreateConnectionAlias :: -- | 'connectionString' Prelude.Text -> CreateConnectionAlias newCreateConnectionAlias pConnectionString_ = CreateConnectionAlias' { tags = Prelude.Nothing, connectionString = pConnectionString_ } -- | The tags to associate with the connection alias. createConnectionAlias_tags :: Lens.Lens' CreateConnectionAlias (Prelude.Maybe [Tag]) createConnectionAlias_tags = Lens.lens (\CreateConnectionAlias' {tags} -> tags) (\s@CreateConnectionAlias' {} a -> s {tags = a} :: CreateConnectionAlias) Prelude.. Lens.mapping Lens.coerced -- | A connection string in the form of a fully qualified domain name (FQDN), -- such as @www.example.com@. -- -- After you create a connection string, it is always associated to your -- Amazon Web Services account. You cannot recreate the same connection -- string with a different account, even if you delete all instances of it -- from the original account. The connection string is globally reserved -- for your account. createConnectionAlias_connectionString :: Lens.Lens' CreateConnectionAlias Prelude.Text createConnectionAlias_connectionString = Lens.lens (\CreateConnectionAlias' {connectionString} -> connectionString) (\s@CreateConnectionAlias' {} a -> s {connectionString = a} :: CreateConnectionAlias) instance Core.AWSRequest CreateConnectionAlias where type AWSResponse CreateConnectionAlias = CreateConnectionAliasResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> CreateConnectionAliasResponse' Prelude.<$> (x Data..?> "AliasId") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable CreateConnectionAlias where hashWithSalt _salt CreateConnectionAlias' {..} = _salt `Prelude.hashWithSalt` tags `Prelude.hashWithSalt` connectionString instance Prelude.NFData CreateConnectionAlias where rnf CreateConnectionAlias' {..} = Prelude.rnf tags `Prelude.seq` Prelude.rnf connectionString instance Data.ToHeaders CreateConnectionAlias where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "WorkspacesService.CreateConnectionAlias" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON CreateConnectionAlias where toJSON CreateConnectionAlias' {..} = Data.object ( Prelude.catMaybes [ ("Tags" Data..=) Prelude.<$> tags, Prelude.Just ("ConnectionString" Data..= connectionString) ] ) instance Data.ToPath CreateConnectionAlias where toPath = Prelude.const "/" instance Data.ToQuery CreateConnectionAlias where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newCreateConnectionAliasResponse' smart constructor. data CreateConnectionAliasResponse = CreateConnectionAliasResponse' { -- | The identifier of the connection alias. aliasId :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateConnectionAliasResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'aliasId', 'createConnectionAliasResponse_aliasId' - The identifier of the connection alias. -- -- 'httpStatus', 'createConnectionAliasResponse_httpStatus' - The response's http status code. newCreateConnectionAliasResponse :: -- | 'httpStatus' Prelude.Int -> CreateConnectionAliasResponse newCreateConnectionAliasResponse pHttpStatus_ = CreateConnectionAliasResponse' { aliasId = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The identifier of the connection alias. createConnectionAliasResponse_aliasId :: Lens.Lens' CreateConnectionAliasResponse (Prelude.Maybe Prelude.Text) createConnectionAliasResponse_aliasId = Lens.lens (\CreateConnectionAliasResponse' {aliasId} -> aliasId) (\s@CreateConnectionAliasResponse' {} a -> s {aliasId = a} :: CreateConnectionAliasResponse) -- | The response's http status code. createConnectionAliasResponse_httpStatus :: Lens.Lens' CreateConnectionAliasResponse Prelude.Int createConnectionAliasResponse_httpStatus = Lens.lens (\CreateConnectionAliasResponse' {httpStatus} -> httpStatus) (\s@CreateConnectionAliasResponse' {} a -> s {httpStatus = a} :: CreateConnectionAliasResponse) instance Prelude.NFData CreateConnectionAliasResponse where rnf CreateConnectionAliasResponse' {..} = Prelude.rnf aliasId `Prelude.seq` Prelude.rnf httpStatus