{-# 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.WorkSpaces.StartWorkspaces -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Starts the specified WorkSpaces. -- -- You cannot start a WorkSpace unless it has a running mode of @AutoStop@ -- and a state of @STOPPED@. module Amazonka.WorkSpaces.StartWorkspaces ( -- * Creating a Request StartWorkspaces (..), newStartWorkspaces, -- * Request Lenses startWorkspaces_startWorkspaceRequests, -- * Destructuring the Response StartWorkspacesResponse (..), newStartWorkspacesResponse, -- * Response Lenses startWorkspacesResponse_failedRequests, startWorkspacesResponse_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.WorkSpaces.Types -- | /See:/ 'newStartWorkspaces' smart constructor. data StartWorkspaces = StartWorkspaces' { -- | The WorkSpaces to start. You can specify up to 25 WorkSpaces. startWorkspaceRequests :: Prelude.NonEmpty StartRequest } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'StartWorkspaces' 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: -- -- 'startWorkspaceRequests', 'startWorkspaces_startWorkspaceRequests' - The WorkSpaces to start. You can specify up to 25 WorkSpaces. newStartWorkspaces :: -- | 'startWorkspaceRequests' Prelude.NonEmpty StartRequest -> StartWorkspaces newStartWorkspaces pStartWorkspaceRequests_ = StartWorkspaces' { startWorkspaceRequests = Lens.coerced Lens.# pStartWorkspaceRequests_ } -- | The WorkSpaces to start. You can specify up to 25 WorkSpaces. startWorkspaces_startWorkspaceRequests :: Lens.Lens' StartWorkspaces (Prelude.NonEmpty StartRequest) startWorkspaces_startWorkspaceRequests = Lens.lens (\StartWorkspaces' {startWorkspaceRequests} -> startWorkspaceRequests) (\s@StartWorkspaces' {} a -> s {startWorkspaceRequests = a} :: StartWorkspaces) Prelude.. Lens.coerced instance Core.AWSRequest StartWorkspaces where type AWSResponse StartWorkspaces = StartWorkspacesResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> StartWorkspacesResponse' Prelude.<$> (x Data..?> "FailedRequests" Core..!@ Prelude.mempty) Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable StartWorkspaces where hashWithSalt _salt StartWorkspaces' {..} = _salt `Prelude.hashWithSalt` startWorkspaceRequests instance Prelude.NFData StartWorkspaces where rnf StartWorkspaces' {..} = Prelude.rnf startWorkspaceRequests instance Data.ToHeaders StartWorkspaces where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "WorkspacesService.StartWorkspaces" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON StartWorkspaces where toJSON StartWorkspaces' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ( "StartWorkspaceRequests" Data..= startWorkspaceRequests ) ] ) instance Data.ToPath StartWorkspaces where toPath = Prelude.const "/" instance Data.ToQuery StartWorkspaces where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newStartWorkspacesResponse' smart constructor. data StartWorkspacesResponse = StartWorkspacesResponse' { -- | Information about the WorkSpaces that could not be started. failedRequests :: Prelude.Maybe [FailedWorkspaceChangeRequest], -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'StartWorkspacesResponse' 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: -- -- 'failedRequests', 'startWorkspacesResponse_failedRequests' - Information about the WorkSpaces that could not be started. -- -- 'httpStatus', 'startWorkspacesResponse_httpStatus' - The response's http status code. newStartWorkspacesResponse :: -- | 'httpStatus' Prelude.Int -> StartWorkspacesResponse newStartWorkspacesResponse pHttpStatus_ = StartWorkspacesResponse' { failedRequests = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | Information about the WorkSpaces that could not be started. startWorkspacesResponse_failedRequests :: Lens.Lens' StartWorkspacesResponse (Prelude.Maybe [FailedWorkspaceChangeRequest]) startWorkspacesResponse_failedRequests = Lens.lens (\StartWorkspacesResponse' {failedRequests} -> failedRequests) (\s@StartWorkspacesResponse' {} a -> s {failedRequests = a} :: StartWorkspacesResponse) Prelude.. Lens.mapping Lens.coerced -- | The response's http status code. startWorkspacesResponse_httpStatus :: Lens.Lens' StartWorkspacesResponse Prelude.Int startWorkspacesResponse_httpStatus = Lens.lens (\StartWorkspacesResponse' {httpStatus} -> httpStatus) (\s@StartWorkspacesResponse' {} a -> s {httpStatus = a} :: StartWorkspacesResponse) instance Prelude.NFData StartWorkspacesResponse where rnf StartWorkspacesResponse' {..} = Prelude.rnf failedRequests `Prelude.seq` Prelude.rnf httpStatus