Debugging
YetiForce is a very advanced system that has thousands of files and hundreds of dependencies, and the numbers are growing each day. That's why to be able to analyze problems within the system, many logging mechanisms have been created and if there is a need they can be activated in a corresponding place. There are other ways to approach and analyze errors, but they are not listed in this article because they may require an advanced level of programming or are specific for a particular environment and implemented functionalities.
Introduction
It is necessary to understand a problem in such a way that helps to find its cause. Otherwise, you can waste a lot of time. HTML, CSS, JS, AJAX -it's best to debug them in the browser). Various tools should be used for debugging, such as XDebug, server logs, application logs. For the browsers, it is recommended to use Google Chrome. Sometimes it is necessary to add something unusual to the code, so it will display an error in a corresponding place. A good idea might be to perform simple network tests to eliminate issues between the server and user's browser.
Log file paths
- cache/logs/phpError.log - general PHP error logs. Log visibility is determined by a few indirect factors, e.g. web server configuration
- cache/logs/errors.log - PHP error logs controlled by the system
- cache/logs/system.log - primary logs for debugging the system, recorded information depends on the selected level of recording
- cache/logs/davException.log - error logs for DAV integration
- cache/logs/davDebug.log - debugging logs for DAV integration
- cache/logs/webserviceDebug.log - debugging logs for API/webservice
- cache/logs/webserviceErrors.log - error logs for API/webservice
- cache/logs/viewer-debug.log - debugging logs for data displaying layer - Smarts
- cache/logs/smtp - mail logs for smtp
- cache/logs/ldap - mail logs for ldap
- cache/logs/imap - mail logs for imap
- cache/logs/session - mail logs for session
- cache/logs/sql - mail logs for sql
- cache/logs/update.log - error logs for system updater
If the files described above do not exist, they will be created after enabling logs (as long as the application has adequate permissions in the file system).
YetiForce system logs
In order to enable log files recording, you need to set the LOG_TO_FILE
value to true
in config/Debug.php; then set the appropriate level of recording changes LOG_LEVELS
.
https://github.com/YetiForceCompany/YetiForceCRM/blob/developer/config/Debug.php#L20-L27
Debugging levels (from least to most showing):
- error
- warning
- info
- trace
- profile
Possible value variants:
- ['error']
- ['error', 'warning', 'info', 'trace', 'profile']
- 'All'
- 3
Logs will be registered in the following file: cache/logs/system.log
. The cache/logs/
directory needs to have write permissions.
PHP logs
To start analyzing problems or errors in the system, log recording and displaying server messages should be enabled. Without this change, the system will not be able to inform you about issues with, e.g., short script execution time. In the php.ini configuration, set the values of log_errors
and display_errors
to On
. If the configuration allows you to override PHP parameters, use .htaccess
Additional configuration with .htaccess. Before starting debugging, it is important to check in the panel Administrator documentation → Logs → Server - configuration
that the described parameters are correctly set.
MySQL logs
Errors in SQL queries are logged by YetiForce system logs, with an error level of error
.
Smarty logs
Configuration file: config/Debug.php
https://github.com/YetiForceCompany/YetiForceCRM/blob/developer/config/Debug.php#L71-L75
Roundcube
email client debugging
Configuration file: config/Debug.php
Roundcube allows you to debug various elements:
https://github.com/YetiForceCompany/YetiForceCRM/blob/developer/config/Debug.php#L114-L145
DAV integration debugging
Configuration file: config/Debug.php
The parameter enables an additional plugin which is used to log/save all data received and sent by the server to the cache/logs/davDebug.log
file.
https://github.com/YetiForceCompany/YetiForceCRM/blob/developer/config/Debug.php#L105-L109
Podsumowanie
YetiForce system logs - critical
public static $LOG_TO_FILE = true;
public static $LOG_LEVELS = ['error'];
public static $LOG_TRACE_LEVEL = 9;
public static $DEBUG_CRON = true;
public static $SMARTY_ERROR_REPORTING = E_ALL & ~E_NOTICE;
public static $JS_DEBUG = true;
public static $DAV_DEBUG_EXCEPTIONS = true;
public static $DAV_DEBUG_PLUGIN = true;
public static $apiLogException = true;
public static $MAILER_DEBUG = true;
php.ini
error_reporting = E_ALL
html_errors = On
log_errors = On
display_errors = On
display_startup_errors = On
error_log = __php__log_path__/php_error.log
nginx vhost
error_log __nginx__log_path__/nginx_error.log notice;
proxy_intercept_errors on;
fastcgi_intercept_errors on;
PHP (php-fpm.conf)
[global]
error_log = __nginx__log_path__/fpm_error.log.log
[www]
php_flag[display_errors] = on
php_admin_flag[log_errors] = true