├── distribution-files ├── mysql │ └── .keep └── nginx │ ├── modules │ ├── scgi_params │ ├── uwsgi_params │ ├── nginx.conf │ ├── conf.d │ └── default.conf │ ├── fastcgi_params │ ├── ssl │ ├── wildcard.cert │ └── wildcard.key │ ├── koi-win │ ├── koi-utf │ ├── win-utf │ └── mime.types ├── .gitignore ├── docker-mediawiki-build ├── php-fpm │ ├── aerospike.ini │ ├── opcache.ini │ ├── laravel.ini │ ├── xdebug.ini │ ├── mysql.ini │ ├── xdebug │ ├── xlaravel.pool.conf │ ├── Dockerfile-72 │ └── php72.ini └── parsoid │ ├── Dockerfile │ └── config.yaml ├── .env.example ├── .editorconfig ├── Makefile ├── autoinstall.yml ├── docker-compose.yml ├── README.md └── runfirst.bash /distribution-files/mysql/.keep: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | distribution-files/* 2 | .env 3 | -------------------------------------------------------------------------------- /distribution-files/nginx/modules: -------------------------------------------------------------------------------- 1 | /usr/lib/nginx/modules -------------------------------------------------------------------------------- /docker-mediawiki-build/php-fpm/aerospike.ini: -------------------------------------------------------------------------------- 1 | extension=aerospike.so 2 | aerospike.udf.lua_system_path=/usr/local/aerospike/lua 3 | aerospike.udf.lua_user_path=/usr/local/aerospike/usr-lua -------------------------------------------------------------------------------- /.env.example: -------------------------------------------------------------------------------- 1 | MEDIAWIKIVERSION=1.31 2 | 3 | AUTOINSTALL=bannana 4 | SERVERURL=http://localhost 5 | WIKINAME=NaoWiki 6 | DBNAME=mediawiki 7 | DBPASS=HC51qp6xYIK 8 | ADMINUSER=Admin 9 | ADMINPASSWORD=EDI917VJb30 10 | 11 | WEB_PORT=80 12 | WEB_SSL_PORT=443 13 | -------------------------------------------------------------------------------- /docker-mediawiki-build/php-fpm/opcache.ini: -------------------------------------------------------------------------------- 1 | ; NOTE: The actual opcache.so extention is NOT SET HERE but rather (/usr/local/etc/php/conf.d/docker-php-ext-opcache.ini) 2 | 3 | opcache.enable="1" 4 | opcache.memory_consumption="256" 5 | opcache.use_cwd="0" 6 | opcache.max_file_size="0" 7 | opcache.max_accelerated_files = 30000 8 | opcache.validate_timestamps="1" 9 | opcache.revalidate_freq="0" 10 | -------------------------------------------------------------------------------- /.editorconfig: -------------------------------------------------------------------------------- 1 | [*] 2 | indent_style = space 3 | indent_size = 4 4 | end_of_line = lf 5 | charset = utf-8 6 | trim_trailing_whitespace = true 7 | insert_final_newline = true 8 | spaces_around_brackets = outside 9 | spaces_around_operators = true 10 | 11 | [*.md] 12 | trim_trailing_whitespace = false 13 | 14 | [*.{php, js}] 15 | quote_type = single 16 | 17 | [Makefile] 18 | indent_style = tab 19 | 20 | [*.mk] 21 | indent_style = tab 22 | -------------------------------------------------------------------------------- /docker-mediawiki-build/php-fpm/laravel.ini: -------------------------------------------------------------------------------- 1 | date.timezone=UTC 2 | display_errors=Off 3 | log_errors=On 4 | 5 | ; Maximum amount of memory a script may consume (128MB) 6 | ; http://php.net/memory-limit 7 | memory_limit = 256M 8 | ; Maximum allowed size for uploaded files. 9 | ; http://php.net/upload-max-filesize 10 | upload_max_filesize = 20M 11 | ; Sets max size of post data allowed. 12 | ; http://php.net/post-max-size 13 | post_max_size = 20M 14 | max_execution_time=600 15 | default_socket_timeout=3600 16 | request_terminate_timeout=600 17 | -------------------------------------------------------------------------------- /docker-mediawiki-build/php-fpm/xdebug.ini: -------------------------------------------------------------------------------- 1 | ; NOTE: The actual debug.so extention is NOT SET HERE but rather (/usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini) 2 | 3 | ; xdebug.remote_host=dockerhost 4 | xdebug.remote_connect_back=1 5 | xdebug.remote_port=9000 6 | xdebug.idekey=PHPSTORM 7 | 8 | xdebug.remote_autostart=0 9 | xdebug.remote_enable=0 10 | xdebug.cli_color=0 11 | xdebug.profiler_enable=0 12 | xdebug.profiler_output_dir="~/xdebug/phpstorm/tmp/profiling" 13 | 14 | xdebug.remote_handler=dbgp 15 | xdebug.remote_mode=req 16 | 17 | xdebug.var_display_max_children=-1 18 | xdebug.var_display_max_data=-1 19 | xdebug.var_display_max_depth=-1 20 | 21 | -------------------------------------------------------------------------------- /distribution-files/nginx/scgi_params: -------------------------------------------------------------------------------- 1 | 2 | scgi_param REQUEST_METHOD $request_method; 3 | scgi_param REQUEST_URI $request_uri; 4 | scgi_param QUERY_STRING $query_string; 5 | scgi_param CONTENT_TYPE $content_type; 6 | 7 | scgi_param DOCUMENT_URI $document_uri; 8 | scgi_param DOCUMENT_ROOT $document_root; 9 | scgi_param SCGI 1; 10 | scgi_param SERVER_PROTOCOL $server_protocol; 11 | scgi_param REQUEST_SCHEME $scheme; 12 | scgi_param HTTPS $https if_not_empty; 13 | 14 | scgi_param REMOTE_ADDR $remote_addr; 15 | scgi_param REMOTE_PORT $remote_port; 16 | scgi_param SERVER_PORT $server_port; 17 | scgi_param SERVER_NAME $server_name; 18 | -------------------------------------------------------------------------------- /distribution-files/nginx/uwsgi_params: -------------------------------------------------------------------------------- 1 | 2 | uwsgi_param QUERY_STRING $query_string; 3 | uwsgi_param REQUEST_METHOD $request_method; 4 | uwsgi_param CONTENT_TYPE $content_type; 5 | uwsgi_param CONTENT_LENGTH $content_length; 6 | 7 | uwsgi_param REQUEST_URI $request_uri; 8 | uwsgi_param PATH_INFO $document_uri; 9 | uwsgi_param DOCUMENT_ROOT $document_root; 10 | uwsgi_param SERVER_PROTOCOL $server_protocol; 11 | uwsgi_param REQUEST_SCHEME $scheme; 12 | uwsgi_param HTTPS $https if_not_empty; 13 | 14 | uwsgi_param REMOTE_ADDR $remote_addr; 15 | uwsgi_param REMOTE_PORT $remote_port; 16 | uwsgi_param SERVER_PORT $server_port; 17 | uwsgi_param SERVER_NAME $server_name; 18 | -------------------------------------------------------------------------------- /distribution-files/nginx/nginx.conf: -------------------------------------------------------------------------------- 1 | user www-data; 2 | worker_processes 1; 3 | 4 | error_log /var/log/nginx/error.log warn; 5 | pid /var/run/nginx.pid; 6 | 7 | 8 | events { 9 | worker_connections 1024; 10 | } 11 | 12 | 13 | http { 14 | include /etc/nginx/mime.types; 15 | default_type application/octet-stream; 16 | 17 | log_format main '$remote_addr - $remote_user [$time_local] "$request" ' 18 | '$status $body_bytes_sent "$http_referer" ' 19 | '"$http_user_agent" "$http_x_forwarded_for"'; 20 | 21 | access_log /var/log/nginx/access.log main; 22 | 23 | sendfile on; 24 | #tcp_nopush on; 25 | 26 | keepalive_timeout 65; 27 | 28 | #gzip on; 29 | 30 | include /etc/nginx/conf.d/*.conf; 31 | } 32 | -------------------------------------------------------------------------------- /docker-mediawiki-build/parsoid/Dockerfile: -------------------------------------------------------------------------------- 1 | 2 | FROM node:6-wheezy 3 | 4 | ##################################### 5 | # Git: 6 | ##################################### 7 | ARG INSTALL_GIT=true 8 | ENV INSTALL_GIT ${INSTALL_GIT} 9 | RUN if [ ${INSTALL_GIT} = true ]; then \ 10 | apt-get update && \ 11 | apt-get install -y git && \ 12 | rm -r /var/lib/apt/lists/* \ 13 | ;fi 14 | 15 | ##################################### 16 | # Parsoid: 17 | ##################################### 18 | RUN \ 19 | git clone https://gerrit.wikimedia.org/r/p/mediawiki/services/parsoid --depth 1 && \ 20 | cd parsoid && \ 21 | npm install 22 | 23 | # 24 | #-------------------------------------------------------------------------- 25 | # Final Touch 26 | #-------------------------------------------------------------------------- 27 | # 28 | 29 | ADD ./config.yaml /parsoid/ 30 | 31 | #RUN rm -r /var/lib/apt/lists/* 32 | 33 | WORKDIR /parsoid 34 | 35 | CMD npm start 36 | -------------------------------------------------------------------------------- /Makefile: -------------------------------------------------------------------------------- 1 | # Spread cli arguments 2 | ifneq (,$(filter $(firstword $(MAKECMDGOALS)),exec)) 3 | CLI_ARGS := $(wordlist 2,$(words $(MAKECMDGOALS)),$(MAKECMDGOALS)) 4 | $(eval $(CLI_ARGS):;@:) 5 | endif 6 | 7 | docker-compose = docker-compose -f docker-compose.yml $1 8 | 9 | -include .env 10 | 11 | init: 12 | cp .env.example .env 13 | 14 | config: 15 | sed -i 's/MYSQL_ROOT_PASSWORD=.*/MYSQL_ROOT_PASSWORD=${DBPASS}/g' ./docker-compose.yml 16 | sed -i 's/MYSQL_ROOT_PASSWORD=.*/MYSQL_ROOT_PASSWORD=${DBPASS}/g' ./autoinstall.yml 17 | sed -i 's/MYSQL_PASSWORD=.*/MYSQL_PASSWORD=${DBPASS}/g' ./docker-compose.yml 18 | sed -i 's/MYSQL_PASSWORD=.*/MYSQL_PASSWORD=${DBPASS}/g' ./autoinstall.yml 19 | sudo ./runfirst.bash 20 | 21 | up: 22 | $(call docker-compose, up -d --force-recreate) 23 | 24 | down: 25 | $(call docker-compose, down --volumes) 26 | 27 | reup: down up 28 | 29 | destroy: 30 | @if [ -d ./distribution-files/mediawiki ]; then sudo rm -fr ./distribution-files/mediawiki; fi 31 | -------------------------------------------------------------------------------- /distribution-files/nginx/conf.d/default.conf: -------------------------------------------------------------------------------- 1 | server { 2 | listen 80; 3 | server_name _; 4 | return 301 https://$host$request_uri; 5 | } 6 | 7 | server { 8 | listen 443 ssl; 9 | server_name _; 10 | ssl_certificate ssl/wildcard.cert; 11 | ssl_certificate_key ssl/wildcard.key; 12 | ssl_protocols TLSv1 TLSv1.1 TLSv1.2; 13 | ssl_ciphers HIGH:!aNULL:!MD5; 14 | root /var/www/mediawiki; 15 | index index.php; 16 | 17 | location ~ \.htaccess { 18 | deny all; 19 | } 20 | 21 | location / { 22 | try_files $uri $uri/ @rewrite; 23 | } 24 | 25 | location @rewrite { 26 | rewrite ^/(.*)$ /index.php; 27 | } 28 | 29 | location ^~ /maintenance/ { 30 | return 403; 31 | } 32 | 33 | location ~ \.php$ { 34 | include /etc/nginx/fastcgi_params; 35 | 36 | fastcgi_pass phpfpm:9000; 37 | fastcgi_index index.php; 38 | 39 | fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; 40 | 41 | try_files $uri @rewrite; 42 | } 43 | } 44 | -------------------------------------------------------------------------------- /distribution-files/nginx/fastcgi_params: -------------------------------------------------------------------------------- 1 | 2 | fastcgi_param QUERY_STRING $query_string; 3 | fastcgi_param REQUEST_METHOD $request_method; 4 | fastcgi_param CONTENT_TYPE $content_type; 5 | fastcgi_param CONTENT_LENGTH $content_length; 6 | 7 | fastcgi_param SCRIPT_NAME $fastcgi_script_name; 8 | fastcgi_param REQUEST_URI $request_uri; 9 | fastcgi_param DOCUMENT_URI $document_uri; 10 | fastcgi_param DOCUMENT_ROOT $document_root; 11 | fastcgi_param SERVER_PROTOCOL $server_protocol; 12 | fastcgi_param REQUEST_SCHEME $scheme; 13 | fastcgi_param HTTPS $https if_not_empty; 14 | 15 | fastcgi_param GATEWAY_INTERFACE CGI/1.1; 16 | fastcgi_param SERVER_SOFTWARE nginx/$nginx_version; 17 | 18 | fastcgi_param REMOTE_ADDR $remote_addr; 19 | fastcgi_param REMOTE_PORT $remote_port; 20 | fastcgi_param SERVER_ADDR $server_addr; 21 | fastcgi_param SERVER_PORT $server_port; 22 | fastcgi_param SERVER_NAME $server_name; 23 | 24 | # PHP only, required if PHP was built with --enable-force-cgi-redirect 25 | fastcgi_param REDIRECT_STATUS 200; 26 | -------------------------------------------------------------------------------- /distribution-files/nginx/ssl/wildcard.cert: -------------------------------------------------------------------------------- 1 | -----BEGIN CERTIFICATE----- 2 | MIIC+TCCAeGgAwIBAgIJAOMpL9NpxDJuMA0GCSqGSIb3DQEBBQUAMBMxETAPBgNV 3 | BAMMCHdpbGRjYXJkMB4XDTE2MTIxNjIxNDc0MFoXDTI2MTIxNDIxNDc0MFowEzER 4 | MA8GA1UEAwwId2lsZGNhcmQwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB 5 | AQDi6gypnM1mMzedi63yFA4hInzAb5Ojw5E+ug3bPAQpixJ3mKqlxs/Ull5g7FED 6 | ZUjUxvqPl3H0VAAwaqxRDbramBehmLDhsWeSnH6uWxWUx/GFY9r6Qe9ct4/T+rIi 7 | wO6893TLiIw6eFnMa9vHd2zCnc15h12fmGuVR8CJrqQKbhYLGxPTEynQ1ZfHugEm 8 | TH7tXiaSTzcAHUyKKD/wsHY7gHUZZJ4cjK2samJ7sHThBk2dEJQvcJa7noPcDK2Z 9 | U0Ap63noox5i5H5PbSHO/YlLJUnrLGyHfcPuIHnCW18GXDWlX/LrNR2vUCuTNLV3 10 | kjhOOY460kTmpw2xWc4olU8FAgMBAAGjUDBOMB0GA1UdDgQWBBQDBUs+R9wlbg6L 11 | 3X5dw13FSfdJUjAfBgNVHSMEGDAWgBQDBUs+R9wlbg6L3X5dw13FSfdJUjAMBgNV 12 | HRMEBTADAQH/MA0GCSqGSIb3DQEBBQUAA4IBAQDdt4Jrr/yCyKc9R6EdsHSr1i1T 13 | mPUGA544Ow3QK3A2ROrHLVPE6ZGjNDNT1+45dcBp93QSrnbH8k92B8AQtPhKxUzF 14 | vaIXLpaxNA/d14GA7lpyJmNiCS1M95lQyIfbHkEsy9fDI5IpZEkWJDQXFx/qnZrK 15 | rMCm+YixW6yLc/lGq/3g9ItURRRaUCn1/vk/MlpKUfSIbChVFhWzPD+5UiNwo6Jg 16 | DTrxl4ajVeHlxLL/Dz0XYMI5HDh6CE4hC54PwIMWhTuRYV8DCHpPbxa+sAoCfoWv 17 | pGkF/ZXDixqPS5sFsD+UTv5lzAz55GF2/AhvWxsOPLoPlE45YID1VF0Ohbvs 18 | -----END CERTIFICATE----- 19 | -------------------------------------------------------------------------------- /autoinstall.yml: -------------------------------------------------------------------------------- 1 | version: '2' 2 | services: 3 | phpfpm: 4 | container_name: no-one-else-should-be-using-this-name 5 | build: 6 | context: ./docker-mediawiki-build/php-fpm 7 | args: 8 | - INSTALL_XDEBUG=true 9 | - INSTALL_BLACKFIRE=false 10 | - INSTALL_SOAP=true 11 | - INSTALL_IMAP=true 12 | - INSTALL_MONGO=false 13 | - INSTALL_AMQP=false 14 | - INSTALL_MSSQL=true 15 | - INSTALL_ZIP_ARCHIVE=true 16 | - INSTALL_BCMATH=true 17 | - INSTALL_GMP=true 18 | - INSTALL_PHPREDIS=false 19 | - INSTALL_MEMCACHED=true 20 | - INSTALL_OPCACHE=true 21 | - INSTALL_EXIF=true 22 | - INSTALL_AEROSPIKE=false 23 | - INSTALL_MYSQLI=true 24 | - INSTALL_PGSQL=true 25 | - INSTALL_PG_CLIENT=true 26 | - INSTALL_TOKENIZER=true 27 | - INSTALL_INTL=true 28 | - INSTALL_GHOSTSCRIPT=true 29 | - INSTALL_LDAP=true 30 | - INSTALL_SWOOLE=false 31 | - INSTALL_IMAGE_OPTIMIZERS=true 32 | - INSTALL_IMAGEMAGICK=true 33 | dockerfile: "Dockerfile-72" 34 | volumes: 35 | - "./distribution-files/mediawiki:/var/www/mediawiki" 36 | - "/etc/passwd:/etc/passwd:ro" 37 | - "/etc/shadow:/etc/shadow:ro" 38 | - "/etc/group:/etc/group:ro" 39 | depends_on: 40 | - mysql 41 | entrypoint: 42 | - sh 43 | - -c 44 | - 'sleep 100000' 45 | 46 | mysql: 47 | container_name: no-one-else-should-be-using-this-name-or-this 48 | image: mariadb:10.0 49 | volumes: 50 | - "./distribution-files/mysql:/var/lib/mysql" 51 | environment: 52 | - MYSQL_ROOT_PASSWORD=HC51qp6xYIK 53 | - MYSQL_USER=root@% 54 | - MYSQL_PASSWORD=HC51qp6xYIK 55 | -------------------------------------------------------------------------------- /distribution-files/nginx/ssl/wildcard.key: -------------------------------------------------------------------------------- 1 | -----BEGIN RSA PRIVATE KEY----- 2 | MIIEpAIBAAKCAQEA4uoMqZzNZjM3nYut8hQOISJ8wG+To8ORProN2zwEKYsSd5iq 3 | pcbP1JZeYOxRA2VI1Mb6j5dx9FQAMGqsUQ262pgXoZiw4bFnkpx+rlsVlMfxhWPa 4 | +kHvXLeP0/qyIsDuvPd0y4iMOnhZzGvbx3dswp3NeYddn5hrlUfAia6kCm4WCxsT 5 | 0xMp0NWXx7oBJkx+7V4mkk83AB1Miig/8LB2O4B1GWSeHIytrGpie7B04QZNnRCU 6 | L3CWu56D3AytmVNAKet56KMeYuR+T20hzv2JSyVJ6yxsh33D7iB5wltfBlw1pV/y 7 | 6zUdr1ArkzS1d5I4TjmOOtJE5qcNsVnOKJVPBQIDAQABAoIBAQChTxrzVInbtls5 8 | /zsH1WP6ACdJMch16agOPHtvN6oJ0litdnURZlUGXmL3aedpj44H3O/wNgwHUdPU 9 | l3CqKiWEEgzyjrZnqxLi8adI0W11F/JFDih0MX00nzV6z0PlWtwcr5lyuz5croO/ 10 | w4k4slg5va59T1KqCtOoCpsABYuN8T+/vOxcQ4R/kAsYeheSPDIWqygeuN0lz0WB 11 | VjZgwm80RX/hl9KghwoahI9yjxeoBAqymMMuctVMDW8ESSio1xptdbol1KsLqxGc 12 | OtewEgdyIT7DVIVPJLXfoEIUd2Th5zJWfHCHiR7iFO6eyeVyzr2PfNu02tUPoJ79 13 | 4WWY9pGhAoGBAPMrq249E5UGsCBUMhWueM6HoB/s1LUItvA4MYNiGdBOgH3Au8ck 14 | bDg7WF0AE/OAZ5r/g5BJ2m4AnHWIvmOGIFxmhb7nY5WMINcCaUZUPZTho7wueHuD 15 | wC70tVFhDOiEJe8xxuL3UQnUB5Hy44e8RE5wqw8EmXHtTIwmfK6cPxANAoGBAO7i 16 | 0TfvWz9tMqUpAM0KjrMGVAUySM6xYzXY6eK5dHQutBpz1U7z/EnCjjX/DnCqveHz 17 | PDKzbIU8sZVXVSRJbzG+Q6uF1avW3jg54o2vCluX/ojqO1Nm48KXPFfYoVhwa1I9 18 | YZ/la10721S6TKkalvRl2Uwgr0WSggyTe6ntwoTZAoGAC3JZzoWnf1NiRRNRjD27 19 | SBWQTxBp7t+rJOGwSvv6NRkM6V6COFyZj4gTn8UaK1M3DU/L1KX1V0pGEy5NsAen 20 | TFIzJ4pi4K5I+XYOmJXslC6O85PIbiAEkvFH+72yyts1oe3Y6+Qyd2D4vkENvtz4 21 | 5ixdkQZpZriB6vMA2YNXYJ0CgYEAnOeyEBFRV9m7mCvUcNjsXb5cVYVvuQNebLHq 22 | /ZZeXSmH9o/6nX84SKJXkjPTIkGjstN2yL59Gw6Afdz8+XaaaIvWGsUvUU0ybK/o 23 | lLNSFFNDRl7DVMaR9vArHHAXmeVNOJlElCe2W2jDaWVskO38FM8I6S3WsdXHQcdl 24 | RHn8eBECgYB3Gnygh/OmSBMu4uWP8dvMd32MQmizeUU+fbqLOMD22HSTI4+7KRUg 25 | E/BYIS3agk0v/0n27Xm/3xvnYB3728X0rP0rdnJZR31L7MwyzTuYs4RBzNN4InNw 26 | hAe05ZLUyTnKGwqstmSGjATvxn5qC4XJTODYm8F6fj9Ccn+D3ZMHfg== 27 | -----END RSA PRIVATE KEY----- 28 | -------------------------------------------------------------------------------- /docker-compose.yml: -------------------------------------------------------------------------------- 1 | version: '2' 2 | services: 3 | phpfpm: 4 | build: 5 | context: ./docker-mediawiki-build/php-fpm 6 | args: 7 | - INSTALL_XDEBUG=true 8 | - INSTALL_BLACKFIRE=false 9 | - INSTALL_SOAP=true 10 | - INSTALL_IMAP=true 11 | - INSTALL_MONGO=false 12 | - INSTALL_AMQP=false 13 | - INSTALL_MSSQL=true 14 | - INSTALL_ZIP_ARCHIVE=true 15 | - INSTALL_BCMATH=true 16 | - INSTALL_GMP=true 17 | - INSTALL_PHPREDIS=false 18 | - INSTALL_MEMCACHED=true 19 | - INSTALL_OPCACHE=true 20 | - INSTALL_EXIF=true 21 | - INSTALL_AEROSPIKE=false 22 | - INSTALL_MYSQLI=true 23 | - INSTALL_PGSQL=true 24 | - INSTALL_PG_CLIENT=true 25 | - INSTALL_TOKENIZER=true 26 | - INSTALL_INTL=true 27 | - INSTALL_GHOSTSCRIPT=true 28 | - INSTALL_LDAP=true 29 | - INSTALL_SWOOLE=false 30 | - INSTALL_IMAGE_OPTIMIZERS=true 31 | - INSTALL_IMAGEMAGICK=true 32 | dockerfile: "Dockerfile-72" 33 | volumes: 34 | - "./distribution-files/mediawiki:/var/www/mediawiki" 35 | - "/etc/passwd:/etc/passwd:ro" 36 | - "/etc/shadow:/etc/shadow:ro" 37 | - "/etc/group:/etc/group:ro" 38 | nginx: 39 | image: nginx:1.10 40 | ports: 41 | - "${WEB_PORT}:80" 42 | - "${WEB_SSL_PORT}:443" 43 | volumes: 44 | - "./distribution-files/nginx:/etc/nginx" 45 | - "./distribution-files/mediawiki:/var/www/mediawiki" 46 | - "/etc/passwd:/etc/passwd:ro" 47 | - "/etc/shadow:/etc/shadow:ro" 48 | - "/etc/group:/etc/group:ro" 49 | depends_on: 50 | - phpfpm 51 | - parsoid 52 | mysql: 53 | image: mariadb:10.0 54 | volumes: 55 | - "./distribution-files/mysql:/var/lib/mysql" 56 | environment: 57 | - MYSQL_ROOT_PASSWORD=HC51qp6xYIK 58 | - MYSQL_USER=root@% 59 | - MYSQL_PASSWORD=HC51qp6xYIK 60 | depends_on: 61 | - nginx 62 | parsoid: 63 | build: 64 | context: ./docker-mediawiki-build/parsoid 65 | hostname: parsoid 66 | -------------------------------------------------------------------------------- /docker-mediawiki-build/php-fpm/mysql.ini: -------------------------------------------------------------------------------- 1 | [MySQL] 2 | ; Allow accessing, from PHP's perspective, local files with LOAD DATA statements 3 | ; http://php.net/mysql.allow_local_infile 4 | mysql.allow_local_infile = On 5 | 6 | ; Allow or prevent persistent links. 7 | ; http://php.net/mysql.allow-persistent 8 | mysql.allow_persistent = On 9 | 10 | ; If mysqlnd is used: Number of cache slots for the internal result set cache 11 | ; http://php.net/mysql.cache_size 12 | mysql.cache_size = 2000 13 | 14 | ; Maximum number of persistent links. -1 means no limit. 15 | ; http://php.net/mysql.max-persistent 16 | mysql.max_persistent = -1 17 | 18 | ; Maximum number of links (persistent + non-persistent). -1 means no limit. 19 | ; http://php.net/mysql.max-links 20 | mysql.max_links = -1 21 | 22 | ; Default port number for mysql_connect(). If unset, mysql_connect() will use 23 | ; the $MYSQL_TCP_PORT or the mysql-tcp entry in /etc/services or the 24 | ; compile-time value defined MYSQL_PORT (in that order). Win32 will only look 25 | ; at MYSQL_PORT. 26 | ; http://php.net/mysql.default-port 27 | mysql.default_port = 28 | 29 | ; Default socket name for local MySQL connects. If empty, uses the built-in 30 | ; MySQL defaults. 31 | ; http://php.net/mysql.default-socket 32 | mysql.default_socket = 33 | 34 | ; Default host for mysql_connect() (doesn't apply in safe mode). 35 | ; http://php.net/mysql.default-host 36 | mysql.default_host = 37 | 38 | ; Default user for mysql_connect() (doesn't apply in safe mode). 39 | ; http://php.net/mysql.default-user 40 | mysql.default_user = 41 | 42 | ; Default password for mysql_connect() (doesn't apply in safe mode). 43 | ; Note that this is generally a *bad* idea to store passwords in this file. 44 | ; *Any* user with PHP access can run 'echo get_cfg_var("mysql.default_password") 45 | ; and reveal this password! And of course, any users with read access to this 46 | ; file will be able to reveal the password as well. 47 | ; http://php.net/mysql.default-password 48 | mysql.default_password = 49 | 50 | ; Maximum time (in seconds) for connect timeout. -1 means no limit 51 | ; http://php.net/mysql.connect-timeout 52 | mysql.connect_timeout = 60 53 | 54 | ; Trace mode. When trace_mode is active (=On), warnings for table/index scans and 55 | ; SQL-Errors will be displayed. 56 | ; http://php.net/mysql.trace-mode 57 | mysql.trace_mode = Off 58 | 59 | -------------------------------------------------------------------------------- /distribution-files/nginx/koi-win: -------------------------------------------------------------------------------- 1 | 2 | charset_map koi8-r windows-1251 { 3 | 4 | 80 88 ; # euro 5 | 6 | 95 95 ; # bullet 7 | 8 | 9A A0 ; #   9 | 10 | 9E B7 ; # · 11 | 12 | A3 B8 ; # small yo 13 | A4 BA ; # small Ukrainian ye 14 | 15 | A6 B3 ; # small Ukrainian i 16 | A7 BF ; # small Ukrainian yi 17 | 18 | AD B4 ; # small Ukrainian soft g 19 | AE A2 ; # small Byelorussian short u 20 | 21 | B0 B0 ; # ° 22 | 23 | B3 A8 ; # capital YO 24 | B4 AA ; # capital Ukrainian YE 25 | 26 | B6 B2 ; # capital Ukrainian I 27 | B7 AF ; # capital Ukrainian YI 28 | 29 | B9 B9 ; # numero sign 30 | 31 | BD A5 ; # capital Ukrainian soft G 32 | BE A1 ; # capital Byelorussian short U 33 | 34 | BF A9 ; # (C) 35 | 36 | C0 FE ; # small yu 37 | C1 E0 ; # small a 38 | C2 E1 ; # small b 39 | C3 F6 ; # small ts 40 | C4 E4 ; # small d 41 | C5 E5 ; # small ye 42 | C6 F4 ; # small f 43 | C7 E3 ; # small g 44 | C8 F5 ; # small kh 45 | C9 E8 ; # small i 46 | CA E9 ; # small j 47 | CB EA ; # small k 48 | CC EB ; # small l 49 | CD EC ; # small m 50 | CE ED ; # small n 51 | CF EE ; # small o 52 | 53 | D0 EF ; # small p 54 | D1 FF ; # small ya 55 | D2 F0 ; # small r 56 | D3 F1 ; # small s 57 | D4 F2 ; # small t 58 | D5 F3 ; # small u 59 | D6 E6 ; # small zh 60 | D7 E2 ; # small v 61 | D8 FC ; # small soft sign 62 | D9 FB ; # small y 63 | DA E7 ; # small z 64 | DB F8 ; # small sh 65 | DC FD ; # small e 66 | DD F9 ; # small shch 67 | DE F7 ; # small ch 68 | DF FA ; # small hard sign 69 | 70 | E0 DE ; # capital YU 71 | E1 C0 ; # capital A 72 | E2 C1 ; # capital B 73 | E3 D6 ; # capital TS 74 | E4 C4 ; # capital D 75 | E5 C5 ; # capital YE 76 | E6 D4 ; # capital F 77 | E7 C3 ; # capital G 78 | E8 D5 ; # capital KH 79 | E9 C8 ; # capital I 80 | EA C9 ; # capital J 81 | EB CA ; # capital K 82 | EC CB ; # capital L 83 | ED CC ; # capital M 84 | EE CD ; # capital N 85 | EF CE ; # capital O 86 | 87 | F0 CF ; # capital P 88 | F1 DF ; # capital YA 89 | F2 D0 ; # capital R 90 | F3 D1 ; # capital S 91 | F4 D2 ; # capital T 92 | F5 D3 ; # capital U 93 | F6 C6 ; # capital ZH 94 | F7 C2 ; # capital V 95 | F8 DC ; # capital soft sign 96 | F9 DB ; # capital Y 97 | FA C7 ; # capital Z 98 | FB D8 ; # capital SH 99 | FC DD ; # capital E 100 | FD D9 ; # capital SHCH 101 | FE D7 ; # capital CH 102 | FF DA ; # capital hard sign 103 | } 104 | -------------------------------------------------------------------------------- /docker-mediawiki-build/php-fpm/xdebug: -------------------------------------------------------------------------------- 1 | #! /bin/bash 2 | 3 | # NOTE: At the moment, this has only been confirmed to work with PHP 7 4 | 5 | 6 | # Grab full name of php-fpm container 7 | PHP_FPM_CONTAINER=$(docker ps | grep php-fpm | awk '{print $1}') 8 | 9 | 10 | # Grab OS type 11 | if [[ "$(uname)" == "Darwin" ]]; then 12 | OS_TYPE="OSX" 13 | else 14 | OS_TYPE=$(expr substr $(uname -s) 1 5) 15 | fi 16 | 17 | 18 | xdebug_status () 19 | { 20 | echo 'xDebug status' 21 | 22 | # If running on Windows, need to prepend with winpty :( 23 | if [[ $OS_TYPE == "MINGW" ]]; then 24 | winpty docker exec -it $PHP_FPM_CONTAINER bash -c 'php -v' 25 | 26 | else 27 | docker exec -it $PHP_FPM_CONTAINER bash -c 'php -v' 28 | fi 29 | 30 | } 31 | 32 | 33 | xdebug_start () 34 | { 35 | echo 'Start xDebug' 36 | 37 | # And uncomment line with xdebug extension, thus enabling it 38 | ON_CMD="sed -i 's/^;zend_extension=/zend_extension=/g' \ 39 | /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini" 40 | 41 | 42 | # If running on Windows, need to prepend with winpty :( 43 | if [[ $OS_TYPE == "MINGW" ]]; then 44 | winpty docker exec -it $PHP_FPM_CONTAINER bash -c "${ON_CMD}" 45 | docker restart $PHP_FPM_CONTAINER 46 | winpty docker exec -it $PHP_FPM_CONTAINER bash -c 'php -v' 47 | 48 | else 49 | docker exec -it $PHP_FPM_CONTAINER bash -c "${ON_CMD}" 50 | docker restart $PHP_FPM_CONTAINER 51 | docker exec -it $PHP_FPM_CONTAINER bash -c 'php -v' 52 | fi 53 | } 54 | 55 | 56 | xdebug_stop () 57 | { 58 | echo 'Stop xDebug' 59 | 60 | # Comment out xdebug extension line 61 | OFF_CMD="sed -i 's/^zend_extension=/;zend_extension=/g' /usr/local/etc/php/conf.d/docker-php-ext-xdebug.ini" 62 | 63 | 64 | # If running on Windows, need to prepend with winpty :( 65 | if [[ $OS_TYPE == "MINGW" ]]; then 66 | # This is the equivalent of: 67 | # winpty docker exec -it laradock_php-fpm_1 bash -c 'bla bla bla' 68 | # Thanks to @michaelarnauts at https://github.com/docker/compose/issues/593 69 | winpty docker exec -it $PHP_FPM_CONTAINER bash -c "${OFF_CMD}" 70 | docker restart $PHP_FPM_CONTAINER 71 | #docker-compose restart php-fpm 72 | winpty docker exec -it $PHP_FPM_CONTAINER bash -c 'php -v' 73 | 74 | else 75 | docker exec -it $PHP_FPM_CONTAINER bash -c "${OFF_CMD}" 76 | # docker-compose restart php-fpm 77 | docker restart $PHP_FPM_CONTAINER 78 | docker exec -it $PHP_FPM_CONTAINER bash -c 'php -v' 79 | fi 80 | } 81 | 82 | 83 | case $@ in 84 | stop|STOP) 85 | xdebug_stop 86 | ;; 87 | start|START) 88 | xdebug_start 89 | ;; 90 | status|STATUS) 91 | xdebug_status 92 | ;; 93 | *) 94 | echo "xDebug [Stop | Start | Status] in the ${PHP_FPM_CONTAINER} container." 95 | echo "xDebug must have already been installed." 96 | echo "Usage:" 97 | echo " .php-fpm/xdebug stop|start|status" 98 | 99 | esac 100 | 101 | exit 1 102 | -------------------------------------------------------------------------------- /distribution-files/nginx/koi-utf: -------------------------------------------------------------------------------- 1 | 2 | # This map is not a full koi8-r <> utf8 map: it does not contain 3 | # box-drawing and some other characters. Besides this map contains 4 | # several koi8-u and Byelorussian letters which are not in koi8-r. 5 | # If you need a full and standard map, use contrib/unicode2nginx/koi-utf 6 | # map instead. 7 | 8 | charset_map koi8-r utf-8 { 9 | 10 | 80 E282AC ; # euro 11 | 12 | 95 E280A2 ; # bullet 13 | 14 | 9A C2A0 ; #   15 | 16 | 9E C2B7 ; # · 17 | 18 | A3 D191 ; # small yo 19 | A4 D194 ; # small Ukrainian ye 20 | 21 | A6 D196 ; # small Ukrainian i 22 | A7 D197 ; # small Ukrainian yi 23 | 24 | AD D291 ; # small Ukrainian soft g 25 | AE D19E ; # small Byelorussian short u 26 | 27 | B0 C2B0 ; # ° 28 | 29 | B3 D081 ; # capital YO 30 | B4 D084 ; # capital Ukrainian YE 31 | 32 | B6 D086 ; # capital Ukrainian I 33 | B7 D087 ; # capital Ukrainian YI 34 | 35 | B9 E28496 ; # numero sign 36 | 37 | BD D290 ; # capital Ukrainian soft G 38 | BE D18E ; # capital Byelorussian short U 39 | 40 | BF C2A9 ; # (C) 41 | 42 | C0 D18E ; # small yu 43 | C1 D0B0 ; # small a 44 | C2 D0B1 ; # small b 45 | C3 D186 ; # small ts 46 | C4 D0B4 ; # small d 47 | C5 D0B5 ; # small ye 48 | C6 D184 ; # small f 49 | C7 D0B3 ; # small g 50 | C8 D185 ; # small kh 51 | C9 D0B8 ; # small i 52 | CA D0B9 ; # small j 53 | CB D0BA ; # small k 54 | CC D0BB ; # small l 55 | CD D0BC ; # small m 56 | CE D0BD ; # small n 57 | CF D0BE ; # small o 58 | 59 | D0 D0BF ; # small p 60 | D1 D18F ; # small ya 61 | D2 D180 ; # small r 62 | D3 D181 ; # small s 63 | D4 D182 ; # small t 64 | D5 D183 ; # small u 65 | D6 D0B6 ; # small zh 66 | D7 D0B2 ; # small v 67 | D8 D18C ; # small soft sign 68 | D9 D18B ; # small y 69 | DA D0B7 ; # small z 70 | DB D188 ; # small sh 71 | DC D18D ; # small e 72 | DD D189 ; # small shch 73 | DE D187 ; # small ch 74 | DF D18A ; # small hard sign 75 | 76 | E0 D0AE ; # capital YU 77 | E1 D090 ; # capital A 78 | E2 D091 ; # capital B 79 | E3 D0A6 ; # capital TS 80 | E4 D094 ; # capital D 81 | E5 D095 ; # capital YE 82 | E6 D0A4 ; # capital F 83 | E7 D093 ; # capital G 84 | E8 D0A5 ; # capital KH 85 | E9 D098 ; # capital I 86 | EA D099 ; # capital J 87 | EB D09A ; # capital K 88 | EC D09B ; # capital L 89 | ED D09C ; # capital M 90 | EE D09D ; # capital N 91 | EF D09E ; # capital O 92 | 93 | F0 D09F ; # capital P 94 | F1 D0AF ; # capital YA 95 | F2 D0A0 ; # capital R 96 | F3 D0A1 ; # capital S 97 | F4 D0A2 ; # capital T 98 | F5 D0A3 ; # capital U 99 | F6 D096 ; # capital ZH 100 | F7 D092 ; # capital V 101 | F8 D0AC ; # capital soft sign 102 | F9 D0AB ; # capital Y 103 | FA D097 ; # capital Z 104 | FB D0A8 ; # capital SH 105 | FC D0AD ; # capital E 106 | FD D0A9 ; # capital SHCH 107 | FE D0A7 ; # capital CH 108 | FF D0AA ; # capital hard sign 109 | } 110 | -------------------------------------------------------------------------------- /docker-mediawiki-build/parsoid/config.yaml: -------------------------------------------------------------------------------- 1 | # This is a sample configuration file 2 | # 3 | # Copy this file to config.yaml and edit that file to fit your needs. 4 | # 5 | # Also see: 6 | # - `npm start -- -h` for more information about passing config files via 7 | # the commandline. 8 | # - lib/config/ParsoidConfig.js for all the properties that you can configure 9 | # here. Not all properties are documented here. 10 | 11 | worker_heartbeat_timeout: 300000 12 | 13 | logging: 14 | level: info 15 | 16 | #metrics: 17 | # type: log 18 | 19 | services: 20 | - module: lib/index.js 21 | entrypoint: apiServiceWorker 22 | conf: 23 | # For backwards compatibility, and to continue to support non-static 24 | # configs for the time being, optionally provide a path to a 25 | # localsettings.js file. See localsettings.example.js 26 | #localsettings: ./localsettings.js 27 | 28 | # Set your own user-agent string 29 | # Otherwise, defaults to: 30 | # 'Parsoid/' 31 | #userAgent: 'My-User-Agent-String' 32 | 33 | # Configure Parsoid to point to your MediaWiki instances. 34 | mwApis: 35 | - # This is the only required parameter, 36 | # the URL of you MediaWiki API endpoint. 37 | uri: 'https://nginx/api.php' 38 | # The "domain" is used for communication with Visual Editor 39 | # and RESTBase. It defaults to the hostname portion of 40 | # the `uri` property below, but you can manually set it 41 | # to an arbitrary string. 42 | domain: 'wiki' 43 | # To specify a proxy (or proxy headers) specific to this prefix 44 | # (which overrides defaultAPIProxyURI). Alternatively, set `proxy` 45 | # to `null` to override and force no proxying when a default proxy 46 | # has been set. 47 | #proxy: 48 | # uri: 'http://my.proxy:1234/' 49 | # headers: # optional 50 | # 'X-Forwarded-Proto': 'https' 51 | 52 | # We pre-define wikipedias as 'enwiki', 'dewiki' etc. Similarly 53 | # for other projects: 'enwiktionary', 'enwikiquote', 'enwikibooks', 54 | # 'enwikivoyage' etc. 55 | # The default for this is false. Uncomment the line below if you want 56 | # to load WMF's config for wikipedias, etc. 57 | #loadWMF: true 58 | 59 | # A default proxy to connect to the API endpoints. 60 | # Default: undefined (no proxying). 61 | # Overridden by per-wiki proxy config in setMwApi. 62 | #defaultAPIProxyURI: 'http://proxy.example.org:8080' 63 | 64 | # Enable debug mode (prints extra debugging messages) 65 | #debug: true 66 | 67 | # Use the PHP preprocessor to expand templates via the MW API (default true) 68 | #usePHPPreProcessor: false 69 | 70 | # Use selective serialization (default false) 71 | #useSelser: true 72 | 73 | # Allow cross-domain requests to the API (default '*') 74 | # Sets Access-Control-Allow-Origin header 75 | # disable: 76 | #allowCORS: false 77 | # restrict: 78 | #allowCORS: 'some.domain.org' 79 | 80 | # Allow override of port/interface: 81 | #serverPort: 8000 82 | serverInterface: '0.0.0.0' 83 | 84 | # Enable linting of some wikitext errors to the log 85 | #linting: true 86 | # Send lint errors to MW API instead of to the log 87 | #linterSendAPI: false 88 | 89 | # Require SSL certificates to be valid (default true) 90 | # Set to false when using self-signed SSL certificates 91 | strictSSL: false 92 | 93 | # Use a different server for CSS style modules. 94 | # Leaving it undefined (the default) will use the same URI as the MW API, 95 | # changing api.php for load.php. 96 | #modulesLoadURI: 'http://example.org/load.php' 97 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | READ THIS FIRST 2 | ======================= 3 | I don't want to deprecate this, it probably still works just fine. There's really better options out there though. I'm not trying to shill my blog, but I don't know where else to put this: 4 | https://hireryan.today/2021/08/20/running-single-node-kubernetes-with-persistent-data/ 5 | 6 | If you want a simple deployment paradigm with files you can access locally this is the way to go. I need to finish the series, but you can just use helm. 7 | 8 | 9 | Containerized Mediawiki 10 | ======================= 11 | 12 | Runs on Linux only. (kernel version 3.10+) - Only tested on Ubuntu 16.04 13 | 14 | ## Installation 15 | 16 | Run: 17 | ``` 18 | make init 19 | ``` 20 | 21 | Set variables in `.env` if you want to customize your install. Then run: 22 | ``` 23 | make config 24 | make up 25 | ``` 26 | 27 | ## Usage 28 | 29 | To restart the container, run: 30 | ``` 31 | make reup 32 | ``` 33 | 34 | To stop the container: 35 | ``` 36 | make down 37 | ``` 38 | 39 | To destroy the container: 40 | ``` 41 | make destroy 42 | ``` 43 | 44 | ## Freshly re-engineered! 45 | I just rebuilt everything to be a little less static. The upside is it's easier to pick your version and I have a lot less to maintain, the down side is that it's a little less "wow" factor and probably more prone to code rot. Still better than just time/feature rot I suppose. 46 | 47 | ## Whats Changed? 48 | 49 | * PHP and Parsoid are now runtime builds 50 | * These builds are now located in this repo at docker-mediawiki-build 51 | * Wiki initialization can be programmatic via environment variables 52 | 53 | The PHP image is based on laradock's php (Like, pretty aggressively. I added a few things, but I need to go trim the fat). The build file is for PHP 7.2. This shouldn't be a problem for mediawiki core, I think they backported 7.2 support to the 27 branch but don't quote me on that. If you run into issues open a bug and I can fix it a lot quicker now that I adopted (poached?) laradocks build structure. Or feel free to go grab a build file right from laradock and submit a pull after the needed adjustments. 54 | 55 | ## Auto install and setting your version 56 | In the .env file, there is a series of variables that are pretty self explanatory. AUTOINSTALL can be set to anything other than "false" and it will do the auto install. You could set it to "banana", and it would work. In fact, I hope you do. If you have not yet built your PHP image, it will build it at that time. 57 | 58 | ## Gotchas and stuff to be aware of 59 | First, if you do a manual install just remember the host for mysql is the service name in compose, so "mysql" is the host when prompted. Also, you may want to change the password in the compose file. 60 | 61 | The old version of this repo was nice because everything was pre built and you knew it would work. It's worked for the last year without me touching it. This is a bit more of a who knows? Did parsoid get updated, did the "localsettings" variable get changed? Does version X of VE or Mediawiki play nice with PHP version Y? This is always going to grab updated code though, and it's all prepackaged by mediawiki. It's easier to maintain and update and with any luck people will join in and we can build a nice little project around this. 62 | 63 | At the time of this writing, I just finished it and there was pretty much just a smoke test. I spun it up with and without auto install and made an edit. I fixed in the old wiki an issue with too many people using visual editor. I think if I recall it was tying up PHP connections or something. I have yet to look fully into the laradock (what this is now based off of) configurations. 64 | 65 | ## Contributions 66 | It's all right here in this repo now. Easy to access, easy to maintain. The only file modifications I make are now handled by runfirst.bash, and a little HEREDOC. The PHP build file is just a laradock file with git, pygments, and composer installed. If you have better bash-isms or cleaner structuring (which shouldn't be to hard given the current state :P) fork, adjust as desired, submit a pull. 67 | -------------------------------------------------------------------------------- /docker-mediawiki-build/php-fpm/xlaravel.pool.conf: -------------------------------------------------------------------------------- 1 | ; Unix user/group of processes 2 | ; Note: The user is mandatory. If the group is not set, the default user's group 3 | ; will be used. 4 | user = www-data 5 | group = www-data 6 | 7 | ; The address on which to accept FastCGI requests. 8 | ; Valid syntaxes are: 9 | ; 'ip.add.re.ss:port' - to listen on a TCP socket to a specific address on 10 | ; a specific port; 11 | ; 'port' - to listen on a TCP socket to all addresses on a 12 | ; specific port; 13 | ; '/path/to/unix/socket' - to listen on a unix socket. 14 | ; Note: This value is mandatory. 15 | listen = 0.0.0.0:9000 16 | 17 | ; Choose how the process manager will control the number of child processes. 18 | ; Possible Values: 19 | ; static - a fixed number (pm.max_children) of child processes; 20 | ; dynamic - the number of child processes are set dynamically based on the 21 | ; following directives. With this process management, there will be 22 | ; always at least 1 children. 23 | ; pm.max_children - the maximum number of children that can 24 | ; be alive at the same time. 25 | ; pm.start_servers - the number of children created on startup. 26 | ; pm.min_spare_servers - the minimum number of children in 'idle' 27 | ; state (waiting to process). If the number 28 | ; of 'idle' processes is less than this 29 | ; number then some children will be created. 30 | ; pm.max_spare_servers - the maximum number of children in 'idle' 31 | ; state (waiting to process). If the number 32 | ; of 'idle' processes is greater than this 33 | ; number then some children will be killed. 34 | ; ondemand - no children are created at startup. Children will be forked when 35 | ; new requests will connect. The following parameter are used: 36 | ; pm.max_children - the maximum number of children that 37 | ; can be alive at the same time. 38 | ; pm.process_idle_timeout - The number of seconds after which 39 | ; an idle process will be killed. 40 | ; Note: This value is mandatory. 41 | pm = dynamic 42 | 43 | ; The number of child processes to be created when pm is set to 'static' and the 44 | ; maximum number of child processes when pm is set to 'dynamic' or 'ondemand'. 45 | ; This value sets the limit on the number of simultaneous requests that will be 46 | ; served. Equivalent to the ApacheMaxClients directive with mpm_prefork. 47 | ; Equivalent to the PHP_FCGI_CHILDREN environment variable in the original PHP 48 | ; CGI. The below defaults are based on a server without much resources. Don't 49 | ; forget to tweak pm.* to fit your needs. 50 | ; Note: Used when pm is set to 'static', 'dynamic' or 'ondemand' 51 | ; Note: This value is mandatory. 52 | pm.max_children = 20 53 | 54 | ; The number of child processes created on startup. 55 | ; Note: Used only when pm is set to 'dynamic' 56 | ; Default Value: min_spare_servers + (max_spare_servers - min_spare_servers) / 2 57 | pm.start_servers = 2 58 | 59 | ; The desired minimum number of idle server processes. 60 | ; Note: Used only when pm is set to 'dynamic' 61 | ; Note: Mandatory when pm is set to 'dynamic' 62 | pm.min_spare_servers = 1 63 | 64 | ; The desired maximum number of idle server processes. 65 | ; Note: Used only when pm is set to 'dynamic' 66 | ; Note: Mandatory when pm is set to 'dynamic' 67 | pm.max_spare_servers = 3 68 | 69 | ;--------------------- 70 | 71 | ; Make specific Docker environment variables available to PHP 72 | env[DB_1_ENV_MYSQL_DATABASE] = $DB_1_ENV_MYSQL_DATABASE 73 | env[DB_1_ENV_MYSQL_USER] = $DB_1_ENV_MYSQL_USER 74 | env[DB_1_ENV_MYSQL_PASSWORD] = $DB_1_ENV_MYSQL_PASSWORD 75 | 76 | catch_workers_output = yes 77 | -------------------------------------------------------------------------------- /distribution-files/nginx/win-utf: -------------------------------------------------------------------------------- 1 | 2 | # This map is not a full windows-1251 <> utf8 map: it does not 3 | # contain Serbian and Macedonian letters. If you need a full map, 4 | # use contrib/unicode2nginx/win-utf map instead. 5 | 6 | charset_map windows-1251 utf-8 { 7 | 8 | 82 E2809A ; # single low-9 quotation mark 9 | 10 | 84 E2809E ; # double low-9 quotation mark 11 | 85 E280A6 ; # ellipsis 12 | 86 E280A0 ; # dagger 13 | 87 E280A1 ; # double dagger 14 | 88 E282AC ; # euro 15 | 89 E280B0 ; # per mille 16 | 17 | 91 E28098 ; # left single quotation mark 18 | 92 E28099 ; # right single quotation mark 19 | 93 E2809C ; # left double quotation mark 20 | 94 E2809D ; # right double quotation mark 21 | 95 E280A2 ; # bullet 22 | 96 E28093 ; # en dash 23 | 97 E28094 ; # em dash 24 | 25 | 99 E284A2 ; # trade mark sign 26 | 27 | A0 C2A0 ; #   28 | A1 D18E ; # capital Byelorussian short U 29 | A2 D19E ; # small Byelorussian short u 30 | 31 | A4 C2A4 ; # currency sign 32 | A5 D290 ; # capital Ukrainian soft G 33 | A6 C2A6 ; # borken bar 34 | A7 C2A7 ; # section sign 35 | A8 D081 ; # capital YO 36 | A9 C2A9 ; # (C) 37 | AA D084 ; # capital Ukrainian YE 38 | AB C2AB ; # left-pointing double angle quotation mark 39 | AC C2AC ; # not sign 40 | AD C2AD ; # soft hypen 41 | AE C2AE ; # (R) 42 | AF D087 ; # capital Ukrainian YI 43 | 44 | B0 C2B0 ; # ° 45 | B1 C2B1 ; # plus-minus sign 46 | B2 D086 ; # capital Ukrainian I 47 | B3 D196 ; # small Ukrainian i 48 | B4 D291 ; # small Ukrainian soft g 49 | B5 C2B5 ; # micro sign 50 | B6 C2B6 ; # pilcrow sign 51 | B7 C2B7 ; # · 52 | B8 D191 ; # small yo 53 | B9 E28496 ; # numero sign 54 | BA D194 ; # small Ukrainian ye 55 | BB C2BB ; # right-pointing double angle quotation mark 56 | 57 | BF D197 ; # small Ukrainian yi 58 | 59 | C0 D090 ; # capital A 60 | C1 D091 ; # capital B 61 | C2 D092 ; # capital V 62 | C3 D093 ; # capital G 63 | C4 D094 ; # capital D 64 | C5 D095 ; # capital YE 65 | C6 D096 ; # capital ZH 66 | C7 D097 ; # capital Z 67 | C8 D098 ; # capital I 68 | C9 D099 ; # capital J 69 | CA D09A ; # capital K 70 | CB D09B ; # capital L 71 | CC D09C ; # capital M 72 | CD D09D ; # capital N 73 | CE D09E ; # capital O 74 | CF D09F ; # capital P 75 | 76 | D0 D0A0 ; # capital R 77 | D1 D0A1 ; # capital S 78 | D2 D0A2 ; # capital T 79 | D3 D0A3 ; # capital U 80 | D4 D0A4 ; # capital F 81 | D5 D0A5 ; # capital KH 82 | D6 D0A6 ; # capital TS 83 | D7 D0A7 ; # capital CH 84 | D8 D0A8 ; # capital SH 85 | D9 D0A9 ; # capital SHCH 86 | DA D0AA ; # capital hard sign 87 | DB D0AB ; # capital Y 88 | DC D0AC ; # capital soft sign 89 | DD D0AD ; # capital E 90 | DE D0AE ; # capital YU 91 | DF D0AF ; # capital YA 92 | 93 | E0 D0B0 ; # small a 94 | E1 D0B1 ; # small b 95 | E2 D0B2 ; # small v 96 | E3 D0B3 ; # small g 97 | E4 D0B4 ; # small d 98 | E5 D0B5 ; # small ye 99 | E6 D0B6 ; # small zh 100 | E7 D0B7 ; # small z 101 | E8 D0B8 ; # small i 102 | E9 D0B9 ; # small j 103 | EA D0BA ; # small k 104 | EB D0BB ; # small l 105 | EC D0BC ; # small m 106 | ED D0BD ; # small n 107 | EE D0BE ; # small o 108 | EF D0BF ; # small p 109 | 110 | F0 D180 ; # small r 111 | F1 D181 ; # small s 112 | F2 D182 ; # small t 113 | F3 D183 ; # small u 114 | F4 D184 ; # small f 115 | F5 D185 ; # small kh 116 | F6 D186 ; # small ts 117 | F7 D187 ; # small ch 118 | F8 D188 ; # small sh 119 | F9 D189 ; # small shch 120 | FA D18A ; # small hard sign 121 | FB D18B ; # small y 122 | FC D18C ; # small soft sign 123 | FD D18D ; # small e 124 | FE D18E ; # small yu 125 | FF D18F ; # small ya 126 | } 127 | -------------------------------------------------------------------------------- /distribution-files/nginx/mime.types: -------------------------------------------------------------------------------- 1 | 2 | types { 3 | text/html html htm shtml; 4 | text/css css; 5 | text/xml xml; 6 | image/gif gif; 7 | image/jpeg jpeg jpg; 8 | application/javascript js; 9 | application/atom+xml atom; 10 | application/rss+xml rss; 11 | 12 | text/mathml mml; 13 | text/plain txt; 14 | text/vnd.sun.j2me.app-descriptor jad; 15 | text/vnd.wap.wml wml; 16 | text/x-component htc; 17 | 18 | image/png png; 19 | image/tiff tif tiff; 20 | image/vnd.wap.wbmp wbmp; 21 | image/x-icon ico; 22 | image/x-jng jng; 23 | image/x-ms-bmp bmp; 24 | image/svg+xml svg svgz; 25 | image/webp webp; 26 | 27 | application/font-woff woff; 28 | application/java-archive jar war ear; 29 | application/json json; 30 | application/mac-binhex40 hqx; 31 | application/msword doc; 32 | application/pdf pdf; 33 | application/postscript ps eps ai; 34 | application/rtf rtf; 35 | application/vnd.apple.mpegurl m3u8; 36 | application/vnd.ms-excel xls; 37 | application/vnd.ms-fontobject eot; 38 | application/vnd.ms-powerpoint ppt; 39 | application/vnd.wap.wmlc wmlc; 40 | application/vnd.google-earth.kml+xml kml; 41 | application/vnd.google-earth.kmz kmz; 42 | application/x-7z-compressed 7z; 43 | application/x-cocoa cco; 44 | application/x-java-archive-diff jardiff; 45 | application/x-java-jnlp-file jnlp; 46 | application/x-makeself run; 47 | application/x-perl pl pm; 48 | application/x-pilot prc pdb; 49 | application/x-rar-compressed rar; 50 | application/x-redhat-package-manager rpm; 51 | application/x-sea sea; 52 | application/x-shockwave-flash swf; 53 | application/x-stuffit sit; 54 | application/x-tcl tcl tk; 55 | application/x-x509-ca-cert der pem crt; 56 | application/x-xpinstall xpi; 57 | application/xhtml+xml xhtml; 58 | application/xspf+xml xspf; 59 | application/zip zip; 60 | 61 | application/octet-stream bin exe dll; 62 | application/octet-stream deb; 63 | application/octet-stream dmg; 64 | application/octet-stream iso img; 65 | application/octet-stream msi msp msm; 66 | 67 | application/vnd.openxmlformats-officedocument.wordprocessingml.document docx; 68 | application/vnd.openxmlformats-officedocument.spreadsheetml.sheet xlsx; 69 | application/vnd.openxmlformats-officedocument.presentationml.presentation pptx; 70 | 71 | audio/midi mid midi kar; 72 | audio/mpeg mp3; 73 | audio/ogg ogg; 74 | audio/x-m4a m4a; 75 | audio/x-realaudio ra; 76 | 77 | video/3gpp 3gpp 3gp; 78 | video/mp2t ts; 79 | video/mp4 mp4; 80 | video/mpeg mpeg mpg; 81 | video/quicktime mov; 82 | video/webm webm; 83 | video/x-flv flv; 84 | video/x-m4v m4v; 85 | video/x-mng mng; 86 | video/x-ms-asf asx asf; 87 | video/x-ms-wmv wmv; 88 | video/x-msvideo avi; 89 | } 90 | -------------------------------------------------------------------------------- /runfirst.bash: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | if [[ $EUID -ne 0 ]]; then 3 | echo "This script must be run as root" 1>&2 4 | exit 1 5 | fi 6 | DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" 7 | 8 | source .env 9 | 10 | #system prep 11 | command -v docker >/dev/null 2>&1 || { curl -s https://get.docker.com/ | bash; } 12 | command -v pip >/dev/null 2>&1 || { \curl -L https://bootstrap.pypa.io/get-pip.py | python || \curl -L https://bootstrap.pypa.io/get-pip.py | python3; } 13 | command -v docker-compose >/dev/null 2>&1 || { pip install docker-compose; } 14 | getent passwd www-data >/dev/null 2>&1 || { useradd www-data; } 15 | #I don't want to add OS detection here. These will be on most systems, I think the docker install does curl at the least. 16 | command -v curl >/dev/null 2>&1 || { echo "please install curl and rerun this script"; exit 1; } 17 | command -v wget >/dev/null 2>&1 || { echo "please install wget and rerun this script"; exit 1; } 18 | 19 | #Get Software 20 | if [[ -d "$DIR/distribution-files/mediawiki" ]]; then 21 | printf "\nMediawiki has already been initialized. Please remove $DIR/distribution-files/mediawiki if you would like to reninitialze the platform \n\n" 22 | exit 1 23 | fi 24 | 25 | #I'm not a hugefan of this nasty bash block, but I don't want to get into crazy awkisms and 26 | #They don't provide a real nice way to just grab a latest release thats not nightly 27 | MEDIAWIKISEMVAR=$(curl -s https://releases.wikimedia.org/mediawiki/$MEDIAWIKIVERSION/ | grep -o \<.*[0-9]*\-[0-9]*\-[0-9]* \ 28 | | grep -v sig | grep -v core | grep -v '\-rc' | grep tar.gz \ 29 | | awk '{print $7, $6}' | sort -rn | head -1 \ 30 | | grep -o \>mediawiki-.*.tar.gz | sed 's/>//g') 31 | 32 | wget -qO- https://releases.wikimedia.org/mediawiki/$MEDIAWIKIVERSION/$MEDIAWIKISEMVAR | tar xvz -C $DIR/distribution-files/ 33 | 34 | mv $DIR/distribution-files/$(sed 's/.tar.gz//g' <(echo $MEDIAWIKISEMVAR)) $DIR/distribution-files/mediawiki 35 | 36 | #And again, but now with the extension 37 | MEDIAWIKIREL=$(sed 's/\./_/g' <(echo $MEDIAWIKIVERSION)) 38 | #Their website randomly stopped playing nice with curl after working all day. Had to add cruft to make it work. 39 | VEXTENTION=$(curl -s 'https://extdist.wmflabs.org/dist/extensions/' -H 'dnt: 1' -H 'accept-encoding: gzip, deflate, br' -H 'accept-language: en-US,en;q=0.9' -H 'upgrade-insecure-requests: 1' -H 'user-agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.108 Safari/537.36' -H 'accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8' -H 'cache-control: max-age=0' -H 'authority: extdist.wmflabs.org' --compressed | grep VisualEditor | grep $MEDIAWIKIREL | grep -o \>Visual.*.tar.gz | sed 's/>//g') 40 | 41 | wget -qO- https://extdist.wmflabs.org/dist/extensions/$VEXTENTION | tar xvz -C $DIR/distribution-files/mediawiki/extensions/ 42 | 43 | if [[ $? != 0 ]]; then 44 | clear 45 | printf "\nIssue with $VEXTENTION download \n\n" 46 | exit 1 47 | fi 48 | 49 | clear 50 | printf "\nWiki Initialized \n\n" 51 | 52 | #Perms 53 | find $DIR/distribution-files/mediawiki -type d -exec chmod 755 {} + 54 | find $DIR/distribution-files/mediawiki -type f -exec chmod 644 {} + 55 | chown -R www-data $DIR/distribution-files/mediawiki 56 | 57 | #I don't want to distribute a file anymore. So patching will take place on the fly. VE, mysql host, and Local settings placement will be covered here. 58 | 59 | #VE settings 60 | cat > $DIR/tmpfile < 'parsoid:8000', 90 | 'domain' => 'wiki', 91 | 'forwardCookies' => true 92 | ); 93 | 94 | \$wgSessionsInObjectCache = true; 95 | 96 | EOD; 97 | 98 | \$file = "/var/www/mediawiki/LocalSettings.php"; 99 | if (!file_exists(\$file)) { 100 | if (is_writable("/var/www/mediawiki/")) { 101 | \$handle = fopen(\$file, 'w') or die('Cannot open file: '.\$file); 102 | fwrite(\$handle, \$localSettings); 103 | } 104 | } 105 | 106 | return \$localSettings; 107 | HEREDOC 108 | 109 | sed -i "/return \$localSettings/ { 110 | r $DIR/tmpfile 111 | d 112 | }" $DIR/distribution-files/mediawiki/includes/installer/LocalSettingsGenerator.php 113 | rm $DIR/tmpfile 114 | 115 | 116 | if [[ $AUTOINSTALL != "false" ]]; then 117 | docker-compose -f $DIR/autoinstall.yml up -d --force-recreate 118 | 119 | echo "sleeping 15 for mysql init" 120 | secs=15 121 | while [ $secs -gt 0 ]; do 122 | echo -ne "$secs\033[0K\r" 123 | sleep 1 124 | : $((secs--)) 125 | done 126 | 127 | docker exec -ti no-one-else-should-be-using-this-name php mediawiki/maintenance/install.php --dbuser="root" --dbpass="$DBPASS" --dbname="$DBNAME" --dbserver="mysql" --installdbuser="root" --installdbpass="$DBPASS" --server="$SERVERURL" --lang=en --pass="$ADMINPASSWORD" "$WIKINAME" "$ADMINUSER" 128 | 129 | docker rm -f no-one-else-should-be-using-this-name 130 | docker rm -f no-one-else-should-be-using-this-name-or-this 131 | 132 | clear 133 | printf "\nYour wiki has been created, now you can run:\nmake up \n\n" 134 | fi 135 | -------------------------------------------------------------------------------- /docker-mediawiki-build/php-fpm/Dockerfile-72: -------------------------------------------------------------------------------- 1 | # 2 | #-------------------------------------------------------------------------- 3 | # Image Setup 4 | #-------------------------------------------------------------------------- 5 | # 6 | # To edit the 'php-fpm' base Image, visit its repository on Github 7 | # https://github.com/Laradock/php-fpm 8 | # 9 | # To change its version, see the available Tags on the Docker Hub: 10 | # https://hub.docker.com/r/laradock/php-fpm/tags/ 11 | # 12 | # Note: Base Image name format {image-tag}-{php-version} 13 | # 14 | 15 | FROM laradock/php-fpm:2.0-72 16 | 17 | MAINTAINER Mahmoud Zalt 18 | 19 | # 20 | #-------------------------------------------------------------------------- 21 | # Mandatory Software's Installation 22 | #-------------------------------------------------------------------------- 23 | # 24 | # Mandatory Software's such as ("mcrypt", "pdo_mysql", "libssl-dev", ....) 25 | # are installed on the base image 'laradock/php-fpm' image. If you want 26 | # to add more Software's or remove existing one, you need to edit the 27 | # base image (https://github.com/Laradock/php-fpm). 28 | # 29 | 30 | # 31 | #-------------------------------------------------------------------------- 32 | # Optional Software's Installation 33 | #-------------------------------------------------------------------------- 34 | # 35 | # Optional Software's will only be installed if you set them to `true` 36 | # in the `docker-compose.yml` before the build. 37 | # Example: 38 | # - INSTALL_ZIP_ARCHIVE=true 39 | # 40 | 41 | ##################################### 42 | # SOAP: 43 | ##################################### 44 | 45 | ARG INSTALL_SOAP=false 46 | RUN if [ ${INSTALL_SOAP} = true ]; then \ 47 | # Install the soap extension 48 | apt-get update -yqq && \ 49 | apt-get -y install libxml2-dev php-soap && \ 50 | docker-php-ext-install soap \ 51 | ;fi 52 | 53 | ##################################### 54 | # pgsql 55 | ##################################### 56 | 57 | ARG INSTALL_PGSQL=false 58 | RUN if [ ${INSTALL_PGSQL} = true ]; then \ 59 | # Install the pgsql extension 60 | apt-get update -yqq && \ 61 | docker-php-ext-install pgsql \ 62 | ;fi 63 | 64 | ##################################### 65 | # pgsql client 66 | ##################################### 67 | 68 | ARG INSTALL_PG_CLIENT=false 69 | RUN if [ ${INSTALL_PG_CLIENT} = true ]; then \ 70 | # Create folders if not exists (https://github.com/tianon/docker-brew-debian/issues/65) 71 | mkdir -p /usr/share/man/man1 && \ 72 | mkdir -p /usr/share/man/man7 && \ 73 | # Install the pgsql client 74 | apt-get update -yqq && \ 75 | apt-get install -y postgresql-client \ 76 | ;fi 77 | 78 | ##################################### 79 | # xDebug: 80 | ##################################### 81 | 82 | ARG INSTALL_XDEBUG=false 83 | RUN if [ ${INSTALL_XDEBUG} = true ]; then \ 84 | # Install the xdebug extension 85 | pecl install xdebug && \ 86 | docker-php-ext-enable xdebug \ 87 | ;fi 88 | 89 | # Copy xdebug configuration for remote debugging 90 | COPY ./xdebug.ini /usr/local/etc/php/conf.d/xdebug.ini 91 | 92 | ##################################### 93 | # Blackfire: 94 | ##################################### 95 | 96 | ARG INSTALL_BLACKFIRE=false 97 | RUN if [ ${INSTALL_XDEBUG} = false -a ${INSTALL_BLACKFIRE} = true ]; then \ 98 | version=$(php -r "echo PHP_MAJOR_VERSION.PHP_MINOR_VERSION;") \ 99 | && curl -A "Docker" -o /tmp/blackfire-probe.tar.gz -D - -L -s https://blackfire.io/api/v1/releases/probe/php/linux/amd64/$version \ 100 | && tar zxpf /tmp/blackfire-probe.tar.gz -C /tmp \ 101 | && mv /tmp/blackfire-*.so $(php -r "echo ini_get('extension_dir');")/blackfire.so \ 102 | && printf "extension=blackfire.so\nblackfire.agent_socket=tcp://blackfire:8707\n" > $PHP_INI_DIR/conf.d/blackfire.ini \ 103 | ;fi 104 | 105 | ##################################### 106 | # PHP REDIS EXTENSION FOR PHP 7.0 107 | ##################################### 108 | 109 | ARG INSTALL_PHPREDIS=false 110 | RUN if [ ${INSTALL_PHPREDIS} = true ]; then \ 111 | # Install Php Redis Extension 112 | printf "\n" | pecl install -o -f redis \ 113 | && rm -rf /tmp/pear \ 114 | && docker-php-ext-enable redis \ 115 | ;fi 116 | 117 | ##################################### 118 | # Swoole EXTENSION FOR PHP 7 119 | ##################################### 120 | 121 | ARG INSTALL_SWOOLE=false 122 | RUN if [ ${INSTALL_SWOOLE} = true ]; then \ 123 | # Install Php Swoole Extension 124 | pecl install swoole \ 125 | && docker-php-ext-enable swoole \ 126 | ;fi 127 | 128 | ##################################### 129 | # MongoDB: 130 | ##################################### 131 | 132 | ARG INSTALL_MONGO=false 133 | RUN if [ ${INSTALL_MONGO} = true ]; then \ 134 | # Install the mongodb extension 135 | pecl install mongodb && \ 136 | docker-php-ext-enable mongodb \ 137 | ;fi 138 | 139 | ##################################### 140 | # AMQP: 141 | ##################################### 142 | 143 | ARG INSTALL_AMQP=false 144 | RUN if [ ${INSTALL_AMQP} = true ]; then \ 145 | apt-get update && \ 146 | apt-get install librabbitmq-dev -y && \ 147 | # Install the amqp extension 148 | pecl install amqp && \ 149 | docker-php-ext-enable amqp \ 150 | ;fi 151 | 152 | ##################################### 153 | # ZipArchive: 154 | ##################################### 155 | 156 | ARG INSTALL_ZIP_ARCHIVE=false 157 | RUN if [ ${INSTALL_ZIP_ARCHIVE} = true ]; then \ 158 | # Install the zip extension 159 | docker-php-ext-install zip \ 160 | ;fi 161 | 162 | ##################################### 163 | # bcmath: 164 | ##################################### 165 | 166 | ARG INSTALL_BCMATH=false 167 | RUN if [ ${INSTALL_BCMATH} = true ]; then \ 168 | # Install the bcmath extension 169 | docker-php-ext-install bcmath \ 170 | ;fi 171 | 172 | ##################################### 173 | # GMP (GNU Multiple Precision): 174 | ##################################### 175 | 176 | ARG INSTALL_GMP=false 177 | RUN if [ ${INSTALL_GMP} = true ]; then \ 178 | # Install the GMP extension 179 | apt-get update -yqq && \ 180 | apt-get install -y libgmp-dev && \ 181 | docker-php-ext-install gmp \ 182 | ;fi 183 | 184 | ##################################### 185 | # PHP Memcached: 186 | ##################################### 187 | 188 | ARG INSTALL_MEMCACHED=false 189 | RUN if [ ${INSTALL_MEMCACHED} = true ]; then \ 190 | # Install the php memcached extension 191 | curl -L -o /tmp/memcached.tar.gz "https://github.com/php-memcached-dev/php-memcached/archive/php7.tar.gz" \ 192 | && mkdir -p memcached \ 193 | && tar -C memcached -zxvf /tmp/memcached.tar.gz --strip 1 \ 194 | && ( \ 195 | cd memcached \ 196 | && phpize \ 197 | && ./configure \ 198 | && make -j$(nproc) \ 199 | && make install \ 200 | ) \ 201 | && rm -r memcached \ 202 | && rm /tmp/memcached.tar.gz \ 203 | && docker-php-ext-enable memcached \ 204 | ;fi 205 | 206 | ##################################### 207 | # Exif: 208 | ##################################### 209 | 210 | ARG INSTALL_EXIF=false 211 | RUN if [ ${INSTALL_EXIF} = true ]; then \ 212 | # Enable Exif PHP extentions requirements 213 | docker-php-ext-install exif \ 214 | ;fi 215 | 216 | ##################################### 217 | # PHP Aerospike: 218 | ##################################### 219 | 220 | ARG INSTALL_AEROSPIKE=false 221 | ENV INSTALL_AEROSPIKE ${INSTALL_AEROSPIKE} 222 | 223 | # Copy aerospike configration for remote debugging 224 | COPY ./aerospike.ini /usr/local/etc/php/conf.d/aerospike.ini 225 | 226 | RUN if [ ${INSTALL_AEROSPIKE} = true ]; then \ 227 | # Fix dependencies for PHPUnit within aerospike extension 228 | apt-get update -yqq && \ 229 | apt-get -y install sudo wget && \ 230 | 231 | # Install the php aerospike extension (using 7.2.0-in-progress branch until support for 7.2 on master) 232 | curl -L -o /tmp/aerospike-client-php.tar.gz "https://github.com/aerospike/aerospike-client-php/archive/7.2.0-in-progress.tar.gz" \ 233 | && mkdir -p aerospike-client-php \ 234 | && tar -C aerospike-client-php -zxvf /tmp/aerospike-client-php.tar.gz --strip 1 \ 235 | && ( \ 236 | cd aerospike-client-php/src \ 237 | && phpize \ 238 | && ./build.sh \ 239 | && make install \ 240 | ) \ 241 | && rm /tmp/aerospike-client-php.tar.gz \ 242 | ;fi 243 | 244 | RUN if [ ${INSTALL_AEROSPIKE} = false ]; then \ 245 | rm /usr/local/etc/php/conf.d/aerospike.ini \ 246 | ;fi 247 | 248 | ##################################### 249 | # Opcache: 250 | ##################################### 251 | 252 | ARG INSTALL_OPCACHE=false 253 | RUN if [ ${INSTALL_OPCACHE} = true ]; then \ 254 | docker-php-ext-install opcache \ 255 | ;fi 256 | 257 | # Copy opcache configration 258 | COPY ./opcache.ini /usr/local/etc/php/conf.d/opcache.ini 259 | 260 | ##################################### 261 | # Mysqli Modifications: 262 | ##################################### 263 | 264 | ARG INSTALL_MYSQLI=false 265 | RUN if [ ${INSTALL_MYSQLI} = true ]; then \ 266 | docker-php-ext-install mysqli \ 267 | ;fi 268 | 269 | ##################################### 270 | # Tokenizer Modifications: 271 | ##################################### 272 | 273 | ARG INSTALL_TOKENIZER=false 274 | RUN if [ ${INSTALL_TOKENIZER} = true ]; then \ 275 | docker-php-ext-install tokenizer \ 276 | ;fi 277 | 278 | ##################################### 279 | # Human Language and Character Encoding Support: 280 | ##################################### 281 | 282 | ARG INSTALL_INTL=false 283 | RUN if [ ${INSTALL_INTL} = true ]; then \ 284 | # Install intl and requirements 285 | apt-get update -yqq && \ 286 | apt-get install -y zlib1g-dev libicu-dev g++ && \ 287 | docker-php-ext-configure intl && \ 288 | docker-php-ext-install intl \ 289 | ;fi 290 | 291 | ##################################### 292 | # GHOSTSCRIPT: 293 | ##################################### 294 | 295 | ARG INSTALL_GHOSTSCRIPT=false 296 | RUN if [ ${INSTALL_GHOSTSCRIPT} = true ]; then \ 297 | # Install the ghostscript extension 298 | # for PDF editing 299 | apt-get update -yqq \ 300 | && apt-get install -y \ 301 | poppler-utils \ 302 | ghostscript \ 303 | ;fi 304 | 305 | ##################################### 306 | # LDAP: 307 | ##################################### 308 | 309 | ARG INSTALL_LDAP=false 310 | RUN if [ ${INSTALL_LDAP} = true ]; then \ 311 | apt-get update -yqq && \ 312 | apt-get install -y libldap2-dev && \ 313 | docker-php-ext-configure ldap --with-libdir=lib/x86_64-linux-gnu/ && \ 314 | docker-php-ext-install ldap \ 315 | ;fi 316 | 317 | ##################################### 318 | # SQL SERVER: 319 | ##################################### 320 | 321 | ARG INSTALL_MSSQL=false 322 | ENV INSTALL_MSSQL ${INSTALL_MSSQL} 323 | RUN if [ ${INSTALL_MSSQL} = true ]; then \ 324 | ##################################### 325 | # Ref from https://github.com/Microsoft/msphpsql/wiki/Dockerfile-for-adding-pdo_sqlsrv-and-sqlsrv-to-official-php-image 326 | ##################################### 327 | # Add Microsoft repo for Microsoft ODBC Driver 13 for Linux 328 | apt-get update -yqq && apt-get install -y apt-transport-https gnupg \ 329 | && curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add - \ 330 | && curl https://packages.microsoft.com/config/debian/8/prod.list > /etc/apt/sources.list.d/mssql-release.list \ 331 | && apt-get update -yqq \ 332 | 333 | # Install Dependencies 334 | && ACCEPT_EULA=Y apt-get install -y unixodbc unixodbc-dev libgss3 odbcinst msodbcsql locales \ 335 | && echo "en_US.UTF-8 UTF-8" > /etc/locale.gen && locale-gen \ 336 | 337 | # Install pdo_sqlsrv and sqlsrv from PECL. Replace pdo_sqlsrv-4.1.8preview with preferred version. 338 | && pecl install pdo_sqlsrv-4.1.8preview sqlsrv-4.1.8preview \ 339 | && docker-php-ext-enable pdo_sqlsrv sqlsrv \ 340 | ;fi 341 | 342 | ##################################### 343 | # Image optimizers: 344 | ##################################### 345 | USER root 346 | ARG INSTALL_IMAGE_OPTIMIZERS=false 347 | ENV INSTALL_IMAGE_OPTIMIZERS ${INSTALL_IMAGE_OPTIMIZERS} 348 | RUN if [ ${INSTALL_IMAGE_OPTIMIZERS} = true ]; then \ 349 | apt-get update -yqq && \ 350 | apt-get install -y --force-yes jpegoptim optipng pngquant gifsicle \ 351 | ;fi 352 | 353 | ##################################### 354 | # ImageMagick: 355 | ##################################### 356 | USER root 357 | ARG INSTALL_IMAGEMAGICK=false 358 | ENV INSTALL_IMAGEMAGICK ${INSTALL_IMAGEMAGICK} 359 | RUN if [ ${INSTALL_IMAGEMAGICK} = true ]; then \ 360 | apt-get update -y && \ 361 | apt-get install -y libmagickwand-dev imagemagick && \ 362 | pecl install imagick && \ 363 | docker-php-ext-enable imagick \ 364 | ;fi 365 | 366 | ##################################### 367 | # IMAP: 368 | ##################################### 369 | ARG INSTALL_IMAP=false 370 | ENV INSTALL_IMAP ${INSTALL_IMAP} 371 | RUN if [ ${INSTALL_IMAP} = true ]; then \ 372 | apt-get update && \ 373 | apt-get install -y libc-client-dev libkrb5-dev && \ 374 | rm -r /var/lib/apt/lists/* && \ 375 | docker-php-ext-configure imap --with-kerberos --with-imap-ssl && \ 376 | docker-php-ext-install imap \ 377 | ;fi 378 | 379 | 380 | ##################################### 381 | # Git: 382 | ##################################### 383 | ARG INSTALL_GIT=true 384 | ENV INSTALL_GIT ${INSTALL_GIT} 385 | RUN if [ ${INSTALL_GIT} = true ]; then \ 386 | apt-get update && \ 387 | apt-get install -y git && \ 388 | rm -r /var/lib/apt/lists/* \ 389 | ;fi 390 | 391 | 392 | ##################################### 393 | # COMPOSER: 394 | ##################################### 395 | RUN if [ true = true ]; then \ 396 | php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');" && \ 397 | php composer-setup.php --install-dir=/bin --filename=composer && \ 398 | php -r "unlink('composer-setup.php');" \ 399 | ;fi 400 | 401 | 402 | ##################################### 403 | # Python: 404 | ##################################### 405 | RUN if [ true = true ]; then \ 406 | apt-get update && \ 407 | apt-get install -y python && \ 408 | rm -r /var/lib/apt/lists/* \ 409 | ;fi 410 | 411 | 412 | ##################################### 413 | # Pygments: 414 | ##################################### 415 | ADD https://bootstrap.pypa.io/get-pip.py / 416 | RUN python /get-pip.py && \ 417 | pip install Pygments 418 | 419 | 420 | ##################################### 421 | # Check PHP version: 422 | ##################################### 423 | 424 | RUN php -v | head -n 1 | grep -q "PHP 7.2." 425 | 426 | 427 | # 428 | #-------------------------------------------------------------------------- 429 | # Final Touch 430 | #-------------------------------------------------------------------------- 431 | # 432 | 433 | ADD ./laravel.ini /usr/local/etc/php/conf.d 434 | ADD ./xlaravel.pool.conf /usr/local/etc/php-fpm.d/ 435 | 436 | #RUN rm -r /var/lib/apt/lists/* 437 | 438 | RUN usermod -u 1000 www-data 439 | 440 | WORKDIR /var/www 441 | 442 | CMD ["php-fpm"] 443 | 444 | EXPOSE 9000 445 | -------------------------------------------------------------------------------- /docker-mediawiki-build/php-fpm/php72.ini: -------------------------------------------------------------------------------- 1 | [PHP] 2 | 3 | ;;;;;;;;;;;;;;;;;;; 4 | ; About php.ini ; 5 | ;;;;;;;;;;;;;;;;;;; 6 | ; PHP's initialization file, generally called php.ini, is responsible for 7 | ; configuring many of the aspects of PHP's behavior. 8 | 9 | ; PHP attempts to find and load this configuration from a number of locations. 10 | ; The following is a summary of its search order: 11 | ; 1. SAPI module specific location. 12 | ; 2. The PHPRC environment variable. (As of PHP 5.2.0) 13 | ; 3. A number of predefined registry keys on Windows (As of PHP 5.2.0) 14 | ; 4. Current working directory (except CLI) 15 | ; 5. The web server's directory (for SAPI modules), or directory of PHP 16 | ; (otherwise in Windows) 17 | ; 6. The directory from the --with-config-file-path compile time option, or the 18 | ; Windows directory (C:\windows or C:\winnt) 19 | ; See the PHP docs for more specific information. 20 | ; http://php.net/configuration.file 21 | 22 | ; The syntax of the file is extremely simple. Whitespace and lines 23 | ; beginning with a semicolon are silently ignored (as you probably guessed). 24 | ; Section headers (e.g. [Foo]) are also silently ignored, even though 25 | ; they might mean something in the future. 26 | 27 | ; Directives following the section heading [PATH=/www/mysite] only 28 | ; apply to PHP files in the /www/mysite directory. Directives 29 | ; following the section heading [HOST=www.example.com] only apply to 30 | ; PHP files served from www.example.com. Directives set in these 31 | ; special sections cannot be overridden by user-defined INI files or 32 | ; at runtime. Currently, [PATH=] and [HOST=] sections only work under 33 | ; CGI/FastCGI. 34 | ; http://php.net/ini.sections 35 | 36 | ; Directives are specified using the following syntax: 37 | ; directive = value 38 | ; Directive names are *case sensitive* - foo=bar is different from FOO=bar. 39 | ; Directives are variables used to configure PHP or PHP extensions. 40 | ; There is no name validation. If PHP can't find an expected 41 | ; directive because it is not set or is mistyped, a default value will be used. 42 | 43 | ; The value can be a string, a number, a PHP constant (e.g. E_ALL or M_PI), one 44 | ; of the INI constants (On, Off, True, False, Yes, No and None) or an expression 45 | ; (e.g. E_ALL & ~E_NOTICE), a quoted string ("bar"), or a reference to a 46 | ; previously set variable or directive (e.g. ${foo}) 47 | 48 | ; Expressions in the INI file are limited to bitwise operators and parentheses: 49 | ; | bitwise OR 50 | ; ^ bitwise XOR 51 | ; & bitwise AND 52 | ; ~ bitwise NOT 53 | ; ! boolean NOT 54 | 55 | ; Boolean flags can be turned on using the values 1, On, True or Yes. 56 | ; They can be turned off using the values 0, Off, False or No. 57 | 58 | ; An empty string can be denoted by simply not writing anything after the equal 59 | ; sign, or by using the None keyword: 60 | 61 | ; foo = ; sets foo to an empty string 62 | ; foo = None ; sets foo to an empty string 63 | ; foo = "None" ; sets foo to the string 'None' 64 | 65 | ; If you use constants in your value, and these constants belong to a 66 | ; dynamically loaded extension (either a PHP extension or a Zend extension), 67 | ; you may only use these constants *after* the line that loads the extension. 68 | 69 | ;;;;;;;;;;;;;;;;;;; 70 | ; About this file ; 71 | ;;;;;;;;;;;;;;;;;;; 72 | ; PHP comes packaged with two INI files. One that is recommended to be used 73 | ; in production environments and one that is recommended to be used in 74 | ; development environments. 75 | 76 | ; php.ini-production contains settings which hold security, performance and 77 | ; best practices at its core. But please be aware, these settings may break 78 | ; compatibility with older or less security conscience applications. We 79 | ; recommending using the production ini in production and testing environments. 80 | 81 | ; php.ini-development is very similar to its production variant, except it is 82 | ; much more verbose when it comes to errors. We recommend using the 83 | ; development version only in development environments, as errors shown to 84 | ; application users can inadvertently leak otherwise secure information. 85 | 86 | ; This is php.ini-production INI file. 87 | 88 | ;;;;;;;;;;;;;;;;;;; 89 | ; Quick Reference ; 90 | ;;;;;;;;;;;;;;;;;;; 91 | ; The following are all the settings which are different in either the production 92 | ; or development versions of the INIs with respect to PHP's default behavior. 93 | ; Please see the actual settings later in the document for more details as to why 94 | ; we recommend these changes in PHP's behavior. 95 | 96 | ; display_errors 97 | ; Default Value: On 98 | ; Development Value: On 99 | ; Production Value: Off 100 | 101 | ; display_startup_errors 102 | ; Default Value: Off 103 | ; Development Value: On 104 | ; Production Value: Off 105 | 106 | ; error_reporting 107 | ; Default Value: E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATED 108 | ; Development Value: E_ALL 109 | ; Production Value: E_ALL & ~E_DEPRECATED & ~E_STRICT 110 | 111 | ; html_errors 112 | ; Default Value: On 113 | ; Development Value: On 114 | ; Production value: On 115 | 116 | ; log_errors 117 | ; Default Value: Off 118 | ; Development Value: On 119 | ; Production Value: On 120 | 121 | ; max_input_time 122 | ; Default Value: -1 (Unlimited) 123 | ; Development Value: 60 (60 seconds) 124 | ; Production Value: 60 (60 seconds) 125 | 126 | ; output_buffering 127 | ; Default Value: Off 128 | ; Development Value: 4096 129 | ; Production Value: 4096 130 | 131 | ; register_argc_argv 132 | ; Default Value: On 133 | ; Development Value: Off 134 | ; Production Value: Off 135 | 136 | ; request_order 137 | ; Default Value: None 138 | ; Development Value: "GP" 139 | ; Production Value: "GP" 140 | 141 | ; session.gc_divisor 142 | ; Default Value: 100 143 | ; Development Value: 1000 144 | ; Production Value: 1000 145 | 146 | ; session.sid_bits_per_character 147 | ; Default Value: 4 148 | ; Development Value: 5 149 | ; Production Value: 5 150 | 151 | ; short_open_tag 152 | ; Default Value: On 153 | ; Development Value: Off 154 | ; Production Value: Off 155 | 156 | ; track_errors 157 | ; Default Value: Off 158 | ; Development Value: On 159 | ; Production Value: Off 160 | 161 | ; variables_order 162 | ; Default Value: "EGPCS" 163 | ; Development Value: "GPCS" 164 | ; Production Value: "GPCS" 165 | 166 | ;;;;;;;;;;;;;;;;;;;; 167 | ; php.ini Options ; 168 | ;;;;;;;;;;;;;;;;;;;; 169 | ; Name for user-defined php.ini (.htaccess) files. Default is ".user.ini" 170 | ;user_ini.filename = ".user.ini" 171 | 172 | ; To disable this feature set this option to empty value 173 | ;user_ini.filename = 174 | 175 | ; TTL for user-defined php.ini files (time-to-live) in seconds. Default is 300 seconds (5 minutes) 176 | ;user_ini.cache_ttl = 300 177 | 178 | ;;;;;;;;;;;;;;;;;;;; 179 | ; Language Options ; 180 | ;;;;;;;;;;;;;;;;;;;; 181 | 182 | ; Enable the PHP scripting language engine under Apache. 183 | ; http://php.net/engine 184 | engine = On 185 | 186 | ; This directive determines whether or not PHP will recognize code between 187 | ; tags as PHP source which should be processed as such. It is 188 | ; generally recommended that should be used and that this feature 189 | ; should be disabled, as enabling it may result in issues when generating XML 190 | ; documents, however this remains supported for backward compatibility reasons. 191 | ; Note that this directive does not control the would work. 323 | ; http://php.net/syntax-highlighting 324 | ;highlight.string = #DD0000 325 | ;highlight.comment = #FF9900 326 | ;highlight.keyword = #007700 327 | ;highlight.default = #0000BB 328 | ;highlight.html = #000000 329 | 330 | ; If enabled, the request will be allowed to complete even if the user aborts 331 | ; the request. Consider enabling it if executing long requests, which may end up 332 | ; being interrupted by the user or a browser timing out. PHP's default behavior 333 | ; is to disable this feature. 334 | ; http://php.net/ignore-user-abort 335 | ;ignore_user_abort = On 336 | 337 | ; Determines the size of the realpath cache to be used by PHP. This value should 338 | ; be increased on systems where PHP opens many files to reflect the quantity of 339 | ; the file operations performed. 340 | ; http://php.net/realpath-cache-size 341 | ;realpath_cache_size = 4096k 342 | 343 | ; Duration of time, in seconds for which to cache realpath information for a given 344 | ; file or directory. For systems with rarely changing files, consider increasing this 345 | ; value. 346 | ; http://php.net/realpath-cache-ttl 347 | ;realpath_cache_ttl = 120 348 | 349 | ; Enables or disables the circular reference collector. 350 | ; http://php.net/zend.enable-gc 351 | zend.enable_gc = On 352 | 353 | ; If enabled, scripts may be written in encodings that are incompatible with 354 | ; the scanner. CP936, Big5, CP949 and Shift_JIS are the examples of such 355 | ; encodings. To use this feature, mbstring extension must be enabled. 356 | ; Default: Off 357 | ;zend.multibyte = Off 358 | 359 | ; Allows to set the default encoding for the scripts. This value will be used 360 | ; unless "declare(encoding=...)" directive appears at the top of the script. 361 | ; Only affects if zend.multibyte is set. 362 | ; Default: "" 363 | ;zend.script_encoding = 364 | 365 | ;;;;;;;;;;;;;;;;; 366 | ; Miscellaneous ; 367 | ;;;;;;;;;;;;;;;;; 368 | 369 | ; Decides whether PHP may expose the fact that it is installed on the server 370 | ; (e.g. by adding its signature to the Web server header). It is no security 371 | ; threat in any way, but it makes it possible to determine whether you use PHP 372 | ; on your server or not. 373 | ; http://php.net/expose-php 374 | expose_php = On 375 | 376 | ;;;;;;;;;;;;;;;;;;; 377 | ; Resource Limits ; 378 | ;;;;;;;;;;;;;;;;;;; 379 | 380 | ; Maximum execution time of each script, in seconds 381 | ; http://php.net/max-execution-time 382 | ; Note: This directive is hardcoded to 0 for the CLI SAPI 383 | max_execution_time = 600 384 | 385 | ; Maximum amount of time each script may spend parsing request data. It's a good 386 | ; idea to limit this time on productions servers in order to eliminate unexpectedly 387 | ; long running scripts. 388 | ; Note: This directive is hardcoded to -1 for the CLI SAPI 389 | ; Default Value: -1 (Unlimited) 390 | ; Development Value: 60 (60 seconds) 391 | ; Production Value: 60 (60 seconds) 392 | ; http://php.net/max-input-time 393 | max_input_time = 120 394 | 395 | ; Maximum input variable nesting level 396 | ; http://php.net/max-input-nesting-level 397 | ;max_input_nesting_level = 64 398 | 399 | ; How many GET/POST/COOKIE input variables may be accepted 400 | ; max_input_vars = 1000 401 | 402 | ; Maximum amount of memory a script may consume (128MB) 403 | ; http://php.net/memory-limit 404 | memory_limit = 256M 405 | 406 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 407 | ; Error handling and logging ; 408 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; 409 | 410 | ; This directive informs PHP of which errors, warnings and notices you would like 411 | ; it to take action for. The recommended way of setting values for this 412 | ; directive is through the use of the error level constants and bitwise 413 | ; operators. The error level constants are below here for convenience as well as 414 | ; some common settings and their meanings. 415 | ; By default, PHP is set to take action on all errors, notices and warnings EXCEPT 416 | ; those related to E_NOTICE and E_STRICT, which together cover best practices and 417 | ; recommended coding standards in PHP. For performance reasons, this is the 418 | ; recommend error reporting setting. Your production server shouldn't be wasting 419 | ; resources complaining about best practices and coding standards. That's what 420 | ; development servers and development settings are for. 421 | ; Note: The php.ini-development file has this setting as E_ALL. This 422 | ; means it pretty much reports everything which is exactly what you want during 423 | ; development and early testing. 424 | ; 425 | ; Error Level Constants: 426 | ; E_ALL - All errors and warnings (includes E_STRICT as of PHP 5.4.0) 427 | ; E_ERROR - fatal run-time errors 428 | ; E_RECOVERABLE_ERROR - almost fatal run-time errors 429 | ; E_WARNING - run-time warnings (non-fatal errors) 430 | ; E_PARSE - compile-time parse errors 431 | ; E_NOTICE - run-time notices (these are warnings which often result 432 | ; from a bug in your code, but it's possible that it was 433 | ; intentional (e.g., using an uninitialized variable and 434 | ; relying on the fact it is automatically initialized to an 435 | ; empty string) 436 | ; E_STRICT - run-time notices, enable to have PHP suggest changes 437 | ; to your code which will ensure the best interoperability 438 | ; and forward compatibility of your code 439 | ; E_CORE_ERROR - fatal errors that occur during PHP's initial startup 440 | ; E_CORE_WARNING - warnings (non-fatal errors) that occur during PHP's 441 | ; initial startup 442 | ; E_COMPILE_ERROR - fatal compile-time errors 443 | ; E_COMPILE_WARNING - compile-time warnings (non-fatal errors) 444 | ; E_USER_ERROR - user-generated error message 445 | ; E_USER_WARNING - user-generated warning message 446 | ; E_USER_NOTICE - user-generated notice message 447 | ; E_DEPRECATED - warn about code that will not work in future versions 448 | ; of PHP 449 | ; E_USER_DEPRECATED - user-generated deprecation warnings 450 | ; 451 | ; Common Values: 452 | ; E_ALL (Show all errors, warnings and notices including coding standards.) 453 | ; E_ALL & ~E_NOTICE (Show all errors, except for notices) 454 | ; E_ALL & ~E_NOTICE & ~E_STRICT (Show all errors, except for notices and coding standards warnings.) 455 | ; E_COMPILE_ERROR|E_RECOVERABLE_ERROR|E_ERROR|E_CORE_ERROR (Show only errors) 456 | ; Default Value: E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATED 457 | ; Development Value: E_ALL 458 | ; Production Value: E_ALL & ~E_DEPRECATED & ~E_STRICT 459 | ; http://php.net/error-reporting 460 | error_reporting = E_ALL & ~E_DEPRECATED & ~E_STRICT 461 | 462 | ; This directive controls whether or not and where PHP will output errors, 463 | ; notices and warnings too. Error output is very useful during development, but 464 | ; it could be very dangerous in production environments. Depending on the code 465 | ; which is triggering the error, sensitive information could potentially leak 466 | ; out of your application such as database usernames and passwords or worse. 467 | ; For production environments, we recommend logging errors rather than 468 | ; sending them to STDOUT. 469 | ; Possible Values: 470 | ; Off = Do not display any errors 471 | ; stderr = Display errors to STDERR (affects only CGI/CLI binaries!) 472 | ; On or stdout = Display errors to STDOUT 473 | ; Default Value: On 474 | ; Development Value: On 475 | ; Production Value: Off 476 | ; http://php.net/display-errors 477 | display_errors = Off 478 | 479 | ; The display of errors which occur during PHP's startup sequence are handled 480 | ; separately from display_errors. PHP's default behavior is to suppress those 481 | ; errors from clients. Turning the display of startup errors on can be useful in 482 | ; debugging configuration problems. We strongly recommend you 483 | ; set this to 'off' for production servers. 484 | ; Default Value: Off 485 | ; Development Value: On 486 | ; Production Value: Off 487 | ; http://php.net/display-startup-errors 488 | display_startup_errors = Off 489 | 490 | ; Besides displaying errors, PHP can also log errors to locations such as a 491 | ; server-specific log, STDERR, or a location specified by the error_log 492 | ; directive found below. While errors should not be displayed on productions 493 | ; servers they should still be monitored and logging is a great way to do that. 494 | ; Default Value: Off 495 | ; Development Value: On 496 | ; Production Value: On 497 | ; http://php.net/log-errors 498 | log_errors = On 499 | 500 | ; Set maximum length of log_errors. In error_log information about the source is 501 | ; added. The default is 1024 and 0 allows to not apply any maximum length at all. 502 | ; http://php.net/log-errors-max-len 503 | log_errors_max_len = 1024 504 | 505 | ; Do not log repeated messages. Repeated errors must occur in same file on same 506 | ; line unless ignore_repeated_source is set true. 507 | ; http://php.net/ignore-repeated-errors 508 | ignore_repeated_errors = Off 509 | 510 | ; Ignore source of message when ignoring repeated messages. When this setting 511 | ; is On you will not log errors with repeated messages from different files or 512 | ; source lines. 513 | ; http://php.net/ignore-repeated-source 514 | ignore_repeated_source = Off 515 | 516 | ; If this parameter is set to Off, then memory leaks will not be shown (on 517 | ; stdout or in the log). This has only effect in a debug compile, and if 518 | ; error reporting includes E_WARNING in the allowed list 519 | ; http://php.net/report-memleaks 520 | report_memleaks = On 521 | 522 | ; This setting is on by default. 523 | ;report_zend_debug = 0 524 | 525 | ; Store the last error/warning message in $php_errormsg (boolean). Setting this value 526 | ; to On can assist in debugging and is appropriate for development servers. It should 527 | ; however be disabled on production servers. 528 | ; Default Value: Off 529 | ; Development Value: On 530 | ; Production Value: Off 531 | ; http://php.net/track-errors 532 | track_errors = Off 533 | 534 | ; Turn off normal error reporting and emit XML-RPC error XML 535 | ; http://php.net/xmlrpc-errors 536 | ;xmlrpc_errors = 0 537 | 538 | ; An XML-RPC faultCode 539 | ;xmlrpc_error_number = 0 540 | 541 | ; When PHP displays or logs an error, it has the capability of formatting the 542 | ; error message as HTML for easier reading. This directive controls whether 543 | ; the error message is formatted as HTML or not. 544 | ; Note: This directive is hardcoded to Off for the CLI SAPI 545 | ; Default Value: On 546 | ; Development Value: On 547 | ; Production value: On 548 | ; http://php.net/html-errors 549 | html_errors = On 550 | 551 | ; If html_errors is set to On *and* docref_root is not empty, then PHP 552 | ; produces clickable error messages that direct to a page describing the error 553 | ; or function causing the error in detail. 554 | ; You can download a copy of the PHP manual from http://php.net/docs 555 | ; and change docref_root to the base URL of your local copy including the 556 | ; leading '/'. You must also specify the file extension being used including 557 | ; the dot. PHP's default behavior is to leave these settings empty, in which 558 | ; case no links to documentation are generated. 559 | ; Note: Never use this feature for production boxes. 560 | ; http://php.net/docref-root 561 | ; Examples 562 | ;docref_root = "/phpmanual/" 563 | 564 | ; http://php.net/docref-ext 565 | ;docref_ext = .html 566 | 567 | ; String to output before an error message. PHP's default behavior is to leave 568 | ; this setting blank. 569 | ; http://php.net/error-prepend-string 570 | ; Example: 571 | ;error_prepend_string = "" 572 | 573 | ; String to output after an error message. PHP's default behavior is to leave 574 | ; this setting blank. 575 | ; http://php.net/error-append-string 576 | ; Example: 577 | ;error_append_string = "" 578 | 579 | ; Log errors to specified file. PHP's default behavior is to leave this value 580 | ; empty. 581 | ; http://php.net/error-log 582 | ; Example: 583 | ;error_log = php_errors.log 584 | ; Log errors to syslog (Event Log on Windows). 585 | ;error_log = syslog 586 | 587 | ;windows.show_crt_warning 588 | ; Default value: 0 589 | ; Development value: 0 590 | ; Production value: 0 591 | 592 | ;;;;;;;;;;;;;;;;; 593 | ; Data Handling ; 594 | ;;;;;;;;;;;;;;;;; 595 | 596 | ; The separator used in PHP generated URLs to separate arguments. 597 | ; PHP's default setting is "&". 598 | ; http://php.net/arg-separator.output 599 | ; Example: 600 | ;arg_separator.output = "&" 601 | 602 | ; List of separator(s) used by PHP to parse input URLs into variables. 603 | ; PHP's default setting is "&". 604 | ; NOTE: Every character in this directive is considered as separator! 605 | ; http://php.net/arg-separator.input 606 | ; Example: 607 | ;arg_separator.input = ";&" 608 | 609 | ; This directive determines which super global arrays are registered when PHP 610 | ; starts up. G,P,C,E & S are abbreviations for the following respective super 611 | ; globals: GET, POST, COOKIE, ENV and SERVER. There is a performance penalty 612 | ; paid for the registration of these arrays and because ENV is not as commonly 613 | ; used as the others, ENV is not recommended on productions servers. You 614 | ; can still get access to the environment variables through getenv() should you 615 | ; need to. 616 | ; Default Value: "EGPCS" 617 | ; Development Value: "GPCS" 618 | ; Production Value: "GPCS"; 619 | ; http://php.net/variables-order 620 | variables_order = "GPCS" 621 | 622 | ; This directive determines which super global data (G,P & C) should be 623 | ; registered into the super global array REQUEST. If so, it also determines 624 | ; the order in which that data is registered. The values for this directive 625 | ; are specified in the same manner as the variables_order directive, 626 | ; EXCEPT one. Leaving this value empty will cause PHP to use the value set 627 | ; in the variables_order directive. It does not mean it will leave the super 628 | ; globals array REQUEST empty. 629 | ; Default Value: None 630 | ; Development Value: "GP" 631 | ; Production Value: "GP" 632 | ; http://php.net/request-order 633 | request_order = "GP" 634 | 635 | ; This directive determines whether PHP registers $argv & $argc each time it 636 | ; runs. $argv contains an array of all the arguments passed to PHP when a script 637 | ; is invoked. $argc contains an integer representing the number of arguments 638 | ; that were passed when the script was invoked. These arrays are extremely 639 | ; useful when running scripts from the command line. When this directive is 640 | ; enabled, registering these variables consumes CPU cycles and memory each time 641 | ; a script is executed. For performance reasons, this feature should be disabled 642 | ; on production servers. 643 | ; Note: This directive is hardcoded to On for the CLI SAPI 644 | ; Default Value: On 645 | ; Development Value: Off 646 | ; Production Value: Off 647 | ; http://php.net/register-argc-argv 648 | register_argc_argv = Off 649 | 650 | ; When enabled, the ENV, REQUEST and SERVER variables are created when they're 651 | ; first used (Just In Time) instead of when the script starts. If these 652 | ; variables are not used within a script, having this directive on will result 653 | ; in a performance gain. The PHP directive register_argc_argv must be disabled 654 | ; for this directive to have any affect. 655 | ; http://php.net/auto-globals-jit 656 | auto_globals_jit = On 657 | 658 | ; Whether PHP will read the POST data. 659 | ; This option is enabled by default. 660 | ; Most likely, you won't want to disable this option globally. It causes $_POST 661 | ; and $_FILES to always be empty; the only way you will be able to read the 662 | ; POST data will be through the php://input stream wrapper. This can be useful 663 | ; to proxy requests or to process the POST data in a memory efficient fashion. 664 | ; http://php.net/enable-post-data-reading 665 | ;enable_post_data_reading = Off 666 | 667 | ; Maximum size of POST data that PHP will accept. 668 | ; Its value may be 0 to disable the limit. It is ignored if POST data reading 669 | ; is disabled through enable_post_data_reading. 670 | ; http://php.net/post-max-size 671 | post_max_size = 8M 672 | 673 | ; Automatically add files before PHP document. 674 | ; http://php.net/auto-prepend-file 675 | auto_prepend_file = 676 | 677 | ; Automatically add files after PHP document. 678 | ; http://php.net/auto-append-file 679 | auto_append_file = 680 | 681 | ; By default, PHP will output a media type using the Content-Type header. To 682 | ; disable this, simply set it to be empty. 683 | ; 684 | ; PHP's built-in default media type is set to text/html. 685 | ; http://php.net/default-mimetype 686 | default_mimetype = "text/html" 687 | 688 | ; PHP's default character set is set to UTF-8. 689 | ; http://php.net/default-charset 690 | default_charset = "UTF-8" 691 | 692 | ; PHP internal character encoding is set to empty. 693 | ; If empty, default_charset is used. 694 | ; http://php.net/internal-encoding 695 | ;internal_encoding = 696 | 697 | ; PHP input character encoding is set to empty. 698 | ; If empty, default_charset is used. 699 | ; http://php.net/input-encoding 700 | ;input_encoding = 701 | 702 | ; PHP output character encoding is set to empty. 703 | ; If empty, default_charset is used. 704 | ; See also output_buffer. 705 | ; http://php.net/output-encoding 706 | ;output_encoding = 707 | 708 | ;;;;;;;;;;;;;;;;;;;;;;;;; 709 | ; Paths and Directories ; 710 | ;;;;;;;;;;;;;;;;;;;;;;;;; 711 | 712 | ; UNIX: "/path1:/path2" 713 | ;include_path = ".:/php/includes" 714 | ; 715 | ; Windows: "\path1;\path2" 716 | ;include_path = ".;c:\php\includes" 717 | ; 718 | ; PHP's default setting for include_path is ".;/path/to/php/pear" 719 | ; http://php.net/include-path 720 | 721 | ; The root of the PHP pages, used only if nonempty. 722 | ; if PHP was not compiled with FORCE_REDIRECT, you SHOULD set doc_root 723 | ; if you are running php as a CGI under any web server (other than IIS) 724 | ; see documentation for security issues. The alternate is to use the 725 | ; cgi.force_redirect configuration below 726 | ; http://php.net/doc-root 727 | doc_root = 728 | 729 | ; The directory under which PHP opens the script using /~username used only 730 | ; if nonempty. 731 | ; http://php.net/user-dir 732 | user_dir = 733 | 734 | ; Directory in which the loadable extensions (modules) reside. 735 | ; http://php.net/extension-dir 736 | ; extension_dir = "./" 737 | ; On windows: 738 | ; extension_dir = "ext" 739 | 740 | ; Directory where the temporary files should be placed. 741 | ; Defaults to the system default (see sys_get_temp_dir) 742 | ; sys_temp_dir = "/tmp" 743 | 744 | ; Whether or not to enable the dl() function. The dl() function does NOT work 745 | ; properly in multithreaded servers, such as IIS or Zeus, and is automatically 746 | ; disabled on them. 747 | ; http://php.net/enable-dl 748 | enable_dl = Off 749 | 750 | ; cgi.force_redirect is necessary to provide security running PHP as a CGI under 751 | ; most web servers. Left undefined, PHP turns this on by default. You can 752 | ; turn it off here AT YOUR OWN RISK 753 | ; **You CAN safely turn this off for IIS, in fact, you MUST.** 754 | ; http://php.net/cgi.force-redirect 755 | ;cgi.force_redirect = 1 756 | 757 | ; if cgi.nph is enabled it will force cgi to always sent Status: 200 with 758 | ; every request. PHP's default behavior is to disable this feature. 759 | ;cgi.nph = 1 760 | 761 | ; if cgi.force_redirect is turned on, and you are not running under Apache or Netscape 762 | ; (iPlanet) web servers, you MAY need to set an environment variable name that PHP 763 | ; will look for to know it is OK to continue execution. Setting this variable MAY 764 | ; cause security issues, KNOW WHAT YOU ARE DOING FIRST. 765 | ; http://php.net/cgi.redirect-status-env 766 | ;cgi.redirect_status_env = 767 | 768 | ; cgi.fix_pathinfo provides *real* PATH_INFO/PATH_TRANSLATED support for CGI. PHP's 769 | ; previous behaviour was to set PATH_TRANSLATED to SCRIPT_FILENAME, and to not grok 770 | ; what PATH_INFO is. For more information on PATH_INFO, see the cgi specs. Setting 771 | ; this to 1 will cause PHP CGI to fix its paths to conform to the spec. A setting 772 | ; of zero causes PHP to behave as before. Default is 1. You should fix your scripts 773 | ; to use SCRIPT_FILENAME rather than PATH_TRANSLATED. 774 | ; http://php.net/cgi.fix-pathinfo 775 | ;cgi.fix_pathinfo=1 776 | 777 | ; if cgi.discard_path is enabled, the PHP CGI binary can safely be placed outside 778 | ; of the web tree and people will not be able to circumvent .htaccess security. 779 | ; http://php.net/cgi.dicard-path 780 | ;cgi.discard_path=1 781 | 782 | ; FastCGI under IIS (on WINNT based OS) supports the ability to impersonate 783 | ; security tokens of the calling client. This allows IIS to define the 784 | ; security context that the request runs under. mod_fastcgi under Apache 785 | ; does not currently support this feature (03/17/2002) 786 | ; Set to 1 if running under IIS. Default is zero. 787 | ; http://php.net/fastcgi.impersonate 788 | ;fastcgi.impersonate = 1 789 | 790 | ; Disable logging through FastCGI connection. PHP's default behavior is to enable 791 | ; this feature. 792 | ;fastcgi.logging = 0 793 | 794 | ; cgi.rfc2616_headers configuration option tells PHP what type of headers to 795 | ; use when sending HTTP response code. If set to 0, PHP sends Status: header that 796 | ; is supported by Apache. When this option is set to 1, PHP will send 797 | ; RFC2616 compliant header. 798 | ; Default is zero. 799 | ; http://php.net/cgi.rfc2616-headers 800 | ;cgi.rfc2616_headers = 0 801 | 802 | ; cgi.check_shebang_line controls whether CGI PHP checks for line starting with #! 803 | ; (shebang) at the top of the running script. This line might be needed if the 804 | ; script support running both as stand-alone script and via PHP CGI<. PHP in CGI 805 | ; mode skips this line and ignores its content if this directive is turned on. 806 | ; http://php.net/cgi.check-shebang-line 807 | ;cgi.check_shebang_line=1 808 | 809 | ;;;;;;;;;;;;;;;; 810 | ; File Uploads ; 811 | ;;;;;;;;;;;;;;;; 812 | 813 | ; Whether to allow HTTP file uploads. 814 | ; http://php.net/file-uploads 815 | file_uploads = On 816 | 817 | ; Temporary directory for HTTP uploaded files (will use system default if not 818 | ; specified). 819 | ; http://php.net/upload-tmp-dir 820 | ;upload_tmp_dir = 821 | 822 | ; Maximum allowed size for uploaded files. 823 | ; http://php.net/upload-max-filesize 824 | upload_max_filesize = 2M 825 | 826 | ; Maximum number of files that can be uploaded via a single request 827 | max_file_uploads = 20 828 | 829 | ;;;;;;;;;;;;;;;;;; 830 | ; Fopen wrappers ; 831 | ;;;;;;;;;;;;;;;;;; 832 | 833 | ; Whether to allow the treatment of URLs (like http:// or ftp://) as files. 834 | ; http://php.net/allow-url-fopen 835 | allow_url_fopen = On 836 | 837 | ; Whether to allow include/require to open URLs (like http:// or ftp://) as files. 838 | ; http://php.net/allow-url-include 839 | allow_url_include = Off 840 | 841 | ; Define the anonymous ftp password (your email address). PHP's default setting 842 | ; for this is empty. 843 | ; http://php.net/from 844 | ;from="john@doe.com" 845 | 846 | ; Define the User-Agent string. PHP's default setting for this is empty. 847 | ; http://php.net/user-agent 848 | ;user_agent="PHP" 849 | 850 | ; Default timeout for socket based streams (seconds) 851 | ; http://php.net/default-socket-timeout 852 | default_socket_timeout = 60 853 | 854 | ; If your scripts have to deal with files from Macintosh systems, 855 | ; or you are running on a Mac and need to deal with files from 856 | ; unix or win32 systems, setting this flag will cause PHP to 857 | ; automatically detect the EOL character in those files so that 858 | ; fgets() and file() will work regardless of the source of the file. 859 | ; http://php.net/auto-detect-line-endings 860 | ;auto_detect_line_endings = Off 861 | 862 | ;;;;;;;;;;;;;;;;;;;;;; 863 | ; Dynamic Extensions ; 864 | ;;;;;;;;;;;;;;;;;;;;;; 865 | 866 | ; If you wish to have an extension loaded automatically, use the following 867 | ; syntax: 868 | ; 869 | ; extension=modulename.extension 870 | ; 871 | ; For example, on Windows: 872 | ; 873 | ; extension=mysqli.dll 874 | ; 875 | ; ... or under UNIX: 876 | ; 877 | ; extension=mysqli.so 878 | ; 879 | ; ... or with a path: 880 | ; 881 | ; extension=/path/to/extension/mysqli.so 882 | ; 883 | ; If you only provide the name of the extension, PHP will look for it in its 884 | ; default extension directory. 885 | ; 886 | ; Windows Extensions 887 | ; Note that ODBC support is built in, so no dll is needed for it. 888 | ; Note that many DLL files are located in the extensions/ (PHP 4) ext/ (PHP 5+) 889 | ; extension folders as well as the separate PECL DLL download (PHP 5+). 890 | ; Be sure to appropriately set the extension_dir directive. 891 | ; 892 | ;extension=php_bz2.dll 893 | ;extension=php_curl.dll 894 | ;extension=php_fileinfo.dll 895 | ;extension=php_ftp.dll 896 | ;extension=php_gd2.dll 897 | ;extension=php_gettext.dll 898 | ;extension=php_gmp.dll 899 | ;extension=php_intl.dll 900 | ;extension=php_imap.dll 901 | ;extension=php_interbase.dll 902 | ;extension=php_ldap.dll 903 | ;extension=php_mbstring.dll 904 | ;extension=php_exif.dll ; Must be after mbstring as it depends on it 905 | ;extension=php_mysqli.dll 906 | ;extension=php_oci8_12c.dll ; Use with Oracle Database 12c Instant Client 907 | ;extension=php_openssl.dll 908 | ;extension=php_pdo_firebird.dll 909 | ;extension=php_pdo_mysql.dll 910 | ;extension=php_pdo_oci.dll 911 | ;extension=php_pdo_odbc.dll 912 | ;extension=php_pdo_pgsql.dll 913 | ;extension=php_pdo_sqlite.dll 914 | ;extension=php_pgsql.dll 915 | ;extension=php_shmop.dll 916 | 917 | ; The MIBS data available in the PHP distribution must be installed. 918 | ; See http://www.php.net/manual/en/snmp.installation.php 919 | ;extension=php_snmp.dll 920 | 921 | ;extension=php_soap.dll 922 | ;extension=php_sockets.dll 923 | ;extension=php_sqlite3.dll 924 | ;extension=php_tidy.dll 925 | ;extension=php_xmlrpc.dll 926 | ;extension=php_xsl.dll 927 | 928 | ;;;;;;;;;;;;;;;;;;; 929 | ; Module Settings ; 930 | ;;;;;;;;;;;;;;;;;;; 931 | 932 | [CLI Server] 933 | ; Whether the CLI web server uses ANSI color coding in its terminal output. 934 | cli_server.color = On 935 | 936 | [Date] 937 | ; Defines the default timezone used by the date functions 938 | ; http://php.net/date.timezone 939 | ;date.timezone = 940 | 941 | ; http://php.net/date.default-latitude 942 | ;date.default_latitude = 31.7667 943 | 944 | ; http://php.net/date.default-longitude 945 | ;date.default_longitude = 35.2333 946 | 947 | ; http://php.net/date.sunrise-zenith 948 | ;date.sunrise_zenith = 90.583333 949 | 950 | ; http://php.net/date.sunset-zenith 951 | ;date.sunset_zenith = 90.583333 952 | 953 | [filter] 954 | ; http://php.net/filter.default 955 | ;filter.default = unsafe_raw 956 | 957 | ; http://php.net/filter.default-flags 958 | ;filter.default_flags = 959 | 960 | [iconv] 961 | ; Use of this INI entry is deprecated, use global input_encoding instead. 962 | ; If empty, default_charset or input_encoding or iconv.input_encoding is used. 963 | ; The precedence is: default_charset < intput_encoding < iconv.input_encoding 964 | ;iconv.input_encoding = 965 | 966 | ; Use of this INI entry is deprecated, use global internal_encoding instead. 967 | ; If empty, default_charset or internal_encoding or iconv.internal_encoding is used. 968 | ; The precedence is: default_charset < internal_encoding < iconv.internal_encoding 969 | ;iconv.internal_encoding = 970 | 971 | ; Use of this INI entry is deprecated, use global output_encoding instead. 972 | ; If empty, default_charset or output_encoding or iconv.output_encoding is used. 973 | ; The precedence is: default_charset < output_encoding < iconv.output_encoding 974 | ; To use an output encoding conversion, iconv's output handler must be set 975 | ; otherwise output encoding conversion cannot be performed. 976 | ;iconv.output_encoding = 977 | 978 | [intl] 979 | ;intl.default_locale = 980 | ; This directive allows you to produce PHP errors when some error 981 | ; happens within intl functions. The value is the level of the error produced. 982 | ; Default is 0, which does not produce any errors. 983 | ;intl.error_level = E_WARNING 984 | ;intl.use_exceptions = 0 985 | 986 | [sqlite3] 987 | ;sqlite3.extension_dir = 988 | 989 | [Pcre] 990 | ;PCRE library backtracking limit. 991 | ; http://php.net/pcre.backtrack-limit 992 | ;pcre.backtrack_limit=100000 993 | 994 | ;PCRE library recursion limit. 995 | ;Please note that if you set this value to a high number you may consume all 996 | ;the available process stack and eventually crash PHP (due to reaching the 997 | ;stack size limit imposed by the Operating System). 998 | ; http://php.net/pcre.recursion-limit 999 | ;pcre.recursion_limit=100000 1000 | 1001 | ;Enables or disables JIT compilation of patterns. This requires the PCRE 1002 | ;library to be compiled with JIT support. 1003 | ;pcre.jit=1 1004 | 1005 | [Pdo] 1006 | ; Whether to pool ODBC connections. Can be one of "strict", "relaxed" or "off" 1007 | ; http://php.net/pdo-odbc.connection-pooling 1008 | ;pdo_odbc.connection_pooling=strict 1009 | 1010 | ;pdo_odbc.db2_instance_name 1011 | 1012 | [Pdo_mysql] 1013 | ; If mysqlnd is used: Number of cache slots for the internal result set cache 1014 | ; http://php.net/pdo_mysql.cache_size 1015 | pdo_mysql.cache_size = 2000 1016 | 1017 | ; Default socket name for local MySQL connects. If empty, uses the built-in 1018 | ; MySQL defaults. 1019 | ; http://php.net/pdo_mysql.default-socket 1020 | pdo_mysql.default_socket= 1021 | 1022 | [Phar] 1023 | ; http://php.net/phar.readonly 1024 | ;phar.readonly = On 1025 | 1026 | ; http://php.net/phar.require-hash 1027 | ;phar.require_hash = On 1028 | 1029 | ;phar.cache_list = 1030 | 1031 | [mail function] 1032 | ; For Win32 only. 1033 | ; http://php.net/smtp 1034 | SMTP = localhost 1035 | ; http://php.net/smtp-port 1036 | smtp_port = 25 1037 | 1038 | ; For Win32 only. 1039 | ; http://php.net/sendmail-from 1040 | ;sendmail_from = me@example.com 1041 | 1042 | ; For Unix only. You may supply arguments as well (default: "sendmail -t -i"). 1043 | ; http://php.net/sendmail-path 1044 | ;sendmail_path = 1045 | 1046 | ; Force the addition of the specified parameters to be passed as extra parameters 1047 | ; to the sendmail binary. These parameters will always replace the value of 1048 | ; the 5th parameter to mail(). 1049 | ;mail.force_extra_parameters = 1050 | 1051 | ; Add X-PHP-Originating-Script: that will include uid of the script followed by the filename 1052 | mail.add_x_header = On 1053 | 1054 | ; The path to a log file that will log all mail() calls. Log entries include 1055 | ; the full path of the script, line number, To address and headers. 1056 | ;mail.log = 1057 | ; Log mail to syslog (Event Log on Windows). 1058 | ;mail.log = syslog 1059 | 1060 | [ODBC] 1061 | ; http://php.net/odbc.default-db 1062 | ;odbc.default_db = Not yet implemented 1063 | 1064 | ; http://php.net/odbc.default-user 1065 | ;odbc.default_user = Not yet implemented 1066 | 1067 | ; http://php.net/odbc.default-pw 1068 | ;odbc.default_pw = Not yet implemented 1069 | 1070 | ; Controls the ODBC cursor model. 1071 | ; Default: SQL_CURSOR_STATIC (default). 1072 | ;odbc.default_cursortype 1073 | 1074 | ; Allow or prevent persistent links. 1075 | ; http://php.net/odbc.allow-persistent 1076 | odbc.allow_persistent = On 1077 | 1078 | ; Check that a connection is still valid before reuse. 1079 | ; http://php.net/odbc.check-persistent 1080 | odbc.check_persistent = On 1081 | 1082 | ; Maximum number of persistent links. -1 means no limit. 1083 | ; http://php.net/odbc.max-persistent 1084 | odbc.max_persistent = -1 1085 | 1086 | ; Maximum number of links (persistent + non-persistent). -1 means no limit. 1087 | ; http://php.net/odbc.max-links 1088 | odbc.max_links = -1 1089 | 1090 | ; Handling of LONG fields. Returns number of bytes to variables. 0 means 1091 | ; passthru. 1092 | ; http://php.net/odbc.defaultlrl 1093 | odbc.defaultlrl = 4096 1094 | 1095 | ; Handling of binary data. 0 means passthru, 1 return as is, 2 convert to char. 1096 | ; See the documentation on odbc_binmode and odbc_longreadlen for an explanation 1097 | ; of odbc.defaultlrl and odbc.defaultbinmode 1098 | ; http://php.net/odbc.defaultbinmode 1099 | odbc.defaultbinmode = 1 1100 | 1101 | ;birdstep.max_links = -1 1102 | 1103 | [Interbase] 1104 | ; Allow or prevent persistent links. 1105 | ibase.allow_persistent = 1 1106 | 1107 | ; Maximum number of persistent links. -1 means no limit. 1108 | ibase.max_persistent = -1 1109 | 1110 | ; Maximum number of links (persistent + non-persistent). -1 means no limit. 1111 | ibase.max_links = -1 1112 | 1113 | ; Default database name for ibase_connect(). 1114 | ;ibase.default_db = 1115 | 1116 | ; Default username for ibase_connect(). 1117 | ;ibase.default_user = 1118 | 1119 | ; Default password for ibase_connect(). 1120 | ;ibase.default_password = 1121 | 1122 | ; Default charset for ibase_connect(). 1123 | ;ibase.default_charset = 1124 | 1125 | ; Default timestamp format. 1126 | ibase.timestampformat = "%Y-%m-%d %H:%M:%S" 1127 | 1128 | ; Default date format. 1129 | ibase.dateformat = "%Y-%m-%d" 1130 | 1131 | ; Default time format. 1132 | ibase.timeformat = "%H:%M:%S" 1133 | 1134 | [MySQLi] 1135 | 1136 | ; Maximum number of persistent links. -1 means no limit. 1137 | ; http://php.net/mysqli.max-persistent 1138 | mysqli.max_persistent = -1 1139 | 1140 | ; Allow accessing, from PHP's perspective, local files with LOAD DATA statements 1141 | ; http://php.net/mysqli.allow_local_infile 1142 | ;mysqli.allow_local_infile = On 1143 | 1144 | ; Allow or prevent persistent links. 1145 | ; http://php.net/mysqli.allow-persistent 1146 | mysqli.allow_persistent = On 1147 | 1148 | ; Maximum number of links. -1 means no limit. 1149 | ; http://php.net/mysqli.max-links 1150 | mysqli.max_links = -1 1151 | 1152 | ; If mysqlnd is used: Number of cache slots for the internal result set cache 1153 | ; http://php.net/mysqli.cache_size 1154 | mysqli.cache_size = 2000 1155 | 1156 | ; Default port number for mysqli_connect(). If unset, mysqli_connect() will use 1157 | ; the $MYSQL_TCP_PORT or the mysql-tcp entry in /etc/services or the 1158 | ; compile-time value defined MYSQL_PORT (in that order). Win32 will only look 1159 | ; at MYSQL_PORT. 1160 | ; http://php.net/mysqli.default-port 1161 | mysqli.default_port = 3306 1162 | 1163 | ; Default socket name for local MySQL connects. If empty, uses the built-in 1164 | ; MySQL defaults. 1165 | ; http://php.net/mysqli.default-socket 1166 | mysqli.default_socket = 1167 | 1168 | ; Default host for mysql_connect() (doesn't apply in safe mode). 1169 | ; http://php.net/mysqli.default-host 1170 | mysqli.default_host = 1171 | 1172 | ; Default user for mysql_connect() (doesn't apply in safe mode). 1173 | ; http://php.net/mysqli.default-user 1174 | mysqli.default_user = 1175 | 1176 | ; Default password for mysqli_connect() (doesn't apply in safe mode). 1177 | ; Note that this is generally a *bad* idea to store passwords in this file. 1178 | ; *Any* user with PHP access can run 'echo get_cfg_var("mysqli.default_pw") 1179 | ; and reveal this password! And of course, any users with read access to this 1180 | ; file will be able to reveal the password as well. 1181 | ; http://php.net/mysqli.default-pw 1182 | mysqli.default_pw = 1183 | 1184 | ; Allow or prevent reconnect 1185 | mysqli.reconnect = Off 1186 | 1187 | [mysqlnd] 1188 | ; Enable / Disable collection of general statistics by mysqlnd which can be 1189 | ; used to tune and monitor MySQL operations. 1190 | ; http://php.net/mysqlnd.collect_statistics 1191 | mysqlnd.collect_statistics = On 1192 | 1193 | ; Enable / Disable collection of memory usage statistics by mysqlnd which can be 1194 | ; used to tune and monitor MySQL operations. 1195 | ; http://php.net/mysqlnd.collect_memory_statistics 1196 | mysqlnd.collect_memory_statistics = Off 1197 | 1198 | ; Records communication from all extensions using mysqlnd to the specified log 1199 | ; file. 1200 | ; http://php.net/mysqlnd.debug 1201 | ;mysqlnd.debug = 1202 | 1203 | ; Defines which queries will be logged. 1204 | ; http://php.net/mysqlnd.log_mask 1205 | ;mysqlnd.log_mask = 0 1206 | 1207 | ; Default size of the mysqlnd memory pool, which is used by result sets. 1208 | ; http://php.net/mysqlnd.mempool_default_size 1209 | ;mysqlnd.mempool_default_size = 16000 1210 | 1211 | ; Size of a pre-allocated buffer used when sending commands to MySQL in bytes. 1212 | ; http://php.net/mysqlnd.net_cmd_buffer_size 1213 | ;mysqlnd.net_cmd_buffer_size = 2048 1214 | 1215 | ; Size of a pre-allocated buffer used for reading data sent by the server in 1216 | ; bytes. 1217 | ; http://php.net/mysqlnd.net_read_buffer_size 1218 | ;mysqlnd.net_read_buffer_size = 32768 1219 | 1220 | ; Timeout for network requests in seconds. 1221 | ; http://php.net/mysqlnd.net_read_timeout 1222 | ;mysqlnd.net_read_timeout = 31536000 1223 | 1224 | ; SHA-256 Authentication Plugin related. File with the MySQL server public RSA 1225 | ; key. 1226 | ; http://php.net/mysqlnd.sha256_server_public_key 1227 | ;mysqlnd.sha256_server_public_key = 1228 | 1229 | [OCI8] 1230 | 1231 | ; Connection: Enables privileged connections using external 1232 | ; credentials (OCI_SYSOPER, OCI_SYSDBA) 1233 | ; http://php.net/oci8.privileged-connect 1234 | ;oci8.privileged_connect = Off 1235 | 1236 | ; Connection: The maximum number of persistent OCI8 connections per 1237 | ; process. Using -1 means no limit. 1238 | ; http://php.net/oci8.max-persistent 1239 | ;oci8.max_persistent = -1 1240 | 1241 | ; Connection: The maximum number of seconds a process is allowed to 1242 | ; maintain an idle persistent connection. Using -1 means idle 1243 | ; persistent connections will be maintained forever. 1244 | ; http://php.net/oci8.persistent-timeout 1245 | ;oci8.persistent_timeout = -1 1246 | 1247 | ; Connection: The number of seconds that must pass before issuing a 1248 | ; ping during oci_pconnect() to check the connection validity. When 1249 | ; set to 0, each oci_pconnect() will cause a ping. Using -1 disables 1250 | ; pings completely. 1251 | ; http://php.net/oci8.ping-interval 1252 | ;oci8.ping_interval = 60 1253 | 1254 | ; Connection: Set this to a user chosen connection class to be used 1255 | ; for all pooled server requests with Oracle 11g Database Resident 1256 | ; Connection Pooling (DRCP). To use DRCP, this value should be set to 1257 | ; the same string for all web servers running the same application, 1258 | ; the database pool must be configured, and the connection string must 1259 | ; specify to use a pooled server. 1260 | ;oci8.connection_class = 1261 | 1262 | ; High Availability: Using On lets PHP receive Fast Application 1263 | ; Notification (FAN) events generated when a database node fails. The 1264 | ; database must also be configured to post FAN events. 1265 | ;oci8.events = Off 1266 | 1267 | ; Tuning: This option enables statement caching, and specifies how 1268 | ; many statements to cache. Using 0 disables statement caching. 1269 | ; http://php.net/oci8.statement-cache-size 1270 | ;oci8.statement_cache_size = 20 1271 | 1272 | ; Tuning: Enables statement prefetching and sets the default number of 1273 | ; rows that will be fetched automatically after statement execution. 1274 | ; http://php.net/oci8.default-prefetch 1275 | ;oci8.default_prefetch = 100 1276 | 1277 | ; Compatibility. Using On means oci_close() will not close 1278 | ; oci_connect() and oci_new_connect() connections. 1279 | ; http://php.net/oci8.old-oci-close-semantics 1280 | ;oci8.old_oci_close_semantics = Off 1281 | 1282 | [PostgreSQL] 1283 | ; Allow or prevent persistent links. 1284 | ; http://php.net/pgsql.allow-persistent 1285 | pgsql.allow_persistent = On 1286 | 1287 | ; Detect broken persistent links always with pg_pconnect(). 1288 | ; Auto reset feature requires a little overheads. 1289 | ; http://php.net/pgsql.auto-reset-persistent 1290 | pgsql.auto_reset_persistent = Off 1291 | 1292 | ; Maximum number of persistent links. -1 means no limit. 1293 | ; http://php.net/pgsql.max-persistent 1294 | pgsql.max_persistent = -1 1295 | 1296 | ; Maximum number of links (persistent+non persistent). -1 means no limit. 1297 | ; http://php.net/pgsql.max-links 1298 | pgsql.max_links = -1 1299 | 1300 | ; Ignore PostgreSQL backends Notice message or not. 1301 | ; Notice message logging require a little overheads. 1302 | ; http://php.net/pgsql.ignore-notice 1303 | pgsql.ignore_notice = 0 1304 | 1305 | ; Log PostgreSQL backends Notice message or not. 1306 | ; Unless pgsql.ignore_notice=0, module cannot log notice message. 1307 | ; http://php.net/pgsql.log-notice 1308 | pgsql.log_notice = 0 1309 | 1310 | [bcmath] 1311 | ; Number of decimal digits for all bcmath functions. 1312 | ; http://php.net/bcmath.scale 1313 | bcmath.scale = 0 1314 | 1315 | [browscap] 1316 | ; http://php.net/browscap 1317 | ;browscap = extra/browscap.ini 1318 | 1319 | [Session] 1320 | ; Handler used to store/retrieve data. 1321 | ; http://php.net/session.save-handler 1322 | session.save_handler = files 1323 | 1324 | ; Argument passed to save_handler. In the case of files, this is the path 1325 | ; where data files are stored. Note: Windows users have to change this 1326 | ; variable in order to use PHP's session functions. 1327 | ; 1328 | ; The path can be defined as: 1329 | ; 1330 | ; session.save_path = "N;/path" 1331 | ; 1332 | ; where N is an integer. Instead of storing all the session files in 1333 | ; /path, what this will do is use subdirectories N-levels deep, and 1334 | ; store the session data in those directories. This is useful if 1335 | ; your OS has problems with many files in one directory, and is 1336 | ; a more efficient layout for servers that handle many sessions. 1337 | ; 1338 | ; NOTE 1: PHP will not create this directory structure automatically. 1339 | ; You can use the script in the ext/session dir for that purpose. 1340 | ; NOTE 2: See the section on garbage collection below if you choose to 1341 | ; use subdirectories for session storage 1342 | ; 1343 | ; The file storage module creates files using mode 600 by default. 1344 | ; You can change that by using 1345 | ; 1346 | ; session.save_path = "N;MODE;/path" 1347 | ; 1348 | ; where MODE is the octal representation of the mode. Note that this 1349 | ; does not overwrite the process's umask. 1350 | ; http://php.net/session.save-path 1351 | session.save_path = "/tmp" 1352 | 1353 | ; Whether to use strict session mode. 1354 | ; Strict session mode does not accept uninitialized session ID and regenerate 1355 | ; session ID if browser sends uninitialized session ID. Strict mode protects 1356 | ; applications from session fixation via session adoption vulnerability. It is 1357 | ; disabled by default for maximum compatibility, but enabling it is encouraged. 1358 | ; https://wiki.php.net/rfc/strict_sessions 1359 | session.use_strict_mode = 0 1360 | 1361 | ; Whether to use cookies. 1362 | ; http://php.net/session.use-cookies 1363 | session.use_cookies = 1 1364 | 1365 | ; http://php.net/session.cookie-secure 1366 | ;session.cookie_secure = 1367 | 1368 | ; This option forces PHP to fetch and use a cookie for storing and maintaining 1369 | ; the session id. We encourage this operation as it's very helpful in combating 1370 | ; session hijacking when not specifying and managing your own session id. It is 1371 | ; not the be-all and end-all of session hijacking defense, but it's a good start. 1372 | ; http://php.net/session.use-only-cookies 1373 | session.use_only_cookies = 1 1374 | 1375 | ; Name of the session (used as cookie name). 1376 | ; http://php.net/session.name 1377 | session.name = PHPSESSID 1378 | 1379 | ; Initialize session on request startup. 1380 | ; http://php.net/session.auto-start 1381 | session.auto_start = 0 1382 | 1383 | ; Lifetime in seconds of cookie or, if 0, until browser is restarted. 1384 | ; http://php.net/session.cookie-lifetime 1385 | session.cookie_lifetime = 0 1386 | 1387 | ; The path for which the cookie is valid. 1388 | ; http://php.net/session.cookie-path 1389 | session.cookie_path = / 1390 | 1391 | ; The domain for which the cookie is valid. 1392 | ; http://php.net/session.cookie-domain 1393 | session.cookie_domain = 1394 | 1395 | ; Whether or not to add the httpOnly flag to the cookie, which makes it inaccessible to browser scripting languages such as JavaScript. 1396 | ; http://php.net/session.cookie-httponly 1397 | session.cookie_httponly = 1398 | 1399 | ; Handler used to serialize data. php is the standard serializer of PHP. 1400 | ; http://php.net/session.serialize-handler 1401 | session.serialize_handler = php 1402 | 1403 | ; Defines the probability that the 'garbage collection' process is started 1404 | ; on every session initialization. The probability is calculated by using 1405 | ; gc_probability/gc_divisor. Where session.gc_probability is the numerator 1406 | ; and gc_divisor is the denominator in the equation. Setting this value to 1 1407 | ; when the session.gc_divisor value is 100 will give you approximately a 1% chance 1408 | ; the gc will run on any give request. 1409 | ; Default Value: 1 1410 | ; Development Value: 1 1411 | ; Production Value: 1 1412 | ; http://php.net/session.gc-probability 1413 | session.gc_probability = 1 1414 | 1415 | ; Defines the probability that the 'garbage collection' process is started on every 1416 | ; session initialization. The probability is calculated by using the following equation: 1417 | ; gc_probability/gc_divisor. Where session.gc_probability is the numerator and 1418 | ; session.gc_divisor is the denominator in the equation. Setting this value to 1 1419 | ; when the session.gc_divisor value is 100 will give you approximately a 1% chance 1420 | ; the gc will run on any give request. Increasing this value to 1000 will give you 1421 | ; a 0.1% chance the gc will run on any give request. For high volume production servers, 1422 | ; this is a more efficient approach. 1423 | ; Default Value: 100 1424 | ; Development Value: 1000 1425 | ; Production Value: 1000 1426 | ; http://php.net/session.gc-divisor 1427 | session.gc_divisor = 1000 1428 | 1429 | ; After this number of seconds, stored data will be seen as 'garbage' and 1430 | ; cleaned up by the garbage collection process. 1431 | ; http://php.net/session.gc-maxlifetime 1432 | session.gc_maxlifetime = 1440 1433 | 1434 | ; NOTE: If you are using the subdirectory option for storing session files 1435 | ; (see session.save_path above), then garbage collection does *not* 1436 | ; happen automatically. You will need to do your own garbage 1437 | ; collection through a shell script, cron entry, or some other method. 1438 | ; For example, the following script would is the equivalent of 1439 | ; setting session.gc_maxlifetime to 1440 (1440 seconds = 24 minutes): 1440 | ; find /path/to/sessions -cmin +24 -type f | xargs rm 1441 | 1442 | ; Check HTTP Referer to invalidate externally stored URLs containing ids. 1443 | ; HTTP_REFERER has to contain this substring for the session to be 1444 | ; considered as valid. 1445 | ; http://php.net/session.referer-check 1446 | session.referer_check = 1447 | 1448 | ; Set to {nocache,private,public,} to determine HTTP caching aspects 1449 | ; or leave this empty to avoid sending anti-caching headers. 1450 | ; http://php.net/session.cache-limiter 1451 | session.cache_limiter = nocache 1452 | 1453 | ; Document expires after n minutes. 1454 | ; http://php.net/session.cache-expire 1455 | session.cache_expire = 180 1456 | 1457 | ; trans sid support is disabled by default. 1458 | ; Use of trans sid may risk your users' security. 1459 | ; Use this option with caution. 1460 | ; - User may send URL contains active session ID 1461 | ; to other person via. email/irc/etc. 1462 | ; - URL that contains active session ID may be stored 1463 | ; in publicly accessible computer. 1464 | ; - User may access your site with the same session ID 1465 | ; always using URL stored in browser's history or bookmarks. 1466 | ; http://php.net/session.use-trans-sid 1467 | session.use_trans_sid = 0 1468 | 1469 | ; Set session ID character length. This value could be between 22 to 256. 1470 | ; Shorter length than default is supported only for compatibility reason. 1471 | ; Users should use 32 or more chars. 1472 | ; http://php.net/session.sid-length 1473 | ; Default Value: 32 1474 | ; Development Value: 26 1475 | ; Production Value: 26 1476 | session.sid_length = 26 1477 | 1478 | ; The URL rewriter will look for URLs in a defined set of HTML tags. 1479 | ;
is special; if you include them here, the rewriter will 1480 | ; add a hidden field with the info which is otherwise appended 1481 | ; to URLs. tag's action attribute URL will not be modified 1482 | ; unless it is specified. 1483 | ; Note that all valid entries require a "=", even if no value follows. 1484 | ; Default Value: "a=href,area=href,frame=src,form=" 1485 | ; Development Value: "a=href,area=href,frame=src,form=" 1486 | ; Production Value: "a=href,area=href,frame=src,form=" 1487 | ; http://php.net/url-rewriter.tags 1488 | session.trans_sid_tags = "a=href,area=href,frame=src,form=" 1489 | 1490 | ; URL rewriter does not rewrite absolute URLs by default. 1491 | ; To enable rewrites for absolute pathes, target hosts must be specified 1492 | ; at RUNTIME. i.e. use ini_set() 1493 | ; tags is special. PHP will check action attribute's URL regardless 1494 | ; of session.trans_sid_tags setting. 1495 | ; If no host is defined, HTTP_HOST will be used for allowed host. 1496 | ; Example value: php.net,www.php.net,wiki.php.net 1497 | ; Use "," for multiple hosts. No spaces are allowed. 1498 | ; Default Value: "" 1499 | ; Development Value: "" 1500 | ; Production Value: "" 1501 | ;session.trans_sid_hosts="" 1502 | 1503 | ; Define how many bits are stored in each character when converting 1504 | ; the binary hash data to something readable. 1505 | ; Possible values: 1506 | ; 4 (4 bits: 0-9, a-f) 1507 | ; 5 (5 bits: 0-9, a-v) 1508 | ; 6 (6 bits: 0-9, a-z, A-Z, "-", ",") 1509 | ; Default Value: 4 1510 | ; Development Value: 5 1511 | ; Production Value: 5 1512 | ; http://php.net/session.hash-bits-per-character 1513 | session.sid_bits_per_character = 5 1514 | 1515 | ; Enable upload progress tracking in $_SESSION 1516 | ; Default Value: On 1517 | ; Development Value: On 1518 | ; Production Value: On 1519 | ; http://php.net/session.upload-progress.enabled 1520 | ;session.upload_progress.enabled = On 1521 | 1522 | ; Cleanup the progress information as soon as all POST data has been read 1523 | ; (i.e. upload completed). 1524 | ; Default Value: On 1525 | ; Development Value: On 1526 | ; Production Value: On 1527 | ; http://php.net/session.upload-progress.cleanup 1528 | ;session.upload_progress.cleanup = On 1529 | 1530 | ; A prefix used for the upload progress key in $_SESSION 1531 | ; Default Value: "upload_progress_" 1532 | ; Development Value: "upload_progress_" 1533 | ; Production Value: "upload_progress_" 1534 | ; http://php.net/session.upload-progress.prefix 1535 | ;session.upload_progress.prefix = "upload_progress_" 1536 | 1537 | ; The index name (concatenated with the prefix) in $_SESSION 1538 | ; containing the upload progress information 1539 | ; Default Value: "PHP_SESSION_UPLOAD_PROGRESS" 1540 | ; Development Value: "PHP_SESSION_UPLOAD_PROGRESS" 1541 | ; Production Value: "PHP_SESSION_UPLOAD_PROGRESS" 1542 | ; http://php.net/session.upload-progress.name 1543 | ;session.upload_progress.name = "PHP_SESSION_UPLOAD_PROGRESS" 1544 | 1545 | ; How frequently the upload progress should be updated. 1546 | ; Given either in percentages (per-file), or in bytes 1547 | ; Default Value: "1%" 1548 | ; Development Value: "1%" 1549 | ; Production Value: "1%" 1550 | ; http://php.net/session.upload-progress.freq 1551 | ;session.upload_progress.freq = "1%" 1552 | 1553 | ; The minimum delay between updates, in seconds 1554 | ; Default Value: 1 1555 | ; Development Value: 1 1556 | ; Production Value: 1 1557 | ; http://php.net/session.upload-progress.min-freq 1558 | ;session.upload_progress.min_freq = "1" 1559 | 1560 | ; Only write session data when session data is changed. Enabled by default. 1561 | ; http://php.net/session.lazy-write 1562 | ;session.lazy_write = On 1563 | 1564 | [Assertion] 1565 | ; Switch whether to compile assertions at all (to have no overhead at run-time) 1566 | ; -1: Do not compile at all 1567 | ; 0: Jump over assertion at run-time 1568 | ; 1: Execute assertions 1569 | ; Changing from or to a negative value is only possible in php.ini! (For turning assertions on and off at run-time, see assert.active, when zend.assertions = 1) 1570 | ; Default Value: 1 1571 | ; Development Value: 1 1572 | ; Production Value: -1 1573 | ; http://php.net/zend.assertions 1574 | zend.assertions = -1 1575 | 1576 | ; Assert(expr); active by default. 1577 | ; http://php.net/assert.active 1578 | ;assert.active = On 1579 | 1580 | ; Throw an AssertationException on failed assertions 1581 | ; http://php.net/assert.exception 1582 | ;assert.exception = On 1583 | 1584 | ; Issue a PHP warning for each failed assertion. (Overridden by assert.exception if active) 1585 | ; http://php.net/assert.warning 1586 | ;assert.warning = On 1587 | 1588 | ; Don't bail out by default. 1589 | ; http://php.net/assert.bail 1590 | ;assert.bail = Off 1591 | 1592 | ; User-function to be called if an assertion fails. 1593 | ; http://php.net/assert.callback 1594 | ;assert.callback = 0 1595 | 1596 | ; Eval the expression with current error_reporting(). Set to true if you want 1597 | ; error_reporting(0) around the eval(). 1598 | ; http://php.net/assert.quiet-eval 1599 | ;assert.quiet_eval = 0 1600 | 1601 | [COM] 1602 | ; path to a file containing GUIDs, IIDs or filenames of files with TypeLibs 1603 | ; http://php.net/com.typelib-file 1604 | ;com.typelib_file = 1605 | 1606 | ; allow Distributed-COM calls 1607 | ; http://php.net/com.allow-dcom 1608 | ;com.allow_dcom = true 1609 | 1610 | ; autoregister constants of a components typlib on com_load() 1611 | ; http://php.net/com.autoregister-typelib 1612 | ;com.autoregister_typelib = true 1613 | 1614 | ; register constants casesensitive 1615 | ; http://php.net/com.autoregister-casesensitive 1616 | ;com.autoregister_casesensitive = false 1617 | 1618 | ; show warnings on duplicate constant registrations 1619 | ; http://php.net/com.autoregister-verbose 1620 | ;com.autoregister_verbose = true 1621 | 1622 | ; The default character set code-page to use when passing strings to and from COM objects. 1623 | ; Default: system ANSI code page 1624 | ;com.code_page= 1625 | 1626 | [mbstring] 1627 | ; language for internal character representation. 1628 | ; This affects mb_send_mail() and mbstring.detect_order. 1629 | ; http://php.net/mbstring.language 1630 | ;mbstring.language = Japanese 1631 | 1632 | ; Use of this INI entry is deprecated, use global internal_encoding instead. 1633 | ; internal/script encoding. 1634 | ; Some encoding cannot work as internal encoding. (e.g. SJIS, BIG5, ISO-2022-*) 1635 | ; If empty, default_charset or internal_encoding or iconv.internal_encoding is used. 1636 | ; The precedence is: default_charset < internal_encoding < iconv.internal_encoding 1637 | ;mbstring.internal_encoding = 1638 | 1639 | ; Use of this INI entry is deprecated, use global input_encoding instead. 1640 | ; http input encoding. 1641 | ; mbstring.encoding_traslation = On is needed to use this setting. 1642 | ; If empty, default_charset or input_encoding or mbstring.input is used. 1643 | ; The precedence is: default_charset < intput_encoding < mbsting.http_input 1644 | ; http://php.net/mbstring.http-input 1645 | ;mbstring.http_input = 1646 | 1647 | ; Use of this INI entry is deprecated, use global output_encoding instead. 1648 | ; http output encoding. 1649 | ; mb_output_handler must be registered as output buffer to function. 1650 | ; If empty, default_charset or output_encoding or mbstring.http_output is used. 1651 | ; The precedence is: default_charset < output_encoding < mbstring.http_output 1652 | ; To use an output encoding conversion, mbstring's output handler must be set 1653 | ; otherwise output encoding conversion cannot be performed. 1654 | ; http://php.net/mbstring.http-output 1655 | ;mbstring.http_output = 1656 | 1657 | ; enable automatic encoding translation according to 1658 | ; mbstring.internal_encoding setting. Input chars are 1659 | ; converted to internal encoding by setting this to On. 1660 | ; Note: Do _not_ use automatic encoding translation for 1661 | ; portable libs/applications. 1662 | ; http://php.net/mbstring.encoding-translation 1663 | ;mbstring.encoding_translation = Off 1664 | 1665 | ; automatic encoding detection order. 1666 | ; "auto" detect order is changed according to mbstring.language 1667 | ; http://php.net/mbstring.detect-order 1668 | ;mbstring.detect_order = auto 1669 | 1670 | ; substitute_character used when character cannot be converted 1671 | ; one from another 1672 | ; http://php.net/mbstring.substitute-character 1673 | ;mbstring.substitute_character = none 1674 | 1675 | ; overload(replace) single byte functions by mbstring functions. 1676 | ; mail(), ereg(), etc are overloaded by mb_send_mail(), mb_ereg(), 1677 | ; etc. Possible values are 0,1,2,4 or combination of them. 1678 | ; For example, 7 for overload everything. 1679 | ; 0: No overload 1680 | ; 1: Overload mail() function 1681 | ; 2: Overload str*() functions 1682 | ; 4: Overload ereg*() functions 1683 | ; http://php.net/mbstring.func-overload 1684 | ;mbstring.func_overload = 0 1685 | 1686 | ; enable strict encoding detection. 1687 | ; Default: Off 1688 | ;mbstring.strict_detection = On 1689 | 1690 | ; This directive specifies the regex pattern of content types for which mb_output_handler() 1691 | ; is activated. 1692 | ; Default: mbstring.http_output_conv_mimetype=^(text/|application/xhtml\+xml) 1693 | ;mbstring.http_output_conv_mimetype= 1694 | 1695 | [gd] 1696 | ; Tell the jpeg decode to ignore warnings and try to create 1697 | ; a gd image. The warning will then be displayed as notices 1698 | ; disabled by default 1699 | ; http://php.net/gd.jpeg-ignore-warning 1700 | ;gd.jpeg_ignore_warning = 1 1701 | 1702 | [exif] 1703 | ; Exif UNICODE user comments are handled as UCS-2BE/UCS-2LE and JIS as JIS. 1704 | ; With mbstring support this will automatically be converted into the encoding 1705 | ; given by corresponding encode setting. When empty mbstring.internal_encoding 1706 | ; is used. For the decode settings you can distinguish between motorola and 1707 | ; intel byte order. A decode setting cannot be empty. 1708 | ; http://php.net/exif.encode-unicode 1709 | ;exif.encode_unicode = ISO-8859-15 1710 | 1711 | ; http://php.net/exif.decode-unicode-motorola 1712 | ;exif.decode_unicode_motorola = UCS-2BE 1713 | 1714 | ; http://php.net/exif.decode-unicode-intel 1715 | ;exif.decode_unicode_intel = UCS-2LE 1716 | 1717 | ; http://php.net/exif.encode-jis 1718 | ;exif.encode_jis = 1719 | 1720 | ; http://php.net/exif.decode-jis-motorola 1721 | ;exif.decode_jis_motorola = JIS 1722 | 1723 | ; http://php.net/exif.decode-jis-intel 1724 | ;exif.decode_jis_intel = JIS 1725 | 1726 | [Tidy] 1727 | ; The path to a default tidy configuration file to use when using tidy 1728 | ; http://php.net/tidy.default-config 1729 | ;tidy.default_config = /usr/local/lib/php/default.tcfg 1730 | 1731 | ; Should tidy clean and repair output automatically? 1732 | ; WARNING: Do not use this option if you are generating non-html content 1733 | ; such as dynamic images 1734 | ; http://php.net/tidy.clean-output 1735 | tidy.clean_output = Off 1736 | 1737 | [soap] 1738 | ; Enables or disables WSDL caching feature. 1739 | ; http://php.net/soap.wsdl-cache-enabled 1740 | soap.wsdl_cache_enabled=1 1741 | 1742 | ; Sets the directory name where SOAP extension will put cache files. 1743 | ; http://php.net/soap.wsdl-cache-dir 1744 | soap.wsdl_cache_dir="/tmp" 1745 | 1746 | ; (time to live) Sets the number of second while cached file will be used 1747 | ; instead of original one. 1748 | ; http://php.net/soap.wsdl-cache-ttl 1749 | soap.wsdl_cache_ttl=86400 1750 | 1751 | ; Sets the size of the cache limit. (Max. number of WSDL files to cache) 1752 | soap.wsdl_cache_limit = 5 1753 | 1754 | [sysvshm] 1755 | ; A default size of the shared memory segment 1756 | ;sysvshm.init_mem = 10000 1757 | 1758 | [ldap] 1759 | ; Sets the maximum number of open links or -1 for unlimited. 1760 | ldap.max_links = -1 1761 | 1762 | [dba] 1763 | ;dba.default_handler= 1764 | 1765 | [opcache] 1766 | ; Determines if Zend OPCache is enabled 1767 | ;opcache.enable=1 1768 | 1769 | ; Determines if Zend OPCache is enabled for the CLI version of PHP 1770 | ;opcache.enable_cli=1 1771 | 1772 | ; The OPcache shared memory storage size. 1773 | ;opcache.memory_consumption=128 1774 | 1775 | ; The amount of memory for interned strings in Mbytes. 1776 | ;opcache.interned_strings_buffer=8 1777 | 1778 | ; The maximum number of keys (scripts) in the OPcache hash table. 1779 | ; Only numbers between 200 and 1000000 are allowed. 1780 | ;opcache.max_accelerated_files=10000 1781 | 1782 | ; The maximum percentage of "wasted" memory until a restart is scheduled. 1783 | ;opcache.max_wasted_percentage=5 1784 | 1785 | ; When this directive is enabled, the OPcache appends the current working 1786 | ; directory to the script key, thus eliminating possible collisions between 1787 | ; files with the same name (basename). Disabling the directive improves 1788 | ; performance, but may break existing applications. 1789 | ;opcache.use_cwd=1 1790 | 1791 | ; When disabled, you must reset the OPcache manually or restart the 1792 | ; webserver for changes to the filesystem to take effect. 1793 | ;opcache.validate_timestamps=1 1794 | 1795 | ; How often (in seconds) to check file timestamps for changes to the shared 1796 | ; memory storage allocation. ("1" means validate once per second, but only 1797 | ; once per request. "0" means always validate) 1798 | ;opcache.revalidate_freq=2 1799 | 1800 | ; Enables or disables file search in include_path optimization 1801 | ;opcache.revalidate_path=0 1802 | 1803 | ; If disabled, all PHPDoc comments are dropped from the code to reduce the 1804 | ; size of the optimized code. 1805 | ;opcache.save_comments=1 1806 | 1807 | ; If enabled, a fast shutdown sequence is used for the accelerated code 1808 | ; Depending on the used Memory Manager this may cause some incompatibilities. 1809 | ;opcache.fast_shutdown=0 1810 | 1811 | ; Allow file existence override (file_exists, etc.) performance feature. 1812 | ;opcache.enable_file_override=0 1813 | 1814 | ; A bitmask, where each bit enables or disables the appropriate OPcache 1815 | ; passes 1816 | ;opcache.optimization_level=0xffffffff 1817 | 1818 | ;opcache.inherited_hack=1 1819 | ;opcache.dups_fix=0 1820 | 1821 | ; The location of the OPcache blacklist file (wildcards allowed). 1822 | ; Each OPcache blacklist file is a text file that holds the names of files 1823 | ; that should not be accelerated. The file format is to add each filename 1824 | ; to a new line. The filename may be a full path or just a file prefix 1825 | ; (i.e., /var/www/x blacklists all the files and directories in /var/www 1826 | ; that start with 'x'). Line starting with a ; are ignored (comments). 1827 | ;opcache.blacklist_filename= 1828 | 1829 | ; Allows exclusion of large files from being cached. By default all files 1830 | ; are cached. 1831 | ;opcache.max_file_size=0 1832 | 1833 | ; Check the cache checksum each N requests. 1834 | ; The default value of "0" means that the checks are disabled. 1835 | ;opcache.consistency_checks=0 1836 | 1837 | ; How long to wait (in seconds) for a scheduled restart to begin if the cache 1838 | ; is not being accessed. 1839 | ;opcache.force_restart_timeout=180 1840 | 1841 | ; OPcache error_log file name. Empty string assumes "stderr". 1842 | ;opcache.error_log= 1843 | 1844 | ; All OPcache errors go to the Web server log. 1845 | ; By default, only fatal errors (level 0) or errors (level 1) are logged. 1846 | ; You can also enable warnings (level 2), info messages (level 3) or 1847 | ; debug messages (level 4). 1848 | ;opcache.log_verbosity_level=1 1849 | 1850 | ; Preferred Shared Memory back-end. Leave empty and let the system decide. 1851 | ;opcache.preferred_memory_model= 1852 | 1853 | ; Protect the shared memory from unexpected writing during script execution. 1854 | ; Useful for internal debugging only. 1855 | ;opcache.protect_memory=0 1856 | 1857 | ; Allows calling OPcache API functions only from PHP scripts which path is 1858 | ; started from specified string. The default "" means no restriction 1859 | ;opcache.restrict_api= 1860 | 1861 | ; Mapping base of shared memory segments (for Windows only). All the PHP 1862 | ; processes have to map shared memory into the same address space. This 1863 | ; directive allows to manually fix the "Unable to reattach to base address" 1864 | ; errors. 1865 | ;opcache.mmap_base= 1866 | 1867 | ; Enables and sets the second level cache directory. 1868 | ; It should improve performance when SHM memory is full, at server restart or 1869 | ; SHM reset. The default "" disables file based caching. 1870 | ;opcache.file_cache= 1871 | 1872 | ; Enables or disables opcode caching in shared memory. 1873 | ;opcache.file_cache_only=0 1874 | 1875 | ; Enables or disables checksum validation when script loaded from file cache. 1876 | ;opcache.file_cache_consistency_checks=1 1877 | 1878 | ; Implies opcache.file_cache_only=1 for a certain process that failed to 1879 | ; reattach to the shared memory (for Windows only). Explicitly enabled file 1880 | ; cache is required. 1881 | ;opcache.file_cache_fallback=1 1882 | 1883 | ; Enables or disables copying of PHP code (text segment) into HUGE PAGES. 1884 | ; This should improve performance, but requires appropriate OS configuration. 1885 | ;opcache.huge_code_pages=1 1886 | 1887 | ; Validate cached file permissions. 1888 | ;opcache.validate_permission=0 1889 | 1890 | ; Prevent name collisions in chroot'ed environment. 1891 | ;opcache.validate_root=0 1892 | 1893 | [curl] 1894 | ; A default value for the CURLOPT_CAINFO option. This is required to be an 1895 | ; absolute path. 1896 | ;curl.cainfo = 1897 | 1898 | [openssl] 1899 | ; The location of a Certificate Authority (CA) file on the local filesystem 1900 | ; to use when verifying the identity of SSL/TLS peers. Most users should 1901 | ; not specify a value for this directive as PHP will attempt to use the 1902 | ; OS-managed cert stores in its absence. If specified, this value may still 1903 | ; be overridden on a per-stream basis via the "cafile" SSL stream context 1904 | ; option. 1905 | ;openssl.cafile= 1906 | 1907 | ; If openssl.cafile is not specified or if the CA file is not found, the 1908 | ; directory pointed to by openssl.capath is searched for a suitable 1909 | ; certificate. This value must be a correctly hashed certificate directory. 1910 | ; Most users should not specify a value for this directive as PHP will 1911 | ; attempt to use the OS-managed cert stores in its absence. If specified, 1912 | ; this value may still be overridden on a per-stream basis via the "capath" 1913 | ; SSL stream context option. 1914 | ;openssl.capath= 1915 | 1916 | ; Local Variables: 1917 | ; tab-width: 4 1918 | ; End: 1919 | --------------------------------------------------------------------------------