{-# 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.Location.CreateRouteCalculator
-- 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 route calculator resource in your AWS account.
--
-- You can send requests to a route calculator resource to estimate travel
-- time, distance, and get directions. A route calculator sources traffic
-- and road network data from your chosen data provider.
--
-- If your application is tracking or routing assets you use in your
-- business, such as delivery vehicles or employees, you may only use HERE
-- as your geolocation provider. See section 82 of the
-- <http://aws.amazon.com/service-terms AWS service terms> for more
-- details.
module Amazonka.Location.CreateRouteCalculator
  ( -- * Creating a Request
    CreateRouteCalculator (..),
    newCreateRouteCalculator,

    -- * Request Lenses
    createRouteCalculator_description,
    createRouteCalculator_pricingPlan,
    createRouteCalculator_tags,
    createRouteCalculator_calculatorName,
    createRouteCalculator_dataSource,

    -- * Destructuring the Response
    CreateRouteCalculatorResponse (..),
    newCreateRouteCalculatorResponse,

    -- * Response Lenses
    createRouteCalculatorResponse_httpStatus,
    createRouteCalculatorResponse_calculatorArn,
    createRouteCalculatorResponse_calculatorName,
    createRouteCalculatorResponse_createTime,
  )
where

import qualified Amazonka.Core as Core
import qualified Amazonka.Core.Lens.Internal as Lens
import qualified Amazonka.Data as Data
import Amazonka.Location.Types
import qualified Amazonka.Prelude as Prelude
import qualified Amazonka.Request as Request
import qualified Amazonka.Response as Response

-- | /See:/ 'newCreateRouteCalculator' smart constructor.
data CreateRouteCalculator = CreateRouteCalculator'
  { -- | The optional description for the route calculator resource.
    CreateRouteCalculator -> Maybe Text
description :: Prelude.Maybe Prelude.Text,
    -- | No longer used. If included, the only allowed value is
    -- @RequestBasedUsage@.
    CreateRouteCalculator -> Maybe PricingPlan
pricingPlan :: Prelude.Maybe PricingPlan,
    -- | Applies one or more tags to the route calculator resource. A tag is a
    -- key-value pair helps manage, identify, search, and filter your resources
    -- by labelling them.
    --
    -- -   For example: { @\"tag1\" : \"value1\"@, @\"tag2\" : \"value2\"@}
    --
    -- Format: @\"key\" : \"value\"@
    --
    -- Restrictions:
    --
    -- -   Maximum 50 tags per resource
    --
    -- -   Each resource tag must be unique with a maximum of one value.
    --
    -- -   Maximum key length: 128 Unicode characters in UTF-8
    --
    -- -   Maximum value length: 256 Unicode characters in UTF-8
    --
    -- -   Can use alphanumeric characters (A–Z, a–z, 0–9), and the following
    --     characters: + - = . _ : \/ \@.
    --
    -- -   Cannot use \"aws:\" as a prefix for a key.
    CreateRouteCalculator -> Maybe (HashMap Text Text)
tags :: Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text),
    -- | The name of the route calculator resource.
    --
    -- Requirements:
    --
    -- -   Can use alphanumeric characters (A–Z, a–z, 0–9) , hyphens (-),
    --     periods (.), and underscores (_).
    --
    -- -   Must be a unique Route calculator resource name.
    --
    -- -   No spaces allowed. For example, @ExampleRouteCalculator@.
    CreateRouteCalculator -> Text
calculatorName :: Prelude.Text,
    -- | Specifies the data provider of traffic and road network data.
    --
    -- This field is case-sensitive. Enter the valid values as shown. For
    -- example, entering @HERE@ returns an error. Route calculators that use
    -- Esri as a data source only calculate routes that are shorter than 400
    -- km.
    --
    -- Valid values include:
    --
    -- -   @Esri@ – For additional information about
    --     <https://docs.aws.amazon.com/location/latest/developerguide/esri.html Esri>\'s
    --     coverage in your region of interest, see
    --     <https://doc.arcgis.com/en/arcgis-online/reference/network-coverage.htm Esri details on street networks and traffic coverage>.
    --
    -- -   @Here@ – For additional information about
    --     <https://docs.aws.amazon.com/location/latest/developerguide/HERE.html HERE Technologies>\'
    --     coverage in your region of interest, see
    --     <https://developer.here.com/documentation/routing-api/dev_guide/topics/coverage/car-routing.html HERE car routing coverage>
    --     and
    --     <https://developer.here.com/documentation/routing-api/dev_guide/topics/coverage/truck-routing.html HERE truck routing coverage>.
    --
    -- For additional information , see
    -- <https://docs.aws.amazon.com/location/latest/developerguide/what-is-data-provider.html Data providers>
    -- on the /Amazon Location Service Developer Guide/.
    CreateRouteCalculator -> Text
dataSource :: Prelude.Text
  }
  deriving (CreateRouteCalculator -> CreateRouteCalculator -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateRouteCalculator -> CreateRouteCalculator -> Bool
$c/= :: CreateRouteCalculator -> CreateRouteCalculator -> Bool
== :: CreateRouteCalculator -> CreateRouteCalculator -> Bool
$c== :: CreateRouteCalculator -> CreateRouteCalculator -> Bool
Prelude.Eq, ReadPrec [CreateRouteCalculator]
ReadPrec CreateRouteCalculator
Int -> ReadS CreateRouteCalculator
ReadS [CreateRouteCalculator]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateRouteCalculator]
$creadListPrec :: ReadPrec [CreateRouteCalculator]
readPrec :: ReadPrec CreateRouteCalculator
$creadPrec :: ReadPrec CreateRouteCalculator
readList :: ReadS [CreateRouteCalculator]
$creadList :: ReadS [CreateRouteCalculator]
readsPrec :: Int -> ReadS CreateRouteCalculator
$creadsPrec :: Int -> ReadS CreateRouteCalculator
Prelude.Read, Int -> CreateRouteCalculator -> ShowS
[CreateRouteCalculator] -> ShowS
CreateRouteCalculator -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateRouteCalculator] -> ShowS
$cshowList :: [CreateRouteCalculator] -> ShowS
show :: CreateRouteCalculator -> String
$cshow :: CreateRouteCalculator -> String
showsPrec :: Int -> CreateRouteCalculator -> ShowS
$cshowsPrec :: Int -> CreateRouteCalculator -> ShowS
Prelude.Show, forall x. Rep CreateRouteCalculator x -> CreateRouteCalculator
forall x. CreateRouteCalculator -> Rep CreateRouteCalculator x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x. Rep CreateRouteCalculator x -> CreateRouteCalculator
$cfrom :: forall x. CreateRouteCalculator -> Rep CreateRouteCalculator x
Prelude.Generic)

-- |
-- Create a value of 'CreateRouteCalculator' 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:
--
-- 'description', 'createRouteCalculator_description' - The optional description for the route calculator resource.
--
-- 'pricingPlan', 'createRouteCalculator_pricingPlan' - No longer used. If included, the only allowed value is
-- @RequestBasedUsage@.
--
-- 'tags', 'createRouteCalculator_tags' - Applies one or more tags to the route calculator resource. A tag is a
-- key-value pair helps manage, identify, search, and filter your resources
-- by labelling them.
--
-- -   For example: { @\"tag1\" : \"value1\"@, @\"tag2\" : \"value2\"@}
--
-- Format: @\"key\" : \"value\"@
--
-- Restrictions:
--
-- -   Maximum 50 tags per resource
--
-- -   Each resource tag must be unique with a maximum of one value.
--
-- -   Maximum key length: 128 Unicode characters in UTF-8
--
-- -   Maximum value length: 256 Unicode characters in UTF-8
--
-- -   Can use alphanumeric characters (A–Z, a–z, 0–9), and the following
--     characters: + - = . _ : \/ \@.
--
-- -   Cannot use \"aws:\" as a prefix for a key.
--
-- 'calculatorName', 'createRouteCalculator_calculatorName' - The name of the route calculator resource.
--
-- Requirements:
--
-- -   Can use alphanumeric characters (A–Z, a–z, 0–9) , hyphens (-),
--     periods (.), and underscores (_).
--
-- -   Must be a unique Route calculator resource name.
--
-- -   No spaces allowed. For example, @ExampleRouteCalculator@.
--
-- 'dataSource', 'createRouteCalculator_dataSource' - Specifies the data provider of traffic and road network data.
--
-- This field is case-sensitive. Enter the valid values as shown. For
-- example, entering @HERE@ returns an error. Route calculators that use
-- Esri as a data source only calculate routes that are shorter than 400
-- km.
--
-- Valid values include:
--
-- -   @Esri@ – For additional information about
--     <https://docs.aws.amazon.com/location/latest/developerguide/esri.html Esri>\'s
--     coverage in your region of interest, see
--     <https://doc.arcgis.com/en/arcgis-online/reference/network-coverage.htm Esri details on street networks and traffic coverage>.
--
-- -   @Here@ – For additional information about
--     <https://docs.aws.amazon.com/location/latest/developerguide/HERE.html HERE Technologies>\'
--     coverage in your region of interest, see
--     <https://developer.here.com/documentation/routing-api/dev_guide/topics/coverage/car-routing.html HERE car routing coverage>
--     and
--     <https://developer.here.com/documentation/routing-api/dev_guide/topics/coverage/truck-routing.html HERE truck routing coverage>.
--
-- For additional information , see
-- <https://docs.aws.amazon.com/location/latest/developerguide/what-is-data-provider.html Data providers>
-- on the /Amazon Location Service Developer Guide/.
newCreateRouteCalculator ::
  -- | 'calculatorName'
  Prelude.Text ->
  -- | 'dataSource'
  Prelude.Text ->
  CreateRouteCalculator
newCreateRouteCalculator :: Text -> Text -> CreateRouteCalculator
newCreateRouteCalculator
  Text
pCalculatorName_
  Text
pDataSource_ =
    CreateRouteCalculator'
      { $sel:description:CreateRouteCalculator' :: Maybe Text
description =
          forall a. Maybe a
Prelude.Nothing,
        $sel:pricingPlan:CreateRouteCalculator' :: Maybe PricingPlan
pricingPlan = forall a. Maybe a
Prelude.Nothing,
        $sel:tags:CreateRouteCalculator' :: Maybe (HashMap Text Text)
tags = forall a. Maybe a
Prelude.Nothing,
        $sel:calculatorName:CreateRouteCalculator' :: Text
calculatorName = Text
pCalculatorName_,
        $sel:dataSource:CreateRouteCalculator' :: Text
dataSource = Text
pDataSource_
      }

-- | The optional description for the route calculator resource.
createRouteCalculator_description :: Lens.Lens' CreateRouteCalculator (Prelude.Maybe Prelude.Text)
createRouteCalculator_description :: Lens' CreateRouteCalculator (Maybe Text)
createRouteCalculator_description = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateRouteCalculator' {Maybe Text
description :: Maybe Text
$sel:description:CreateRouteCalculator' :: CreateRouteCalculator -> Maybe Text
description} -> Maybe Text
description) (\s :: CreateRouteCalculator
s@CreateRouteCalculator' {} Maybe Text
a -> CreateRouteCalculator
s {$sel:description:CreateRouteCalculator' :: Maybe Text
description = Maybe Text
a} :: CreateRouteCalculator)

-- | No longer used. If included, the only allowed value is
-- @RequestBasedUsage@.
createRouteCalculator_pricingPlan :: Lens.Lens' CreateRouteCalculator (Prelude.Maybe PricingPlan)
createRouteCalculator_pricingPlan :: Lens' CreateRouteCalculator (Maybe PricingPlan)
createRouteCalculator_pricingPlan = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateRouteCalculator' {Maybe PricingPlan
pricingPlan :: Maybe PricingPlan
$sel:pricingPlan:CreateRouteCalculator' :: CreateRouteCalculator -> Maybe PricingPlan
pricingPlan} -> Maybe PricingPlan
pricingPlan) (\s :: CreateRouteCalculator
s@CreateRouteCalculator' {} Maybe PricingPlan
a -> CreateRouteCalculator
s {$sel:pricingPlan:CreateRouteCalculator' :: Maybe PricingPlan
pricingPlan = Maybe PricingPlan
a} :: CreateRouteCalculator)

-- | Applies one or more tags to the route calculator resource. A tag is a
-- key-value pair helps manage, identify, search, and filter your resources
-- by labelling them.
--
-- -   For example: { @\"tag1\" : \"value1\"@, @\"tag2\" : \"value2\"@}
--
-- Format: @\"key\" : \"value\"@
--
-- Restrictions:
--
-- -   Maximum 50 tags per resource
--
-- -   Each resource tag must be unique with a maximum of one value.
--
-- -   Maximum key length: 128 Unicode characters in UTF-8
--
-- -   Maximum value length: 256 Unicode characters in UTF-8
--
-- -   Can use alphanumeric characters (A–Z, a–z, 0–9), and the following
--     characters: + - = . _ : \/ \@.
--
-- -   Cannot use \"aws:\" as a prefix for a key.
createRouteCalculator_tags :: Lens.Lens' CreateRouteCalculator (Prelude.Maybe (Prelude.HashMap Prelude.Text Prelude.Text))
createRouteCalculator_tags :: Lens' CreateRouteCalculator (Maybe (HashMap Text Text))
createRouteCalculator_tags = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateRouteCalculator' {Maybe (HashMap Text Text)
tags :: Maybe (HashMap Text Text)
$sel:tags:CreateRouteCalculator' :: CreateRouteCalculator -> Maybe (HashMap Text Text)
tags} -> Maybe (HashMap Text Text)
tags) (\s :: CreateRouteCalculator
s@CreateRouteCalculator' {} Maybe (HashMap Text Text)
a -> CreateRouteCalculator
s {$sel:tags:CreateRouteCalculator' :: Maybe (HashMap Text Text)
tags = Maybe (HashMap Text Text)
a} :: CreateRouteCalculator) 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 route calculator resource.
--
-- Requirements:
--
-- -   Can use alphanumeric characters (A–Z, a–z, 0–9) , hyphens (-),
--     periods (.), and underscores (_).
--
-- -   Must be a unique Route calculator resource name.
--
-- -   No spaces allowed. For example, @ExampleRouteCalculator@.
createRouteCalculator_calculatorName :: Lens.Lens' CreateRouteCalculator Prelude.Text
createRouteCalculator_calculatorName :: Lens' CreateRouteCalculator Text
createRouteCalculator_calculatorName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateRouteCalculator' {Text
calculatorName :: Text
$sel:calculatorName:CreateRouteCalculator' :: CreateRouteCalculator -> Text
calculatorName} -> Text
calculatorName) (\s :: CreateRouteCalculator
s@CreateRouteCalculator' {} Text
a -> CreateRouteCalculator
s {$sel:calculatorName:CreateRouteCalculator' :: Text
calculatorName = Text
a} :: CreateRouteCalculator)

-- | Specifies the data provider of traffic and road network data.
--
-- This field is case-sensitive. Enter the valid values as shown. For
-- example, entering @HERE@ returns an error. Route calculators that use
-- Esri as a data source only calculate routes that are shorter than 400
-- km.
--
-- Valid values include:
--
-- -   @Esri@ – For additional information about
--     <https://docs.aws.amazon.com/location/latest/developerguide/esri.html Esri>\'s
--     coverage in your region of interest, see
--     <https://doc.arcgis.com/en/arcgis-online/reference/network-coverage.htm Esri details on street networks and traffic coverage>.
--
-- -   @Here@ – For additional information about
--     <https://docs.aws.amazon.com/location/latest/developerguide/HERE.html HERE Technologies>\'
--     coverage in your region of interest, see
--     <https://developer.here.com/documentation/routing-api/dev_guide/topics/coverage/car-routing.html HERE car routing coverage>
--     and
--     <https://developer.here.com/documentation/routing-api/dev_guide/topics/coverage/truck-routing.html HERE truck routing coverage>.
--
-- For additional information , see
-- <https://docs.aws.amazon.com/location/latest/developerguide/what-is-data-provider.html Data providers>
-- on the /Amazon Location Service Developer Guide/.
createRouteCalculator_dataSource :: Lens.Lens' CreateRouteCalculator Prelude.Text
createRouteCalculator_dataSource :: Lens' CreateRouteCalculator Text
createRouteCalculator_dataSource = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateRouteCalculator' {Text
dataSource :: Text
$sel:dataSource:CreateRouteCalculator' :: CreateRouteCalculator -> Text
dataSource} -> Text
dataSource) (\s :: CreateRouteCalculator
s@CreateRouteCalculator' {} Text
a -> CreateRouteCalculator
s {$sel:dataSource:CreateRouteCalculator' :: Text
dataSource = Text
a} :: CreateRouteCalculator)

instance Core.AWSRequest CreateRouteCalculator where
  type
    AWSResponse CreateRouteCalculator =
      CreateRouteCalculatorResponse
  request :: (Service -> Service)
-> CreateRouteCalculator -> Request CreateRouteCalculator
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 CreateRouteCalculator
-> ClientResponse ClientBody
-> m (Either
        Error (ClientResponse (AWSResponse CreateRouteCalculator)))
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 -> Text -> Text -> ISO8601 -> CreateRouteCalculatorResponse
CreateRouteCalculatorResponse'
            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.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"CalculatorArn")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"CalculatorName")
            forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
Prelude.<*> (Object
x forall a. FromJSON a => Object -> Key -> Either String a
Data..:> Key
"CreateTime")
      )

instance Prelude.Hashable CreateRouteCalculator where
  hashWithSalt :: Int -> CreateRouteCalculator -> Int
hashWithSalt Int
_salt CreateRouteCalculator' {Maybe Text
Maybe (HashMap Text Text)
Maybe PricingPlan
Text
dataSource :: Text
calculatorName :: Text
tags :: Maybe (HashMap Text Text)
pricingPlan :: Maybe PricingPlan
description :: Maybe Text
$sel:dataSource:CreateRouteCalculator' :: CreateRouteCalculator -> Text
$sel:calculatorName:CreateRouteCalculator' :: CreateRouteCalculator -> Text
$sel:tags:CreateRouteCalculator' :: CreateRouteCalculator -> Maybe (HashMap Text Text)
$sel:pricingPlan:CreateRouteCalculator' :: CreateRouteCalculator -> Maybe PricingPlan
$sel:description:CreateRouteCalculator' :: CreateRouteCalculator -> Maybe Text
..} =
    Int
_salt
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe Text
description
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe PricingPlan
pricingPlan
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Maybe (HashMap Text Text)
tags
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
calculatorName
      forall a. Hashable a => Int -> a -> Int
`Prelude.hashWithSalt` Text
dataSource

instance Prelude.NFData CreateRouteCalculator where
  rnf :: CreateRouteCalculator -> ()
rnf CreateRouteCalculator' {Maybe Text
Maybe (HashMap Text Text)
Maybe PricingPlan
Text
dataSource :: Text
calculatorName :: Text
tags :: Maybe (HashMap Text Text)
pricingPlan :: Maybe PricingPlan
description :: Maybe Text
$sel:dataSource:CreateRouteCalculator' :: CreateRouteCalculator -> Text
$sel:calculatorName:CreateRouteCalculator' :: CreateRouteCalculator -> Text
$sel:tags:CreateRouteCalculator' :: CreateRouteCalculator -> Maybe (HashMap Text Text)
$sel:pricingPlan:CreateRouteCalculator' :: CreateRouteCalculator -> Maybe PricingPlan
$sel:description:CreateRouteCalculator' :: CreateRouteCalculator -> Maybe Text
..} =
    forall a. NFData a => a -> ()
Prelude.rnf Maybe Text
description
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe PricingPlan
pricingPlan
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Maybe (HashMap Text Text)
tags
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
calculatorName
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
dataSource

instance Data.ToHeaders CreateRouteCalculator where
  toHeaders :: CreateRouteCalculator -> 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 CreateRouteCalculator where
  toJSON :: CreateRouteCalculator -> Value
toJSON CreateRouteCalculator' {Maybe Text
Maybe (HashMap Text Text)
Maybe PricingPlan
Text
dataSource :: Text
calculatorName :: Text
tags :: Maybe (HashMap Text Text)
pricingPlan :: Maybe PricingPlan
description :: Maybe Text
$sel:dataSource:CreateRouteCalculator' :: CreateRouteCalculator -> Text
$sel:calculatorName:CreateRouteCalculator' :: CreateRouteCalculator -> Text
$sel:tags:CreateRouteCalculator' :: CreateRouteCalculator -> Maybe (HashMap Text Text)
$sel:pricingPlan:CreateRouteCalculator' :: CreateRouteCalculator -> Maybe PricingPlan
$sel:description:CreateRouteCalculator' :: CreateRouteCalculator -> Maybe Text
..} =
    [Pair] -> Value
Data.object
      ( forall a. [Maybe a] -> [a]
Prelude.catMaybes
          [ (Key
"Description" 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
description,
            (Key
"PricingPlan" 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 PricingPlan
pricingPlan,
            (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 (HashMap Text Text)
tags,
            forall a. a -> Maybe a
Prelude.Just
              (Key
"CalculatorName" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
calculatorName),
            forall a. a -> Maybe a
Prelude.Just (Key
"DataSource" forall kv v. (KeyValue kv, ToJSON v) => Key -> v -> kv
Data..= Text
dataSource)
          ]
      )

instance Data.ToPath CreateRouteCalculator where
  toPath :: CreateRouteCalculator -> ByteString
toPath = forall a b. a -> b -> a
Prelude.const ByteString
"/routes/v0/calculators"

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

-- | /See:/ 'newCreateRouteCalculatorResponse' smart constructor.
data CreateRouteCalculatorResponse = CreateRouteCalculatorResponse'
  { -- | The response's http status code.
    CreateRouteCalculatorResponse -> Int
httpStatus :: Prelude.Int,
    -- | The Amazon Resource Name (ARN) for the route calculator resource. Use
    -- the ARN when you specify a resource across all AWS.
    --
    -- -   Format example:
    --     @arn:aws:geo:region:account-id:route-calculator\/ExampleCalculator@
    CreateRouteCalculatorResponse -> Text
calculatorArn :: Prelude.Text,
    -- | The name of the route calculator resource.
    --
    -- -   For example, @ExampleRouteCalculator@.
    CreateRouteCalculatorResponse -> Text
calculatorName :: Prelude.Text,
    -- | The timestamp when the route calculator resource was created in
    -- <https://www.iso.org/iso-8601-date-and-time-format.html ISO 8601>
    -- format: @YYYY-MM-DDThh:mm:ss.sssZ@.
    --
    -- -   For example, @2020–07-2T12:15:20.000Z+01:00@
    CreateRouteCalculatorResponse -> ISO8601
createTime :: Data.ISO8601
  }
  deriving (CreateRouteCalculatorResponse
-> CreateRouteCalculatorResponse -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: CreateRouteCalculatorResponse
-> CreateRouteCalculatorResponse -> Bool
$c/= :: CreateRouteCalculatorResponse
-> CreateRouteCalculatorResponse -> Bool
== :: CreateRouteCalculatorResponse
-> CreateRouteCalculatorResponse -> Bool
$c== :: CreateRouteCalculatorResponse
-> CreateRouteCalculatorResponse -> Bool
Prelude.Eq, ReadPrec [CreateRouteCalculatorResponse]
ReadPrec CreateRouteCalculatorResponse
Int -> ReadS CreateRouteCalculatorResponse
ReadS [CreateRouteCalculatorResponse]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [CreateRouteCalculatorResponse]
$creadListPrec :: ReadPrec [CreateRouteCalculatorResponse]
readPrec :: ReadPrec CreateRouteCalculatorResponse
$creadPrec :: ReadPrec CreateRouteCalculatorResponse
readList :: ReadS [CreateRouteCalculatorResponse]
$creadList :: ReadS [CreateRouteCalculatorResponse]
readsPrec :: Int -> ReadS CreateRouteCalculatorResponse
$creadsPrec :: Int -> ReadS CreateRouteCalculatorResponse
Prelude.Read, Int -> CreateRouteCalculatorResponse -> ShowS
[CreateRouteCalculatorResponse] -> ShowS
CreateRouteCalculatorResponse -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [CreateRouteCalculatorResponse] -> ShowS
$cshowList :: [CreateRouteCalculatorResponse] -> ShowS
show :: CreateRouteCalculatorResponse -> String
$cshow :: CreateRouteCalculatorResponse -> String
showsPrec :: Int -> CreateRouteCalculatorResponse -> ShowS
$cshowsPrec :: Int -> CreateRouteCalculatorResponse -> ShowS
Prelude.Show, forall x.
Rep CreateRouteCalculatorResponse x
-> CreateRouteCalculatorResponse
forall x.
CreateRouteCalculatorResponse
-> Rep CreateRouteCalculatorResponse x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cto :: forall x.
Rep CreateRouteCalculatorResponse x
-> CreateRouteCalculatorResponse
$cfrom :: forall x.
CreateRouteCalculatorResponse
-> Rep CreateRouteCalculatorResponse x
Prelude.Generic)

-- |
-- Create a value of 'CreateRouteCalculatorResponse' 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', 'createRouteCalculatorResponse_httpStatus' - The response's http status code.
--
-- 'calculatorArn', 'createRouteCalculatorResponse_calculatorArn' - The Amazon Resource Name (ARN) for the route calculator resource. Use
-- the ARN when you specify a resource across all AWS.
--
-- -   Format example:
--     @arn:aws:geo:region:account-id:route-calculator\/ExampleCalculator@
--
-- 'calculatorName', 'createRouteCalculatorResponse_calculatorName' - The name of the route calculator resource.
--
-- -   For example, @ExampleRouteCalculator@.
--
-- 'createTime', 'createRouteCalculatorResponse_createTime' - The timestamp when the route calculator resource was created in
-- <https://www.iso.org/iso-8601-date-and-time-format.html ISO 8601>
-- format: @YYYY-MM-DDThh:mm:ss.sssZ@.
--
-- -   For example, @2020–07-2T12:15:20.000Z+01:00@
newCreateRouteCalculatorResponse ::
  -- | 'httpStatus'
  Prelude.Int ->
  -- | 'calculatorArn'
  Prelude.Text ->
  -- | 'calculatorName'
  Prelude.Text ->
  -- | 'createTime'
  Prelude.UTCTime ->
  CreateRouteCalculatorResponse
newCreateRouteCalculatorResponse :: Int -> Text -> Text -> UTCTime -> CreateRouteCalculatorResponse
newCreateRouteCalculatorResponse
  Int
pHttpStatus_
  Text
pCalculatorArn_
  Text
pCalculatorName_
  UTCTime
pCreateTime_ =
    CreateRouteCalculatorResponse'
      { $sel:httpStatus:CreateRouteCalculatorResponse' :: Int
httpStatus =
          Int
pHttpStatus_,
        $sel:calculatorArn:CreateRouteCalculatorResponse' :: Text
calculatorArn = Text
pCalculatorArn_,
        $sel:calculatorName:CreateRouteCalculatorResponse' :: Text
calculatorName = Text
pCalculatorName_,
        $sel:createTime:CreateRouteCalculatorResponse' :: ISO8601
createTime = forall (a :: Format). Iso' (Time a) UTCTime
Data._Time forall t b. AReview t b -> b -> t
Lens.# UTCTime
pCreateTime_
      }

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

-- | The Amazon Resource Name (ARN) for the route calculator resource. Use
-- the ARN when you specify a resource across all AWS.
--
-- -   Format example:
--     @arn:aws:geo:region:account-id:route-calculator\/ExampleCalculator@
createRouteCalculatorResponse_calculatorArn :: Lens.Lens' CreateRouteCalculatorResponse Prelude.Text
createRouteCalculatorResponse_calculatorArn :: Lens' CreateRouteCalculatorResponse Text
createRouteCalculatorResponse_calculatorArn = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateRouteCalculatorResponse' {Text
calculatorArn :: Text
$sel:calculatorArn:CreateRouteCalculatorResponse' :: CreateRouteCalculatorResponse -> Text
calculatorArn} -> Text
calculatorArn) (\s :: CreateRouteCalculatorResponse
s@CreateRouteCalculatorResponse' {} Text
a -> CreateRouteCalculatorResponse
s {$sel:calculatorArn:CreateRouteCalculatorResponse' :: Text
calculatorArn = Text
a} :: CreateRouteCalculatorResponse)

-- | The name of the route calculator resource.
--
-- -   For example, @ExampleRouteCalculator@.
createRouteCalculatorResponse_calculatorName :: Lens.Lens' CreateRouteCalculatorResponse Prelude.Text
createRouteCalculatorResponse_calculatorName :: Lens' CreateRouteCalculatorResponse Text
createRouteCalculatorResponse_calculatorName = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateRouteCalculatorResponse' {Text
calculatorName :: Text
$sel:calculatorName:CreateRouteCalculatorResponse' :: CreateRouteCalculatorResponse -> Text
calculatorName} -> Text
calculatorName) (\s :: CreateRouteCalculatorResponse
s@CreateRouteCalculatorResponse' {} Text
a -> CreateRouteCalculatorResponse
s {$sel:calculatorName:CreateRouteCalculatorResponse' :: Text
calculatorName = Text
a} :: CreateRouteCalculatorResponse)

-- | The timestamp when the route calculator resource was created in
-- <https://www.iso.org/iso-8601-date-and-time-format.html ISO 8601>
-- format: @YYYY-MM-DDThh:mm:ss.sssZ@.
--
-- -   For example, @2020–07-2T12:15:20.000Z+01:00@
createRouteCalculatorResponse_createTime :: Lens.Lens' CreateRouteCalculatorResponse Prelude.UTCTime
createRouteCalculatorResponse_createTime :: Lens' CreateRouteCalculatorResponse UTCTime
createRouteCalculatorResponse_createTime = forall s a b t. (s -> a) -> (s -> b -> t) -> Lens s t a b
Lens.lens (\CreateRouteCalculatorResponse' {ISO8601
createTime :: ISO8601
$sel:createTime:CreateRouteCalculatorResponse' :: CreateRouteCalculatorResponse -> ISO8601
createTime} -> ISO8601
createTime) (\s :: CreateRouteCalculatorResponse
s@CreateRouteCalculatorResponse' {} ISO8601
a -> CreateRouteCalculatorResponse
s {$sel:createTime:CreateRouteCalculatorResponse' :: ISO8601
createTime = ISO8601
a} :: CreateRouteCalculatorResponse) forall b c a. (b -> c) -> (a -> b) -> a -> c
Prelude.. forall (a :: Format). Iso' (Time a) UTCTime
Data._Time

instance Prelude.NFData CreateRouteCalculatorResponse where
  rnf :: CreateRouteCalculatorResponse -> ()
rnf CreateRouteCalculatorResponse' {Int
Text
ISO8601
createTime :: ISO8601
calculatorName :: Text
calculatorArn :: Text
httpStatus :: Int
$sel:createTime:CreateRouteCalculatorResponse' :: CreateRouteCalculatorResponse -> ISO8601
$sel:calculatorName:CreateRouteCalculatorResponse' :: CreateRouteCalculatorResponse -> Text
$sel:calculatorArn:CreateRouteCalculatorResponse' :: CreateRouteCalculatorResponse -> Text
$sel:httpStatus:CreateRouteCalculatorResponse' :: CreateRouteCalculatorResponse -> 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 Text
calculatorArn
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf Text
calculatorName
      seq :: forall a b. a -> b -> b
`Prelude.seq` forall a. NFData a => a -> ()
Prelude.rnf ISO8601
createTime