{-# 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.ServiceCatalogAppRegistry.AssociateAttributeGroup -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Associates an attribute group with an application to augment the -- application\'s metadata with the group\'s attributes. This feature -- enables applications to be described with user-defined details that are -- machine-readable, such as third-party integrations. module Amazonka.ServiceCatalogAppRegistry.AssociateAttributeGroup ( -- * Creating a Request AssociateAttributeGroup (..), newAssociateAttributeGroup, -- * Request Lenses associateAttributeGroup_application, associateAttributeGroup_attributeGroup, -- * Destructuring the Response AssociateAttributeGroupResponse (..), newAssociateAttributeGroupResponse, -- * Response Lenses associateAttributeGroupResponse_applicationArn, associateAttributeGroupResponse_attributeGroupArn, associateAttributeGroupResponse_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.ServiceCatalogAppRegistry.Types -- | /See:/ 'newAssociateAttributeGroup' smart constructor. data AssociateAttributeGroup = AssociateAttributeGroup' { -- | The name or ID of the application. application :: Prelude.Text, -- | The name or ID of the attribute group that holds the attributes to -- describe the application. attributeGroup :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'AssociateAttributeGroup' 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: -- -- 'application', 'associateAttributeGroup_application' - The name or ID of the application. -- -- 'attributeGroup', 'associateAttributeGroup_attributeGroup' - The name or ID of the attribute group that holds the attributes to -- describe the application. newAssociateAttributeGroup :: -- | 'application' Prelude.Text -> -- | 'attributeGroup' Prelude.Text -> AssociateAttributeGroup newAssociateAttributeGroup pApplication_ pAttributeGroup_ = AssociateAttributeGroup' { application = pApplication_, attributeGroup = pAttributeGroup_ } -- | The name or ID of the application. associateAttributeGroup_application :: Lens.Lens' AssociateAttributeGroup Prelude.Text associateAttributeGroup_application = Lens.lens (\AssociateAttributeGroup' {application} -> application) (\s@AssociateAttributeGroup' {} a -> s {application = a} :: AssociateAttributeGroup) -- | The name or ID of the attribute group that holds the attributes to -- describe the application. associateAttributeGroup_attributeGroup :: Lens.Lens' AssociateAttributeGroup Prelude.Text associateAttributeGroup_attributeGroup = Lens.lens (\AssociateAttributeGroup' {attributeGroup} -> attributeGroup) (\s@AssociateAttributeGroup' {} a -> s {attributeGroup = a} :: AssociateAttributeGroup) instance Core.AWSRequest AssociateAttributeGroup where type AWSResponse AssociateAttributeGroup = AssociateAttributeGroupResponse request overrides = Request.putJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> AssociateAttributeGroupResponse' Prelude.<$> (x Data..?> "applicationArn") Prelude.<*> (x Data..?> "attributeGroupArn") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable AssociateAttributeGroup where hashWithSalt _salt AssociateAttributeGroup' {..} = _salt `Prelude.hashWithSalt` application `Prelude.hashWithSalt` attributeGroup instance Prelude.NFData AssociateAttributeGroup where rnf AssociateAttributeGroup' {..} = Prelude.rnf application `Prelude.seq` Prelude.rnf attributeGroup instance Data.ToHeaders AssociateAttributeGroup where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON AssociateAttributeGroup where toJSON = Prelude.const (Data.Object Prelude.mempty) instance Data.ToPath AssociateAttributeGroup where toPath AssociateAttributeGroup' {..} = Prelude.mconcat [ "/applications/", Data.toBS application, "/attribute-groups/", Data.toBS attributeGroup ] instance Data.ToQuery AssociateAttributeGroup where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newAssociateAttributeGroupResponse' smart constructor. data AssociateAttributeGroupResponse = AssociateAttributeGroupResponse' { -- | The Amazon resource name (ARN) of the application that was augmented -- with attributes. applicationArn :: Prelude.Maybe Prelude.Text, -- | The Amazon resource name (ARN) of the attribute group that contains the -- application\'s new attributes. attributeGroupArn :: 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 'AssociateAttributeGroupResponse' 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: -- -- 'applicationArn', 'associateAttributeGroupResponse_applicationArn' - The Amazon resource name (ARN) of the application that was augmented -- with attributes. -- -- 'attributeGroupArn', 'associateAttributeGroupResponse_attributeGroupArn' - The Amazon resource name (ARN) of the attribute group that contains the -- application\'s new attributes. -- -- 'httpStatus', 'associateAttributeGroupResponse_httpStatus' - The response's http status code. newAssociateAttributeGroupResponse :: -- | 'httpStatus' Prelude.Int -> AssociateAttributeGroupResponse newAssociateAttributeGroupResponse pHttpStatus_ = AssociateAttributeGroupResponse' { applicationArn = Prelude.Nothing, attributeGroupArn = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The Amazon resource name (ARN) of the application that was augmented -- with attributes. associateAttributeGroupResponse_applicationArn :: Lens.Lens' AssociateAttributeGroupResponse (Prelude.Maybe Prelude.Text) associateAttributeGroupResponse_applicationArn = Lens.lens (\AssociateAttributeGroupResponse' {applicationArn} -> applicationArn) (\s@AssociateAttributeGroupResponse' {} a -> s {applicationArn = a} :: AssociateAttributeGroupResponse) -- | The Amazon resource name (ARN) of the attribute group that contains the -- application\'s new attributes. associateAttributeGroupResponse_attributeGroupArn :: Lens.Lens' AssociateAttributeGroupResponse (Prelude.Maybe Prelude.Text) associateAttributeGroupResponse_attributeGroupArn = Lens.lens (\AssociateAttributeGroupResponse' {attributeGroupArn} -> attributeGroupArn) (\s@AssociateAttributeGroupResponse' {} a -> s {attributeGroupArn = a} :: AssociateAttributeGroupResponse) -- | The response's http status code. associateAttributeGroupResponse_httpStatus :: Lens.Lens' AssociateAttributeGroupResponse Prelude.Int associateAttributeGroupResponse_httpStatus = Lens.lens (\AssociateAttributeGroupResponse' {httpStatus} -> httpStatus) (\s@AssociateAttributeGroupResponse' {} a -> s {httpStatus = a} :: AssociateAttributeGroupResponse) instance Prelude.NFData AssociateAttributeGroupResponse where rnf AssociateAttributeGroupResponse' {..} = Prelude.rnf applicationArn `Prelude.seq` Prelude.rnf attributeGroupArn `Prelude.seq` Prelude.rnf httpStatus