1. Go to this page and download the library: Download kubinyete/template-sdk-php library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
kubinyete / template-sdk-php example snippets
# OpenMeteoClient.php
namespace Kubinyete\ExampleSdkPhp;
use Kubinyete\ExampleSdkPhp\Endpoint\ForecastEndpoint;
use Kubinyete\ExampleSdkPhp\Exception\OpenMeteoException;
use Kubinyete\ExampleSdkPhp\Client;
use Kubinyete\ExampleSdkPhp\Exception\HttpException;
use Kubinyete\ExampleSdkPhp\Http\Client\GuzzleHttpClient;
use Kubinyete\ExampleSdkPhp\Http\Response;
use Kubinyete\ExampleSdkPhp\IO\JsonSerializer;
class OpenMeteoClient extends Client
{
public function __construct(int $version = 1)
{
parent::__construct(
new OpenMeteoEnvironment($version),
new GuzzleHttpClient(),
new JsonSerializer()
);
}
public function forecast(): ForecastEndpoint
{
return ForecastEndpoint::create($this, $this);
}
//
// @NOTE:
// Dealing with errors on 200 status codes
protected function responseReceived(Response $response): Response
{
if ($response->getParsedPath('error')) {
throw new OpenMeteoException((string)$response->getParsedPath('reason'), 0, null, $response);
}
return $response;
}
// @NOTE:
// Translating Client/Server errors
protected function exceptionThrown(Throwable $e): void
{
if ($e instanceof HttpException && $e->getResponse()) {
$this->responseReceived($e->getResponse());
}
throw $e;
}
}
# ForecastEndpoint.php
namespace Kubinyete\ExampleSdkPhp\Endpoint;
use Kubinyete\ExampleSdkPhp\Model\Forecast;
use Kubinyete\ExampleSdkPhp\Model\ForecastSettings;
use Kubinyete\ExampleSdkPhp\Core\Endpoint;
class ForecastEndpoint extends Endpoint
{
protected string $location = '/forecast';
// @NOTE:
// Using a more object-oriented approach using an Endpoint object.
public function now(ForecastSettings $forecastSettings): Forecast
{
$response = $this->get($forecastSettings->jsonSerialize());
return Forecast::parse($response->getParsed());
}
}