diff --git a/.gitignore b/.gitignore
index 638aba9..50aac20 100644
--- a/.gitignore
+++ b/.gitignore
@@ -4,5 +4,3 @@ vendor
composer.lock
*.phar
.build
-
-drupal-web
diff --git a/drupal-web/.dockerignore b/drupal-web/.dockerignore
new file mode 100644
index 0000000..1972606
--- /dev/null
+++ b/drupal-web/.dockerignore
@@ -0,0 +1,3 @@
+.git
+vendor
+web/sites/default/files
diff --git a/drupal-web/.env.example b/drupal-web/.env.example
new file mode 100644
index 0000000..6058123
--- /dev/null
+++ b/drupal-web/.env.example
@@ -0,0 +1,27 @@
+#
+# Copy and rename this file to .env at root of this project.
+#
+
+# A common use case is to supply database creds via the environment. Edit settings.php
+# like so:
+#
+# $databases['default']['default'] = [
+# 'database' => getenv('MYSQL_DATABASE'),
+# 'driver' => 'mysql',
+# 'host' => getenv('MYSQL_HOSTNAME'),
+# 'namespace' => 'Drupal\\Core\\Database\\Driver\\mysql',
+# 'password' => getenv('MYSQL_PASSWORD'),
+# 'port' => getenv('MYSQL_PORT'),
+# 'prefix' => '',
+# 'username' => getenv('MYSQL_USER'),
+# ];
+#
+# Uncomment and populate as needed.
+# MYSQL_DATABASE=
+# MYSQL_HOSTNAME=
+# MYSQL_PASSWORD=
+# MYSQL_PORT=
+# MYSQL_USER=
+
+# Another common use case is to set Drush's --uri via environment.
+# DRUSH_OPTIONS_URI=http://example.com
diff --git a/drupal-web/.gitignore b/drupal-web/.gitignore
new file mode 100644
index 0000000..201b012
--- /dev/null
+++ b/drupal-web/.gitignore
@@ -0,0 +1,28 @@
+# Ignore directories generated by Composer
+/drush/contrib/
+/vendor/
+/web/core/
+/web/modules/contrib/
+/web/themes/contrib/
+/web/profiles/contrib/
+/web/libraries/
+
+# Ingore files that are only for the current local environment
+web/sites/*/settings.local.php
+web/sites/*/services.local.yml
+
+# Ignore Drupal's file directory
+/web/sites/*/files/
+
+# Ignore SimpleTest multi-site environment.
+/web/sites/simpletest
+
+# Ignore files generated by PhpStorm
+/.idea/
+
+# Ignore .env files as they are personal
+/.env
+/.editorconfig
+/.gitattributes
+
+/tmp
\ No newline at end of file
diff --git a/drupal-web/.travis.yml b/drupal-web/.travis.yml
new file mode 100644
index 0000000..ac51e49
--- /dev/null
+++ b/drupal-web/.travis.yml
@@ -0,0 +1,40 @@
+language: php
+dist: trusty
+sudo: false
+
+php:
+ - 7.0
+ - 7.1
+ - 7.2
+ - 7.3
+
+env:
+ global:
+ - SIMPLETEST_DB=sqlite://tmp/site.sqlite
+ - SIMPLETEST_BASE_URL="http://127.0.0.1:8080"
+ matrix:
+ - RELEASE=stable COMPOSER_CHANNEL=stable
+ - RELEASE=dev COMPOSER_CHANNEL=stable
+ - RELEASE=stable COMPOSER_CHANNEL=snapshot
+
+before_install:
+ - echo 'sendmail_path = /bin/true' >> ~/.phpenv/versions/$(phpenv version-name)/etc/conf.d/travis.ini
+ - phpenv config-rm xdebug.ini
+ - composer --verbose self-update --$COMPOSER_CHANNEL
+ - composer --version
+
+install:
+ - composer --verbose validate
+ - composer --verbose install
+
+script:
+ - if [[ $RELEASE = dev ]]; then composer --verbose remove --no-update drupal/console; fi;
+ - if [[ $RELEASE = dev ]]; then composer --verbose require --no-update drupal/core:8.8.x-dev; composer --verbose require --no-update --dev drupal/core-dev:8.8.x-dev; fi;
+ - if [[ $RELEASE = dev ]]; then composer --verbose update; fi;
+ - ./vendor/bin/drush site-install --verbose --yes --db-url=sqlite://tmp/site.sqlite
+ - ./vendor/bin/drush runserver $SIMPLETEST_BASE_URL &
+ - until curl -s $SIMPLETEST_BASE_URL; do true; done > /dev/null
+ # Run a single unit test to verfiy the testing setup.
+ - ./vendor/bin/phpunit -c ./web/core ./web/core/modules/system/tests/src/Unit/SystemRequirementsTest.php
+ - ./vendor/bin/drush
+ - if [[ $RELEASE = stable ]]; then ./vendor/bin/drupal; fi;
diff --git a/drupal-web/LICENSE b/drupal-web/LICENSE
new file mode 100644
index 0000000..23cb790
--- /dev/null
+++ b/drupal-web/LICENSE
@@ -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.
+
+ {description}
+ Copyright (C) {year} {fullname}
+
+ 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.
diff --git a/drupal-web/README.md b/drupal-web/README.md
new file mode 100644
index 0000000..83f99b3
--- /dev/null
+++ b/drupal-web/README.md
@@ -0,0 +1,174 @@
+# ALGM Drutiny Drupal website example
+
+* To run drupal instance:
+ * Docker running
+ * `pygmy up`
+ * `docker-compose up -d`
+ * `docker-compose exec cli bash`
+ * `COMPOSER_MEMORY_LIMIT=-1 composer install`
+ * `drush si`
+
+* Now with the drutiny development:
+ * `docker-compose exec cli bash`
+ * `cd /ALGM`
+ * `composer require bomoko/algm_drutiny_profile:dev-master`
+
+* At this point you should be able to run the following:
+ * `cd /ALGM`
+ * `./vendor/bin/drutiny policy:list`
+ * `./vendor/bin/drutiny policy:audit Drupal-8:DblogDisabled @self`
+ * `./vendor/bin/drutiny profile:run ALGMbasicaudit @self`
+
+* Create a new policy and test it:
+ * Create a new branch in this repo.
+ * Create the new policies, profiles, etc (root of the repo) and push the branch up.
+ * `cd /ALGM`
+ * `composer require bomoko/algm_drutiny_profile:dev-YOURBRANCH#commit-hash`
+ * Your changes should now appear in the list of policies or profiles.
+
+
+## Composer template for Drupal projects
+
+[](https://travis-ci.org/drupal-composer/drupal-project)
+
+This project template provides a starter kit for managing your site
+dependencies with [Composer](https://getcomposer.org/).
+
+If you want to know how to use it as replacement for
+[Drush Make](https://github.com/drush-ops/drush/blob/8.x/docs/make.md) visit
+the [Documentation on drupal.org](https://www.drupal.org/node/2471553).
+
+## Usage
+
+First you need to [install composer](https://getcomposer.org/doc/00-intro.md#installation-linux-unix-osx).
+
+> Note: The instructions below refer to the [global composer installation](https://getcomposer.org/doc/00-intro.md#globally).
+You might need to replace `composer` with `php composer.phar` (or similar)
+for your setup.
+
+After that you can create the project:
+
+```
+composer create-project drupal-composer/drupal-project:8.x-dev some-dir --no-interaction
+```
+
+With `composer require ...` you can download new dependencies to your
+installation.
+
+```
+cd some-dir
+composer require drupal/devel:~1.0
+```
+
+The `composer create-project` command passes ownership of all files to the
+project that is created. You should create a new git repository, and commit
+all files not excluded by the .gitignore file.
+
+## What does the template do?
+
+When installing the given `composer.json` some tasks are taken care of:
+
+* Drupal will be installed in the `web`-directory.
+* Autoloader is implemented to use the generated composer autoloader in `vendor/autoload.php`,
+ instead of the one provided by Drupal (`web/vendor/autoload.php`).
+* Modules (packages of type `drupal-module`) will be placed in `web/modules/contrib/`
+* Theme (packages of type `drupal-theme`) will be placed in `web/themes/contrib/`
+* Profiles (packages of type `drupal-profile`) will be placed in `web/profiles/contrib/`
+* Creates default writable versions of `settings.php` and `services.yml`.
+* Creates `web/sites/default/files`-directory.
+* Latest version of drush is installed locally for use at `vendor/bin/drush`.
+* Latest version of DrupalConsole is installed locally for use at `vendor/bin/drupal`.
+* Creates environment variables based on your .env file. See [.env.example](.env.example).
+
+## Updating Drupal Core
+
+This project will attempt to keep all of your Drupal Core files up-to-date; the
+project [drupal/core-composer-scaffold](https://github.com/drupal/core-composer-scaffold)
+is used to ensure that your scaffold files are updated every time drupal/core is
+updated. If you customize any of the "scaffolding" files (commonly .htaccess),
+you may need to merge conflicts if any of your modified files are updated in a
+new release of Drupal core.
+
+Follow the steps below to update your core files.
+
+1. Run `composer update drupal/core drupal/core-dev --with-dependencies` to update Drupal Core and its dependencies.
+2. Run `git diff` to determine if any of the scaffolding files have changed.
+ Review the files for any changes and restore any customizations to
+ `.htaccess` or `robots.txt`.
+1. Commit everything all together in a single commit, so `web` will remain in
+ sync with the `core` when checking out branches or running `git bisect`.
+1. In the event that there are non-trivial conflicts in step 2, you may wish
+ to perform these steps on a branch, and use `git merge` to combine the
+ updated core files with your customized files. This facilitates the use
+ of a [three-way merge tool such as kdiff3](http://www.gitshah.com/2010/12/how-to-setup-kdiff-as-diff-tool-for-git.html). This setup is not necessary if your changes are simple;
+ keeping all of your modifications at the beginning or end of the file is a
+ good strategy to keep merges easy.
+
+## Generate composer.json from existing project
+
+With using [the "Composer Generate" drush extension](https://www.drupal.org/project/composer_generate)
+you can now generate a basic `composer.json` file from an existing project. Note
+that the generated `composer.json` might differ from this project's file.
+
+
+## FAQ
+
+### Should I commit the contrib modules I download?
+
+Composer recommends **no**. They provide [argumentation against but also
+workrounds if a project decides to do it anyway](https://getcomposer.org/doc/faqs/should-i-commit-the-dependencies-in-my-vendor-directory.md).
+
+### Should I commit the scaffolding files?
+
+The [Drupal Composer Scaffold](https://github.com/drupal/core-composer-scaffold) plugin can download the scaffold files (like
+index.php, update.php, …) to the web/ directory of your project. If you have not customized those files you could choose
+to not check them into your version control system (e.g. git). If that is the case for your project it might be
+convenient to automatically run the drupal-scaffold plugin after every install or update of your project. You can
+achieve that by registering `@composer drupal:scaffold` as post-install and post-update command in your composer.json:
+
+```json
+"scripts": {
+ "post-install-cmd": [
+ "@composer drupal:scaffold",
+ "..."
+ ],
+ "post-update-cmd": [
+ "@composer drupal:scaffold",
+ "..."
+ ]
+},
+```
+### How can I apply patches to downloaded modules?
+
+If you need to apply patches (depending on the project being modified, a pull
+request is often a better solution), you can do so with the
+[composer-patches](https://github.com/cweagans/composer-patches) plugin.
+
+To add a patch to drupal module foobar insert the patches section in the extra
+section of composer.json:
+```json
+"extra": {
+ "patches": {
+ "drupal/foobar": {
+ "Patch description": "URL or local path to patch"
+ }
+ }
+}
+```
+### How do I switch from packagist.drupal-composer.org to packages.drupal.org?
+
+Follow the instructions in the [documentation on drupal.org](https://www.drupal.org/docs/develop/using-composer/using-packagesdrupalorg).
+
+### How do I specify a PHP version ?
+
+This project supports PHP 7.0 as minimum version (see [Drupal 8 PHP requirements](https://www.drupal.org/docs/8/system-requirements/drupal-8-php-requirements)), however it's possible that a `composer update` will upgrade some package that will then require PHP 7+.
+
+To prevent this you can add this code to specify the PHP version you want to use in the `config` section of `composer.json`:
+```json
+"config": {
+ "sort-packages": true,
+ "platform": {
+ "php": "7.0.33"
+ }
+},
+```
diff --git a/drupal-web/cli.dockerfile b/drupal-web/cli.dockerfile
new file mode 100644
index 0000000..bc8e558
--- /dev/null
+++ b/drupal-web/cli.dockerfile
@@ -0,0 +1,15 @@
+FROM algmprivsecops/algmcli:latest as algmtools
+
+FROM amazeeio/php:7.2-cli-drupal
+
+COPY composer.json composer.lock /app/
+COPY scripts /app/scripts
+# Uncomment if you have a patches directory in your Drupal Installation
+# COPY patches /app/patches
+RUN composer install
+COPY . /app
+
+COPY --from=algmtools /ALGM /ALGM
+
+# Define where the Drupal Root is located
+ENV WEBROOT=web
\ No newline at end of file
diff --git a/drupal-web/composer.json b/drupal-web/composer.json
new file mode 100644
index 0000000..5c4a838
--- /dev/null
+++ b/drupal-web/composer.json
@@ -0,0 +1,79 @@
+{
+ "name": "drupal-composer/drupal-project",
+ "description": "Project template for Drupal 8 projects with composer",
+ "type": "project",
+ "license": "GPL-2.0-or-later",
+ "authors": [
+ {
+ "name": "",
+ "role": ""
+ }
+ ],
+ "repositories": [
+ {
+ "type": "composer",
+ "url": "https://packages.drupal.org/8"
+ }
+ ],
+ "require": {
+ "php": ">=7.0.8",
+ "composer/installers": "^1.2",
+ "cweagans/composer-patches": "^1.6.5",
+ "drupal/console": "^1.0.2",
+ "drupal/core": "^8.8.0",
+ "drupal/core-composer-scaffold": "^8.8.0",
+ "vlucas/phpdotenv": "^4.0",
+ "webflo/drupal-finder": "^1.0.0",
+ "zaporylie/composer-drupal-optimizations": "^1.0"
+ },
+ "require-dev": {
+ "drupal/core-dev": "^8.8.0"
+ },
+ "conflict": {
+ "drupal/drupal": "*"
+ },
+ "minimum-stability": "dev",
+ "prefer-stable": true,
+ "config": {
+ "sort-packages": true
+ },
+ "autoload": {
+ "classmap": [
+ "scripts/composer/ScriptHandler.php"
+ ],
+ "files": ["load.environment.php"]
+ },
+ "scripts": {
+ "pre-install-cmd": [
+ "DrupalProject\\composer\\ScriptHandler::checkComposerVersion"
+ ],
+ "pre-update-cmd": [
+ "DrupalProject\\composer\\ScriptHandler::checkComposerVersion"
+ ],
+ "post-install-cmd": [
+ "DrupalProject\\composer\\ScriptHandler::createRequiredFiles"
+ ],
+ "post-update-cmd": [
+ "DrupalProject\\composer\\ScriptHandler::createRequiredFiles"
+ ]
+ },
+ "extra": {
+ "composer-exit-on-patch-failure": true,
+ "patchLevel": {
+ "drupal/core": "-p2"
+ },
+ "drupal-scaffold": {
+ "locations": {
+ "web-root": "web/"
+ }
+ },
+ "installer-paths": {
+ "web/core": ["type:drupal-core"],
+ "web/libraries/{$name}": ["type:drupal-library"],
+ "web/modules/contrib/{$name}": ["type:drupal-module"],
+ "web/profiles/contrib/{$name}": ["type:drupal-profile"],
+ "web/themes/contrib/{$name}": ["type:drupal-theme"],
+ "drush/Commands/contrib/{$name}": ["type:drupal-drush"]
+ }
+ }
+}
diff --git a/drupal-web/config/sync/.htaccess b/drupal-web/config/sync/.htaccess
new file mode 100644
index 0000000..25776a3
--- /dev/null
+++ b/drupal-web/config/sync/.htaccess
@@ -0,0 +1,24 @@
+# Deny all requests from Apache 2.4+.
+
+ Require all denied
+
+
+# Deny all requests from Apache 2.0-2.2.
+
+ Deny from all
+
+
+# Turn off all options we don't need.
+Options -Indexes -ExecCGI -Includes -MultiViews
+
+# Set the catch-all handler to prevent scripts from being executed.
+SetHandler Drupal_Security_Do_Not_Remove_See_SA_2006_006
+
+ # Override the handler again if we're run later in the evaluation list.
+ SetHandler Drupal_Security_Do_Not_Remove_See_SA_2013_003
+
+
+# If we know how to do it safely, disable the PHP engine entirely.
+
+ php_flag engine off
+
\ No newline at end of file
diff --git a/drupal-web/docker-compose.yml b/drupal-web/docker-compose.yml
new file mode 100644
index 0000000..2d9dd49
--- /dev/null
+++ b/drupal-web/docker-compose.yml
@@ -0,0 +1,120 @@
+version: '2.3'
+
+x-lagoon-project:
+ # Lagoon project name (leave `&lagoon-project` when you edit this)
+ &lagoon-project drutiny-drupal-example
+
+x-volumes:
+ &default-volumes
+ # Define all volumes you would like to have real-time mounted into the docker containers
+ volumes:
+ - .:/app:delegated
+
+x-environment:
+ &default-environment
+ LAGOON_PROJECT: *lagoon-project
+ # Route that should be used locally
+ LAGOON_ROUTE: http://drutiny-drupal.docker.amazee.io
+ # Uncomment if you like to have the system behave like in production
+ #LAGOON_ENVIRONMENT_TYPE: production
+ # Uncomment to enable xdebug and then restart via `docker-compose up -d`
+ #XDEBUG_ENABLE: "true"
+
+
+services:
+
+ cli: # cli container, will be used for executing composer and any local commands (drush, drupal, etc.)
+ build:
+ context: .
+ dockerfile: cli.dockerfile
+ image: *lagoon-project # this image will be reused as `CLI_IMAGE` in subsequent Docker builds
+ labels:
+ # Lagoon Labels
+ lagoon.type: cli-persistent
+ lagoon.persistent.name: nginx # mount the persistent storage of nginx into this container
+ lagoon.persistent: /app/web/sites/default/files/ # location where the persistent storage should be mounted
+ << : *default-volumes # loads the defined volumes from the top
+ volumes_from: # mount the ssh-agent from the pygmy or cachalot ssh-agent
+ - container:amazeeio-ssh-agent
+ environment:
+ << : *default-environment # loads the defined environment variables from the top
+
+ nginx:
+ build:
+ context: .
+ dockerfile: nginx.dockerfile
+ args:
+ CLI_IMAGE: *lagoon-project # Inject the name of the cli image
+ labels:
+ lagoon.type: nginx-php-persistent
+ lagoon.persistent: /app/web/sites/default/files/ # define where the persistent storage should be mounted too
+ << : *default-volumes # loads the defined volumes from the top
+ depends_on:
+ - cli # basically just tells docker-compose to build the cli first
+ environment:
+ << : *default-environment # loads the defined environment variables from the top
+ LAGOON_LOCALDEV_URL: nginx-drupal.docker.amazee.io # generate another route for nginx, by default we go to varnish
+ networks:
+ - amazeeio-network
+ - default
+
+ php:
+ build:
+ context: .
+ dockerfile: php.dockerfile
+ args:
+ CLI_IMAGE: *lagoon-project
+ labels:
+ lagoon.type: nginx-php-persistent
+ lagoon.name: nginx # we want this service be part of the nginx pod in Lagoon
+ lagoon.persistent: /app/web/sites/default/files/ # define where the persistent storage should be mounted too
+ << : *default-volumes # loads the defined volumes from the top
+ depends_on:
+ - cli # basically just tells docker-compose to build the cli first
+ environment:
+ << : *default-environment # loads the defined environment variables from the top
+
+
+ mariadb:
+ image: amazeeio/mariadb-drupal
+ labels:
+ lagoon.type: mariadb
+ ports:
+ - "3306" # exposes the port 3306 with a random local port, find it with `docker-compose port mariadb 3306`
+ environment:
+ << : *default-environment
+
+ ## Uncomment for Redis
+ # redis:
+ # image: amazeeio/redis
+ # labels:
+ # lagoon.type: redis
+ # environment:
+ # << : *default-environment
+
+ ## Uncomment for Solr
+ # solr:
+ # image: amazeeio/solr:6.6-drupal
+ # labels:
+ # lagoon.type: solr
+ # ports:
+ # - "8983" # exposes the port 8983 with a random local port, find it with `docker-compose port solr 8983`
+ # environment:
+ # << : *default-environment
+
+ varnish:
+ image: amazeeio/varnish-drupal
+ labels:
+ lagoon.type: varnish
+ links:
+ - nginx # links varnish to the nginx in this docker-compose project, or it would try to connect to any nginx running in docker
+ environment:
+ << : *default-environment
+ VARNISH_BYPASS: "true" # by default we bypass varnish, change to 'false' or remove in order to tell varnish to cache if possible
+ networks:
+ - amazeeio-network
+ - default
+
+networks:
+ amazeeio-network:
+ external: true
diff --git a/drupal-web/drush/Commands/PolicyCommands.php b/drupal-web/drush/Commands/PolicyCommands.php
new file mode 100644
index 0000000..290b4e0
--- /dev/null
+++ b/drupal-web/drush/Commands/PolicyCommands.php
@@ -0,0 +1,38 @@
+input()->getArgument('target') == '@prod') {
+ throw new \Exception(dt('Per !file, you may never overwrite the production database.', ['!file' => __FILE__]));
+ }
+ }
+
+ /**
+ * Limit rsync operations to production site.
+ *
+ * @hook validate core:rsync
+ *
+ * @throws \Exception
+ */
+ public function rsyncValidate(CommandData $commandData) {
+ if (preg_match("/^@prod/", $commandData->input()->getArgument('target'))) {
+ throw new \Exception(dt('Per !file, you may never rsync to the production site.', ['!file' => __FILE__]));
+ }
+ }
+}
diff --git a/drupal-web/drush/README.md b/drupal-web/drush/README.md
new file mode 100644
index 0000000..9d7bd39
--- /dev/null
+++ b/drupal-web/drush/README.md
@@ -0,0 +1 @@
+This directory contains commands, configuration and site aliases for Drush. See https://packagist.org/search/?type=drupal-drush for a directory of Drush commands installable via Composer.
diff --git a/drupal-web/drush/aliases.drushrc.php b/drupal-web/drush/aliases.drushrc.php
new file mode 100644
index 0000000..363d725
--- /dev/null
+++ b/drupal-web/drush/aliases.drushrc.php
@@ -0,0 +1,37 @@
+ 'cache,cache_*,history,sessions,watchdog,feeds_log');
+$command_specific['sql-dump'] = array('structure-tables-list' => 'cache,cache_*,history,sessions,watchdog,feeds_log');
diff --git a/drupal-web/drush/sites/self.site.yml b/drupal-web/drush/sites/self.site.yml
new file mode 100644
index 0000000..fda7194
--- /dev/null
+++ b/drupal-web/drush/sites/self.site.yml
@@ -0,0 +1,14 @@
+# Edit or remove this file as needed.
+# Docs at https://github.com/drush-ops/drush/blob/master/examples/example.site.yml
+
+#prod:
+# host: prod.domain.com
+# user: www-admin
+# root: /path/to/drupal
+# uri: http://www.example.com
+#
+#stage:
+# host: stage.domain.com
+# user: www-admin
+# root: /path/to/drupal
+# uri: http://stage.example.com
diff --git a/drupal-web/load.environment.php b/drupal-web/load.environment.php
new file mode 100644
index 0000000..eef1d28
--- /dev/null
+++ b/drupal-web/load.environment.php
@@ -0,0 +1,15 @@
+safeLoad();
diff --git a/drupal-web/nginx.dockerfile b/drupal-web/nginx.dockerfile
new file mode 100644
index 0000000..237595a
--- /dev/null
+++ b/drupal-web/nginx.dockerfile
@@ -0,0 +1,9 @@
+ARG CLI_IMAGE
+FROM ${CLI_IMAGE} as cli
+
+FROM amazeeio/nginx-drupal
+
+COPY --from=cli /app /app
+
+# Define where the Drupal Root is located
+ENV WEBROOT=web
diff --git a/drupal-web/php.dockerfile b/drupal-web/php.dockerfile
new file mode 100644
index 0000000..0c91f03
--- /dev/null
+++ b/drupal-web/php.dockerfile
@@ -0,0 +1,6 @@
+ARG CLI_IMAGE
+FROM ${CLI_IMAGE} as cli
+
+FROM amazeeio/php:7.2-fpm
+
+COPY --from=cli /app /app
diff --git a/drupal-web/phpunit.xml.dist b/drupal-web/phpunit.xml.dist
new file mode 100644
index 0000000..ce29746
--- /dev/null
+++ b/drupal-web/phpunit.xml.dist
@@ -0,0 +1,15 @@
+
+
+
+
+
+ ./test/
+
+
+
diff --git a/drupal-web/scripts/composer/ScriptHandler.php b/drupal-web/scripts/composer/ScriptHandler.php
new file mode 100644
index 0000000..51026d3
--- /dev/null
+++ b/drupal-web/scripts/composer/ScriptHandler.php
@@ -0,0 +1,100 @@
+locateRoot(getcwd());
+ $drupalRoot = $drupalFinder->getDrupalRoot();
+
+ $dirs = [
+ 'modules',
+ 'profiles',
+ 'themes',
+ ];
+
+ // Required for unit testing
+ foreach ($dirs as $dir) {
+ if (!$fs->exists($drupalRoot . '/'. $dir)) {
+ $fs->mkdir($drupalRoot . '/'. $dir);
+ $fs->touch($drupalRoot . '/'. $dir . '/.gitkeep');
+ }
+ }
+
+ // Prepare the settings file for installation
+ if (!$fs->exists($drupalRoot . '/sites/default/settings.php') && $fs->exists($drupalRoot . '/sites/default/default.settings.php')) {
+ $fs->copy($drupalRoot . '/sites/default/default.settings.php', $drupalRoot . '/sites/default/settings.php');
+ require_once $drupalRoot . '/core/includes/bootstrap.inc';
+ require_once $drupalRoot . '/core/includes/install.inc';
+ new Settings([]);
+ $settings['settings']['config_sync_directory'] = (object) [
+ 'value' => Path::makeRelative($drupalFinder->getComposerRoot() . '/config/sync', $drupalRoot),
+ 'required' => TRUE,
+ ];
+ drupal_rewrite_settings($settings, $drupalRoot . '/sites/default/settings.php');
+ $fs->chmod($drupalRoot . '/sites/default/settings.php', 0666);
+ $event->getIO()->write("Created a sites/default/settings.php file with chmod 0666");
+ }
+
+ // Create the files directory with chmod 0777
+ if (!$fs->exists($drupalRoot . '/sites/default/files')) {
+ $oldmask = umask(0);
+ $fs->mkdir($drupalRoot . '/sites/default/files', 0777);
+ umask($oldmask);
+ $event->getIO()->write("Created a sites/default/files directory with chmod 0777");
+ }
+ }
+
+ /**
+ * Checks if the installed version of Composer is compatible.
+ *
+ * Composer 1.0.0 and higher consider a `composer install` without having a
+ * lock file present as equal to `composer update`. We do not ship with a lock
+ * file to avoid merge conflicts downstream, meaning that if a project is
+ * installed with an older version of Composer the scaffolding of Drupal will
+ * not be triggered. We check this here instead of in drupal-scaffold to be
+ * able to give immediate feedback to the end user, rather than failing the
+ * installation after going through the lengthy process of compiling and
+ * downloading the Composer dependencies.
+ *
+ * @see https://github.com/composer/composer/pull/5035
+ */
+ public static function checkComposerVersion(Event $event) {
+ $composer = $event->getComposer();
+ $io = $event->getIO();
+
+ $version = $composer::VERSION;
+
+ // The dev-channel of composer uses the git revision as version number,
+ // try to the branch alias instead.
+ if (preg_match('/^[0-9a-f]{40}$/i', $version)) {
+ $version = $composer::BRANCH_ALIAS_VERSION;
+ }
+
+ // If Composer is installed through git we have no easy way to determine if
+ // it is new enough, just display a warning.
+ if ($version === '@package_version@' || $version === '@package_branch_alias_version@') {
+ $io->writeError('You are running a development version of Composer. If you experience problems, please update Composer to the latest stable version.');
+ }
+ elseif (Comparator::lessThan($version, '1.0.0')) {
+ $io->writeError('Drupal-project requires Composer version 1.0.0 or higher. Please update your Composer before continuing.');
+ exit(1);
+ }
+ }
+
+}
diff --git a/drupal-web/web/.gitignore b/drupal-web/web/.gitignore
new file mode 100644
index 0000000..b18f7db
--- /dev/null
+++ b/drupal-web/web/.gitignore
@@ -0,0 +1,13 @@
+/.csslintrc
+/.eslintignore
+/.eslintrc.json
+/.ht.router.php
+/.htaccess
+/INSTALL.txt
+/README.txt
+/autoload.php
+/example.gitignore
+/index.php
+/robots.txt
+/update.php
+/web.config
\ No newline at end of file
diff --git a/drupal-web/web/modules/.gitignore b/drupal-web/web/modules/.gitignore
new file mode 100644
index 0000000..739a339
--- /dev/null
+++ b/drupal-web/web/modules/.gitignore
@@ -0,0 +1 @@
+/README.txt
\ No newline at end of file
diff --git a/drupal-web/web/profiles/.gitignore b/drupal-web/web/profiles/.gitignore
new file mode 100644
index 0000000..739a339
--- /dev/null
+++ b/drupal-web/web/profiles/.gitignore
@@ -0,0 +1 @@
+/README.txt
\ No newline at end of file
diff --git a/drupal-web/web/sites/.gitignore b/drupal-web/web/sites/.gitignore
new file mode 100644
index 0000000..0d11947
--- /dev/null
+++ b/drupal-web/web/sites/.gitignore
@@ -0,0 +1,4 @@
+/README.txt
+/development.services.yml
+/example.settings.local.php
+/example.sites.php
\ No newline at end of file
diff --git a/drupal-web/web/sites/default/.gitignore b/drupal-web/web/sites/default/.gitignore
new file mode 100644
index 0000000..3176441
--- /dev/null
+++ b/drupal-web/web/sites/default/.gitignore
@@ -0,0 +1,6 @@
+/README.txt
+/development.services.yml
+/example.settings.local.php
+/example.sites.php
+/default.services.yml
+/default.settings.php
\ No newline at end of file
diff --git a/drupal-web/web/sites/default/all.services.yml b/drupal-web/web/sites/default/all.services.yml
new file mode 100644
index 0000000..e6bb7c8
--- /dev/null
+++ b/drupal-web/web/sites/default/all.services.yml
@@ -0,0 +1,4 @@
+### Lagoon Drupal 8 all environment services file.
+#
+# This file should contain service definitions that are needed on all environments
+#
diff --git a/drupal-web/web/sites/default/all.settings.php b/drupal-web/web/sites/default/all.settings.php
new file mode 100755
index 0000000..88fa5fe
--- /dev/null
+++ b/drupal-web/web/sites/default/all.settings.php
@@ -0,0 +1,14 @@
+ 'mysql',
+ 'database' => getenv('MARIADB_DATABASE') ?: 'drupal',
+ 'username' => getenv('MARIADB_USERNAME') ?: 'drupal',
+ 'password' => getenv('MARIADB_PASSWORD') ?: 'drupal',
+ 'host' => getenv('MARIADB_HOST') ?: 'mariadb',
+ 'port' => 3306,
+ 'prefix' => '',
+ );
+}
+
+// Lagoon Solr connection
+// WARNING: you have to create a search_api server having "solr" machine name at
+// /admin/config/search/search-api/add-server to make this work.
+if (getenv('LAGOON') && (file_exists($app_root . '/modules/contrib/search_api_solr') || file_exists($app_root . 'modules/search_api_solr'))) {
+ $config['search_api.server.solr']['backend_config']['connector_config']['host'] = (getenv('SOLR_HOST') ?: 'solr');
+ $config['search_api.server.solr']['backend_config']['connector_config']['path'] = '/solr/';
+ $config['search_api.server.solr']['backend_config']['connector_config']['core'] = (getenv('SOLR_CORE') ?: 'drupal');
+ $config['search_api.server.solr']['backend_config']['connector_config']['port'] = 8983;
+ $config['search_api.server.solr']['backend_config']['connector_config']['http_user'] = (getenv('SOLR_USER') ?: '');
+ $config['search_api.server.solr']['backend_config']['connector_config']['http']['http_user'] = (getenv('SOLR_USER') ?: '');
+ $config['search_api.server.solr']['backend_config']['connector_config']['http_pass'] = (getenv('SOLR_PASSWORD') ?: '');
+ $config['search_api.server.solr']['backend_config']['connector_config']['http']['http_pass'] = (getenv('SOLR_PASSWORD') ?: '');
+ $config['search_api.server.solr']['name'] = 'Lagoon Solr - Environment: ' . getenv('LAGOON_PROJECT');
+}
+
+// Lagoon Redis connection if Drupal Redis module exists and PHP Redis Module is loaded.
+if (getenv('LAGOON') && (file_exists($app_root . '/modules/contrib/redis') || file_exists($app_root . 'modules/redis')) && extension_loaded('redis')) {
+ $settings['redis.connection']['interface'] = 'PhpRedis';
+ $settings['redis.connection']['host'] = getenv('REDIS_HOST') ?: 'redis';
+ $settings['redis.connection']['port'] = getenv('REDIS_SERVICE_PORT') ?: '6379';
+
+ $settings['cache_prefix']['default'] = getenv('LAGOON_PROJECT') . '_' . getenv('LAGOON_GIT_SAFE_BRANCH');
+
+ // Do not set the cache during installations of Drupal.
+ if (!drupal_installation_attempted()) {
+ $settings['cache']['default'] = 'cache.backend.redis';
+
+ // Include the default example.services.yml from the module, which will
+ // replace all supported backend services (that currently includes the cache tags
+ // checksum service and the lock backends, check the file for the current list)
+ $settings['container_yamls'][] = 'modules/contrib/redis/example.services.yml';
+
+ // Allow the services to work before the Redis module itself is enabled.
+ $settings['container_yamls'][] = 'modules/contrib/redis/redis.services.yml';
+
+ // Manually add the classloader path, this is required for the container cache bin definition below
+ // and allows to use it without the redis module being enabled.
+ $class_loader->addPsr4('Drupal\\redis\\', 'modules/contrib/redis/src');
+
+ // Use redis for container cache.
+ // The container cache is used to load the container definition itself, and
+ // thus any configuration stored in the container itself is not available
+ // yet. These lines force the container cache to use Redis rather than the
+ // default SQL cache.
+ $settings['bootstrap_container_definition'] = [
+ 'parameters' => [],
+ 'services' => [
+ 'redis.factory' => [
+ 'class' => 'Drupal\redis\ClientFactory',
+ ],
+ 'cache.backend.redis' => [
+ 'class' => 'Drupal\redis\Cache\CacheBackendFactory',
+ 'arguments' => ['@redis.factory', '@cache_tags_provider.container', '@serialization.phpserialize'],
+ ],
+ 'cache.container' => [
+ 'class' => '\Drupal\redis\Cache\PhpRedis',
+ 'factory' => ['@cache.backend.redis', 'get'],
+ 'arguments' => ['container'],
+ ],
+ 'cache_tags_provider.container' => [
+ 'class' => 'Drupal\redis\Cache\RedisCacheTagsChecksum',
+ 'arguments' => ['@redis.factory'],
+ ],
+ 'serialization.phpserialize' => [
+ 'class' => 'Drupal\Component\Serialization\PhpSerialize',
+ ],
+ ],
+ ];
+ }
+}
+
+// Trusted Host Patterns, see https://www.drupal.org/node/2410395 for more information.
+// If your site runs on multiple domains, you need to add these domains here.
+if (getenv('LAGOON_ROUTES')) {
+ $settings['trusted_host_patterns'] = array(
+ // Escape dots, remove schema, use commas as regex separator.
+ '^' . str_replace(['.', 'https://', 'http://', ','], ['\.', '', '', '|'], getenv('LAGOON_ROUTES')) . '$',
+ );
+}
+
+// Temp directory.
+if (getenv('TMP')) {
+ $config['system.file']['path']['temporary'] = getenv('TMP');
+}
+
+// Hash Salt.
+if (getenv('LAGOON')) {
+ $settings['hash_salt'] = hash('sha256', getenv('LAGOON_PROJECT'));
+}
+
+// Settings for all environments.
+if (file_exists(__DIR__ . '/all.settings.php')) {
+ include __DIR__ . '/all.settings.php';
+}
+
+// Services for all environments.
+if (file_exists(__DIR__ . '/all.services.yml')) {
+ $settings['container_yamls'][] = __DIR__ . '/all.services.yml';
+}
+
+if (getenv('LAGOON_ENVIRONMENT_TYPE')) {
+ // Environment specific settings files.
+ if (file_exists(__DIR__ . '/' . getenv('LAGOON_ENVIRONMENT_TYPE') . '.settings.php')) {
+ include __DIR__ . '/' . getenv('LAGOON_ENVIRONMENT_TYPE') . '.settings.php';
+ }
+
+ // Environment specific services files.
+ if (file_exists(__DIR__ . '/' . getenv('LAGOON_ENVIRONMENT_TYPE') . '.services.yml')) {
+ $settings['container_yamls'][] = __DIR__ . '/' . getenv('LAGOON_ENVIRONMENT_TYPE') . '.services.yml';
+ }
+}
+
+// Last: this servers specific settings files.
+if (file_exists(__DIR__ . '/settings.local.php')) {
+ include __DIR__ . '/settings.local.php';
+}
+// Last: This server specific services file.
+if (file_exists(__DIR__ . '/services.local.yml')) {
+ $settings['container_yamls'][] = __DIR__ . '/services.local.yml';
+}
diff --git a/drupal-web/web/themes/.gitignore b/drupal-web/web/themes/.gitignore
new file mode 100644
index 0000000..739a339
--- /dev/null
+++ b/drupal-web/web/themes/.gitignore
@@ -0,0 +1 @@
+/README.txt
\ No newline at end of file