{-# 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.CodeGuruReviewer.DescribeRepositoryAssociation -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Returns a -- -- object that contains information about the requested repository -- association. module Amazonka.CodeGuruReviewer.DescribeRepositoryAssociation ( -- * Creating a Request DescribeRepositoryAssociation (..), newDescribeRepositoryAssociation, -- * Request Lenses describeRepositoryAssociation_associationArn, -- * Destructuring the Response DescribeRepositoryAssociationResponse (..), newDescribeRepositoryAssociationResponse, -- * Response Lenses describeRepositoryAssociationResponse_repositoryAssociation, describeRepositoryAssociationResponse_tags, describeRepositoryAssociationResponse_httpStatus, ) where import Amazonka.CodeGuruReviewer.Types 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 -- | /See:/ 'newDescribeRepositoryAssociation' smart constructor. data DescribeRepositoryAssociation = DescribeRepositoryAssociation' { -- | The Amazon Resource Name (ARN) of the -- -- object. You can retrieve this ARN by calling -- . associationArn :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeRepositoryAssociation' 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: -- -- 'associationArn', 'describeRepositoryAssociation_associationArn' - The Amazon Resource Name (ARN) of the -- -- object. You can retrieve this ARN by calling -- . newDescribeRepositoryAssociation :: -- | 'associationArn' Prelude.Text -> DescribeRepositoryAssociation newDescribeRepositoryAssociation pAssociationArn_ = DescribeRepositoryAssociation' { associationArn = pAssociationArn_ } -- | The Amazon Resource Name (ARN) of the -- -- object. You can retrieve this ARN by calling -- . describeRepositoryAssociation_associationArn :: Lens.Lens' DescribeRepositoryAssociation Prelude.Text describeRepositoryAssociation_associationArn = Lens.lens (\DescribeRepositoryAssociation' {associationArn} -> associationArn) (\s@DescribeRepositoryAssociation' {} a -> s {associationArn = a} :: DescribeRepositoryAssociation) instance Core.AWSRequest DescribeRepositoryAssociation where type AWSResponse DescribeRepositoryAssociation = DescribeRepositoryAssociationResponse request overrides = Request.get (overrides defaultService) response = Response.receiveJSON ( \s h x -> DescribeRepositoryAssociationResponse' Prelude.<$> (x Data..?> "RepositoryAssociation") Prelude.<*> (x Data..?> "Tags" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DescribeRepositoryAssociation where hashWithSalt _salt DescribeRepositoryAssociation' {..} = _salt `Prelude.hashWithSalt` associationArn instance Prelude.NFData DescribeRepositoryAssociation where rnf DescribeRepositoryAssociation' {..} = Prelude.rnf associationArn instance Data.ToHeaders DescribeRepositoryAssociation where toHeaders = Prelude.const ( Prelude.mconcat [ "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToPath DescribeRepositoryAssociation where toPath DescribeRepositoryAssociation' {..} = Prelude.mconcat ["/associations/", Data.toBS associationArn] instance Data.ToQuery DescribeRepositoryAssociation where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDescribeRepositoryAssociationResponse' smart constructor. data DescribeRepositoryAssociationResponse = DescribeRepositoryAssociationResponse' { -- | Information about the repository association. repositoryAssociation :: Prelude.Maybe RepositoryAssociation, -- | An array of key-value pairs used to tag an associated repository. A tag -- is a custom attribute label with two parts: -- -- - A /tag key/ (for example, @CostCenter@, @Environment@, @Project@, or -- @Secret@). Tag keys are case sensitive. -- -- - An optional field known as a /tag value/ (for example, -- @111122223333@, @Production@, or a team name). Omitting the tag -- value is the same as using an empty string. Like tag keys, tag -- values are case sensitive. tags :: Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text), -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DescribeRepositoryAssociationResponse' 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: -- -- 'repositoryAssociation', 'describeRepositoryAssociationResponse_repositoryAssociation' - Information about the repository association. -- -- 'tags', 'describeRepositoryAssociationResponse_tags' - An array of key-value pairs used to tag an associated repository. A tag -- is a custom attribute label with two parts: -- -- - A /tag key/ (for example, @CostCenter@, @Environment@, @Project@, or -- @Secret@). Tag keys are case sensitive. -- -- - An optional field known as a /tag value/ (for example, -- @111122223333@, @Production@, or a team name). Omitting the tag -- value is the same as using an empty string. Like tag keys, tag -- values are case sensitive. -- -- 'httpStatus', 'describeRepositoryAssociationResponse_httpStatus' - The response's http status code. newDescribeRepositoryAssociationResponse :: -- | 'httpStatus' Prelude.Int -> DescribeRepositoryAssociationResponse newDescribeRepositoryAssociationResponse pHttpStatus_ = DescribeRepositoryAssociationResponse' { repositoryAssociation = Prelude.Nothing, tags = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Information about the repository association. describeRepositoryAssociationResponse_repositoryAssociation :: Lens.Lens' DescribeRepositoryAssociationResponse (Prelude.Maybe RepositoryAssociation) describeRepositoryAssociationResponse_repositoryAssociation = Lens.lens (\DescribeRepositoryAssociationResponse' {repositoryAssociation} -> repositoryAssociation) (\s@DescribeRepositoryAssociationResponse' {} a -> s {repositoryAssociation = a} :: DescribeRepositoryAssociationResponse) -- | An array of key-value pairs used to tag an associated repository. A tag -- is a custom attribute label with two parts: -- -- - A /tag key/ (for example, @CostCenter@, @Environment@, @Project@, or -- @Secret@). Tag keys are case sensitive. -- -- - An optional field known as a /tag value/ (for example, -- @111122223333@, @Production@, or a team name). Omitting the tag -- value is the same as using an empty string. Like tag keys, tag -- values are case sensitive. describeRepositoryAssociationResponse_tags :: Lens.Lens' DescribeRepositoryAssociationResponse (Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text)) describeRepositoryAssociationResponse_tags = Lens.lens (\DescribeRepositoryAssociationResponse' {tags} -> tags) (\s@DescribeRepositoryAssociationResponse' {} a -> s {tags = a} :: DescribeRepositoryAssociationResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. describeRepositoryAssociationResponse_httpStatus :: Lens.Lens' DescribeRepositoryAssociationResponse Prelude.Int describeRepositoryAssociationResponse_httpStatus = Lens.lens (\DescribeRepositoryAssociationResponse' {httpStatus} -> httpStatus) (\s@DescribeRepositoryAssociationResponse' {} a -> s {httpStatus = a} :: DescribeRepositoryAssociationResponse) instance Prelude.NFData DescribeRepositoryAssociationResponse where rnf DescribeRepositoryAssociationResponse' {..} = Prelude.rnf repositoryAssociation `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf httpStatus