{-# 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.EnableAWSOrganizationsAccess
-- Copyright   : (c) 2013-2023 Brendan Hay
-- License     : Mozilla Public License, v. 2.0.
-- Maintainer  : Brendan Hay
-- Stability   : auto-generated
-- Portability : non-portable (GHC extensions)
--
-- Enable portfolio sharing feature through Organizations. This API will
-- allow Service Catalog to receive updates on your organization in order
-- to sync your shares with the current structure. This API can only be
-- called by the management account in the organization.
--
-- When you call this API, Service Catalog calls
-- @organizations:EnableAWSServiceAccess@ on your behalf so that your
-- shares stay in sync with any changes in your Organizations structure.
--
-- Note that a delegated administrator is not authorized to invoke
-- @EnableAWSOrganizationsAccess@.
--
-- If you have previously disabled Organizations access for Service
-- Catalog, and then enable access again, the portfolio access permissions
-- might not sync with the latest changes to the organization structure.
-- Specifically, accounts that you removed from the organization after
-- disabling Service Catalog access, and before you enabled access again,
-- can retain access to the previously shared portfolio. As a result, an
-- account that has been removed from the organization might still be able
-- to create or manage Amazon Web Services resources when it is no longer
-- authorized to do so. Amazon Web Services is working to resolve this
-- issue.
module Amazonka.ServiceCatalog.EnableAWSOrganizationsAccess
  ( -- * Creating a Request
    EnableAWSOrganizationsAccess (..),
    newEnableAWSOrganizationsAccess,

    -- * Destructuring the Response
    EnableAWSOrganizationsAccessResponse (..),
    newEnableAWSOrganizationsAccessResponse,

    -- * Response Lenses
    enableAWSOrganizationsAccessResponse_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:/ 'newEnableAWSOrganizationsAccess' smart constructor.
data EnableAWSOrganizationsAccess = EnableAWSOrganizationsAccess'
  {
  }
  deriving (EnableAWSOrganizationsAccess
-> EnableAWSOrganizationsAccess -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: EnableAWSOrganizationsAccess
-> EnableAWSOrganizationsAccess -> Bool
$c/= :: EnableAWSOrganizationsAccess
-> EnableAWSOrganizationsAccess -> Bool
== :: EnableAWSOrganizationsAccess
-> EnableAWSOrganizationsAccess -> Bool
$c== :: EnableAWSOrganizationsAccess
-> EnableAWSOrganizationsAccess -> Bool
Prelude.Eq, ReadPrec [EnableAWSOrganizationsAccess]
ReadPrec EnableAWSOrganizationsAccess
Int -> ReadS EnableAWSOrganizationsAccess
ReadS [EnableAWSOrganizationsAccess]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [EnableAWSOrganizationsAccess]
$creadListPrec :: ReadPrec [EnableAWSOrganizationsAccess]
readPrec :: ReadPrec EnableAWSOrganizationsAccess
$creadPrec :: ReadPrec EnableAWSOrganizationsAccess
readList :: ReadS [EnableAWSOrganizationsAccess]
$creadList :: ReadS [EnableAWSOrganizationsAccess]
readsPrec :: Int -> ReadS EnableAWSOrganizationsAccess
$creadsPrec :: Int -> ReadS EnableAWSOrganizationsAccess
Prelude.Read, Int -> EnableAWSOrganizationsAccess -> ShowS
[EnableAWSOrganizationsAccess] -> ShowS
EnableAWSOrganizationsAccess -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [EnableAWSOrganizationsAccess] -> ShowS
$cshowList :: [EnableAWSOrganizationsAccess] -> ShowS
show :: EnableAWSOrganizationsAccess -> String
$cshow :: EnableAWSOrganizationsAccess -> String
showsPrec :: Int -> EnableAWSOrganizationsAccess -> ShowS
$cshowsPrec :: Int -> EnableAWSOrganizationsAccess -> ShowS
Prelude.Show, forall x.
Rep EnableAWSOrganizationsAccess x -> EnableAWSOrganizationsAccess
forall x.
EnableAWSOrganizationsAccess -> Rep EnableAWSOrganizationsAccess x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep EnableAWSOrganizationsAccess x -> EnableAWSOrganizationsAccess
$cfrom :: forall x.
EnableAWSOrganizationsAccess -> Rep EnableAWSOrganizationsAccess x
Prelude.Generic)

-- |
-- Create a value of 'EnableAWSOrganizationsAccess' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
newEnableAWSOrganizationsAccess ::
  EnableAWSOrganizationsAccess
newEnableAWSOrganizationsAccess :: EnableAWSOrganizationsAccess
newEnableAWSOrganizationsAccess =
  EnableAWSOrganizationsAccess
EnableAWSOrganizationsAccess'

instance Core.AWSRequest EnableAWSOrganizationsAccess where
  type
    AWSResponse EnableAWSOrganizationsAccess =
      EnableAWSOrganizationsAccessResponse
  request :: (Service -> Service)
-> EnableAWSOrganizationsAccess
-> Request EnableAWSOrganizationsAccess
request Service -> Service
overrides =
    forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.postJSON (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy EnableAWSOrganizationsAccess
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse EnableAWSOrganizationsAccess)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> () -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveEmpty
      ( \Int
s ResponseHeaders
h ()
x ->
          Int -> EnableAWSOrganizationsAccessResponse
EnableAWSOrganizationsAccessResponse'
            forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> (forall (f :: * -> *) a. Applicative f => a -> f a
Prelude.pure (forall a. Enum a => a -> Int
Prelude.fromEnum Int
s))
      )

instance
  Prelude.Hashable
    EnableAWSOrganizationsAccess
  where
  hashWithSalt :: Int -> EnableAWSOrganizationsAccess -> Int
hashWithSalt Int
_salt EnableAWSOrganizationsAccess
_ =
    Int
_salt forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` ()

instance Prelude.NFData EnableAWSOrganizationsAccess where
  rnf :: EnableAWSOrganizationsAccess -> ()
rnf EnableAWSOrganizationsAccess
_ = ()

instance Data.ToHeaders EnableAWSOrganizationsAccess where
  toHeaders :: EnableAWSOrganizationsAccess -> ResponseHeaders
toHeaders =
    forall a b. a -> b -> a
Prelude.const
      ( forall a. Monoid a => [a] -> a
Prelude.mconcat
          [ HeaderName
"X-Amz-Target"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"AWS242ServiceCatalogService.EnableAWSOrganizationsAccess" ::
                          Prelude.ByteString
                      ),
            HeaderName
"Content-Type"
              forall a. ToHeader a => HeaderName -> a -> ResponseHeaders
Data.=# ( ByteString
"application/x-amz-json-1.1" ::
                          Prelude.ByteString
                      )
          ]
      )

instance Data.ToJSON EnableAWSOrganizationsAccess where
  toJSON :: EnableAWSOrganizationsAccess -> Value
toJSON = forall a b. a -> b -> a
Prelude.const (Object -> Value
Data.Object forall a. Monoid a => a
Prelude.mempty)

instance Data.ToPath EnableAWSOrganizationsAccess where
  toPath :: EnableAWSOrganizationsAccess -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/"

instance Data.ToQuery EnableAWSOrganizationsAccess where
  toQuery :: EnableAWSOrganizationsAccess -> QueryString
toQuery = forall a b. a -> b -> a
Prelude.const forall a. Monoid a => a
Prelude.mempty

-- | /See:/ 'newEnableAWSOrganizationsAccessResponse' smart constructor.
data EnableAWSOrganizationsAccessResponse = EnableAWSOrganizationsAccessResponse'
  { -- | The response's http status code.
    EnableAWSOrganizationsAccessResponse -> Int
httpStatus :: Prelude.Int
  }
  deriving (EnableAWSOrganizationsAccessResponse
-> EnableAWSOrganizationsAccessResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: EnableAWSOrganizationsAccessResponse
-> EnableAWSOrganizationsAccessResponse -> Bool
$c/= :: EnableAWSOrganizationsAccessResponse
-> EnableAWSOrganizationsAccessResponse -> Bool
== :: EnableAWSOrganizationsAccessResponse
-> EnableAWSOrganizationsAccessResponse -> Bool
$c== :: EnableAWSOrganizationsAccessResponse
-> EnableAWSOrganizationsAccessResponse -> Bool
Prelude.Eq, ReadPrec [EnableAWSOrganizationsAccessResponse]
ReadPrec EnableAWSOrganizationsAccessResponse
Int -> ReadS EnableAWSOrganizationsAccessResponse
ReadS [EnableAWSOrganizationsAccessResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [EnableAWSOrganizationsAccessResponse]
$creadListPrec :: ReadPrec [EnableAWSOrganizationsAccessResponse]
readPrec :: ReadPrec EnableAWSOrganizationsAccessResponse
$creadPrec :: ReadPrec EnableAWSOrganizationsAccessResponse
readList :: ReadS [EnableAWSOrganizationsAccessResponse]
$creadList :: ReadS [EnableAWSOrganizationsAccessResponse]
readsPrec :: Int -> ReadS EnableAWSOrganizationsAccessResponse
$creadsPrec :: Int -> ReadS EnableAWSOrganizationsAccessResponse
Prelude.Read, Int -> EnableAWSOrganizationsAccessResponse -> ShowS
[EnableAWSOrganizationsAccessResponse] -> ShowS
EnableAWSOrganizationsAccessResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [EnableAWSOrganizationsAccessResponse] -> ShowS
$cshowList :: [EnableAWSOrganizationsAccessResponse] -> ShowS
show :: EnableAWSOrganizationsAccessResponse -> String
$cshow :: EnableAWSOrganizationsAccessResponse -> String
showsPrec :: Int -> EnableAWSOrganizationsAccessResponse -> ShowS
$cshowsPrec :: Int -> EnableAWSOrganizationsAccessResponse -> ShowS
Prelude.Show, forall x.
Rep EnableAWSOrganizationsAccessResponse x
-> EnableAWSOrganizationsAccessResponse
forall x.
EnableAWSOrganizationsAccessResponse
-> Rep EnableAWSOrganizationsAccessResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep EnableAWSOrganizationsAccessResponse x
-> EnableAWSOrganizationsAccessResponse
$cfrom :: forall x.
EnableAWSOrganizationsAccessResponse
-> Rep EnableAWSOrganizationsAccessResponse x
Prelude.Generic)

-- |
-- Create a value of 'EnableAWSOrganizationsAccessResponse' with all optional fields omitted.
--
-- Use <https://hackage.haskell.org/package/generic-lens generic-lens> or <https://hackage.haskell.org/package/optics optics> to modify other optional fields.
--
-- The following record fields are available, with the corresponding lenses provided
-- for backwards compatibility:
--
-- 'httpStatus', 'enableAWSOrganizationsAccessResponse_httpStatus' - The response's http status code.
newEnableAWSOrganizationsAccessResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  EnableAWSOrganizationsAccessResponse
newEnableAWSOrganizationsAccessResponse :: Int -> EnableAWSOrganizationsAccessResponse
newEnableAWSOrganizationsAccessResponse Int
pHttpStatus_ =
  EnableAWSOrganizationsAccessResponse'
    { $sel:httpStatus:EnableAWSOrganizationsAccessResponse' :: Int
httpStatus =
        Int
pHttpStatus_
    }

-- | The response's http status code.
enableAWSOrganizationsAccessResponse_httpStatus :: Lens.Lens' EnableAWSOrganizationsAccessResponse Prelude.Int
enableAWSOrganizationsAccessResponse_httpStatus :: Lens' EnableAWSOrganizationsAccessResponse Int
enableAWSOrganizationsAccessResponse_httpStatus = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\EnableAWSOrganizationsAccessResponse' {Int
httpStatus :: Int
$sel:httpStatus:EnableAWSOrganizationsAccessResponse' :: EnableAWSOrganizationsAccessResponse -> Int
httpStatus} -> Int
httpStatus) (\s :: EnableAWSOrganizationsAccessResponse
s@EnableAWSOrganizationsAccessResponse' {} Int
a -> EnableAWSOrganizationsAccessResponse
s {$sel:httpStatus:EnableAWSOrganizationsAccessResponse' :: Int
httpStatus = Int
a} :: EnableAWSOrganizationsAccessResponse)

instance
  Prelude.NFData
    EnableAWSOrganizationsAccessResponse
  where
  rnf :: EnableAWSOrganizationsAccessResponse -> ()
rnf EnableAWSOrganizationsAccessResponse' {Int
httpStatus :: Int
$sel:httpStatus:EnableAWSOrganizationsAccessResponse' :: EnableAWSOrganizationsAccessResponse -> Int
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus