Setting up a dev environment for Wordpress Plugin: Step-by-step guide
Posted on - September 3, 2024 by Andy Cinquin
Plugin developmentForVoyezWeb developmentCapRoverCoolifyPHP developmentMySQL databasesDevelopment environmentWordPress plugin
Prerequisites
Before starting this tutorial, you need to have:
- PHP 8.2 installed
- An available database (MySQL or MariaDB)
- A server with CapRover / Coolify
Setting up the environment
Hello everyone,
In this article, we'll see how I developed the ForVoyez plugin, the steps I went through, and how I approached it.
First, for the dev environment, I had taken a course from Grafikart a few years ago, and I remembered they used "WordPlate" (GitHub - vinkla/wordplate: WordPlate is a boilerplate for WordPress, built with Composer and designed with sensible defaults.)
So I went to check out the repo in question, and I found it wasn't too bad and could do the job. So I had my WordPress base.
In addition to this base, I needed a base for my database.
To do this, I deployed a database on my CapRover via a MariaDB Docker image.
To do this, I deployed a database on my CapRover via a MariaDB Docker image.
I added the following environment variables:
data:image/s3,"s3://crabby-images/df2b6/df2b653b4e389fb2f0bff304ab839996b46588e1" alt="Webpage displaying a configuration panel for database settings with tabs for HTTP Settings, App Configs, and Deployment. App Configs tab shows settings for environmental variables and options for MySQL database instance."
data:image/s3,"s3://crabby-images/df2b6/df2b653b4e389fb2f0bff304ab839996b46588e1" alt="Webpage displaying a configuration panel for database settings with tabs for HTTP Settings, App Configs, and Deployment. App Configs tab shows settings for environmental variables and options for MySQL database instance."
And mapped 3308 & 3308 to be able to access this port from the outside.
Then in my dev environment, after running the following command for WordPlate:
composer create-project --prefer-dist vinkla/wordplate forvoyez-wp
I filled in the corresponding credentials, and in the "database" part of my IDE as well:
data:image/s3,"s3://crabby-images/fcb43/fcb434694c7ed21d09a24c8811d9564f79968646" alt="Screenshot of a database management software interface showing list of supported databases, navigation for a database with tables, views, and routines, and toolbar with options for query console and data sources"
data:image/s3,"s3://crabby-images/fcb43/fcb434694c7ed21d09a24c8811d9564f79968646" alt="Screenshot of a database management software interface showing list of supported databases, navigation for a database with tables, views, and routines, and toolbar with options for query console and data sources"
Then I simply needed to fill in the necessary elements: the port, address, db, user, and password.
data:image/s3,"s3://crabby-images/be8a2/be8a21c5f9309ab8b48aeab5cf2f13afdad1538e" alt="Screenshot of a database configuration window in an IDE with fields for host, port, user, and password. Red arrows pointing to modified or incomplete sections."
data:image/s3,"s3://crabby-images/be8a2/be8a21c5f9309ab8b48aeab5cf2f13afdad1538e" alt="Screenshot of a database configuration window in an IDE with fields for host, port, user, and password. Red arrows pointing to modified or incomplete sections."
Then all that's left is to create the database:
data:image/s3,"s3://crabby-images/342a6/342a604d592412da95d3b67c851ec1b31c2c72c0" alt="Image of computer screen displaying open code editor or database management interface with command to create a new database named 'forvoyez'"
data:image/s3,"s3://crabby-images/14993/149934e67f1712b2047f8f52ef6e85b54ac95ed8" alt="Screenshot of computer interface highlighting Query Console option in database development application"
data:image/s3,"s3://crabby-images/342a6/342a604d592412da95d3b67c851ec1b31c2c72c0" alt="Image of computer screen displaying open code editor or database management interface with command to create a new database named 'forvoyez'"
CREATE DATABASE forvoyez
Perfect!
Now we have a functional environment to start with, all that's left is to fill in the environment variables for WordPress!
data:image/s3,"s3://crabby-images/7fc81/7fc810182613e417eb5d10895d048677671e1379" alt="Screenshot of an Integrated Development Environment (IDE) with an open project showing a .env file containing environment configuration settings."
data:image/s3,"s3://crabby-images/7fc81/7fc810182613e417eb5d10895d048677671e1379" alt="Screenshot of an Integrated Development Environment (IDE) with an open project showing a .env file containing environment configuration settings."
All these elements can be added and replaced, we change the environment variables to connect to the database.
Then, all that's left is to launch WordPress!
We type:
We type:
composer install
and
npm install
then
php -S 127.0.0.1:8000 -t public/
We then go to the URL in question (127.0.0.1) via a browser:
data:image/s3,"s3://crabby-images/d13ef/d13ef3c2b7512eb21f0b70249083ff74b7f06432" alt="WordPress installation setup screen displaying site information fields and password strength indicator with an option to discourage search engine indexing"
data:image/s3,"s3://crabby-images/73dd8/73dd8089e83444c48f7b96c54e02a51edb67d37d" alt="WordPress installation setup screen prompting user to enter site information and discouraging search engine indexing"
data:image/s3,"s3://crabby-images/d13ef/d13ef3c2b7512eb21f0b70249083ff74b7f06432" alt="WordPress installation setup screen displaying site information fields and password strength indicator with an option to discourage search engine indexing"
data:image/s3,"s3://crabby-images/73dd8/73dd8089e83444c48f7b96c54e02a51edb67d37d" alt="WordPress installation setup screen prompting user to enter site information and discouraging search engine indexing"
And we fill out the small form!
And we're off to develop this plugin!
🚀 Thanks for reading!
If you enjoyed this article, feel free to share it around.
💡 Got an idea? Let's talk !☕