You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

TillerClientV3.php 4.1KB

10 mesi fa
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. <?php
  2. /**
  3. * Copyright Souke (2018)
  4. *
  5. * contact@souke.fr
  6. *
  7. * Ce logiciel est un programme informatique servant à aider les producteurs
  8. * à distribuer leur production en circuits courts.
  9. *
  10. * Ce logiciel est régi par la licence CeCILL soumise au droit français et
  11. * respectant les principes de diffusion des logiciels libres. Vous pouvez
  12. * utiliser, modifier et/ou redistribuer ce programme sous les conditions
  13. * de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA
  14. * sur le site "http://www.cecill.info".
  15. *
  16. * En contrepartie de l'accessibilité au code source et des droits de copie,
  17. * de modification et de redistribution accordés par cette licence, il n'est
  18. * offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons,
  19. * seule une responsabilité restreinte pèse sur l'auteur du programme, le
  20. * titulaire des droits patrimoniaux et les concédants successifs.
  21. *
  22. * A cet égard l'attention de l'utilisateur est attirée sur les risques
  23. * associés au chargement, à l'utilisation, à la modification et/ou au
  24. * développement et à la reproduction du logiciel par l'utilisateur étant
  25. * donné sa spécificité de logiciel libre, qui peut le rendre complexe à
  26. * manipuler et qui le réserve donc à des développeurs et des professionnels
  27. * avertis possédant des connaissances informatiques approfondies. Les
  28. * utilisateurs sont donc invités à charger et tester l'adéquation du
  29. * logiciel à leurs besoins dans des conditions permettant d'assurer la
  30. * sécurité de leurs systèmes et ou de leurs données et, plus généralement,
  31. * à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.
  32. *
  33. * Le fait que vous puissiez accéder à cet en-tête signifie que vous avez
  34. * pris connaissance de la licence CeCILL, et que vous en avez accepté les
  35. * termes.
  36. */
  37. namespace common\components\Tiller;
  38. use common\components\Tiller\TillerClientInterface;
  39. use GuzzleHttp\Exception\RequestException;
  40. use linslin\yii2\curl;
  41. class TillerClientV3 implements TillerClientInterface
  42. {
  43. var $client;
  44. var $storeId;
  45. var $headers = [];
  46. var $urlApi = 'https://api.tiller.systems/';
  47. public function __construct(string $storeId = null, string $accessToken = null)
  48. {
  49. $this->client = new \GuzzleHttp\Client();
  50. $this->storeId = (int) $storeId;
  51. $this->headers = [
  52. 'authorization' => 'Bearer '.$accessToken,
  53. 'accept' => 'application/json',
  54. 'content-type' => 'application/json',
  55. ];
  56. }
  57. public function getUrlAuthorizeCode(string $clientId = null, string $redirectUri = null): string
  58. {
  59. if($clientId && $redirectUri) {
  60. return "https://oauth.api.tiller.systems/oauth2/authorize?client_id=$clientId&response_type=code&scope=&redirect_uri=$redirectUri";
  61. }
  62. return '#';
  63. }
  64. public function isAuthenticated(): bool
  65. {
  66. return $this->getOrders(date('Y-m-d')) !== false;
  67. }
  68. public function getOrders($date)
  69. {
  70. try {
  71. $response = $this->client->request('POST', $this->urlApi.'orders/v3/orders/search', [
  72. 'body' => json_encode([
  73. 'storeIds' => [$this->storeId],
  74. 'openDate' => [
  75. 'from' => date('Y-m-d H:i:s', strtotime($date)),
  76. 'to' => date('Y-m-d H:i:s', strtotime($date) + 24 * 60 * 60 - 1)
  77. ]
  78. ]),
  79. 'headers' => $this->headers
  80. ]);
  81. return $response->getBody()->getContents();
  82. }
  83. catch (RequestException $exception) {
  84. return false;
  85. }
  86. }
  87. public function postOrder($params)
  88. {
  89. try {
  90. $response = $this->client->request('POST', $this->urlApi.'purchase-requests/v1/requests?storeId='.$this->storeId, [
  91. 'body' => json_encode($params),
  92. 'headers' => $this->headers
  93. ]);
  94. }
  95. catch (RequestException $exception) {
  96. print_r($exception);
  97. die();
  98. }
  99. return $response->getBody()->getContents();
  100. }
  101. }