PHP Luminova: Abstract Base Class for Application Configuration Classes
Base configuration serves as an underlying of your application configuration classes, which may be required by the framework depending on the component used in your application.
The base configuration service as the foundation of your application's configuration classes, which are essential for the framework depending on the components utilized in your application. To create a new configuration class, you need to extend and define necessary properties and method as you need.
Class Declaration
- Class namespace: \Luminova\Base\BaseConfig
- This class is an Abstract class
- This class implements: \Luminova\Interface\LazyInterface
Usages
Bellow is an example how you can extend the BaseConfig class.
// app/Config/Config.php
<?php 
namespace App\Config;
use \luminova\Base\BaseConfig;
class Config extends BaseConfig 
{
    public const MY_VAR = 'var';
}Now you can import your configuration class anywhere you would like to use it or register in service to make it available anywhere.
Properties
File extensions based on MIME types. Where the key is the MIME type and the value is the extension.
protected static array $extensions = [
    'image/jpeg' => 'jpg',
    'image/png' => 'png',
    // ...
];Note: Only define this property in
App\Config\Filesclass.
Methods
getEnv
An alternative to the global helper function env, the getEnv method allows you to retrieve an environment variable with a specific return type.
final public static getEnv(string $key, mixed $default = null, string|null $return = null): mixedParameters:
| Parameter | Type | Description | 
|---|---|---|
| $key | string | The environment variable key to retrieve. | 
| $default | mixed | The default value to return if the key is not found. | 
| $return | string|null | The expected return type. Can be one of: | 
Return Value:
mixed - Returns the environment variable cast to the specified type, or default if not found.
Supported Return Types:
- bool.
- int.
- float.
- double.
- nullable.
- string.
getNonce
Generate or retrieve a nonce with an optional prefix.
final public static getNonce(int $length = 16, string $prefix = ''): stringParameters:
| Parameter | Type | Description | 
|---|---|---|
| $length | int | The length of the random bytes to generate (default: 16). | 
| $prefix | string | An optional prefix for the nonce (default: ''). | 
Return Value:
string Return a cached generated nonce value.
removeCsp
Remove a directive from the Content-Security-Policy (CSP).
public removeCsp(string $directive): selfParameters:
| Parameter | Type | Description | 
|---|---|---|
| $directive | string | The CSP directive to remove. | 
Return Value:
self - Returns the instance of configuration class.
clearCsp
Clear all directives from the Content-Security-Policy (CSP).
public clearCsp(): selfReturn Value:
self - Returns the instance of configuration class.
getCsp
Build and return the Content-Security-Policy (CSP) as a string.
public getCsp(): stringReturn Value:
string - Returns the CSP policy string in the correct format.
getCspMetaTag
Generate the <meta> tag for embedding the CSP in HTML documents.
public getCspMetaTag(string $id = ''): stringParameters:
| Parameter | Type | Description | 
|---|---|---|
| $id | string | The CSP element identifier (default: none). | 
Return Value:
string - Returns the <meta> tag with the CSP as the content.
sendCspHeader
Send the Content-Security-Policy (CSP) as an HTTP header.
public sendCspHeader(): voidgetExtension
Get the file extension based on the MIME type.
This function returns the appropriate file extension for a given MIME type. It first checks if the MIME type exists in the developer defined static $extensions array, and if not, it uses a match expression to determine the extension.
public static getExtension(string $mimeType): string Parameters:
| Parameter | Type | Description | 
|---|---|---|
| $mimeType | string | The MIME type of the file. | 
Return Value:
string - Return the corresponding file extension (without the dot), or 'bin' if the MIME type is not recognized.
Example:
<?php
use App\Config\Files;
$file = 'path/to/file.png';
Files::getExtension(get_mime($file)); Arabic
 Arabic Chinese
 Chinese Dutch
 Dutch English
 English French
 French German
 German Indonesian
 Indonesian Italian
 Italian Japanese
 Japanese Korean
 Korean Malay
 Malay Portuguese
 Portuguese Russian
 Russian Spanish
 Spanish