Class FileLog
File Storage stream for Logging. Writes logs to different files based on the level of log it is.
Property Summary
- 
        $_config protected
arrayRuntime config
 - 
        $_configInitialized protected
boolWhether the config property has already been configured with defaults
 - 
        $_defaultConfig protected
arrayDefault config for this class
 - 
        $_file protected
stringThe name of the file to save logs into.
 - 
        $_path protected
stringPath to save log files on.
 - 
        $_size protected
intMax file size, used for log file rotation.
 
Method Summary
- 
          
__construct() public
Sets protected properties based on config provided
 - 
          
_configDelete() protected
Delete a single config key
 - 
          
_configRead() protected
Read a config variable
 - 
          
_configWrite() protected
Write a config variable
 - 
          
_format() protected
Converts to string the provided data so it can be logged. The context can optionally be used by log engines to interpolate variables or add additional info to the logged message.
 - 
          
_getFilename() protected
Get filename
 - 
          
_rotateFile() protected
Rotate log file if size specified in config is reached. Also if
rotatecount is reached oldest file is removed. - 
          
alert() public
Action must be taken immediately.
 - 
          
config() public
Usage
 - 
          
configShallow() public
Merge provided config with existing config. Unlike
config()which does a recursive merge for nested keys, this method does a simple merge. - 
          
critical() public
Critical conditions.
 - 
          
debug() public
Detailed debug information.
 - 
          
emergency() public
System is unusable.
 - 
          
error() public
Runtime errors that do not require immediate action but should typically be logged and monitored.
 - 
          
info() public
Interesting events.
 - 
          
levels() public
Get the levels this logger is interested in.
 - 
          
log() public
Implements writing to log files.
 - 
          
notice() public
Normal but significant events.
 - 
          
scopes() public
Get the scopes this logger is interested in.
 - 
          
warning() public
Exceptional occurrences that are not errors.
 
Method Detail
__construct() ¶ public
__construct(array $config = [])
      Sets protected properties based on config provided
Parameters
- 
                
array$config optional Configuration array
_configDelete() ¶ protected
_configDelete(string $key): void
      Delete a single config key
Parameters
- 
                
string$key Key to delete.
Returns
voidThrows
Cake\Core\Exception\Exceptionif attempting to clobber existing config
_configRead() ¶ protected
_configRead(string|null $key): mixed
      Read a config variable
Parameters
- 
                
string|null$key Key to read.
Returns
mixed_configWrite() ¶ protected
_configWrite(string|array $key, mixed $value, bool|string $merge = false): void
      Write a config variable
Parameters
- 
                
string|array$key Key to write to.
- 
                
mixed$value Value to write.
- 
                
bool|string$merge optional True to merge recursively, 'shallow' for simple merge, false to overwrite, defaults to false.
Returns
voidThrows
Cake\Core\Exception\Exceptionif attempting to clobber existing config
_format() ¶ protected
_format(mixed $data, array $context = []): string
      Converts to string the provided data so it can be logged. The context can optionally be used by log engines to interpolate variables or add additional info to the logged message.
Parameters
- 
                
mixed$data The data to be converted to string and logged.
- 
                
array$context optional Additional logging information for the message.
Returns
string_getFilename() ¶ protected
_getFilename(string $level): string
      Get filename
Parameters
- 
                
string$level The level of log.
Returns
stringFile name
_rotateFile() ¶ protected
_rotateFile(string $filename): bool|null
      Rotate log file if size specified in config is reached.
Also if rotate count is reached oldest file is removed.
Parameters
- 
                
string$filename Log file name
Returns
bool|nullTrue if rotated successfully or false in case of error. Null if file doesn't need to be rotated.
alert() ¶ public
alert(string $message, array $context = array()): null
      Action must be taken immediately.
Example: Entire website down, database unavailable, etc. This should trigger the SMS alerts and wake you up.
Parameters
- 
                
string$message - 
                
array$context optional 
Returns
nullconfig() ¶ public
config(string|array|null $key = null, mixed|null $value = null, bool $merge = true): mixed
      Usage
Reading the whole config:
$this->config();
Reading a specific value:
$this->config('key');
Reading a nested value:
$this->config('some.nested.key');
Setting a specific value:
$this->config('key', $value);
Setting a nested value:
$this->config('some.nested.key', $value);
Updating multiple config settings at the same time:
$this->config(['one' => 'value', 'another' => 'value']);
        
                  Parameters
- 
                
string|array|null$key optional The key to get/set, or a complete array of configs.
- 
                
mixed|null$value optional The value to set.
- 
                
bool$merge optional Whether to recursively merge or overwrite existing config, defaults to true.
Returns
mixedConfig value being read, or the object itself on write operations.
Throws
Cake\Core\Exception\ExceptionWhen trying to set a key that is invalid.
configShallow() ¶ public
configShallow(string|array $key, mixed|null $value = null): $this
      Merge provided config with existing config. Unlike config() which does
a recursive merge for nested keys, this method does a simple merge.
Setting a specific value:
$this->config('key', $value);
Setting a nested value:
$this->config('some.nested.key', $value);
Updating multiple config settings at the same time:
$this->config(['one' => 'value', 'another' => 'value']);
        
                  Parameters
- 
                
string|array$key The key to set, or a complete array of configs.
- 
                
mixed|null$value optional The value to set.
Returns
$thisThe object itself.
critical() ¶ public
critical(string $message, array $context = array()): null
      Critical conditions.
Example: Application component unavailable, unexpected exception.
Parameters
- 
                
string$message - 
                
array$context optional 
Returns
nulldebug() ¶ public
debug(string $message, array $context = array()): null
      Detailed debug information.
Parameters
- 
                
string$message - 
                
array$context optional 
Returns
nullemergency() ¶ public
emergency(string $message, array $context = array()): null
      System is unusable.
Parameters
- 
                
string$message - 
                
array$context optional 
Returns
nullerror() ¶ public
error(string $message, array $context = array()): null
      Runtime errors that do not require immediate action but should typically be logged and monitored.
Parameters
- 
                
string$message - 
                
array$context optional 
Returns
nullinfo() ¶ public
info(string $message, array $context = array()): null
      Interesting events.
Example: User logs in, SQL logs.
Parameters
- 
                
string$message - 
                
array$context optional 
Returns
nulllog() ¶ public
log(mixed $level, string $message, array $context = []): bool
      Implements writing to log files.
Parameters
- 
                
mixed$level The severity level of the message being written. See Cake\Log\Log::$_levels for list of possible levels.
- 
                
string$message The message you want to log.
- 
                
array$context optional Additional information about the logged message
Returns
boolsuccess of write.
notice() ¶ public
notice(string $message, array $context = array()): null
      Normal but significant events.
Parameters
- 
                
string$message - 
                
array$context optional 
Returns
nullwarning() ¶ public
warning(string $message, array $context = array()): null
      Exceptional occurrences that are not errors.
Example: Use of deprecated APIs, poor use of an API, undesirable things that are not necessarily wrong.
Parameters
- 
                
string$message - 
                
array$context optional 
Returns
nullProperty Detail
$_configInitialized ¶ protected
Whether the config property has already been configured with defaults
Type
bool$_defaultConfig ¶ protected
Default config for this class
levelsstring or array, levels the engine is interested inscopesstring or array, scopes the engine is interested infileLog file namepathThe path to save logs on.sizeUsed to implement basic log file rotation. If log file size reaches specified size the existing file is renamed by appending timestamp to filename and new log file is created. Can be integer bytes value or human readable string values like '10MB', '100KB' etc.rotateLog files are rotated specified times before being removed. If value is 0, old versions are removed rather then rotated.maskA mask is applied when log files are created. Left empty no chmod is made.
Type
array