{-# 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.ServiceCatalog.AssociatePrincipalWithPortfolio -- 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 the specified principal ARN with the specified portfolio. -- -- If you share the portfolio with principal name sharing enabled, the -- @PrincipalARN@ association is included in the share. -- -- The @PortfolioID@, @PrincipalARN@, and @PrincipalType@ parameters are -- required. -- -- You can associate a maximum of 10 Principals with a portfolio using -- @PrincipalType@ as @IAM_PATTERN@ -- -- When you associate a principal with portfolio, a potential privilege -- escalation path may occur when that portfolio is then shared with other -- accounts. For a user in a recipient account who is /not/ an Service -- Catalog Admin, but still has the ability to create Principals -- (Users\/Groups\/Roles), that user could create a role that matches a -- principal name association for the portfolio. Although this user may not -- know which principal names are associated through Service Catalog, they -- may be able to guess the user. If this potential escalation path is a -- concern, then Service Catalog recommends using @PrincipalType@ as @IAM@. -- With this configuration, the @PrincipalARN@ must already exist in the -- recipient account before it can be associated. module Amazonka.ServiceCatalog.AssociatePrincipalWithPortfolio ( -- * Creating a Request AssociatePrincipalWithPortfolio (..), newAssociatePrincipalWithPortfolio, -- * Request Lenses associatePrincipalWithPortfolio_acceptLanguage, associatePrincipalWithPortfolio_portfolioId, associatePrincipalWithPortfolio_principalARN, associatePrincipalWithPortfolio_principalType, -- * Destructuring the Response AssociatePrincipalWithPortfolioResponse (..), newAssociatePrincipalWithPortfolioResponse, -- * Response Lenses associatePrincipalWithPortfolioResponse_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.ServiceCatalog.Types -- | /See:/ 'newAssociatePrincipalWithPortfolio' smart constructor. data AssociatePrincipalWithPortfolio = AssociatePrincipalWithPortfolio' { -- | The language code. -- -- - @en@ - English (default) -- -- - @jp@ - Japanese -- -- - @zh@ - Chinese acceptLanguage :: Prelude.Maybe Prelude.Text, -- | The portfolio identifier. portfolioId :: Prelude.Text, -- | The ARN of the principal (IAM user, role, or group). This field allows -- an ARN with no @accountID@ if @PrincipalType@ is @IAM_PATTERN@. -- -- You can associate multiple @IAM@ patterns even if the account has no -- principal with that name. This is useful in Principal Name Sharing if -- you want to share a principal without creating it in the account that -- owns the portfolio. principalARN :: Prelude.Text, -- | The principal type. The supported value is @IAM@ if you use a fully -- defined ARN, or @IAM_PATTERN@ if you use an ARN with no @accountID@. principalType :: PrincipalType } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'AssociatePrincipalWithPortfolio' 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: -- -- 'acceptLanguage', 'associatePrincipalWithPortfolio_acceptLanguage' - The language code. -- -- - @en@ - English (default) -- -- - @jp@ - Japanese -- -- - @zh@ - Chinese -- -- 'portfolioId', 'associatePrincipalWithPortfolio_portfolioId' - The portfolio identifier. -- -- 'principalARN', 'associatePrincipalWithPortfolio_principalARN' - The ARN of the principal (IAM user, role, or group). This field allows -- an ARN with no @accountID@ if @PrincipalType@ is @IAM_PATTERN@. -- -- You can associate multiple @IAM@ patterns even if the account has no -- principal with that name. This is useful in Principal Name Sharing if -- you want to share a principal without creating it in the account that -- owns the portfolio. -- -- 'principalType', 'associatePrincipalWithPortfolio_principalType' - The principal type. The supported value is @IAM@ if you use a fully -- defined ARN, or @IAM_PATTERN@ if you use an ARN with no @accountID@. newAssociatePrincipalWithPortfolio :: -- | 'portfolioId' Prelude.Text -> -- | 'principalARN' Prelude.Text -> -- | 'principalType' PrincipalType -> AssociatePrincipalWithPortfolio newAssociatePrincipalWithPortfolio pPortfolioId_ pPrincipalARN_ pPrincipalType_ = AssociatePrincipalWithPortfolio' { acceptLanguage = Prelude.Nothing, portfolioId = pPortfolioId_, principalARN = pPrincipalARN_, principalType = pPrincipalType_ } -- | The language code. -- -- - @en@ - English (default) -- -- - @jp@ - Japanese -- -- - @zh@ - Chinese associatePrincipalWithPortfolio_acceptLanguage :: Lens.Lens' AssociatePrincipalWithPortfolio (Prelude.Maybe Prelude.Text) associatePrincipalWithPortfolio_acceptLanguage = Lens.lens (\AssociatePrincipalWithPortfolio' {acceptLanguage} -> acceptLanguage) (\s@AssociatePrincipalWithPortfolio' {} a -> s {acceptLanguage = a} :: AssociatePrincipalWithPortfolio) -- | The portfolio identifier. associatePrincipalWithPortfolio_portfolioId :: Lens.Lens' AssociatePrincipalWithPortfolio Prelude.Text associatePrincipalWithPortfolio_portfolioId = Lens.lens (\AssociatePrincipalWithPortfolio' {portfolioId} -> portfolioId) (\s@AssociatePrincipalWithPortfolio' {} a -> s {portfolioId = a} :: AssociatePrincipalWithPortfolio) -- | The ARN of the principal (IAM user, role, or group). This field allows -- an ARN with no @accountID@ if @PrincipalType@ is @IAM_PATTERN@. -- -- You can associate multiple @IAM@ patterns even if the account has no -- principal with that name. This is useful in Principal Name Sharing if -- you want to share a principal without creating it in the account that -- owns the portfolio. associatePrincipalWithPortfolio_principalARN :: Lens.Lens' AssociatePrincipalWithPortfolio Prelude.Text associatePrincipalWithPortfolio_principalARN = Lens.lens (\AssociatePrincipalWithPortfolio' {principalARN} -> principalARN) (\s@AssociatePrincipalWithPortfolio' {} a -> s {principalARN = a} :: AssociatePrincipalWithPortfolio) -- | The principal type. The supported value is @IAM@ if you use a fully -- defined ARN, or @IAM_PATTERN@ if you use an ARN with no @accountID@. associatePrincipalWithPortfolio_principalType :: Lens.Lens' AssociatePrincipalWithPortfolio PrincipalType associatePrincipalWithPortfolio_principalType = Lens.lens (\AssociatePrincipalWithPortfolio' {principalType} -> principalType) (\s@AssociatePrincipalWithPortfolio' {} a -> s {principalType = a} :: AssociatePrincipalWithPortfolio) instance Core.AWSRequest AssociatePrincipalWithPortfolio where type AWSResponse AssociatePrincipalWithPortfolio = AssociatePrincipalWithPortfolioResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> AssociatePrincipalWithPortfolioResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable AssociatePrincipalWithPortfolio where hashWithSalt _salt AssociatePrincipalWithPortfolio' {..} = _salt `Prelude.hashWithSalt` acceptLanguage `Prelude.hashWithSalt` portfolioId `Prelude.hashWithSalt` principalARN `Prelude.hashWithSalt` principalType instance Prelude.NFData AssociatePrincipalWithPortfolio where rnf AssociatePrincipalWithPortfolio' {..} = Prelude.rnf acceptLanguage `Prelude.seq` Prelude.rnf portfolioId `Prelude.seq` Prelude.rnf principalARN `Prelude.seq` Prelude.rnf principalType instance Data.ToHeaders AssociatePrincipalWithPortfolio where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWS242ServiceCatalogService.AssociatePrincipalWithPortfolio" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON AssociatePrincipalWithPortfolio where toJSON AssociatePrincipalWithPortfolio' {..} = Data.object ( Prelude.catMaybes [ ("AcceptLanguage" Data..=) Prelude.<$> acceptLanguage, Prelude.Just ("PortfolioId" Data..= portfolioId), Prelude.Just ("PrincipalARN" Data..= principalARN), Prelude.Just ("PrincipalType" Data..= principalType) ] ) instance Data.ToPath AssociatePrincipalWithPortfolio where toPath = Prelude.const "/" instance Data.ToQuery AssociatePrincipalWithPortfolio where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newAssociatePrincipalWithPortfolioResponse' smart constructor. data AssociatePrincipalWithPortfolioResponse = AssociatePrincipalWithPortfolioResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'AssociatePrincipalWithPortfolioResponse' 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: -- -- 'httpStatus', 'associatePrincipalWithPortfolioResponse_httpStatus' - The response's http status code. newAssociatePrincipalWithPortfolioResponse :: -- | 'httpStatus' Prelude.Int -> AssociatePrincipalWithPortfolioResponse newAssociatePrincipalWithPortfolioResponse pHttpStatus_ = AssociatePrincipalWithPortfolioResponse' { httpStatus = pHttpStatus_ } -- | The response's http status code. associatePrincipalWithPortfolioResponse_httpStatus :: Lens.Lens' AssociatePrincipalWithPortfolioResponse Prelude.Int associatePrincipalWithPortfolioResponse_httpStatus = Lens.lens (\AssociatePrincipalWithPortfolioResponse' {httpStatus} -> httpStatus) (\s@AssociatePrincipalWithPortfolioResponse' {} a -> s {httpStatus = a} :: AssociatePrincipalWithPortfolioResponse) instance Prelude.NFData AssociatePrincipalWithPortfolioResponse where rnf AssociatePrincipalWithPortfolioResponse' {..} = Prelude.rnf httpStatus