Cloudauth.php 53 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499
  1. <?php
  2. // This file is auto-generated, don't edit it. Thanks.
  3. namespace AlibabaCloud\SDK\Cloudauth\V20190307;
  4. use AlibabaCloud\Endpoint\Endpoint;
  5. use AlibabaCloud\OpenApiUtil\OpenApiUtilClient;
  6. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\AIGCFaceVerifyRequest;
  7. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\AIGCFaceVerifyResponse;
  8. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\CompareFacesRequest;
  9. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\CompareFacesResponse;
  10. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\CompareFaceVerifyRequest;
  11. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\CompareFaceVerifyResponse;
  12. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\ContrastFaceVerifyAdvanceRequest;
  13. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\ContrastFaceVerifyRequest;
  14. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\ContrastFaceVerifyResponse;
  15. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\CreateAuthKeyRequest;
  16. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\CreateAuthKeyResponse;
  17. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\CreateVerifySettingRequest;
  18. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\CreateVerifySettingResponse;
  19. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DescribeDeviceInfoRequest;
  20. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DescribeDeviceInfoResponse;
  21. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DescribeFaceVerifyRequest;
  22. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DescribeFaceVerifyResponse;
  23. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DescribeOssUploadTokenResponse;
  24. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DescribeSmartStatisticsPageListRequest;
  25. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DescribeSmartStatisticsPageListResponse;
  26. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DescribeVerifyResultRequest;
  27. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DescribeVerifyResultResponse;
  28. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DescribeVerifySDKRequest;
  29. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DescribeVerifySDKResponse;
  30. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DescribeVerifyTokenRequest;
  31. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DescribeVerifyTokenResponse;
  32. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DetectFaceAttributesRequest;
  33. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\DetectFaceAttributesResponse;
  34. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\Id2MetaVerifyRequest;
  35. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\Id2MetaVerifyResponse;
  36. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\InitFaceVerifyRequest;
  37. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\InitFaceVerifyResponse;
  38. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\LivenessFaceVerifyRequest;
  39. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\LivenessFaceVerifyResponse;
  40. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\Mobile3MetaDetailVerifyRequest;
  41. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\Mobile3MetaDetailVerifyResponse;
  42. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\Mobile3MetaSimpleVerifyRequest;
  43. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\Mobile3MetaSimpleVerifyResponse;
  44. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\ModifyDeviceInfoRequest;
  45. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\ModifyDeviceInfoResponse;
  46. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\VerifyMaterialRequest;
  47. use AlibabaCloud\SDK\Cloudauth\V20190307\Models\VerifyMaterialResponse;
  48. use AlibabaCloud\SDK\OpenPlatform\V20191219\Models\AuthorizeFileUploadRequest;
  49. use AlibabaCloud\SDK\OpenPlatform\V20191219\Models\AuthorizeFileUploadResponse;
  50. use AlibabaCloud\SDK\OpenPlatform\V20191219\OpenPlatform;
  51. use AlibabaCloud\SDK\OSS\OSS;
  52. use AlibabaCloud\SDK\OSS\OSS\PostObjectRequest;
  53. use AlibabaCloud\SDK\OSS\OSS\PostObjectRequest\header;
  54. use AlibabaCloud\Tea\FileForm\FileForm\FileField;
  55. use AlibabaCloud\Tea\Utils\Utils;
  56. use AlibabaCloud\Tea\Utils\Utils\RuntimeOptions;
  57. use Darabonba\OpenApi\Models\Config;
  58. use Darabonba\OpenApi\Models\OpenApiRequest;
  59. use Darabonba\OpenApi\Models\Params;
  60. use Darabonba\OpenApi\OpenApiClient;
  61. class Cloudauth extends OpenApiClient
  62. {
  63. public function __construct($config)
  64. {
  65. parent::__construct($config);
  66. $this->_endpointRule = 'central';
  67. $this->checkConfig($config);
  68. $this->_endpoint = $this->getEndpoint('cloudauth', $this->_regionId, $this->_endpointRule, $this->_network, $this->_suffix, $this->_endpointMap, $this->_endpoint);
  69. }
  70. /**
  71. * @param string $productId
  72. * @param string $regionId
  73. * @param string $endpointRule
  74. * @param string $network
  75. * @param string $suffix
  76. * @param string[] $endpointMap
  77. * @param string $endpoint
  78. *
  79. * @return string
  80. */
  81. public function getEndpoint($productId, $regionId, $endpointRule, $network, $suffix, $endpointMap, $endpoint)
  82. {
  83. if (!Utils::empty_($endpoint)) {
  84. return $endpoint;
  85. }
  86. if (!Utils::isUnset($endpointMap) && !Utils::empty_(@$endpointMap[$regionId])) {
  87. return @$endpointMap[$regionId];
  88. }
  89. return Endpoint::getEndpointRules($productId, $regionId, $endpointRule, $network, $suffix);
  90. }
  91. /**
  92. * @param AIGCFaceVerifyRequest $request
  93. * @param RuntimeOptions $runtime
  94. *
  95. * @return AIGCFaceVerifyResponse
  96. */
  97. public function aIGCFaceVerifyWithOptions($request, $runtime)
  98. {
  99. Utils::validateModel($request);
  100. $query = [];
  101. if (!Utils::isUnset($request->faceContrastPictureUrl)) {
  102. $query['FaceContrastPictureUrl'] = $request->faceContrastPictureUrl;
  103. }
  104. if (!Utils::isUnset($request->ossBucketName)) {
  105. $query['OssBucketName'] = $request->ossBucketName;
  106. }
  107. if (!Utils::isUnset($request->ossObjectName)) {
  108. $query['OssObjectName'] = $request->ossObjectName;
  109. }
  110. if (!Utils::isUnset($request->outerOrderNo)) {
  111. $query['OuterOrderNo'] = $request->outerOrderNo;
  112. }
  113. if (!Utils::isUnset($request->productCode)) {
  114. $query['ProductCode'] = $request->productCode;
  115. }
  116. if (!Utils::isUnset($request->sceneId)) {
  117. $query['SceneId'] = $request->sceneId;
  118. }
  119. $body = [];
  120. if (!Utils::isUnset($request->faceContrastPicture)) {
  121. $body['FaceContrastPicture'] = $request->faceContrastPicture;
  122. }
  123. $req = new OpenApiRequest([
  124. 'query' => OpenApiUtilClient::query($query),
  125. 'body' => OpenApiUtilClient::parseToMap($body),
  126. ]);
  127. $params = new Params([
  128. 'action' => 'AIGCFaceVerify',
  129. 'version' => '2019-03-07',
  130. 'protocol' => 'HTTPS',
  131. 'pathname' => '/',
  132. 'method' => 'POST',
  133. 'authType' => 'AK',
  134. 'style' => 'RPC',
  135. 'reqBodyType' => 'formData',
  136. 'bodyType' => 'json',
  137. ]);
  138. return AIGCFaceVerifyResponse::fromMap($this->callApi($params, $req, $runtime));
  139. }
  140. /**
  141. * @param AIGCFaceVerifyRequest $request
  142. *
  143. * @return AIGCFaceVerifyResponse
  144. */
  145. public function aIGCFaceVerify($request)
  146. {
  147. $runtime = new RuntimeOptions([]);
  148. return $this->aIGCFaceVerifyWithOptions($request, $runtime);
  149. }
  150. /**
  151. * @param CompareFaceVerifyRequest $request
  152. * @param RuntimeOptions $runtime
  153. *
  154. * @return CompareFaceVerifyResponse
  155. */
  156. public function compareFaceVerifyWithOptions($request, $runtime)
  157. {
  158. Utils::validateModel($request);
  159. $body = [];
  160. if (!Utils::isUnset($request->crop)) {
  161. $body['Crop'] = $request->crop;
  162. }
  163. if (!Utils::isUnset($request->outerOrderNo)) {
  164. $body['OuterOrderNo'] = $request->outerOrderNo;
  165. }
  166. if (!Utils::isUnset($request->productCode)) {
  167. $body['ProductCode'] = $request->productCode;
  168. }
  169. if (!Utils::isUnset($request->sceneId)) {
  170. $body['SceneId'] = $request->sceneId;
  171. }
  172. if (!Utils::isUnset($request->sourceCertifyId)) {
  173. $body['SourceCertifyId'] = $request->sourceCertifyId;
  174. }
  175. if (!Utils::isUnset($request->sourceFaceContrastPicture)) {
  176. $body['SourceFaceContrastPicture'] = $request->sourceFaceContrastPicture;
  177. }
  178. if (!Utils::isUnset($request->sourceFaceContrastPictureUrl)) {
  179. $body['SourceFaceContrastPictureUrl'] = $request->sourceFaceContrastPictureUrl;
  180. }
  181. if (!Utils::isUnset($request->sourceOssBucketName)) {
  182. $body['SourceOssBucketName'] = $request->sourceOssBucketName;
  183. }
  184. if (!Utils::isUnset($request->sourceOssObjectName)) {
  185. $body['SourceOssObjectName'] = $request->sourceOssObjectName;
  186. }
  187. if (!Utils::isUnset($request->targetCertifyId)) {
  188. $body['TargetCertifyId'] = $request->targetCertifyId;
  189. }
  190. if (!Utils::isUnset($request->targetFaceContrastPicture)) {
  191. $body['TargetFaceContrastPicture'] = $request->targetFaceContrastPicture;
  192. }
  193. if (!Utils::isUnset($request->targetFaceContrastPictureUrl)) {
  194. $body['TargetFaceContrastPictureUrl'] = $request->targetFaceContrastPictureUrl;
  195. }
  196. if (!Utils::isUnset($request->targetOssBucketName)) {
  197. $body['TargetOssBucketName'] = $request->targetOssBucketName;
  198. }
  199. if (!Utils::isUnset($request->targetOssObjectName)) {
  200. $body['TargetOssObjectName'] = $request->targetOssObjectName;
  201. }
  202. $req = new OpenApiRequest([
  203. 'body' => OpenApiUtilClient::parseToMap($body),
  204. ]);
  205. $params = new Params([
  206. 'action' => 'CompareFaceVerify',
  207. 'version' => '2019-03-07',
  208. 'protocol' => 'HTTPS',
  209. 'pathname' => '/',
  210. 'method' => 'POST',
  211. 'authType' => 'AK',
  212. 'style' => 'RPC',
  213. 'reqBodyType' => 'formData',
  214. 'bodyType' => 'json',
  215. ]);
  216. return CompareFaceVerifyResponse::fromMap($this->callApi($params, $req, $runtime));
  217. }
  218. /**
  219. * @param CompareFaceVerifyRequest $request
  220. *
  221. * @return CompareFaceVerifyResponse
  222. */
  223. public function compareFaceVerify($request)
  224. {
  225. $runtime = new RuntimeOptions([]);
  226. return $this->compareFaceVerifyWithOptions($request, $runtime);
  227. }
  228. /**
  229. * @param CompareFacesRequest $request
  230. * @param RuntimeOptions $runtime
  231. *
  232. * @return CompareFacesResponse
  233. */
  234. public function compareFacesWithOptions($request, $runtime)
  235. {
  236. Utils::validateModel($request);
  237. $body = [];
  238. if (!Utils::isUnset($request->sourceImageType)) {
  239. $body['SourceImageType'] = $request->sourceImageType;
  240. }
  241. if (!Utils::isUnset($request->sourceImageValue)) {
  242. $body['SourceImageValue'] = $request->sourceImageValue;
  243. }
  244. if (!Utils::isUnset($request->targetImageType)) {
  245. $body['TargetImageType'] = $request->targetImageType;
  246. }
  247. if (!Utils::isUnset($request->targetImageValue)) {
  248. $body['TargetImageValue'] = $request->targetImageValue;
  249. }
  250. $req = new OpenApiRequest([
  251. 'body' => OpenApiUtilClient::parseToMap($body),
  252. ]);
  253. $params = new Params([
  254. 'action' => 'CompareFaces',
  255. 'version' => '2019-03-07',
  256. 'protocol' => 'HTTPS',
  257. 'pathname' => '/',
  258. 'method' => 'POST',
  259. 'authType' => 'AK',
  260. 'style' => 'RPC',
  261. 'reqBodyType' => 'formData',
  262. 'bodyType' => 'json',
  263. ]);
  264. return CompareFacesResponse::fromMap($this->callApi($params, $req, $runtime));
  265. }
  266. /**
  267. * @param CompareFacesRequest $request
  268. *
  269. * @return CompareFacesResponse
  270. */
  271. public function compareFaces($request)
  272. {
  273. $runtime = new RuntimeOptions([]);
  274. return $this->compareFacesWithOptions($request, $runtime);
  275. }
  276. /**
  277. * @param ContrastFaceVerifyRequest $request
  278. * @param RuntimeOptions $runtime
  279. *
  280. * @return ContrastFaceVerifyResponse
  281. */
  282. public function contrastFaceVerifyWithOptions($request, $runtime)
  283. {
  284. Utils::validateModel($request);
  285. $query = [];
  286. if (!Utils::isUnset($request->model)) {
  287. $query['Model'] = $request->model;
  288. }
  289. $body = [];
  290. if (!Utils::isUnset($request->certName)) {
  291. $body['CertName'] = $request->certName;
  292. }
  293. if (!Utils::isUnset($request->certNo)) {
  294. $body['CertNo'] = $request->certNo;
  295. }
  296. if (!Utils::isUnset($request->certType)) {
  297. $body['CertType'] = $request->certType;
  298. }
  299. if (!Utils::isUnset($request->certifyId)) {
  300. $body['CertifyId'] = $request->certifyId;
  301. }
  302. if (!Utils::isUnset($request->crop)) {
  303. $body['Crop'] = $request->crop;
  304. }
  305. if (!Utils::isUnset($request->deviceToken)) {
  306. $body['DeviceToken'] = $request->deviceToken;
  307. }
  308. if (!Utils::isUnset($request->encryptType)) {
  309. $body['EncryptType'] = $request->encryptType;
  310. }
  311. if (!Utils::isUnset($request->faceContrastFile)) {
  312. $body['FaceContrastFile'] = $request->faceContrastFile;
  313. }
  314. if (!Utils::isUnset($request->faceContrastPicture)) {
  315. $body['FaceContrastPicture'] = $request->faceContrastPicture;
  316. }
  317. if (!Utils::isUnset($request->faceContrastPictureUrl)) {
  318. $body['FaceContrastPictureUrl'] = $request->faceContrastPictureUrl;
  319. }
  320. if (!Utils::isUnset($request->ip)) {
  321. $body['Ip'] = $request->ip;
  322. }
  323. if (!Utils::isUnset($request->mobile)) {
  324. $body['Mobile'] = $request->mobile;
  325. }
  326. if (!Utils::isUnset($request->ossBucketName)) {
  327. $body['OssBucketName'] = $request->ossBucketName;
  328. }
  329. if (!Utils::isUnset($request->ossObjectName)) {
  330. $body['OssObjectName'] = $request->ossObjectName;
  331. }
  332. if (!Utils::isUnset($request->outerOrderNo)) {
  333. $body['OuterOrderNo'] = $request->outerOrderNo;
  334. }
  335. if (!Utils::isUnset($request->productCode)) {
  336. $body['ProductCode'] = $request->productCode;
  337. }
  338. if (!Utils::isUnset($request->sceneId)) {
  339. $body['SceneId'] = $request->sceneId;
  340. }
  341. if (!Utils::isUnset($request->userId)) {
  342. $body['UserId'] = $request->userId;
  343. }
  344. $req = new OpenApiRequest([
  345. 'query' => OpenApiUtilClient::query($query),
  346. 'body' => OpenApiUtilClient::parseToMap($body),
  347. ]);
  348. $params = new Params([
  349. 'action' => 'ContrastFaceVerify',
  350. 'version' => '2019-03-07',
  351. 'protocol' => 'HTTPS',
  352. 'pathname' => '/',
  353. 'method' => 'POST',
  354. 'authType' => 'AK',
  355. 'style' => 'RPC',
  356. 'reqBodyType' => 'formData',
  357. 'bodyType' => 'json',
  358. ]);
  359. return ContrastFaceVerifyResponse::fromMap($this->callApi($params, $req, $runtime));
  360. }
  361. /**
  362. * @param ContrastFaceVerifyRequest $request
  363. *
  364. * @return ContrastFaceVerifyResponse
  365. */
  366. public function contrastFaceVerify($request)
  367. {
  368. $runtime = new RuntimeOptions([]);
  369. return $this->contrastFaceVerifyWithOptions($request, $runtime);
  370. }
  371. /**
  372. * @param ContrastFaceVerifyAdvanceRequest $request
  373. * @param RuntimeOptions $runtime
  374. *
  375. * @return ContrastFaceVerifyResponse
  376. */
  377. public function contrastFaceVerifyAdvance($request, $runtime)
  378. {
  379. // Step 0: init client
  380. $accessKeyId = $this->_credential->getAccessKeyId();
  381. $accessKeySecret = $this->_credential->getAccessKeySecret();
  382. $securityToken = $this->_credential->getSecurityToken();
  383. $credentialType = $this->_credential->getType();
  384. $openPlatformEndpoint = $this->_openPlatformEndpoint;
  385. if (Utils::isUnset($openPlatformEndpoint)) {
  386. $openPlatformEndpoint = 'openplatform.aliyuncs.com';
  387. }
  388. if (Utils::isUnset($credentialType)) {
  389. $credentialType = 'access_key';
  390. }
  391. $authConfig = new Config([
  392. 'accessKeyId' => $accessKeyId,
  393. 'accessKeySecret' => $accessKeySecret,
  394. 'securityToken' => $securityToken,
  395. 'type' => $credentialType,
  396. 'endpoint' => $openPlatformEndpoint,
  397. 'protocol' => $this->_protocol,
  398. 'regionId' => $this->_regionId,
  399. ]);
  400. $authClient = new OpenPlatform($authConfig);
  401. $authRequest = new AuthorizeFileUploadRequest([
  402. 'product' => 'Cloudauth',
  403. 'regionId' => $this->_regionId,
  404. ]);
  405. $authResponse = new AuthorizeFileUploadResponse([]);
  406. $ossConfig = new \AlibabaCloud\SDK\OSS\OSS\Config([
  407. 'accessKeySecret' => $accessKeySecret,
  408. 'type' => 'access_key',
  409. 'protocol' => $this->_protocol,
  410. 'regionId' => $this->_regionId,
  411. ]);
  412. $ossClient = null;
  413. $fileObj = new FileField([]);
  414. $ossHeader = new header([]);
  415. $uploadRequest = new PostObjectRequest([]);
  416. $ossRuntime = new \AlibabaCloud\Tea\OSSUtils\OSSUtils\RuntimeOptions([]);
  417. OpenApiUtilClient::convert($runtime, $ossRuntime);
  418. $contrastFaceVerifyReq = new ContrastFaceVerifyRequest([]);
  419. OpenApiUtilClient::convert($request, $contrastFaceVerifyReq);
  420. if (!Utils::isUnset($request->faceContrastFileObject)) {
  421. $authResponse = $authClient->authorizeFileUploadWithOptions($authRequest, $runtime);
  422. $ossConfig->accessKeyId = $authResponse->body->accessKeyId;
  423. $ossConfig->endpoint = OpenApiUtilClient::getEndpoint($authResponse->body->endpoint, $authResponse->body->useAccelerate, $this->_endpointType);
  424. $ossClient = new OSS($ossConfig);
  425. $fileObj = new FileField([
  426. 'filename' => $authResponse->body->objectKey,
  427. 'content' => $request->faceContrastFileObject,
  428. 'contentType' => '',
  429. ]);
  430. $ossHeader = new header([
  431. 'accessKeyId' => $authResponse->body->accessKeyId,
  432. 'policy' => $authResponse->body->encodedPolicy,
  433. 'signature' => $authResponse->body->signature,
  434. 'key' => $authResponse->body->objectKey,
  435. 'file' => $fileObj,
  436. 'successActionStatus' => '201',
  437. ]);
  438. $uploadRequest = new PostObjectRequest([
  439. 'bucketName' => $authResponse->body->bucket,
  440. 'header' => $ossHeader,
  441. ]);
  442. $ossClient->postObject($uploadRequest, $ossRuntime);
  443. $contrastFaceVerifyReq->faceContrastFile = 'http://' . $authResponse->body->bucket . '.' . $authResponse->body->endpoint . '/' . $authResponse->body->objectKey . '';
  444. }
  445. return $this->contrastFaceVerifyWithOptions($contrastFaceVerifyReq, $runtime);
  446. }
  447. /**
  448. * @param CreateAuthKeyRequest $request
  449. * @param RuntimeOptions $runtime
  450. *
  451. * @return CreateAuthKeyResponse
  452. */
  453. public function createAuthKeyWithOptions($request, $runtime)
  454. {
  455. Utils::validateModel($request);
  456. $query = [];
  457. if (!Utils::isUnset($request->authYears)) {
  458. $query['AuthYears'] = $request->authYears;
  459. }
  460. if (!Utils::isUnset($request->bizType)) {
  461. $query['BizType'] = $request->bizType;
  462. }
  463. if (!Utils::isUnset($request->test)) {
  464. $query['Test'] = $request->test;
  465. }
  466. if (!Utils::isUnset($request->userDeviceId)) {
  467. $query['UserDeviceId'] = $request->userDeviceId;
  468. }
  469. $req = new OpenApiRequest([
  470. 'query' => OpenApiUtilClient::query($query),
  471. ]);
  472. $params = new Params([
  473. 'action' => 'CreateAuthKey',
  474. 'version' => '2019-03-07',
  475. 'protocol' => 'HTTPS',
  476. 'pathname' => '/',
  477. 'method' => 'POST',
  478. 'authType' => 'AK',
  479. 'style' => 'RPC',
  480. 'reqBodyType' => 'formData',
  481. 'bodyType' => 'json',
  482. ]);
  483. return CreateAuthKeyResponse::fromMap($this->callApi($params, $req, $runtime));
  484. }
  485. /**
  486. * @param CreateAuthKeyRequest $request
  487. *
  488. * @return CreateAuthKeyResponse
  489. */
  490. public function createAuthKey($request)
  491. {
  492. $runtime = new RuntimeOptions([]);
  493. return $this->createAuthKeyWithOptions($request, $runtime);
  494. }
  495. /**
  496. * @param CreateVerifySettingRequest $request
  497. * @param RuntimeOptions $runtime
  498. *
  499. * @return CreateVerifySettingResponse
  500. */
  501. public function createVerifySettingWithOptions($request, $runtime)
  502. {
  503. Utils::validateModel($request);
  504. $query = [];
  505. if (!Utils::isUnset($request->bizName)) {
  506. $query['BizName'] = $request->bizName;
  507. }
  508. if (!Utils::isUnset($request->bizType)) {
  509. $query['BizType'] = $request->bizType;
  510. }
  511. if (!Utils::isUnset($request->guideStep)) {
  512. $query['GuideStep'] = $request->guideStep;
  513. }
  514. if (!Utils::isUnset($request->privacyStep)) {
  515. $query['PrivacyStep'] = $request->privacyStep;
  516. }
  517. if (!Utils::isUnset($request->resultStep)) {
  518. $query['ResultStep'] = $request->resultStep;
  519. }
  520. if (!Utils::isUnset($request->solution)) {
  521. $query['Solution'] = $request->solution;
  522. }
  523. $req = new OpenApiRequest([
  524. 'query' => OpenApiUtilClient::query($query),
  525. ]);
  526. $params = new Params([
  527. 'action' => 'CreateVerifySetting',
  528. 'version' => '2019-03-07',
  529. 'protocol' => 'HTTPS',
  530. 'pathname' => '/',
  531. 'method' => 'POST',
  532. 'authType' => 'AK',
  533. 'style' => 'RPC',
  534. 'reqBodyType' => 'formData',
  535. 'bodyType' => 'json',
  536. ]);
  537. return CreateVerifySettingResponse::fromMap($this->callApi($params, $req, $runtime));
  538. }
  539. /**
  540. * @param CreateVerifySettingRequest $request
  541. *
  542. * @return CreateVerifySettingResponse
  543. */
  544. public function createVerifySetting($request)
  545. {
  546. $runtime = new RuntimeOptions([]);
  547. return $this->createVerifySettingWithOptions($request, $runtime);
  548. }
  549. /**
  550. * @param DescribeDeviceInfoRequest $request
  551. * @param RuntimeOptions $runtime
  552. *
  553. * @return DescribeDeviceInfoResponse
  554. */
  555. public function describeDeviceInfoWithOptions($request, $runtime)
  556. {
  557. Utils::validateModel($request);
  558. $query = [];
  559. if (!Utils::isUnset($request->bizType)) {
  560. $query['BizType'] = $request->bizType;
  561. }
  562. if (!Utils::isUnset($request->currentPage)) {
  563. $query['CurrentPage'] = $request->currentPage;
  564. }
  565. if (!Utils::isUnset($request->deviceId)) {
  566. $query['DeviceId'] = $request->deviceId;
  567. }
  568. if (!Utils::isUnset($request->expiredEndDay)) {
  569. $query['ExpiredEndDay'] = $request->expiredEndDay;
  570. }
  571. if (!Utils::isUnset($request->expiredStartDay)) {
  572. $query['ExpiredStartDay'] = $request->expiredStartDay;
  573. }
  574. if (!Utils::isUnset($request->pageSize)) {
  575. $query['PageSize'] = $request->pageSize;
  576. }
  577. if (!Utils::isUnset($request->userDeviceId)) {
  578. $query['UserDeviceId'] = $request->userDeviceId;
  579. }
  580. $req = new OpenApiRequest([
  581. 'query' => OpenApiUtilClient::query($query),
  582. ]);
  583. $params = new Params([
  584. 'action' => 'DescribeDeviceInfo',
  585. 'version' => '2019-03-07',
  586. 'protocol' => 'HTTPS',
  587. 'pathname' => '/',
  588. 'method' => 'POST',
  589. 'authType' => 'AK',
  590. 'style' => 'RPC',
  591. 'reqBodyType' => 'formData',
  592. 'bodyType' => 'json',
  593. ]);
  594. return DescribeDeviceInfoResponse::fromMap($this->callApi($params, $req, $runtime));
  595. }
  596. /**
  597. * @param DescribeDeviceInfoRequest $request
  598. *
  599. * @return DescribeDeviceInfoResponse
  600. */
  601. public function describeDeviceInfo($request)
  602. {
  603. $runtime = new RuntimeOptions([]);
  604. return $this->describeDeviceInfoWithOptions($request, $runtime);
  605. }
  606. /**
  607. * @param DescribeFaceVerifyRequest $request
  608. * @param RuntimeOptions $runtime
  609. *
  610. * @return DescribeFaceVerifyResponse
  611. */
  612. public function describeFaceVerifyWithOptions($request, $runtime)
  613. {
  614. Utils::validateModel($request);
  615. $query = [];
  616. if (!Utils::isUnset($request->certifyId)) {
  617. $query['CertifyId'] = $request->certifyId;
  618. }
  619. if (!Utils::isUnset($request->pictureReturnType)) {
  620. $query['PictureReturnType'] = $request->pictureReturnType;
  621. }
  622. if (!Utils::isUnset($request->sceneId)) {
  623. $query['SceneId'] = $request->sceneId;
  624. }
  625. $req = new OpenApiRequest([
  626. 'query' => OpenApiUtilClient::query($query),
  627. ]);
  628. $params = new Params([
  629. 'action' => 'DescribeFaceVerify',
  630. 'version' => '2019-03-07',
  631. 'protocol' => 'HTTPS',
  632. 'pathname' => '/',
  633. 'method' => 'POST',
  634. 'authType' => 'AK',
  635. 'style' => 'RPC',
  636. 'reqBodyType' => 'formData',
  637. 'bodyType' => 'json',
  638. ]);
  639. return DescribeFaceVerifyResponse::fromMap($this->callApi($params, $req, $runtime));
  640. }
  641. /**
  642. * @param DescribeFaceVerifyRequest $request
  643. *
  644. * @return DescribeFaceVerifyResponse
  645. */
  646. public function describeFaceVerify($request)
  647. {
  648. $runtime = new RuntimeOptions([]);
  649. return $this->describeFaceVerifyWithOptions($request, $runtime);
  650. }
  651. /**
  652. * @param RuntimeOptions $runtime
  653. *
  654. * @return DescribeOssUploadTokenResponse
  655. */
  656. public function describeOssUploadTokenWithOptions($runtime)
  657. {
  658. $req = new OpenApiRequest([]);
  659. $params = new Params([
  660. 'action' => 'DescribeOssUploadToken',
  661. 'version' => '2019-03-07',
  662. 'protocol' => 'HTTPS',
  663. 'pathname' => '/',
  664. 'method' => 'POST',
  665. 'authType' => 'AK',
  666. 'style' => 'RPC',
  667. 'reqBodyType' => 'formData',
  668. 'bodyType' => 'json',
  669. ]);
  670. return DescribeOssUploadTokenResponse::fromMap($this->callApi($params, $req, $runtime));
  671. }
  672. /**
  673. * @return DescribeOssUploadTokenResponse
  674. */
  675. public function describeOssUploadToken()
  676. {
  677. $runtime = new RuntimeOptions([]);
  678. return $this->describeOssUploadTokenWithOptions($runtime);
  679. }
  680. /**
  681. * @param DescribeSmartStatisticsPageListRequest $request
  682. * @param RuntimeOptions $runtime
  683. *
  684. * @return DescribeSmartStatisticsPageListResponse
  685. */
  686. public function describeSmartStatisticsPageListWithOptions($request, $runtime)
  687. {
  688. Utils::validateModel($request);
  689. $query = [];
  690. if (!Utils::isUnset($request->currentPage)) {
  691. $query['CurrentPage'] = $request->currentPage;
  692. }
  693. if (!Utils::isUnset($request->endDate)) {
  694. $query['EndDate'] = $request->endDate;
  695. }
  696. if (!Utils::isUnset($request->pageSize)) {
  697. $query['PageSize'] = $request->pageSize;
  698. }
  699. if (!Utils::isUnset($request->sceneId)) {
  700. $query['SceneId'] = $request->sceneId;
  701. }
  702. if (!Utils::isUnset($request->serviceCode)) {
  703. $query['ServiceCode'] = $request->serviceCode;
  704. }
  705. if (!Utils::isUnset($request->startDate)) {
  706. $query['StartDate'] = $request->startDate;
  707. }
  708. $req = new OpenApiRequest([
  709. 'query' => OpenApiUtilClient::query($query),
  710. ]);
  711. $params = new Params([
  712. 'action' => 'DescribeSmartStatisticsPageList',
  713. 'version' => '2019-03-07',
  714. 'protocol' => 'HTTPS',
  715. 'pathname' => '/',
  716. 'method' => 'POST',
  717. 'authType' => 'AK',
  718. 'style' => 'RPC',
  719. 'reqBodyType' => 'formData',
  720. 'bodyType' => 'json',
  721. ]);
  722. return DescribeSmartStatisticsPageListResponse::fromMap($this->callApi($params, $req, $runtime));
  723. }
  724. /**
  725. * @param DescribeSmartStatisticsPageListRequest $request
  726. *
  727. * @return DescribeSmartStatisticsPageListResponse
  728. */
  729. public function describeSmartStatisticsPageList($request)
  730. {
  731. $runtime = new RuntimeOptions([]);
  732. return $this->describeSmartStatisticsPageListWithOptions($request, $runtime);
  733. }
  734. /**
  735. * @param DescribeVerifyResultRequest $request
  736. * @param RuntimeOptions $runtime
  737. *
  738. * @return DescribeVerifyResultResponse
  739. */
  740. public function describeVerifyResultWithOptions($request, $runtime)
  741. {
  742. Utils::validateModel($request);
  743. $query = [];
  744. if (!Utils::isUnset($request->bizId)) {
  745. $query['BizId'] = $request->bizId;
  746. }
  747. if (!Utils::isUnset($request->bizType)) {
  748. $query['BizType'] = $request->bizType;
  749. }
  750. $req = new OpenApiRequest([
  751. 'query' => OpenApiUtilClient::query($query),
  752. ]);
  753. $params = new Params([
  754. 'action' => 'DescribeVerifyResult',
  755. 'version' => '2019-03-07',
  756. 'protocol' => 'HTTPS',
  757. 'pathname' => '/',
  758. 'method' => 'POST',
  759. 'authType' => 'AK',
  760. 'style' => 'RPC',
  761. 'reqBodyType' => 'formData',
  762. 'bodyType' => 'json',
  763. ]);
  764. return DescribeVerifyResultResponse::fromMap($this->callApi($params, $req, $runtime));
  765. }
  766. /**
  767. * @param DescribeVerifyResultRequest $request
  768. *
  769. * @return DescribeVerifyResultResponse
  770. */
  771. public function describeVerifyResult($request)
  772. {
  773. $runtime = new RuntimeOptions([]);
  774. return $this->describeVerifyResultWithOptions($request, $runtime);
  775. }
  776. /**
  777. * @param DescribeVerifySDKRequest $request
  778. * @param RuntimeOptions $runtime
  779. *
  780. * @return DescribeVerifySDKResponse
  781. */
  782. public function describeVerifySDKWithOptions($request, $runtime)
  783. {
  784. Utils::validateModel($request);
  785. $query = [];
  786. if (!Utils::isUnset($request->taskId)) {
  787. $query['TaskId'] = $request->taskId;
  788. }
  789. $req = new OpenApiRequest([
  790. 'query' => OpenApiUtilClient::query($query),
  791. ]);
  792. $params = new Params([
  793. 'action' => 'DescribeVerifySDK',
  794. 'version' => '2019-03-07',
  795. 'protocol' => 'HTTPS',
  796. 'pathname' => '/',
  797. 'method' => 'POST',
  798. 'authType' => 'AK',
  799. 'style' => 'RPC',
  800. 'reqBodyType' => 'formData',
  801. 'bodyType' => 'json',
  802. ]);
  803. return DescribeVerifySDKResponse::fromMap($this->callApi($params, $req, $runtime));
  804. }
  805. /**
  806. * @param DescribeVerifySDKRequest $request
  807. *
  808. * @return DescribeVerifySDKResponse
  809. */
  810. public function describeVerifySDK($request)
  811. {
  812. $runtime = new RuntimeOptions([]);
  813. return $this->describeVerifySDKWithOptions($request, $runtime);
  814. }
  815. /**
  816. * @param DescribeVerifyTokenRequest $request
  817. * @param RuntimeOptions $runtime
  818. *
  819. * @return DescribeVerifyTokenResponse
  820. */
  821. public function describeVerifyTokenWithOptions($request, $runtime)
  822. {
  823. Utils::validateModel($request);
  824. $query = [];
  825. if (!Utils::isUnset($request->bizId)) {
  826. $query['BizId'] = $request->bizId;
  827. }
  828. if (!Utils::isUnset($request->bizType)) {
  829. $query['BizType'] = $request->bizType;
  830. }
  831. if (!Utils::isUnset($request->callbackSeed)) {
  832. $query['CallbackSeed'] = $request->callbackSeed;
  833. }
  834. if (!Utils::isUnset($request->callbackUrl)) {
  835. $query['CallbackUrl'] = $request->callbackUrl;
  836. }
  837. if (!Utils::isUnset($request->faceRetainedImageUrl)) {
  838. $query['FaceRetainedImageUrl'] = $request->faceRetainedImageUrl;
  839. }
  840. if (!Utils::isUnset($request->failedRedirectUrl)) {
  841. $query['FailedRedirectUrl'] = $request->failedRedirectUrl;
  842. }
  843. if (!Utils::isUnset($request->idCardBackImageUrl)) {
  844. $query['IdCardBackImageUrl'] = $request->idCardBackImageUrl;
  845. }
  846. if (!Utils::isUnset($request->idCardFrontImageUrl)) {
  847. $query['IdCardFrontImageUrl'] = $request->idCardFrontImageUrl;
  848. }
  849. if (!Utils::isUnset($request->idCardNumber)) {
  850. $query['IdCardNumber'] = $request->idCardNumber;
  851. }
  852. if (!Utils::isUnset($request->name)) {
  853. $query['Name'] = $request->name;
  854. }
  855. if (!Utils::isUnset($request->passedRedirectUrl)) {
  856. $query['PassedRedirectUrl'] = $request->passedRedirectUrl;
  857. }
  858. if (!Utils::isUnset($request->userId)) {
  859. $query['UserId'] = $request->userId;
  860. }
  861. if (!Utils::isUnset($request->userIp)) {
  862. $query['UserIp'] = $request->userIp;
  863. }
  864. if (!Utils::isUnset($request->userPhoneNumber)) {
  865. $query['UserPhoneNumber'] = $request->userPhoneNumber;
  866. }
  867. if (!Utils::isUnset($request->userRegistTime)) {
  868. $query['UserRegistTime'] = $request->userRegistTime;
  869. }
  870. $req = new OpenApiRequest([
  871. 'query' => OpenApiUtilClient::query($query),
  872. ]);
  873. $params = new Params([
  874. 'action' => 'DescribeVerifyToken',
  875. 'version' => '2019-03-07',
  876. 'protocol' => 'HTTPS',
  877. 'pathname' => '/',
  878. 'method' => 'POST',
  879. 'authType' => 'AK',
  880. 'style' => 'RPC',
  881. 'reqBodyType' => 'formData',
  882. 'bodyType' => 'json',
  883. ]);
  884. return DescribeVerifyTokenResponse::fromMap($this->callApi($params, $req, $runtime));
  885. }
  886. /**
  887. * @param DescribeVerifyTokenRequest $request
  888. *
  889. * @return DescribeVerifyTokenResponse
  890. */
  891. public function describeVerifyToken($request)
  892. {
  893. $runtime = new RuntimeOptions([]);
  894. return $this->describeVerifyTokenWithOptions($request, $runtime);
  895. }
  896. /**
  897. * @param DetectFaceAttributesRequest $request
  898. * @param RuntimeOptions $runtime
  899. *
  900. * @return DetectFaceAttributesResponse
  901. */
  902. public function detectFaceAttributesWithOptions($request, $runtime)
  903. {
  904. Utils::validateModel($request);
  905. $body = [];
  906. if (!Utils::isUnset($request->bizType)) {
  907. $body['BizType'] = $request->bizType;
  908. }
  909. if (!Utils::isUnset($request->materialValue)) {
  910. $body['MaterialValue'] = $request->materialValue;
  911. }
  912. $req = new OpenApiRequest([
  913. 'body' => OpenApiUtilClient::parseToMap($body),
  914. ]);
  915. $params = new Params([
  916. 'action' => 'DetectFaceAttributes',
  917. 'version' => '2019-03-07',
  918. 'protocol' => 'HTTPS',
  919. 'pathname' => '/',
  920. 'method' => 'POST',
  921. 'authType' => 'AK',
  922. 'style' => 'RPC',
  923. 'reqBodyType' => 'formData',
  924. 'bodyType' => 'json',
  925. ]);
  926. return DetectFaceAttributesResponse::fromMap($this->callApi($params, $req, $runtime));
  927. }
  928. /**
  929. * @param DetectFaceAttributesRequest $request
  930. *
  931. * @return DetectFaceAttributesResponse
  932. */
  933. public function detectFaceAttributes($request)
  934. {
  935. $runtime = new RuntimeOptions([]);
  936. return $this->detectFaceAttributesWithOptions($request, $runtime);
  937. }
  938. /**
  939. * @param Id2MetaVerifyRequest $request
  940. * @param RuntimeOptions $runtime
  941. *
  942. * @return Id2MetaVerifyResponse
  943. */
  944. public function id2MetaVerifyWithOptions($request, $runtime)
  945. {
  946. Utils::validateModel($request);
  947. $query = [];
  948. if (!Utils::isUnset($request->identifyNum)) {
  949. $query['IdentifyNum'] = $request->identifyNum;
  950. }
  951. if (!Utils::isUnset($request->paramType)) {
  952. $query['ParamType'] = $request->paramType;
  953. }
  954. if (!Utils::isUnset($request->userName)) {
  955. $query['UserName'] = $request->userName;
  956. }
  957. $req = new OpenApiRequest([
  958. 'query' => OpenApiUtilClient::query($query),
  959. ]);
  960. $params = new Params([
  961. 'action' => 'Id2MetaVerify',
  962. 'version' => '2019-03-07',
  963. 'protocol' => 'HTTPS',
  964. 'pathname' => '/',
  965. 'method' => 'POST',
  966. 'authType' => 'AK',
  967. 'style' => 'RPC',
  968. 'reqBodyType' => 'formData',
  969. 'bodyType' => 'json',
  970. ]);
  971. return Id2MetaVerifyResponse::fromMap($this->callApi($params, $req, $runtime));
  972. }
  973. /**
  974. * @param Id2MetaVerifyRequest $request
  975. *
  976. * @return Id2MetaVerifyResponse
  977. */
  978. public function id2MetaVerify($request)
  979. {
  980. $runtime = new RuntimeOptions([]);
  981. return $this->id2MetaVerifyWithOptions($request, $runtime);
  982. }
  983. /**
  984. * @param InitFaceVerifyRequest $request
  985. * @param RuntimeOptions $runtime
  986. *
  987. * @return InitFaceVerifyResponse
  988. */
  989. public function initFaceVerifyWithOptions($request, $runtime)
  990. {
  991. Utils::validateModel($request);
  992. $query = [];
  993. if (!Utils::isUnset($request->birthday)) {
  994. $query['Birthday'] = $request->birthday;
  995. }
  996. if (!Utils::isUnset($request->callbackToken)) {
  997. $query['CallbackToken'] = $request->callbackToken;
  998. }
  999. if (!Utils::isUnset($request->callbackUrl)) {
  1000. $query['CallbackUrl'] = $request->callbackUrl;
  1001. }
  1002. if (!Utils::isUnset($request->certName)) {
  1003. $query['CertName'] = $request->certName;
  1004. }
  1005. if (!Utils::isUnset($request->certNo)) {
  1006. $query['CertNo'] = $request->certNo;
  1007. }
  1008. if (!Utils::isUnset($request->certType)) {
  1009. $query['CertType'] = $request->certType;
  1010. }
  1011. if (!Utils::isUnset($request->certifyId)) {
  1012. $query['CertifyId'] = $request->certifyId;
  1013. }
  1014. if (!Utils::isUnset($request->certifyUrlStyle)) {
  1015. $query['CertifyUrlStyle'] = $request->certifyUrlStyle;
  1016. }
  1017. if (!Utils::isUnset($request->certifyUrlType)) {
  1018. $query['CertifyUrlType'] = $request->certifyUrlType;
  1019. }
  1020. if (!Utils::isUnset($request->encryptType)) {
  1021. $query['EncryptType'] = $request->encryptType;
  1022. }
  1023. if (!Utils::isUnset($request->faceContrastPictureUrl)) {
  1024. $query['FaceContrastPictureUrl'] = $request->faceContrastPictureUrl;
  1025. }
  1026. if (!Utils::isUnset($request->faceGuardOutput)) {
  1027. $query['FaceGuardOutput'] = $request->faceGuardOutput;
  1028. }
  1029. if (!Utils::isUnset($request->ip)) {
  1030. $query['Ip'] = $request->ip;
  1031. }
  1032. if (!Utils::isUnset($request->metaInfo)) {
  1033. $query['MetaInfo'] = $request->metaInfo;
  1034. }
  1035. if (!Utils::isUnset($request->mobile)) {
  1036. $query['Mobile'] = $request->mobile;
  1037. }
  1038. if (!Utils::isUnset($request->mode)) {
  1039. $query['Mode'] = $request->mode;
  1040. }
  1041. if (!Utils::isUnset($request->ossBucketName)) {
  1042. $query['OssBucketName'] = $request->ossBucketName;
  1043. }
  1044. if (!Utils::isUnset($request->ossObjectName)) {
  1045. $query['OssObjectName'] = $request->ossObjectName;
  1046. }
  1047. if (!Utils::isUnset($request->outerOrderNo)) {
  1048. $query['OuterOrderNo'] = $request->outerOrderNo;
  1049. }
  1050. if (!Utils::isUnset($request->procedurePriority)) {
  1051. $query['ProcedurePriority'] = $request->procedurePriority;
  1052. }
  1053. if (!Utils::isUnset($request->productCode)) {
  1054. $query['ProductCode'] = $request->productCode;
  1055. }
  1056. if (!Utils::isUnset($request->rarelyCharacters)) {
  1057. $query['RarelyCharacters'] = $request->rarelyCharacters;
  1058. }
  1059. if (!Utils::isUnset($request->readImg)) {
  1060. $query['ReadImg'] = $request->readImg;
  1061. }
  1062. if (!Utils::isUnset($request->returnUrl)) {
  1063. $query['ReturnUrl'] = $request->returnUrl;
  1064. }
  1065. if (!Utils::isUnset($request->sceneId)) {
  1066. $query['SceneId'] = $request->sceneId;
  1067. }
  1068. if (!Utils::isUnset($request->suitableType)) {
  1069. $query['SuitableType'] = $request->suitableType;
  1070. }
  1071. if (!Utils::isUnset($request->userId)) {
  1072. $query['UserId'] = $request->userId;
  1073. }
  1074. if (!Utils::isUnset($request->validityDate)) {
  1075. $query['ValidityDate'] = $request->validityDate;
  1076. }
  1077. if (!Utils::isUnset($request->voluntaryCustomizedContent)) {
  1078. $query['VoluntaryCustomizedContent'] = $request->voluntaryCustomizedContent;
  1079. }
  1080. $body = [];
  1081. if (!Utils::isUnset($request->authId)) {
  1082. $body['AuthId'] = $request->authId;
  1083. }
  1084. if (!Utils::isUnset($request->crop)) {
  1085. $body['Crop'] = $request->crop;
  1086. }
  1087. if (!Utils::isUnset($request->faceContrastPicture)) {
  1088. $body['FaceContrastPicture'] = $request->faceContrastPicture;
  1089. }
  1090. if (!Utils::isUnset($request->model)) {
  1091. $body['Model'] = $request->model;
  1092. }
  1093. $req = new OpenApiRequest([
  1094. 'query' => OpenApiUtilClient::query($query),
  1095. 'body' => OpenApiUtilClient::parseToMap($body),
  1096. ]);
  1097. $params = new Params([
  1098. 'action' => 'InitFaceVerify',
  1099. 'version' => '2019-03-07',
  1100. 'protocol' => 'HTTPS',
  1101. 'pathname' => '/',
  1102. 'method' => 'POST',
  1103. 'authType' => 'AK',
  1104. 'style' => 'RPC',
  1105. 'reqBodyType' => 'formData',
  1106. 'bodyType' => 'json',
  1107. ]);
  1108. return InitFaceVerifyResponse::fromMap($this->callApi($params, $req, $runtime));
  1109. }
  1110. /**
  1111. * @param InitFaceVerifyRequest $request
  1112. *
  1113. * @return InitFaceVerifyResponse
  1114. */
  1115. public function initFaceVerify($request)
  1116. {
  1117. $runtime = new RuntimeOptions([]);
  1118. return $this->initFaceVerifyWithOptions($request, $runtime);
  1119. }
  1120. /**
  1121. * @param LivenessFaceVerifyRequest $request
  1122. * @param RuntimeOptions $runtime
  1123. *
  1124. * @return LivenessFaceVerifyResponse
  1125. */
  1126. public function livenessFaceVerifyWithOptions($request, $runtime)
  1127. {
  1128. Utils::validateModel($request);
  1129. $query = [];
  1130. if (!Utils::isUnset($request->model)) {
  1131. $query['Model'] = $request->model;
  1132. }
  1133. $body = [];
  1134. if (!Utils::isUnset($request->certifyId)) {
  1135. $body['CertifyId'] = $request->certifyId;
  1136. }
  1137. if (!Utils::isUnset($request->crop)) {
  1138. $body['Crop'] = $request->crop;
  1139. }
  1140. if (!Utils::isUnset($request->deviceToken)) {
  1141. $body['DeviceToken'] = $request->deviceToken;
  1142. }
  1143. if (!Utils::isUnset($request->faceContrastPicture)) {
  1144. $body['FaceContrastPicture'] = $request->faceContrastPicture;
  1145. }
  1146. if (!Utils::isUnset($request->faceContrastPictureUrl)) {
  1147. $body['FaceContrastPictureUrl'] = $request->faceContrastPictureUrl;
  1148. }
  1149. if (!Utils::isUnset($request->ip)) {
  1150. $body['Ip'] = $request->ip;
  1151. }
  1152. if (!Utils::isUnset($request->mobile)) {
  1153. $body['Mobile'] = $request->mobile;
  1154. }
  1155. if (!Utils::isUnset($request->ossBucketName)) {
  1156. $body['OssBucketName'] = $request->ossBucketName;
  1157. }
  1158. if (!Utils::isUnset($request->ossObjectName)) {
  1159. $body['OssObjectName'] = $request->ossObjectName;
  1160. }
  1161. if (!Utils::isUnset($request->outerOrderNo)) {
  1162. $body['OuterOrderNo'] = $request->outerOrderNo;
  1163. }
  1164. if (!Utils::isUnset($request->productCode)) {
  1165. $body['ProductCode'] = $request->productCode;
  1166. }
  1167. if (!Utils::isUnset($request->sceneId)) {
  1168. $body['SceneId'] = $request->sceneId;
  1169. }
  1170. if (!Utils::isUnset($request->userId)) {
  1171. $body['UserId'] = $request->userId;
  1172. }
  1173. $req = new OpenApiRequest([
  1174. 'query' => OpenApiUtilClient::query($query),
  1175. 'body' => OpenApiUtilClient::parseToMap($body),
  1176. ]);
  1177. $params = new Params([
  1178. 'action' => 'LivenessFaceVerify',
  1179. 'version' => '2019-03-07',
  1180. 'protocol' => 'HTTPS',
  1181. 'pathname' => '/',
  1182. 'method' => 'POST',
  1183. 'authType' => 'AK',
  1184. 'style' => 'RPC',
  1185. 'reqBodyType' => 'formData',
  1186. 'bodyType' => 'json',
  1187. ]);
  1188. return LivenessFaceVerifyResponse::fromMap($this->callApi($params, $req, $runtime));
  1189. }
  1190. /**
  1191. * @param LivenessFaceVerifyRequest $request
  1192. *
  1193. * @return LivenessFaceVerifyResponse
  1194. */
  1195. public function livenessFaceVerify($request)
  1196. {
  1197. $runtime = new RuntimeOptions([]);
  1198. return $this->livenessFaceVerifyWithOptions($request, $runtime);
  1199. }
  1200. /**
  1201. * @param Mobile3MetaDetailVerifyRequest $request
  1202. * @param RuntimeOptions $runtime
  1203. *
  1204. * @return Mobile3MetaDetailVerifyResponse
  1205. */
  1206. public function mobile3MetaDetailVerifyWithOptions($request, $runtime)
  1207. {
  1208. Utils::validateModel($request);
  1209. $query = [];
  1210. if (!Utils::isUnset($request->identifyNum)) {
  1211. $query['IdentifyNum'] = $request->identifyNum;
  1212. }
  1213. if (!Utils::isUnset($request->mobile)) {
  1214. $query['Mobile'] = $request->mobile;
  1215. }
  1216. if (!Utils::isUnset($request->paramType)) {
  1217. $query['ParamType'] = $request->paramType;
  1218. }
  1219. if (!Utils::isUnset($request->userName)) {
  1220. $query['UserName'] = $request->userName;
  1221. }
  1222. $req = new OpenApiRequest([
  1223. 'query' => OpenApiUtilClient::query($query),
  1224. ]);
  1225. $params = new Params([
  1226. 'action' => 'Mobile3MetaDetailVerify',
  1227. 'version' => '2019-03-07',
  1228. 'protocol' => 'HTTPS',
  1229. 'pathname' => '/',
  1230. 'method' => 'POST',
  1231. 'authType' => 'AK',
  1232. 'style' => 'RPC',
  1233. 'reqBodyType' => 'formData',
  1234. 'bodyType' => 'json',
  1235. ]);
  1236. return Mobile3MetaDetailVerifyResponse::fromMap($this->callApi($params, $req, $runtime));
  1237. }
  1238. /**
  1239. * @param Mobile3MetaDetailVerifyRequest $request
  1240. *
  1241. * @return Mobile3MetaDetailVerifyResponse
  1242. */
  1243. public function mobile3MetaDetailVerify($request)
  1244. {
  1245. $runtime = new RuntimeOptions([]);
  1246. return $this->mobile3MetaDetailVerifyWithOptions($request, $runtime);
  1247. }
  1248. /**
  1249. * @param Mobile3MetaSimpleVerifyRequest $request
  1250. * @param RuntimeOptions $runtime
  1251. *
  1252. * @return Mobile3MetaSimpleVerifyResponse
  1253. */
  1254. public function mobile3MetaSimpleVerifyWithOptions($request, $runtime)
  1255. {
  1256. Utils::validateModel($request);
  1257. $query = [];
  1258. if (!Utils::isUnset($request->identifyNum)) {
  1259. $query['IdentifyNum'] = $request->identifyNum;
  1260. }
  1261. if (!Utils::isUnset($request->mobile)) {
  1262. $query['Mobile'] = $request->mobile;
  1263. }
  1264. if (!Utils::isUnset($request->paramType)) {
  1265. $query['ParamType'] = $request->paramType;
  1266. }
  1267. if (!Utils::isUnset($request->userName)) {
  1268. $query['UserName'] = $request->userName;
  1269. }
  1270. $req = new OpenApiRequest([
  1271. 'query' => OpenApiUtilClient::query($query),
  1272. ]);
  1273. $params = new Params([
  1274. 'action' => 'Mobile3MetaSimpleVerify',
  1275. 'version' => '2019-03-07',
  1276. 'protocol' => 'HTTPS',
  1277. 'pathname' => '/',
  1278. 'method' => 'POST',
  1279. 'authType' => 'AK',
  1280. 'style' => 'RPC',
  1281. 'reqBodyType' => 'formData',
  1282. 'bodyType' => 'json',
  1283. ]);
  1284. return Mobile3MetaSimpleVerifyResponse::fromMap($this->callApi($params, $req, $runtime));
  1285. }
  1286. /**
  1287. * @param Mobile3MetaSimpleVerifyRequest $request
  1288. *
  1289. * @return Mobile3MetaSimpleVerifyResponse
  1290. */
  1291. public function mobile3MetaSimpleVerify($request)
  1292. {
  1293. $runtime = new RuntimeOptions([]);
  1294. return $this->mobile3MetaSimpleVerifyWithOptions($request, $runtime);
  1295. }
  1296. /**
  1297. * @param ModifyDeviceInfoRequest $request
  1298. * @param RuntimeOptions $runtime
  1299. *
  1300. * @return ModifyDeviceInfoResponse
  1301. */
  1302. public function modifyDeviceInfoWithOptions($request, $runtime)
  1303. {
  1304. Utils::validateModel($request);
  1305. $query = [];
  1306. if (!Utils::isUnset($request->bizType)) {
  1307. $query['BizType'] = $request->bizType;
  1308. }
  1309. if (!Utils::isUnset($request->deviceId)) {
  1310. $query['DeviceId'] = $request->deviceId;
  1311. }
  1312. if (!Utils::isUnset($request->duration)) {
  1313. $query['Duration'] = $request->duration;
  1314. }
  1315. if (!Utils::isUnset($request->expiredDay)) {
  1316. $query['ExpiredDay'] = $request->expiredDay;
  1317. }
  1318. if (!Utils::isUnset($request->userDeviceId)) {
  1319. $query['UserDeviceId'] = $request->userDeviceId;
  1320. }
  1321. $req = new OpenApiRequest([
  1322. 'query' => OpenApiUtilClient::query($query),
  1323. ]);
  1324. $params = new Params([
  1325. 'action' => 'ModifyDeviceInfo',
  1326. 'version' => '2019-03-07',
  1327. 'protocol' => 'HTTPS',
  1328. 'pathname' => '/',
  1329. 'method' => 'POST',
  1330. 'authType' => 'AK',
  1331. 'style' => 'RPC',
  1332. 'reqBodyType' => 'formData',
  1333. 'bodyType' => 'json',
  1334. ]);
  1335. return ModifyDeviceInfoResponse::fromMap($this->callApi($params, $req, $runtime));
  1336. }
  1337. /**
  1338. * @param ModifyDeviceInfoRequest $request
  1339. *
  1340. * @return ModifyDeviceInfoResponse
  1341. */
  1342. public function modifyDeviceInfo($request)
  1343. {
  1344. $runtime = new RuntimeOptions([]);
  1345. return $this->modifyDeviceInfoWithOptions($request, $runtime);
  1346. }
  1347. /**
  1348. * @param VerifyMaterialRequest $request
  1349. * @param RuntimeOptions $runtime
  1350. *
  1351. * @return VerifyMaterialResponse
  1352. */
  1353. public function verifyMaterialWithOptions($request, $runtime)
  1354. {
  1355. Utils::validateModel($request);
  1356. $query = [];
  1357. if (!Utils::isUnset($request->bizId)) {
  1358. $query['BizId'] = $request->bizId;
  1359. }
  1360. if (!Utils::isUnset($request->bizType)) {
  1361. $query['BizType'] = $request->bizType;
  1362. }
  1363. if (!Utils::isUnset($request->faceImageUrl)) {
  1364. $query['FaceImageUrl'] = $request->faceImageUrl;
  1365. }
  1366. if (!Utils::isUnset($request->idCardBackImageUrl)) {
  1367. $query['IdCardBackImageUrl'] = $request->idCardBackImageUrl;
  1368. }
  1369. if (!Utils::isUnset($request->idCardFrontImageUrl)) {
  1370. $query['IdCardFrontImageUrl'] = $request->idCardFrontImageUrl;
  1371. }
  1372. if (!Utils::isUnset($request->idCardNumber)) {
  1373. $query['IdCardNumber'] = $request->idCardNumber;
  1374. }
  1375. if (!Utils::isUnset($request->name)) {
  1376. $query['Name'] = $request->name;
  1377. }
  1378. if (!Utils::isUnset($request->userId)) {
  1379. $query['UserId'] = $request->userId;
  1380. }
  1381. $req = new OpenApiRequest([
  1382. 'query' => OpenApiUtilClient::query($query),
  1383. ]);
  1384. $params = new Params([
  1385. 'action' => 'VerifyMaterial',
  1386. 'version' => '2019-03-07',
  1387. 'protocol' => 'HTTPS',
  1388. 'pathname' => '/',
  1389. 'method' => 'POST',
  1390. 'authType' => 'AK',
  1391. 'style' => 'RPC',
  1392. 'reqBodyType' => 'formData',
  1393. 'bodyType' => 'json',
  1394. ]);
  1395. return VerifyMaterialResponse::fromMap($this->callApi($params, $req, $runtime));
  1396. }
  1397. /**
  1398. * @param VerifyMaterialRequest $request
  1399. *
  1400. * @return VerifyMaterialResponse
  1401. */
  1402. public function verifyMaterial($request)
  1403. {
  1404. $runtime = new RuntimeOptions([]);
  1405. return $this->verifyMaterialWithOptions($request, $runtime);
  1406. }
  1407. }