schneespur/release/schneespur-1.0.2/app/Services/Weather/WeatherProviderRegistry.php
Michael 7288b93500 Release v1.0.2: diagnostic infrastructure core
Add neutral diagnostic framework for future reporting modules:
- DiagnosticReporterInterface, Registry, Manager, PayloadSanitizer
- Laravel exception hook in bootstrap/app.php
- Module permission declarations (requires_permissions in module.json)
- Core diagnostic report points (module boot/install/update failures)
- Module documentation update (moduldoku.md)

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-05-18 16:54:11 +00:00

59 lines
1.5 KiB
PHP

<?php
namespace App\Services\Weather;
use App\Models\Setting;
use App\Services\Extension\ExtensionRegistry;
use Illuminate\Contracts\Container\Container;
class WeatherProviderRegistry extends ExtensionRegistry
{
public const DEFAULT_PROVIDER = 'openmeteo_free';
public function __construct(
private readonly Container $container,
) {}
/**
* @param class-string<WeatherProviderInterface> $class
*/
public function register(string $slug, mixed $class): void
{
parent::register($slug, $class);
}
public function resolve(?string $slug = null): WeatherProviderInterface
{
$slug ??= Setting::get('weather_provider', self::DEFAULT_PROVIDER);
if (! $this->has($slug)) {
$slug = self::DEFAULT_PROVIDER;
}
return $this->container->make($this->items[$slug]);
}
/**
* @return array<string, array{name: string, requires_api_key: bool}> slug => provider info
*/
public function availableProviders(): array
{
$result = [];
foreach ($this->all() as $slug => $class) {
$provider = $this->container->make($class);
$result[$slug] = [
'name' => $provider->name(),
'requires_api_key' => $provider->requiresApiKey(),
];
}
return $result;
}
public function activeSlug(): string
{
$slug = Setting::get('weather_provider', self::DEFAULT_PROVIDER);
return $this->has($slug) ? $slug : self::DEFAULT_PROVIDER;
}
}