-
-
Notifications
You must be signed in to change notification settings - Fork 25
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Created post Mezzio101 #250
base: staging
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,173 @@ | ||
--- | ||
id: 2025-01-30-mezzio101-using-mezzio-skeleton-installer | ||
author: bidi | ||
title: 'Mezzio 101: Create an Application Using the Mezzio Skeleton Installer' | ||
draft: false | ||
public: true | ||
created: '2025-01-30T11:00:00-01:00' | ||
updated: '2025-01-30T11:00:00-01:00' | ||
tags: | ||
- mezzio | ||
- skeleton | ||
- tutorial | ||
--- | ||
|
||
Creating a site from scratch has always been a daunting task for developers. | ||
The difficulty doesn't come so much from the complex coding, but from the imprecise specifications. | ||
Even if you start with clear goals in mind, the project can grow exponentially in complexity as time goes by. | ||
New technical requirements, new features, bug fixes and refactoring all get in the way of the developer resting on his laurels. | ||
|
||
One might argue the above are only possible in the programming world. | ||
We aren't building bridges here. | ||
|
||
We need a reliable, well-maintained starting point for our projects. | ||
This scaffolding should be a basis that allows us to expand as needed in the future. | ||
|
||
<!--- EXTENDED --> | ||
|
||
> This will be the first article of a series meant to showcase how to build a fully-operational application using Mezzio. | ||
|
||
### Where to start? | ||
|
||
Building the project manually is a complex operation that has too many moving parts to be accessible. | ||
Also, each of us will build it in his own image and that invites chaos even if we have the best intentions. | ||
A better solution is using the Mezzio Skeleton Installer that handles a lot of aspects automatically, the most basic being listed below: | ||
|
||
- Standard directory and file structure | ||
- Routing | ||
- Middleware | ||
- Templating | ||
- CI/CD | ||
|
||
The Laminas Project is known to offer a PHP framework and component library that is kept up-to-date with the latest updates in the PHP ecosystem. | ||
A second, but highly important aspect is their focus on standards defined by the [PHP Framework Interop Group](https://www.php-fig.org/). | ||
|
||
#### Prerequisites | ||
|
||
You need a working installation of [PHP](https://www.php.net/manual/en/install.php) and [Composer](https://getcomposer.org/) available on your `$PATH`. | ||
|
||
### What is Mezzio? | ||
|
||
As mentioned on [the Zend official site](https://www.zend.com/resources/what-mezzio-why-would-i-use-it), 'Mezzio is the Laminas middleware runtime -- previously known as Expressive in the Zend framework.' | ||
Mezzio is designed around PHP-FIG, the PHP Framework Interop Group, that has defined several standards recommendations. | ||
The goal of the standards is to ensure that PHP code is written in a consistent, interoperable, and maintainable way. | ||
|
||
### What is middleware? | ||
|
||
Middleware is code that is executed between the request and response. | ||
Most commonly, it performs these tasks, but more layers can be defined based on your application: | ||
|
||
- Aggregates incoming data. | ||
- Processes the request. | ||
- Creates and returns a response. | ||
|
||
There are several advantages to using middleware: | ||
|
||
- It enables old systems to interface with newer ones. | ||
- It's scalable. | ||
- Integrations are created more easily. | ||
- It enables automating processes. | ||
|
||
### Installing Mezzio | ||
|
||
Let's put aside the technical stuff in favor of some real work that you can be proud of. | ||
Building things with our hands, kind of. | ||
|
||
To start, create a folder where you want your project files to be created. | ||
|
||
```shell | ||
mkdir -p ~/Projects/my-mezzio-project | ||
``` | ||
|
||
The next command will launch the Mezzio Skeleton Installer. | ||
We will go through the installation process together, using the recommended settings. | ||
We will opt primarily for the Laminas-supported options to maintain consistency. | ||
Funnily enough, the installation should complete in less time than it takes for you to read this tutorial. | ||
|
||
```shell | ||
composer create-project mezzio/mezzio-skeleton ~/Projects/my-mezzio-project | ||
``` | ||
|
||
You should see the text and prompt below: | ||
|
||
data:image/s3,"s3://crabby-images/a4a57/a4a57048facf26bc26ab10f922377c0214b80183" alt="step-1-installation-type" | ||
|
||
Submit `3` for option `Modular`. | ||
|
||
data:image/s3,"s3://crabby-images/b26db/b26dbfef3bb61dc21cf87df6a4299389a1a04ad0" alt="step-2-dependency-injection" | ||
|
||
Submit `1` for option `laminas-servicemanager`. | ||
Just as a side note, this option is Laminas's factory-driven dependency injection container. | ||
Its version 4.0 supports PSR-11: Container interface version 1.1 and 2. | ||
|
||
data:image/s3,"s3://crabby-images/0d743/0d743324ab56b0ee65eb9531c39fd44fe6df094c" alt="step-3-router" | ||
|
||
Submit `1` for `fastroute`. | ||
|
||
data:image/s3,"s3://crabby-images/652d1/652d1eb0d848e7249822fe171c9c21ac62a2100b" alt="step-4-templating" | ||
|
||
We chose `Twig` as the templating engine because of its concise syntax, extensibility and well-written documentation. | ||
The Mezzio Skeleton Installer does offer several alternatives for the templating engines: | ||
|
||
- `Plates` is a simple templating engine that sees the templates themselves as PHP files. | ||
- `Twig` is reliable, actively-developed and well-known in the PHP community. | ||
- `laminas-view` is related to Laminas MVC. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I understand why you've chosen twig - but perhaps extrapolate on the reasons not to eat our own dog-food and use laminas-view. For example: "… laminas-view is a good choice if you're familiar with Laminas-MVC, but we've approached this article on the assumption that more people will have prior experience of Twig" laminas-view works perfectly well with with Mezzio, even though it does have a long history of being coupled to the MVC framework. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
we have in plan an article dedicated to all template engines options in mezzio. |
||
|
||
The default option for this step doesn't install any templating engine, but we only recommend this option if you want to build a CLI or API. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. You might use Laminas components for CLI applications, but Mezzio, not so much :) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Well, it's the idea that you do not need a template engine for CLI. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I mean, why would you use the Mezzio skeleton to scaffold out a CLI app? The CLI bit needs removing so it's just:
|
||
|
||
Submit `2` for `Twig`. | ||
|
||
data:image/s3,"s3://crabby-images/fcc11/fcc11595113f60ee9c05c3fc75e154b2e7773f2d" alt="step-5-error-reporting" | ||
|
||
Submit `1` for `Whoops`. | ||
At this point, the installer has enough information to install the 3rd party packages in the application. | ||
|
||
You can expect to see this prompt regarding dependency injection. | ||
|
||
data:image/s3,"s3://crabby-images/b9ad3/b9ad3e520c50bb2f7df03ffff6c43a261e732bda" alt="step-6-injection" | ||
|
||
Submit `1` for `config/config.php`. | ||
|
||
data:image/s3,"s3://crabby-images/de2c7/de2c79b8cbb397465ddc8b8d2f79ad9b0243ace1" alt="step-7-injection-confirmation" | ||
|
||
Submit `y` for `Remember this option for other packages of the same type? (Y/n)`. | ||
|
||
The final step in the installation performs the following operations: | ||
|
||
- Sets up `phpcs` the [PHP Code Sniffer](https://github.com/PHPCSStandards/PHP_CodeSniffer) | ||
- Clears the cache | ||
- Enables development mode | ||
|
||
data:image/s3,"s3://crabby-images/62deb/62deb3947ee71a74562c929b4194389528c75fe3" alt="step-8-installation-complete" | ||
|
||
#### The result of your work so far | ||
|
||
To run the application, you need to navigate to the installation folder using the command below. | ||
|
||
```shell | ||
cd ~/Projects/my-mezzio-project/ | ||
``` | ||
|
||
Then start the web server for your project. | ||
|
||
```shell | ||
php -S 0.0.0.0:8080 -t public | ||
``` | ||
|
||
Now go to your favorite browser and type this URL `http://localhost:8080/`. | ||
|
||
If everything worked correctly, you should now have a working application like in the screenshot below. | ||
You can then visit the recommended links to learn more about using the components we chose during the installation. | ||
|
||
data:image/s3,"s3://crabby-images/f14f7/f14f72dd8a7c741d932e81f9c171030f1030b6df" alt="step-9-installation-complete" | ||
|
||
bidi47 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
#### Coming up in the Mezzio101 series | ||
|
||
With our base application set up, the next article will detail how to create new pages and modules to organize your content. | ||
For this purpose we will create new files, update the application configuration and also use the command line interface. | ||
|
||
### Additional Resources | ||
|
||
- Learn more about [Laminas](https://docs.laminas.dev/). | ||
- Learn more about [Mezzio](https://docs.mezzio.dev/) and its [features](https://docs.mezzio.dev/mezzio/v3/getting-started/features/). | ||
- Learn more about [Mezzio's fundamentals from Matthew Setter's book 'Mezzio Essentials'](https://mezzioessentials.com/). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What is meant by this? Using components of Laminas?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It means the default options in the installer: laminas-servicemanager instead of the rest of DI libraries, fastroute , and twig
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The default option for template engine is
n
(none) which raises the question of why Twig is chosen. (The tutorial does not explain this.)There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am in doubt about that.
Indeed
none
is the default option, but we should consider using Twig in this series of tutorials in order to provide some practical value for the developers.Or we should have one article about all optional templates which can be used.
I really do not think that somebody use no template engine in a real life application. Eventually only if they need only CLI I/O
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I expanded the section for choosing the templating engine.