Skip to content

Latest commit

 

History

History
48 lines (35 loc) · 3.93 KB

README.md

File metadata and controls

48 lines (35 loc) · 3.93 KB

Gatsby Wordpress multi-app for Platform.sh

Deploy on Platform.sh

This template builds a two application project to deploy the Headless CMS pattern using Gatsby as its frontend and Wordpress for its backend. The gatsby-source-wordpress source plugin is used to pull data from Wordpress during the post_deploy hook into the Gatsby Data Layer and build the frontend site. Gatsby utilizes the Platform.sh Configuration Reader library for Node.js to define the backend data source in its configuration. It is intended for you to use as a starting point and modify for your own needs.

Note that after you have completed the Wordpress installation, the project will require a redeploy to build and deploy Gatsby for the first time. See the included README's post-install section for details.

Gatsby is a free and open source framework based on React that helps developers build statically-generated websites and apps, and WordPress is a blogging and lightweight CMS written in PHP.

Features

  • Node.js 14
  • PHP 7.4
  • MariaDB 10.4
  • Automatic TLS certificates
  • npm-based build for Gatsby
  • Composer-based build for Wordpress
  • Multi-app configuration
  • Delayed SSG build (post deploy hook)

Post-install

  1. When you initially deploy the template, you will receive a 403 error on the base route. There is not yet any content to build the Gatsby site, because Wordpress has not yet been fully installed. Visit the backend.<generated url> subdomain, and run through the Wordpress installer as normal. You will not be asked for database credentials as those are already provided.
  2. Once you have completed the Wordpress install, redeploy the environment with platform redeploy -p <PROJECT ID> -e master.

Customizations

The following files and additions make the framework work. If using this project as a reference for your own existing project, replicate the changes below to your project.

  • The .platform.app.yaml, .platform/services.yaml, and .platform/routes.yaml files have been added. These provide Platform.sh-specific configuration and are present in all projects on Platform.sh. You may customize them as you see fit.
  • Additional Platform.sh configuration reader modules for both PHP and Node.js have been added. They provide convenience wrappers for accessing the Platform.sh environment variables.
  • gatsby-config.js has been modified to read the Wordpress backend url and assign it to the baseUrl attribute for the gatsby-source-wordpress plugin. Since routes are not available during the build hook, and since we want this value to be generated and unique on each environment, gatsby build runs and pulls in content from the Wordpress app during the post_deploy hook on the mounted public directory. gatbsby-source-wordpress can have additional parameters set to modify your configuration, so consult the documentation.

References