At NYC Opportunity, we are utilizing Docker to help us more easily and consistently manage our products, specifically, ACCESS NYC, Growing Up NYC, Working NYC, and more.
This repository contains a Docker image that will install the latest version of WordPress to be served by nginx. It is the Boilerplate for running and maintaining all of our WordPress products and contains scripts for deployment, syncing, configuration, and notifications with all product environments hosted on WP Engine.
- Docker Images
- Usage
- Configuration
- WP-CLI
- Composer
- Git Hooks
- Database
- Bin Scripts
- WordPress Filesystem Guide
- Security
Below is simplified set of steps for getting started. Look at the notes for special details.
$1 Download a zip of this repository, or clone it to a new project directory.
$ git clone https://github.com/CityOfNewYork/nyco-wp-boilerplate.git your-project-name && cd your-project-name
$2 Run the bin/boilerplate
command, select [2] Update your Wordpress Project
then [1] Yes
in the prompt to proceed. This will hide the .git
directory but save it for updating later (see Dual Project Development for more details).
$3 Move your files into the /wp starter directory. Optionally, clone or place a WordPress site in the current directory (if doing this see the /wp directory note below).
$4 Optional but important if you have a database dump to work with. Place any .sql file in the /data directory. See notes below for details on seeding the database.
$5 Run
$ docker-compose build
to build your images. Then run
$ docker-compose up
to start them. After a few moments, you will be able to open up localhost:8080
to visit your site.
-
Generate your Salts then copy and paste them in their corresponding fields in the wp-config.php file.
-
Mounting files: The Docker image will pull the latest version of WordPress and mount any files to the WordPress container not included in the /wp when running
docker-compose build
so you could have only the /wp-content directory in your project if you always want to work with the latest version of WordPress. The docker-compose.yml file includes commented out lines that will also achieve the same thing for mounting certain files to the WordPress container. -
Bootstrapping: In the /wp directory provided you'll find sample composer.json, phpcs.xml, .gitignore, wp-config.php files to help bootstrap a new WordPress project. You may delete, replace, or modify any boilerplate files in the /wp directory to meet your project's needs.
-
/wp directory: You can clone a WordPress site directly into the boilerplate root and delete the /wp directory. You will need to update the /config/bin.cfg
WP
setting and the instances of ./wp in the docker-compose.yml file. -
Database Seeding: The name for the .sql dump does not matter as the mysql image will look for any .sql file in the /data directory and execute it on the database defined in the docker-compose.yml file. You will need to 'Find and Replace' the site url value in the .sql file to match your expected host (the default expected host is
http://localhost:8080
). This can be done manually before import in any text editing program or after using the WP-CLI. If there is no SQL file present when the image is created it will create an empty database which you can import data into using the WP-CLI, Sequel Pro, or phpMyAdmin. -
Database Reset: To reset the database you can remove the service container
docker-compose rm mysql
, then, remove the volumedocker volume rm {{ volume name }}
. To look up the volume name usedocker volume ls
. -
Proxy: If you are working behind a proxy, uncomment associated lines in the main wordpress-fpm/Dockerfile and enter your proxy in the appropriate areas.
-
WP Engine Sites: If copying an existing WP Engine WordPress site from a backup point, it will have it's own /wp-config.php file and some "drop in" plugins in the /wp-content directory and "must use" wp-content/must-use directory included.
-
Composer: If running
composer install
fails and you have a composer.phar file in your root directory, runphp composer.phar i
. If you do not have Composer installed, see Get Composer. -
Optional Images: To use optional images, uncomment them in the docker-compose.yml file.
-
Docker: You can use the
-d
flag (docker-compose up -d
) to run in detached mode. -
Docker: To create an interactive shell with the WordPress container, you can run
docker-compose exec wordpress sh
.
The Bin Scripts use a configuration file in /config/bin.cfg for interacting with the local WordPress site and remote services.
Config Blocks | Description |
---|---|
Colors | These are the colors used for Slack and other message highlighting. They currently are set to match the NYC Opportunity brand. Used by the push command. |
Domain | The production domain and CDN for the WP Engine installation go here. Used by the sourcemaps command. |
WordPress | WordPress directory configuration including the WP path, theme directory name, minified .js directory path, and matching pattern for minified .js files. Used by sourcemaps and other commands. |
GitHub | GITHUB_URL The url for the product repository. Used by the push command. |
Projects | All of the product environment remote names should be added here. Used by the menu command. |
Rollbar | The access token for the a Rollbar account and local Rollbar username go here. Used by the push and sourcemaps commands. |
Slack | Deployment and synchronization scripts post to Slack to alert the team on various tasks. Used by various commands. |
S3 Uploads | The name of an S3 bucket where uploads may be stored. Only needed if using the uploads command. |
WP Engine API | Commands that use the WP Engine API require API credentials to be generated in your user profile and set to the variables in this block. |
config/config.yml - This file is used in conjunction with the NYCO WP Config WordPress plugin for environment configuration. See that repository for details on integrating with WordPress. If a site uses that plugin it needs to be present in the wp-content/mu-plugins/config/ directory.
WP-CLI is a command line interface for WordPress. It is set up to work with your WordPress installation through this Boilerplate. Read more about WP-CLI at it's website. To use WP-CLI commands, you need to run...
$ docker-compose exec wordpress /bin/wp {{ command }}
... in place of wp {{ command }}
to run one off commands on the container. Optionally, create an alias...
alias dcwp="docker-compose exec wordpress /bin/wp"
... so you don't have to type out docker-compose exec
. Optionally, shell into the container to run commands directly in the container.
$ docker-compose exec wordpress sh
Then commands can be run using the normal CLI;
$ wp {{ command }}
There a lot of things you can do with the CLI such as import a database...
$ wp db import database.sql
... replace strings in a the database...
$ wp search-replace 'https://production.com' 'http://localhost:8080'
... and add a local administrative user:
$ wp user create username username@domain.com --role=administrator --user_pass=wp
Refer to the documentation for more commands.
This boilerplate comes with a root composer package that you may use to manage php packages and plugins. To use composer, install it on your machine and run...
$ composer update
... to install the vendor package (or php composer.phar i
depending on your setup). You may also want to add /vendor to your WordPress .gitignore file, if it hasn't been already.
The root Composer package requires the following packages and plugins. Plugins for enhancing WordPress security are denoted by *
. These enhance some of the security measures provided by WordPress and WP Engine, however, using plugins alone is not a comprehensive solution for securing WordPress websites. Refer to the security section for more details.
Composer Packages | Type | Description |
---|---|---|
Duplicate Post | Plugin | Enables the duplication of posts and custom post types. |
NYCO WP Config | Must Use Plugin | Determines php constants set on runtime based on specific environments. The plugin will pull from an object of variables set in the mu-plugins/config/config.yml file and set the appropriate group to constants that can be accessed by site functions, templates, and plugins. It will also autoload an environment-specific php file from the mu-plugins/config/. To pull in the appropriate settings, set the WP_ENV constant in the wp-config.php file of each environment. For example; define('WP_ENV', 'development'); will load the default secrets at the root level of the config.yml file and the development: block as well as autoload the development.php file. Default constants are loaded in the root of the config.yml file and the default.php configuration file is always loaded (the Composer autoloader is required here). |
NYCO WP Assets | Must Use Plugin | Provides helper functions for enqueuing JavaScript and stylesheet assets and integrations defined in the mu-plugins/config/integrations.yml file. |
S3 Uploads | Plugin | A lightweight plugin for storing uploads on Amazon S3 instead of the local filesystem. Note, this requires an AWS S3 bucket. |
Timber | Vendor | Integrates the Twig Template Engine and more for easier theme development. |
* Aryo Activity Log | Plugin | * Tracks and displays user activity in a dedicated log page. |
* Google Authenticator | Plugin | * Enables 2-Factor Authentication for WordPress Users. |
* Limit Login Attempts Reloaded | Plugin | * Limits the number of login attempts a user can have if they use the wrong password or authenticator token. |
* LoggedIn | Plugin | * Allows the setting for number of active logins a user can have. |
* WP Security Questions | Plugin | * Enables security question feature on registration, login, and forgot password screens. |
* WPS Hide Login | Plugin | * Lets site administrators customize the url of the WordPress admin login screen. |
* WPScan | Plugin | * Identifies security issues of WordPress plugins installed against the WPScan Vulnerability Database. |
* Defender | Plugin | * Provides a selection of security measures such as hiding the default /wp-login.php path for logging into the cms, enabling two-factor authentication, setting security headers, and more. This plugin provides a good all-in-one solution and UI for modifying security features for site administrators, however, most of the features it provides can be hard-coded with plugins described above and Must Use Plugins. |
Require Dev | The following packages are included for local development and purposes in the require-dev block. |
|
Code Sniffer | Vendor | Code linting for PHP. |
Whoops | Vendor | Much nicer error log for PHP. |
Query Monitor | Plugin | Creates a developer tools panel for WordPress Admins. |
Redis Cache | Plugin | A persistent object cache powered by Redis. Using Object Caching is optional but it is recommended for site speed. |
WordPress Auto Login | Plugin | Creates a quick login link for local development. Important, this is ignored by the site's .gitignore so it doesn't get added to a live environment. |
WP Crontrol | Plugin | Lets you view and control whatβs happening in the WP-Cron system. |
Composer will install packages in one of three directory locations in the site depending on the type of package it is.
- /vendor; by default, Composer will install packages here. These may include helper libraries or SDKs used for php programming.
Packages have the Composer Library Installer included as a dependency are able to reroute their installation to directories alternative to the ./vendor directory. This is to support different php based application frameworks. For WordPress, there are four possible directories (see the Composer Library Installer documentation for details), however, for the purposes of this site most packages are installed the two following directories:
- /wp-content/plugins; packages that are WordPress plugins are installed in the WordPress plugin directory.
- /wp-content/mu-plugins; packages that are Must Use WordPress plugins are installed in the Must Use plugin directory.
Normally, /vendor packages wouldn't be checked in to version control. They are installed on the server level in each environment. However, this site is deployed to WP Engine which does not support Composer so the packages need to be checked in and deployed to the site using git. By default /vendor packages are not tracked by the repository. If a composer package is required by production it needs to be included in the repository so it can be deployed to WP Engine. The .gitignore manually includes tracked repositories using the !
prefix. This does not apply to WordPress plugins.
# Composer #
############
/vendor/* # Exclude all /vendor packages
!/vendor/autoload.php # Include the autoloader
!/vendor/altorouter # example package inclusion
...
The autoloader is what includes PHP package files in the application. It works by requiring package php files when the classnames they include are invoked. The autoloader needs to be required in every application before Composer packages can be run. The site loads requires the autoloader in /wp-content/mu-plugins/config/default.php. This only applies to packages in the /vendor directory. WordPress Plugins and Must Use Plugins are not autoloaded.
<?php
require_once ABSPATH . '/vendor/autoload.php';
Different types of autoloaders can be generated. The composer.json includes scripts that will generate a "development" autoloader that requires packages defined in the require
and require-dev
json blocks (including whoops).
$ composer run development
The "production" autoloader will only require packages in the require
json block. Once you are done developing and before deployment generate the production autoloader which will remove development dependencies in the autoloader.
$ composer run production
The command to install new packages is composer require
. See the Composer docs for more details on the CLI. Packages can be installed from Packagist or WordPress Packagist. To require a package run:
$ composer require {{ vendor }}/{{ package }}:{{ version constraint }}
For example:
$ composer require timber/timber:^1.18
... will require the Timber package and install the latest minor version, greater than 1.18
and less than 2.0.0
. The caret designates the version range. Version constraints can be read about in more detail in the Composer documentation.
The command to update packages is composer update
. Running it will install packages based on their version constraint in the composer.json file. Individual packages can be updated by specifying the package name.
$ composer update {{ vendor }}/{{ package }}
For example:
$ composer update timber/timber
The Composer package includes scripts that can be run via the command:
$ composer run {{ script }}
Script | Description |
---|---|
development |
Rebuilds the autoloader including development dependencies. |
production |
Rebuilds the autoloader omitting development dependencies. |
predeploy |
Rebuilds the autoloader using the production script then runs PHP Code Sniffer using the lint script (described below). |
lint |
Runs PHP Code Sniffer which will display violations of the standard defined in the phpcs.xml file. |
fix |
Runs PHP Code Sniffer in fix mode which will attempt to fix violations automatically. It is not necessarily recommended to run this on large scripts because if it fails it will leave a script partially formatted and malformed. |
version |
Regenerates the composer.lock file and rebuilds the autoloader for production. |
deps |
This is a shorthand for composer show --tree for illustrating package dependencies. |
This repository includes a Git Hook directory. To utilize git hooks they need to be configured in the repository by running the following command:
$ git config core.hooksPath .githooks
Below is a description of the available Git Hooks.
Hook | Description |
---|---|
pre-push |
Runs the Composer predeploy script. See composer scripts. |
This repository includes a GitHub Dependabot configuration to watch production Composer and NPM dependencies for secure updates.
You can look at the database with tools like Sequel Pro. The connection host will be 127.0.0.1
and the db username/password/name will be wp
or whatever you set in your configuration if you changed the config file.
Script source can be found in the /bin directory. Be sure to fill out the configuration file before using these scripts.
$ bin/{{ script }} {{ args (if any) }}
Create an alias command for running a Boilerplate project bin script from any directory.
$ bp {{ script }} {{ args (if any) }}
Examples:
$ bp ssh {{ instance }}
or
$ bp backup {{ instance }}
To set it up.
- Change "bp" in the bin/bp file to your project's shorthand (so it doesn't conflict with other projects). The alias name
bp
, the alias function reference_bp
, and the function name_bp
. - Run
. bin/bp
to add the alias and try it out. - Add
. ~/path/to/project/bin/bp
to your bash profile to have it added on terminal startup.
Then you can use your alias for your project in place of bin/
for each script below.
- Boilerplate
boilerplate
- Menu
menu
- Backup
backup
- Push
push
- Pull
pull
- Purge
purge
- SSH
ssh
- rsync
rsync
- Uploads
uploads
- Config
config
- Version
version
- Publish
publish
- Sourcemaps
sourcemaps
$ bin/boilerplate
Switch between development on your WordPress site or this boilerplate project. This will allow you to fetch the latest changes to the boilerplate or contribute! To run this executable, enter the following at the root of this project:
Based on your selection, the git tracking for the project that you were not working on will be placed in the temp/bp/
for the boilerplate or temp/wp/
for WordPress.
$ bin/menu
With bin/menu
, you will be given the option to do the following actions:
# |
Action | Description |
---|---|---|
[0] |
Deploy | Deploy your local branch to a remote environment; calls bin/push |
[1] |
Sync | Sync your uploads to/from a remote; calls bin/uploads or bin/config based on selection |
[2] |
Update | Upgrade the entire WordPress core to a specified version detailed in the root composer.json |
[3] |
Lint | Runs PHP linting using the native syntax checker php -l {{ file }} . The wp/composer.json also uses PHP Code Sniffer with a custom XML specification. See Composer scripts for more details. |
Make your selections based on the values in the square brackets.
$ bin/backup {{ remote }}
Use the WP Engine API to request a backup point for a remote WP Engine installation. The command accepts the installation name as the only argument.
$ bin/backup mysitetest
This command uses the jq package to parse the response from the API. It can be installed via Homebrew using the command brew install jq
. WP Engine API credentials must also be set in the config for this command to work.
$ bin/push {{ remote }} -b {{ branch (optional) }} -m {{ message (optional) }} -f {{ true (optional) }}
Push a local Git branch to a remote origin. Most instances of running the command will look like the following:
$ bin/push mysitetest
This will push changes from the env/mysitetest
branch to the remote remote origin mysitetest
. The {{ remote }}
argument should be the same as the git remote repository for a WP Engine installation. Use ...
$ git remote add {{ remote }} git@git.wpengine.com:production/{{ remote }}.git
... when adding remotes before using the command. The WP Engine Git Push service and adding remotes is also described in further detail in WP Engine's Git Push tutorial.
There are a few integrations that the command will trigger if they are configured.
- Post a message to a Slack channel that a deployment is being made and when it is completed.
- Push a deployment for tracking in Rollbar.
Setting the -f
flag to true
will perform a forced git push.
$ bin/pull {{ remote }}
Pulls a remote instance's master branch to the current local branch.
$ bin/purge {{ remote }}
Use the WP Engine API to purge the object cache of a remote WP Engine installation. The command accepts the installation name as the only argument.
$ bin/purge mysitetest
This command uses the jq package to parse the response from the API. It can be installed via Homebrew using the command brew install jq
. WP Engine API credentials must also be set in the config for this command to work.
$ bin/ssh {{ remote }}
Use WP Engine's SSH Gateway to remotely navigate an installation's filesystem.
$ bin/rsync {{ remote }} {{ file }} {{ -u or -d }}
rsync
remote files from a WP Engine installation to your local and vise versa. The -u
flag will sync local to remote (upload) and -d
will sync remote to local (download).
$ bin/uploads {{ -u or -d }}
If using a plugin such as S3-Uploads to offload your media library to a static S3 bucket, you can use the S3 Uploads command to sync uploads (up or down) to a specified bucket. The script assumes you are using a single bucket for all of your installations.
The -u
flag will sync local to remote (upload) and -d
will sync remote to local (download). The uploads
script uses the AWS CLI which must be installed on your computer. Additionally, you may need to configure authenticating with a session token if your AWS account requires users to use MFA. There are several scripts to help with this.
$ bin/config {{ remote }} {{ -u or -d }}
rsync
the local config/config.yml to a remote environment's wp-content/mu-plugins/config directory.
The -u
flag will sync local to remote (upload) and -d
will sync remote to local (download).
$ bin/version {{ semantic version number }}
Version the repository with the latest release number. This will update the root composer.json then run the version
Composer script, which is set by default to regenerate the composer.lock file and regenerate the autoloader for production.
It will also update the theme's style.css, the theme's package.json, and regenerate package-lock.json file. Then, it will run an NPM Script named "version" that should be defined in the theme's package.json file. This script can run any any process that requires an update to the front-end styles or scripts dependent on the version of the package.json.
Finally, it will commit the file changes and tag the repository.
$ bin/publish
Publishing will push committed changes or publish the current branch to the origin repository as well as publish all local tags that do not exist on origin. This can be used to publish newly created versions after the versioning script.
$ bin/sourcemaps {{ remote }}
We use Rollbar for error monitoring. After every new script is deployed we need to supply new sourcemaps to Rollbar to identify the source of errors. This script will read all of the files in the theme's assets/js folder and will attempt to upload sourcemaps for all files with the extension .js. The script files need to match the pattern {{ script }}.{{ hash }}.js, ex; main.485af636.js. It will assume there is a sourcemap with the same name and extension .map, ex; main.485af636.js.map. The theme and paths to minified scripts can be modified in the configuration.
If the WP Engine install is using the CDN feature, that will need to be set in the configuration, ex; CDN_{{ REMOTE }}
or CDN_ACCESSNYC
. If there is no CDN, it will assume that the script is hosted on the default instance on WP Engine; https://{{ remote }}.wpengine.com
or https://accessnycstage.wpengine.com
.
Below is a recommended filesystem for NYCO WordPress Boilerplate sites. Directory and file names that are not WordPress core files may vary per project.
The root of the WordPress site is reserved for repository/core files, composer.json, and some site/developer configurations. It should not contain static assets such as favicons, xml sitemaps, or robots.txt files (of which can be configured by the theme and plugins).
- WordPress Core files
- WordPress Config
- Git and GitHub configuration
- Composer Root
- Composer Scripts configuration
- Readme, security, license and other policies
An important note about the .htaccess file which is not included here. This should only include the default rewrite module for permalinks. WP Engine does not support the .htaccess file as of PHP 7.4. Custom redirects and hiding files must be done on the server level.
β π .githooks - Hooks to run when committing, pushing, etc. This directory needs to be configured in the repo configuration by running; git config core.hooksPath .githooks β π pre-push - Runs the Composer predeploy script before pushing to the remote repository. β π .github - GitHub configurations. β π dependabot.yml - Dependabot configuration. β π vendor - Composer packages will be installed here. β π wp-admin - WordPress Core directory. β π wp-content - Must use plugins, themes, uploads, etc. β π wp-includes - WordPress Core directory. β π .gitignore - Git file ignores and includes. β π composer.json - Root composer package containing required packages, plugins, and Composer scripts. See composer.json schema docs and Composer guide. β π composer.lock - Composer lock package that defines the required versions. β π phpcs.xml - NYCO PHP Code Sniffer configuration. PSR2 with two spaces, braces on same line. β π README.md - Site readme file. β π SECURITY.md - Site security policy. β π LICENSE - Site open source license. β π wp-config.php - Database, salts, debug settings. Note, this should not be checked into a project's repository. The π wp-config.php file in the local project will differ from the one in a remote environment. β π ...
- π wp-content β π mu-plugins β π ... β π ... β π ... β π ...
Must Use Plugins can be used to handle most of the custom configuration for the WordPress site including registering custom post types, registering WordPress REST API routes, configuring plugin settings, and other functionality for major features of the site. Most WordPress code bases tend to keep these in the theme which is better suited for styling the front-end and passing context to view templates.
- Custom Post Type Registration
- WordPress REST API Route Registration
- Constant Definition (NYCO WP Config or other). Note, some constants need to be defined in the root π wp-config.php file.
- Plugin Configuration
- Additional Logic and Custom Functionality
This repository includes some Must Use Plugins to provide support for security concerns (denoted by *
) and plugin/site configuration. They can be customized for any installation.
Plugin | Description |
---|---|
@config | Instantiates NYCO WP Config. The @ symbol in the file name ensures this plugin is instantiated before everything else as it contains constant settings that may be relevant to other plugins. |
Add meta description to head | Adds the description defined in the WordPress Admin settings to the description meta tag in the head for the homepage only. |
Clean up head | Remove unnecessary scripts, styles, and tags from the default WordPress head tag. |
Robots.txt | Modifies the default output of WordPress' robots.txt based on the WordPress Search Engine Visibility Settings (Settings > Reading). |
Timber | Instantiates Timber for a more pleasant theme development experience. |
Upload Mimes | Adds the SVG mime type to enable support for SVG files in the media uploader. |
WP Assets | Instantiates NYCO WP Assets. |
* Auto update options | * Disables ping-back flag, pings, comments, closes comments for old posts, notifies if there are new comments, and disables user registration. |
* Close attachment comments and pings | * Disable future comments and ping status (spam) for attachments as there is no way to close comments in admin settings. For previously uploaded attachments the wp cli can be used to close them (examples are included in the source of this plugin). |
* Configure core sitemaps | * Configuration for the WordPress sitemaps feature. Filters out users, taxonomies, and other post types that do not have page views. Note, prior to WordPress 5.5 this was not available to WordPress natively. |
* Disable XML-RPC | * Disable XML-RPC methods that require authentication. |
* Nonce Life | * Changing the default WordPress nonce lifetime from 1 day to 30 minutes. |
* REST Endpoints | * Explicitly disables WordPress REST API user endpoints. |
* WP Headers | * This plugin enables sending security headers to the client. The headers are configured by defining php constants described below. |
Configuration for the WP Headers Must Use Plugin included in this repository.
Constant | Type | Default Value | Description |
---|---|---|---|
WP_HEADERS_DNS_PREFETCH_CONTROL |
string | undefined |
Set to 'on' for X-DNS-Prefetch-Control . |
WP_HEADERS_SAMEORIGIN |
boolean | undefined |
true sets X-Frame-Options to SAMEORIGIN . |
WP_HEADERS_NOSNIFF |
boolean | undefined |
true sets X-Content-Type-Options to nosniff . |
CSP Header Policy Constants | Content Security Policies. Each of the constants below build up into the single custom content security policy. | ||
WP_HEADERS_CSP_DEFAULT |
string | 'self' |
Default directive for unspecified policies. |
WP_HEADERS_CSP_STYLE |
string | 'self' |
Stylesheet source directive. |
WP_HEADERS_CSP_FONT |
string | 'self' |
Font source directive. |
WP_HEADERS_CSP_IMG |
string | 'self' |
Image source directive. |
WP_HEADERS_CSP_SCRIPT |
string | 'self' 'nonce-{{ CSP_SCRIPT_NONCE }}' |
JavaScript source directive. A nonce will be created and a script_loader_tag filter will append the nonce to scripts that are registered and enqueued. The nonce will also be set to the constant CSP_SCRIPT_NONCE that can be added to permit inline <script> tags in templates. |
WP_HEADERS_CSP_CONNECT |
string | 'self' |
JavaScript URL loading directive. |
WP_HEADERS_CSP_FRAME |
string | 'none' |
iFrame source directive. |
WP_HEADERS_CSP_OBJECT |
string | 'none' |
Object, embed, and applet directive. |
WP_HEADERS_CSP_REPORTING |
string | undefined |
Sets the reporting directive to an endpoint for debugging the policy and violations. Sets both the report-to and report-uri for compatibility. Note, the endpoint that processes the response needs to be created. |
WP_HEADERS_CSP_SEND |
boolean | undefined |
Setting false will prevent the CSP header policy from being sent. |
- π wp-content β π themes β π theme β π ... β π ... β π ... β π ...
The theme for the site contains all of the php functions, templates, styling, and scripts relevant the front-end templates. This is the only WordPress theme that is compatible with the WordPress site.
- View Controllers
- View Templates
- View Assets and Source
- Gutenberg Blocks
- Shortcodes
- Template functions and tags
β π acf-json - Advanced Custom Fields JSON files for syncing custom fields between environments. β π assets - The source for image, style, and script files live in the π src directory and are compiled to the π assets directory. This is done with NPM Scripts in π package.json file and π node_scripts directory. β π blocks - Custom Gutenberg Block source. β π lib - Theme functions, filters, and other helpers that assist in rendering views (includes). β π node_modules - Node modules will be installed here if using NPM to manage dependencies. β π node_scripts - Custom node scripts required to manage assets. β π shortcodes - Theme shortcodes available to content administrators. β π timber-posts - Site and Post Type classes that extend Timber posts and provide processed data to views. β π Site.php - Timber site class extension to add properties to Timber/Site. β π Post.php - Timber post class extension. β π ... β π src - Asset source. β π scss - Sass source, if required. β π _main.scss - Main Sass entry-point. β π ar.scss - Arabic font variable setting. β π light.scss - Light color mode variable setting. β π dark.scss - Dark color mode variable setting. β π latin.scss - Latin font face variable setting. β π ltr.scss - Left-to-right variable setting. β π rtl.scss - Right-to-left variable setting. β π ko.scss - Korean font face variable setting. β π ur.scss - Urdu font face variable setting. β π zh-hant.scss - Chinese font face variable setting. β π ... β π js - JavaScript source. β π modules - Supporting ES modules. β π main.js - Main JavaScript entry-point. β π search.js - The Search view JavaScript (if required). β π single.js - The Single view JavaScript (if required). β π ... β π views - View templates are generally organized on a component level and by site feature, including Twig, Vue.js, JSX, and/or jst (pre-compiled js templates) files. β π components - Component pattern templates. β π elements - Element pattern templates. β π emails - Email view templates (if required). β π objects - Object pattern templates. β π partials - Misc. view template partials. β π base.twig - The base template, extended by view templates. β π search.twig - The search view template. β π singular.twig - The single view template. β π ... β π archive.php - Archive view controller. Context for the view is added here. β π footer.php - This may be required to prevent plugins from using the wp_footer() function to render output. β π functions.php - Main PHP entry point. Includes files from π blocks, π lib, and π shortcodes. β π header.php - This may be required to prevent plugins from using the wp_header() function to render output. β π index.php - Index view controller. Context for the view is added here. β π search.php - Search view controller. Context for the view is added here. β π singular.php - Single view controller. Context for the view is added here. β π .nvmrc - If a specific node version is required, this file can specify the version. More details can be found in the Node Version Manager docs. β π package.json - Contains required front-end packages for the theme. β π package-lock.json - Keep the package lock file along with the theme. β π manifest.json - A manifest.json file for progressive web applications. β π style.css - Theme meta data; name, version, author, etc. β π editor-style.css - Editor styles. Theme support needs to be added and the stylesheet must be instantiated. β π wp-admin-bar.css - WP Admin Bar styles (if any). This stylesheet needs to be registered and enqueued for admin views. β π ...
Refer to this free security whitepaper from WordPress.org to become more familiar with the security components and best practices of the WordPress Core software. Additionally, the Open Web Application Security Project (OWASP) provides guidelines for implementing security for WordPress sites that includes free and open source resources instead of commercial ones. Some of the practices mentioned are included in this boilerplate through plugins and documentation while others should be implemented on a case by case basis.
The Mayor's Office for Economic Opportunity (NYC Opportunity) is committed to sharing open source software that we use in our products. Feel free to ask questions and share feedback. Interested in contributing? See our open positions on buildwithnyc.github.io. Follow our team on Github (if you are part of the @cityofnewyork organization) or browse our work on Github.