installation_guide_fr_FR.html 60 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005
  1. <html lang="en">
  2. <head>
  3. <meta charset="utf-8" />
  4. <title>Guide d'installation de Chamilo</title>
  5. <link rel="stylesheet" href="../public/build/css/app.css" type="text/css" media="screen,projection" />
  6. <link rel="stylesheet" href="../public/build/css/themes/chamilo/default.css" type="text/css" media="screen,projection" />
  7. <link rel="stylesheet" href="default.css" type="text/css" media="screen,projection" />
  8. <link rel="stylesheet" href="../public/build/css/print.css" type="text/css" media="print" />
  9. <script src="../public/build/app.js"></script>
  10. </head>
  11. <body>
  12. <nav class="navbar navbar-default navbar-fixed-top">
  13. <div class="container">
  14. <div class="navbar-header">
  15. <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1">
  16. <span class="sr-only">Toggle navigation</span>
  17. <span class="icon-bar"></span>
  18. <span class="icon-bar"></span>
  19. <span class="icon-bar"></span>
  20. </button>
  21. <a class="navbar-brand" href="#">Chamilo - Documentation</a>
  22. </div>
  23. <div class="collapse navbar-collapse">
  24. <ul class="nav navbar-nav">
  25. <li class="active"><a href="index.html">Home</a></li>
  26. <li ><a href="readme.html">About</a></li>
  27. <li><a href="license.html">License</a></li>
  28. <li><a href="credits.html">Credits</a></li>
  29. <li ><a href="dependencies.html">Dependencies</a></li>
  30. <li><a href="changelog.html">Changelog</a></li>
  31. </ul>
  32. </div><!--/.nav-collapse -->
  33. </div>
  34. </nav>
  35. <div class="container">
  36. <h1>Guide d'installation de Chamilo LMS 1.11</h1>
  37. <p>Merci d'avoir téléchargé Chamilo</p>
  38. <ul>
  39. <li>Vous pouvez tester Chamilo LMS, en tnt que professeur, sans l'installer, sur <a href="http://campus.chamilo.org/?language=french">le campus libre de Chamilo</a></li>
  40. </ul>
  41. <p>Ce guide explique comment installer Chamilo LMS. Nous recommandons activement la lecture complète de ce guide avant de commencer l'installation.</p>
  42. <p>English: Get back to the <a href="installation_guide.html">English version of the installation guide</a>.</p>
  43. <p>Spanish: También puede leer <a href="installation_guide_es_ES.html">esta guía de instalación en español</a>.</p>
  44. <p>Italian: You can also read <a href="installation_guide_it_IT.html">this guide in Italian</a>.</p>
  45. <h2><b>Index</b></h2>
  46. <ol>
  47. <li><a href="#1._Pre-requisites">Prérequis</a></li>
  48. <li><a href="#2._Installation_of_Chamilo_LMS">Installation de Chamilo LMS</a></li>
  49. <li><a href="#3._Upgrade_from_a_previous_version_of">Upgrade depuis une version antérieure de Chamilo/Dok€os</a></li>
  50. <li><a href="#4._Troubleshooting">Problèmes</a></li>
  51. <li><a href="#5._Administration_section">La section d'administration</a></li>
  52. <li><a href="#6._LDAP">LDAP&nbsp;</a></li>
  53. <li><a href="#9._WIRIS_mathematical_formulas">Formules mathématiques avec WIRIS</a></li>
  54. <li><a href="#10._Xapian_fulltext_indexing">Indexation full-text avec Xapian</a></li>
  55. <li><a href="#11._Chamilo_rapid_ppt_conversion">Chamilo Rapid - système de conversion PPT</a></li>
  56. <li><a href="#12._Setting_cron_up">Configurer de tâches "chronologiques"</a></li>
  57. <li><a href="#13._Changing_language_names_order">Changer l'ordre des noms/prénoms par langue</a></li>
  58. <li><a href="#14._Improving_files_download">Améliorer le temps de téléchargement de fichiers</a></li>
  59. <li><a href="#15._Videoconference">Vidéo-conférence</a></li>
  60. <li><a href="#16._Rewrite">Configuration de la réécriture</a></li>
  61. </ol>
  62. <br />
  63. <hr style="width: 100%; height: 2px;" />
  64. <h2><a name="1._Pre-requisites"></a>1. Prérequis</h2>
  65. Chamilo peut être installé sous Windows, Linux, Max OS X et serveurs UNIX
  66. indifféremment. Cela dit, nous recommandons activement l'utilisation d'un
  67. serveur Linux pour sa flexibilité optimale, son facile contrôle à distance
  68. et sa capacité de redimensionnement. En particulier, nous recommandons la
  69. distribution Debian (ou sa petite soeur Ubuntu)<br />
  70. <br />
  71. Chamilo est un système de gestion de l'apprentissage (LMS) qui fonctionne
  72. principallement sur base d'un <span style="font-weight: bold;">serveur web (Apache 2.2+)</span>, de <span style="font-weight: bold;">MySQL 5.6+ ou de MariaDB 5+
  73. (5 ou 10)</span> et de <span style="font-weight: bold;">PHP 5.5+</span> (7.1 recommandé). <br />
  74. <br />
  75. Tous ces éléments logiciels sont sous licence de logiciels libres et sont
  76. disponibles gratuitement.<br />
  77. <br />
  78. Pour faire fonctionner Chamilo <span style="font-weight: bold;">LMS</span> sur votre serveur,
  79. il est suggéré d'installer WAMP, LAMP ou MAMP (ou leurs composants
  80. individuellement):
  81. <ul>
  82. <li>Pour installer <span style="font-weight: bold;">WAMP</span> (AMP sous Windows), nous
  83. recommandons le paquet
  84. <a href="http://www.apachefriends.org/en/xampp.html">XAMPP</a> en
  85. installateur ".exe"</li>
  86. <li>Pour installer <span style="font-weight: bold;">LAMP</span>
  87. (AMP sous Linux), utilisez le système de gestion de paquets de votre
  88. distribution préférée (apt, Synaptic, RPMFinder, yum etc.). Par exemple,
  89. sur un serveur Ubuntu, vous pouvez utiliser le Shell (terminal) ou
  90. Synaptic via le guide
  91. <a href="http://ubuntuguide.org/wiki/Ubuntu:Feisty#Apache_HTTP_Server">
  92. Ubuntuguide on Apache</a> et les sections suivantes du présent guide/li>
  93. <li>Pour installer <span style="font-weight: bold;">MAMP</span> (AMP sur Mac OS X),
  94. référez-vous au site dédié de
  95. <a href="http://www.mamp.info/en/index.php">MAMP</a></li>
  96. <li>Assurez-vous de vérifier les
  97. <a href="dependencies.html" title="Dependencies">dépendances</a> si vous
  98. avez besoin de connaîtres les pré-requis de façon plus précise.
  99. </ul>
  100. <br />
  101. <h3><span style="font-weight: bold;">Serveurs de base de données MySQL ou MariaDB</span></h3>
  102. Vous aurez besoin d'un login et d'un mot de passe pour gérer et <em>supprimer+créer</em> une base
  103. de données. Généralement, la configuration par défaut sur des ordinateurs
  104. locaux est de permettre la connexion comme utilisateur root avec un mot de passe
  105. vide. Il est FORTEMENT RECOMMANDÉ de modifier le mot de passe et de définir un
  106. utilisateur avec un accès à une (et une seule) base de données spécifique.
  107. Veuillez vous référer à la documentation de MySQL ou MariaDB pour ce faire.
  108. <br />
  109. <span class="text-muted">
  110. Les versions de Chamilo antérieures à la 1.9.0 nécessitaient de choisir entre une installation sur plusieurs bases
  111. et une installation obsolète sur une seule base. Ca a été clarifié et simplifié par l'usage d'une seule base de données.
  112. </span><br />
  113. <span class="text-muted">Si vous ne disposez pas des permissions de suppression+création de la base de
  114. données choisie, Chamilo ne pourra pas terminer l'installation car, pour éviter tout déchêt d'une
  115. version antérieure de Chamilo ou d'un autre système, nous supprimons d'abord la base de données avant
  116. de la recréer. C'est expliqué dans <a href="https://github.com/chamilo/chamilo-lms/issues/2172">un peu plus de détail dans cette demande</a></span><br />
  117. <h3><span style="font-weight: bold;">Redirections d'Apache</span></h3>
  118. <div>
  119. Depuis sa version 1.10, Chamilo exige que le serveur web puisse gérer les redirections. Il s'agit d'un pré-requis très commun de nos jours pour les applications web (autant CMS que LMS, ERP, etc) qui permet, entre autres, l'utilisation intelligente et user-friendly des URLs.<br />
  120. Si vous utilisez un autre serveur web qu'Apache, dirigez-vous à la section "Configuration de la réécriture" en fin de ce document.<br />
  121. Si vous utilisez Apache, la configuration des redirections se fait en deux étapes simples:
  122. <ul>
  123. <li>Activer le module "rewrite" d'Apache (en ligne de commande, faites simplement un "<i>sudo a2enmod rewrite</i>")</li>
  124. <li>Configurer le VirtualHost d'Apache pour qu'il inclue le bloc suivant, ce qui permettra l'interprétation des fichiers .htaccess</li>
  125. </ul>
  126. Pour Apache <=2.2 (remplacez /var/www/chamilo par le chemin vers votre répertoire de Chamilo):
  127. <pre>
  128. &lt;Directory /&gt;
  129. AllowOverride All
  130. Order allow,deny
  131. allow from all
  132. &lt;/Directory&gt;
  133. &lt;Directory /var/www/chamilo/&gt;
  134. AllowOverride All
  135. Order allow,deny
  136. allow from all
  137. &lt;/Directory&gt;
  138. </pre>
  139. et pour Apache >=2.4:
  140. <pre>
  141. &lt;Directory /&gt;
  142. AllowOverride All
  143. Require all granted
  144. &lt;/Directory&gt;
  145. &lt;Directory /var/www/chamilo/&gt;
  146. AllowOverride All
  147. Require all granted
  148. &lt;/Directory&gt;
  149. </pre>
  150. <br />
  151. Une fois configurée cette partie (qui est peut-être déjà mise en place par votre fournisseur d'hébergement), il suffit de redémarrer le serveur web pour activer la modification.
  152. </div>
  153. <hr style="width: 100%; height: 2px;" />
  154. <h2><a name="2._Installation_of_Chamilo_LMS"></a><span style="font-weight: bold;">2. Installation de Chamilo LMS</span></h2>
  155. <p>
  156. Avant d'installer Chamilo LMS, vous devez comprendre que du fait que Chamilo est un logiciel libre,
  157. de nombreux prestataires de service ont été en mesure de développer des extensions pour Chamilo,
  158. qui ont rendu son installation possible par différents biais :<br />
  159. <ul>
  160. <li>Comme un paquet "tout-compris" fourni par un fournisseur officiel certifié par l'association Chamilo</li>
  161. <li>Comme une solution installable depuis de nombreux hébergeurs supportant cPanel et Scriptaculous</li>
  162. <li>Sur votre hébergeur préféré en utilisant des installateurs distants comme Installatron</li>
  163. <li>Sur votre propre serveur, en le téléchargeant et l'installant manuellement</li>
  164. <li>Sur votre ordinateur, à la maison ou au bureau, juste pour tester et développer</li>
  165. </ul>
  166. Ce guide couvre uniquement les deux dernières méthodes. Pour les premières, veuillez consulter votre fournisseur de services pour plus d'infos.
  167. <br /><br />
  168. Pour installer Chamilo LMS, suivez ces 6 étapes :
  169. <ol>
  170. <li><a href="http://www.chamilo.org/download">Télécharger Chamilo LMS</a></li>
  171. <li>Décompressez-le</li>
  172. <li>Copiez le répertoire de Chamilo dans le répertoire racine de votre serveur web.
  173. Celui-ci peut se trouver dans <span style="font-weight: bold;">C:\xampp\htdocs\</span> sur
  174. une machine Windows avec WAMP, ou dans <span style="font-weight: bold;">/var/www/html/</span> (ou /var/www/) sur un serveur Linux</li>
  175. <li>Vérifiez que votre serveur web supporte les .htaccess (Voir la section "Configuration de la réécriture" plus bas)</li>
  176. <li>Ouvrez votre navigateur (Firefox, Chrome, ...) et tapez l'adresse suivante
  177. <span style="font-weight: bold;">http://localhost/chamilo/</span> si vous l'avez installé localement ou
  178. <span style="font-weight: bold;">http://www.domain.com/chamilo/</span> si vous l'avez installé à distance*
  179. </li>
  180. <li>Suivez le processus d'installation. Vous pouvez accepter toutes les
  181. valeurs par défaut. Pensez à modifier le mot de passe d'administrateur
  182. afin de vous en souvenir plus tard.</li>
  183. </ol>
  184. <span class="text-muted">* Nous recommandons de définir un Virtual Host spécifique pour cette installation, si vous avez les compétences pour ce faire</span>
  185. <br />
  186. <span class="muted">Note: si vous installez Chamilo localement en utilisant
  187. "localhost" ou l'adresse IP de votre ordinateur durant l'installation, vous
  188. pourriez rencontrer des difficultés lors de l'accès depuis d'autres ordinateurs.
  189. Pour éviter ça, vous pouvez
  190. <a href="http://beeznest.wordpress.com/2013/01/15/answering-to-different-addresses-with-chamilo/">appliquer une petite modification à votre
  191. fichier de configuration</a>.</span>
  192. <br /> <br />
  193. Les répertoires suivants doivent êtres lisibles, éditables et exécutables par votre serveur web.
  194. <br />
  195. <span class="muted">Note: Cela ne requiert généralement pas de modification spécifique
  196. sous Windows (ce qui est d'ailleurs l'une des raisons principales pour
  197. l'existence d'autant de virus et malware pour ce système d'exploitation,
  198. mais cela demande l'utilisation de "chmod" sous Linux et Mac. Dans ces
  199. derniers cas, veuillez suivre les instructions qui suivent.</span>
  200. <br /><br />
  201. Remplacez [chamilo] par le répertoire où vous avez placé le contenu du zip:
  202. <ul>
  203. <li>[chamilo]/app/</li>
  204. <li>[chamilo]/vendor/ (nécessite seulement d'être lisible et exécutable)</li>
  205. <li>[chamilo]/web/</li>
  206. <li>[chamilo]/main/default_course_document/images/</li>
  207. </ul>
  208. Optionnellement, vous pouvez faire la même chose pour les répertoires suivants
  209. si vous souhaitez permettre l'envoi de styles CSS ou la définition de nouvelles
  210. langues par les administrateurs de Chamilo:
  211. <ul>
  212. <li>[chamilo]/main/lang/</li>
  213. </ul>
  214. <br />
  215. <span class="text-muted">
  216. Si vous trouvez un répertoire tests/ à la racine, veuillez le supprimer.
  217. Il s'agit d'un répertoire de développement qui ne bénéficie pas des
  218. vérifications de sécurité nécessaires pour un système en production. Il ne
  219. devrait en tout cas *jamais* être accessible aux utilisateurs finaux sur un
  220. système en production.
  221. </span>
  222. <br /><br />
  223. <p><span class="text-muted">Sous les systèmes d'exploitation Linux, Mac OS X et BSD, vous pouvez utiliser
  224. la commande <em>chmod 0775</em> pour modifier les permissions, bien que nous
  225. recommandions, pour des raisons de sécurité, de cherchez l'assistance d'un
  226. administrateur système expérimenté pour le faire.
  227. Sous Windows, vous pourriez avoir besoin de vérifier les propriétés de ces
  228. répertoires (en cliquant dessus avec le bouton droit de la souris).</span></p>
  229. <h3>Sécurité : liste à vérifier après l'installation</h3>
  230. <ul>
  231. <li><strong>Protégez votre répertoire de configuration: </strong>
  232. assurez-vous que personne (à part vous) ne puisse l'éditer.
  233. Vous trouverez le répertoire de configuration dans <em>(chamilo folder)</em>/app/config.
  234. Rendez-le lisible uniquement (windows/xwindows: click-droit sur le répertoire
  235. pour en éditer les propriétés - Linux/BSD/MacOSX: utilisez la commande "chmod -r 0555".
  236. Le fichier de configuration (main/inc/conf/configuration.php) est créé par votre serveur webThe config
  237. file is created by your web server (Apache + PHP, usually) so you may
  238. need to be root user to change its permissions.</li>
  239. <li><strong>Configurez votre installation de Chamilo: </strong>
  240. dans la section d'administration de Chamilo, vous pouvez utiliser les paramètres
  241. de configuration pour ajuster le comportement de votre installation.</li>
  242. <li>Des astuces pour une sécurité plus forte sont disponibles dans notre nouveau <a href="./security.html">guide de sécurité</a></li>
  243. </ul>
  244. <br />
  245. <h3>Configuration de PHP</h3>
  246. Pour obtenir le meilleur de votre installation de Chamilo, vous devez configurer vos paramètres PHP: <br />
  247. <ul>
  248. <li>
  249. Configurer les mails de Chamilo : la plupart des portails Chamilo utilisent les propriétés mail définies dans le fichier php.ini.
  250. Cependant si vous utilisez un serveur mail distinct, vous voudrez peut-être ajuster les propriétés mail
  251. dans <em>(chamilo folder)</em>/app/config/mail.conf.php
  252. </li>
  253. <li>Editez le fichier php.ini (sous Windows, il devrait se trouver dans
  254. <span style="font-weight: bold;">C:\xampp\php\php.ini</span>,
  255. et sous Debian ou Ubuntu (Linux) :
  256. <span style="font-weight: bold;">/etc/php5/apache2/php.ini</span></li>
  257. <li>cherchez les mots contenant "_max" et augmentez les deux valeurs pour optimiser le serveur</li>
  258. <li>nous recommandons les valeurs suivantes : </li>
  259. </ul>
  260. <div class="code">
  261. max_execution_time = 300 ;Maximum execution time of each script, in seconds<br />
  262. max_input_time = 600 ;Maximum amount of time each script may spend parsing request data<br />
  263. memory_limit = 128M ;Maximum amount of memory a script may consume (128MB)<br />
  264. post_max_size = 100M<br />
  265. upload_max_filesize = 100M;<br />
  266. short_open_tag = Off<br />
  267. safe_mode = Off<br />
  268. magic_quotes_gpc = Off<br />
  269. magic_quotes_runtime = Off<br />
  270. </div>
  271. <br />
  272. <p>
  273. <strong>Important :</strong>
  274. Vous aurez besoin de définir votre <em>date.timezone</em> en fonction de votre fuseau horaire.
  275. Par exemple si votre serveur se trouve dans la zone America/New_York, indiquez cette valeur pour
  276. le paramètre date.timezone du fichier php.ini :
  277. </p>
  278. <div class="code">
  279. date.timezone = 'America/New_York'
  280. </div>
  281. <p><strong>Note:</strong> PHP 5.3.9 introduit un nouveau paramètre appelé
  282. "max_input_vars", qui limite le nombre d'éléments que vous pouvez envoyer au
  283. travers d'un formulaire déterminé. Si vous devez gérer de grandes quantités
  284. d'utilisateurs ou de longs parcours d'apprentissage (de nombreux éléments),
  285. assurez-vous de configurer ce paramètre plus haut que se valeur par défault
  286. de 1000.</p>
  287. <p><strong>Utilisateurs de BSD:</strong> les librairies suivantes doivent être
  288. inclues durant l'installation de PHP:</p>
  289. <ul>
  290. <li>php5-session : L'extension pour le partage des sessions pour php</li>
  291. <li>php5-mysqlnd (ou php5-mysqli) : L'extension mysql pour php</li>
  292. <li>php5-zlib : L'extension zlib partagée pour php</li>
  293. <li>php5-pcre: L'extension pcre partagée pour php</li>
  294. <li>php5-xml</li>
  295. <li>php5-json</li>
  296. <li>php5-mcrypt</li>
  297. <li>php5-iconv ou php5-mbstring (au choix)</li>
  298. <li>php5-gd L'extension de manipulation d'images pour PHP</li>
  299. <li>php5-intl L'extension pour la gestion de l'internationalisation pour PHP</li>
  300. </ul>
  301. <p>Nous recommandons aussi les extensions suivantes:</p>
  302. <ul>
  303. <li>php5-ctype</li>
  304. <li>php5-ldap</li>
  305. <li>php5-xapian</li>
  306. <li>php5-curl</li>
  307. <li>php5-xsl</li>
  308. </ul>
  309. <div style="color: red;">Certains sections de ce manuel ne sont pas encore traduites. N'hésitez pas à consulter
  310. le <a href="http://www.chamilo.org/forum">forum de Chamilo</a> si la lecture
  311. en anglais vous est impossible.</div>
  312. <hr />
  313. <h2><a name="3._Upgrade_from_a_previous_version_of"></a>3. Mettre à jour depuis
  314. une version antérieure de Chamilo LMS (1.*) ou de Dok€os (&lt;2.0)</h2>
  315. Avant de mettre à jour, nous recommandons chaudement la prise d'une copie de
  316. sauvegarde de votre installation (répertoires et bases de données).
  317. Si vous ne savez pas comment faire, consultez votre fournisseur d'hébergement
  318. ou un administrateur système qualifié avant de continuer l'installation.<br /><br />
  319. <em>Chamilo LMS 1.10 (et donc 1.11) est livré avec une nouvelle structure de bases de données
  320. en comparaison avec 1.8. Bien que le script de migration la prenne
  321. complètement en charge, il pourrait générer une surcharge sur votre serveur
  322. durant la mise à jour, et il changera la base de données de façon assez
  323. profonde, préservant les données le mieux possible (nous avons testé la
  324. procédure de nombreuses fois, mais rappelez-vous qu'il s'agit d'un logiciel
  325. GNU/GPLv3 et que nous ne saurions être tenus pour responsables de ce qui
  326. pourrait arriver à vos données sans la supervision d'un professionnel).
  327. C'est pour cela que nous recommandons *vraiment* de faire un backup complet de
  328. votre système avant la mise à jour.</em>
  329. <br />
  330. <br />
  331. Notez également que Chamilo LMS 1.10 (et donc 1.11) agrège les fichiers du dossier
  332. main/lang en un fichier unique par langue. Si vous avez modifiez les fichiers de langue directement (plutôt que
  333. d'utiliser la méthode recommandée des sous-langages), vous devriez faire une copie
  334. des traductions modifiées avant la mise à jour. Les sous-langages nécessitent également
  335. un peu de travail manuel, mais la procédure de mise à jour n'y touchera pas directement.
  336. <br /><br />
  337. <div class="text-muted"> NOTE: Pour les bases de données très lourdes de Chamilo,
  338. certains de nos fournisseurs officiels ont dévelopé des procédures de
  339. migration optimisées qui utilisent plus de mémoire mais exécutent les
  340. migrations beaucoup plus rapidement. Si c'est le genre de choses qui
  341. vous intéresse, nous vous recommandons chaudement de les contacter (voir
  342. références ci-dessous).</div>
  343. <div class="text-muted">
  344. NOTE: Cette version de Chamilo peut seulement être utilisée pour mettre à jour des versions antérieures de Chamilo ou de Dok€os.
  345. Par exemple vous ne pouvez pas utiliser les scripts de mise à jour normaux de Chamilo 1.11 pour effectuer une mise à jour depuis Dok€os 2.0 (dont la sortie est ultérieure à celle de la création de Chamilo).
  346. Si vous avez besoin de ce genre de choses, nous vous conseillons de contacter <a href="https://chamilo.org/providers">les fournisseurs officiels de l'Association Chamilo</a>)
  347. </div>
  348. <p></p>
  349. <h3>3.1 Mettre à jour depuis Chamilo 1.11.x (upgrade mineure)</h3>
  350. Comme cette version est une version mineure de Chamilo par rapport à une
  351. quelconque version 1.11.*, les seuls pas à suivre sont:
  352. <ul>
  353. <li>
  354. vérifier que vous n'avez pas créé une version modifiée d'une feuille de
  355. style en utilisant un répertoire css existant <span class="text-muted">(si c'est le cas, elle sera
  356. écrasée par la mise à jour. Gardez-en une copie que vous renommerez au
  357. moment de la replacer dans le répertoire main/css/)</span>
  358. </li>
  359. <li> téléchargez le paquet d'installation de Chamilo 1.11 depuis la
  360. <a href="http://www.chamilo.org/download">page de téléchargement de Chamilo</a></li>
  361. <li> dézippez les nouveaux fichiers de Chamilo 1.11 par dessus les fichiers de
  362. l'ancienne version (ou dézippez les fichiers dans un répertoire et copiez-les ensuite
  363. là où se trouve votre version actuelle de Chamilo)</li>
  364. <li> éditez le fichier app/config/configuration.php: à la fin du fichier,
  365. localisez le numéro de version antérieur (p.ex. '1.11.0') et remplacez-le
  366. par le numéro de la nouvelle version (p.ex. '1.11.2')</li>
  367. <li> Videz votre dossier archive/ : faites une copie temporaire de index.html, supprimez touss les contenus *dans* ce dossier (ne supprimer pas le dossier, juste ses contenus). Vous pouvez également vider ce dossier depuis le lien "Vidange du répertoire archive" du bloc "Système" de l'interface d'administration.</li>
  368. <li> fini! Il n'y a pas d'autre procédure requise</li>
  369. </ul>
  370. <br />
  371. <h3>3.2 Mettre à jour depuis Chamilo 1.9.x ou 1.10.x</h3>
  372. <ul>
  373. <li> assurez-vous qu'aucune table ne persiste d'une version antérieure de Chamilo. Ces tables peuvent en effet causer une erreur durant la mise à jour. En particulier, les tables des versions 1.8.* et antérieures pouvaient se répéter une fois par cours, résultant en un grand nombre de tables partageant le même préfixe. Seules les tables sans préfixe ou avec un préfixe "c_" sont légitimes dans les versions 1.9 et supérieures. Assurez-vous qu'aucune de ces anciennes tables ne persiste. Prenez une copie de sauvegarde de votre base de données (au cas où) puis supprimez-les (drop table ...).</li>
  374. <li> vérifiez que vous n'avez pas laissé de feuille de style personnalisée ou d'image <span class="text-muted">(le cas échant, faites-en une sauvegarde*)</span></li>
  375. <li> télécharger le paquet Chamilo 1.11 depuis la <a href="http://www.chamilo.org/download">page de téléchargement de Chamilo</a></li>
  376. <li> décompressez les nouveaux fichiers de Chamilo 1.11 sur les fichiers de votre ancienne installation (ou décompressez les dans un nouveau dossier et copier les fichiers extraits sur les anciens fichiers).</li>
  377. <li> vérifiez que le fichier .htaccess de la version 1.11 a bien été copié</li>
  378. <li> vérifiez que "AllowOverride All" est présent dans votre configuration Apache, car l'interprétation du fichier .htaccess est capitale pour le fonctionnement de Chamilo</li>
  379. <li> accéder à l'adresse de votre portail URL + main/install </li>
  380. <li> Choisissez votre langue et cliquez sur <span style="font-style: italic;">Mettre à jour depuis la version 1.8.x / 1.9.x</span></li>
  381. <li> Videz votre dossier archive/ : faites une copie temporaire de index.html, supprimez touss les contenus *dans* ce dossier (ne supprimer pas le dossier, juste ses contenus). Vous pouvez également vider ce dossier depuis le lien "Vidange du répertoire archive" du bloc "Système" de l'interface d'administration.</li>
  382. </ul>
  383. <br />
  384. <span class="text-muted">* Les styles et images se trouvent dans les répertoires main/css ou main/img.
  385. Vous pouvez les récupérer depuis la copie de sauvegarde (que vous n'avez pas manqué de prendre).
  386. Toute image ou style modifié qui utilise le nom de l'image/style par défaut sera
  387. écrasé lors de l'étape suivante. Pour éviter la perte de customisations, assurez-vous toujours
  388. de copier les styles/images sous un nouveau nom et de modifier la copie et non l'original.
  389. L'original sera toujours écrasé par la nouvelle version. Dans Dok€os 1.8.5, nous avons changé
  390. le nom de quelques thèmes CSS. La compatibilité descendante est assurée par le fait que la mise à
  391. jour ne fait qu'ajouter de nouveaux thèmes, mais essayez toujours d'utiliser de préférence les
  392. nouveaux thèmes plutot que se conserver d'anciennes versions qui ne seront plus maintenues.</span>
  393. <br />
  394. <p></p>
  395. <p>
  396. <b>ATTENTION:</b><br />
  397. Ne supprimez pas le précédent dossier d'installation de Chamilo avant d'avoir installé le nouveau.
  398. Quand la mise à jour sera terminée, les dossiers obsolètes devraient être automatiquement pris en charge.
  399. </p>
  400. <h3>3.3 Mettre à jour depuis Chamilo 1.8.x</h3>
  401. Pour mettre à jour depuis une version antérieure à la 1.9.0, vous devrez commencer par la mettre à jour vers la version 1.9.10.x,
  402. et seulement alors mettre à jours vers la 1.11.x.
  403. Vous pouvez trouver une version téléchargeable de 1.9.10.x ici: <a href="https://github.com/chamilo/chamilo-lms/releases">https://github.com/chamilo/chamilo-lms/releases</a>
  404. <p></p>
  405. <h3>3.4 Dans les deux derniers cas</h3>
  406. Les répertoires suivants doivent être accessibles en lecture, écriture et
  407. exécution pour le serveur web:
  408. <ul>
  409. <li>[chamilo]/main/lang/ (pour supprimer les fichiers de langues inutiles)</li>
  410. <li>[chamilo]/courses/ (pour déplacer les cours dans le dossier app/courses)</li>
  411. <li>[chamilo]/archive/ (pour supprimer les fichiers inutiles ou les déplacer dans app/cache/)</li>
  412. <li>[chamilo]/home/ (pour déplacer les fichiers dans app/home)</li>
  413. <li>[chamilo]/app</li>
  414. <li>[chamilo]/web</li>
  415. <li>[chamilo]/vendor</li>
  416. <li>[chamilo]/main/default_course_document/images/</li>
  417. </ul>
  418. On Linux, Mac OS X and BSD operating systems you can quick-fix this using the
  419. <em>chmod 0777</em> command, but if you are unsure, we recommend you seek advice for
  420. your own OS on <a href="https://www.chamilo.org/forum">our forum</a>.
  421. In Windows, you may need to check the properties of the folders.
  422. <p></p>
  423. <hr style="width: 100%; height: 2px;" />
  424. <h2><a name="4._Troubleshooting"></a>4. Problèmes</h2>
  425. <p>If you have&nbsp;problems, go to the <a href="https://chamilo.org">Chamilo website</a> and ask a question on the
  426. <a href="https://chamilo.forum">support forum</a>. Please read the previous messages first to see if there is
  427. already an answer to your question.</p>
  428. <h2></h2>
  429. <hr style="width: 100%; height: 2px;" />
  430. <h2><a name="5._Administration_section"></a>5. Section d'administration</h2>
  431. <p>Pour accéder à la section d'administration, ouvrez un navigateur, chargez l'adresse de votre Chamilo
  432. et connectez-vous avec l'utilisateur administrateur.
  433. Vous verrez alors un onglet "Administration" dans le menu principal.
  434. Vous pouvez y gérer les utilisateurs, les cours, les sessions et
  435. l'apparence de votre site</p>
  436. <p></p>
  437. <hr style="width: 100%; height: 2px;" />
  438. <h2><a name="6._LDAP"></a>6. LDAP</h2>
  439. <p>
  440. <i>This part is optional, only organisations with an LDAP server will need to read this.</i><br />
  441. An LDAP module is already provided in Chamilo, but it has to be configured to make it work.</p>
  442. <h3><b>Compiler</b></h3>
  443. <p>
  444. Linux servers: It's possible that you have to recompile php with ldap support.
  445. Newer distributions also allow downloading rpms for additional packages.</p>
  446. <h3><b>Activer LDAP dans Chamilo</b></h3>
  447. <p class="text-muted">
  448. Note: Vérifiez la configuration LDAP dans Chamilo pour voir le détail
  449. </p>
  450. <p>
  451. In [Chamilo folder]/app/config/configuration.php, around line 93, you'll find settings like the following: <br />
  452. // -> Uncomment the two lines below to activate LDAP AND edit main/inc/conf/auth.conf.php for configuration<br />
  453. // $extAuthSource["extldap"]["login"] = $_configuration['root_sys'].$_configuration['code_append']."auth/external_login/login.ldap.php";<br />
  454. // $extAuthSource["extldap"]["newUser"] = $_configuration['root_sys'].$_configuration['code_append']."auth/external_login/newUser.ldap.php";<br />
  455. <br />
  456. remove the // from the last two lines to activate LDAP.<br />
  457. </p>
  458. <h3><b>Settings</b></h3>
  459. <p>
  460. Ask the LDAP server admin for the settings:</p>
  461. <ul>
  462. <li>ldap server name</li>
  463. <li>ldap server port (usually 389)</li>
  464. <li>ldap dc</li>
  465. </ul>
  466. Since 1.8.5, you have to change the LDAP settings inside the "Portal
  467. administration" panel, under "Chamilo configuration settings", section
  468. "LDAP".
  469. <br />
  470. As an example, you should find the following kind of values:<br />
  471. LDAP main server's address: "myldapserver.com"; // your ldap server<br />
  472. LDAP main server's port: 389; // your ldap server's port number<br />
  473. LDAP domain: "dc=xx, dc=yy, dc=zz"; //domain<br />
  474. <br />
  475. <h3><b>Teacher/student status</b></h3>
  476. <p>
  477. By default, Chamilo will check if the "employeenumber" field has a value. If it has, then Chamilo will
  478. consider this user as being a teacher.<br />
  479. If you want to change this behaviour, you can edit main/auth/ldap/authldap.php, function ldap_put_user_info_locally(),
  480. and change the <em>if (empty($info_array[$tutor_field]))</em> condition to whatever suits you.<br />
  481. You can also remove this check by removing the condition and leaving only the <em>$status = STUDENT;</em> line.</p>
  482. <h3><b>Protected LDAP servers</b></h3>
  483. <p>
  484. Some LDAP servers do not support anonymous use of the directory services.<br />
  485. In this case, you should fill in the appropriate fields in the
  486. administration panel (e.g. "manager" and "mypassword") and Chamilo will
  487. try to authenticate using these, or fall back to anonymous mode before
  488. giving up.</p>
  489. <h3>LDAP import into sessions</h3>
  490. <p>There is a new set of scripts now that allow you to insert users
  491. from LDAP directly into a Chamilo session. This, however, relies on a
  492. set of static choices in the LDAP contact attributes.<br />
  493. The fields used intensively by the Chamlio module are:<br />
  494. </p>
  495. <ul>
  496. <li>uid, which is matched to the username in Chamilo</li>
  497. <li>userPassword, which is matched to the user password, although
  498. this part will only work for non-encrypted passwords for now, but it
  499. shouldn't be necessary if using the LDAP server as authentication</li>
  500. <li>ou should end with the year of the person registration or any
  501. criteria you will use to filter users, so that they can be retrieved on
  502. that criteria</li>
  503. <li>sn is used as the lastname field in Chamilo</li>
  504. <li>givenName is used as the firstname field in Chamilo</li>
  505. <li>mail is used as the email field in Chamilo</li>
  506. </ul>
  507. <hr style="width: 100%; height: 2px;" />
  508. <h2><a name="9._WIRIS_mathematical_formulas"></a>9. Formules mathématiques avec WIRIS</h2>
  509. <p>Installing this plugin you get WIRIS editor and WIRIS CAS. <br/>
  510. This activation will not be completed unless you have previously downloaded the <a href="http://www.wiris.com/plugins/ckeditor/download" target="_blank">PHP plugin for CKeditor WIRIS</a> and unzipped its contents into the main/inc/lib/ckeditor/editor/plugins/ckeditor_wiris/ directory. <br/>This is necessary because Wiris is proprietary software and its services are <a href="http://www.wiris.com/store/who-pays" target="_blank">commercial</a>. To make adjustments to the plugin, edit configuration.ini file or replace his content by configuration.ini.default Chamilo file.</p>
  511. <hr style="width: 100%; height: 2px;" />
  512. <h2><a name="10._Xapian_fulltext_indexing"></a>Indexation full-text avec Xapian</h2>
  513. <div>
  514. <em>Note</em>: This step will require a dedicated server or a virtual dedicated server as the packages involved are not available on most shared hosting solutions.<br />
  515. On Debian or Ubuntu 10.04 and superior, you will simply need to install the php5-xapian package and restart your web server:
  516. <pre>
  517. sudo apt-get install php5-xapian
  518. sudo /etc/init.d/apache2 restart
  519. </pre>
  520. Then go to your administration page -&gt; Configuration settings -&gt; Search
  521. and enable the search tool. Follow the recommendations on the page to get the
  522. complete indexing suite installed. Once you're done, all documents you import
  523. into your Chamilo portal in a recognized format will be indexed and searchable.
  524. Chamilo Administrators training (which you can ask any <a href="http://www.chamilo.org/en/providers">Chamilo's Official
  525. Provider</a> for) include a full review of the full-text search feature.
  526. </div>
  527. <p class="text-muted">
  528. Note: Xapian's licensing for the PHP extension is a bit different than what is necessary to enter the Debian repositories, so it has been excluded. You can, however, generate your own package by following the <a href="http://trac.xapian.org/wiki/FAQ/PHP%20Bindings%20Package">packaging instructions on Xapian's wiki</a>.
  529. </p>
  530. <hr style="width: 100%; height: 2px;" />
  531. <h2><a name="11._Chamilo_rapid_ppt_conversion"></a>Chamilo Rapide - Conversion de PPT</h2>
  532. <div>
  533. <em>Note</em>: This step will require a dedicated server or a virtual dedicated server as the packages involved are not available on most shared hosting solutions.<br />
  534. On Debian or Ubuntu 11.10 and superior, install LibreOffice.org v3 and start it as a headless server:
  535. <pre>
  536. sudo apt-get install libreoffice
  537. sudo soffice -accept="socket,host=127.0.0.1,port=2002,tcpNoDelay=1;urp;" -headless -nodefault -nofirststartwizard -nolockcheck -nologo -norestore &amp;
  538. </pre>
  539. Then go to your administration page -&gt; <i>Chamilo Rapid</i> and set the host to "localhost" and the port to "2002". Save. Go to your course, learning path tool and see the new icon appeared. Import your PPT. This should work.
  540. <em>Note</em>: Sometimes, this doesn't work out so easily. You can probably ask for the assistance of any system administrator around with a bit of Java and PHP experience, or you can always ask one of the Chamilo's Official Providers for assistance (ask for a guaranteed commercial contract).
  541. </div>
  542. <hr style="width: 100%; height: 2px;" />
  543. <h2><a name="12._Setting_cron_up"></a>Configurer les tâches chronologiques</h2>
  544. <p>
  545. Since Chamilo 1.8.8, a few tasks need to be executed regularly in order to get
  546. the best out of your server resources. One of such tasks (and the only one
  547. around at the time of Chamilo 1.8.8) is the sending of internal messaging
  548. notifications by e-mail, i.e. when you receive an e-mail from another person or
  549. from a group inside the internal messaging system of Chamilo, if all e-mails are
  550. sent immediately, then you might not have the chance to receive them at your
  551. pace, once a day or even once a week. For cases like this you, as a Chamilo
  552. administrator, should setup a cron process on the server to check the queue of
  553. e-mails and send is timely.</p>
  554. <div>
  555. Setting up a cron task is easy and there are several ways to do it. We recommend
  556. you have a look at the <a href="http://drupal.org/cron">Drupal documentation
  557. for setting up cron</a> and define your own cron process as:
  558. <pre>
  559. 35 * * * * wget -O - -q -t 1 http://campus.example.com/main/cron/run.php
  560. </pre>
  561. Make sure you have a look into run.php as maybe you want to change a few
  562. settings there.
  563. </div>
  564. <hr style="width: 100%; height: 2px;" />
  565. <h2><a name="13._Changing_language_names_order"></a>Changer l'ordre nom/prénom des langues</h2>
  566. <div>
  567. As Chamilo becomes more popular and crosses many borders now, it frequently happens that administrators want to re-order the firstname and lastname fields in tables, and also on which field it is sorted first.<br/><br />
  568. This can easily be modified by editing the app/config/configuration.php file, finding the following section, uncommenting the PHP lines and adapting it to your language:<br />
  569. <pre>// Custom name_order_conventions
  570. //$_configuration['name_order_conventions'] = array(
  571. // 'french' => array('format' => 'title last_name first_name', 'sort_by' => 'last_name')
  572. //);</pre><br />
  573. Feel free to change this to<br />
  574. <pre>// Custom name_order_conventions
  575. $_configuration['name_order_conventions'] = array(
  576. 'french' => array('format' => 'first_name last_name', 'sort_by' => 'last_name')
  577. );</pre><br />
  578. for example. The effect should be immediate.
  579. </div>
  580. Please note that, although Chamilo allows you to define its position, the "title" field does not exist at this time, so no need to worry about it.
  581. <hr style="width: 100%; height: 2px;" />
  582. <h2><a name="14._Improving_files_download"></a>Améliorer la performance des téléchargements de fichiers</h2>
  583. <div>
  584. File download can be very slow when passing through a PHP script to control permissions. One solution to this
  585. is to use the X-Sendfile header, which depends on a module on the webserver. <a href="http://stackoverflow.com/a/3731639/1406662">Check http://stackoverflow.com/a/3731639/1406662 for more details on implementing Sendfile</a>.
  586. Chamilo LMS 1.9.8 (and following versions) supports the X-Sendfile headers, but requires a specific line of configuration to be
  587. added to configuration.php:
  588. <pre>
  589. $_configuration['enable_x_sendfile_headers'] = true;
  590. </pre>
  591. If you have issues with files taking a long time to download, make sure you reconfigure your webserver and add this line. You should see an notable difference in download time.
  592. </div>
  593. <hr style="width: 100%; height: 2px;" />
  594. <h2><a name="15._Videoconference"></a>Vidéo-conférence</h2>
  595. <p>
  596. Chamilo supporte la connexion à deux serveurs de vidéo-conférence : BigBlueButton (versions 0.81 et 0.9) et OpenMeetings.<br />
  597. Tandis que BigBlueButton paraît plus simple d'installation, plus clairement documenté et plus
  598. abouti esthétiquement, certains utilisateurs ont attesté que OpenMeetings consomme moins
  599. de bande passante, est moins restrictif en termes d'environnement et offre plus d'outils
  600. et de connecteurs.<br />
  601. La décision vous revient, mais dans chaque cas vous aurez à installer un serveur de vidéo-conférence
  602. en plus du processus d'installation normal de Chamilo.<br />
  603. Consultez le <a href="http://docs.bigbluebutton.org/install/install.html">guide d'installation de BigBlueButton</a>
  604. Une fois celui-ci installé, entrez la commande "bbb-conf --secret" pour obtenir les paramètres à indiquer dans le plugin
  605. "Vidéo-conférence" de Chamilo (page Paramètres de configuration).<br />
  606. Une icône "Vidéo-conférence" devrait alors apparaître dans chaque cours.<br />
  607. </p>
  608. <hr style="width: 100%; height: 2px;" />
  609. <h2><a name="16._Rewrite"></a>Réécriture</h2>
  610. <p>
  611. Chamilo LMS 1.10 est la première version nécessitant que le serveur web autorise les redirections d'url (et donc 1.11 également).<br />
  612. Pour Apache, il s'agit d'active le module rewrite et d'autoriser l'utilisation des fichiers .htaccess ou d'ajouter une section spécifique dans le Virtual Host.<br />
  613. Pour Nginx, il s'agit de définir les règles de redirections dans le Virtual Host.<br /><br />
  614. Pour être certain que c'est à la portée de tous, nous recommandons le fichier de configuration ci-dessous pour vous aider dans les deux cas.
  615. Notez que l'utilisation d'un fichier .htaccess est la solution la plus facile mais peut altérer les performances de votre serveur,
  616. car les fichiers .htaccess sont interprêtés à *chaque* requête, alors qu'une section de configuration supplémentaire dans le Virtual Host
  617. est compilée uniquement lors du chargement du serveur.
  618. <h3>Apache + .htaccess</h3>
  619. <div>
  620. Pour activer le .htaccess dans Apache, vous devez juste vérifier une chose : dans un tag &lt;Directory&gt; du dossier racine de Chamilo, vérifiez que les lignes suivantes sont présentes :
  621. <pre>
  622. AllowOverride All
  623. Order allow,deny
  624. allow from all
  625. </pre>
  626. ou, si vous travaillez avec Apache 2.4, la syntaxe est légèrement différente et ressemble plutôt à ça :
  627. <pre>
  628. AllowOverride All
  629. Require all granted
  630. </pre>
  631. </div>
  632. <h3>Apache RewriteRules</h3>
  633. <pre>
  634. &lt;LocationMatch "/.git*"&gt;
  635. order deny,allow
  636. deny from all
  637. &lt;/LocationMatch&gt;
  638. &lt;Directory ~/.&gt;
  639. AllowOverride None
  640. Options -Indexes
  641. &lt;/Directory&gt;
  642. &lt;Directory "/var/www/chamilo"&gt;
  643. RewriteEngine On
  644. RewriteCond %{QUERY_STRING} ^id=(.*)$
  645. RewriteRule ^certificates/$ certificates/index.php?id=%1 [L]
  646. RewriteRule ^courses/([^/]+)/?$ main/course_home/course_home.php?cDir=$1 [QSA,L]
  647. RewriteRule ^courses/([^/]+)/index.php$ main/course_home/course_home.php?cDir=$1 [QSA,L]
  648. RewriteRule ^courses/([^/]+)/scorm/(.*([\.js|\.css|\.png|\.jpg|\.jpeg|\.gif]))$ app/courses/$1/scorm/$2 [QSA,L]
  649. RewriteRule ^courses/([^/]+)/scorm/(.*)$ main/document/download_scorm.php?doc_url=/$2&cDir=$1 [QSA,L]
  650. RewriteRule ^courses/([^/]+)/document/certificates/(.*)$ app/courses/$1/document/certificates/$2 [QSA,L]
  651. RewriteRule ^courses/([^/]+)/document/(.*)$ main/document/download.php?doc_url=/$2&cDir=$1 [QSA,L]
  652. RewriteRule ^courses/([^/]+)/upload/course_home_icons/(.*([\.js|\.css|\.png|\.jpg|\.jpeg|\.gif]))$ app/courses/$1/upload/course_home_icons/$2 [QSA,L]
  653. RewriteRule ^courses/([^/]+)/upload/([^/]+)/(.*)$ main/document/download_uploaded_files.php?code=$1&type=$2&file=$3 [QSA,L]
  654. RewriteRule ^courses/([^/]+)/work/(.*)$ main/work/download.php?file=work/$2&cDir=$1 [QSA,L]
  655. RewriteRule ^courses/([^/]+)/course-pic85x85.png$ main/inc/ajax/course.ajax.php?a=get_course_image&code=$1&image=course_image_source [QSA,L]
  656. RewriteRule ^courses/([^/]+)/course-pic.png$ main/inc/ajax/course.ajax.php?a=get_course_image&code=$1&image=course_image_large_source [QSA,L]
  657. RewriteRule ^courses/([^/]+)/(.*)$ app/courses/$1/$2 [QSA,L]
  658. RewriteRule ^session/(\d{1,})/about/?$ main/session/about.php?session_id=$1 [L]
  659. RewriteRule ^course/(\d{1,})/about/?$ main/course_info/about.php?course_id=$1 [L]
  660. RewriteRule ^badge/(\d{1,}) main/badge/issued.php?issue=$1 [L]
  661. RewriteRule ^skill/(\d{1,})/user/(\d{1,}) main/badge/issued_all.php?skill=$1&user=$2 [L]
  662. RewriteRule ^badge/(\d{1,})/user/(\d{1,}) main/badge/issued_all.php?skill=$1&user=$2 [L]
  663. RewriteRule ^main/exercice/(.*)$ main/exercise/$1 [QSA,L]
  664. RewriteRule ^main/newscorm/(.*)$ main/lp/$1 [QSA,L]
  665. RewriteRule ^service/(\d{1,})$ plugin/buycourses/src/service_information.php?service_id=$1 [L]
  666. RewriteRule ^lti/os$ plugin/ims_lti/outcome_service.php [L]
  667. RewriteRule ^([^/.]+)/?$ user.php?$1 [L]
  668. RewriteRule ^(tests|.git) - [F,L,NC]
  669. &lt;/Directory&gt;
  670. </pre>
  671. <h3>Nginx</h3>
  672. Nginx ne supporte pas les règles .htaccess, donc vous n'avez pas d'autre option que d'appliquer les règles suivantes (notez que la configuration PHP peut changer).
  673. Ce sont uniquement les redirections à placer dans un bloc server{}, comme les autres valeurs peuvent changer d'une installation à l'autre.
  674. <pre>
  675. # Add your own "server {" header here with listen, server_name, access_log, error_log, index, root and error_page params
  676. charset utf-8;
  677. location @rewrite{
  678. rewrite ^certificates/$ certificates/index.php last;
  679. rewrite ^/courses/([^/]+)/$ /main/course_home/course_home.php?cDir=$1 last;
  680. rewrite ^/courses/([^/]+)/index.php$ /main/course_home/course_home.php?cDir=$1 last;
  681. rewrite ^/courses/([^/]+)/scorm/(.*)$ /main/document/download_scorm.php?doc_url=/$2&cDir=$1 last;
  682. # Alternatively, you can choose to give direct access to all SCORM files, which is much faster but less secure
  683. # rewrite "^/courses/([^/]+)/scorm/(.*)$" /app/courses/$1/scorm/$2 break;
  684. rewrite "^/courses/([^/]+)/document/certificates/(.*)$" /app/courses/$1/document/certificates/$2 last;
  685. rewrite ^/courses/([^/]+)/document/(.*)$ /main/document/download.php?doc_url=/$2&cDir=$1 last;
  686. rewrite ^/courses/([^/]+)/upload/([^/]+)/(.*)$ /main/document/download_uploaded_files.php?code=$1&type=$2&file=$3 last;
  687. rewrite ^/courses/([^/]+)/work/(.*)$ /main/work/download.php?file=work/$2&cDir=$1 last;
  688. rewrite ^/courses/([^/]+)/(.*)$ /app/courses/$1/$2 last;
  689. rewrite ^/session/([^/]+)/about/?$ /main/session/about.php?session_id=$1 last;
  690. rewrite ^/badge/(\d+) /main/badge/issued.php?issue=$1 last;
  691. rewrite ^/skill/(\d+)/user/(\d+)$ /main/badge/issued_all.php?skill=$1&user=$2 last;
  692. rewrite ^/badge/(\d+)/user/(\d+)$ /main/badge/issued_all.php?skill=$1&user=$2 last;
  693. rewrite ^/main/exercice/(.*)$ /main/exercise/$1 last;
  694. rewrite ^/main/newscorm/(.*)$ /main/lp/$1 last;
  695. rewrite ^/service/(\d+)$ /plugin/buycourses/src/service_information.php?service_id=$1 last;
  696. rewrite "^/main/upload/users/(.*)/(.*)/my_files/(.*)$" /app/upload/users/$1/$2/my_files/$3 last;
  697. try_files $uri /index.php$is_args$args;
  698. break;
  699. }
  700. location / {
  701. rewrite ^/courses/([^/]+)/$ /main/course_home/course_home.php?cDir=$1 last;
  702. rewrite ^/courses/([^/]+)/index.php$ /main/course_home/course_home.php?cDir=$1 last;
  703. rewrite ^/skill/(\d+)/user/(\d+)$ /main/badge/issued_all.php?skill=$1&user=$2 last;
  704. rewrite ^/badge/(\d+)/user/(\d+)$ /main/badge/issued_all.php?skill=$1&user=$2 last;
  705. try_files $uri @rewrite;
  706. }
  707. location /main {
  708. rewrite ^/main/admin/$ /main/admin/index.php last;
  709. }
  710. location ~ \.php$ {
  711. client_max_body_size 20M;
  712. try_files $uri /index.php$is_args$args;
  713. rewrite ^/certificates/$ /certificates/index.php?id=%1 last;
  714. rewrite ^/courses/([^/]+)/$ /main/course_home/course_home.php?cDir=$1 last;
  715. rewrite ^/courses/([^/]+)/index.php$ /main/course_home/course_home.php?cDir=$1 last;
  716. rewrite ^/session/([^/]+)/about/?$ /main/session/about.php?session_id=$1 last;
  717. rewrite ^/badge/([^/]+) /main/badge/issued.php?issue=$1 last;
  718. rewrite ^/main/exercice/(.+)$ /main/exercise/$1 last;
  719. rewrite ^/main/newscorm/(.+)$ /main/lp/$1 last;
  720. fastcgi_pass unix:/var/run/php5-fpm.sock;
  721. fastcgi_split_path_info ^(.+\.php)(/.*)$;
  722. include fastcgi_params;
  723. fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
  724. fastcgi_param HTTPS off;
  725. }
  726. # Serve static files directly
  727. location ~* \.(png|jpe?g|gif|ico|js|css|mp3|swf|flv|mp4|ogg)$ {
  728. expires 1y;
  729. access_log off;
  730. rewrite ^/courses/([^/]+)/course-pic85x85.png$ /app/courses/$1/course-pic85x85.png last;
  731. rewrite ^/courses/([^/]+)/course-pic.png$ /app/courses/$1/course-pic.png last;
  732. rewrite ^/courses/([^/]+)/scorm/(.*)$ /main/document/download_scorm.php?doc_url=/$2&cDir=$1 last;
  733. rewrite ^/courses/([^/]+)/document/(.*)$ /main/document/download.php?doc_url=/$2&cDir=$1 last;
  734. rewrite ^/courses/([^/]+)/work/(.*)$ /main/work/download.php?file=work/$2&cDir=$1 last;
  735. rewrite ^/courses/([^/]+)/upload/(.*)$ /app/courses/$1/upload/$2 last;
  736. # For all these media resources not treated by previous rewrites, give direct access (no permission check)
  737. rewrite ^/courses/(.*)$ /app/courses/$1 break;
  738. try_files $uri @rewrite;
  739. }
  740. location ~ ~\.(ht|git){
  741. deny all;
  742. }
  743. location ^~ /tests/ {
  744. deny all;
  745. }
  746. </pre>
  747. <h3>IIS</h3>
  748. <div>
  749. L'utilisateur @ullfindsmit sur Github a été bien aimable en nous partageant la configuration suivante
  750. pour IIS, qu'il a testé au préalable. Ces règles sont basées sur les configurations ci-dessus et, bien
  751. que nous n'ayons pas testé la configuration nous-même, elle est suffisamment proche de la configuration
  752. d'Apache et de Nginx pour nous permettre de vous la suggérer ici:<br /><br />
  753. <pre>
  754. &lt;?xml version="1.0" encoding="UTF-8"?&gt;
  755. &lt;configuration&gt;
  756. &lt;system.webServer&gt;
  757. &lt;rewrite&gt;
  758. &lt;rules&gt;
  759. &lt;rule name="rule 1v" stopProcessing="true"&gt;
  760. &lt;match url="^certificates/$" /&gt;
  761. &lt;action type="Rewrite" url="/certificates/index.php?id=%1" /&gt;
  762. &lt;/rule&gt;
  763. &lt;rule name="rule 2v" stopProcessing="true"&gt;
  764. &lt;match url="^courses/([^/]+)/?$" /&gt;
  765. &lt;action type="Rewrite" url="/main/course_home/course_home.php?cDir={R:1}" appendQueryString="true" /&gt;
  766. &lt;/rule&gt;
  767. &lt;rule name="rule 3v" stopProcessing="true"&gt;
  768. &lt;match url="^courses/([^/]+)/index.php$" /&gt;
  769. &lt;action type="Rewrite" url="/main/course_home/course_home.php?cDir={R:1}" appendQueryString="true" /&gt;
  770. &lt;/rule&gt;
  771. &lt;rule name="rule 4v" stopProcessing="true"&gt;
  772. &lt;match url="^courses/([^/]+)/scorm/(.*)$" /&gt;
  773. &lt;action type="Rewrite" url="/main/document/download_scorm.php?doc_url=/{R:2}&amp;cDir={R:1}" appendQueryString="true" /&gt;
  774. &lt;/rule&gt;
  775. &lt;rule name="rule 5v" stopProcessing="true"&gt;
  776. &lt;match url="^courses/([^/]+)/document/certificates/(.*)$" /&gt;
  777. &lt;action type="Rewrite" url="/app/courses/{R:1}/document/certificates/{R:2}" appendQueryString="true" /&gt;
  778. &lt;/rule&gt;
  779. &lt;rule name="rule 6v" stopProcessing="true"&gt;
  780. &lt;match url="^courses/([^/]+)/document/(.*)$" /&gt;
  781. &lt;action type="Rewrite" url="/main/document/download.php?doc_url=/{R:2}&amp;cDir={R:1}" appendQueryString="true" /&gt;
  782. &lt;/rule&gt;
  783. &lt;rule name="rule 7v" stopProcessing="true"&gt;
  784. &lt;match url="^courses/([^/]+)/upload/([^/]+)/(.*)$" /&gt;
  785. &lt;action type="Rewrite" url="/main/document/download_uploaded_files.php?code={R:1}&amp;type={R:2}&amp;file={R:3}" appendQueryString="true" /&gt;
  786. &lt;/rule&gt;
  787. &lt;rule name="rule 8v" stopProcessing="true"&gt;
  788. &lt;match url="^courses/([^/]+)/work/(.*)$" /&gt;
  789. &lt;action type="Rewrite" url="/main/work/download.php?file=work/{R:2}&amp;cDir={R:1}" appendQueryString="true" /&gt;
  790. &lt;/rule&gt;
  791. &lt;rule name="rule 9v" stopProcessing="true"&gt;
  792. &lt;match url="^courses/([^/]+)/course-pic85x85.png$" /&gt;
  793. &lt;action type="Rewrite" url="/main/inc/ajax/course.ajax.php?a=get_course_image&amp;code={R:1}&amp;image=course_image_source" appendQueryString="true" /&gt;
  794. &lt;/rule&gt;
  795. &lt;rule name="rule 10v" stopProcessing="true"&gt;
  796. &lt;match url="^courses/([^/]+)/course-pic.png$" /&gt;
  797. &lt;action type="Rewrite" url="/main/inc/ajax/course.ajax.php?a=get_course_image&amp;code={R:1}&amp;image=course_image_large_source" appendQueryString="true" /&gt;
  798. &lt;/rule&gt;
  799. &lt;rule name="rule 11v" stopProcessing="true"&gt;
  800. &lt;match url="^courses/([^/]+)/(.*)$" /&gt;
  801. &lt;action type="Rewrite" url="/app/courses/{R:1}/{R:2}" appendQueryString="true" /&gt;
  802. &lt;/rule&gt;
  803. &lt;rule name="rule 12v" stopProcessing="true"&gt;
  804. &lt;match url="^session/(\d{1,})/about/?$" /&gt;
  805. &lt;action type="Rewrite" url="/main/session/about.php?session_id={R:1}" /&gt;
  806. &lt;/rule&gt;
  807. &lt;rule name="rule 13v" stopProcessing="true"&gt;
  808. &lt;match url="^badge/(\d{1,})" /&gt;
  809. &lt;action type="Rewrite" url="/main/badge/issued.php?issue={R:1}" /&gt;
  810. &lt;/rule&gt;
  811. &lt;rule name="rule 14v" stopProcessing="true"&gt;
  812. &lt;match url="^skill/(\d{1,})/user/(\d{1,})" /&gt;
  813. &lt;action type="Rewrite" url="/main/badge/issued_all.php?skill={R:1}&amp;user={R:2}" /&gt;
  814. &lt;/rule&gt;
  815. &lt;rule name="rule 15v" stopProcessing="true"&gt;
  816. &lt;match url="^badge/(\d{1,})/user/(\d{1,})" /&gt;
  817. &lt;action type="Rewrite" url="/main/badge/issued_all.php?skill={R:1}&amp;user={R:2}" /&gt;
  818. &lt;/rule&gt;
  819. &lt;rule name="rule 16v" stopProcessing="true"&gt;
  820. &lt;match url="^main/exercice/(.*)$" /&gt;
  821. &lt;action type="Rewrite" url="/main/exercise/{R:1}" appendQueryString="true" /&gt;
  822. &lt;/rule&gt;
  823. &lt;rule name="rule 17v" stopProcessing="true"&gt;
  824. &lt;match url="^main/newscorm/(.*)$" /&gt;
  825. &lt;action type="Rewrite" url="/main/lp/{R:1}" appendQueryString="true" /&gt;
  826. &lt;/rule&gt;
  827. &lt;rule name="rule 18v" stopProcessing="true"&gt;
  828. &lt;match url="^service/(\d{1,})$" /&gt;
  829. &lt;action type="Rewrite" url="/plugin/buycourses/src/service_information.php?service_id={R:1}" /&gt;
  830. &lt;/rule&gt;
  831. &lt;rule name="rule 19v" stopProcessing="true"&gt;
  832. &lt;match url="^([^/.]+)/?$" /&gt;
  833. &lt;action type="Rewrite" url="/user.php?{R:1}" /&gt;
  834. &lt;/rule&gt;
  835. &lt;rule name="rule 20v" stopProcessing="true"&gt;
  836. &lt;match url="^(tests|.git)" ignoreCase="true" /&gt;
  837. &lt;action type="Rewrite" url="/-" /&gt;
  838. &lt;/rule&gt;
  839. &lt;/rules&gt;
  840. &lt;/rewrite&gt;
  841. &lt;/system.webServer&gt;
  842. &lt;/configuration&gt;
  843. </pre>
  844. </div>
  845. <hr style="width: 100%; height: 2px;" />
  846. <p>
  847. <br />
  848. <br />
  849. Adresse de contact<br />
  850. Mail: info@chamilo.org<br />
  851. <br />
  852. </p>
  853. <hr />
  854. </div>
  855. <hr />
  856. <a href="http://validator.w3.org/check?uri=referer"><img src="//www.w3.org/Icons/valid-xhtml10-blue" alt="Valid XHTML 1.0 Transitional" style="margin: 1em; float: right;" height="31" width="88" /></a>
  857. <a href="http://jigsaw.w3.org/css-validator/">
  858. <img src="//jigsaw.w3.org/css-validator/images/vcss-blue" style="margin: 1em; float: right;" alt="Valid CSS" />
  859. </a>
  860. </body>
  861. </html>