提取文件文本内容

master
yangbowen 1 year ago
parent 07ab5fee08
commit 1cf02f465a
  1. 14
      .idea/deployment.xml
  2. 13
      .idea/low-carbon-platform-php.iml
  3. 8
      .idea/modules.xml
  4. 22
      .idea/php.xml
  5. 11
      .idea/phpunit.xml
  6. 6
      .idea/vcs.xml
  7. 119
      .idea/workspace.xml
  8. 12
      .openapi-generator/FILES
  9. 2
      .openapi-generator/api-doc-php-sdk.sha256
  10. 4
      README.md
  11. 1
      composer.json
  12. 57
      docs/Api/AiApi.md
  13. 9
      docs/Model/ExtractTextParam.md
  14. 9
      docs/Model/ExtractTextResult.md
  15. 20
      docs/Model/ResponseOpenAPIExtractTextResult.md
  16. 358
      lib/Api/AiApi.php
  17. 413
      lib/Model/ExtractTextParam.php
  18. 410
      lib/Model/ExtractTextResult.php
  19. 784
      lib/Model/ResponseOpenAPIExtractTextResult.php
  20. 12
      test/Api/AiApiTest.php
  21. 90
      test/Model/ExtractTextParamTest.php
  22. 90
      test/Model/ExtractTextResultTest.php
  23. 189
      test/Model/ResponseOpenAPIExtractTextResultTest.php

@ -1,14 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="PublishConfigData" remoteFilesAllowedToDisappearOnAutoupload="false">
<serverData>
<paths name="docker">
<serverdata>
<mappings>
<mapping local="$PROJECT_DIR$" web="/" />
</mappings>
</serverdata>
</paths>
</serverData>
</component>
</project>

@ -1,13 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="WEB_MODULE" version="4">
<component name="NewModuleRootManager">
<content url="file://$MODULE_DIR$">
<sourceFolder url="file://$MODULE_DIR$/lib" isTestSource="false" packagePrefix="OpenAPI\Client\" />
<sourceFolder url="file://$MODULE_DIR$/test" isTestSource="true" packagePrefix="OpenAPI\Client\Test\" />
<sourceFolder url="file://$MODULE_DIR$/test/Api" isTestSource="true" />
<sourceFolder url="file://$MODULE_DIR$/test/Model" isTestSource="true" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

@ -1,8 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ProjectModuleManager">
<modules>
<module fileurl="file://$PROJECT_DIR$/.idea/low-carbon-platform-php.iml" filepath="$PROJECT_DIR$/.idea/low-carbon-platform-php.iml" />
</modules>
</component>
</project>

@ -1,22 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="MessDetectorOptionsConfiguration">
<option name="transferred" value="true" />
</component>
<component name="PHPCSFixerOptionsConfiguration">
<option name="transferred" value="true" />
</component>
<component name="PHPCodeSnifferOptionsConfiguration">
<option name="highlightLevel" value="WARNING" />
<option name="transferred" value="true" />
</component>
<component name="PhpProjectSharedConfiguration" php_language_level="7.4">
<option name="suggestChangeDefaultLanguageLevel" value="false" />
</component>
<component name="PhpStanOptionsConfiguration">
<option name="transferred" value="true" />
</component>
<component name="PsalmOptionsConfiguration">
<option name="transferred" value="true" />
</component>
</project>

@ -1,11 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="PHPUnit">
<option name="directories">
<list>
<option value="$PROJECT_DIR$/test/Api" />
<option value="$PROJECT_DIR$/test/Model" />
</list>
</option>
</component>
</project>

@ -1,6 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="" vcs="Git" />
</component>
</project>

@ -1,125 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<project version="4"> <project version="4">
<component name="AutoImportSettings">
<option name="autoReloadType" value="SELECTIVE" />
</component>
<component name="ChangeListManager">
<list default="true" id="f6d0117d-22fc-446a-a3f7-79e1aa508ea5" name="Changes" comment="参数文件">
<change afterPath="$PROJECT_DIR$/docs/Model/ResponseOpenAPITokensCountResult.md" afterDir="false" />
<change afterPath="$PROJECT_DIR$/docs/Model/TokenCountParam.md" afterDir="false" />
<change afterPath="$PROJECT_DIR$/docs/Model/TokensCountResult.md" afterDir="false" />
</list>
<option name="SHOW_DIALOG" value="false" />
<option name="HIGHLIGHT_CONFLICTS" value="true" />
<option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
<option name="LAST_RESOLUTION" value="IGNORE" />
</component>
<component name="ComposerSettings" notifyAboutMissingVendor="false" synchronizationState="SYNCHRONIZE">
<pharConfigPath>$PROJECT_DIR$/composer.json</pharConfigPath>
<execution>
<phar pharPath="$PROJECT_DIR$/composer.phar" />
</execution>
</component>
<component name="Git.Settings">
<option name="PUSH_TAGS">
<GitPushTagMode>
<option name="argument" value="--tags" />
<option name="title" value="All" />
</GitPushTagMode>
</option>
<option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" />
</component>
<component name="MarkdownSettingsMigration">
<option name="stateVersion" value="1" />
</component>
<component name="PhpWorkspaceProjectConfiguration" interpreter_name="PHP8.0" />
<component name="ProjectColorInfo">{
&quot;customColor&quot;: &quot;&quot;,
&quot;associatedIndex&quot;: 6
}</component>
<component name="ProjectId" id="2eZRE4IWa7gPUTXmZDOy8yp9zuE" />
<component name="ProjectViewState">
<option name="hideEmptyMiddlePackages" value="true" />
<option name="showLibraryContents" value="true" />
</component>
<component name="PropertiesComponent">{ <component name="PropertiesComponent">{
&quot;keyToString&quot;: { &quot;keyToString&quot;: {
&quot;RunOnceActivity.OpenProjectViewOnStart&quot;: &quot;true&quot;, &quot;settings.editor.selected.configurable&quot;: &quot;configurable.group.appearance&quot;
&quot;RunOnceActivity.ShowReadmeOnStart&quot;: &quot;true&quot;,
&quot;WebServerToolWindowFactoryState&quot;: &quot;false&quot;,
&quot;git-widget-placeholder&quot;: &quot;master&quot;,
&quot;ignore.virus.scanning.warn.message&quot;: &quot;true&quot;,
&quot;node.js.detected.package.eslint&quot;: &quot;true&quot;,
&quot;node.js.detected.package.tslint&quot;: &quot;true&quot;,
&quot;node.js.selected.package.eslint&quot;: &quot;(autodetect)&quot;,
&quot;node.js.selected.package.tslint&quot;: &quot;(autodetect)&quot;,
&quot;nodejs_package_manager_path&quot;: &quot;npm&quot;,
&quot;settings.editor.selected.configurable&quot;: &quot;reference.webide.settings.project.settings.php&quot;,
&quot;vue.rearranger.settings.migration&quot;: &quot;true&quot;
} }
}</component> }</component>
<component name="SpellCheckerSettings" RuntimeDictionaries="0" Folders="0" CustomDictionaries="0" DefaultDictionary="application-level" UseSingleDictionary="true" transferred="true" />
<component name="TaskManager">
<task active="true" id="Default" summary="Default task">
<changelist id="f6d0117d-22fc-446a-a3f7-79e1aa508ea5" name="Changes" comment="" />
<created>1712109998194</created>
<option name="number" value="Default" />
<option name="presentableId" value="Default" />
<updated>1712109998194</updated>
<workItem from="1712109999299" duration="2573000" />
<workItem from="1712112719178" duration="1373000" />
<workItem from="1712122401269" duration="29000" />
<workItem from="1712128553069" duration="69000" />
</task>
<task id="LOCAL-00001" summary="新增统计token接口">
<option name="closed" value="true" />
<created>1712110130388</created>
<option name="number" value="00001" />
<option name="presentableId" value="LOCAL-00001" />
<option name="project" value="LOCAL" />
<updated>1712110130388</updated>
</task>
<task id="LOCAL-00002" summary="新增统计token接口">
<option name="closed" value="true" />
<created>1712112106501</created>
<option name="number" value="00002" />
<option name="presentableId" value="LOCAL-00002" />
<option name="project" value="LOCAL" />
<updated>1712112106501</updated>
</task>
<task id="LOCAL-00003" summary="新增统计token接口">
<option name="closed" value="true" />
<created>1712112345799</created>
<option name="number" value="00003" />
<option name="presentableId" value="LOCAL-00003" />
<option name="project" value="LOCAL" />
<updated>1712112345799</updated>
</task>
<task id="LOCAL-00004" summary="新增统计token接口">
<option name="closed" value="true" />
<created>1712112490787</created>
<option name="number" value="00004" />
<option name="presentableId" value="LOCAL-00004" />
<option name="project" value="LOCAL" />
<updated>1712112490787</updated>
</task>
<task id="LOCAL-00005" summary="参数文件">
<option name="closed" value="true" />
<created>1712112777402</created>
<option name="number" value="00005" />
<option name="presentableId" value="LOCAL-00005" />
<option name="project" value="LOCAL" />
<updated>1712112777402</updated>
</task>
<option name="localTasksCounter" value="6" />
<servers />
</component>
<component name="TypeScriptGeneratedFilesManager">
<option name="version" value="3" />
</component>
<component name="VcsManagerConfiguration">
<MESSAGE value="新增统计token接口" />
<MESSAGE value="参数文件" />
<option name="LAST_COMMIT_MESSAGE" value="参数文件" />
</component>
</project> </project>

@ -12,8 +12,14 @@ docs/Model/ChatParam.md
docs/Model/ChatParam.md docs/Model/ChatParam.md
docs/Model/ChatResult.md docs/Model/ChatResult.md
docs/Model/ChatResult.md docs/Model/ChatResult.md
docs/Model/ExtractTextParam.md
docs/Model/ExtractTextParam.md
docs/Model/ExtractTextResult.md
docs/Model/ExtractTextResult.md
docs/Model/ResponseOpenAPIChatResult.md docs/Model/ResponseOpenAPIChatResult.md
docs/Model/ResponseOpenAPIChatResult.md docs/Model/ResponseOpenAPIChatResult.md
docs/Model/ResponseOpenAPIExtractTextResult.md
docs/Model/ResponseOpenAPIExtractTextResult.md
docs/Model/ResponseOpenAPITokensCountResult.md docs/Model/ResponseOpenAPITokensCountResult.md
docs/Model/ResponseOpenAPITokensCountResult.md docs/Model/ResponseOpenAPITokensCountResult.md
docs/Model/SpeechResult.md docs/Model/SpeechResult.md
@ -36,8 +42,11 @@ lib/Configuration.php
lib/HeaderSelector.php lib/HeaderSelector.php
lib/Model/ChatParam.php lib/Model/ChatParam.php
lib/Model/ChatResult.php lib/Model/ChatResult.php
lib/Model/ExtractTextParam.php
lib/Model/ExtractTextResult.php
lib/Model/ModelInterface.php lib/Model/ModelInterface.php
lib/Model/ResponseOpenAPIChatResult.php lib/Model/ResponseOpenAPIChatResult.php
lib/Model/ResponseOpenAPIExtractTextResult.php
lib/Model/ResponseOpenAPITokensCountResult.php lib/Model/ResponseOpenAPITokensCountResult.php
lib/Model/SpeechResult.php lib/Model/SpeechResult.php
lib/Model/StreamModule.php lib/Model/StreamModule.php
@ -52,7 +61,10 @@ phpunit.xml.dist
test/Api/AiApiTest.php test/Api/AiApiTest.php
test/Model/ChatParamTest.php test/Model/ChatParamTest.php
test/Model/ChatResultTest.php test/Model/ChatResultTest.php
test/Model/ExtractTextParamTest.php
test/Model/ExtractTextResultTest.php
test/Model/ResponseOpenAPIChatResultTest.php test/Model/ResponseOpenAPIChatResultTest.php
test/Model/ResponseOpenAPIExtractTextResultTest.php
test/Model/ResponseOpenAPITokensCountResultTest.php test/Model/ResponseOpenAPITokensCountResultTest.php
test/Model/SpeechResultTest.php test/Model/SpeechResultTest.php
test/Model/StreamModuleTest.php test/Model/StreamModuleTest.php

@ -1 +1 @@
93328f7a4d67575a1c99daa92560bd0a39e5116d1e4eb8dd9cd149ca46040344 8ddb52fb40c3511783f56cc9adf3407cbd17f68f1d980389999b4b0584c8e064

@ -154,13 +154,17 @@ function example()
Class | Method | HTTP request | Description Class | Method | HTTP request | Description
------------ | ------------- | ------------- | ------------- ------------ | ------------- | ------------- | -------------
*AiApi* | [**chat**](docs/Api/AiApi.md#chat) | **POST** /v1/ai/chat | 元梦ai-对话 *AiApi* | [**chat**](docs/Api/AiApi.md#chat) | **POST** /v1/ai/chat | 元梦ai-对话
*AiApi* | [**extractText**](docs/Api/AiApi.md#extracttext) | **POST** /v1/ai/extractText | 元梦ai-提取文件文本内容
*AiApi* | [**tokenCount**](docs/Api/AiApi.md#tokencount) | **POST** /v1/ai/tokenCount | 元梦ai-token统计 *AiApi* | [**tokenCount**](docs/Api/AiApi.md#tokencount) | **POST** /v1/ai/tokenCount | 元梦ai-token统计
## 模型文档 ## 模型文档
- [ChatParam](docs/Model/ChatParam.md) - [ChatParam](docs/Model/ChatParam.md)
- [ChatResult](docs/Model/ChatResult.md) - [ChatResult](docs/Model/ChatResult.md)
- [ExtractTextParam](docs/Model/ExtractTextParam.md)
- [ExtractTextResult](docs/Model/ExtractTextResult.md)
- [ResponseOpenAPIChatResult](docs/Model/ResponseOpenAPIChatResult.md) - [ResponseOpenAPIChatResult](docs/Model/ResponseOpenAPIChatResult.md)
- [ResponseOpenAPIExtractTextResult](docs/Model/ResponseOpenAPIExtractTextResult.md)
- [ResponseOpenAPITokensCountResult](docs/Model/ResponseOpenAPITokensCountResult.md) - [ResponseOpenAPITokensCountResult](docs/Model/ResponseOpenAPITokensCountResult.md)
- [SpeechResult](docs/Model/SpeechResult.md) - [SpeechResult](docs/Model/SpeechResult.md)
- [StreamModule](docs/Model/StreamModule.md) - [StreamModule](docs/Model/StreamModule.md)

@ -1,5 +1,6 @@
{ {
"name": "tsl3060/low-carbon-platform", "name": "tsl3060/low-carbon-platform",
"version": "1.1.2",
"description": "碳丝路数据开放平台", "description": "碳丝路数据开放平台",
"keywords": [ "keywords": [
"openapitools", "openapitools",

@ -3,6 +3,7 @@
| Method | HTTP request | Description | | Method | HTTP request | Description |
| ------------- | ------------- | ------------- | | ------------- | ------------- | ------------- |
| [**chat()**](AiApi.md#chat) | **POST** /v1/ai/chat | 元梦ai-对话 | | [**chat()**](AiApi.md#chat) | **POST** /v1/ai/chat | 元梦ai-对话 |
| [**extractText()**](AiApi.md#extractText) | **POST** /v1/ai/extractText | 元梦ai-提取文件文本内容 |
| [**tokenCount()**](AiApi.md#tokenCount) | **POST** /v1/ai/tokenCount | 元梦ai-token统计 | | [**tokenCount()**](AiApi.md#tokenCount) | **POST** /v1/ai/tokenCount | 元梦ai-token统计 |
@ -58,6 +59,62 @@ try {
[[返回模型列表]](../../README.md#模型文档) [[返回模型列表]](../../README.md#模型文档)
[[返回README]](../../README.md) [[返回README]](../../README.md)
## `extractText()`
```php
extractText($file, $file2, $param): \OpenAPI\Client\Model\ResponseOpenAPIExtractTextResult
```
元梦ai-提取文件文本内容
提取上传文件的文本内容
### 示例
```php
<?php
require_once(__DIR__ . '/vendor/autoload.php');
$apiInstance = new OpenAPI\Client\Api\AiApi(
// If you want use custom http client, pass your client which implements `GuzzleHttp\ClientInterface`.
// This is optional, `GuzzleHttp\Client` will be used as default.
new GuzzleHttp\Client()
);
$file = "/path/to/file.txt"; // \SplFileObject
$file2 = "/path/to/file.txt"; // \SplFileObject
$param = new \OpenAPI\Client\Model\ExtractTextParam(); // \OpenAPI\Client\Model\ExtractTextParam
try {
$result = $apiInstance->extractText($file, $file2, $param);
print_r($result);
} catch (Exception $e) {
echo 'Exception when calling AiApi->extractText: ', $e->getMessage(), PHP_EOL;
}
```
### 参数
| Name | Type | Description | Notes |
| ------------- | ------------- | ------------- | ------------- |
| **file** | **\SplFileObject****\SplFileObject**| | |
| **file2** | **\SplFileObject****\SplFileObject**| | [optional] |
| **param** | [**\OpenAPI\Client\Model\ExtractTextParam**](../Model/ExtractTextParam.md)| | [optional] |
### 返回类型
[**\OpenAPI\Client\Model\ResponseOpenAPIExtractTextResult**](../Model/ResponseOpenAPIExtractTextResult.md)
### HTTP请求头
- **Content-Type**: `multipart/form-data`
- **Accept**: `*/*`
[[回到顶部]](#) [[返回API列表]](../../README.md#api端点文档)
[[返回模型列表]](../../README.md#模型文档)
[[返回README]](../../README.md)
## `tokenCount()` ## `tokenCount()`
```php ```php

@ -0,0 +1,9 @@
# # ExtractTextParam
## 属性
Name | Type | Description | Notes
------------ | ------------- | ------------- | -------------
**extension** | **string** | 文件扩展名(可选值:ppt、pptx、doc、docx、xls、xlsx、pdf) |
[[返回模型列表]](../../README.md#模型文档) [[返回API列表]](../../README.md#api端点文档) [[返回README]](../../README.md)

@ -0,0 +1,9 @@
# # ExtractTextResult
## 属性
Name | Type | Description | Notes
------------ | ------------- | ------------- | -------------
**text** | **string** | 文本内容 | [optional]
[[返回模型列表]](../../README.md#模型文档) [[返回API列表]](../../README.md#api端点文档) [[返回README]](../../README.md)

@ -0,0 +1,20 @@
# # ResponseOpenAPIExtractTextResult
## 属性
Name | Type | Description | Notes
------------ | ------------- | ------------- | -------------
**time** | **string** | 该消息发生的时间 | [optional]
**openid** | **string** | | [optional]
**payload** | [**\OpenAPI\Client\Model\ExtractTextResult**](ExtractTextResult.md) | | [optional]
**sign** | **string** | | [optional]
**charset** | **string** | | [optional]
**description** | **string** | | [optional]
**response_id** | **string** | 消息的唯一ID | [optional]
**err_code** | **int** | 该消息的错误码 | [optional]
**err_msg** | **string** | 错误消息描述 | [optional]
**sub_err** | **int** | 子错误的具体的代号 | [optional]
**sub_msg** | **string** | 子错误对应的提示消息 | [optional]
**sign_type** | **string** | | [optional]
[[返回模型列表]](../../README.md#模型文档) [[返回API列表]](../../README.md#api端点文档) [[返回README]](../../README.md)

@ -81,6 +81,9 @@ class AiApi
'chat' => [ 'chat' => [
'application/json', 'application/json',
], ],
'extractText' => [
'multipart/form-data',
],
'tokenCount' => [ 'tokenCount' => [
'application/json', 'application/json',
], ],
@ -419,7 +422,7 @@ class AiApi
$additionalParams['sign'] = $this->apiClient->requestSign($additionalParams); $additionalParams['sign'] = $this->apiClient->requestSign($additionalParams);
// 根据Content-Type决定如何合并额外的参数 // 根据Content-Type决定如何合并额外的参数
if (stripos($headers['Content-Type'], 'application/json') !== false) { if (array_key_exists("Content-Type", $headers) && stripos($headers['Content-Type'], 'application/json') !== false) {
// 如果是application/json,将额外的参数合并到现有的JSON对象中 // 如果是application/json,将额外的参数合并到现有的JSON对象中
$existingParams = json_decode($httpBody, true); $existingParams = json_decode($httpBody, true);
if ($existingParams === null) { if ($existingParams === null) {
@ -427,7 +430,7 @@ class AiApi
} }
$mergedParams = array_merge($existingParams, $additionalParams); $mergedParams = array_merge($existingParams, $additionalParams);
$httpBody = json_encode($mergedParams, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE); $httpBody = json_encode($mergedParams, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE);
} else { } else if(array_key_exists("Content-Type", $headers)){
// 如果不是application/json,将额外的参数合并到现有的查询字符串中 // 如果不是application/json,将额外的参数合并到现有的查询字符串中
$existingParams = []; $existingParams = [];
if ($httpBody != null) { if ($httpBody != null) {
@ -458,6 +461,353 @@ class AiApi
); );
} }
/**
* Operation extractText
*
* 元梦ai-提取文件文本内容
*
* @param \SplFileObject $file file (required)
* @param \SplFileObject $file2 file2 (optional)
* @param \OpenAPI\Client\Model\ExtractTextParam $param param (optional)
* @param string $contentType The value for the Content-Type header. Check self::contentTypes['extractText'] to see the possible values for this operation
*
* @throws \OpenAPI\Client\ApiException on non-2xx response
* @throws \InvalidArgumentException
* @return \OpenAPI\Client\Model\ResponseOpenAPIExtractTextResult
*/
public function extractText($file, $file2 = null, $param = null, string $contentType = self::contentTypes['extractText'][0])
{
list($response) = $this->extractTextWithHttpInfo($file, $file2, $param, $contentType);
return $response;
}
/**
* Operation extractTextWithHttpInfo
*
* 元梦ai-提取文件文本内容
*
* @param \SplFileObject $file (required)
* @param \SplFileObject $file2 (optional)
* @param \OpenAPI\Client\Model\ExtractTextParam $param (optional)
* @param string $contentType The value for the Content-Type header. Check self::contentTypes['extractText'] to see the possible values for this operation
*
* @throws \OpenAPI\Client\ApiException on non-2xx response
* @throws \InvalidArgumentException
* @return array of \OpenAPI\Client\Model\ResponseOpenAPIExtractTextResult, HTTP status code, HTTP response headers (array of strings)
*/
public function extractTextWithHttpInfo($file, $file2 = null, $param = null, string $contentType = self::contentTypes['extractText'][0])
{
$request = $this->extractTextRequest($file, $file2, $param, $contentType);
try {
$options = $this->createHttpClientOption();
try {
$response = $this->client->send($request, $options);
} catch (RequestException $e) {
throw new ApiException(
"[{$e->getCode()}] {$e->getMessage()}",
(int) $e->getCode(),
$e->getResponse() ? $e->getResponse()->getHeaders() : null,
$e->getResponse() ? (string) $e->getResponse()->getBody() : null
);
} catch (ConnectException $e) {
throw new ApiException(
"[{$e->getCode()}] {$e->getMessage()}",
(int) $e->getCode(),
null,
null
);
}
// 响应预处理
$data = json_decode($response->getBody(), true);
if (json_last_error() !== JSON_ERROR_NONE) {
throw new ApiException("JSON解码错误: " . json_last_error_msg());
}
// 验证签名
if (!$this->apiClient->verifySign($data)) {
throw new ApiException(
'Verification failed',
$response->getStatusCode(),
$response->getHeaders(),
$response->getBody()
);
}
$statusCode = $response->getStatusCode();
if ($statusCode < 200 || $statusCode > 299) {
throw new ApiException(
sprintf(
'[%d] Error connecting to the API (%s)',
$statusCode,
(string) $request->getUri()
),
$statusCode,
$response->getHeaders(),
(string) $response->getBody()
);
}
switch($statusCode) {
case 200:
if ('\OpenAPI\Client\Model\ResponseOpenAPIExtractTextResult' === '\SplFileObject') {
$content = $response->getBody(); //stream goes to serializer
} else {
$content = (string) $response->getBody();
if ('\OpenAPI\Client\Model\ResponseOpenAPIExtractTextResult' !== 'string') {
$content = json_decode($content);
}
}
return [
ObjectSerializer::deserialize($content, '\OpenAPI\Client\Model\ResponseOpenAPIExtractTextResult', []),
$response->getStatusCode(),
$response->getHeaders()
];
}
$returnType = '\OpenAPI\Client\Model\ResponseOpenAPIExtractTextResult';
if ($returnType === '\SplFileObject') {
$content = $response->getBody(); //stream goes to serializer
} else {
$content = (string) $response->getBody();
if ($returnType !== 'string') {
$content = json_decode($content);
}
}
return [
ObjectSerializer::deserialize($content, $returnType, []),
$response->getStatusCode(),
$response->getHeaders()
];
} catch (ApiException $e) {
switch ($e->getCode()) {
case 200:
$data = ObjectSerializer::deserialize(
$e->getResponseBody(),
'\OpenAPI\Client\Model\ResponseOpenAPIExtractTextResult',
$e->getResponseHeaders()
);
$e->setResponseObject($data);
break;
}
throw $e;
}
}
/**
* Operation extractTextAsync
*
* 元梦ai-提取文件文本内容
*
* @param \SplFileObject $file (required)
* @param \SplFileObject $file2 (optional)
* @param \OpenAPI\Client\Model\ExtractTextParam $param (optional)
* @param string $contentType The value for the Content-Type header. Check self::contentTypes['extractText'] to see the possible values for this operation
*
* @throws \InvalidArgumentException
* @return \GuzzleHttp\Promise\PromiseInterface
*/
public function extractTextAsync($file, $file2 = null, $param = null, string $contentType = self::contentTypes['extractText'][0])
{
return $this->extractTextAsyncWithHttpInfo($file, $file2, $param, $contentType)
->then(
function ($response) {
return $response[0];
}
);
}
/**
* Operation extractTextAsyncWithHttpInfo
*
* 元梦ai-提取文件文本内容
*
* @param \SplFileObject $file (required)
* @param \SplFileObject $file2 (optional)
* @param \OpenAPI\Client\Model\ExtractTextParam $param (optional)
* @param string $contentType The value for the Content-Type header. Check self::contentTypes['extractText'] to see the possible values for this operation
*
* @throws \InvalidArgumentException
* @return \GuzzleHttp\Promise\PromiseInterface
*/
public function extractTextAsyncWithHttpInfo($file, $file2 = null, $param = null, string $contentType = self::contentTypes['extractText'][0])
{
$returnType = '\OpenAPI\Client\Model\ResponseOpenAPIExtractTextResult';
$request = $this->extractTextRequest($file, $file2, $param, $contentType);
return $this->client
->sendAsync($request, $this->createHttpClientOption())
->then(
function ($response) use ($returnType) {
if ($returnType === '\SplFileObject') {
$content = $response->getBody(); //stream goes to serializer
} else {
$content = (string) $response->getBody();
if ($returnType !== 'string') {
$content = json_decode($content);
}
}
return [
ObjectSerializer::deserialize($content, $returnType, []),
$response->getStatusCode(),
$response->getHeaders()
];
},
function ($exception) {
$response = $exception->getResponse();
$statusCode = $response->getStatusCode();
throw new ApiException(
sprintf(
'[%d] Error connecting to the API (%s)',
$statusCode,
$exception->getRequest()->getUri()
),
$statusCode,
$response->getHeaders(),
(string) $response->getBody()
);
}
);
}
/**
* Create request for operation 'extractText'
*
* @param \SplFileObject $file (required)
* @param \SplFileObject $file2 (optional)
* @param \OpenAPI\Client\Model\ExtractTextParam $param (optional)
* @param string $contentType The value for the Content-Type header. Check self::contentTypes['extractText'] to see the possible values for this operation
*
* @throws \InvalidArgumentException
* @return \GuzzleHttp\Psr7\Request
*/
public function extractTextRequest($file, $file2 = null, $param = null, string $contentType = self::contentTypes['extractText'][0])
{
// verify the required parameter 'file' is set
if ($file === null || (is_array($file) && count($file) === 0)) {
throw new \InvalidArgumentException(
'Missing the required parameter $file when calling extractText'
);
}
$resourcePath = '/v1/ai/extractText';
$formParams = [];
$queryParams = [];
$headerParams = [];
$httpBody = '';
$multipart = false;
// query params
$queryParams = array_merge($queryParams, ObjectSerializer::toQueryValue(
$file,
'file', // param base name
'string', // openApiType
'form', // style
true, // explode
true // required
) ?? []);
// form params
if ($file2 !== null) {
$multipart = true;
$formParams['file'] = [];
$paramFiles = is_array($file2) ? $file2 : [$file2];
foreach ($paramFiles as $paramFile) {
$formParams['file'][] = \GuzzleHttp\Psr7\Utils::tryFopen(
ObjectSerializer::toFormValue($paramFile),
'rb'
);
}
}
// form params
if ($param !== null) {
$formParams['param'] = ObjectSerializer::toFormValue($param);
}
$headers = $this->headerSelector->selectHeaders(
['*/*', ],
$contentType,
$multipart
);
// for model (json/xml)
// 初始化额外的参数
$additionalParams = [
'payload' => json_decode($httpBody, true),
'path' => $resourcePath,
'charset' => $this->config->getCharset(),
'time' => date($this->config->getDataFormat(), time()),
'sign_type' => $this->config->getSignType(),
'access_token' => '',
'app_id' => $this->config->getAppid(),
'sign' => ''
];
$additionalParams['sign'] = $this->apiClient->requestSign($additionalParams);
if (count($formParams) > 0) {
if ($multipart) {
$multipartContents = [];
foreach ($formParams as $formParamName => $formParamValue) {
$formParamValueItems = is_array($formParamValue) ? $formParamValue : [$formParamValue];
foreach ($formParamValueItems as $formParamValueItem) {
$multipartContents[] = [
'name' => $formParamName,
'contents' => $formParamValueItem
];
}
}
$multipartContents[] = [
'name' => 'sign_param',
'contents' => json_encode($additionalParams)
];
// for HTTP post (form)
$httpBody = new MultipartStream($multipartContents);
} elseif (stripos($headers['Content-Type'], 'application/json') !== false) {
# if Content-Type contains "application/json", json_encode the form parameters
$httpBody = \GuzzleHttp\Utils::jsonEncode($formParams);
} else {
// for HTTP post (form)
$httpBody = ObjectSerializer::buildQuery($formParams);
}
}
$defaultHeaders = [];
if ($this->config->getUserAgent()) {
$defaultHeaders['User-Agent'] = $this->config->getUserAgent();
}
$headers = array_merge(
$defaultHeaders,
$headerParams,
$headers
);
$operationHost = $this->config->getHost();
$query = ObjectSerializer::buildQuery($queryParams);
return new Request(
'POST',
$operationHost . $resourcePath . ($query ? "?{$query}" : ''),
$headers,
$httpBody
);
}
/** /**
* Operation tokenCount * Operation tokenCount
* *
@ -744,7 +1094,7 @@ class AiApi
$additionalParams['sign'] = $this->apiClient->requestSign($additionalParams); $additionalParams['sign'] = $this->apiClient->requestSign($additionalParams);
// 根据Content-Type决定如何合并额外的参数 // 根据Content-Type决定如何合并额外的参数
if (stripos($headers['Content-Type'], 'application/json') !== false) { if (array_key_exists("Content-Type", $headers) && stripos($headers['Content-Type'], 'application/json') !== false) {
// 如果是application/json,将额外的参数合并到现有的JSON对象中 // 如果是application/json,将额外的参数合并到现有的JSON对象中
$existingParams = json_decode($httpBody, true); $existingParams = json_decode($httpBody, true);
if ($existingParams === null) { if ($existingParams === null) {
@ -752,7 +1102,7 @@ class AiApi
} }
$mergedParams = array_merge($existingParams, $additionalParams); $mergedParams = array_merge($existingParams, $additionalParams);
$httpBody = json_encode($mergedParams, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE); $httpBody = json_encode($mergedParams, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE);
} else { } else if(array_key_exists("Content-Type", $headers)){
// 如果不是application/json,将额外的参数合并到现有的查询字符串中 // 如果不是application/json,将额外的参数合并到现有的查询字符串中
$existingParams = []; $existingParams = [];
if ($httpBody != null) { if ($httpBody != null) {

@ -0,0 +1,413 @@
<?php
/**
* ExtractTextParam
*
* PHP version 7.4
*
* @category Class
* @package OpenAPI\Client
* @author OpenAPI Generator team
* @link https://openapi-generator.tech
*/
/**
* 碳丝路数据开放平台API
*
* 碳丝路数据开放平台
*
* The version of the OpenAPI document: 0.4.8
* Generated by: https://openapi-generator.tech
* OpenAPI Generator version: 7.0.1
*/
/**
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Do not edit the class manually.
*/
namespace OpenAPI\Client\Model;
use \ArrayAccess;
use \OpenAPI\Client\ObjectSerializer;
/**
* ExtractTextParam Class Doc Comment
*
* @category Class
* @description 提取文件文本所需参数
* @package OpenAPI\Client
* @author OpenAPI Generator team
* @link https://openapi-generator.tech
* @implements \ArrayAccess<string, mixed>
*/
class ExtractTextParam implements ModelInterface, ArrayAccess, \JsonSerializable
{
public const DISCRIMINATOR = null;
/**
* The original name of the model.
*
* @var string
*/
protected static $openAPIModelName = 'ExtractTextParam';
/**
* Array of property to type mappings. Used for (de)serialization
*
* @var string[]
*/
protected static $openAPITypes = [
'extension' => 'string'
];
/**
* Array of property to format mappings. Used for (de)serialization
*
* @var string[]
* @phpstan-var array<string, string|null>
* @psalm-var array<string, string|null>
*/
protected static $openAPIFormats = [
'extension' => null
];
/**
* Array of nullable properties. Used for (de)serialization
*
* @var boolean[]
*/
protected static array $openAPINullables = [
'extension' => false
];
/**
* If a nullable field gets set to null, insert it here
*
* @var boolean[]
*/
protected array $openAPINullablesSetToNull = [];
/**
* Array of property to type mappings. Used for (de)serialization
*
* @return array
*/
public static function openAPITypes()
{
return self::$openAPITypes;
}
/**
* Array of property to format mappings. Used for (de)serialization
*
* @return array
*/
public static function openAPIFormats()
{
return self::$openAPIFormats;
}
/**
* Array of nullable properties
*
* @return array
*/
protected static function openAPINullables(): array
{
return self::$openAPINullables;
}
/**
* Array of nullable field names deliberately set to null
*
* @return boolean[]
*/
private function getOpenAPINullablesSetToNull(): array
{
return $this->openAPINullablesSetToNull;
}
/**
* Setter - Array of nullable field names deliberately set to null
*
* @param boolean[] $openAPINullablesSetToNull
*/
private function setOpenAPINullablesSetToNull(array $openAPINullablesSetToNull): void
{
$this->openAPINullablesSetToNull = $openAPINullablesSetToNull;
}
/**
* Checks if a property is nullable
*
* @param string $property
* @return bool
*/
public static function isNullable(string $property): bool
{
return self::openAPINullables()[$property] ?? false;
}
/**
* Checks if a nullable property is set to null.
*
* @param string $property
* @return bool
*/
public function isNullableSetToNull(string $property): bool
{
return in_array($property, $this->getOpenAPINullablesSetToNull(), true);
}
/**
* Array of attributes where the key is the local name,
* and the value is the original name
*
* @var string[]
*/
protected static $attributeMap = [
'extension' => 'extension'
];
/**
* Array of attributes to setter functions (for deserialization of responses)
*
* @var string[]
*/
protected static $setters = [
'extension' => 'setExtension'
];
/**
* Array of attributes to getter functions (for serialization of requests)
*
* @var string[]
*/
protected static $getters = [
'extension' => 'getExtension'
];
/**
* Array of attributes where the key is the local name,
* and the value is the original name
*
* @return array
*/
public static function attributeMap()
{
return self::$attributeMap;
}
/**
* Array of attributes to setter functions (for deserialization of responses)
*
* @return array
*/
public static function setters()
{
return self::$setters;
}
/**
* Array of attributes to getter functions (for serialization of requests)
*
* @return array
*/
public static function getters()
{
return self::$getters;
}
/**
* The original name of the model.
*
* @return string
*/
public function getModelName()
{
return self::$openAPIModelName;
}
/**
* Associative array for storing property values
*
* @var mixed[]
*/
protected $container = [];
/**
* Constructor
*
* @param mixed[] $data Associated array of property values
* initializing the model
*/
public function __construct(array $data = null)
{
$this->setIfExists('extension', $data ?? [], null);
}
/**
* Sets $this->container[$variableName] to the given data or to the given default Value; if $variableName
* is nullable and its value is set to null in the $fields array, then mark it as "set to null" in the
* $this->openAPINullablesSetToNull array
*
* @param string $variableName
* @param array $fields
* @param mixed $defaultValue
*/
private function setIfExists(string $variableName, array $fields, $defaultValue): void
{
if (self::isNullable($variableName) && array_key_exists($variableName, $fields) && is_null($fields[$variableName])) {
$this->openAPINullablesSetToNull[] = $variableName;
}
$this->container[$variableName] = $fields[$variableName] ?? $defaultValue;
}
/**
* Show all the invalid properties with reasons.
*
* @return array invalid properties with reasons
*/
public function listInvalidProperties()
{
$invalidProperties = [];
if ($this->container['extension'] === null) {
$invalidProperties[] = "'extension' can't be null";
}
return $invalidProperties;
}
/**
* Validate all the properties in the model
* return true if all passed
*
* @return bool True if all properties are valid
*/
public function valid()
{
return count($this->listInvalidProperties()) === 0;
}
/**
* Gets extension
*
* @return string
*/
public function getExtension()
{
return $this->container['extension'];
}
/**
* Sets extension
*
* @param string $extension 文件扩展名(可选值:ppt、pptx、doc、docx、xls、xlsx、pdf)
*
* @return self
*/
public function setExtension($extension)
{
if (is_null($extension)) {
throw new \InvalidArgumentException('non-nullable extension cannot be null');
}
$this->container['extension'] = $extension;
return $this;
}
/**
* Returns true if offset exists. False otherwise.
*
* @param integer $offset Offset
*
* @return boolean
*/
public function offsetExists($offset): bool
{
return isset($this->container[$offset]);
}
/**
* Gets offset.
*
* @param integer $offset Offset
*
* @return mixed|null
*/
#[\ReturnTypeWillChange]
public function offsetGet($offset)
{
return $this->container[$offset] ?? null;
}
/**
* Sets value based on offset.
*
* @param int|null $offset Offset
* @param mixed $value Value to be set
*
* @return void
*/
public function offsetSet($offset, $value): void
{
if (is_null($offset)) {
$this->container[] = $value;
} else {
$this->container[$offset] = $value;
}
}
/**
* Unsets offset.
*
* @param integer $offset Offset
*
* @return void
*/
public function offsetUnset($offset): void
{
unset($this->container[$offset]);
}
/**
* Serializes the object to a value that can be serialized natively by json_encode().
* @link https://www.php.net/manual/en/jsonserializable.jsonserialize.php
*
* @return mixed Returns data which can be serialized by json_encode(), which is a value
* of any type other than a resource.
*/
#[\ReturnTypeWillChange]
public function jsonSerialize()
{
return ObjectSerializer::sanitizeForSerialization($this);
}
/**
* Gets the string presentation of the object
*
* @return string
*/
public function __toString()
{
return json_encode(
ObjectSerializer::sanitizeForSerialization($this),
JSON_PRETTY_PRINT
);
}
/**
* Gets a header-safe presentation of the object
*
* @return string
*/
public function toHeaderValue()
{
return json_encode(ObjectSerializer::sanitizeForSerialization($this));
}
}

@ -0,0 +1,410 @@
<?php
/**
* ExtractTextResult
*
* PHP version 7.4
*
* @category Class
* @package OpenAPI\Client
* @author OpenAPI Generator team
* @link https://openapi-generator.tech
*/
/**
* 碳丝路数据开放平台API
*
* 碳丝路数据开放平台
*
* The version of the OpenAPI document: 0.4.8
* Generated by: https://openapi-generator.tech
* OpenAPI Generator version: 7.0.1
*/
/**
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Do not edit the class manually.
*/
namespace OpenAPI\Client\Model;
use \ArrayAccess;
use \OpenAPI\Client\ObjectSerializer;
/**
* ExtractTextResult Class Doc Comment
*
* @category Class
* @description 提取文本结果
* @package OpenAPI\Client
* @author OpenAPI Generator team
* @link https://openapi-generator.tech
* @implements \ArrayAccess<string, mixed>
*/
class ExtractTextResult implements ModelInterface, ArrayAccess, \JsonSerializable
{
public const DISCRIMINATOR = null;
/**
* The original name of the model.
*
* @var string
*/
protected static $openAPIModelName = 'ExtractTextResult';
/**
* Array of property to type mappings. Used for (de)serialization
*
* @var string[]
*/
protected static $openAPITypes = [
'text' => 'string'
];
/**
* Array of property to format mappings. Used for (de)serialization
*
* @var string[]
* @phpstan-var array<string, string|null>
* @psalm-var array<string, string|null>
*/
protected static $openAPIFormats = [
'text' => null
];
/**
* Array of nullable properties. Used for (de)serialization
*
* @var boolean[]
*/
protected static array $openAPINullables = [
'text' => false
];
/**
* If a nullable field gets set to null, insert it here
*
* @var boolean[]
*/
protected array $openAPINullablesSetToNull = [];
/**
* Array of property to type mappings. Used for (de)serialization
*
* @return array
*/
public static function openAPITypes()
{
return self::$openAPITypes;
}
/**
* Array of property to format mappings. Used for (de)serialization
*
* @return array
*/
public static function openAPIFormats()
{
return self::$openAPIFormats;
}
/**
* Array of nullable properties
*
* @return array
*/
protected static function openAPINullables(): array
{
return self::$openAPINullables;
}
/**
* Array of nullable field names deliberately set to null
*
* @return boolean[]
*/
private function getOpenAPINullablesSetToNull(): array
{
return $this->openAPINullablesSetToNull;
}
/**
* Setter - Array of nullable field names deliberately set to null
*
* @param boolean[] $openAPINullablesSetToNull
*/
private function setOpenAPINullablesSetToNull(array $openAPINullablesSetToNull): void
{
$this->openAPINullablesSetToNull = $openAPINullablesSetToNull;
}
/**
* Checks if a property is nullable
*
* @param string $property
* @return bool
*/
public static function isNullable(string $property): bool
{
return self::openAPINullables()[$property] ?? false;
}
/**
* Checks if a nullable property is set to null.
*
* @param string $property
* @return bool
*/
public function isNullableSetToNull(string $property): bool
{
return in_array($property, $this->getOpenAPINullablesSetToNull(), true);
}
/**
* Array of attributes where the key is the local name,
* and the value is the original name
*
* @var string[]
*/
protected static $attributeMap = [
'text' => 'text'
];
/**
* Array of attributes to setter functions (for deserialization of responses)
*
* @var string[]
*/
protected static $setters = [
'text' => 'setText'
];
/**
* Array of attributes to getter functions (for serialization of requests)
*
* @var string[]
*/
protected static $getters = [
'text' => 'getText'
];
/**
* Array of attributes where the key is the local name,
* and the value is the original name
*
* @return array
*/
public static function attributeMap()
{
return self::$attributeMap;
}
/**
* Array of attributes to setter functions (for deserialization of responses)
*
* @return array
*/
public static function setters()
{
return self::$setters;
}
/**
* Array of attributes to getter functions (for serialization of requests)
*
* @return array
*/
public static function getters()
{
return self::$getters;
}
/**
* The original name of the model.
*
* @return string
*/
public function getModelName()
{
return self::$openAPIModelName;
}
/**
* Associative array for storing property values
*
* @var mixed[]
*/
protected $container = [];
/**
* Constructor
*
* @param mixed[] $data Associated array of property values
* initializing the model
*/
public function __construct(array $data = null)
{
$this->setIfExists('text', $data ?? [], null);
}
/**
* Sets $this->container[$variableName] to the given data or to the given default Value; if $variableName
* is nullable and its value is set to null in the $fields array, then mark it as "set to null" in the
* $this->openAPINullablesSetToNull array
*
* @param string $variableName
* @param array $fields
* @param mixed $defaultValue
*/
private function setIfExists(string $variableName, array $fields, $defaultValue): void
{
if (self::isNullable($variableName) && array_key_exists($variableName, $fields) && is_null($fields[$variableName])) {
$this->openAPINullablesSetToNull[] = $variableName;
}
$this->container[$variableName] = $fields[$variableName] ?? $defaultValue;
}
/**
* Show all the invalid properties with reasons.
*
* @return array invalid properties with reasons
*/
public function listInvalidProperties()
{
$invalidProperties = [];
return $invalidProperties;
}
/**
* Validate all the properties in the model
* return true if all passed
*
* @return bool True if all properties are valid
*/
public function valid()
{
return count($this->listInvalidProperties()) === 0;
}
/**
* Gets text
*
* @return string|null
*/
public function getText()
{
return $this->container['text'];
}
/**
* Sets text
*
* @param string|null $text 文本内容
*
* @return self
*/
public function setText($text)
{
if (is_null($text)) {
throw new \InvalidArgumentException('non-nullable text cannot be null');
}
$this->container['text'] = $text;
return $this;
}
/**
* Returns true if offset exists. False otherwise.
*
* @param integer $offset Offset
*
* @return boolean
*/
public function offsetExists($offset): bool
{
return isset($this->container[$offset]);
}
/**
* Gets offset.
*
* @param integer $offset Offset
*
* @return mixed|null
*/
#[\ReturnTypeWillChange]
public function offsetGet($offset)
{
return $this->container[$offset] ?? null;
}
/**
* Sets value based on offset.
*
* @param int|null $offset Offset
* @param mixed $value Value to be set
*
* @return void
*/
public function offsetSet($offset, $value): void
{
if (is_null($offset)) {
$this->container[] = $value;
} else {
$this->container[$offset] = $value;
}
}
/**
* Unsets offset.
*
* @param integer $offset Offset
*
* @return void
*/
public function offsetUnset($offset): void
{
unset($this->container[$offset]);
}
/**
* Serializes the object to a value that can be serialized natively by json_encode().
* @link https://www.php.net/manual/en/jsonserializable.jsonserialize.php
*
* @return mixed Returns data which can be serialized by json_encode(), which is a value
* of any type other than a resource.
*/
#[\ReturnTypeWillChange]
public function jsonSerialize()
{
return ObjectSerializer::sanitizeForSerialization($this);
}
/**
* Gets the string presentation of the object
*
* @return string
*/
public function __toString()
{
return json_encode(
ObjectSerializer::sanitizeForSerialization($this),
JSON_PRETTY_PRINT
);
}
/**
* Gets a header-safe presentation of the object
*
* @return string
*/
public function toHeaderValue()
{
return json_encode(ObjectSerializer::sanitizeForSerialization($this));
}
}

@ -0,0 +1,784 @@
<?php
/**
* ResponseOpenAPIExtractTextResult
*
* PHP version 7.4
*
* @category Class
* @package OpenAPI\Client
* @author OpenAPI Generator team
* @link https://openapi-generator.tech
*/
/**
* 碳丝路数据开放平台API
*
* 碳丝路数据开放平台
*
* The version of the OpenAPI document: 0.4.8
* Generated by: https://openapi-generator.tech
* OpenAPI Generator version: 7.0.1
*/
/**
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Do not edit the class manually.
*/
namespace OpenAPI\Client\Model;
use \ArrayAccess;
use \OpenAPI\Client\ObjectSerializer;
/**
* ResponseOpenAPIExtractTextResult Class Doc Comment
*
* @category Class
* @description 消息载体对象
* @package OpenAPI\Client
* @author OpenAPI Generator team
* @link https://openapi-generator.tech
* @implements \ArrayAccess<string, mixed>
*/
class ResponseOpenAPIExtractTextResult implements ModelInterface, ArrayAccess, \JsonSerializable
{
public const DISCRIMINATOR = null;
/**
* The original name of the model.
*
* @var string
*/
protected static $openAPIModelName = 'ResponseOpenAPIExtractTextResult';
/**
* Array of property to type mappings. Used for (de)serialization
*
* @var string[]
*/
protected static $openAPITypes = [
'time' => 'string',
'openid' => 'string',
'payload' => '\OpenAPI\Client\Model\ExtractTextResult',
'sign' => 'string',
'charset' => 'string',
'description' => 'string',
'response_id' => 'string',
'err_code' => 'int',
'err_msg' => 'string',
'sub_err' => 'int',
'sub_msg' => 'string',
'sign_type' => 'string'
];
/**
* Array of property to format mappings. Used for (de)serialization
*
* @var string[]
* @phpstan-var array<string, string|null>
* @psalm-var array<string, string|null>
*/
protected static $openAPIFormats = [
'time' => null,
'openid' => null,
'payload' => null,
'sign' => null,
'charset' => null,
'description' => null,
'response_id' => null,
'err_code' => 'int32',
'err_msg' => null,
'sub_err' => 'int32',
'sub_msg' => null,
'sign_type' => null
];
/**
* Array of nullable properties. Used for (de)serialization
*
* @var boolean[]
*/
protected static array $openAPINullables = [
'time' => false,
'openid' => false,
'payload' => false,
'sign' => false,
'charset' => false,
'description' => false,
'response_id' => false,
'err_code' => false,
'err_msg' => false,
'sub_err' => false,
'sub_msg' => false,
'sign_type' => false
];
/**
* If a nullable field gets set to null, insert it here
*
* @var boolean[]
*/
protected array $openAPINullablesSetToNull = [];
/**
* Array of property to type mappings. Used for (de)serialization
*
* @return array
*/
public static function openAPITypes()
{
return self::$openAPITypes;
}
/**
* Array of property to format mappings. Used for (de)serialization
*
* @return array
*/
public static function openAPIFormats()
{
return self::$openAPIFormats;
}
/**
* Array of nullable properties
*
* @return array
*/
protected static function openAPINullables(): array
{
return self::$openAPINullables;
}
/**
* Array of nullable field names deliberately set to null
*
* @return boolean[]
*/
private function getOpenAPINullablesSetToNull(): array
{
return $this->openAPINullablesSetToNull;
}
/**
* Setter - Array of nullable field names deliberately set to null
*
* @param boolean[] $openAPINullablesSetToNull
*/
private function setOpenAPINullablesSetToNull(array $openAPINullablesSetToNull): void
{
$this->openAPINullablesSetToNull = $openAPINullablesSetToNull;
}
/**
* Checks if a property is nullable
*
* @param string $property
* @return bool
*/
public static function isNullable(string $property): bool
{
return self::openAPINullables()[$property] ?? false;
}
/**
* Checks if a nullable property is set to null.
*
* @param string $property
* @return bool
*/
public function isNullableSetToNull(string $property): bool
{
return in_array($property, $this->getOpenAPINullablesSetToNull(), true);
}
/**
* Array of attributes where the key is the local name,
* and the value is the original name
*
* @var string[]
*/
protected static $attributeMap = [
'time' => 'time',
'openid' => 'openid',
'payload' => 'payload',
'sign' => 'sign',
'charset' => 'charset',
'description' => 'description',
'response_id' => 'response_id',
'err_code' => 'err_code',
'err_msg' => 'err_msg',
'sub_err' => 'sub_err',
'sub_msg' => 'sub_msg',
'sign_type' => 'sign_type'
];
/**
* Array of attributes to setter functions (for deserialization of responses)
*
* @var string[]
*/
protected static $setters = [
'time' => 'setTime',
'openid' => 'setOpenid',
'payload' => 'setPayload',
'sign' => 'setSign',
'charset' => 'setCharset',
'description' => 'setDescription',
'response_id' => 'setResponseId',
'err_code' => 'setErrCode',
'err_msg' => 'setErrMsg',
'sub_err' => 'setSubErr',
'sub_msg' => 'setSubMsg',
'sign_type' => 'setSignType'
];
/**
* Array of attributes to getter functions (for serialization of requests)
*
* @var string[]
*/
protected static $getters = [
'time' => 'getTime',
'openid' => 'getOpenid',
'payload' => 'getPayload',
'sign' => 'getSign',
'charset' => 'getCharset',
'description' => 'getDescription',
'response_id' => 'getResponseId',
'err_code' => 'getErrCode',
'err_msg' => 'getErrMsg',
'sub_err' => 'getSubErr',
'sub_msg' => 'getSubMsg',
'sign_type' => 'getSignType'
];
/**
* Array of attributes where the key is the local name,
* and the value is the original name
*
* @return array
*/
public static function attributeMap()
{
return self::$attributeMap;
}
/**
* Array of attributes to setter functions (for deserialization of responses)
*
* @return array
*/
public static function setters()
{
return self::$setters;
}
/**
* Array of attributes to getter functions (for serialization of requests)
*
* @return array
*/
public static function getters()
{
return self::$getters;
}
/**
* The original name of the model.
*
* @return string
*/
public function getModelName()
{
return self::$openAPIModelName;
}
/**
* Associative array for storing property values
*
* @var mixed[]
*/
protected $container = [];
/**
* Constructor
*
* @param mixed[] $data Associated array of property values
* initializing the model
*/
public function __construct(array $data = null)
{
$this->setIfExists('time', $data ?? [], null);
$this->setIfExists('openid', $data ?? [], null);
$this->setIfExists('payload', $data ?? [], null);
$this->setIfExists('sign', $data ?? [], null);
$this->setIfExists('charset', $data ?? [], null);
$this->setIfExists('description', $data ?? [], null);
$this->setIfExists('response_id', $data ?? [], null);
$this->setIfExists('err_code', $data ?? [], null);
$this->setIfExists('err_msg', $data ?? [], null);
$this->setIfExists('sub_err', $data ?? [], null);
$this->setIfExists('sub_msg', $data ?? [], null);
$this->setIfExists('sign_type', $data ?? [], null);
}
/**
* Sets $this->container[$variableName] to the given data or to the given default Value; if $variableName
* is nullable and its value is set to null in the $fields array, then mark it as "set to null" in the
* $this->openAPINullablesSetToNull array
*
* @param string $variableName
* @param array $fields
* @param mixed $defaultValue
*/
private function setIfExists(string $variableName, array $fields, $defaultValue): void
{
if (self::isNullable($variableName) && array_key_exists($variableName, $fields) && is_null($fields[$variableName])) {
$this->openAPINullablesSetToNull[] = $variableName;
}
$this->container[$variableName] = $fields[$variableName] ?? $defaultValue;
}
/**
* Show all the invalid properties with reasons.
*
* @return array invalid properties with reasons
*/
public function listInvalidProperties()
{
$invalidProperties = [];
return $invalidProperties;
}
/**
* Validate all the properties in the model
* return true if all passed
*
* @return bool True if all properties are valid
*/
public function valid()
{
return count($this->listInvalidProperties()) === 0;
}
/**
* Gets time
*
* @return string|null
*/
public function getTime()
{
return $this->container['time'];
}
/**
* Sets time
*
* @param string|null $time 该消息发生的时间
*
* @return self
*/
public function setTime($time)
{
if (is_null($time)) {
throw new \InvalidArgumentException('non-nullable time cannot be null');
}
$this->container['time'] = $time;
return $this;
}
/**
* Gets openid
*
* @return string|null
*/
public function getOpenid()
{
return $this->container['openid'];
}
/**
* Sets openid
*
* @param string|null $openid openid
*
* @return self
*/
public function setOpenid($openid)
{
if (is_null($openid)) {
throw new \InvalidArgumentException('non-nullable openid cannot be null');
}
$this->container['openid'] = $openid;
return $this;
}
/**
* Gets payload
*
* @return \OpenAPI\Client\Model\ExtractTextResult|null
*/
public function getPayload()
{
return $this->container['payload'];
}
/**
* Sets payload
*
* @param \OpenAPI\Client\Model\ExtractTextResult|null $payload payload
*
* @return self
*/
public function setPayload($payload)
{
if (is_null($payload)) {
throw new \InvalidArgumentException('non-nullable payload cannot be null');
}
$this->container['payload'] = $payload;
return $this;
}
/**
* Gets sign
*
* @return string|null
*/
public function getSign()
{
return $this->container['sign'];
}
/**
* Sets sign
*
* @param string|null $sign sign
*
* @return self
*/
public function setSign($sign)
{
if (is_null($sign)) {
throw new \InvalidArgumentException('non-nullable sign cannot be null');
}
$this->container['sign'] = $sign;
return $this;
}
/**
* Gets charset
*
* @return string|null
*/
public function getCharset()
{
return $this->container['charset'];
}
/**
* Sets charset
*
* @param string|null $charset charset
*
* @return self
*/
public function setCharset($charset)
{
if (is_null($charset)) {
throw new \InvalidArgumentException('non-nullable charset cannot be null');
}
$this->container['charset'] = $charset;
return $this;
}
/**
* Gets description
*
* @return string|null
*/
public function getDescription()
{
return $this->container['description'];
}
/**
* Sets description
*
* @param string|null $description description
*
* @return self
*/
public function setDescription($description)
{
if (is_null($description)) {
throw new \InvalidArgumentException('non-nullable description cannot be null');
}
$this->container['description'] = $description;
return $this;
}
/**
* Gets response_id
*
* @return string|null
*/
public function getResponseId()
{
return $this->container['response_id'];
}
/**
* Sets response_id
*
* @param string|null $response_id 消息的唯一ID
*
* @return self
*/
public function setResponseId($response_id)
{
if (is_null($response_id)) {
throw new \InvalidArgumentException('non-nullable response_id cannot be null');
}
$this->container['response_id'] = $response_id;
return $this;
}
/**
* Gets err_code
*
* @return int|null
*/
public function getErrCode()
{
return $this->container['err_code'];
}
/**
* Sets err_code
*
* @param int|null $err_code 该消息的错误码
*
* @return self
*/
public function setErrCode($err_code)
{
if (is_null($err_code)) {
throw new \InvalidArgumentException('non-nullable err_code cannot be null');
}
$this->container['err_code'] = $err_code;
return $this;
}
/**
* Gets err_msg
*
* @return string|null
*/
public function getErrMsg()
{
return $this->container['err_msg'];
}
/**
* Sets err_msg
*
* @param string|null $err_msg 错误消息描述
*
* @return self
*/
public function setErrMsg($err_msg)
{
if (is_null($err_msg)) {
throw new \InvalidArgumentException('non-nullable err_msg cannot be null');
}
$this->container['err_msg'] = $err_msg;
return $this;
}
/**
* Gets sub_err
*
* @return int|null
*/
public function getSubErr()
{
return $this->container['sub_err'];
}
/**
* Sets sub_err
*
* @param int|null $sub_err 子错误的具体的代号
*
* @return self
*/
public function setSubErr($sub_err)
{
if (is_null($sub_err)) {
throw new \InvalidArgumentException('non-nullable sub_err cannot be null');
}
$this->container['sub_err'] = $sub_err;
return $this;
}
/**
* Gets sub_msg
*
* @return string|null
*/
public function getSubMsg()
{
return $this->container['sub_msg'];
}
/**
* Sets sub_msg
*
* @param string|null $sub_msg 子错误对应的提示消息
*
* @return self
*/
public function setSubMsg($sub_msg)
{
if (is_null($sub_msg)) {
throw new \InvalidArgumentException('non-nullable sub_msg cannot be null');
}
$this->container['sub_msg'] = $sub_msg;
return $this;
}
/**
* Gets sign_type
*
* @return string|null
*/
public function getSignType()
{
return $this->container['sign_type'];
}
/**
* Sets sign_type
*
* @param string|null $sign_type sign_type
*
* @return self
*/
public function setSignType($sign_type)
{
if (is_null($sign_type)) {
throw new \InvalidArgumentException('non-nullable sign_type cannot be null');
}
$this->container['sign_type'] = $sign_type;
return $this;
}
/**
* Returns true if offset exists. False otherwise.
*
* @param integer $offset Offset
*
* @return boolean
*/
public function offsetExists($offset): bool
{
return isset($this->container[$offset]);
}
/**
* Gets offset.
*
* @param integer $offset Offset
*
* @return mixed|null
*/
#[\ReturnTypeWillChange]
public function offsetGet($offset)
{
return $this->container[$offset] ?? null;
}
/**
* Sets value based on offset.
*
* @param int|null $offset Offset
* @param mixed $value Value to be set
*
* @return void
*/
public function offsetSet($offset, $value): void
{
if (is_null($offset)) {
$this->container[] = $value;
} else {
$this->container[$offset] = $value;
}
}
/**
* Unsets offset.
*
* @param integer $offset Offset
*
* @return void
*/
public function offsetUnset($offset): void
{
unset($this->container[$offset]);
}
/**
* Serializes the object to a value that can be serialized natively by json_encode().
* @link https://www.php.net/manual/en/jsonserializable.jsonserialize.php
*
* @return mixed Returns data which can be serialized by json_encode(), which is a value
* of any type other than a resource.
*/
#[\ReturnTypeWillChange]
public function jsonSerialize()
{
return ObjectSerializer::sanitizeForSerialization($this);
}
/**
* Gets the string presentation of the object
*
* @return string
*/
public function __toString()
{
return json_encode(
ObjectSerializer::sanitizeForSerialization($this),
JSON_PRETTY_PRINT
);
}
/**
* Gets a header-safe presentation of the object
*
* @return string
*/
public function toHeaderValue()
{
return json_encode(ObjectSerializer::sanitizeForSerialization($this));
}
}

@ -83,6 +83,18 @@ class AiApiTest extends TestCase
$this->markTestIncomplete('Not implemented'); $this->markTestIncomplete('Not implemented');
} }
/**
* Test case for extractText
*
* 元梦ai-提取文件文本内容.
*
*/
public function testExtractText()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/** /**
* Test case for tokenCount * Test case for tokenCount
* *

@ -0,0 +1,90 @@
<?php
/**
* ExtractTextParamTest
*
* PHP version 7.4
*
* @category Class
* @package OpenAPI\Client
* @author OpenAPI Generator team
* @link https://openapi-generator.tech
*/
/**
* 碳丝路数据开放平台API
*
* 碳丝路数据开放平台
*
* The version of the OpenAPI document: 0.4.8
* Generated by: https://openapi-generator.tech
* OpenAPI Generator version: 7.0.1
*/
/**
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Please update the test case below to test the model.
*/
namespace OpenAPI\Client\Test\Model;
use PHPUnit\Framework\TestCase;
/**
* ExtractTextParamTest Class Doc Comment
*
* @category Class
* @description 提取文件文本所需参数
* @package OpenAPI\Client
* @author OpenAPI Generator team
* @link https://openapi-generator.tech
*/
class ExtractTextParamTest extends TestCase
{
/**
* Setup before running any test case
*/
public static function setUpBeforeClass(): void
{
}
/**
* Setup before running each test case
*/
public function setUp(): void
{
}
/**
* Clean up after running each test case
*/
public function tearDown(): void
{
}
/**
* Clean up after running all test cases
*/
public static function tearDownAfterClass(): void
{
}
/**
* Test "ExtractTextParam"
*/
public function testExtractTextParam()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "extension"
*/
public function testPropertyExtension()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
}

@ -0,0 +1,90 @@
<?php
/**
* ExtractTextResultTest
*
* PHP version 7.4
*
* @category Class
* @package OpenAPI\Client
* @author OpenAPI Generator team
* @link https://openapi-generator.tech
*/
/**
* 碳丝路数据开放平台API
*
* 碳丝路数据开放平台
*
* The version of the OpenAPI document: 0.4.8
* Generated by: https://openapi-generator.tech
* OpenAPI Generator version: 7.0.1
*/
/**
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Please update the test case below to test the model.
*/
namespace OpenAPI\Client\Test\Model;
use PHPUnit\Framework\TestCase;
/**
* ExtractTextResultTest Class Doc Comment
*
* @category Class
* @description 提取文本结果
* @package OpenAPI\Client
* @author OpenAPI Generator team
* @link https://openapi-generator.tech
*/
class ExtractTextResultTest extends TestCase
{
/**
* Setup before running any test case
*/
public static function setUpBeforeClass(): void
{
}
/**
* Setup before running each test case
*/
public function setUp(): void
{
}
/**
* Clean up after running each test case
*/
public function tearDown(): void
{
}
/**
* Clean up after running all test cases
*/
public static function tearDownAfterClass(): void
{
}
/**
* Test "ExtractTextResult"
*/
public function testExtractTextResult()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "text"
*/
public function testPropertyText()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
}

@ -0,0 +1,189 @@
<?php
/**
* ResponseOpenAPIExtractTextResultTest
*
* PHP version 7.4
*
* @category Class
* @package OpenAPI\Client
* @author OpenAPI Generator team
* @link https://openapi-generator.tech
*/
/**
* 碳丝路数据开放平台API
*
* 碳丝路数据开放平台
*
* The version of the OpenAPI document: 0.4.8
* Generated by: https://openapi-generator.tech
* OpenAPI Generator version: 7.0.1
*/
/**
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Please update the test case below to test the model.
*/
namespace OpenAPI\Client\Test\Model;
use PHPUnit\Framework\TestCase;
/**
* ResponseOpenAPIExtractTextResultTest Class Doc Comment
*
* @category Class
* @description 消息载体对象
* @package OpenAPI\Client
* @author OpenAPI Generator team
* @link https://openapi-generator.tech
*/
class ResponseOpenAPIExtractTextResultTest extends TestCase
{
/**
* Setup before running any test case
*/
public static function setUpBeforeClass(): void
{
}
/**
* Setup before running each test case
*/
public function setUp(): void
{
}
/**
* Clean up after running each test case
*/
public function tearDown(): void
{
}
/**
* Clean up after running all test cases
*/
public static function tearDownAfterClass(): void
{
}
/**
* Test "ResponseOpenAPIExtractTextResult"
*/
public function testResponseOpenAPIExtractTextResult()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "time"
*/
public function testPropertyTime()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "openid"
*/
public function testPropertyOpenid()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "payload"
*/
public function testPropertyPayload()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "sign"
*/
public function testPropertySign()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "charset"
*/
public function testPropertyCharset()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "description"
*/
public function testPropertyDescription()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "response_id"
*/
public function testPropertyResponseId()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "err_code"
*/
public function testPropertyErrCode()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "err_msg"
*/
public function testPropertyErrMsg()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "sub_err"
*/
public function testPropertySubErr()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "sub_msg"
*/
public function testPropertySubMsg()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
/**
* Test attribute "sign_type"
*/
public function testPropertySignType()
{
// TODO: implement
$this->markTestIncomplete('Not implemented');
}
}
Loading…
Cancel
Save