Bedrock

MIT License Packagist Build Status Follow Roots

A modern WordPress stack
Built with ❤️

Official Website | Documentation | Change Log

## Supporting **Bedrock** is an open source project and completely free to use. However, the amount of effort needed to maintain and develop new features and products within the Roots ecosystem is not sustainable without proper financial backing. If you have the capability, please consider donating using the links below:
[![Donate via Patreon](https://img.shields.io/badge/donate-patreon-orange.svg?style=flat-square&logo=patreon")](https://www.patreon.com/rootsdev) [![Donate via PayPal](https://img.shields.io/badge/donate-paypal-blue.svg?style=flat-square&logo=paypal)](https://www.paypal.me/rootsdev)
## Overview Bedrock is a modern WordPress stack that helps you get started with the best development tools and project structure. Much of the philosophy behind Bedrock is inspired by the [Twelve-Factor App](http://12factor.net/) methodology including the [WordPress specific version](https://roots.io/twelve-factor-wordpress/). ## Features - Better folder structure - Dependency management with [Composer](https://getcomposer.org) - Easy WordPress configuration with environment specific files - Environment variables with [Dotenv](https://github.com/vlucas/phpdotenv) - Autoloader for mu-plugins (use regular plugins as mu-plugins) - Enhanced security (separated web root and secure passwords with [wp-password-bcrypt](https://github.com/roots/wp-password-bcrypt)) ## Requirements - PHP >= 7.1 - Composer - [Install](https://getcomposer.org/doc/00-intro.md#installation-linux-unix-osx) ## Installation 1. Create a new project: ```sh $ composer create-project roots/bedrock ``` 2. Update environment variables in the `.env` file. Wrap values that may contain non-alphanumeric characters with quotes, or they may be incorrectly parsed. - Database variables - `DB_NAME` - Database name - `DB_USER` - Database user - `DB_PASSWORD` - Database password - `DB_HOST` - Database host - Optionally, you can define `DATABASE_URL` for using a DSN instead of using the variables above (e.g. `mysql://user:password@127.0.0.1:3306/db_name`) - `WP_ENV` - Set to environment (`development`, `staging`, `production`) - `WP_HOME` - Full URL to WordPress home (https://example.com) - `WP_SITEURL` - Full URL to WordPress including subdirectory (https://example.com/wp) - `AUTH_KEY`, `SECURE_AUTH_KEY`, `LOGGED_IN_KEY`, `NONCE_KEY`, `AUTH_SALT`, `SECURE_AUTH_SALT`, `LOGGED_IN_SALT`, `NONCE_SALT` - Generate with [wp-cli-dotenv-command](https://github.com/aaemnnosttv/wp-cli-dotenv-command) - Generate with [our WordPress salts generator](https://roots.io/salts.html) 3. Add theme(s) in `web/app/themes/` as you would for a normal WordPress site 4. Set the document root on your webserver to Bedrock's `web` folder: `/path/to/site/web/` 5. Access WordPress admin at `https://example.com/wp/wp-admin/` ## Documentation Bedrock documentation is available at [https://roots.io/docs/bedrock/master/installation/](https://roots.io/docs/bedrock/master/installation/). ## Contributing Contributions are welcome from everyone. We have [contributing guidelines](https://github.com/roots/guidelines/blob/master/CONTRIBUTING.md) to help you get started. ## Bedrock sponsors Help support our open-source development efforts by [becoming a patron](https://www.patreon.com/rootsdev). Kinsta KM Digital ## Community Keep track of development and community news. - Participate on the [Roots Discourse](https://discourse.roots.io/) - Follow [@rootswp on Twitter](https://twitter.com/rootswp) - Read and subscribe to the [Roots Blog](https://roots.io/blog/) - Subscribe to the [Roots Newsletter](https://roots.io/subscribe/) - Listen to the [Roots Radio podcast](https://roots.io/podcast/)