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>
59 lines
1.5 KiB
PHP
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;
|
|
}
|
|
}
|