{-# 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.DialogFlow.Projects.Locations.Agents.Sessions.ServerStreamingDetectIntent -- 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) -- -- Processes a natural language query and returns structured, actionable data as a result through server-side streaming. Server-side streaming allows Dialogflow to send earlier in a single request. -- -- /See:/ for @dialogflow.projects.locations.agents.sessions.serverStreamingDetectIntent@. module Gogol.DialogFlow.Projects.Locations.Agents.Sessions.ServerStreamingDetectIntent ( -- * Resource DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntentResource, -- ** Constructing a Request DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent (..), newDialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent, ) where import Gogol.DialogFlow.Types import Gogol.Prelude qualified as Core -- | A resource alias for @dialogflow.projects.locations.agents.sessions.serverStreamingDetectIntent@ method which the -- 'DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent' request conforms to. type DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntentResource = "v3" Core.:> Core.CaptureMode "session" "serverStreamingDetectIntent" Core.Text Core.:> Core.QueryParam "$.xgafv" Xgafv Core.:> Core.QueryParam "access_token" Core.Text Core.:> Core.QueryParam "callback" Core.Text Core.:> Core.QueryParam "uploadType" Core.Text Core.:> Core.QueryParam "upload_protocol" Core.Text Core.:> Core.QueryParam "alt" Core.AltJSON Core.:> Core.ReqBody '[Core.JSON] GoogleCloudDialogflowCxV3DetectIntentRequest Core.:> Core.Post '[Core.JSON] GoogleCloudDialogflowCxV3DetectIntentResponse -- | Processes a natural language query and returns structured, actionable data as a result through server-side streaming. Server-side streaming allows Dialogflow to send earlier in a single request. -- -- /See:/ 'newDialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent' smart constructor. data DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent = DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent { -- | V1 error format. xgafv :: (Core.Maybe Xgafv), -- | OAuth access token. accessToken :: (Core.Maybe Core.Text), -- | JSONP callback :: (Core.Maybe Core.Text), -- | Multipart request metadata. payload :: GoogleCloudDialogflowCxV3DetectIntentRequest, -- | Required. The name of the session this query is sent to. Format: @projects\/\/locations\/\/agents\/\/sessions\/@ or @projects\/\/locations\/\/agents\/\/environments\/\/sessions\/@. If @Environment ID@ is not specified, we assume default \'draft\' environment. It\'s up to the API caller to choose an appropriate @Session ID@. It can be a random number or some type of session identifiers (preferably hashed). The length of the @Session ID@ must not exceed 36 characters. For more information, see the . Note: Always use agent versions for production traffic. See . session :: 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 'DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent' with the minimum fields required to make a request. newDialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent :: -- | Multipart request metadata. See 'payload'. GoogleCloudDialogflowCxV3DetectIntentRequest -> -- | Required. The name of the session this query is sent to. Format: @projects\/\/locations\/\/agents\/\/sessions\/@ or @projects\/\/locations\/\/agents\/\/environments\/\/sessions\/@. If @Environment ID@ is not specified, we assume default \'draft\' environment. It\'s up to the API caller to choose an appropriate @Session ID@. It can be a random number or some type of session identifiers (preferably hashed). The length of the @Session ID@ must not exceed 36 characters. For more information, see the . Note: Always use agent versions for production traffic. See . See 'session'. Core.Text -> DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent newDialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent payload session = DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent { xgafv = Core.Nothing, accessToken = Core.Nothing, callback = Core.Nothing, payload = payload, session = session, uploadType = Core.Nothing, uploadProtocol = Core.Nothing } instance Core.GoogleRequest DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent where type Rs DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent = GoogleCloudDialogflowCxV3DetectIntentResponse type Scopes DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent = '[CloudPlatform'FullControl, Dialogflow'FullControl] requestClient DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntent {..} = go session xgafv accessToken callback uploadType uploadProtocol (Core.Just Core.AltJSON) payload dialogFlowService where go = Core.buildClient ( Core.Proxy :: Core.Proxy DialogFlowProjectsLocationsAgentsSessionsServerStreamingDetectIntentResource ) Core.mempty