Merge pull request 'package' (#1) from package into master
Reviewed-on: #1
This commit is contained in:
@@ -3,7 +3,7 @@
|
||||
declare(strict_types=1);
|
||||
|
||||
use App\Application\Settings\SettingsInterface;
|
||||
use App\Service\OpenWeatherClient;
|
||||
use Ohrionmartin\Weather\Service\OpenWeatherClient;
|
||||
use GuzzleHttp\Client;
|
||||
use DI\ContainerBuilder;
|
||||
use Monolog\Handler\StreamHandler;
|
||||
|
@@ -3,7 +3,7 @@
|
||||
declare(strict_types=1);
|
||||
|
||||
use App\Domain\User\UserRepository;
|
||||
use App\Infrastructure\Persistence\User\InMemoryUserRepository;
|
||||
use Ohrionmartin\Weather\Infrastructure\Persistence\User\InMemoryUserRepository;
|
||||
use DI\ContainerBuilder;
|
||||
|
||||
return function (ContainerBuilder $containerBuilder) {
|
||||
|
@@ -4,7 +4,7 @@ declare(strict_types=1);
|
||||
|
||||
use App\Application\Actions\User\ListUsersAction;
|
||||
use App\Application\Actions\User\ViewUserAction;
|
||||
use App\Application\Actions\Weather\GetWeatherAction;
|
||||
use Ohrionmartin\Weather\Application\Actions\Weather\GetWeatherAction;
|
||||
use Psr\Http\Message\ResponseInterface as Response;
|
||||
use Psr\Http\Message\ServerRequestInterface as Request;
|
||||
use Slim\App;
|
||||
|
@@ -1,63 +1,27 @@
|
||||
{
|
||||
"name": "slim/slim-skeleton",
|
||||
"description": "A Slim Framework skeleton application for rapid development",
|
||||
"keywords": [
|
||||
"microframework",
|
||||
"rest",
|
||||
"router",
|
||||
"psr7"
|
||||
],
|
||||
"homepage": "http://github.com/slimphp/Slim-Skeleton",
|
||||
"name": "ohrionmartin/weather",
|
||||
"description": "Reusable Slim components for fetching weather via OpenWeather One Call API 3.0",
|
||||
"type": "library",
|
||||
"license": "MIT",
|
||||
"autoload": {
|
||||
"psr-4": {
|
||||
"Ohrionmartin\\Weather\\": "src/"
|
||||
}
|
||||
},
|
||||
"authors": [
|
||||
{
|
||||
"name": "Josh Lockhart",
|
||||
"email": "info@joshlockhart.com",
|
||||
"homepage": "http://www.joshlockhart.com/"
|
||||
},
|
||||
{
|
||||
"name": "Pierre Berube",
|
||||
"email": "pierre@lgse.com",
|
||||
"homepage": "http://www.lgse.com/"
|
||||
"name": "Oh Martin",
|
||||
"email": "oh@nampharm.com.na"
|
||||
}
|
||||
],
|
||||
"minimum-stability": "stable",
|
||||
"require": {
|
||||
"php": "^7.4 || ^8.0",
|
||||
"ext-json": "*",
|
||||
"guzzlehttp/guzzle": "^7",
|
||||
"monolog/monolog": "^2.8",
|
||||
"php-di/php-di": "^6.4",
|
||||
"slim/psr7": "^1.5",
|
||||
"slim/slim": "^4.10",
|
||||
"vlucas/phpdotenv": "^5.6"
|
||||
},
|
||||
"require-dev": {
|
||||
"jangregor/phpstan-prophecy": "^1.0.0",
|
||||
"phpspec/prophecy-phpunit": "^2.0",
|
||||
"phpstan/extension-installer": "^1.2.0",
|
||||
"phpstan/phpstan": "^1.8",
|
||||
"phpunit/phpunit": "^9.5.26",
|
||||
"squizlabs/php_codesniffer": "^3.7"
|
||||
"guzzlehttp/guzzle": "^7.8"
|
||||
},
|
||||
"config": {
|
||||
"allow-plugins": {
|
||||
"phpstan/extension-installer": true
|
||||
},
|
||||
"process-timeout": 0,
|
||||
"sort-packages": true
|
||||
},
|
||||
"autoload": {
|
||||
"psr-4": {
|
||||
"App\\": "src/"
|
||||
"phpstan/extension-installer": false
|
||||
}
|
||||
},
|
||||
"autoload-dev": {
|
||||
"psr-4": {
|
||||
"Tests\\": "tests/"
|
||||
}
|
||||
},
|
||||
"scripts": {
|
||||
"start": "php -S localhost:8080 -t public",
|
||||
"test": "phpunit"
|
||||
}
|
||||
}
|
||||
|
@@ -2,9 +2,9 @@
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace App\Application\Actions\Weather;
|
||||
namespace Ohrionmartin\Weather\Application\Actions\Weather;
|
||||
|
||||
use App\Service\OpenWeatherClient;
|
||||
use Ohrionmartin\Weather\Service\OpenWeatherClient;
|
||||
use Psr\Http\Message\ResponseInterface as Response;
|
||||
use Psr\Http\Message\ServerRequestInterface as Request;
|
||||
|
||||
|
@@ -2,7 +2,7 @@
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace App\Infrastructure\Persistence\User;
|
||||
namespace Ohrionmartin\Weather\Infrastructure\Persistence\User;
|
||||
|
||||
use App\Domain\User\User;
|
||||
use App\Domain\User\UserNotFoundException;
|
||||
|
46
src/Infrastructure/Provider/SlimWeatherProvider.php
Normal file
46
src/Infrastructure/Provider/SlimWeatherProvider.php
Normal file
@@ -0,0 +1,46 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace Ohrionmartin\Weather\Infrastructure\Provider;
|
||||
|
||||
use Ohrionmartin\Weather\Application\Actions\Weather\GetWeatherAction;
|
||||
use Ohrionmartin\Weather\Service\OpenWeatherClient;
|
||||
use DI\ContainerBuilder;
|
||||
use GuzzleHttp\Client;
|
||||
use Psr\Container\ContainerInterface;
|
||||
use Slim\App;
|
||||
|
||||
final class SlimWeatherProvider
|
||||
{
|
||||
public static function register(ContainerBuilder $cb): void
|
||||
{
|
||||
$cb->addDefinitions([
|
||||
Client::class => function () {
|
||||
return new Client([
|
||||
'headers' => [
|
||||
'Accept' => 'application/json',
|
||||
'User-Agent' => 'Slim-Weather/1.0',
|
||||
],
|
||||
]);
|
||||
},
|
||||
|
||||
OpenWeatherClient::class => function (ContainerInterface $c) {
|
||||
$apiKey = $_ENV['OPENWEATHER_API_KEY'] ?? $_SERVER['OPENWEATHER_API_KEY'] ?? '';
|
||||
$baseUrl = 'https://api.openweathermap.org/data/3.0';
|
||||
|
||||
if ($apiKey === '') {
|
||||
throw new \RuntimeException('OPENWEATHER_API_KEY is not configured');
|
||||
}
|
||||
|
||||
return new OpenWeatherClient($c->get(Client::class), $apiKey, $baseUrl);
|
||||
},
|
||||
]);
|
||||
}
|
||||
|
||||
public static function routes(App $app): void
|
||||
{
|
||||
// Expose a ready-to-use endpoint for consumers (optional)
|
||||
$app->get('/weather', GetWeatherAction::class);
|
||||
}
|
||||
}
|
@@ -2,7 +2,7 @@
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace App\Service;
|
||||
namespace Ohrionmartin\Weather\Service;
|
||||
|
||||
use GuzzleHttp\ClientInterface;
|
||||
use GuzzleHttp\Exception\GuzzleException;
|
||||
|
@@ -6,7 +6,7 @@ namespace Tests\Infrastructure\Persistence\User;
|
||||
|
||||
use App\Domain\User\User;
|
||||
use App\Domain\User\UserNotFoundException;
|
||||
use App\Infrastructure\Persistence\User\InMemoryUserRepository;
|
||||
use Ohrionmartin\Weather\Infrastructure\Persistence\User\InMemoryUserRepository;
|
||||
use Tests\TestCase;
|
||||
|
||||
class InMemoryUserRepositoryTest extends TestCase
|
||||
|
Reference in New Issue
Block a user