Skip to content

Latest commit

 

History

History
117 lines (60 loc) · 9.02 KB

README.md

File metadata and controls

117 lines (60 loc) · 9.02 KB

The Avenue Concept Placeholder Site Development Theme

Local Directory Name

Every docker project should be in a uniquely named directory in your filesystem. Due to a quirk in docker, the name of the directory must be unique among directories with docker projects in them, or you'll get weird database crosstalk with the project whose directory has the same name. I recommend naming the directory for the project something like {{ project name }}-{{ website type }}.

Directory Name: the-avenue-concept-placeholder

Environment

Each project needs its own unique environment file, .env, which specifies some data that's unique to the project. This is used to set up the docker file and to provide authentication variables for the ./.deploy.sh script, which deploys your development to the specified remote server. When starting a project, you need to either obtain or set up this .env file. A incomplete template, .sample.env is included with this repository. It looks like this:

VOLUME_BASE_PATH=.

MYSQL_ROOT_PASSWORD=docker
MYSQL_DATABASE=wordpress
MYSQL_USER=docker
MYSQL_PASSWORD=docker

WORDPRESS_DB_HOST=database
WORDPRESS_DB_NAME=wordpress
WORDPRESS_DB_USER=docker
WORDPRESS_DB_PASSWORD=docker

DOCKER_WORDPRESS_CONTAINER= # add the name of your project + '_wordpress_1' here
DOCKER_DATABASE_CONTAINER= # add the name of your project + '_database_1' here

KINSTA_IP= #add the IP of your remote server, usually a Kinsta staging instance, here.
KINSTA_PORT= #add the port for SSH on the remote server here.
KINSTA_USER= #add the username of the SSH user here.

To complete the file, fill in the DOCKER_DATABASE_CONTAINER and DOCKER_WORDPRESS_CONTAINER. If you're planning to deploy this codebase at any point, fill in the details for your remote location, otherwise delete the variable names. When you're done, rename the file .env, and you should be set.

DevOps Assumptions

We're replacing our previous Webpack + BrowserSync development setup with a Gulp development setup for this project. Our concensus is that Webpack bundling is simply too slow, and that Webpack HMR is too convoluted to properly implement in a non-react setup, where styles and markup are not bundled as javascript modules.

Gulp has us returning to a (somewhat) simpler and (hopefully much) quicker environment based on browserify and livereload. The benefits are a simpler toolchain, a much quicker develop, save, check loop, and hot-reloading CSS into the page.

The webpack.config.js file has been replaced with a Gulp configuration file: gulpfile.js in the project root. This file defines four rules, described below:

  • gulp scss. Builds the front-end sass, compiling it down to CSS. from the scss/main.scss file, it builds a bundle, which is written to bundles/bundle.css. Does autoprefixing for a range of browsers automatically, so don't bother.

  • gulp admin-scss. Builds the admin sass, compiling it down to CSS. from the scss/admin.scss file, it builds a bundle, which is written to bundles/admin-bundle.css. Does autoprefixing for a range of browsers automatically, so don't bother.

  • gulp js. Builds the all javascript, compiling it from ES6, node-style javascript to a standard browser-compliant bundle.. from the scss/admin.scss file, it builds a bundle, which is written to bundles/admin-bundle.css.

  • gulp files. For environments that have a source directory different from the served directory, this rule copies files (optionally modifying or compressing them) to the served directory. In this project, the served directory is the source directory; this rule does nothing, and is not called.

  • gulp build. The default rule. Runs admin-scss, scss, and js in that order.

  • gulp watch. Starts a livereload server that watches for changes to php files or javascript, and runs the corresponding build rules, then reloads the page. For scss files, it builds the files, then injects the resulting bundle into the page without a reload.

  • gulp. The default rule. Runs admin-scss, scss, js, and watch, in that order.

The npm scripts have also been updated. You can run npm run build to invoke gulp build, if you like. Similarly npm run watch will invoke gulp watch. If you're switching to this build process from Webpack, delete your node_modules directory to get rid of any unneeded modules, and then run npm install. Thats it.

Plugin Dependencies: Wordpress

  • Object Sync for Salesforce. This plugin provides a low-level abstraction for connecting an arbitrary salesforce instance with an arbitrary wordpress installation. I intend to use it as a base for keeping User data in sync between salesforce and Wordpress.

  • WooCommerce Base. Ecommerce Manager. Free. The obvious base ecommerce package for the site.

  • WooCommerce Stripe. Payment gateway. Free. We'll use stripe for all transactions. We had a good experience integrating with stripe on a previous project. Stripe also plays well with WooCommerce Subscriptions and securely saving cards, which we'll need.

  • WooCommerce Subscriptions. Secure Recurring Payments Scheduler. $199.00. Subscriptions and Recurring payments. We'll want to use this to manage recurring payments, as in donations and memberships.

  • WooCommerce Product Bundles. For selling bundled products. $49.00. These may be things like a Course, and an Associate Course Fee.

  • WooCommerce Custom Post Types Manager. Allows for woocommerce fields to be associated with non-product post-types. $25.99. We'll use this to turn each of our critical custom post types.

  • TechCrunch WP Asynchronous Tasks. Allows for Asynchronous request processing for WordPress in PHP: helpful because php execution environments are single-threaded, and we have a lot of processing to do at a given time. Free.

Setting up the Development Environment.

  1. Install Docker. Make sure that the docker installation you're selecting contains docker-machine and docker-compose as well as the simple docker command. Follow the installation prompts.

  2. Clone this repository locally to a directory in your workspace. The specific location of the directory is not significant.

  3. From inside the cloned drectory, Run npm install to get the dependencies for this project. When that's done, run npm run build to test your installation. If you don't get any errors from the build process, and you see a folder named 'bundles' in the 'themes/custom' folder, with files named 'admin-bundle.css', 'bundle.css' and 'bundle.js', the process worked.

  4. Rename the .sample.env file to .env, and fill in the missing fields KINSTA_IP, KINSTA_IP with the target Kinsta instance for this project (if relevant, otherwise delete the field), and the ACF_PRO_KEY field.

  5. Next, we need to enable Public Key access to the staging environment for you. You can do this using the ssh-copy-id command line tool, along with the typical public key you use for Digital Ocean, for example. Typically, your public key will be in ~/.ssh/id_rsa.pub, so you would run ssh-copy-id -i ~/.ssh/id_rsa.pub {{user:ip.of.destination}}. The password for this specific instance (which you'll need to copy your id_rsa.pub file over) can be found in the Kinsta management console.

  6. run docker-compose up -d to provision a new virtual environment and database running wordpress.

  7. run npm run watch to start the development environment. The docker container will watch for changes as you make them, and reload the page at http://localhost:8080.

  8. When you're done working, run docker-compose down to safely close the development environment.

Starting Work

  1. You only need to do the above steps once. To start working locally, run docker-compose up -d to start your containers, and npm run watch to start webpack. When you're done working, kill npm run watch with ^C, and run docker-compose down to bring down your containers.

  2. To deploy your work to the staging site, run npm run deploy from the root directory. This command will place whatever's in your compiled dist directory into the appropriate locations on the server.

Pulling the Remote Database

  1. Head to the staging environment, log in, and use WP-Migrate-DB to generate a new, string-replaced database file.

  2. Run ./.pull-database.sh <path-to-mysql-export> from the project directory. This script will import this file into the docker mysql instance you have running locally.

Resources

  • Information on Wordpress Gutenburg, and making sure to future-proof for it is available here. The Gutenberg plugin (which is being merged into Core in release 5.0.0) is installed for prototyping.