ffflabel / project
WordPress boilerplate with modern development tools, easier configuration, and an improved folder structure
Installs: 17
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:project
pkg:composer/ffflabel/project
Requires
- php: >=8.1
- composer/installers: ^2.2
- ffflabel/ffflabel: ^v0.1.0
- ffflabel/services: ^0.1.6
- oscarotero/env: ^2.1
- roots/bedrock-autoloader: ^1.0
- roots/bedrock-disallow-indexing: ^2.0
- roots/wordpress: 6.8.1
- roots/wp-config: 1.0.0
- vlucas/phpdotenv: ^5.5
- wpengine/advanced-custom-fields-pro: ^6.4.0.1
Requires (Dev)
- roave/security-advisories: dev-master@dev
- squizlabs/php_codesniffer: ^3.0.2
README
based on Bedrock
Features
- Better folder structure
- Dependency management with Composer
- Easy WordPress configuration with environment specific files
- Environment variables with Dotenv
- Autoloader for mu-plugins (use regular plugins as mu-plugins)
- Enhanced security (separated web root and secure passwords with wp-password-bcrypt)
Use Trellis for additional features:
- Easy development environments with Vagrant
- Easy server provisioning with Ansible (Ubuntu 16.04, PHP 7.1, MariaDB)
- One-command deploys
See a complete working example in the roots-example-project.com repo.
Requirements
- PHP >= 7.0
- Composer - Install
Installation
- Create a project folder your-project-folder-name, enter to it and create a new project for your project:
composer create-project ffflabel/project .
- Update environment variables in .envfile:
- DB_NAME- Database name
- DB_USER- Database user
- DB_PASSWORD- Database password
- DB_HOST- Database host
- WP_ENV- Set to environment (- development,- staging,- production)
- WP_HOME- Full URL to WordPress home (http://example.com)
- WP_SITEURL- Full URL to WordPress including subdirectory (http://example.com/wp)
- AUTH_KEY,- SECURE_AUTH_KEY,- LOGGED_IN_KEY,- NONCE_KEY,- AUTH_SALT,- SECURE_AUTH_SALT,- LOGGED_IN_SALT,- NONCE_SALT
If you want to automatically generate the security keys (assuming you have wp-cli installed locally) you can use the very handy wp-cli-dotenv-command:
  wp package install aaemnnosttv/wp-cli-dotenv-command
  wp dotenv salts regenerate
Or, you can cut and paste from the Roots WordPress Salt Generator.
- 
Add theme(s) in web/app/themesas you would for a normal WordPress site.
- 
Set your site vhost document root to /path/to/site/web/(/path/to/site/current/web/if using deploys)
- 
Access WP admin at http://example.com/wp/wp-admin
Deploys
- 
Go to the your-project-folder-name\.github\workflows\deploy-dev.ymland update variables:- REPO- git ssh repository
- ROOT_DIR- path to the project on the server
 
- 
Go to project Git repository Settings -> Secrets and variables -> Actionsand add Repository secrets:- SSH_DEV_HOST- ssh host - IP of the host server
- SSH_DEV_USERNAME- ssh user name to connect to the server
- SSH_DEV_PORT- ssh port
- SSH_DEV_KEY- openssh private key (puttyprivatekey_openssh)
 
There are two methods to deploy Bedrock sites out of the box:
Any other deployment method can be used as well with one requirement:
composer install must be run as part of the deploy process.
Documentation
Bedrock documentation is available at https://roots.io/bedrock/docs/.
Contributing
Contributions are welcome from everyone. We have contributing guidelines to help you get started.
Community
Keep track of development and community news.
- Participate on the Roots Discourse
- Follow @rootswp on Twitter
- Read and subscribe to the Roots Blog
- Subscribe to the Roots Newsletter
- Listen to the Roots Radio podcast