Overview
Comment: | Ajout de constantes de config permettant d'activer l'auto-reporting d'erreur et la page de visualisation des logs système |
---|---|
Downloads: | Tarball | ZIP archive | SQL archive |
Timelines: | family | ancestors | descendants | both | trunk |
Files: | files | file ages | folders |
SHA1: |
c081cefd98bee3f553f715d28cddc6e4 |
User & Date: | bohwaz on 2018-11-09 16:55:33 |
Other Links: | manifest | tags |
Context
2018-11-09
| ||
17:00 | Ajout d'un test basique sur la validité du code PHP avant de créer une release check-in: 658c587767 user: bohwaz tags: trunk | |
16:55 | Ajout de constantes de config permettant d'activer l'auto-reporting d'erreur et la page de visualisation des logs système check-in: c081cefd98 user: bohwaz tags: trunk | |
16:46 | Ajout d'une page permettant de lister les logs système check-in: 07e6f99b20 user: bohwaz tags: trunk | |
Changes
Modified src/config.dist.php from [4b1bdaf310] to [fd9bfab8c2].
︙ | ︙ | |||
126 127 128 129 130 131 132 | */ //const ADMIN_URL = 'https://admin.garradin.chezmoi.tld/'; /** * Affichage des erreurs * Si "true" alors un message expliquant l'erreur et comment rapporter le bug s'affiche * en cas d'erreur. Sinon rien ne sera affiché. | | | > > | | > > > > > > > > > > > > > > > > > > > > > > > > | | | | | | 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 | */ //const ADMIN_URL = 'https://admin.garradin.chezmoi.tld/'; /** * Affichage des erreurs * Si "true" alors un message expliquant l'erreur et comment rapporter le bug s'affiche * en cas d'erreur. Sinon rien ne sera affiché. * * Défaut : false * * Il est fortement conseillé de mettre cette valeur à false en production ! */ const SHOW_ERRORS = false; /** * Envoi des erreurs par e-mail * * Si renseigné, un email sera envoyé à l'adresse indiquée à chaque fois qu'une erreur * d'exécution sera rencontrée. * Si "false" alors aucun email ne sera envoyé. * Note : les erreurs sont déjà toutes loguées dans error.log à la racine de DATA_ROOT * * Défaut : false */ const MAIL_ERRORS = false; /** * Envoi des erreurs à une API compatible AirBrake/Errbit * * Si renseigné avec une URL HTTP(S) valide, chaque erreur système sera envoyée * automatiquement à cette URL. * * Si laissé à null, aucun rapport ne sera envoyé. * * Défaut : null */ const ERRORS_REPORT_URL = null; /** * Activation de la page permettant de visualiser et rapporter les erreurs présentes * dans le error.log. * * Conseillé de mettre à false si vous ne voulez pas que les administrateurs de votre * instance puissent voir les erreurs système. * * Défaut : true * (Afin d'aider au rapport de bugs des instances auto-hébergées) */ const ERRORS_ENABLE_LOG_VIEW = true; /** * Utilisation de cron pour les tâches automatiques * * Si "true" on s'attend à ce qu'une tâche automatisée appelle * le script cron.php à la racine toutes les 24 heures. Sinon Garradin * effectuera les actions automatiques quand quelqu'un se connecte à * l'administration ou visite le site. * * Défaut : false */ const USE_CRON = false; /** * Activation de l'envoi de fichier directement par le serveur web. * (X-SendFile) * * Permet d'améliorer la rapidité d'envoi des fichiers. * Supporte les serveurs web suivants : * - Apache avec mod_xsendfile (paquet libapache2-mod-xsendfile) * - Lighttpd * * N'activer que si vous êtes sûr que le module est installé et activé (sinon * les fichiers ne pourront être vus ou téléchargés). * Nginx n'est PAS supporté, car X-Accel-Redirect ne peut gérer que des fichiers * qui sont *dans* le document root du vhost, ce qui n'est pas le cas ici. * * Défaut : false */ |
︙ | ︙ | |||
193 194 195 196 197 198 199 | * * Défaut : false */ const SMTP_HOST = false; /** * Port du serveur SMTP | | | | | | | | | | 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 | * * Défaut : false */ const SMTP_HOST = false; /** * Port du serveur SMTP * * 25 = port standard pour connexion non chiffrée (465 pour Gmail) * 587 = port standard pour connexion SSL * * Défaut : 587 */ const SMTP_PORT = 587; /** * Login utilisateur pour le server SMTP * * mettre à null pour utiliser un serveur local ou anonyme * * Défaut : null */ //const SMTP_USER = 'garradin@monserveur.com'; /** * Mot de passe pour le serveur SMTP * * mettre à null pour utiliser un serveur local ou anonyme * * Défaut : null */ //const SMTP_PASSWORD = 'abcd'; /** * Sécurité du serveur SMTP * * NONE = pas de chiffrement * SSL = connexion SSL native * TLS = connexion TLS native (le plus sécurisé) * STARTTLS = utilisation de STARTTLS (moyennement sécurisé) * * Défaut : STARTTLS */ const SMTP_SECURITY = 'STARTTLS'; /** * Activer les sauvegardes automatiques * * Utile à désactiver si vous avez déjà des sauvegardes effectuées * automatiquement au niveau du système. * * Sinon les sauvegardes seront effectuées soit par la tâche cron * soit à l'affichage de la page d'accueil (si nécessaire). * * Voir paramètre USE_CRON aussi * * Défaut : true */ const ENABLE_AUTOMATIC_BACKUPS = true; |
Modified src/include/init.php from [e2c365beec] to [b52a5657db].
︙ | ︙ | |||
96 97 98 99 100 101 102 103 104 105 106 107 108 109 | 'DB_SCHEMA' => ROOT . '/include/data/schema.sql', 'PLUGINS_ROOT' => DATA_ROOT . '/plugins', 'PREFER_HTTPS' => false, 'ALLOW_MODIFIED_IMPORT' => true, 'PLUGINS_SYSTEM' => '', 'SHOW_ERRORS' => true, 'MAIL_ERRORS' => false, 'USE_CRON' => false, 'ENABLE_XSENDFILE' => false, 'SMTP_HOST' => false, 'SMTP_USER' => null, 'SMTP_PASSWORD' => null, 'SMTP_PORT' => 587, 'SMTP_SECURITY' => 'STARTTLS', | > > | 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 | 'DB_SCHEMA' => ROOT . '/include/data/schema.sql', 'PLUGINS_ROOT' => DATA_ROOT . '/plugins', 'PREFER_HTTPS' => false, 'ALLOW_MODIFIED_IMPORT' => true, 'PLUGINS_SYSTEM' => '', 'SHOW_ERRORS' => true, 'MAIL_ERRORS' => false, 'ERRORS_REPORT_URL' => null, 'ERRORS_ENABLE_LOG_VIEW'=> true, 'USE_CRON' => false, 'ENABLE_XSENDFILE' => false, 'SMTP_HOST' => false, 'SMTP_USER' => null, 'SMTP_PASSWORD' => null, 'SMTP_PORT' => 587, 'SMTP_SECURITY' => 'STARTTLS', |
︙ | ︙ | |||
162 163 164 165 166 167 168 | { $classname = ltrim($classname, '\\'); if (array_key_exists($classname, self::$loaded)) { return true; } | | | | 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 | { $classname = ltrim($classname, '\\'); if (array_key_exists($classname, self::$loaded)) { return true; } // Plugins if (substr($classname, 0, 16) == 'Garradin\\Plugin\\') { $classname = substr($classname, 16); $plugin_name = substr($classname, 0, strpos($classname, '\\')); $filename = str_replace('\\', '/', substr($classname, strpos($classname, '\\')+1)); $path = Plugin::getPath(strtolower($plugin_name)) . '/lib/' . $filename . '.php'; } else { // PSR-0 autoload $filename = str_replace('\\', '/', $classname); $path = ROOT . '/include/lib/' . $filename . '.php'; |
︙ | ︙ | |||
216 217 218 219 220 221 222 | ErrorManager::setContext([ 'rootDirectory' => ROOT, 'garradin_data_root' => DATA_ROOT, 'garradin_version' => garradin_version(), ]); | > > | > | | 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 | ErrorManager::setContext([ 'rootDirectory' => ROOT, 'garradin_data_root' => DATA_ROOT, 'garradin_version' => garradin_version(), ]); if (ERRORS_REPORT_URL) { ErrorManager::setRemoteReporting(ERRORS_REPORT_URL, false); } ErrorManager::setProductionErrorTemplate('<!DOCTYPE html><html><head><title>Erreur interne</title> <style type="text/css"> body {font-family: sans-serif; } code, p, h1 { max-width: 400px; margin: 1em auto; display: block; } code { text-align: right; color: #666; } a { color: blue; } form { text-align: center; } </style></head><body><h1>Erreur interne</h1><p>Désolé mais le serveur a rencontré une erreur interne et ne peut répondre à votre requête. Merci de ré-essayer plus tard.</p> <p>Si vous suspectez un bug dans Garradin, vous pouvez suivre <a href="http://dev.kd2.org/garradin/Rapporter+un+bug">ces instructions</a> pour le rapporter.</p> <if(sent)><p>Un-e responsable a été notifié-e et cette erreur sera corrigée dès que possible.</p></if> <if(logged)><code>L\'erreur a été enregistrée dans les journaux système (error.log) sous la référence : <b>{$ref}</b></code></if> <p><a href="' . WWW_URL . '">← Retour à la page d\'accueil</a></p> </body></html>'); ErrorManager::setHtmlHeader('<!DOCTYPE html><meta charset="utf-8" /><style type="text/css"> body { font-family: sans-serif; } * { margin: 0; padding: 0; } u, code b, i, h3 { font-style: normal; font-weight: normal; text-decoration: none; } #icn { color: #fff; font-size: 2em; float: right; margin: 1em; padding: 1em; background: #900; border-radius: 50%; } |
︙ | ︙ | |||
253 254 255 256 257 258 259 | vertical-align: top; } input { padding: .3em; margin: .5em; font-size: 1.2em; cursor: pointer; } </style> <pre id="icn"> \__/<br /> (xx)<br />//||\\\\</pre> <section> <article> <h1>Une erreur s\'est produite</h1> | | | 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 | vertical-align: top; } input { padding: .3em; margin: .5em; font-size: 1.2em; cursor: pointer; } </style> <pre id="icn"> \__/<br /> (xx)<br />//||\\\\</pre> <section> <article> <h1>Une erreur s\'est produite</h1> <if(report)><form method="post" action="https://garradin.eu/report/"><p><input type="hidden" name="report" value="{$report_json}" /><input type="submit" value="Rapporter l\'erreur aux développeur⋅euses de Garradin →" /></p></form></if> </article> </section> '); function user_error($e) { if (PHP_SAPI == 'cli') |
︙ | ︙ |
Modified src/templates/admin/config/logs.tpl from [494547ec56] to [3e30c074ee].
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | {include file="admin/_head.tpl" title="Journaux" current="config"} {include file="admin/config/_menu.tpl" current="logs"} <ul class="actions sub"> <li{if $type != 'errors'} class="current"{/if}><a href="{$self_url_no_qs}">Actions utilisateurs</a></li> <li{if $type == 'errors'} class="current"{/if}><a href="?type=errors">Erreurs système</a></li> </ul> {if isset($reports) && isset($id)} {foreach from=$main.errors item="error"} <h2>{$error.type}: {$error.message} [Code: {$error.errorCode}]</h2> {if !empty($error.backtrace)} {foreach from=$error.backtrace item=trace} <h4>{$trace.function}{if !empty($trace.args)} ({$trace.args|count} arg.){/if}</h4> | > > | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | {include file="admin/_head.tpl" title="Journaux" current="config"} {include file="admin/config/_menu.tpl" current="logs"} {if ERRORS_ENABLE_LOG_VIEW} <ul class="actions sub"> <li{if $type != 'errors'} class="current"{/if}><a href="{$self_url_no_qs}">Actions utilisateurs</a></li> <li{if $type == 'errors'} class="current"{/if}><a href="?type=errors">Erreurs système</a></li> </ul> {/if} {if isset($reports) && isset($id)} {foreach from=$main.errors item="error"} <h2>{$error.type}: {$error.message} [Code: {$error.errorCode}]</h2> {if !empty($error.backtrace)} {foreach from=$error.backtrace item=trace} <h4>{$trace.function}{if !empty($trace.args)} ({$trace.args|count} arg.){/if}</h4> |
︙ | ︙ |
Modified src/www/admin/config/logs.php from [708f1ed139] to [3641ab6b53].
1 2 3 4 5 6 7 | <?php namespace Garradin; use KD2\ErrorManager; require_once __DIR__ . '/_inc.php'; | | | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | <?php namespace Garradin; use KD2\ErrorManager; require_once __DIR__ . '/_inc.php'; if (qg('type') == 'errors' && ERRORS_ENABLE_LOG_VIEW) { $reports = ErrorManager::getReportsFromLog(null, qg('id')); $reports = array_reverse($reports, true); foreach ($reports as &$report) { $report->context->date = strtotime($report->context->date); |
︙ | ︙ |