it's working!
This commit is contained in:
commit
1b7efa8c25
13
.env
Normal file
13
.env
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
COMPOSE_PROJECT_NAME=materiod8
|
||||||
|
|
||||||
|
PROJECT_ROOT=./public_html
|
||||||
|
LEGACY_ROOT=./drupal7
|
||||||
|
LOG_ROOT=./log
|
||||||
|
|
||||||
|
DB_IMPORTE_FILE_D8=./ressources/materio_d8.sql
|
||||||
|
DB_IMPORTE_FILE_D7=./ressources/materio_d7.sql
|
||||||
|
DB_ROOT_PASSWORD=materio
|
||||||
|
DB_NAME=materio_d8
|
||||||
|
DB_LEGACY_NAME=materio_d7
|
||||||
|
DB_USERNAME=materio
|
||||||
|
DB_PASSWORD=materio
|
5
.gitignore
vendored
Normal file
5
.gitignore
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
public_html/*
|
||||||
|
drupal7/*
|
||||||
|
log/*
|
||||||
|
*.sql
|
||||||
|
bin
|
3
.gitmodules
vendored
Normal file
3
.gitmodules
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
[submodule "public_html"]
|
||||||
|
path = public_html
|
||||||
|
url = https://figureslibres.io/gogs/bachir/materio-d8.git
|
2
Docker/mysql/mysql.cnf
Normal file
2
Docker/mysql/mysql.cnf
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
[mysqld]
|
||||||
|
max_allowed_packet=500M
|
3
Docker/nginx/Dockerfile
Normal file
3
Docker/nginx/Dockerfile
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
FROM nginx:latest
|
||||||
|
|
||||||
|
COPY ./default.conf /etc/nginx/conf.d/default.conf
|
37
Docker/nginx/default.conf
Normal file
37
Docker/nginx/default.conf
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
server {
|
||||||
|
listen 80 default_server;
|
||||||
|
root /var/www/html;
|
||||||
|
index index.html index.php;
|
||||||
|
server_name *.materio.com;
|
||||||
|
|
||||||
|
charset utf-8;
|
||||||
|
|
||||||
|
location / {
|
||||||
|
try_files $uri $uri/ /index.php?$query_string;
|
||||||
|
}
|
||||||
|
|
||||||
|
location = /favicon.ico { access_log off; log_not_found off; }
|
||||||
|
location = /robots.txt { access_log off; log_not_found off; }
|
||||||
|
|
||||||
|
access_log on;
|
||||||
|
error_log /var/log/nginx/error.log error;
|
||||||
|
|
||||||
|
sendfile off;
|
||||||
|
|
||||||
|
client_max_body_size 100m;
|
||||||
|
|
||||||
|
location ~ \.php$ {
|
||||||
|
fastcgi_split_path_info ^(.+\.php)(/.+)$;
|
||||||
|
fastcgi_pass php:9000;
|
||||||
|
fastcgi_index index.php;
|
||||||
|
include fastcgi_params;
|
||||||
|
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
||||||
|
fastcgi_intercept_errors off;
|
||||||
|
fastcgi_buffer_size 16k;
|
||||||
|
fastcgi_buffers 4 16k;
|
||||||
|
}
|
||||||
|
|
||||||
|
location ~ /\.ht {
|
||||||
|
deny all;
|
||||||
|
}
|
||||||
|
}
|
32
Docker/php/Dockerfile
Normal file
32
Docker/php/Dockerfile
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
FROM php:7.0-fpm
|
||||||
|
|
||||||
|
COPY ./php-custom.ini /usr/local/etc/php/conf.d/php-custom.ini
|
||||||
|
|
||||||
|
RUN apt-get update && apt-get install -y \
|
||||||
|
libfreetype6-dev \
|
||||||
|
libjpeg62-turbo-dev \
|
||||||
|
libmcrypt-dev \
|
||||||
|
libpng-dev \
|
||||||
|
mysql-client \
|
||||||
|
zip && \
|
||||||
|
docker-php-ext-install -j$(nproc) mcrypt iconv && \
|
||||||
|
docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ && \
|
||||||
|
apt-get install -y imagemagick libmagickwand-dev && \
|
||||||
|
pecl install imagick && docker-php-ext-enable imagick && \
|
||||||
|
docker-php-ext-install -j$(nproc) gd && \
|
||||||
|
docker-php-ext-install pdo_mysql zip && \
|
||||||
|
docker-php-ext-install opcache && \
|
||||||
|
apt-get install -y git vim && \
|
||||||
|
pecl install redis-3.1.0 && \
|
||||||
|
pecl install xdebug-2.5.0 && \
|
||||||
|
docker-php-ext-enable redis xdebug
|
||||||
|
|
||||||
|
RUN export COMPOSER_HOME=/usr/local/composer && \
|
||||||
|
curl -sS https://getcomposer.org/installer \
|
||||||
|
| php -- --install-dir=/usr/local/bin --filename=composer && \
|
||||||
|
curl https://drupalconsole.com/installer \
|
||||||
|
-L -o /usr/local/bin/drupal && \
|
||||||
|
chmod +x /usr/local/bin/drupal && \
|
||||||
|
curl https://github.com/drush-ops/drush-launcher/releases/download/0.6.0/drush.phar \
|
||||||
|
-L -o /usr/local/bin/drush && \
|
||||||
|
chmod +x /usr/local/bin/drush
|
3
Docker/php/php-custom.ini
Normal file
3
Docker/php/php-custom.ini
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
memory_limit = 512M
|
||||||
|
upload_max_filesize = 50M
|
||||||
|
post_max_size = 50M
|
339
LICENSE.txt
Normal file
339
LICENSE.txt
Normal file
@ -0,0 +1,339 @@
|
|||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
Version 2, June 1991
|
||||||
|
|
||||||
|
Copyright (C) 1989, 1991 Free Software Foundation, Inc.,
|
||||||
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
|
Preamble
|
||||||
|
|
||||||
|
The licenses for most software are designed to take away your
|
||||||
|
freedom to share and change it. By contrast, the GNU General Public
|
||||||
|
License is intended to guarantee your freedom to share and change free
|
||||||
|
software--to make sure the software is free for all its users. This
|
||||||
|
General Public License applies to most of the Free Software
|
||||||
|
Foundation's software and to any other program whose authors commit to
|
||||||
|
using it. (Some other Free Software Foundation software is covered by
|
||||||
|
the GNU Lesser General Public License instead.) You can apply it to
|
||||||
|
your programs, too.
|
||||||
|
|
||||||
|
When we speak of free software, we are referring to freedom, not
|
||||||
|
price. Our General Public Licenses are designed to make sure that you
|
||||||
|
have the freedom to distribute copies of free software (and charge for
|
||||||
|
this service if you wish), that you receive source code or can get it
|
||||||
|
if you want it, that you can change the software or use pieces of it
|
||||||
|
in new free programs; and that you know you can do these things.
|
||||||
|
|
||||||
|
To protect your rights, we need to make restrictions that forbid
|
||||||
|
anyone to deny you these rights or to ask you to surrender the rights.
|
||||||
|
These restrictions translate to certain responsibilities for you if you
|
||||||
|
distribute copies of the software, or if you modify it.
|
||||||
|
|
||||||
|
For example, if you distribute copies of such a program, whether
|
||||||
|
gratis or for a fee, you must give the recipients all the rights that
|
||||||
|
you have. You must make sure that they, too, receive or can get the
|
||||||
|
source code. And you must show them these terms so they know their
|
||||||
|
rights.
|
||||||
|
|
||||||
|
We protect your rights with two steps: (1) copyright the software, and
|
||||||
|
(2) offer you this license which gives you legal permission to copy,
|
||||||
|
distribute and/or modify the software.
|
||||||
|
|
||||||
|
Also, for each author's protection and ours, we want to make certain
|
||||||
|
that everyone understands that there is no warranty for this free
|
||||||
|
software. If the software is modified by someone else and passed on, we
|
||||||
|
want its recipients to know that what they have is not the original, so
|
||||||
|
that any problems introduced by others will not reflect on the original
|
||||||
|
authors' reputations.
|
||||||
|
|
||||||
|
Finally, any free program is threatened constantly by software
|
||||||
|
patents. We wish to avoid the danger that redistributors of a free
|
||||||
|
program will individually obtain patent licenses, in effect making the
|
||||||
|
program proprietary. To prevent this, we have made it clear that any
|
||||||
|
patent must be licensed for everyone's free use or not licensed at all.
|
||||||
|
|
||||||
|
The precise terms and conditions for copying, distribution and
|
||||||
|
modification follow.
|
||||||
|
|
||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||||
|
|
||||||
|
0. This License applies to any program or other work which contains
|
||||||
|
a notice placed by the copyright holder saying it may be distributed
|
||||||
|
under the terms of this General Public License. The "Program", below,
|
||||||
|
refers to any such program or work, and a "work based on the Program"
|
||||||
|
means either the Program or any derivative work under copyright law:
|
||||||
|
that is to say, a work containing the Program or a portion of it,
|
||||||
|
either verbatim or with modifications and/or translated into another
|
||||||
|
language. (Hereinafter, translation is included without limitation in
|
||||||
|
the term "modification".) Each licensee is addressed as "you".
|
||||||
|
|
||||||
|
Activities other than copying, distribution and modification are not
|
||||||
|
covered by this License; they are outside its scope. The act of
|
||||||
|
running the Program is not restricted, and the output from the Program
|
||||||
|
is covered only if its contents constitute a work based on the
|
||||||
|
Program (independent of having been made by running the Program).
|
||||||
|
Whether that is true depends on what the Program does.
|
||||||
|
|
||||||
|
1. You may copy and distribute verbatim copies of the Program's
|
||||||
|
source code as you receive it, in any medium, provided that you
|
||||||
|
conspicuously and appropriately publish on each copy an appropriate
|
||||||
|
copyright notice and disclaimer of warranty; keep intact all the
|
||||||
|
notices that refer to this License and to the absence of any warranty;
|
||||||
|
and give any other recipients of the Program a copy of this License
|
||||||
|
along with the Program.
|
||||||
|
|
||||||
|
You may charge a fee for the physical act of transferring a copy, and
|
||||||
|
you may at your option offer warranty protection in exchange for a fee.
|
||||||
|
|
||||||
|
2. You may modify your copy or copies of the Program or any portion
|
||||||
|
of it, thus forming a work based on the Program, and copy and
|
||||||
|
distribute such modifications or work under the terms of Section 1
|
||||||
|
above, provided that you also meet all of these conditions:
|
||||||
|
|
||||||
|
a) You must cause the modified files to carry prominent notices
|
||||||
|
stating that you changed the files and the date of any change.
|
||||||
|
|
||||||
|
b) You must cause any work that you distribute or publish, that in
|
||||||
|
whole or in part contains or is derived from the Program or any
|
||||||
|
part thereof, to be licensed as a whole at no charge to all third
|
||||||
|
parties under the terms of this License.
|
||||||
|
|
||||||
|
c) If the modified program normally reads commands interactively
|
||||||
|
when run, you must cause it, when started running for such
|
||||||
|
interactive use in the most ordinary way, to print or display an
|
||||||
|
announcement including an appropriate copyright notice and a
|
||||||
|
notice that there is no warranty (or else, saying that you provide
|
||||||
|
a warranty) and that users may redistribute the program under
|
||||||
|
these conditions, and telling the user how to view a copy of this
|
||||||
|
License. (Exception: if the Program itself is interactive but
|
||||||
|
does not normally print such an announcement, your work based on
|
||||||
|
the Program is not required to print an announcement.)
|
||||||
|
|
||||||
|
These requirements apply to the modified work as a whole. If
|
||||||
|
identifiable sections of that work are not derived from the Program,
|
||||||
|
and can be reasonably considered independent and separate works in
|
||||||
|
themselves, then this License, and its terms, do not apply to those
|
||||||
|
sections when you distribute them as separate works. But when you
|
||||||
|
distribute the same sections as part of a whole which is a work based
|
||||||
|
on the Program, the distribution of the whole must be on the terms of
|
||||||
|
this License, whose permissions for other licensees extend to the
|
||||||
|
entire whole, and thus to each and every part regardless of who wrote it.
|
||||||
|
|
||||||
|
Thus, it is not the intent of this section to claim rights or contest
|
||||||
|
your rights to work written entirely by you; rather, the intent is to
|
||||||
|
exercise the right to control the distribution of derivative or
|
||||||
|
collective works based on the Program.
|
||||||
|
|
||||||
|
In addition, mere aggregation of another work not based on the Program
|
||||||
|
with the Program (or with a work based on the Program) on a volume of
|
||||||
|
a storage or distribution medium does not bring the other work under
|
||||||
|
the scope of this License.
|
||||||
|
|
||||||
|
3. You may copy and distribute the Program (or a work based on it,
|
||||||
|
under Section 2) in object code or executable form under the terms of
|
||||||
|
Sections 1 and 2 above provided that you also do one of the following:
|
||||||
|
|
||||||
|
a) Accompany it with the complete corresponding machine-readable
|
||||||
|
source code, which must be distributed under the terms of Sections
|
||||||
|
1 and 2 above on a medium customarily used for software interchange; or,
|
||||||
|
|
||||||
|
b) Accompany it with a written offer, valid for at least three
|
||||||
|
years, to give any third party, for a charge no more than your
|
||||||
|
cost of physically performing source distribution, a complete
|
||||||
|
machine-readable copy of the corresponding source code, to be
|
||||||
|
distributed under the terms of Sections 1 and 2 above on a medium
|
||||||
|
customarily used for software interchange; or,
|
||||||
|
|
||||||
|
c) Accompany it with the information you received as to the offer
|
||||||
|
to distribute corresponding source code. (This alternative is
|
||||||
|
allowed only for noncommercial distribution and only if you
|
||||||
|
received the program in object code or executable form with such
|
||||||
|
an offer, in accord with Subsection b above.)
|
||||||
|
|
||||||
|
The source code for a work means the preferred form of the work for
|
||||||
|
making modifications to it. For an executable work, complete source
|
||||||
|
code means all the source code for all modules it contains, plus any
|
||||||
|
associated interface definition files, plus the scripts used to
|
||||||
|
control compilation and installation of the executable. However, as a
|
||||||
|
special exception, the source code distributed need not include
|
||||||
|
anything that is normally distributed (in either source or binary
|
||||||
|
form) with the major components (compiler, kernel, and so on) of the
|
||||||
|
operating system on which the executable runs, unless that component
|
||||||
|
itself accompanies the executable.
|
||||||
|
|
||||||
|
If distribution of executable or object code is made by offering
|
||||||
|
access to copy from a designated place, then offering equivalent
|
||||||
|
access to copy the source code from the same place counts as
|
||||||
|
distribution of the source code, even though third parties are not
|
||||||
|
compelled to copy the source along with the object code.
|
||||||
|
|
||||||
|
4. You may not copy, modify, sublicense, or distribute the Program
|
||||||
|
except as expressly provided under this License. Any attempt
|
||||||
|
otherwise to copy, modify, sublicense or distribute the Program is
|
||||||
|
void, and will automatically terminate your rights under this License.
|
||||||
|
However, parties who have received copies, or rights, from you under
|
||||||
|
this License will not have their licenses terminated so long as such
|
||||||
|
parties remain in full compliance.
|
||||||
|
|
||||||
|
5. You are not required to accept this License, since you have not
|
||||||
|
signed it. However, nothing else grants you permission to modify or
|
||||||
|
distribute the Program or its derivative works. These actions are
|
||||||
|
prohibited by law if you do not accept this License. Therefore, by
|
||||||
|
modifying or distributing the Program (or any work based on the
|
||||||
|
Program), you indicate your acceptance of this License to do so, and
|
||||||
|
all its terms and conditions for copying, distributing or modifying
|
||||||
|
the Program or works based on it.
|
||||||
|
|
||||||
|
6. Each time you redistribute the Program (or any work based on the
|
||||||
|
Program), the recipient automatically receives a license from the
|
||||||
|
original licensor to copy, distribute or modify the Program subject to
|
||||||
|
these terms and conditions. You may not impose any further
|
||||||
|
restrictions on the recipients' exercise of the rights granted herein.
|
||||||
|
You are not responsible for enforcing compliance by third parties to
|
||||||
|
this License.
|
||||||
|
|
||||||
|
7. If, as a consequence of a court judgment or allegation of patent
|
||||||
|
infringement or for any other reason (not limited to patent issues),
|
||||||
|
conditions are imposed on you (whether by court order, agreement or
|
||||||
|
otherwise) that contradict the conditions of this License, they do not
|
||||||
|
excuse you from the conditions of this License. If you cannot
|
||||||
|
distribute so as to satisfy simultaneously your obligations under this
|
||||||
|
License and any other pertinent obligations, then as a consequence you
|
||||||
|
may not distribute the Program at all. For example, if a patent
|
||||||
|
license would not permit royalty-free redistribution of the Program by
|
||||||
|
all those who receive copies directly or indirectly through you, then
|
||||||
|
the only way you could satisfy both it and this License would be to
|
||||||
|
refrain entirely from distribution of the Program.
|
||||||
|
|
||||||
|
If any portion of this section is held invalid or unenforceable under
|
||||||
|
any particular circumstance, the balance of the section is intended to
|
||||||
|
apply and the section as a whole is intended to apply in other
|
||||||
|
circumstances.
|
||||||
|
|
||||||
|
It is not the purpose of this section to induce you to infringe any
|
||||||
|
patents or other property right claims or to contest validity of any
|
||||||
|
such claims; this section has the sole purpose of protecting the
|
||||||
|
integrity of the free software distribution system, which is
|
||||||
|
implemented by public license practices. Many people have made
|
||||||
|
generous contributions to the wide range of software distributed
|
||||||
|
through that system in reliance on consistent application of that
|
||||||
|
system; it is up to the author/donor to decide if he or she is willing
|
||||||
|
to distribute software through any other system and a licensee cannot
|
||||||
|
impose that choice.
|
||||||
|
|
||||||
|
This section is intended to make thoroughly clear what is believed to
|
||||||
|
be a consequence of the rest of this License.
|
||||||
|
|
||||||
|
8. If the distribution and/or use of the Program is restricted in
|
||||||
|
certain countries either by patents or by copyrighted interfaces, the
|
||||||
|
original copyright holder who places the Program under this License
|
||||||
|
may add an explicit geographical distribution limitation excluding
|
||||||
|
those countries, so that distribution is permitted only in or among
|
||||||
|
countries not thus excluded. In such case, this License incorporates
|
||||||
|
the limitation as if written in the body of this License.
|
||||||
|
|
||||||
|
9. The Free Software Foundation may publish revised and/or new versions
|
||||||
|
of the General Public License from time to time. Such new versions will
|
||||||
|
be similar in spirit to the present version, but may differ in detail to
|
||||||
|
address new problems or concerns.
|
||||||
|
|
||||||
|
Each version is given a distinguishing version number. If the Program
|
||||||
|
specifies a version number of this License which applies to it and "any
|
||||||
|
later version", you have the option of following the terms and conditions
|
||||||
|
either of that version or of any later version published by the Free
|
||||||
|
Software Foundation. If the Program does not specify a version number of
|
||||||
|
this License, you may choose any version ever published by the Free Software
|
||||||
|
Foundation.
|
||||||
|
|
||||||
|
10. If you wish to incorporate parts of the Program into other free
|
||||||
|
programs whose distribution conditions are different, write to the author
|
||||||
|
to ask for permission. For software which is copyrighted by the Free
|
||||||
|
Software Foundation, write to the Free Software Foundation; we sometimes
|
||||||
|
make exceptions for this. Our decision will be guided by the two goals
|
||||||
|
of preserving the free status of all derivatives of our free software and
|
||||||
|
of promoting the sharing and reuse of software generally.
|
||||||
|
|
||||||
|
NO WARRANTY
|
||||||
|
|
||||||
|
11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
|
||||||
|
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
|
||||||
|
OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
|
||||||
|
PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
|
||||||
|
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
|
||||||
|
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
|
||||||
|
PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
|
||||||
|
REPAIR OR CORRECTION.
|
||||||
|
|
||||||
|
12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||||
|
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
|
||||||
|
REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
|
||||||
|
INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
|
||||||
|
OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
|
||||||
|
TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
|
||||||
|
YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
|
||||||
|
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGES.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
How to Apply These Terms to Your New Programs
|
||||||
|
|
||||||
|
If you develop a new program, and you want it to be of the greatest
|
||||||
|
possible use to the public, the best way to achieve this is to make it
|
||||||
|
free software which everyone can redistribute and change under these terms.
|
||||||
|
|
||||||
|
To do so, attach the following notices to the program. It is safest
|
||||||
|
to attach them to the start of each source file to most effectively
|
||||||
|
convey the exclusion of warranty; and each file should have at least
|
||||||
|
the "copyright" line and a pointer to where the full notice is found.
|
||||||
|
|
||||||
|
<one line to give the program's name and a brief idea of what it does.>
|
||||||
|
Copyright (C) <year> <name of author>
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License along
|
||||||
|
with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
|
||||||
|
Also add information on how to contact you by electronic and paper mail.
|
||||||
|
|
||||||
|
If the program is interactive, make it output a short notice like this
|
||||||
|
when it starts in an interactive mode:
|
||||||
|
|
||||||
|
Gnomovision version 69, Copyright (C) year name of author
|
||||||
|
Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||||
|
This is free software, and you are welcome to redistribute it
|
||||||
|
under certain conditions; type `show c' for details.
|
||||||
|
|
||||||
|
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||||
|
parts of the General Public License. Of course, the commands you use may
|
||||||
|
be called something other than `show w' and `show c'; they could even be
|
||||||
|
mouse-clicks or menu items--whatever suits your program.
|
||||||
|
|
||||||
|
You should also get your employer (if you work as a programmer) or your
|
||||||
|
school, if any, to sign a "copyright disclaimer" for the program, if
|
||||||
|
necessary. Here is a sample; alter the names:
|
||||||
|
|
||||||
|
Yoyodyne, Inc., hereby disclaims all copyright interest in the program
|
||||||
|
`Gnomovision' (which makes passes at compilers) written by James Hacker.
|
||||||
|
|
||||||
|
<signature of Ty Coon>, 1 April 1989
|
||||||
|
Ty Coon, President of Vice
|
||||||
|
|
||||||
|
This General Public License does not permit incorporating your program into
|
||||||
|
proprietary programs. If your program is a subroutine library, you may
|
||||||
|
consider it more useful to permit linking proprietary applications with the
|
||||||
|
library. If this is what you want to do, use the GNU Lesser General
|
||||||
|
Public License instead of this License.
|
122
README.md
Normal file
122
README.md
Normal file
@ -0,0 +1,122 @@
|
|||||||
|
|
||||||
|
# Materio 8.x Docker Environement
|
||||||
|
Materio powered by druapl 8 in docker environement (nginx, php:7-fpm+drush, phpmyadmin, redis)
|
||||||
|
|
||||||
|
## Install docker
|
||||||
|
```
|
||||||
|
sudo pacman -S docker docker-compose docker-machine
|
||||||
|
```
|
||||||
|
|
||||||
|
## Clone this repos
|
||||||
|
|
||||||
|
this will clone this repos (main docker environement) and the edlp drupal 8 source code (without sites/default folder)
|
||||||
|
|
||||||
|
```
|
||||||
|
git clone --recursive -o figli https://figureslibres.io/gogs/bachir/docker-materio-d8.git
|
||||||
|
```
|
||||||
|
|
||||||
|
### setup /sites/default/settings.php
|
||||||
|
|
||||||
|
```cp -r ressources/default public_html/sites/```
|
||||||
|
|
||||||
|
### get the sites/default/files folder
|
||||||
|
get the files from where you have it and rsync it to public_html/sites/default/files/
|
||||||
|
|
||||||
|
## Mysql
|
||||||
|
Copy your-sql-dump.sql into ./ressources/materio_d8.sql
|
||||||
|
It will be automaticly imported into the mysql container db (only) on the first docker-compose up
|
||||||
|
|
||||||
|
## Hosts and reverse proxy
|
||||||
|
|
||||||
|
add to your /etc/hosts :
|
||||||
|
```
|
||||||
|
127.0.0.1 dev.materio.com
|
||||||
|
127.0.0.1 dev.phpmyadmin.materio.com
|
||||||
|
```
|
||||||
|
configure your apache vhosts to add a reverse proxy that will redirect the dev.materio.com to our container
|
||||||
|
```
|
||||||
|
<Virtualhost *:80>
|
||||||
|
ServerName dev.materio.com
|
||||||
|
ProxyPass / http://127.0.0.1:8880/
|
||||||
|
ProxyPassReverse / http://127.0.0.1:8880/
|
||||||
|
ProxyRequests Off
|
||||||
|
ProxyPreserveHost On
|
||||||
|
</Virtualhost>
|
||||||
|
```
|
||||||
|
```
|
||||||
|
<Virtualhost *:80>
|
||||||
|
ServerName dev.phpmyadmin.materio.com
|
||||||
|
ProxyPass / http://127.0.0.1:8881/
|
||||||
|
ProxyPassReverse / http://127.0.0.1:8881/
|
||||||
|
ProxyRequests Off
|
||||||
|
ProxyPreserveHost On
|
||||||
|
</Virtualhost>
|
||||||
|
```
|
||||||
|
## Docker
|
||||||
|
|
||||||
|
### build
|
||||||
|
only before the first run (may take some time)
|
||||||
|
```
|
||||||
|
sudo docker-compose build
|
||||||
|
```
|
||||||
|
### run
|
||||||
|
then each time you want to launch the app
|
||||||
|
```
|
||||||
|
sudo docker-compose up -d
|
||||||
|
```
|
||||||
|
Be aware that a first up, since the db is empty, it will be populated with your file db.sql. It may take some time depending of your db size.
|
||||||
|
|
||||||
|
## Druapal Composer install
|
||||||
|
Only at first up, finish to install drupal composer dependencies
|
||||||
|
```
|
||||||
|
sudo docker exec -it materiod8_php_1 bash
|
||||||
|
composer install
|
||||||
|
```
|
||||||
|
|
||||||
|
## Visualize
|
||||||
|
You can now visit http://dev.materio.com on your browser
|
||||||
|
|
||||||
|
## Coding
|
||||||
|
### drush
|
||||||
|
you can access to drush by loging into the php container
|
||||||
|
```
|
||||||
|
sudo docker exec -it materiod8_php_1 bash
|
||||||
|
```
|
||||||
|
once inside the php container in /var/www/html you can use drush as usual
|
||||||
|
|
||||||
|
### gulp
|
||||||
|
Dev process needs gulp to run in:
|
||||||
|
- public_html/sites/all/modules/custom/materio/
|
||||||
|
- public_html/sites/all/themes/custom/materio/
|
||||||
|
if you have to modifie js or scss source code, you need to do in each of these 2 folder:
|
||||||
|
```
|
||||||
|
npm install
|
||||||
|
gulp
|
||||||
|
```
|
||||||
|
|
||||||
|
## updateding manualy mysql db
|
||||||
|
copy your db backup into the mysql container
|
||||||
|
```
|
||||||
|
sudo docker cp your-db-file.sql materiod8_mysql_1:/root/
|
||||||
|
```
|
||||||
|
log into mysql container
|
||||||
|
```
|
||||||
|
sudo docker exec -it materiod8_mysql_1 bash
|
||||||
|
```
|
||||||
|
once inside the mysql container you can use mysql command to drop then create and load the db with your file
|
||||||
|
|
||||||
|
|
||||||
|
# sources
|
||||||
|
https://www.ostraining.com/blog/drupal/docker/
|
||||||
|
|
||||||
|
http://tech.osteel.me/posts/2017/01/15/how-to-use-docker-for-local-web-development-an-update.html
|
||||||
|
|
||||||
|
https://mmenozzi.github.io/2016/01/22/php-web-development-with-docker/
|
||||||
|
|
||||||
|
https://dzone.com/articles/continuous-drupal-maintaining-a-drupal-website-wit//
|
||||||
|
|
||||||
|
https://github.com/glaux/drupal8docker
|
||||||
|
|
||||||
|
https://www.jeffgeerling.com/blogs/jeff-geerling/drupal-8-redis-php-7-nginx-and
|
||||||
|
|
||||||
|
https://chromatichq.com/blog/configuring-redis-caching-drupal-8
|
94
docker-compose.yml
Normal file
94
docker-compose.yml
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
version: "3.5"
|
||||||
|
|
||||||
|
services:
|
||||||
|
mysql:
|
||||||
|
image: mariadb:latest
|
||||||
|
volumes:
|
||||||
|
- db-data:/var/lib/mysql
|
||||||
|
- ./Docker/mysql/mysql.cnf:/etc/mysql/conf.d/custom.cnf:ro
|
||||||
|
# - "${DB_IMPORTE_FILE_D8}:/docker-entrypoint-initdb.d/materio_d8.sql"
|
||||||
|
networks:
|
||||||
|
- database
|
||||||
|
hostname: mysql
|
||||||
|
environment:
|
||||||
|
MYSQL_ROOT_PASSWORD: "${DB_ROOT_PASSWORD}"
|
||||||
|
MYSQL_DATABASE: "${DB_NAME}"
|
||||||
|
MYSQL_USER: "${DB_USERNAME}"
|
||||||
|
MYSQL_PASSWORD: "${DB_PASSWORD}"
|
||||||
|
|
||||||
|
mysql-legacy:
|
||||||
|
image: mariadb:latest
|
||||||
|
volumes:
|
||||||
|
- db-data-legacy:/var/lib/mysql
|
||||||
|
- ./Docker/mysql/mysql.cnf:/etc/mysql/conf.d/custom.cnf:ro
|
||||||
|
- "${DB_IMPORTE_FILE_D7}:/docker-entrypoint-initdb.d/materio_d7.sql"
|
||||||
|
networks:
|
||||||
|
- database
|
||||||
|
hostname: mysql-legacy
|
||||||
|
environment:
|
||||||
|
MYSQL_ROOT_PASSWORD: "${DB_ROOT_PASSWORD}"
|
||||||
|
MYSQL_DATABASE: "${DB_LEGACY_NAME}"
|
||||||
|
MYSQL_USER: "${DB_USERNAME}"
|
||||||
|
MYSQL_PASSWORD: "${DB_PASSWORD}"
|
||||||
|
|
||||||
|
redis:
|
||||||
|
image: redis:4
|
||||||
|
volumes:
|
||||||
|
- redis-data:/data
|
||||||
|
networks:
|
||||||
|
- redis
|
||||||
|
ports:
|
||||||
|
- "6389"
|
||||||
|
|
||||||
|
php:
|
||||||
|
build: ./Docker/php/
|
||||||
|
expose:
|
||||||
|
- 9000
|
||||||
|
volumes:
|
||||||
|
- php-root-data:/root
|
||||||
|
- "${PROJECT_ROOT}:/var/www/html"
|
||||||
|
- "${LEGACY_ROOT}:/var/www/drupal6"
|
||||||
|
networks:
|
||||||
|
- database
|
||||||
|
- redis
|
||||||
|
- server
|
||||||
|
depends_on:
|
||||||
|
- mysql
|
||||||
|
- mysql-legacy
|
||||||
|
- redis
|
||||||
|
|
||||||
|
phpmyadmin:
|
||||||
|
image: phpmyadmin/phpmyadmin
|
||||||
|
ports:
|
||||||
|
- 8891:80
|
||||||
|
networks:
|
||||||
|
- database
|
||||||
|
depends_on:
|
||||||
|
- mysql
|
||||||
|
- mysql-legacy
|
||||||
|
environment:
|
||||||
|
PMA_HOSTS: mysql,mysql-legacy
|
||||||
|
|
||||||
|
nginx:
|
||||||
|
build: ./Docker/nginx/
|
||||||
|
ports:
|
||||||
|
- 8890:80
|
||||||
|
volumes:
|
||||||
|
- "${PROJECT_ROOT}:/var/www/html"
|
||||||
|
- "${LOG_ROOT}:/var/log:rw"
|
||||||
|
networks:
|
||||||
|
- server
|
||||||
|
depends_on:
|
||||||
|
- php
|
||||||
|
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
php-root-data:
|
||||||
|
db-data:
|
||||||
|
db-data-legacy:
|
||||||
|
redis-data:
|
||||||
|
|
||||||
|
networks:
|
||||||
|
database:
|
||||||
|
redis:
|
||||||
|
server:
|
1
public_html
Submodule
1
public_html
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit e46a846e3923f055faf24ffd60f41022cfac3529
|
155
ressources/default/services.yml
Normal file
155
ressources/default/services.yml
Normal file
@ -0,0 +1,155 @@
|
|||||||
|
parameters:
|
||||||
|
session.storage.options:
|
||||||
|
# Default ini options for sessions.
|
||||||
|
#
|
||||||
|
# Some distributions of Linux (most notably Debian) ship their PHP
|
||||||
|
# installations with garbage collection (gc) disabled. Since Drupal depends
|
||||||
|
# on PHP's garbage collection for clearing sessions, ensure that garbage
|
||||||
|
# collection occurs by using the most common settings.
|
||||||
|
# @default 1
|
||||||
|
gc_probability: 1
|
||||||
|
# @default 100
|
||||||
|
gc_divisor: 100
|
||||||
|
#
|
||||||
|
# Set session lifetime (in seconds), i.e. the time from the user's last
|
||||||
|
# visit to the active session may be deleted by the session garbage
|
||||||
|
# collector. When a session is deleted, authenticated users are logged out,
|
||||||
|
# and the contents of the user's $_SESSION variable is discarded.
|
||||||
|
# @default 200000
|
||||||
|
gc_maxlifetime: 200000
|
||||||
|
#
|
||||||
|
# Set session cookie lifetime (in seconds), i.e. the time from the session
|
||||||
|
# is created to the cookie expires, i.e. when the browser is expected to
|
||||||
|
# discard the cookie. The value 0 means "until the browser is closed".
|
||||||
|
# @default 2000000
|
||||||
|
cookie_lifetime: 2000000
|
||||||
|
#
|
||||||
|
# Drupal automatically generates a unique session cookie name based on the
|
||||||
|
# full domain name used to access the site. This mechanism is sufficient
|
||||||
|
# for most use-cases, including multi-site deployments. However, if it is
|
||||||
|
# desired that a session can be reused across different subdomains, the
|
||||||
|
# cookie domain needs to be set to the shared base domain. Doing so assures
|
||||||
|
# that users remain logged in as they cross between various subdomains.
|
||||||
|
# To maximize compatibility and normalize the behavior across user agents,
|
||||||
|
# the cookie domain should start with a dot.
|
||||||
|
#
|
||||||
|
# @default none
|
||||||
|
# cookie_domain: '.example.com'
|
||||||
|
#
|
||||||
|
twig.config:
|
||||||
|
# Twig debugging:
|
||||||
|
#
|
||||||
|
# When debugging is enabled:
|
||||||
|
# - The markup of each Twig template is surrounded by HTML comments that
|
||||||
|
# contain theming information, such as template file name suggestions.
|
||||||
|
# - Note that this debugging markup will cause automated tests that directly
|
||||||
|
# check rendered HTML to fail. When running automated tests, 'debug'
|
||||||
|
# should be set to FALSE.
|
||||||
|
# - The dump() function can be used in Twig templates to output information
|
||||||
|
# about template variables.
|
||||||
|
# - Twig templates are automatically recompiled whenever the source code
|
||||||
|
# changes (see auto_reload below).
|
||||||
|
#
|
||||||
|
# For more information about debugging Twig templates, see
|
||||||
|
# https://www.drupal.org/node/1906392.
|
||||||
|
#
|
||||||
|
# Not recommended in production environments
|
||||||
|
# @default false
|
||||||
|
debug: false
|
||||||
|
# Twig auto-reload:
|
||||||
|
#
|
||||||
|
# Automatically recompile Twig templates whenever the source code changes.
|
||||||
|
# If you don't provide a value for auto_reload, it will be determined
|
||||||
|
# based on the value of debug.
|
||||||
|
#
|
||||||
|
# Not recommended in production environments
|
||||||
|
# @default null
|
||||||
|
auto_reload: null
|
||||||
|
# Twig cache:
|
||||||
|
#
|
||||||
|
# By default, Twig templates will be compiled and stored in the filesystem
|
||||||
|
# to increase performance. Disabling the Twig cache will recompile the
|
||||||
|
# templates from source each time they are used. In most cases the
|
||||||
|
# auto_reload setting above should be enabled rather than disabling the
|
||||||
|
# Twig cache.
|
||||||
|
#
|
||||||
|
# Not recommended in production environments
|
||||||
|
# @default true
|
||||||
|
cache: true
|
||||||
|
renderer.config:
|
||||||
|
# Renderer required cache contexts:
|
||||||
|
#
|
||||||
|
# The Renderer will automatically associate these cache contexts with every
|
||||||
|
# render array, hence varying every render array by these cache contexts.
|
||||||
|
#
|
||||||
|
# @default ['languages:language_interface', 'theme', 'user.permissions']
|
||||||
|
required_cache_contexts: ['languages:language_interface', 'theme', 'user.permissions']
|
||||||
|
# Renderer automatic placeholdering conditions:
|
||||||
|
#
|
||||||
|
# Drupal allows portions of the page to be automatically deferred when
|
||||||
|
# rendering to improve cache performance. That is especially helpful for
|
||||||
|
# cache contexts that vary widely, such as the active user. On some sites
|
||||||
|
# those may be different, however, such as sites with only a handful of
|
||||||
|
# users. If you know what the high-cardinality cache contexts are for your
|
||||||
|
# site, specify those here. If you're not sure, the defaults are fairly safe
|
||||||
|
# in general.
|
||||||
|
#
|
||||||
|
# For more information about rendering optimizations see
|
||||||
|
# https://www.drupal.org/developing/api/8/render/arrays/cacheability#optimizing
|
||||||
|
auto_placeholder_conditions:
|
||||||
|
# Max-age at or below which caching is not considered worthwhile.
|
||||||
|
#
|
||||||
|
# Disable by setting to -1.
|
||||||
|
#
|
||||||
|
# @default 0
|
||||||
|
max-age: 0
|
||||||
|
# Cache contexts with a high cardinality.
|
||||||
|
#
|
||||||
|
# Disable by setting to [].
|
||||||
|
#
|
||||||
|
# @default ['session', 'user']
|
||||||
|
contexts: ['session', 'user']
|
||||||
|
# Tags with a high invalidation frequency.
|
||||||
|
#
|
||||||
|
# Disable by setting to [].
|
||||||
|
#
|
||||||
|
# @default []
|
||||||
|
tags: []
|
||||||
|
# Cacheability debugging:
|
||||||
|
#
|
||||||
|
# Responses with cacheability metadata (CacheableResponseInterface instances)
|
||||||
|
# get X-Drupal-Cache-Tags and X-Drupal-Cache-Contexts headers.
|
||||||
|
#
|
||||||
|
# For more information about debugging cacheable responses, see
|
||||||
|
# https://www.drupal.org/developing/api/8/response/cacheable-response-interface
|
||||||
|
#
|
||||||
|
# Not recommended in production environments
|
||||||
|
# @default false
|
||||||
|
http.response.debug_cacheability_headers: false
|
||||||
|
factory.keyvalue:
|
||||||
|
{}
|
||||||
|
# Default key/value storage service to use.
|
||||||
|
# @default keyvalue.database
|
||||||
|
# default: keyvalue.database
|
||||||
|
# Collection-specific overrides.
|
||||||
|
# state: keyvalue.database
|
||||||
|
factory.keyvalue.expirable:
|
||||||
|
{}
|
||||||
|
# Default key/value expirable storage service to use.
|
||||||
|
# @default keyvalue.database.expirable
|
||||||
|
# default: keyvalue.database.expirable
|
||||||
|
# Allowed protocols for URL generation.
|
||||||
|
filter_protocols:
|
||||||
|
- http
|
||||||
|
- https
|
||||||
|
- ftp
|
||||||
|
- news
|
||||||
|
- nntp
|
||||||
|
- tel
|
||||||
|
- telnet
|
||||||
|
- mailto
|
||||||
|
- irc
|
||||||
|
- ssh
|
||||||
|
- sftp
|
||||||
|
- webcal
|
||||||
|
- rtsp
|
110
ressources/default/settings.local.php
Normal file
110
ressources/default/settings.local.php
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @file
|
||||||
|
* Local development override configuration feature.
|
||||||
|
*
|
||||||
|
* To activate this feature, copy and rename it such that its path plus
|
||||||
|
* filename is 'sites/default/settings.local.php'. Then, go to the bottom of
|
||||||
|
* 'sites/default/settings.php' and uncomment the commented lines that mention
|
||||||
|
* 'settings.local.php'.
|
||||||
|
*
|
||||||
|
* If you are using a site name in the path, such as 'sites/example.com', copy
|
||||||
|
* this file to 'sites/example.com/settings.local.php', and uncomment the lines
|
||||||
|
* at the bottom of 'sites/example.com/settings.php'.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Assertions.
|
||||||
|
*
|
||||||
|
* The Drupal project primarily uses runtime assertions to enforce the
|
||||||
|
* expectations of the API by failing when incorrect calls are made by code
|
||||||
|
* under development.
|
||||||
|
*
|
||||||
|
* @see http://php.net/assert
|
||||||
|
* @see https://www.drupal.org/node/2492225
|
||||||
|
*
|
||||||
|
* If you are using PHP 7.0 it is strongly recommended that you set
|
||||||
|
* zend.assertions=1 in the PHP.ini file (It cannot be changed from .htaccess
|
||||||
|
* or runtime) on development machines and to 0 in production.
|
||||||
|
*
|
||||||
|
* @see https://wiki.php.net/rfc/expectations
|
||||||
|
*/
|
||||||
|
assert_options(ASSERT_ACTIVE, TRUE);
|
||||||
|
\Drupal\Component\Assertion\Handle::register();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enable local development services.
|
||||||
|
*/
|
||||||
|
$settings['container_yamls'][] = DRUPAL_ROOT . '/sites/development.services.yml';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Show all error messages, with backtrace information.
|
||||||
|
*
|
||||||
|
* In case the error level could not be fetched from the database, as for
|
||||||
|
* example the database connection failed, we rely only on this value.
|
||||||
|
*/
|
||||||
|
$config['system.logging']['error_level'] = 'verbose';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Disable CSS and JS aggregation.
|
||||||
|
*/
|
||||||
|
$config['system.performance']['css']['preprocess'] = FALSE;
|
||||||
|
$config['system.performance']['js']['preprocess'] = FALSE;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Disable the render cache (this includes the page cache).
|
||||||
|
*
|
||||||
|
* Note: you should test with the render cache enabled, to ensure the correct
|
||||||
|
* cacheability metadata is present. However, in the early stages of
|
||||||
|
* development, you may want to disable it.
|
||||||
|
*
|
||||||
|
* This setting disables the render cache by using the Null cache back-end
|
||||||
|
* defined by the development.services.yml file above.
|
||||||
|
*
|
||||||
|
* Do not use this setting until after the site is installed.
|
||||||
|
*/
|
||||||
|
$settings['cache']['bins']['render'] = 'cache.backend.null';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Disable Dynamic Page Cache.
|
||||||
|
*
|
||||||
|
* Note: you should test with Dynamic Page Cache enabled, to ensure the correct
|
||||||
|
* cacheability metadata is present (and hence the expected behavior). However,
|
||||||
|
* in the early stages of development, you may want to disable it.
|
||||||
|
*/
|
||||||
|
$settings['cache']['bins']['dynamic_page_cache'] = 'cache.backend.null';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Allow test modules and themes to be installed.
|
||||||
|
*
|
||||||
|
* Drupal ignores test modules and themes by default for performance reasons.
|
||||||
|
* During development it can be useful to install test extensions for debugging
|
||||||
|
* purposes.
|
||||||
|
*/
|
||||||
|
$settings['extension_discovery_scan_tests'] = TRUE;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enable access to rebuild.php.
|
||||||
|
*
|
||||||
|
* This setting can be enabled to allow Drupal's php and database cached
|
||||||
|
* storage to be cleared via the rebuild.php page. Access to this page can also
|
||||||
|
* be gained by generating a query string from rebuild_token_calculator.sh and
|
||||||
|
* using these parameters in a request to rebuild.php.
|
||||||
|
*/
|
||||||
|
$settings['rebuild_access'] = TRUE;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Skip file system permissions hardening.
|
||||||
|
*
|
||||||
|
* The system module will periodically check the permissions of your site's
|
||||||
|
* site directory to ensure that it is not writable by the website user. For
|
||||||
|
* sites that are managed with a version control system, this can cause problems
|
||||||
|
* when files in that directory such as settings.php are updated, because the
|
||||||
|
* user pulling in the changes won't have permissions to modify files in the
|
||||||
|
* directory.
|
||||||
|
*/
|
||||||
|
$settings['skip_permissions_hardening'] = TRUE;
|
||||||
|
|
||||||
|
|
||||||
|
// $config['system.theme']['default'] = 'basic';
|
749
ressources/default/settings.php
Normal file
749
ressources/default/settings.php
Normal file
@ -0,0 +1,749 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @file
|
||||||
|
* Drupal site-specific configuration file.
|
||||||
|
*
|
||||||
|
* IMPORTANT NOTE:
|
||||||
|
* This file may have been set to read-only by the Drupal installation program.
|
||||||
|
* If you make changes to this file, be sure to protect it again after making
|
||||||
|
* your modifications. Failure to remove write permissions to this file is a
|
||||||
|
* security risk.
|
||||||
|
*
|
||||||
|
* In order to use the selection rules below the multisite aliasing file named
|
||||||
|
* sites/sites.php must be present. Its optional settings will be loaded, and
|
||||||
|
* the aliases in the array $sites will override the default directory rules
|
||||||
|
* below. See sites/example.sites.php for more information about aliases.
|
||||||
|
*
|
||||||
|
* The configuration directory will be discovered by stripping the website's
|
||||||
|
* hostname from left to right and pathname from right to left. The first
|
||||||
|
* configuration file found will be used and any others will be ignored. If no
|
||||||
|
* other configuration file is found then the default configuration file at
|
||||||
|
* 'sites/default' will be used.
|
||||||
|
*
|
||||||
|
* For example, for a fictitious site installed at
|
||||||
|
* https://www.drupal.org:8080/mysite/test/, the 'settings.php' file is searched
|
||||||
|
* for in the following directories:
|
||||||
|
*
|
||||||
|
* - sites/8080.www.drupal.org.mysite.test
|
||||||
|
* - sites/www.drupal.org.mysite.test
|
||||||
|
* - sites/drupal.org.mysite.test
|
||||||
|
* - sites/org.mysite.test
|
||||||
|
*
|
||||||
|
* - sites/8080.www.drupal.org.mysite
|
||||||
|
* - sites/www.drupal.org.mysite
|
||||||
|
* - sites/drupal.org.mysite
|
||||||
|
* - sites/org.mysite
|
||||||
|
*
|
||||||
|
* - sites/8080.www.drupal.org
|
||||||
|
* - sites/www.drupal.org
|
||||||
|
* - sites/drupal.org
|
||||||
|
* - sites/org
|
||||||
|
*
|
||||||
|
* - sites/default
|
||||||
|
*
|
||||||
|
* Note that if you are installing on a non-standard port number, prefix the
|
||||||
|
* hostname with that number. For example,
|
||||||
|
* https://www.drupal.org:8080/mysite/test/ could be loaded from
|
||||||
|
* sites/8080.www.drupal.org.mysite.test/.
|
||||||
|
*
|
||||||
|
* @see example.sites.php
|
||||||
|
* @see \Drupal\Core\DrupalKernel::getSitePath()
|
||||||
|
*
|
||||||
|
* In addition to customizing application settings through variables in
|
||||||
|
* settings.php, you can create a services.yml file in the same directory to
|
||||||
|
* register custom, site-specific service definitions and/or swap out default
|
||||||
|
* implementations with custom ones.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Database settings:
|
||||||
|
*
|
||||||
|
* The $databases array specifies the database connection or
|
||||||
|
* connections that Drupal may use. Drupal is able to connect
|
||||||
|
* to multiple databases, including multiple types of databases,
|
||||||
|
* during the same request.
|
||||||
|
*
|
||||||
|
* One example of the simplest connection array is shown below. To use the
|
||||||
|
* sample settings, copy and uncomment the code below between the @code and
|
||||||
|
* @endcode lines and paste it after the $databases declaration. You will need
|
||||||
|
* to replace the database username and password and possibly the host and port
|
||||||
|
* with the appropriate credentials for your database system.
|
||||||
|
*
|
||||||
|
* The next section describes how to customize the $databases array for more
|
||||||
|
* specific needs.
|
||||||
|
*
|
||||||
|
* @code
|
||||||
|
* $databases['default']['default'] = array (
|
||||||
|
* 'database' => 'databasename',
|
||||||
|
* 'username' => 'sqlusername',
|
||||||
|
* 'password' => 'sqlpassword',
|
||||||
|
* 'host' => 'localhost',
|
||||||
|
* 'port' => '3306',
|
||||||
|
* 'driver' => 'mysql',
|
||||||
|
* 'prefix' => '',
|
||||||
|
* 'collation' => 'utf8mb4_general_ci',
|
||||||
|
* );
|
||||||
|
* @endcode
|
||||||
|
*/
|
||||||
|
$databases['default']['default'] = array (
|
||||||
|
'database' => 'materio_d8',
|
||||||
|
'username' => 'materio',
|
||||||
|
'password' => 'materio',
|
||||||
|
'prefix' => '',
|
||||||
|
'host' => 'mysql',
|
||||||
|
'port' => '3306',
|
||||||
|
'namespace' => 'Drupal\\Core\\Database\\Driver\\mysql',
|
||||||
|
'driver' => 'mysql',
|
||||||
|
);
|
||||||
|
|
||||||
|
$databases['legacy']['default'] = array (
|
||||||
|
'database' => 'materio_d7',
|
||||||
|
'username' => 'materio',
|
||||||
|
'password' => 'materio',
|
||||||
|
'prefix' => '',
|
||||||
|
'host' => 'mysql',
|
||||||
|
'port' => '3306',
|
||||||
|
'namespace' => 'Drupal\\Core\\Database\\Driver\\mysql',
|
||||||
|
'driver' => 'mysql',
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Customizing database settings.
|
||||||
|
*
|
||||||
|
* Many of the values of the $databases array can be customized for your
|
||||||
|
* particular database system. Refer to the sample in the section above as a
|
||||||
|
* starting point.
|
||||||
|
*
|
||||||
|
* The "driver" property indicates what Drupal database driver the
|
||||||
|
* connection should use. This is usually the same as the name of the
|
||||||
|
* database type, such as mysql or sqlite, but not always. The other
|
||||||
|
* properties will vary depending on the driver. For SQLite, you must
|
||||||
|
* specify a database file name in a directory that is writable by the
|
||||||
|
* webserver. For most other drivers, you must specify a
|
||||||
|
* username, password, host, and database name.
|
||||||
|
*
|
||||||
|
* Transaction support is enabled by default for all drivers that support it,
|
||||||
|
* including MySQL. To explicitly disable it, set the 'transactions' key to
|
||||||
|
* FALSE.
|
||||||
|
* Note that some configurations of MySQL, such as the MyISAM engine, don't
|
||||||
|
* support it and will proceed silently even if enabled. If you experience
|
||||||
|
* transaction related crashes with such configuration, set the 'transactions'
|
||||||
|
* key to FALSE.
|
||||||
|
*
|
||||||
|
* For each database, you may optionally specify multiple "target" databases.
|
||||||
|
* A target database allows Drupal to try to send certain queries to a
|
||||||
|
* different database if it can but fall back to the default connection if not.
|
||||||
|
* That is useful for primary/replica replication, as Drupal may try to connect
|
||||||
|
* to a replica server when appropriate and if one is not available will simply
|
||||||
|
* fall back to the single primary server (The terms primary/replica are
|
||||||
|
* traditionally referred to as master/slave in database server documentation).
|
||||||
|
*
|
||||||
|
* The general format for the $databases array is as follows:
|
||||||
|
* @code
|
||||||
|
* $databases['default']['default'] = $info_array;
|
||||||
|
* $databases['default']['replica'][] = $info_array;
|
||||||
|
* $databases['default']['replica'][] = $info_array;
|
||||||
|
* $databases['extra']['default'] = $info_array;
|
||||||
|
* @endcode
|
||||||
|
*
|
||||||
|
* In the above example, $info_array is an array of settings described above.
|
||||||
|
* The first line sets a "default" database that has one primary database
|
||||||
|
* (the second level default). The second and third lines create an array
|
||||||
|
* of potential replica databases. Drupal will select one at random for a given
|
||||||
|
* request as needed. The fourth line creates a new database with a name of
|
||||||
|
* "extra".
|
||||||
|
*
|
||||||
|
* You can optionally set prefixes for some or all database table names
|
||||||
|
* by using the 'prefix' setting. If a prefix is specified, the table
|
||||||
|
* name will be prepended with its value. Be sure to use valid database
|
||||||
|
* characters only, usually alphanumeric and underscore. If no prefixes
|
||||||
|
* are desired, leave it as an empty string ''.
|
||||||
|
*
|
||||||
|
* To have all database names prefixed, set 'prefix' as a string:
|
||||||
|
* @code
|
||||||
|
* 'prefix' => 'main_',
|
||||||
|
* @endcode
|
||||||
|
* To provide prefixes for specific tables, set 'prefix' as an array.
|
||||||
|
* The array's keys are the table names and the values are the prefixes.
|
||||||
|
* The 'default' element is mandatory and holds the prefix for any tables
|
||||||
|
* not specified elsewhere in the array. Example:
|
||||||
|
* @code
|
||||||
|
* 'prefix' => array(
|
||||||
|
* 'default' => 'main_',
|
||||||
|
* 'users' => 'shared_',
|
||||||
|
* 'sessions' => 'shared_',
|
||||||
|
* 'role' => 'shared_',
|
||||||
|
* 'authmap' => 'shared_',
|
||||||
|
* ),
|
||||||
|
* @endcode
|
||||||
|
* You can also use a reference to a schema/database as a prefix. This may be
|
||||||
|
* useful if your Drupal installation exists in a schema that is not the default
|
||||||
|
* or you want to access several databases from the same code base at the same
|
||||||
|
* time.
|
||||||
|
* Example:
|
||||||
|
* @code
|
||||||
|
* 'prefix' => array(
|
||||||
|
* 'default' => 'main.',
|
||||||
|
* 'users' => 'shared.',
|
||||||
|
* 'sessions' => 'shared.',
|
||||||
|
* 'role' => 'shared.',
|
||||||
|
* 'authmap' => 'shared.',
|
||||||
|
* );
|
||||||
|
* @endcode
|
||||||
|
* NOTE: MySQL and SQLite's definition of a schema is a database.
|
||||||
|
*
|
||||||
|
* Advanced users can add or override initial commands to execute when
|
||||||
|
* connecting to the database server, as well as PDO connection settings. For
|
||||||
|
* example, to enable MySQL SELECT queries to exceed the max_join_size system
|
||||||
|
* variable, and to reduce the database connection timeout to 5 seconds:
|
||||||
|
* @code
|
||||||
|
* $databases['default']['default'] = array(
|
||||||
|
* 'init_commands' => array(
|
||||||
|
* 'big_selects' => 'SET SQL_BIG_SELECTS=1',
|
||||||
|
* ),
|
||||||
|
* 'pdo' => array(
|
||||||
|
* PDO::ATTR_TIMEOUT => 5,
|
||||||
|
* ),
|
||||||
|
* );
|
||||||
|
* @endcode
|
||||||
|
*
|
||||||
|
* WARNING: The above defaults are designed for database portability. Changing
|
||||||
|
* them may cause unexpected behavior, including potential data loss. See
|
||||||
|
* https://www.drupal.org/developing/api/database/configuration for more
|
||||||
|
* information on these defaults and the potential issues.
|
||||||
|
*
|
||||||
|
* More details can be found in the constructor methods for each driver:
|
||||||
|
* - \Drupal\Core\Database\Driver\mysql\Connection::__construct()
|
||||||
|
* - \Drupal\Core\Database\Driver\pgsql\Connection::__construct()
|
||||||
|
* - \Drupal\Core\Database\Driver\sqlite\Connection::__construct()
|
||||||
|
*
|
||||||
|
* Sample Database configuration format for PostgreSQL (pgsql):
|
||||||
|
* @code
|
||||||
|
* $databases['default']['default'] = array(
|
||||||
|
* 'driver' => 'pgsql',
|
||||||
|
* 'database' => 'databasename',
|
||||||
|
* 'username' => 'sqlusername',
|
||||||
|
* 'password' => 'sqlpassword',
|
||||||
|
* 'host' => 'localhost',
|
||||||
|
* 'prefix' => '',
|
||||||
|
* );
|
||||||
|
* @endcode
|
||||||
|
*
|
||||||
|
* Sample Database configuration format for SQLite (sqlite):
|
||||||
|
* @code
|
||||||
|
* $databases['default']['default'] = array(
|
||||||
|
* 'driver' => 'sqlite',
|
||||||
|
* 'database' => '/path/to/databasefilename',
|
||||||
|
* );
|
||||||
|
* @endcode
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Location of the site configuration files.
|
||||||
|
*
|
||||||
|
* The $config_directories array specifies the location of file system
|
||||||
|
* directories used for configuration data. On install, the "sync" directory is
|
||||||
|
* created. This is used for configuration imports. The "active" directory is
|
||||||
|
* not created by default since the default storage for active configuration is
|
||||||
|
* the database rather than the file system. (This can be changed. See "Active
|
||||||
|
* configuration settings" below).
|
||||||
|
*
|
||||||
|
* The default location for the "sync" directory is inside a randomly-named
|
||||||
|
* directory in the public files path. The setting below allows you to override
|
||||||
|
* the "sync" location.
|
||||||
|
*
|
||||||
|
* If you use files for the "active" configuration, you can tell the
|
||||||
|
* Configuration system where this directory is located by adding an entry with
|
||||||
|
* array key CONFIG_ACTIVE_DIRECTORY.
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
* @code
|
||||||
|
* $config_directories = array(
|
||||||
|
* CONFIG_SYNC_DIRECTORY => '/directory/outside/webroot',
|
||||||
|
* );
|
||||||
|
* @endcode
|
||||||
|
*/
|
||||||
|
// $config_directories['sync'] = 'sites/default/files/config_m8lcsLzRkNV5tQJZajFP31fLIFh_rjYnYGBqBKHl1jj1mfCSgbueA4zfQCm6AxRfUUrUtr-gjw/sync';
|
||||||
|
|
||||||
|
$config_directories['sync'] = 'sites/default/config/sync';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Settings:
|
||||||
|
*
|
||||||
|
* $settings contains environment-specific configuration, such as the files
|
||||||
|
* directory and reverse proxy address, and temporary configuration, such as
|
||||||
|
* security overrides.
|
||||||
|
*
|
||||||
|
* @see \Drupal\Core\Site\Settings::get()
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The active installation profile.
|
||||||
|
*
|
||||||
|
* Changing this after installation is not recommended as it changes which
|
||||||
|
* directories are scanned during extension discovery. If this is set prior to
|
||||||
|
* installation this value will be rewritten according to the profile selected
|
||||||
|
* by the user.
|
||||||
|
*
|
||||||
|
* @see install_select_profile()
|
||||||
|
*/
|
||||||
|
# $settings['install_profile'] = '';
|
||||||
|
$settings['install_profile'] = 'filgi_starter_kit';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Salt for one-time login links, cancel links, form tokens, etc.
|
||||||
|
*
|
||||||
|
* This variable will be set to a random value by the installer. All one-time
|
||||||
|
* login links will be invalidated if the value is changed. Note that if your
|
||||||
|
* site is deployed on a cluster of web servers, you must ensure that this
|
||||||
|
* variable has the same value on each server.
|
||||||
|
*
|
||||||
|
* For enhanced security, you may set this variable to the contents of a file
|
||||||
|
* outside your document root; you should also ensure that this file is not
|
||||||
|
* stored with backups of your database.
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
* @code
|
||||||
|
* $settings['hash_salt'] = file_get_contents('/home/example/salt.txt');
|
||||||
|
* @endcode
|
||||||
|
*/
|
||||||
|
// $settings['hash_salt'] = 'Axm7rnWlsvs2TypbEv9DVNWlOBZpfezrQycwaZGzZwu9XLdUSXtulHOooBN3GaJLTy14IwOkAg';
|
||||||
|
|
||||||
|
$settings['hash_salt'] = 'b5ca44da2f343a335a5018fecf2a9a5a12d113450818780648d2f9499e2815f34269f3c83518114c5a9834c359242caa42a2ab295552fc819d9c31217ea88841';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deployment identifier.
|
||||||
|
*
|
||||||
|
* Drupal's dependency injection container will be automatically invalidated and
|
||||||
|
* rebuilt when the Drupal core version changes. When updating contributed or
|
||||||
|
* custom code that changes the container, changing this identifier will also
|
||||||
|
* allow the container to be invalidated as soon as code is deployed.
|
||||||
|
*/
|
||||||
|
# $settings['deployment_identifier'] = \Drupal::VERSION;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Access control for update.php script.
|
||||||
|
*
|
||||||
|
* If you are updating your Drupal installation using the update.php script but
|
||||||
|
* are not logged in using either an account with the "Administer software
|
||||||
|
* updates" permission or the site maintenance account (the account that was
|
||||||
|
* created during installation), you will need to modify the access check
|
||||||
|
* statement below. Change the FALSE to a TRUE to disable the access check.
|
||||||
|
* After finishing the upgrade, be sure to open this file again and change the
|
||||||
|
* TRUE back to a FALSE!
|
||||||
|
*/
|
||||||
|
$settings['update_free_access'] = FALSE;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* External access proxy settings:
|
||||||
|
*
|
||||||
|
* If your site must access the Internet via a web proxy then you can enter the
|
||||||
|
* proxy settings here. Set the full URL of the proxy, including the port, in
|
||||||
|
* variables:
|
||||||
|
* - $settings['http_client_config']['proxy']['http']: The proxy URL for HTTP
|
||||||
|
* requests.
|
||||||
|
* - $settings['http_client_config']['proxy']['https']: The proxy URL for HTTPS
|
||||||
|
* requests.
|
||||||
|
* You can pass in the user name and password for basic authentication in the
|
||||||
|
* URLs in these settings.
|
||||||
|
*
|
||||||
|
* You can also define an array of host names that can be accessed directly,
|
||||||
|
* bypassing the proxy, in $settings['http_client_config']['proxy']['no'].
|
||||||
|
*/
|
||||||
|
# $settings['http_client_config']['proxy']['http'] = 'http://proxy_user:proxy_pass@example.com:8080';
|
||||||
|
# $settings['http_client_config']['proxy']['https'] = 'http://proxy_user:proxy_pass@example.com:8080';
|
||||||
|
# $settings['http_client_config']['proxy']['no'] = ['127.0.0.1', 'localhost'];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse Proxy Configuration:
|
||||||
|
*
|
||||||
|
* Reverse proxy servers are often used to enhance the performance
|
||||||
|
* of heavily visited sites and may also provide other site caching,
|
||||||
|
* security, or encryption benefits. In an environment where Drupal
|
||||||
|
* is behind a reverse proxy, the real IP address of the client should
|
||||||
|
* be determined such that the correct client IP address is available
|
||||||
|
* to Drupal's logging, statistics, and access management systems. In
|
||||||
|
* the most simple scenario, the proxy server will add an
|
||||||
|
* X-Forwarded-For header to the request that contains the client IP
|
||||||
|
* address. However, HTTP headers are vulnerable to spoofing, where a
|
||||||
|
* malicious client could bypass restrictions by setting the
|
||||||
|
* X-Forwarded-For header directly. Therefore, Drupal's proxy
|
||||||
|
* configuration requires the IP addresses of all remote proxies to be
|
||||||
|
* specified in $settings['reverse_proxy_addresses'] to work correctly.
|
||||||
|
*
|
||||||
|
* Enable this setting to get Drupal to determine the client IP from
|
||||||
|
* the X-Forwarded-For header (or $settings['reverse_proxy_header'] if set).
|
||||||
|
* If you are unsure about this setting, do not have a reverse proxy,
|
||||||
|
* or Drupal operates in a shared hosting environment, this setting
|
||||||
|
* should remain commented out.
|
||||||
|
*
|
||||||
|
* In order for this setting to be used you must specify every possible
|
||||||
|
* reverse proxy IP address in $settings['reverse_proxy_addresses'].
|
||||||
|
* If a complete list of reverse proxies is not available in your
|
||||||
|
* environment (for example, if you use a CDN) you may set the
|
||||||
|
* $_SERVER['REMOTE_ADDR'] variable directly in settings.php.
|
||||||
|
* Be aware, however, that it is likely that this would allow IP
|
||||||
|
* address spoofing unless more advanced precautions are taken.
|
||||||
|
*/
|
||||||
|
# $settings['reverse_proxy'] = TRUE;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Specify every reverse proxy IP address in your environment.
|
||||||
|
* This setting is required if $settings['reverse_proxy'] is TRUE.
|
||||||
|
*/
|
||||||
|
# $settings['reverse_proxy_addresses'] = array('a.b.c.d', ...);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set this value if your proxy server sends the client IP in a header
|
||||||
|
* other than X-Forwarded-For.
|
||||||
|
*/
|
||||||
|
# $settings['reverse_proxy_header'] = 'X_CLUSTER_CLIENT_IP';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set this value if your proxy server sends the client protocol in a header
|
||||||
|
* other than X-Forwarded-Proto.
|
||||||
|
*/
|
||||||
|
# $settings['reverse_proxy_proto_header'] = 'X_FORWARDED_PROTO';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set this value if your proxy server sends the client protocol in a header
|
||||||
|
* other than X-Forwarded-Host.
|
||||||
|
*/
|
||||||
|
# $settings['reverse_proxy_host_header'] = 'X_FORWARDED_HOST';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set this value if your proxy server sends the client protocol in a header
|
||||||
|
* other than X-Forwarded-Port.
|
||||||
|
*/
|
||||||
|
# $settings['reverse_proxy_port_header'] = 'X_FORWARDED_PORT';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set this value if your proxy server sends the client protocol in a header
|
||||||
|
* other than Forwarded.
|
||||||
|
*/
|
||||||
|
# $settings['reverse_proxy_forwarded_header'] = 'FORWARDED';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Page caching:
|
||||||
|
*
|
||||||
|
* By default, Drupal sends a "Vary: Cookie" HTTP header for anonymous page
|
||||||
|
* views. This tells a HTTP proxy that it may return a page from its local
|
||||||
|
* cache without contacting the web server, if the user sends the same Cookie
|
||||||
|
* header as the user who originally requested the cached page. Without "Vary:
|
||||||
|
* Cookie", authenticated users would also be served the anonymous page from
|
||||||
|
* the cache. If the site has mostly anonymous users except a few known
|
||||||
|
* editors/administrators, the Vary header can be omitted. This allows for
|
||||||
|
* better caching in HTTP proxies (including reverse proxies), i.e. even if
|
||||||
|
* clients send different cookies, they still get content served from the cache.
|
||||||
|
* However, authenticated users should access the site directly (i.e. not use an
|
||||||
|
* HTTP proxy, and bypass the reverse proxy if one is used) in order to avoid
|
||||||
|
* getting cached pages from the proxy.
|
||||||
|
*/
|
||||||
|
# $settings['omit_vary_cookie'] = TRUE;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class Loader.
|
||||||
|
*
|
||||||
|
* If the APC extension is detected, the Symfony APC class loader is used for
|
||||||
|
* performance reasons. Detection can be prevented by setting
|
||||||
|
* class_loader_auto_detect to false, as in the example below.
|
||||||
|
*/
|
||||||
|
# $settings['class_loader_auto_detect'] = FALSE;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If the APC extension is not detected, either because APC is missing or
|
||||||
|
* because auto-detection has been disabled, auto-loading falls back to
|
||||||
|
* Composer's ClassLoader, which is good for development as it does not break
|
||||||
|
* when code is moved in the file system. You can also decorate the base class
|
||||||
|
* loader with another cached solution than the Symfony APC class loader, as
|
||||||
|
* all production sites should have a cached class loader of some sort enabled.
|
||||||
|
*
|
||||||
|
* To do so, you may decorate and replace the local $class_loader variable. For
|
||||||
|
* example, to use Symfony's APC class loader without automatic detection,
|
||||||
|
* uncomment the code below.
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
if ($settings['hash_salt']) {
|
||||||
|
$prefix = 'drupal.' . hash('sha256', 'drupal.' . $settings['hash_salt']);
|
||||||
|
$apc_loader = new \Symfony\Component\ClassLoader\ApcClassLoader($prefix, $class_loader);
|
||||||
|
unset($prefix);
|
||||||
|
$class_loader->unregister();
|
||||||
|
$apc_loader->register();
|
||||||
|
$class_loader = $apc_loader;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Authorized file system operations:
|
||||||
|
*
|
||||||
|
* The Update Manager module included with Drupal provides a mechanism for
|
||||||
|
* site administrators to securely install missing updates for the site
|
||||||
|
* directly through the web user interface. On securely-configured servers,
|
||||||
|
* the Update manager will require the administrator to provide SSH or FTP
|
||||||
|
* credentials before allowing the installation to proceed; this allows the
|
||||||
|
* site to update the new files as the user who owns all the Drupal files,
|
||||||
|
* instead of as the user the webserver is running as. On servers where the
|
||||||
|
* webserver user is itself the owner of the Drupal files, the administrator
|
||||||
|
* will not be prompted for SSH or FTP credentials (note that these server
|
||||||
|
* setups are common on shared hosting, but are inherently insecure).
|
||||||
|
*
|
||||||
|
* Some sites might wish to disable the above functionality, and only update
|
||||||
|
* the code directly via SSH or FTP themselves. This setting completely
|
||||||
|
* disables all functionality related to these authorized file operations.
|
||||||
|
*
|
||||||
|
* @see https://www.drupal.org/node/244924
|
||||||
|
*
|
||||||
|
* Remove the leading hash signs to disable.
|
||||||
|
*/
|
||||||
|
# $settings['allow_authorize_operations'] = FALSE;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Default mode for directories and files written by Drupal.
|
||||||
|
*
|
||||||
|
* Value should be in PHP Octal Notation, with leading zero.
|
||||||
|
*/
|
||||||
|
# $settings['file_chmod_directory'] = 0775;
|
||||||
|
# $settings['file_chmod_file'] = 0664;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Public file base URL:
|
||||||
|
*
|
||||||
|
* An alternative base URL to be used for serving public files. This must
|
||||||
|
* include any leading directory path.
|
||||||
|
*
|
||||||
|
* A different value from the domain used by Drupal to be used for accessing
|
||||||
|
* public files. This can be used for a simple CDN integration, or to improve
|
||||||
|
* security by serving user-uploaded files from a different domain or subdomain
|
||||||
|
* pointing to the same server. Do not include a trailing slash.
|
||||||
|
*/
|
||||||
|
# $settings['file_public_base_url'] = 'http://downloads.example.com/files';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Public file path:
|
||||||
|
*
|
||||||
|
* A local file system path where public files will be stored. This directory
|
||||||
|
* must exist and be writable by Drupal. This directory must be relative to
|
||||||
|
* the Drupal installation directory and be accessible over the web.
|
||||||
|
*/
|
||||||
|
# $settings['file_public_path'] = 'sites/default/files';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Private file path:
|
||||||
|
*
|
||||||
|
* A local file system path where private files will be stored. This directory
|
||||||
|
* must be absolute, outside of the Drupal installation directory and not
|
||||||
|
* accessible over the web.
|
||||||
|
*
|
||||||
|
* Note: Caches need to be cleared when this value is changed to make the
|
||||||
|
* private:// stream wrapper available to the system.
|
||||||
|
*
|
||||||
|
* See https://www.drupal.org/documentation/modules/file for more information
|
||||||
|
* about securing private files.
|
||||||
|
*/
|
||||||
|
# $settings['file_private_path'] = '';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Session write interval:
|
||||||
|
*
|
||||||
|
* Set the minimum interval between each session write to database.
|
||||||
|
* For performance reasons it defaults to 180.
|
||||||
|
*/
|
||||||
|
# $settings['session_write_interval'] = 180;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* String overrides:
|
||||||
|
*
|
||||||
|
* To override specific strings on your site with or without enabling the Locale
|
||||||
|
* module, add an entry to this list. This functionality allows you to change
|
||||||
|
* a small number of your site's default English language interface strings.
|
||||||
|
*
|
||||||
|
* Remove the leading hash signs to enable.
|
||||||
|
*
|
||||||
|
* The "en" part of the variable name, is dynamic and can be any langcode of
|
||||||
|
* any added language. (eg locale_custom_strings_de for german).
|
||||||
|
*/
|
||||||
|
# $settings['locale_custom_strings_en'][''] = array(
|
||||||
|
# 'forum' => 'Discussion board',
|
||||||
|
# '@count min' => '@count minutes',
|
||||||
|
# );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A custom theme for the offline page:
|
||||||
|
*
|
||||||
|
* This applies when the site is explicitly set to maintenance mode through the
|
||||||
|
* administration page or when the database is inactive due to an error.
|
||||||
|
* The template file should also be copied into the theme. It is located inside
|
||||||
|
* 'core/modules/system/templates/maintenance-page.html.twig'.
|
||||||
|
*
|
||||||
|
* Note: This setting does not apply to installation and update pages.
|
||||||
|
*/
|
||||||
|
# $settings['maintenance_theme'] = 'bartik';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* PHP settings:
|
||||||
|
*
|
||||||
|
* To see what PHP settings are possible, including whether they can be set at
|
||||||
|
* runtime (by using ini_set()), read the PHP documentation:
|
||||||
|
* http://php.net/manual/ini.list.php
|
||||||
|
* See \Drupal\Core\DrupalKernel::bootEnvironment() for required runtime
|
||||||
|
* settings and the .htaccess file for non-runtime settings.
|
||||||
|
* Settings defined there should not be duplicated here so as to avoid conflict
|
||||||
|
* issues.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If you encounter a situation where users post a large amount of text, and
|
||||||
|
* the result is stripped out upon viewing but can still be edited, Drupal's
|
||||||
|
* output filter may not have sufficient memory to process it. If you
|
||||||
|
* experience this issue, you may wish to uncomment the following two lines
|
||||||
|
* and increase the limits of these variables. For more information, see
|
||||||
|
* http://php.net/manual/pcre.configuration.php.
|
||||||
|
*/
|
||||||
|
# ini_set('pcre.backtrack_limit', 200000);
|
||||||
|
# ini_set('pcre.recursion_limit', 200000);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Active configuration settings.
|
||||||
|
*
|
||||||
|
* By default, the active configuration is stored in the database in the
|
||||||
|
* {config} table. To use a different storage mechanism for the active
|
||||||
|
* configuration, do the following prior to installing:
|
||||||
|
* - Create an "active" directory and declare its path in $config_directories
|
||||||
|
* as explained under the 'Location of the site configuration files' section
|
||||||
|
* above in this file. To enhance security, you can declare a path that is
|
||||||
|
* outside your document root.
|
||||||
|
* - Override the 'bootstrap_config_storage' setting here. It must be set to a
|
||||||
|
* callable that returns an object that implements
|
||||||
|
* \Drupal\Core\Config\StorageInterface.
|
||||||
|
* - Override the service definition 'config.storage.active'. Put this
|
||||||
|
* override in a services.yml file in the same directory as settings.php
|
||||||
|
* (definitions in this file will override service definition defaults).
|
||||||
|
*/
|
||||||
|
# $settings['bootstrap_config_storage'] = array('Drupal\Core\Config\BootstrapConfigStorageFactory', 'getFileStorage');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Configuration overrides.
|
||||||
|
*
|
||||||
|
* To globally override specific configuration values for this site,
|
||||||
|
* set them here. You usually don't need to use this feature. This is
|
||||||
|
* useful in a configuration file for a vhost or directory, rather than
|
||||||
|
* the default settings.php.
|
||||||
|
*
|
||||||
|
* Note that any values you provide in these variable overrides will not be
|
||||||
|
* viewable from the Drupal administration interface. The administration
|
||||||
|
* interface displays the values stored in configuration so that you can stage
|
||||||
|
* changes to other environments that don't have the overrides.
|
||||||
|
*
|
||||||
|
* There are particular configuration values that are risky to override. For
|
||||||
|
* example, overriding the list of installed modules in 'core.extension' is not
|
||||||
|
* supported as module install or uninstall has not occurred. Other examples
|
||||||
|
* include field storage configuration, because it has effects on database
|
||||||
|
* structure, and 'core.menu.static_menu_link_overrides' since this is cached in
|
||||||
|
* a way that is not config override aware. Also, note that changing
|
||||||
|
* configuration values in settings.php will not fire any of the configuration
|
||||||
|
* change events.
|
||||||
|
*/
|
||||||
|
# $config['system.site']['name'] = 'My Drupal site';
|
||||||
|
# $config['system.theme']['default'] = 'stark';
|
||||||
|
# $config['user.settings']['anonymous'] = 'Visitor';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fast 404 pages:
|
||||||
|
*
|
||||||
|
* Drupal can generate fully themed 404 pages. However, some of these responses
|
||||||
|
* are for images or other resource files that are not displayed to the user.
|
||||||
|
* This can waste bandwidth, and also generate server load.
|
||||||
|
*
|
||||||
|
* The options below return a simple, fast 404 page for URLs matching a
|
||||||
|
* specific pattern:
|
||||||
|
* - $config['system.performance']['fast_404']['exclude_paths']: A regular
|
||||||
|
* expression to match paths to exclude, such as images generated by image
|
||||||
|
* styles, or dynamically-resized images. The default pattern provided below
|
||||||
|
* also excludes the private file system. If you need to add more paths, you
|
||||||
|
* can add '|path' to the expression.
|
||||||
|
* - $config['system.performance']['fast_404']['paths']: A regular expression to
|
||||||
|
* match paths that should return a simple 404 page, rather than the fully
|
||||||
|
* themed 404 page. If you don't have any aliases ending in htm or html you
|
||||||
|
* can add '|s?html?' to the expression.
|
||||||
|
* - $config['system.performance']['fast_404']['html']: The html to return for
|
||||||
|
* simple 404 pages.
|
||||||
|
*
|
||||||
|
* Remove the leading hash signs if you would like to alter this functionality.
|
||||||
|
*/
|
||||||
|
# $config['system.performance']['fast_404']['exclude_paths'] = '/\/(?:styles)|(?:system\/files)\//';
|
||||||
|
# $config['system.performance']['fast_404']['paths'] = '/\.(?:txt|png|gif|jpe?g|css|js|ico|swf|flv|cgi|bat|pl|dll|exe|asp)$/i';
|
||||||
|
# $config['system.performance']['fast_404']['html'] = '<!DOCTYPE html><html><head><title>404 Not Found</title></head><body><h1>Not Found</h1><p>The requested URL "@path" was not found on this server.</p></body></html>';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Load services definition file.
|
||||||
|
*/
|
||||||
|
$settings['container_yamls'][] = __DIR__ . '/services.yml';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Override the default service container class.
|
||||||
|
*
|
||||||
|
* This is useful for example to trace the service container for performance
|
||||||
|
* tracking purposes, for testing a service container with an error condition or
|
||||||
|
* to test a service container that throws an exception.
|
||||||
|
*/
|
||||||
|
# $settings['container_base_class'] = '\Drupal\Core\DependencyInjection\Container';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Trusted host configuration.
|
||||||
|
*
|
||||||
|
* Drupal core can use the Symfony trusted host mechanism to prevent HTTP Host
|
||||||
|
* header spoofing.
|
||||||
|
*
|
||||||
|
* To enable the trusted host mechanism, you enable your allowable hosts
|
||||||
|
* in $settings['trusted_host_patterns']. This should be an array of regular
|
||||||
|
* expression patterns, without delimiters, representing the hosts you would
|
||||||
|
* like to allow.
|
||||||
|
*
|
||||||
|
* For example:
|
||||||
|
* @code
|
||||||
|
* $settings['trusted_host_patterns'] = array(
|
||||||
|
* '^www\.example\.com$',
|
||||||
|
* );
|
||||||
|
* @endcode
|
||||||
|
* will allow the site to only run from www.example.com.
|
||||||
|
*
|
||||||
|
* If you are running multisite, or if you are running your site from
|
||||||
|
* different domain names (eg, you don't redirect http://www.example.com to
|
||||||
|
* http://example.com), you should specify all of the host patterns that are
|
||||||
|
* allowed by your site.
|
||||||
|
*
|
||||||
|
* For example:
|
||||||
|
* @code
|
||||||
|
* $settings['trusted_host_patterns'] = array(
|
||||||
|
* '^example\.com$',
|
||||||
|
* '^.+\.example\.com$',
|
||||||
|
* '^example\.org$',
|
||||||
|
* '^.+\.example\.org$',
|
||||||
|
* );
|
||||||
|
* @endcode
|
||||||
|
* will allow the site to run off of all variants of example.com and
|
||||||
|
* example.org, with all subdomains included.
|
||||||
|
*/
|
||||||
|
$settings['trusted_host_patterns'] = array(
|
||||||
|
'materio.com',
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Load local development override configuration, if available.
|
||||||
|
*
|
||||||
|
* Use settings.local.php to override variables on secondary (staging,
|
||||||
|
* development, etc) installations of this site. Typically used to disable
|
||||||
|
* caching, JavaScript/CSS compression, re-routing of outgoing emails, and
|
||||||
|
* other things that should not happen on development and testing sites.
|
||||||
|
*
|
||||||
|
* Keep this code block at the end of this file to take full effect.
|
||||||
|
*/
|
||||||
|
if (file_exists(__DIR__ . '/settings.local.php')) {
|
||||||
|
include __DIR__ . '/settings.local.php';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
$settings['redis.connection']['interface'] = 'PhpRedis';
|
||||||
|
$settings['redis.connection']['host'] = 'redis';
|
||||||
|
$settings['cache']['default'] = 'cache.backend.redis';
|
Loading…
x
Reference in New Issue
Block a user