La plupart des aspects de symfony peuvent être configurés via un fichier de configuration
écrit en YAML, ou avec du simple PHP. Dans cette section, settings.yml
, le principal fichier
de configuration est décrit.
Le fichier de configuration principal settings.yml
pour une application peut être trouver dans
le répertoire apps/APP_NAME/config/
.
Comme indiqué dans l'introduction, le fichier settings.yml
est
sensible à l'environnement, et bénéficie du
mécanisme de configuration en cascade.
Chaque section d'un environnement comprend deux sous-sections : .actions
et .settings
. Toutes
les directives de configuration passe par la sous-section .settings
, à l'exception des
actions par défaut pour restituer certaines pages communes.
note
Le fichier de configuration settings.yml
est mis en cache dans un fichier PHP, le processus est
automatiquement géré par la classe
sfDefineEnvironmentConfigHandler
.
Paramètres
.actions
.settings
La sous-section .actions
Configuration par défaut:
default: .actions: error_404_module: default error_404_action: error404 login_module: default login_action: login secure_module: default secure_action: secure module_disabled_module: default module_disabled_action: disabled
La sous-section .actions
définit l'action à exécuter lorsqu'une page commune
doit être restituée. Chaque définition comporte deux éléments : l'un pour le module
(suffixé par _module
) et l'autre pour l'action (suffixé par _action
).
error_404
L'action error_404
est exécutée quand une page 404 doit être restituée.
login
L'action login
est exécutée quand un utilisateur non-identifié essait d'accéder à
une page sécurisée.
secure
L'action secure
est exécutée quand un utilisateur n'a pas les pouvoirs
requis.
module_disabled
L'action module_disabled
est exécuté quand l'utilisateur demande un module
désactivé.
La sous-section .settings
La sous-section .settings
est l'endroit où se réalise la configuration du framework. Les
paragraphes qui suivent décrivent tous les paramètres possibles et sont à peu près classé par ordre
d'importance.
Tous les paramètres définis dans la section .settings
sont disponibles n'importe où dans le
code en utilisant l'objet sfConfig
et en préfixant le paramètre avec sf_
. Par
exemple, pour obtenir la valeur du paramètre charset
, utilisez :
sfConfig::get('sf_charset');
escaping_strategy
Par défaut: true
Le paramètre escaping_strategy
est un paramètre booléen qui détermine si
l'échappement de sortie du sous-framework est activé ou non. Lorsqu'il est activé, toutes les variables
disponibles dans les templates sont automatiquement échappé en appelant le helper
définie par le paramètre escaping_method
(voir ci-dessous).
Faites bien attention à l'escaping_method
, l'helper par défaut utilisé par symfony,
mais cela peut être remplacé au cas par cas, par exemple, en sortant une variable
d'une balise d'un script JavaScript.
L'échappement de sortie du sous-framework utilise le paramètre charset
pour échapper.
Il est fortement recommandé de laisser la valeur par défaut à true
.
tip
Ce réglage peut être activé lorsque vous créez une application avec la tâche
generate:app
en utilisant l'option --escaping-strategy
.
escaping_method
Par défaut: ESC_SPECIALCHARS
L'escaping_method
definit la function par défaut utilisée pour échapper
les variables dans les templates (Voir l'escaping_strategy
ci-dessus).
Vous pouvez choisir l'une des valeurs prédéfinies : ESC_SPECIALCHARS
, ESC_RAW
,
ESC_ENTITIES
, ESC_JS
, ESC_JS_NO_ENTITIES
, et
ESC_SPECIALCHARS
, ou créer votre propre fonction.
La plupart du temps, la valeur par défaut est très bien. L'helper ESC_ENTITIES peut également être utilisé, surtout si vous travaillez uniquement avec les langues anglaise ou européenne.
csrf_secret
Par défaut: a généré de façon aléatoire un secret
Le csrf_secret
est un secret unique pour votre application. S'il n'est pas défini à
false
, il permet la protection CSRF pour toutes les formulaires définies avec le formulaire
du framework. Ce paramètre est également utilisé par le helper link_to()
quand il a besoin
de convertir un lien vers un formulaire (pour simuler une méthode HTTP DELETE
par exemple).
Il est fortement recommandé de changer la valeur par défaut par un secret unique de votre choix.
tip
Ce paramètre peut être activé lorsque vous créez une application avec la tâche
generate:app
en utilisant l'option --csrf-secret
.
charset
Par défaut: utf-8
Le paramètre charset
est le jeu de caractères qui sera utilisé partout dans
le framework : de la réponse du Content-Type
dans le header, à la fonctionnalité
d'échappement de sortie.
La plupart du temps, la valeur par défaut est très bien.
warning
Ce paramètre est utilisé dans de nombreux endroits différents dans le framework, et donc sa valeur est mise en cache à plusieurs endroits. Après l'avoir modifié, le cache de configuration doit être vidé, même dans l'environnement de développement.
enabled_modules
Par défaut: [default]
L'enabled_modules
est un tableau de nom de module à activer pour cette
application. Les modules définis dans un plugin ou dans le noyau de symfony ne sont pas activé
par défaut, et vous devez les lister dans ce paramètre pour qu'ils soient accessibles.
L'ajout d'un module est très simple en l'ajoutant à la liste (l'ordre des modules n'a pas d'importance) :
enabled_modules: [default, sfGuardAuth]
Le module default
défini dans le framework contient toutes les actions par défaut
définies dans la sous-section .actions
de settings.yml
. Il est recommandé de
personnaliser le tout, puis de retirer le module default
de ce
paramètre.
default_timezone
Par défaut: aucun
Le paramètre default_timezone
définit le fuseau horaire par défaut utilisé par PHP. Il
peut avoir n'importe quel fuseau horaire
reconnu par PHP.
note
Si vous ne définissez pas de fuseau horaire, il est conseillé d'en définir un dans le
fichier php.ini
. Sinon, symfony va essayer de deviner le meilleur fuseau horaire
en appelant la fonction
date_default_timezone_get()
de PHP.
cache
Par défaut : false
Le paramètre cache
active ou désactive le modèle de mise en cache.
tip
La configuration générale du système de cache est fait dans
les sections view_cache_manager
et
view_cache
du fichier de configuration
factories.yml
. La configuration la plus fine est faite dans
le fichier de configuration cache.yml
.
etag
Par défaut: true
par défaut sauf pour les environnements de dev
et test
Le paramètre etag
active ou désactive la génération automatique d'en-têtes ETag
HTTP.
Le ETag généré par symfony est un simple MD5 du contenu des
réponses.
asset_timestamp
Par défaut : false
Le paramètre asset_timestamp
active automatiquement l'ajout d'un horodatage pour tous les
actifs à l'intérieur de web_dir
lorsque qu'ils sont utilisés avec le AssetHelper
.
i18n
Par défaut : false
Le paramètre i18n
est un booléen qui active ou désactive le sous framework
i18n. Si votre application estest internationalisée, réglez-le à on
.
tip
La configuration générale du système i18n est à faire dans la section
i18n
du fichier de configuration
factories.yml
.
default_culture
Par défaut: en
Le paramètre default_culture
définit la culture par défaut utilisé par le sous-framework
i18n. Il peut avoir n'importe quelle culture valide.
standard_helpers
Par défaut: [Partial, Cache, Form]
Le paramètre standard_helpers
est un tableau de groupe de helper pour charger tous
les templates (nom du groupe de helper sans le suffixe Helper
).
no_script_name
Par défaut: true
pour l'environnement de prod
de la première application créée,
false
pour les autres
Le paramètre no_script_name
détermine si le nom du script du contrôleur frontal
est ajouté ou non dans l'URL générée. Par défaut il est réglé sur true
par
la tâche generate:app
pour l'environnement de prod
de la première application
créée.
De toute évidence, un seul couple application/environnement peut avoir le paramètre à
true
, dans le cas où tous les contrôleurs frontaux sont dans le même répertoire (web/
). Si vous voulez
plus d'une application avec no_script_name
à true
, déplacez le(s) contrôleur(s)
correspondant(s) dans un sous-répertoire du répertoire racine
web.
lazy_cache_key
Par défaut: true
pour les nouveaux projets, false
pour des projets mis à niveau
Lorsqu'il est activé, le paramètre lazy_cache_key
retarde la création d'une clé cache
jusqu'à ce que la vérification de la mise en cache d'une action ou d'un partial soit terminé. cela peut
avoir pour résultat une grande amélioration des performances, en fonction de votre utilisation des templates
partials.
file_link_format
Par défaut: aucun
Dans le message du débug, les chemins de fichiers sont des liens cliquables si
sf_file_link_format
ou la valeur de configuration PHP de xdebug.file_link_format
est définie.
Par exemple, si vous voulez ouvrir des fichiers dans TextMate, vous pouvez utiliser la valeur suivante :
txmt://open?url=file://%f&line=%l
Le %f
sera remplacé par le chemin absolue du fichier et le %l
sera remplacé par le numéro de ligne.
logging_enabled
Par défaut: true
pour tous les environnements sauf prod
Le paramètre logging_enabled
active la journalisation du sous-framework. Mettez cette option à
false
et il contourne le mécanisme de journalisation et cela fournit un petit
gain de performance.
tip
La configuration la plus fine de la journalisation est faite dans le fichier de configuration
factories.yml
.
web_debug
Par défaut: false
pour tous les environnements sauf dev
Le paramètre web_debug
active la barre d'outil de déboggage web. Elle
est incluse dans une page si le contenu de la réponse est du HTML.
error_reporting
Par défaut:
prod
: E_PARSE | E_COMPILE_ERROR | E_ERROR | E_CORE_ERROR | E_USER_ERRORdev
: E_ALL | E_STRICTtest
: (E_ALL | E_STRICT) ^ E_NOTICE- default: E_PARSE | E_COMPILE_ERROR | E_ERROR | E_CORE_ERROR | E_USER_ERROR
Le paramètre error_reporting
contrôle le niveau de rapport d'erreurs PHP (qui sera
affiché dans le navigateur et écrit dans les journaux).
tip
Le site PHP a quelques informations sur la façon d'utiliser les opérateurs sur les bits.
La configuration par défaut est la plus sensible, et ne devrait pas être modifiée.
note
L'affichage des erreurs dans le navigateur est automatiquement désactivé
pour les contrôleurs frontaux qui ont le debug
désactivé, c'est le cas par défaut
pour l'environnement de prod
.
compressed
Par défaut: false
Le paramètre compressed
permet la compression native de la réponse PHP. S'il est à
true
, symfony utilisera ob_gzhandler
, une fonction
callback de ob_start()
.
Il est recommandé de le laisser à false
et utiliser le mécanisme de compression
natif de votre serveur web à la place.
use_database
Par défaut: true
Le use_database
détermine si l'application utilise une base de données ou non.
check_lock
Par défaut: false
Le paramètre check_lock
active ou désactive le système de verrouillage de l'application
déclenchée par des tâches telles que cache:clear
et project:disable
.
S'il est défini à true
, toutes les requêtes vers des applications désactivées seront automatiquement
redirigées vers la page du noyau symfony lib/exception/data/unavailable.php
.
tip
Vous pouvez remplacer le template par défaut disponible en ajoutant
un fichier config/unavailable.php
à votre projet ou à votre application.
web_debug_web_dir
Par défaut: /sf/sf_web_debug
Le web_debug_web_dir
définit le chemin web pour les ressources de la barre d'outil de déboggage
(images, feuilles de style, et les fichiers JavaScript).
This work is licensed under the Creative Commons Attribution-Share Alike 3.0 Unported License license.