|
|
|
# Check that your Apache virtualhost have this settings:
|
|
|
|
|
|
|
|
#<Directory "/var/www/chamilo-classic">
|
|
|
|
# AllowOverride All
|
|
|
|
# Order allow,deny
|
|
|
|
# Allow from all
|
|
|
|
#</Directory>
|
|
|
|
|
|
|
|
RewriteEngine on
|
|
|
|
|
|
|
|
# Disables access to myfile.php/something
|
|
|
|
AcceptPathInfo Off
|
|
|
|
|
|
|
|
# Prevent execution of PHP from directories used for different types of uploads
|
|
|
|
RedirectMatch 403 ^/app/(?!courses/proxy)(cache|courses|home|logs|upload|Resources/public/css)/.*\.ph(p[3457]?|t|tml|ar)$
|
|
|
|
RedirectMatch 403 ^/main/default_course_document/images/.*\.ph(p[3457]?|t|tml|ar)$
|
|
|
|
RedirectMatch 403 ^/main/lang/.*\.ph(p[3457]?|t|tml|ar)$
|
|
|
|
RedirectMatch 403 ^/web/.*\.ph(p[3457]?|t|tml|ar)$
|
|
|
|
RedirectMatch 403 ^/app/config/.*\.yml(\.dist)?$
|
|
|
|
|
|
|
|
# http://my.chamilo.net/certificates/?id=123 to http://my.chamilo.net/certificates/index.php?id=123
|
|
|
|
RewriteCond %{QUERY_STRING} ^id=(.*)$
|
|
|
|
RewriteRule ^certificates/$ certificates/index.php?id=%1 [L]
|
|
|
|
|
|
|
|
# Course redirection
|
|
|
|
RewriteRule ^courses/([^/]+)/?$ main/course_home/course_home.php?cDir=$1 [QSA,L]
|
|
|
|
RewriteRule ^courses/([^/]+)/index.php$ main/course_home/course_home.php?cDir=$1 [QSA,L]
|
|
|
|
|
|
|
|
# Rewrite everything in the scorm folder of a course to the download script
|
|
|
|
# except JS, CSS and some image files, which can be served directly
|
|
|
|
RewriteRule ^courses/([^/]+)/scorm/(.*([\.js|\.css|\.png|\.jpg|\.jpeg|\.gif]))$ app/courses/$1/scorm/$2 [QSA,L]
|
|
|
|
RewriteRule ^courses/([^/]+)/scorm/(.*)$ main/document/download_scorm.php?doc_url=/$2&cDir=$1 [QSA,L]
|
|
|
|
|
|
|
|
# Rewrite everything in the document folder of a course to the download script
|
|
|
|
# Except certificate resources, which might need to be accessible publicly to all
|
|
|
|
RewriteRule ^courses/([^/]+)/document/certificates/(.*)$ app/courses/$1/document/certificates/$2 [QSA,L]
|
|
|
|
RewriteRule ^courses/([^/]+)/document/(.*)$ main/document/download.php?doc_url=/$2&cDir=$1 [QSA,L]
|
|
|
|
|
|
|
|
# Optimize load of custom per-course icons in courses (avoid download_uploaded_files.php)
|
|
|
|
RewriteRule ^courses/([^/]+)/upload/course_home_icons/(.*([\.js|\.css|\.png|\.jpg|\.jpeg|\.gif]))$ app/courses/$1/upload/course_home_icons/$2 [QSA,L]
|
|
|
|
# Course upload files
|
|
|
|
RewriteRule ^courses/([^/]+)/upload/([^/]+)/(.*)$ main/document/download_uploaded_files.php?code=$1&type=$2&file=$3 [QSA,L]
|
|
|
|
|
|
|
|
# Rewrite everything in the work folder
|
|
|
|
RewriteRule ^courses/([^/]+)/work/(.*)$ main/work/download.php?file=work/$2&cDir=$1 [QSA,L]
|
|
|
|
|
|
|
|
RewriteRule ^courses/([^/]+)/course-pic85x85.png$ main/inc/ajax/course.ajax.php?a=get_course_image&code=$1&image=course_image_source [QSA,L]
|
|
|
|
RewriteRule ^courses/([^/]+)/course-pic.png$ main/inc/ajax/course.ajax.php?a=get_course_image&code=$1&image=course_image_large_source [QSA,L]
|
|
|
|
RewriteRule ^courses/([^/]+)/course-email-pic-cropped.png$ main/inc/ajax/course.ajax.php?a=get_course_image&code=$1&image=course_email_image_source [QSA,L]
|
|
|
|
RewriteRule ^courses/([^/]+)/course-email-pic.png$ main/inc/ajax/course.ajax.php?a=get_course_image&code=$1&image=course_email_image_large_source [QSA,L]
|
|
|
|
|
|
|
|
# Redirect all courses/ to app/courses/
|
|
|
|
RewriteRule ^courses/([^/]+)/(.*)$ app/courses/$1/$2 [QSA,L]
|
|
|
|
|
|
|
|
# About session
|
|
|
|
RewriteRule ^session/(\d{1,})/about/?$ main/session/about.php?session_id=$1 [QSA,L]
|
|
|
|
|
|
|
|
# About course
|
|
|
|
RewriteRule ^course/(\d{1,})/about/?$ main/course_info/about.php?course_id=$1 [QSA,L]
|
|
|
|
|
|
|
|
# Issued individual badge friendly URL
|
|
|
|
RewriteRule ^badge/(\d{1,})/?$ main/badge/issued.php?issue=$1 [QSA,L]
|
|
|
|
|
|
|
|
# Issued badges friendly URL
|
|
|
|
RewriteRule ^skill/(\d{1,})/user/(\d{1,})/?$ main/badge/issued_all.php?skill=$1&user=$2 [L]
|
|
|
|
# Support deprecated URL (avoid 404)
|
|
|
|
RewriteRule ^badge/(\d{1,})/user/(\d{1,})/?$ main/badge/issued_all.php?skill=$1&user=$2 [L]
|
|
|
|
|
|
|
|
# Support old URLs using the exercice (with a c) folder rather than exercise
|
|
|
|
RewriteRule ^main/exercice/(.*)$ main/exercise/$1 [QSA,L]
|
|
|
|
# Support old URLs using the newscorm folder rather than lp
|
|
|
|
RewriteRule ^main/newscorm/(.*)$ main/lp/$1 [QSA,L]
|
|
|
|
|
|
|
|
# service Information
|
|
|
|
RewriteRule ^service/(\d{1,})$ plugin/buycourses/src/service_information.php?service_id=$1 [L]
|
|
|
|
|
|
|
|
# LTI outcome service
|
|
|
|
RewriteRule ^lti/os$ plugin/ims_lti/outcome_service.php [L]
|
|
|
|
|
|
|
|
# Deny direct access to user my files
|
|
|
|
RewriteRule ^app/upload/users/([^/]+)/([^/]+)/my_files/(.*)$ main/social/download_my_files.php?user_id=$2&file=$3 [QSA,L]
|
|
|
|
|
|
|
|
# Deny access
|
|
|
|
RewriteRule ^(tests|.git) - [F,L,NC]
|
|
|
|
|
|
|
|
# Add caching of woff font files to avoid loading 2*15KB each time with Chamilo
|
|
|
|
# default OpenSans font
|
|
|
|
AddType application/font-woff .woff .woff2
|
|
|
|
<IfModule mod_expires.c>
|
|
|
|
ExpiresActive On
|
|
|
|
ExpiresByType application/font-woff "access plus 1 month"
|
|
|
|
</IfModule>
|
|
|
|
|
|
|
|
# Force SSL/HTTPS
|
|
|
|
# We recommend you place this block in your VirtualHost config rather
|
|
|
|
# than uncommenting it below. However, if you have no other way,
|
|
|
|
# feel free to uncomment it, but please remember that this file will
|
|
|
|
# be overwritten during your next Chamilo update.
|
|
|
|
# Also note this will only work if you have an SSL certificate
|
|
|
|
# configured elsewhere in your Apache configuration.
|
|
|
|
|
|
|
|
#RewriteCond %{HTTPS} !=on
|
|
|
|
#RewriteRule .* https://%{HTTP_HOST}%{REQUEST_URI} [R=301,L]
|
|
|
|
#<IfModule mod_headers.c>
|
|
|
|
# Header always set Content-Security-Policy "upgrade-insecure-requests;"
|
|
|
|
#</IfModule>
|