{-# 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.AppMesh.CreateVirtualService
-- 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 a virtual service within a service mesh.
--
-- A virtual service is an abstraction of a real service that is provided
-- by a virtual node directly or indirectly by means of a virtual router.
-- Dependent services call your virtual service by its
-- @virtualServiceName@, and those requests are routed to the virtual node
-- or virtual router that is specified as the provider for the virtual
-- service.
--
-- For more information about virtual services, see
-- <https://docs.aws.amazon.com/app-mesh/latest/userguide/virtual_services.html Virtual services>.
module Amazonka.AppMesh.CreateVirtualService
  ( -- * Creating a Request
    CreateVirtualService (..),
    newCreateVirtualService,

    -- * Request Lenses
    createVirtualService_clientToken,
    createVirtualService_meshOwner,
    createVirtualService_tags,
    createVirtualService_meshName,
    createVirtualService_spec,
    createVirtualService_virtualServiceName,

    -- * Destructuring the Response
    CreateVirtualServiceResponse (..),
    newCreateVirtualServiceResponse,

    -- * Response Lenses
    createVirtualServiceResponse_httpStatus,
    createVirtualServiceResponse_virtualService,
  )
where

import Amazonka.AppMesh.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:/ 'newCreateVirtualService' smart constructor.
data CreateVirtualService = CreateVirtualService'
  { -- | Unique, case-sensitive identifier that you provide to ensure the
    -- idempotency of the request. Up to 36 letters, numbers, hyphens, and
    -- underscores are allowed.
    CreateVirtualService -> Maybe Text
clientToken :: Prelude.Maybe Prelude.Text,
    -- | The Amazon Web Services IAM account ID of the service mesh owner. If the
    -- account ID is not your own, then the account that you specify must share
    -- the mesh with your account before you can create the resource in the
    -- service mesh. For more information about mesh sharing, see
    -- <https://docs.aws.amazon.com/app-mesh/latest/userguide/sharing.html Working with shared meshes>.
    CreateVirtualService -> Maybe Text
meshOwner :: Prelude.Maybe Prelude.Text,
    -- | Optional metadata that you can apply to the virtual service to assist
    -- with categorization and organization. Each tag consists of a key and an
    -- optional value, both of which you define. Tag keys can have a maximum
    -- character length of 128 characters, and tag values can have a maximum
    -- length of 256 characters.
    CreateVirtualService -> Maybe [TagRef]
tags :: Prelude.Maybe [TagRef],
    -- | The name of the service mesh to create the virtual service in.
    CreateVirtualService -> Text
meshName :: Prelude.Text,
    -- | The virtual service specification to apply.
    CreateVirtualService -> VirtualServiceSpec
spec :: VirtualServiceSpec,
    -- | The name to use for the virtual service.
    CreateVirtualService -> Text
virtualServiceName :: Prelude.Text
  }
  deriving (CreateVirtualService -> CreateVirtualService -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateVirtualService -> CreateVirtualService -> Bool
$c/= :: CreateVirtualService -> CreateVirtualService -> Bool
== :: CreateVirtualService -> CreateVirtualService -> Bool
$c== :: CreateVirtualService -> CreateVirtualService -> Bool
Prelude.Eq, ReadPrec [CreateVirtualService]
ReadPrec CreateVirtualService
Int -> ReadS CreateVirtualService
ReadS [CreateVirtualService]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateVirtualService]
$creadListPrec :: ReadPrec [CreateVirtualService]
readPrec :: ReadPrec CreateVirtualService
$creadPrec :: ReadPrec CreateVirtualService
readList :: ReadS [CreateVirtualService]
$creadList :: ReadS [CreateVirtualService]
readsPrec :: Int -> ReadS CreateVirtualService
$creadsPrec :: Int -> ReadS CreateVirtualService
Prelude.Read, Int -> CreateVirtualService -> ShowS
[CreateVirtualService] -> ShowS
CreateVirtualService -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateVirtualService] -> ShowS
$cshowList :: [CreateVirtualService] -> ShowS
show :: CreateVirtualService -> String
$cshow :: CreateVirtualService -> String
showsPrec :: Int -> CreateVirtualService -> ShowS
$cshowsPrec :: Int -> CreateVirtualService -> ShowS
Prelude.Show, forall x. Rep CreateVirtualService x -> CreateVirtualService
forall x. CreateVirtualService -> Rep CreateVirtualService x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep CreateVirtualService x -> CreateVirtualService
$cfrom :: forall x. CreateVirtualService -> Rep CreateVirtualService x
Prelude.Generic)

-- |
-- Create a value of 'CreateVirtualService' 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:
--
-- 'clientToken', 'createVirtualService_clientToken' - Unique, case-sensitive identifier that you provide to ensure the
-- idempotency of the request. Up to 36 letters, numbers, hyphens, and
-- underscores are allowed.
--
-- 'meshOwner', 'createVirtualService_meshOwner' - The Amazon Web Services IAM account ID of the service mesh owner. If the
-- account ID is not your own, then the account that you specify must share
-- the mesh with your account before you can create the resource in the
-- service mesh. For more information about mesh sharing, see
-- <https://docs.aws.amazon.com/app-mesh/latest/userguide/sharing.html Working with shared meshes>.
--
-- 'tags', 'createVirtualService_tags' - Optional metadata that you can apply to the virtual service to assist
-- with categorization and organization. Each tag consists of a key and an
-- optional value, both of which you define. Tag keys can have a maximum
-- character length of 128 characters, and tag values can have a maximum
-- length of 256 characters.
--
-- 'meshName', 'createVirtualService_meshName' - The name of the service mesh to create the virtual service in.
--
-- 'spec', 'createVirtualService_spec' - The virtual service specification to apply.
--
-- 'virtualServiceName', 'createVirtualService_virtualServiceName' - The name to use for the virtual service.
newCreateVirtualService ::
  -- | 'meshName'
  Prelude.Text ->
  -- | 'spec'
  VirtualServiceSpec ->
  -- | 'virtualServiceName'
  Prelude.Text ->
  CreateVirtualService
newCreateVirtualService :: Text -> VirtualServiceSpec -> Text -> CreateVirtualService
newCreateVirtualService
  Text
pMeshName_
  VirtualServiceSpec
pSpec_
  Text
pVirtualServiceName_ =
    CreateVirtualService'
      { $sel:clientToken:CreateVirtualService' :: Maybe Text
clientToken =
          forall a. Maybe a
Prelude.Nothing,
        $sel:meshOwner:CreateVirtualService' :: Maybe Text
meshOwner = forall a. Maybe a
Prelude.Nothing,
        $sel:tags:CreateVirtualService' :: Maybe [TagRef]
tags = forall a. Maybe a
Prelude.Nothing,
        $sel:meshName:CreateVirtualService' :: Text
meshName = Text
pMeshName_,
        $sel:spec:CreateVirtualService' :: VirtualServiceSpec
spec = VirtualServiceSpec
pSpec_,
        $sel:virtualServiceName:CreateVirtualService' :: Text
virtualServiceName = Text
pVirtualServiceName_
      }

-- | Unique, case-sensitive identifier that you provide to ensure the
-- idempotency of the request. Up to 36 letters, numbers, hyphens, and
-- underscores are allowed.
createVirtualService_clientToken :: Lens.Lens' CreateVirtualService (Prelude.Maybe Prelude.Text)
createVirtualService_clientToken :: Lens' CreateVirtualService (Maybe Text)
createVirtualService_clientToken = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualService' {Maybe Text
clientToken :: Maybe Text
$sel:clientToken:CreateVirtualService' :: CreateVirtualService -> Maybe Text
clientToken} -> Maybe Text
clientToken) (\s :: CreateVirtualService
s@CreateVirtualService' {} Maybe Text
a -> CreateVirtualService
s {$sel:clientToken:CreateVirtualService' :: Maybe Text
clientToken = Maybe Text
a} :: CreateVirtualService)

-- | The Amazon Web Services IAM account ID of the service mesh owner. If the
-- account ID is not your own, then the account that you specify must share
-- the mesh with your account before you can create the resource in the
-- service mesh. For more information about mesh sharing, see
-- <https://docs.aws.amazon.com/app-mesh/latest/userguide/sharing.html Working with shared meshes>.
createVirtualService_meshOwner :: Lens.Lens' CreateVirtualService (Prelude.Maybe Prelude.Text)
createVirtualService_meshOwner :: Lens' CreateVirtualService (Maybe Text)
createVirtualService_meshOwner = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualService' {Maybe Text
meshOwner :: Maybe Text
$sel:meshOwner:CreateVirtualService' :: CreateVirtualService -> Maybe Text
meshOwner} -> Maybe Text
meshOwner) (\s :: CreateVirtualService
s@CreateVirtualService' {} Maybe Text
a -> CreateVirtualService
s {$sel:meshOwner:CreateVirtualService' :: Maybe Text
meshOwner = Maybe Text
a} :: CreateVirtualService)

-- | Optional metadata that you can apply to the virtual service to assist
-- with categorization and organization. Each tag consists of a key and an
-- optional value, both of which you define. Tag keys can have a maximum
-- character length of 128 characters, and tag values can have a maximum
-- length of 256 characters.
createVirtualService_tags :: Lens.Lens' CreateVirtualService (Prelude.Maybe [TagRef])
createVirtualService_tags :: Lens' CreateVirtualService (Maybe [TagRef])
createVirtualService_tags = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualService' {Maybe [TagRef]
tags :: Maybe [TagRef]
$sel:tags:CreateVirtualService' :: CreateVirtualService -> Maybe [TagRef]
tags} -> Maybe [TagRef]
tags) (\s :: CreateVirtualService
s@CreateVirtualService' {} Maybe [TagRef]
a -> CreateVirtualService
s {$sel:tags:CreateVirtualService' :: Maybe [TagRef]
tags = Maybe [TagRef]
a} :: CreateVirtualService) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (f :: * -> *) (g :: * -> *) s t a b.
(Functor f, Functor g) =>
AnIso s t a b -> Iso (f s) (g t) (f a) (g b)
Lens.mapping forall s t a b. (Coercible s a, Coercible t b) => Iso s t a b
Lens.coerced

-- | The name of the service mesh to create the virtual service in.
createVirtualService_meshName :: Lens.Lens' CreateVirtualService Prelude.Text
createVirtualService_meshName :: Lens' CreateVirtualService Text
createVirtualService_meshName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualService' {Text
meshName :: Text
$sel:meshName:CreateVirtualService' :: CreateVirtualService -> Text
meshName} -> Text
meshName) (\s :: CreateVirtualService
s@CreateVirtualService' {} Text
a -> CreateVirtualService
s {$sel:meshName:CreateVirtualService' :: Text
meshName = Text
a} :: CreateVirtualService)

-- | The virtual service specification to apply.
createVirtualService_spec :: Lens.Lens' CreateVirtualService VirtualServiceSpec
createVirtualService_spec :: Lens' CreateVirtualService VirtualServiceSpec
createVirtualService_spec = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualService' {VirtualServiceSpec
spec :: VirtualServiceSpec
$sel:spec:CreateVirtualService' :: CreateVirtualService -> VirtualServiceSpec
spec} -> VirtualServiceSpec
spec) (\s :: CreateVirtualService
s@CreateVirtualService' {} VirtualServiceSpec
a -> CreateVirtualService
s {$sel:spec:CreateVirtualService' :: VirtualServiceSpec
spec = VirtualServiceSpec
a} :: CreateVirtualService)

-- | The name to use for the virtual service.
createVirtualService_virtualServiceName :: Lens.Lens' CreateVirtualService Prelude.Text
createVirtualService_virtualServiceName :: Lens' CreateVirtualService Text
createVirtualService_virtualServiceName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualService' {Text
virtualServiceName :: Text
$sel:virtualServiceName:CreateVirtualService' :: CreateVirtualService -> Text
virtualServiceName} -> Text
virtualServiceName) (\s :: CreateVirtualService
s@CreateVirtualService' {} Text
a -> CreateVirtualService
s {$sel:virtualServiceName:CreateVirtualService' :: Text
virtualServiceName = Text
a} :: CreateVirtualService)

instance Core.AWSRequest CreateVirtualService where
  type
    AWSResponse CreateVirtualService =
      CreateVirtualServiceResponse
  request :: (Service -> Service)
-> CreateVirtualService -> Request CreateVirtualService
request Service -> Service
overrides =
    forall a. (ToRequest a, ToJSON a) => Service -> a -> Request a
Request.putJSON (Service -> Service
overrides Service
defaultService)
  response :: forall (m :: * -> *).
MonadResource m =>
(ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy CreateVirtualService
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse CreateVirtualService)))
response =
    forall (m :: * -> *) a.
MonadResource m =>
(Int -> ResponseHeaders -> Object -> Either String (AWSResponse a))
-> (ByteStringLazy -> IO ByteStringLazy)
-> Service
-> Proxy a
-> ClientResponse ClientBody
-> m (Either Error (ClientResponse (AWSResponse a)))
Response.receiveJSON
      ( \Int
s ResponseHeaders
h Object
x ->
          Int -> VirtualServiceData -> CreateVirtualServiceResponse
CreateVirtualServiceResponse'
            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))
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (forall a. FromJSON a => Object -> Either String a
Data.eitherParseJSON Object
x)
      )

instance Prelude.Hashable CreateVirtualService where
  hashWithSalt :: Int -> CreateVirtualService -> Int
hashWithSalt Int
_salt CreateVirtualService' {Maybe [TagRef]
Maybe Text
Text
VirtualServiceSpec
virtualServiceName :: Text
spec :: VirtualServiceSpec
meshName :: Text
tags :: Maybe [TagRef]
meshOwner :: Maybe Text
clientToken :: Maybe Text
$sel:virtualServiceName:CreateVirtualService' :: CreateVirtualService -> Text
$sel:spec:CreateVirtualService' :: CreateVirtualService -> VirtualServiceSpec
$sel:meshName:CreateVirtualService' :: CreateVirtualService -> Text
$sel:tags:CreateVirtualService' :: CreateVirtualService -> Maybe [TagRef]
$sel:meshOwner:CreateVirtualService' :: CreateVirtualService -> Maybe Text
$sel:clientToken:CreateVirtualService' :: CreateVirtualService -> Maybe Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
clientToken
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
meshOwner
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe [TagRef]
tags
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
meshName
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` VirtualServiceSpec
spec
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
virtualServiceName

instance Prelude.NFData CreateVirtualService where
  rnf :: CreateVirtualService -> ()
rnf CreateVirtualService' {Maybe [TagRef]
Maybe Text
Text
VirtualServiceSpec
virtualServiceName :: Text
spec :: VirtualServiceSpec
meshName :: Text
tags :: Maybe [TagRef]
meshOwner :: Maybe Text
clientToken :: Maybe Text
$sel:virtualServiceName:CreateVirtualService' :: CreateVirtualService -> Text
$sel:spec:CreateVirtualService' :: CreateVirtualService -> VirtualServiceSpec
$sel:meshName:CreateVirtualService' :: CreateVirtualService -> Text
$sel:tags:CreateVirtualService' :: CreateVirtualService -> Maybe [TagRef]
$sel:meshOwner:CreateVirtualService' :: CreateVirtualService -> Maybe Text
$sel:clientToken:CreateVirtualService' :: CreateVirtualService -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
clientToken
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
meshOwner
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe [TagRef]
tags
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
meshName
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf VirtualServiceSpec
spec
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
virtualServiceName

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

instance Data.ToJSON CreateVirtualService where
  toJSON :: CreateVirtualService -> Value
toJSON CreateVirtualService' {Maybe [TagRef]
Maybe Text
Text
VirtualServiceSpec
virtualServiceName :: Text
spec :: VirtualServiceSpec
meshName :: Text
tags :: Maybe [TagRef]
meshOwner :: Maybe Text
clientToken :: Maybe Text
$sel:virtualServiceName:CreateVirtualService' :: CreateVirtualService -> Text
$sel:spec:CreateVirtualService' :: CreateVirtualService -> VirtualServiceSpec
$sel:meshName:CreateVirtualService' :: CreateVirtualService -> Text
$sel:tags:CreateVirtualService' :: CreateVirtualService -> Maybe [TagRef]
$sel:meshOwner:CreateVirtualService' :: CreateVirtualService -> Maybe Text
$sel:clientToken:CreateVirtualService' :: CreateVirtualService -> Maybe Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (Key
"clientToken" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe Text
clientToken,
            (Key
"tags" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..=) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
Prelude.<$> Maybe [TagRef]
tags,
            forall a. a -> Maybe a
Prelude.Just (Key
"spec" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= VirtualServiceSpec
spec),
            forall a. a -> Maybe a
Prelude.Just
              (Key
"virtualServiceName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
virtualServiceName)
          ]
      )

instance Data.ToPath CreateVirtualService where
  toPath :: CreateVirtualService -> ByteString
toPath CreateVirtualService' {Maybe [TagRef]
Maybe Text
Text
VirtualServiceSpec
virtualServiceName :: Text
spec :: VirtualServiceSpec
meshName :: Text
tags :: Maybe [TagRef]
meshOwner :: Maybe Text
clientToken :: Maybe Text
$sel:virtualServiceName:CreateVirtualService' :: CreateVirtualService -> Text
$sel:spec:CreateVirtualService' :: CreateVirtualService -> VirtualServiceSpec
$sel:meshName:CreateVirtualService' :: CreateVirtualService -> Text
$sel:tags:CreateVirtualService' :: CreateVirtualService -> Maybe [TagRef]
$sel:meshOwner:CreateVirtualService' :: CreateVirtualService -> Maybe Text
$sel:clientToken:CreateVirtualService' :: CreateVirtualService -> Maybe Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat
      [ ByteString
"/v20190125/meshes/",
        forall a. ToByteString a => a -> ByteString
Data.toBS Text
meshName,
        ByteString
"/virtualServices"
      ]

instance Data.ToQuery CreateVirtualService where
  toQuery :: CreateVirtualService -> QueryString
toQuery CreateVirtualService' {Maybe [TagRef]
Maybe Text
Text
VirtualServiceSpec
virtualServiceName :: Text
spec :: VirtualServiceSpec
meshName :: Text
tags :: Maybe [TagRef]
meshOwner :: Maybe Text
clientToken :: Maybe Text
$sel:virtualServiceName:CreateVirtualService' :: CreateVirtualService -> Text
$sel:spec:CreateVirtualService' :: CreateVirtualService -> VirtualServiceSpec
$sel:meshName:CreateVirtualService' :: CreateVirtualService -> Text
$sel:tags:CreateVirtualService' :: CreateVirtualService -> Maybe [TagRef]
$sel:meshOwner:CreateVirtualService' :: CreateVirtualService -> Maybe Text
$sel:clientToken:CreateVirtualService' :: CreateVirtualService -> Maybe Text
..} =
    forall a. Monoid a => [a] -> a
Prelude.mconcat [ByteString
"meshOwner" forall a. ToQuery a => ByteString -> a -> QueryString
Data.=: Maybe Text
meshOwner]

-- |
--
-- /See:/ 'newCreateVirtualServiceResponse' smart constructor.
data CreateVirtualServiceResponse = CreateVirtualServiceResponse'
  { -- | The response's http status code.
    CreateVirtualServiceResponse -> Int
httpStatus :: Prelude.Int,
    -- | The full description of your virtual service following the create call.
    CreateVirtualServiceResponse -> VirtualServiceData
virtualService :: VirtualServiceData
  }
  deriving (CreateVirtualServiceResponse
-> CreateVirtualServiceResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateVirtualServiceResponse
-> CreateVirtualServiceResponse -> Bool
$c/= :: CreateVirtualServiceResponse
-> CreateVirtualServiceResponse -> Bool
== :: CreateVirtualServiceResponse
-> CreateVirtualServiceResponse -> Bool
$c== :: CreateVirtualServiceResponse
-> CreateVirtualServiceResponse -> Bool
Prelude.Eq, ReadPrec [CreateVirtualServiceResponse]
ReadPrec CreateVirtualServiceResponse
Int -> ReadS CreateVirtualServiceResponse
ReadS [CreateVirtualServiceResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateVirtualServiceResponse]
$creadListPrec :: ReadPrec [CreateVirtualServiceResponse]
readPrec :: ReadPrec CreateVirtualServiceResponse
$creadPrec :: ReadPrec CreateVirtualServiceResponse
readList :: ReadS [CreateVirtualServiceResponse]
$creadList :: ReadS [CreateVirtualServiceResponse]
readsPrec :: Int -> ReadS CreateVirtualServiceResponse
$creadsPrec :: Int -> ReadS CreateVirtualServiceResponse
Prelude.Read, Int -> CreateVirtualServiceResponse -> ShowS
[CreateVirtualServiceResponse] -> ShowS
CreateVirtualServiceResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateVirtualServiceResponse] -> ShowS
$cshowList :: [CreateVirtualServiceResponse] -> ShowS
show :: CreateVirtualServiceResponse -> String
$cshow :: CreateVirtualServiceResponse -> String
showsPrec :: Int -> CreateVirtualServiceResponse -> ShowS
$cshowsPrec :: Int -> CreateVirtualServiceResponse -> ShowS
Prelude.Show, forall x.
Rep CreateVirtualServiceResponse x -> CreateVirtualServiceResponse
forall x.
CreateVirtualServiceResponse -> Rep CreateVirtualServiceResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep CreateVirtualServiceResponse x -> CreateVirtualServiceResponse
$cfrom :: forall x.
CreateVirtualServiceResponse -> Rep CreateVirtualServiceResponse x
Prelude.Generic)

-- |
-- Create a value of 'CreateVirtualServiceResponse' 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', 'createVirtualServiceResponse_httpStatus' - The response's http status code.
--
-- 'virtualService', 'createVirtualServiceResponse_virtualService' - The full description of your virtual service following the create call.
newCreateVirtualServiceResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  -- | 'virtualService'
  VirtualServiceData ->
  CreateVirtualServiceResponse
newCreateVirtualServiceResponse :: Int -> VirtualServiceData -> CreateVirtualServiceResponse
newCreateVirtualServiceResponse
  Int
pHttpStatus_
  VirtualServiceData
pVirtualService_ =
    CreateVirtualServiceResponse'
      { $sel:httpStatus:CreateVirtualServiceResponse' :: Int
httpStatus =
          Int
pHttpStatus_,
        $sel:virtualService:CreateVirtualServiceResponse' :: VirtualServiceData
virtualService = VirtualServiceData
pVirtualService_
      }

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

-- | The full description of your virtual service following the create call.
createVirtualServiceResponse_virtualService :: Lens.Lens' CreateVirtualServiceResponse VirtualServiceData
createVirtualServiceResponse_virtualService :: Lens' CreateVirtualServiceResponse VirtualServiceData
createVirtualServiceResponse_virtualService = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateVirtualServiceResponse' {VirtualServiceData
virtualService :: VirtualServiceData
$sel:virtualService:CreateVirtualServiceResponse' :: CreateVirtualServiceResponse -> VirtualServiceData
virtualService} -> VirtualServiceData
virtualService) (\s :: CreateVirtualServiceResponse
s@CreateVirtualServiceResponse' {} VirtualServiceData
a -> CreateVirtualServiceResponse
s {$sel:virtualService:CreateVirtualServiceResponse' :: VirtualServiceData
virtualService = VirtualServiceData
a} :: CreateVirtualServiceResponse)

instance Prelude.NFData CreateVirtualServiceResponse where
  rnf :: CreateVirtualServiceResponse -> ()
rnf CreateVirtualServiceResponse' {Int
VirtualServiceData
virtualService :: VirtualServiceData
httpStatus :: Int
$sel:virtualService:CreateVirtualServiceResponse' :: CreateVirtualServiceResponse -> VirtualServiceData
$sel:httpStatus:CreateVirtualServiceResponse' :: CreateVirtualServiceResponse -> Int
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Int
httpStatus
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf VirtualServiceData
virtualService