lthn.io/app/Core/Init.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

72 lines
1.8 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;
use Core\Input\Input;
/**
* Application initialisation - the true entry point.
*
* Use this in public/index.php:
*
* require __DIR__.'/../vendor/autoload.php';
* Core\Init::handle();
*
* This replaces Laravel's bootstrap/app.php pattern with
* explicit provider loading via Core\Boot.
*
* The Input::capture() method provides a WAF layer that sanitises
* all input ($_GET, $_POST) before Laravel sees it.
*/
class Init
{
/**
* Handle the incoming request.
*/
public static function handle(): void
{
// Maintenance mode check (before anything else)
$maintenance = dirname(__DIR__).'/storage/framework/maintenance.php';
if (file_exists($maintenance)) {
require $maintenance;
}
// Capture and filter input - WAF layer
// This sanitises $_GET and $_POST before creating the request
$request = Input::capture();
// Hand clean request to Laravel
// Use App\Boot if it exists (app customizations), otherwise Core\Boot
self::boot()::app()->handleRequest($request);
}
/**
* Handle for testing - returns response instead of sending.
*/
public static function handleForTesting(): mixed
{
$request = Input::capture();
return self::boot()::app()->handle($request);
}
/**
* Get the Boot class to use.
*
* Prefers App\Boot if it exists, allowing apps to customise
* providers, middleware, and exception handling.
*/
protected static function boot(): string
{
return class_exists('App\\Boot') ? 'App\\Boot' : Boot::class;
}
}