{-# LANGUAGE DataKinds #-} {-# LANGUAGE DerivingStrategies #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE ImportQualifiedPost #-} {-# LANGUAGE LambdaCase #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE PatternSynonyms #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-duplicate-exports #-} {-# OPTIONS_GHC -fno-warn-name-shadowing #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- | -- Module : Gogol.Classroom.Courses.List -- Copyright : (c) 2015-2025 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Toni Cebrián -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Returns a list of courses that the requesting user is permitted to view, restricted to those that match the request. Returned courses are ordered by creation time, with the most recently created coming first. This method returns the following error codes: * @PERMISSION_DENIED@ for access errors. * @INVALID_ARGUMENT@ if the query argument is malformed. * @NOT_FOUND@ if any users specified in the query arguments do not exist. -- -- /See:/ for @classroom.courses.list@. module Gogol.Classroom.Courses.List ( -- * Resource ClassroomCoursesListResource, -- ** Constructing a Request ClassroomCoursesList (..), newClassroomCoursesList, ) where import Gogol.Classroom.Types import Gogol.Prelude qualified as Core -- | A resource alias for @classroom.courses.list@ method which the -- 'ClassroomCoursesList' request conforms to. type ClassroomCoursesListResource = "v1" Core.:> "courses" Core.:> Core.QueryParam "$.xgafv" Xgafv Core.:> Core.QueryParam "access_token" Core.Text Core.:> Core.QueryParam "callback" Core.Text Core.:> Core.QueryParams "courseStates" CoursesListCourseStates Core.:> Core.QueryParam "pageSize" Core.Int32 Core.:> Core.QueryParam "pageToken" Core.Text Core.:> Core.QueryParam "studentId" Core.Text Core.:> Core.QueryParam "teacherId" Core.Text Core.:> Core.QueryParam "uploadType" Core.Text Core.:> Core.QueryParam "upload_protocol" Core.Text Core.:> Core.QueryParam "alt" Core.AltJSON Core.:> Core.Get '[Core.JSON] ListCoursesResponse -- | Returns a list of courses that the requesting user is permitted to view, restricted to those that match the request. Returned courses are ordered by creation time, with the most recently created coming first. This method returns the following error codes: * @PERMISSION_DENIED@ for access errors. * @INVALID_ARGUMENT@ if the query argument is malformed. * @NOT_FOUND@ if any users specified in the query arguments do not exist. -- -- /See:/ 'newClassroomCoursesList' smart constructor. data ClassroomCoursesList = ClassroomCoursesList { -- | V1 error format. xgafv :: (Core.Maybe Xgafv), -- | OAuth access token. accessToken :: (Core.Maybe Core.Text), -- | JSONP callback :: (Core.Maybe Core.Text), -- | Restricts returned courses to those in one of the specified states The default value is ACTIVE, ARCHIVED, PROVISIONED, DECLINED. courseStates :: (Core.Maybe [CoursesListCourseStates]), -- | Maximum number of items to return. Zero or unspecified indicates that the server may assign a maximum. The server may return fewer than the specified number of results. pageSize :: (Core.Maybe Core.Int32), -- | nextPageToken value returned from a previous list call, indicating that the subsequent page of results should be returned. The list request must be otherwise identical to the one that resulted in this token. pageToken :: (Core.Maybe Core.Text), -- | Restricts returned courses to those having a student with the specified identifier. The identifier can be one of the following: * the numeric identifier for the user * the email address of the user * the string literal @\"me\"@, indicating the requesting user studentId :: (Core.Maybe Core.Text), -- | Restricts returned courses to those having a teacher with the specified identifier. The identifier can be one of the following: * the numeric identifier for the user * the email address of the user * the string literal @\"me\"@, indicating the requesting user teacherId :: (Core.Maybe Core.Text), -- | Legacy upload protocol for media (e.g. \"media\", \"multipart\"). uploadType :: (Core.Maybe Core.Text), -- | Upload protocol for media (e.g. \"raw\", \"multipart\"). uploadProtocol :: (Core.Maybe Core.Text) } deriving (Core.Eq, Core.Show, Core.Generic) -- | Creates a value of 'ClassroomCoursesList' with the minimum fields required to make a request. newClassroomCoursesList :: ClassroomCoursesList newClassroomCoursesList = ClassroomCoursesList { xgafv = Core.Nothing, accessToken = Core.Nothing, callback = Core.Nothing, courseStates = Core.Nothing, pageSize = Core.Nothing, pageToken = Core.Nothing, studentId = Core.Nothing, teacherId = Core.Nothing, uploadType = Core.Nothing, uploadProtocol = Core.Nothing } instance Core.GoogleRequest ClassroomCoursesList where type Rs ClassroomCoursesList = ListCoursesResponse type Scopes ClassroomCoursesList = '[Classroom'Courses, Classroom'Courses'Readonly] requestClient ClassroomCoursesList {..} = go xgafv accessToken callback (courseStates Core.^. Core._Default) pageSize pageToken studentId teacherId uploadType uploadProtocol (Core.Just Core.AltJSON) classroomService where go = Core.buildClient (Core.Proxy :: Core.Proxy ClassroomCoursesListResource) Core.mempty