{-# 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.Snowball.CreateReturnShippingLabel -- 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 shipping label that will be used to return the Snow device to -- Amazon Web Services. module Amazonka.Snowball.CreateReturnShippingLabel ( -- * Creating a Request CreateReturnShippingLabel (..), newCreateReturnShippingLabel, -- * Request Lenses createReturnShippingLabel_shippingOption, createReturnShippingLabel_jobId, -- * Destructuring the Response CreateReturnShippingLabelResponse (..), newCreateReturnShippingLabelResponse, -- * Response Lenses createReturnShippingLabelResponse_status, createReturnShippingLabelResponse_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.Snowball.Types -- | /See:/ 'newCreateReturnShippingLabel' smart constructor. data CreateReturnShippingLabel = CreateReturnShippingLabel' { -- | The shipping speed for a particular job. This speed doesn\'t dictate how -- soon the device is returned to Amazon Web Services. This speed -- represents how quickly it moves to its destination while in transit. -- Regional shipping speeds are as follows: shippingOption :: Prelude.Maybe ShippingOption, -- | The ID for a job that you want to create the return shipping label for; -- for example, @JID123e4567-e89b-12d3-a456-426655440000@. jobId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateReturnShippingLabel' 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: -- -- 'shippingOption', 'createReturnShippingLabel_shippingOption' - The shipping speed for a particular job. This speed doesn\'t dictate how -- soon the device is returned to Amazon Web Services. This speed -- represents how quickly it moves to its destination while in transit. -- Regional shipping speeds are as follows: -- -- 'jobId', 'createReturnShippingLabel_jobId' - The ID for a job that you want to create the return shipping label for; -- for example, @JID123e4567-e89b-12d3-a456-426655440000@. newCreateReturnShippingLabel :: -- | 'jobId' Prelude.Text -> CreateReturnShippingLabel newCreateReturnShippingLabel pJobId_ = CreateReturnShippingLabel' { shippingOption = Prelude.Nothing, jobId = pJobId_ } -- | The shipping speed for a particular job. This speed doesn\'t dictate how -- soon the device is returned to Amazon Web Services. This speed -- represents how quickly it moves to its destination while in transit. -- Regional shipping speeds are as follows: createReturnShippingLabel_shippingOption :: Lens.Lens' CreateReturnShippingLabel (Prelude.Maybe ShippingOption) createReturnShippingLabel_shippingOption = Lens.lens (\CreateReturnShippingLabel' {shippingOption} -> shippingOption) (\s@CreateReturnShippingLabel' {} a -> s {shippingOption = a} :: CreateReturnShippingLabel) -- | The ID for a job that you want to create the return shipping label for; -- for example, @JID123e4567-e89b-12d3-a456-426655440000@. createReturnShippingLabel_jobId :: Lens.Lens' CreateReturnShippingLabel Prelude.Text createReturnShippingLabel_jobId = Lens.lens (\CreateReturnShippingLabel' {jobId} -> jobId) (\s@CreateReturnShippingLabel' {} a -> s {jobId = a} :: CreateReturnShippingLabel) instance Core.AWSRequest CreateReturnShippingLabel where type AWSResponse CreateReturnShippingLabel = CreateReturnShippingLabelResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> CreateReturnShippingLabelResponse' Prelude.<$> (x Data..?> "Status") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable CreateReturnShippingLabel where hashWithSalt _salt CreateReturnShippingLabel' {..} = _salt `Prelude.hashWithSalt` shippingOption `Prelude.hashWithSalt` jobId instance Prelude.NFData CreateReturnShippingLabel where rnf CreateReturnShippingLabel' {..} = Prelude.rnf shippingOption `Prelude.seq` Prelude.rnf jobId instance Data.ToHeaders CreateReturnShippingLabel where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "AWSIESnowballJobManagementService.CreateReturnShippingLabel" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON CreateReturnShippingLabel where toJSON CreateReturnShippingLabel' {..} = Data.object ( Prelude.catMaybes [ ("ShippingOption" Data..=) Prelude.<$> shippingOption, Prelude.Just ("JobId" Data..= jobId) ] ) instance Data.ToPath CreateReturnShippingLabel where toPath = Prelude.const "/" instance Data.ToQuery CreateReturnShippingLabel where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newCreateReturnShippingLabelResponse' smart constructor. data CreateReturnShippingLabelResponse = CreateReturnShippingLabelResponse' { -- | The status information of the task on a Snow device that is being -- returned to Amazon Web Services. status :: Prelude.Maybe ShippingLabelStatus, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateReturnShippingLabelResponse' 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: -- -- 'status', 'createReturnShippingLabelResponse_status' - The status information of the task on a Snow device that is being -- returned to Amazon Web Services. -- -- 'httpStatus', 'createReturnShippingLabelResponse_httpStatus' - The response's http status code. newCreateReturnShippingLabelResponse :: -- | 'httpStatus' Prelude.Int -> CreateReturnShippingLabelResponse newCreateReturnShippingLabelResponse pHttpStatus_ = CreateReturnShippingLabelResponse' { status = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The status information of the task on a Snow device that is being -- returned to Amazon Web Services. createReturnShippingLabelResponse_status :: Lens.Lens' CreateReturnShippingLabelResponse (Prelude.Maybe ShippingLabelStatus) createReturnShippingLabelResponse_status = Lens.lens (\CreateReturnShippingLabelResponse' {status} -> status) (\s@CreateReturnShippingLabelResponse' {} a -> s {status = a} :: CreateReturnShippingLabelResponse) -- | The response's http status code. createReturnShippingLabelResponse_httpStatus :: Lens.Lens' CreateReturnShippingLabelResponse Prelude.Int createReturnShippingLabelResponse_httpStatus = Lens.lens (\CreateReturnShippingLabelResponse' {httpStatus} -> httpStatus) (\s@CreateReturnShippingLabelResponse' {} a -> s {httpStatus = a} :: CreateReturnShippingLabelResponse) instance Prelude.NFData CreateReturnShippingLabelResponse where rnf CreateReturnShippingLabelResponse' {..} = Prelude.rnf status `Prelude.seq` Prelude.rnf httpStatus