lib/v20240522/client.rb



# frozen_string_literal: true

# Copyright (c) 2017-2018 THL A29 Limited, a Tencent company. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#    http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

require 'json'

module TencentCloud
  module Lkeap
    module V20240522
      class Client < TencentCloud::Common::AbstractClient

        def initialize(credential, region, profile = nil)
            api_version = '2024-05-22'
            api_endpoint = 'lkeap.tencentcloudapi.com'
            sdk_version = 'LKEAP_' + File.read(File.expand_path('../VERSION', __dir__)).strip
            super(credential, region, api_version, api_endpoint, sdk_version, profile)
        end


        # ### 接口功能

        # 调用接口,发起一次对话请求。单账号限制接口并发上限为5。
        # 如需使用OpenAI兼容接口, 请参考文档:[Deepseek OpenAI对话接口](https://cloud.tencent.com/document/product/1772/115969)

        # #### 在线体验
        # 如您希望在网页内直接体验 DeepSeek 模型对话,推荐您前往[腾讯云大模型知识引擎](https://cloud.tencent.com/product/lke),使用[ DeepSeek 联网助手](https://lke.cloud.tencent.com/webim_exp/#/chat/wQrAwR)。

        # #### 已支持的模型
        # - DeepSeek-V3-0324(model 参数值为**deepseek-v3-0324**)
        #     - DeepSeek-V3-0324为671B参数MoE模型,在编程与技术能力、上下文理解与长文本处理等方面优势突出。
        #     - 支持64K上下文长度,最大输入56k,最大输出8k(不含思维链)。
        #     - 注意:相比于DeepSeek-V3,DeepSeek-V3-0324仅更新了模型权重,未增加参数量。总模型大小为685B,其中包括671B的主模型权重和 14B 的多令牌预测(MTP)模块权重,后续均描述主模型参数量。
        # - DeepSeek-V3(model 参数值为**deepseek-v3**)
        #     - DeepSeek-V3为671B参数MoE模型,在百科知识、数学推理等多项任务上优势突出,评测成绩在主流榜单中位列开源模型榜首。
        #     - 支持64K上下文长度,最大输入56k,最大输出8k(不含思维链)。
        # - DeepSeek-R1(model 参数值为**deepseek-r1**)
        #     - DeepSeek-R1为671B模型,使用强化学习训练,推理过程包含大量反思和验证,思维链长度可达数万字。 该系列模型在数学、代码以及各种复杂逻辑推理任务上推理效果优异,并为用户展现了完整的思考过程。
        #     -  支持64K上下文长度,最大输入56k,最大输出8k(不含思维链)。

        # ### 计费说明

        # - 标准计费(2025年2月26日起生效),计费模式为后付费小时结,为保证您账户资源的正常使用,请提前[开通后付费](https://lke.cloud.tencent.com/lke#/app/system/charge/postpaid)并及时[充值](https://console.cloud.tencent.com/expense/recharge)。

        #     -   DeepSeek-R1 模型   | 输入:0.004元/千token | 输出(含思维链):0.016元/千token

        #     - DeepSeek-V3 模型 | 输入:0.002元/千token | 输出:0.008元/千token

        #     - DeepSeek-V3-0324 模型 | 输入:0.002元/千token | 输出:0.008元/千token


        # ### Openai兼容协议接口
        # 知识引擎原子能力大模型对话 API 兼容了 OpenAI 的接口规范,这意味着您可以直接使用 OpenAI 官方提供的 SDK 来调用大模型对话接口。您仅需要将 base_url 和 [api_key](https://cloud.tencent.com/document/product/1772/115970) 替换成相关配置,不需要对应用做额外修改,即可无缝将您的应用切换到相应的大模型。请参考文档:[Deepseek OpenAI对话接口](https://cloud.tencent.com/document/product/1772/115969)。
        # > base_url:  https://api.lkeap.cloud.tencent.com/v1

        # > api_key的获取请参考[API KEY管理](https://cloud.tencent.com/document/product/1772/115970)


        # ### 快速接入
        # 1. 完成[实名认证](https://console.cloud.tencent.com/developer/auth)。
        # 2. 主账户前往[控制台](https://console.cloud.tencent.com/lkeap)开通服务。若为子账户,需由主账号在[权限管理](https://console.cloud.tencent.com/cam)中为子账号授权,关联预设策略,策略名称:QcloudLKEAPFullAccess。
        # 3. 通过API Explorer[在线调试](https://console.cloud.tencent.com/api/explorer?Product=lkeap&Version=2024-05-22&Action=ChatCompletions)。
        # 4. 使用[官方 SDK ](https://cloud.tencent.com/document/product/1772/115963#SDK)调用本接口(支持Python/Java/PHP/Go/Node.js/.NET等语言)。

        # -----------

        # ### SDK调用示例
        # 通过本地代码调用本接口(支持Python/Java/PHP/Go/Node.js/.NET等语言):下面的代码以 Python 语言为例,展示如何访问腾讯云上的DeepSeek模型API的样例。
        # (1)安装环境
        # ```
        # python3 -m pip install --upgrade tencentcloud-sdk-python-common
        # python3 -m pip install --upgrade tencentcloud-sdk-python-lkeap
        # ```

        # (2)示例代码

        # - 其中SecretKey和SecretID需要从腾讯云控制台获取

        # - 参数params中模型Model字段可以选择“deepseek-r1“和“deepseek-v3”

        # ```
        # # -*- coding: utf-8 -*-
        # import json

        # from tencentcloud.common.common_client import CommonClient
        # from tencentcloud.common import credential
        # from tencentcloud.common.exception.tencent_cloud_sdk_exception import TencentCloudSDKException
        # from tencentcloud.common.profile.client_profile import ClientProfile
        # from tencentcloud.common.profile.http_profile import HttpProfile

        # class NonStreamResponse(object):
        #     def __init__(self):
        #         self.response = ""

        #     def _deserialize(self, obj):
        #         self.response = json.dumps(obj)

        # try:
        #     # 实例化一个认证对象,入参需要传入腾讯云账户 SecretId 和 SecretKey,此处还需注意密钥对的保密
        #     # 代码泄露可能会导致 SecretId 和 SecretKey 泄露,并威胁账号下所有资源的安全性。以下代码示例仅供参考,建议采用更安全的方式来使用密钥,请参见:https://cloud.tencent.com/document/product/1278/85305
        #     # 密钥可前往官网控制台 https://console.cloud.tencent.com/cam/capi 进行获取
        #     cred = credential.Credential("", "")

        #     httpProfile = HttpProfile()
        #     httpProfile.endpoint = "lkeap.tencentcloudapi.com"
        #     httpProfile.reqTimeout = 40000  # 流式接口可能耗时较长
        #     clientProfile = ClientProfile()
        #     clientProfile.httpProfile = httpProfile

        #     params = "{\"Model\":\"deepseek-r1\",\"Messages\":[{\"Role\":\"user\",\"Content\":\"你好\"}],\"Stream\":true}";
        #     common_client = CommonClient("lkeap", "2024-05-22", cred, "ap-guangzhou", profile=clientProfile)
        #     resp = common_client._call_and_deserialize("ChatCompletions", json.loads(params), NonStreamResponse)
        #     if isinstance(resp, NonStreamResponse):  # 非流式响应
        #         print(resp.response)
        #     else:  # 流式响应
        #         for event in resp:
        #             print(event)
        # except TencentCloudSDKException as err:
        #     print(err)

        # ```

        # **DeepSeek-R1使用建议**

        # 1. 将温度设置在 0.5-0.7 范围内(建议为0.6),以防止无休止的重复或不连贯的输出。
        # 2. 避免添加system prompt,所有说明都应包含在user prompt中。

        # @param request: Request instance for ChatCompletions.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::ChatCompletionsRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::ChatCompletionsResponse`
        def ChatCompletions(request)
          body = send_request('ChatCompletions', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = ChatCompletionsResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于为问答对创建属性标签,以便对内容进行分类和管理。 使用场景:当需要为问答对添加分类标签和属性标记时使用,比如为问答对添加“售后”标签。

        # @param request: Request instance for CreateAttributeLabel.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::CreateAttributeLabelRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::CreateAttributeLabelResponse`
        def CreateAttributeLabel(request)
          body = send_request('CreateAttributeLabel', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = CreateAttributeLabelResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于在系统中创建一个新的知识库。知识库是一个用于存储和管理知识条目的集合,可以包括文档、问答对、属性标签等。创建知识库后,可以向其中添加各种知识条目,以便在后续的知识检索中使用。 使用场景:当需要在系统中建立一个新的知识库以存储和管理特定领域或项目的知识条目时使用。例如,一个用户可能需要创建一个知识库,以存储用户指南、常见问题解答和技术文档。体验用户最多可创建3个知识库,付费用户最多可创建100个知识库。

        # @param request: Request instance for CreateKnowledgeBase.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::CreateKnowledgeBaseRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::CreateKnowledgeBaseResponse`
        def CreateKnowledgeBase(request)
          body = send_request('CreateKnowledgeBase', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = CreateKnowledgeBaseResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于创建新的问答对。问答对可以在SearchKnowledge接口知识检索时提供匹配的答案。 使用场景:当需要添加新的知识点和对应的问答对时使用,比如为产品添加新的常见问题解答。

        # @param request: Request instance for CreateQA.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::CreateQARequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::CreateQAResponse`
        def CreateQA(request)
          body = send_request('CreateQA', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = CreateQAResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 本接口为异步接口的发起请求接口,用于发起文档解析任务。
        # 文档解析支持将图片或PDF、DOCX、PPTX、EXCEL等文件转换成Markdown格式文件,可解析包括表格、公式、图片、标题、段落、页眉、页脚等内容元素,并将内容智能转换成阅读顺序。具体支持文件类型请查看下方输入参数列表。

        # 体验期间单账号限制qps仅为1,若有正式接入需要请与产研团队沟通开放。

        # @param request: Request instance for CreateReconstructDocumentFlow.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::CreateReconstructDocumentFlowRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::CreateReconstructDocumentFlowResponse`
        def CreateReconstructDocumentFlow(request)
          body = send_request('CreateReconstructDocumentFlow', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = CreateReconstructDocumentFlowResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于创建一个文档拆分任务,支持多种文件类型,具备mllm能力,能够解析并深入理解图表中的信息。

        # @param request: Request instance for CreateSplitDocumentFlow.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::CreateSplitDocumentFlowRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::CreateSplitDocumentFlowResponse`
        def CreateSplitDocumentFlow(request)
          body = send_request('CreateSplitDocumentFlow', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = CreateSplitDocumentFlowResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于删除不再需要的属性标签。 使用场景:当某个标签不再使用时,可以将其删除以保持标签系统的整洁。

        # @param request: Request instance for DeleteAttributeLabels.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::DeleteAttributeLabelsRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::DeleteAttributeLabelsResponse`
        def DeleteAttributeLabels(request)
          body = send_request('DeleteAttributeLabels', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = DeleteAttributeLabelsResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于删除已有的文档。 使用场景:当某个文档不再需要时,可以将其删除以保持文档库的整洁。

        # @param request: Request instance for DeleteDocs.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::DeleteDocsRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::DeleteDocsResponse`
        def DeleteDocs(request)
          body = send_request('DeleteDocs', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = DeleteDocsResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于从系统中删除一个现有的知识库。删除知识库将移除该知识库及其所有关联的知识条目(如文档、问答对、属性标签等)。该操作是不可逆的,请在执行前确认是否需要删除。**使用场景**:当某个知识库不再需要时,可以使用此接口将其从系统中删除。例如,一个项目结束后,其相关的知识库可能不再需要存储,可以使用该接口进行删除。

        # @param request: Request instance for DeleteKnowledgeBase.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::DeleteKnowledgeBaseRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::DeleteKnowledgeBaseResponse`
        def DeleteKnowledgeBase(request)
          body = send_request('DeleteKnowledgeBase', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = DeleteKnowledgeBaseResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于删除已有的问答对。 使用场景:当某个问答对不再适用或需要移除时使用。

        # @param request: Request instance for DeleteQAs.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::DeleteQAsRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::DeleteQAsResponse`
        def DeleteQAs(request)
          body = send_request('DeleteQAs', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = DeleteQAsResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于查询特定文档的详细信息。 使用场景:当需要查看某个文档的具体内容和属性时使用。

        # @param request: Request instance for DescribeDoc.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::DescribeDocRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::DescribeDocResponse`
        def DescribeDoc(request)
          body = send_request('DescribeDoc', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = DescribeDocResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 本接口(GetEmbedding)调用文本表示模型,将文本转化为用数值表示的向量形式,可用于文本检索、信息推荐、知识挖掘等场景。
        # 本接口(GetEmbedding)有单账号调用上限控制,如您有提高并发限制的需求请 [联系我们](https://cloud.tencent.com/act/event/Online_service) 。

        # @param request: Request instance for GetEmbedding.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::GetEmbeddingRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::GetEmbeddingResponse`
        def GetEmbedding(request)
          body = send_request('GetEmbedding', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = GetEmbeddingResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 本接口为异步接口的查询结果接口,用于获取文档解析处理结果。

        # @param request: Request instance for GetReconstructDocumentResult.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::GetReconstructDocumentResultRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::GetReconstructDocumentResultResponse`
        def GetReconstructDocumentResult(request)
          body = send_request('GetReconstructDocumentResult', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = GetReconstructDocumentResultResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 查询文档拆分任务结果

        # @param request: Request instance for GetSplitDocumentResult.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::GetSplitDocumentResultRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::GetSplitDocumentResultResponse`
        def GetSplitDocumentResult(request)
          body = send_request('GetSplitDocumentResult', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = GetSplitDocumentResultResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于批量导入问答对,最多支持50,000条数据导入。通过此接口,可以将多个问答对一次性导入系统中,以便在后续的知识检索中使用。导入的问答对可以来自外部系统、文件或其他数据源。使用场景:当需要一次性导入大量的问答对时使用。例如,一个公司可能需要将其产品的常见问题解答从一个文档或外部系统批量导入到知识库中,以便用户可以通过知识检索系统进行查询。

        # @param request: Request instance for ImportQAs.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::ImportQAsRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::ImportQAsResponse`
        def ImportQAs(request)
          body = send_request('ImportQAs', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = ImportQAsResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于获取所有属性标签的列表。 使用场景:用于查看当前系统中所有已有的属性标签,方便进行管理和维护。

        # @param request: Request instance for ListAttributeLabels.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::ListAttributeLabelsRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::ListAttributeLabelsResponse`
        def ListAttributeLabels(request)
          body = send_request('ListAttributeLabels', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = ListAttributeLabelsResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于获取所有文档的列表。 使用场景:用于查看当前系统中所有已有的文档,方便进行管理和维护。

        # @param request: Request instance for ListDocs.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::ListDocsRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::ListDocsResponse`
        def ListDocs(request)
          body = send_request('ListDocs', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = ListDocsResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于获取所有问答对的列表。 使用场景:用于查看当前系统中所有已有的问答对,方便进行管理和维护。

        # @param request: Request instance for ListQAs.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::ListQAsRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::ListQAsResponse`
        def ListQAs(request)
          body = send_request('ListQAs', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = ListQAsResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于修改已有的属性标签。 使用场景:当需要更改属性标签的名称或描述时使用,比如将“售后”标签改为“售前”。

        # @param request: Request instance for ModifyAttributeLabel.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::ModifyAttributeLabelRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::ModifyAttributeLabelResponse`
        def ModifyAttributeLabel(request)
          body = send_request('ModifyAttributeLabel', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = ModifyAttributeLabelResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于修改已有的问答对。 使用场景:当需要更新问答对的内容或答案时使用。

        # @param request: Request instance for ModifyQA.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::ModifyQARequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::ModifyQAResponse`
        def ModifyQA(request)
          body = send_request('ModifyQA', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = ModifyQAResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 多轮改写(QueryRewrite)主要用于多轮对话中,进行指代消解和省略补全。使用本接口,无需输入prompt描述,根据对话历史即可生成更精确的用户查询。在应用场景上,本接口可应用于智能问答、对话式搜索等多种场景。
        # 开通[产品体验](https://lke.cloud.tencent.com/lke/#/trialProduct)后可获得50wtoken体验额度。本接口(QueryRewrite)有单账号调用上限控制,如您有提高并发限制的需求请 [联系我们](https://cloud.tencent.com/act/event/Online_service) 。

        # @param request: Request instance for QueryRewrite.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::QueryRewriteRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::QueryRewriteResponse`
        def QueryRewrite(request)
          body = send_request('QueryRewrite', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = QueryRewriteResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 准实时文档解析接口,使用HTTP SSE 协议通信。

        # @param request: Request instance for ReconstructDocumentSSE.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::ReconstructDocumentSSERequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::ReconstructDocumentSSEResponse`
        def ReconstructDocumentSSE(request)
          body = send_request('ReconstructDocumentSSE', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = ReconstructDocumentSSEResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于检索知识库中的文档和问答对内容。 使用场景:适用于查询长期存储在知识库中的文档和问答对,比如产品手册、用户指南等内容的检索。

        # @param request: Request instance for RetrieveKnowledge.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::RetrieveKnowledgeRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::RetrieveKnowledgeResponse`
        def RetrieveKnowledge(request)
          body = send_request('RetrieveKnowledge', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = RetrieveKnowledgeResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 基于知识引擎精调模型技术的rerank模型,支持对多路召回的结果进行重排序,根据query与切片内容的相关性,按分数由高到低对切片进行排序,并输出对应的打分结果。

        # @param request: Request instance for RunRerank.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::RunRerankRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::RunRerankResponse`
        def RunRerank(request)
          body = send_request('RunRerank', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = RunRerankResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于上传文档内容。上传的文档将存储在知识库中,可以通过RetrieveKnowledge[知识库内容检索接口](https://cloud.tencent.com/document/product/1772/115349)进行检索。
        # 使用场景:适用于需要长期存储和检索的文档内容,如产品手册、用户指南等。

        # @param request: Request instance for UploadDoc.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::UploadDocRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::UploadDocResponse`
        def UploadDoc(request)
          body = send_request('UploadDoc', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = UploadDocResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end

        # 用于上传实时文档内容。
        # 实时文档在上传后可以立即通过SearchRealtime进行实时检索,适用于在会话中对文档进行问答的场景。

        # @param request: Request instance for UploadDocRealtime.
        # @type request: :class:`Tencentcloud::lkeap::V20240522::UploadDocRealtimeRequest`
        # @rtype: :class:`Tencentcloud::lkeap::V20240522::UploadDocRealtimeResponse`
        def UploadDocRealtime(request)
          body = send_request('UploadDocRealtime', request.serialize)
          response = JSON.parse(body)
          if response['Response'].key?('Error') == false
            model = UploadDocRealtimeResponse.new
            model.deserialize(response['Response'])
            model
          else
            code = response['Response']['Error']['Code']
            message = response['Response']['Error']['Message']
            reqid = response['Response']['RequestId']
            raise TencentCloud::Common::TencentCloudSDKException.new(code, message, reqid)
          end
        rescue TencentCloud::Common::TencentCloudSDKException => e
          raise e
        rescue StandardError => e
          raise TencentCloud::Common::TencentCloudSDKException.new(nil, e.inspect)
        end


      end
    end
  end
end