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

50 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);
use Core\Headers\CspNonceService;
if (! function_exists('csp_nonce')) {
/**
* Get the CSP nonce for the current request.
*
* Usage in Blade templates:
* ```blade
* <script nonce="{{ csp_nonce() }}">
* // Your inline JavaScript
* </script>
* ```
*
* @return string The base64-encoded nonce value
*/
function csp_nonce(): string
{
return app(CspNonceService::class)->getNonce();
}
}
if (! function_exists('csp_nonce_attribute')) {
/**
* Get the CSP nonce as an HTML attribute.
*
* Usage in Blade templates:
* ```blade
* <script {!! csp_nonce_attribute() !!}>
* // Your inline JavaScript
* </script>
* ```
*
* @return string The nonce attribute (e.g., 'nonce="abc123..."')
*/
function csp_nonce_attribute(): string
{
return app(CspNonceService::class)->getNonceAttribute();
}
}