2019-11-18 05:58:33 +01:00
|
|
|
---
|
|
|
|
title: Server Requirements
|
|
|
|
icon: server
|
2020-10-22 04:01:30 +02:00
|
|
|
summary: What you will need to run Silverstripe CMS on a web server
|
2019-11-18 05:58:33 +01:00
|
|
|
---
|
|
|
|
|
2011-02-07 07:48:44 +01:00
|
|
|
# Requirements
|
|
|
|
|
2019-11-18 05:58:33 +01:00
|
|
|
Silverstripe CMS needs to be installed on a web server. Content authors and website administrators use their web browser
|
2014-09-21 02:07:58 +02:00
|
|
|
to access a web-based GUI to do their day-to-day work. Website designers and developers require access to the files on
|
|
|
|
the server to update templates, website logic, and perform upgrades or maintenance.
|
2011-02-07 07:48:44 +01:00
|
|
|
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
## PHP
|
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
* PHP >=7.1
|
|
|
|
* PHP extensions: `ctype`, `dom`, `fileinfo`, `hash`, `intl`, `mbstring`, `session`, `simplexml`, `tokenizer`, `xml`
|
|
|
|
* PHP configuration: `memory_limit` with at least `48M`
|
|
|
|
* PHP extension for image manipulation: Either `gd` or `imagick`
|
|
|
|
* PHP extension for a database connector (e.g. `pdo` or `mysqli`)
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
|
|
|
Use [phpinfo()](http://php.net/manual/en/function.phpinfo.php) to inspect your configuration.
|
|
|
|
|
|
|
|
## Database
|
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
* MySQL >=5.6 (
|
|
|
|
built-in, [commercially supported](https://www.silverstripe.org/software/addons/silverstripe-commercially-supported-module-list/))
|
|
|
|
* PostgreSQL ([third party module](https://addons.silverstripe.org/add-ons/silverstripe/postgresql), community
|
|
|
|
supported)
|
|
|
|
* SQL Server ([third party module](https://addons.silverstripe.org/add-ons/silverstripe/mssql), community supported)
|
|
|
|
* SQLite ([third party module](https://addons.silverstripe.org/add-ons/silverstripe/sqlite3), community supported)
|
2020-10-22 04:01:30 +02:00
|
|
|
|
2021-02-24 03:38:55 +01:00
|
|
|
### Default MySQL Collation
|
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
In Silverstripe CMS Recipe 4.7 and later, new projects default to the `utf8mb4_unicode_ci` collation when running
|
|
|
|
against MySQL, which offers better support for multi-byte characters such as emoji. However, this may cause issues
|
|
|
|
related to Varchar fields exceeding the maximum indexable size:
|
2021-02-24 03:38:55 +01:00
|
|
|
|
|
|
|
- MySQL 5.5 and lower cannot support indexes larger than 768 bytes (192 characters)
|
|
|
|
- MySQL 5.6 supports larger indexes (3072 bytes) if the `innodb_large_prefix` setting is enabled (but not by default)
|
|
|
|
- MySQL 5.7 and newer have `innodb_large_prefix` enabled by default
|
|
|
|
- MariaDB ~10.1 matches MySQL 5.6's behaviour, >10.2 matches 5.7's.
|
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
You can rectify this issue by upgrading MySQL, enabling the `innodb_large_prefix` setting if available, or reducing the
|
|
|
|
size of affected fields. If none of these solutions are currently suitable, you can remove the new collation
|
|
|
|
configuration from `app/_config/mysite.yml` to default back to the previous default collation.
|
2021-02-24 03:38:55 +01:00
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
Existing projects that upgrade to Recipe 4.7.0 will unintentionally adopt this configuration change. Recipe 4.7.1 and
|
|
|
|
later are unaffected. See [the release notes](/changelogs/4.7.0/#default-mysql-collation-updated) for more information.
|
2021-02-24 03:38:55 +01:00
|
|
|
|
|
|
|
### Connection mode (sql_mode) when using MySQL server >=5.7.5
|
2020-10-22 04:01:30 +02:00
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
In MySQL versions >=5.7.5, the `ANSI` sql_mode setting behaves differently and includes the `ONLY_FULL_GROUP_BY`
|
|
|
|
setting. It is generally recommended to leave this setting as-is because it results in deterministic SQL. However, for
|
|
|
|
some advanced cases, the sql_mode can be configured on the database connection via the configuration API (
|
|
|
|
see `MySQLDatabase::$sql_mode` for more details.) This setting is only available in Silverstripe CMS 4.7 and later.
|
2020-10-22 04:01:30 +02:00
|
|
|
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
## Webserver Configuration
|
|
|
|
|
|
|
|
### Overview
|
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
Silverstripe CMS needs to handle a variety of HTTP requests, and relies on the hosting environment to be configured securely
|
2021-06-22 10:41:48 +02:00
|
|
|
to enforce restrictions. There are secure defaults in place for Apache, but you should be aware of the configuration
|
|
|
|
regardless of your webserver setup.
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
2019-09-03 08:51:27 +02:00
|
|
|
### Public webroot
|
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
The webroot of your webserver should be configured to the `public/` subfolder. Projects created prior to Silverstripe CMS
|
2021-06-22 10:41:48 +02:00
|
|
|
4.1 might be using the main project folder as the webroot. In this case, you are responsible for ensuring access to
|
|
|
|
system files such as configuration in `*.yml` is protected from public access. We strongly recommend switching to more
|
|
|
|
secure hosting via the `public/`. See [4.1.0 upgrading guide](/changelogs/4.1.0).
|
2019-09-03 08:51:27 +02:00
|
|
|
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
### Filesystem permissions
|
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
During runtime, Silverstripe CMS needs read access for the webserver user to your base path (including your webroot). It
|
2021-06-22 10:41:48 +02:00
|
|
|
also needs write access for the webserver user to the following locations:
|
2021-06-02 00:59:42 +02:00
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
* `public/assets/`: Used by the CMS and other logic to [store uploads](/developer_guides/files/file_storage)
|
|
|
|
* `TEMP_PATH`: Temporary file storage used for the default filesystem-based cache adapters in
|
|
|
|
[Manifests](/developer_guides/execution_pipeline/manifests), [Object Caching](/developer_guides/performance/caching)
|
|
|
|
and [Partial Template Caching](/developer_guides/templates/partial_template_caching).
|
|
|
|
See [Environment Management](/getting_started/environment_management).
|
2021-06-02 00:59:42 +02:00
|
|
|
|
|
|
|
If you aren't explicitly [packaging](#building-packaging-deployment)
|
2021-06-30 11:48:52 +02:00
|
|
|
your Silverstripe CMS project during your deployment process, additional write access may be required to generate supporting
|
2021-06-22 10:41:48 +02:00
|
|
|
files on the fly. This is not recommended, because it can lead to extended execution times as well as cause
|
|
|
|
inconsistencies between multiple server environments when manifest and cache storage isn't shared between servers.
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
|
|
|
### Assets
|
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
Silverstripe CMS allows CMS authors to upload files into the `public/assets/` folder, which should be served by your
|
2021-06-22 10:41:48 +02:00
|
|
|
webserver. **No PHP execution should be allowed in this folder**. This is configured for Apache by default
|
|
|
|
via `public/assets/.htaccess`. The file is generated dynamically during the `dev/build` stage.
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
Additionally, access is whitelisted by file extension through a dynamically generated whitelist based on
|
|
|
|
the `File.allowed_extensions` setting
|
|
|
|
(see [File Security](/developer_guides/files/file_security#file-types)). This whitelist uses the same defaults
|
2021-06-30 11:48:52 +02:00
|
|
|
configured through file upload through Silverstripe CMS, so is considered a second line of defence.
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
2020-10-15 06:08:21 +02:00
|
|
|
### Secure Assets {#secure-assets}
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
Files can be kept in draft stage, and access restricted to certain user groups. These files are stored in a
|
|
|
|
special `.protected/` folder (defaulting to `public/assets/.protected/`).
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
**Requests to files in this folder should be denied by your webserver**.
|
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
Requests to files in the `.protected/` folder are routed to PHP by default when using Apache,
|
|
|
|
through `public/assets/.htaccess`. If you are using another webserver, please follow our guides to ensure a secure
|
|
|
|
setup. See [Developer Guides: File Security](/developer_guides/files/file_security) for details.
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
For additional security, we recommend moving the `.protected/` folder out of `public/assets/`. This removes the
|
|
|
|
possibility of a misconfigured webserver accidentally exposing these files under URL paths, and forces read access via
|
|
|
|
PHP.
|
2020-10-15 06:08:21 +02:00
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
This can be configured via [.env](/getting_started/environment_management) variable, relative to the `index.php`
|
|
|
|
location.
|
2020-10-15 06:08:21 +02:00
|
|
|
|
|
|
|
```
|
|
|
|
SS_PROTECTED_ASSETS_PATH="../.protected/"
|
|
|
|
```
|
|
|
|
|
|
|
|
The resulting folder structure will look as follows:
|
|
|
|
|
|
|
|
```
|
|
|
|
.protected/
|
|
|
|
<hash>/my-protected-file.txt
|
|
|
|
public/
|
|
|
|
index.php
|
|
|
|
assets/
|
|
|
|
my-public-file.txt
|
|
|
|
vendor/
|
|
|
|
app/
|
|
|
|
```
|
|
|
|
|
|
|
|
Don't forget to include this additional folder in any syncing and backup processes!
|
|
|
|
|
2021-06-02 00:59:42 +02:00
|
|
|
### Building, Packaging and Deployment {#building-packaging-deployment}
|
2021-02-17 00:40:27 +01:00
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
It is common to build a Silverstripe CMS application into a package on one environment (e.g. a CI server), and then deploy
|
2021-06-22 10:41:48 +02:00
|
|
|
the package to a (separate) webserver environment(s). This approach relies on all auto-generated files required by
|
2021-06-30 11:48:52 +02:00
|
|
|
Silverstripe CMS to be included in the package, or generated on the fly on each webserver environment.
|
2021-06-22 10:41:48 +02:00
|
|
|
|
|
|
|
The easiest way to ensure this is to commit auto generated files to source control. If those changes are considered too
|
|
|
|
noisy, here's some pointers for auto-generated files to trigger and include in a deployment package:
|
|
|
|
|
|
|
|
* `public/_resources/`: Frontend assets copied from the (inaccessible) `vendor/` folder
|
|
|
|
via [silverstripe/vendor-plugin](https://github.com/silverstripe/vendor-plugin).
|
|
|
|
See [Templates: Requirements](/developer_guides/templates/requirements#exposing-assets-webroot).
|
|
|
|
* `.graphql/` and `public/_graphql/`: Schema and type definitions required by CMS and any GraphQL API endpoint.
|
|
|
|
Generated through
|
|
|
|
[silverstripe/graphql v4](https://github.com/silverstripe/silverstripe-graphql). Triggered by `dev/build`, or
|
|
|
|
a [GraphQL Schema Build](/developer_guides/graphql/getting_started/building_the_schema).
|
|
|
|
* Various recipes create default files in `app/` and `public/` on `composer install`
|
|
|
|
and `composer update` via
|
|
|
|
[silverstripe/recipe-plugin](https://github.com/silverstripe/recipe-plugin).
|
2020-02-14 03:23:20 +01:00
|
|
|
|
|
|
|
### Web Worker Concurrency
|
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
It's generally a good idea to run multiple workers to serve multiple HTTP requests to Silverstripe CMS concurrently. The
|
2021-06-22 10:41:48 +02:00
|
|
|
exact number depends on your website needs. The CMS attempts to request multiple views concurrently. It also
|
|
|
|
routes [protected and draft files](/developer_guides/files/file_security)
|
2021-06-30 11:48:52 +02:00
|
|
|
through Silverstripe CMS. This can increase your concurrency requirements, e.g. when authors batch upload and view dozens of
|
2021-06-22 10:41:48 +02:00
|
|
|
draft files in the CMS.
|
|
|
|
|
|
|
|
When allowing upload of large files through the CMS (through PHP settings), these files might be used
|
2021-06-30 11:48:52 +02:00
|
|
|
as [protected and draft files](/developer_guides/files/file_security). Files in this state get served by Silverstripe CMS
|
2021-06-22 10:41:48 +02:00
|
|
|
rather than your webserver. Since the framework uses [PHP streams](https://www.php.net/manual/en/ref.stream.php), this
|
|
|
|
allows serving of files larger than your PHP memory limit. Please be aware that streaming operations don't count towards
|
|
|
|
PHP's [max_execution_time](https://www.php.net/manual/en/function.set-time-limit.php), which can risk exhaustion of web
|
|
|
|
worker pools for long-running downloads.
|
2020-02-14 03:23:20 +01:00
|
|
|
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
### URL Rewriting
|
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
Silverstripe CMS expects URL paths to be rewritten to `public/index.php`. For Apache, this is preconfigured
|
2021-06-22 10:41:48 +02:00
|
|
|
through `.htaccess` files, and expects using the `mod_rewrite` module. By default, these files are located
|
|
|
|
in `public/.htaccess` and `public/assets/.htaccess`.
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
|
|
|
### HTTP Headers
|
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
Silverstripe CMS can add HTTP headers to responses it handles directly. These headers are often sensitive, for example
|
2021-06-22 10:41:48 +02:00
|
|
|
preventing HTTP caching for responses displaying data based on user sessions, or when serving protected assets. You need
|
|
|
|
to ensure those headers are kept in place in your webserver. For example, Apache allows this
|
|
|
|
through `Header setifempty` (see [docs](https://httpd.apache.org/docs/current/mod/mod_headers.html#header)).
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
See [Developer Guide: Performance](/developer_guides/performance/)
|
|
|
|
and [Developer Guides: File Security](/developer_guides/files/file_security) for more details.
|
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
Silverstripe CMS relies on the `Host` header to construct URLs such as "reset password" links, so you'll need to ensure that
|
2021-06-22 10:41:48 +02:00
|
|
|
the systems hosting it only allow valid values for this header.
|
|
|
|
See [Developer Guide: Security - Request hostname forgery](/developer_guides/security/secure_coding#request-hostname-forgery)
|
|
|
|
.
|
2020-07-29 04:28:20 +02:00
|
|
|
|
|
|
|
### CDNs and other Reverse Proxies
|
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
If your Silverstripe CMS site is hosted behind multiple HTTP layers, you're in charge of controlling which forwarded headers
|
2021-06-22 10:41:48 +02:00
|
|
|
are considered valid, and which IPs can set them.
|
|
|
|
See [Developer Guide: Security - Request hostname forgery](/developer_guides/security/secure_coding#request-hostname-forgery)
|
|
|
|
.
|
2020-07-29 04:28:20 +02:00
|
|
|
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
### Symlinks
|
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
Silverstripe CMS is a modular system, with modules installed and updated via the `composer` PHP dependency manager. These
|
2021-06-22 10:41:48 +02:00
|
|
|
are usually stored in `vendor/`, outside of the `public/` webroot. Since many modules rely on serving frontend assets
|
|
|
|
such as CSS files or images, these are mapped over to the `public/_resources/` folder automatically. If the filesystem
|
|
|
|
supports it, this is achieved through symlinks. Depending on your hosting and deployment mechanisms, you may need to
|
|
|
|
configure the plugin to copy files instead.
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
See [silverstripe/vendor-plugin](https://github.com/silverstripe/vendor-plugin) for details.
|
|
|
|
|
2020-11-25 05:05:33 +01:00
|
|
|
### Caches
|
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
Silverstripe CMS relies on various [caches](/developer_guides/performance/caching/)
|
2021-06-22 10:41:48 +02:00
|
|
|
to achieve performant responses. By default, those caches are stored in a temporary filesystem folder, and are not
|
|
|
|
shared between multiple server instances. Alternative cache backends such as Redis can be
|
2021-06-02 00:59:42 +02:00
|
|
|
[configured](/developer_guides/performance/caching/).
|
2020-11-25 05:05:33 +01:00
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
While cache objects can expire, when using filesystem caching the files are not actively pruned. For long-lived server
|
|
|
|
instances, this can become a capacity issue over time - see
|
2020-11-25 05:05:33 +01:00
|
|
|
[workaround](https://github.com/silverstripe/silverstripe-framework/issues/6678).
|
|
|
|
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
### Error pages
|
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
The default installation
|
|
|
|
includes [silverstripe/errorpage](https://addons.silverstripe.org/add-ons/silverstripe/errorpage), which generates
|
|
|
|
static error pages that bypass PHP execution when those pages are published in the CMS. Once published, the static files
|
|
|
|
are located in `public/assets/error-404.html` and `public/assets/error-500.html`. The default `public/.htaccess` file is
|
|
|
|
configured to have Apache serve those pages based on their HTTP status code.
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
|
|
|
### Other webservers (Nginx, IIS, Lighttpd)
|
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
Serving through webservers other than Apache requires more manual configuration, since the defaults configured
|
|
|
|
through `.htaccess` don't apply. Please apply the considerations above to your webserver to ensure a secure hosting
|
|
|
|
environment. In particular, configure protected assets correctly to avoid exposing draft or protected files uploaded
|
|
|
|
through the CMS.
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
There are various community supported installation instructions for different environments. Nginx is a popular choice,
|
|
|
|
see [Nginx webserver configuration](https://forum.silverstripe.org/t/nginx-webserver-configuration/2246).
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
Silverstripe CMS is known to work with Microsoft IIS, and generates `web.config` files by default
|
2021-06-22 10:41:48 +02:00
|
|
|
(
|
|
|
|
see [Microsoft IIS and SQL Server configuration](https://forum.silverstripe.org/t/microsoft-iis-webserver-and-sql-server-support/2245))
|
|
|
|
.
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
Additionally, there are community supported guides for installing Silverstripe CMS on various environments:
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
* [Hosting via Bitnami](https://bitnami.com/stack/silverstripe/virtual-machine): In the cloud or as a locally hosted
|
|
|
|
virtual machine
|
|
|
|
* [Vagrant/Virtualbox with CentOS](https://forum.silverstripe.org/t/installing-via-vagrant-virtualbox-with-centos/2248)
|
|
|
|
* [macOS with Homebrew](https://forum.silverstripe.org/t/installing-on-osx-with-homebrew/2247)
|
|
|
|
* [macOS with MAMP](https://forum.silverstripe.org/t/installing-on-osx-with-mamp/2249)
|
|
|
|
* [Windows with WAMP](https://forum.silverstripe.org/t/installing-on-windows-via-wamp/2250)
|
|
|
|
* [Vagrant with silverstripe-australia/vagrant-environment](https://github.com/silverstripe-australia/vagrant-environment)
|
|
|
|
* [Vagrant with BetterBrief/vagrant-skeleton](https://github.com/BetterBrief/vagrant-skeleton)
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
## PHP Requirements for older Silverstripe CMS releases {#php-support}
|
2019-04-30 03:07:16 +02:00
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
Silverstripe CMS's PHP support has changed over time and if you are looking to upgrade PHP on your Silverstripe CMS site, this
|
2021-06-22 10:41:48 +02:00
|
|
|
table may be of use:
|
2019-04-30 03:07:16 +02:00
|
|
|
|
2021-06-30 11:48:52 +02:00
|
|
|
| Silverstripe CMS Version | PHP Version | More information |
|
2019-04-30 03:07:16 +02:00
|
|
|
| -------------------- | ----------- | ---------------- |
|
|
|
|
| 3.0 - 3.5 | 5.3 - 5.6 | [requirements docs](https://docs.silverstripe.org/en/3.4/getting_started/server_requirements/)
|
|
|
|
| 3.6 | 5.3 - 7.1 | |
|
|
|
|
| 3.7 | 5.3 - 7.3 | [changelog](https://docs.silverstripe.org/en/3/changelogs/3.7.0/) |
|
|
|
|
| 4.0 - 4.4 | 5.6+ | |
|
2021-02-17 00:40:27 +01:00
|
|
|
| 4.5+ | 7.1+ | [blog post](https://www.silverstripe.org/blog/our-plan-for-ending-php-5-6-support-in-silverstripe-4/) |
|
2019-04-30 03:07:16 +02:00
|
|
|
|
DOCS Rewrite server requirements
* Remove overly specific PHP RNG instructions (that's just built into PHP7 through random_bytes now, which will throw if no suitable RNG is available)
* Remove PHP 5 RNG requirements, since we don't support that PHP release any mre
* Remove verbose explanation of PHP 5.6 support
* Remove conflicting instructions for PHP memory limits
* Remove version numbers from supporetd databases other than MySQL, it's up to the community modules to define that
* Remove Oracle support (code is nine years old!)
* Make "community supported" status clearer on databases, people can draw their own conclusions as open source users on Github
* Remove IIS version number, I think we should just stick to "needs web.config" and not give the impression that this is actively tested
* Remove mention of OSes for web servers, that's kind of irrelevant in today's hosting world (containers, PaaS, etc)
* Shorten install instructions in favour of a "quickstart" and point to lessons instead
* Remove mention of archive download option, we really shouldn't promote this - composer is the de-facto standard
* Add generic descriptions of the hosting environment considerations without going too much into specifics
* Remove Apache version number, we don't test on different versions, and really mostly rely on mod_rewrite working properly. Laravel does the same (doesn't claim specific Apache version support)
2019-09-03 06:07:17 +02:00
|
|
|
## CMS browser requirements
|
2011-02-07 07:48:44 +01:00
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
Silverstripe CMS supports the following web browsers:
|
|
|
|
|
|
|
|
We aim to provide satisfactory experiences in Apple Safari. Silverstripe CMS works well across Windows, Linux, and Mac
|
|
|
|
operating systems.
|
2011-02-07 07:48:44 +01:00
|
|
|
|
2014-09-21 02:07:58 +02:00
|
|
|
## End user requirements
|
2011-02-07 07:48:44 +01:00
|
|
|
|
2021-06-22 10:41:48 +02:00
|
|
|
Silverstripe CMS is designed to make excellent, standards-compliant websites that are compatible with a wide range of
|
2014-09-21 02:07:58 +02:00
|
|
|
industry standard browsers and operating systems. A competent developer is able to produce websites that meet W3C
|
2015-01-13 20:59:55 +01:00
|
|
|
guidelines for HTML, CSS, JavaScript, and accessibility, in addition to meeting specific guide lines, such as
|
2014-09-21 02:07:58 +02:00
|
|
|
e-government requirements.
|