lthn.io/app/Core/Actions/Scheduled.php
Claude 41a90cbff8
feat: lthn.io API serving live chain data
Fixed: basePath self→static binding, namespace detection, event wiring,
SQLite cache, file cache driver. All Mod Boot classes converted to
$listens pattern for lifecycle event discovery.

Working endpoints:
- /v1/explorer/info — live chain height, difficulty, aliases
- /v1/explorer/stats — formatted chain statistics
- /v1/names/directory — alias directory grouped by type
- /v1/names/available/{name} — name availability check
- /v1/names/lookup/{name} — name details

Co-Authored-By: Charon <charon@lethean.io>
2026-04-03 17:17:42 +01:00

46 lines
1.1 KiB
PHP

<?php
/*
* Core PHP Framework
*
* Licensed under the European Union Public Licence (EUPL) v1.2.
* See LICENSE file for details.
*/
declare(strict_types=1);
namespace Core\Actions;
use Attribute;
/**
* Mark an Action class for scheduled execution.
*
* The frequency string maps to Laravel Schedule methods:
* - 'everyMinute' → ->everyMinute()
* - 'dailyAt:09:00' → ->dailyAt('09:00')
* - 'weeklyOn:1,09:00' → ->weeklyOn(1, '09:00')
* - 'hourly' → ->hourly()
* - 'monthlyOn:1,00:00' → ->monthlyOn(1, '00:00')
*
* Usage:
* #[Scheduled(frequency: 'dailyAt:09:00', timezone: 'Europe/London')]
* class PublishDigest
* {
* use Action;
* public function handle(): void { ... }
* }
*
* Discovered by ScheduledActionScanner, persisted to scheduled_actions table
* via `php artisan schedule:sync`, and executed by ScheduleServiceProvider.
*/
#[Attribute(Attribute::TARGET_CLASS)]
class Scheduled
{
public function __construct(
public string $frequency,
public ?string $timezone = null,
public bool $withoutOverlapping = true,
public bool $runInBackground = true,
) {}
}