NOTE: This guide assumes the reader already have a fully functionnal server with ssh access. It also assume the reader is familiar with git and Github.
This recipe will guide you to create a git repository for your own Sprinkle and how you can deploy it on your production environment using Composer. This can be viewed as an alternate method of going live on a server where you have the necessary tools to install UserFrosting (git, Composer, npm, node, etc.). One advantage of this method is easy setup and super easy updates !
This method doesn't require you to have a git version of the main UserFrosting repository. Instead, it uses git to clone the latest UserFrosting version and Composer to manage your sprinkle, who is stored in an independent git repository. Your sprinkle will then behave just like any Composer dependency. The magic behind this method comes from the integration of UserFrosting sprinkles with Composer installers. More info on this can be found on the Community Sprinkles page.
For this guide, we will be using Github as our git provider. We'll first create a git repository for our sprinkle, configure said sprinkle to be able to install it with Composer and finally deploy a fresh UserFrosting installation with our Sprinkle.
First thing is to do is create a new Github repository for our Sprinkle, if you don't already have one. Note that only your sprinkle's code should be in that repository. You don't need to add the core UserFrosting code in that repository. Just your code is enough. You can look at the Community Sprinkles on Github if you want an example of what a sprinkle repository looks like. Note that your repository can be public or private. Just remember that private repository can't be added to Packagist (more on this later).
For this example, we'll name our repository
userfrosting/pastries
. The name you give your sprinkle here doesn't matter and will be prefixed with your username. Just make sure to change the references to that name later when we use it !
Once you have your sprinkle repository sprinkle ready and committed your code to it, you'll be ready to configure your sprinkle and start deploying !
composer.json
fileAs stated in the Sprinkles Chapter, each sprinkles requires a composer.json
file. To be able to deploy your sprinkle using Composer, we need to make sure it follows some basic principles:
type
installer-name
(optional)composer.json
fileLet's look at our userfrosting/pastries
Composer file :
{
"name": "userfrosting/pastries",
"type": "userfrosting-sprinkle",
"description": "Simple Pastries List for UserFrosting",
"keywords": ["pastries", "sprinkle", "userfrosting"],
"homepage": "https://github.com/userfrosting/pastries",
"license" : "MIT",
"autoload": {
"psr-4": {
"UserFrosting\\Sprinkle\\Pastries\\": "src/"
}
},
"extra": {
"installer-name": "pastries"
}
}
So far, it's not so much different than a normal composer.json
file. But the first element is really important. In the type
section, you must use the userfrosting-sprinkle
name. This is what tells Composer Installer that this Composer dependency is a Sprinkle and that it needs to install it in the sprinkle directory. Otherwise, your sprinkle will be installed in the app/vendor
directory !
The installer-name
part is also important if you want to install your sprinkle in a different directory than the repository name. For example, if your GitHub repository is named Pastries_Sprinkle
, without the installer-name
instruction, Composer would install your sprinkle package in app/sprinkles/Pastries_Sprinkle
. The installer name allows you to specify a different name for the installation directory.
Now that we have our Sprinkle ready for deployment via Composer, it's time to move to our staging or production server and install a fresh copy of UserFrosting. The instructions here are similar to the Quick Start Guide. If you're not familiar with those instructions, it's still time to go back to the beginning !
Using ssh, cd
where you want to install UserFrosting and use git to clone the latest version of UserFrosting into a new userfrosting
folder:
$ git clone https://github.com/userfrosting/UserFrosting.git userfrosting
At this point, we'll add our custom sprinkle to the system. Let's start by creating our sprinkles.json
file. cd
nto the newly created userfrosting
folder and use nano (or whatever) to create a new empty file:
$ nano app/sprinkles.json
That file usually contains a list of all the sprinkles we want to load on our installation. However, it's actually a disguised composer.json
file! This means, not only can we add our sprinkle to the list, we can use this file to ask Composer to clone it for us. Lets's look at the finalized content and then dive into each section:
{
"require": {
"userfrosting/pastries": "dev-master"
},
"repositories": [
{
"type": "git",
"url": "git@github.com:userfrosting/pastries.git"
}
],
"base": [
"core",
"account",
"admin",
"pastries"
]
}
If you want to load multiple repository using this method, simply list all of your repository in each section.
require
tells Composer to download your package and what version to use. Change userfrosting/pastries
to your repository full name and keep dev-master
as the version. This way, Composer will load the code from the master
branch of your repository.
repository
tells Composer where to find your package. Each repository here is defined using a type
and url
. The type
instruct Composer on how to download to the repository and the url
is the url of your repository. See Composer Documentation for more info on this. If your repository is on Github, just change the userfrosting/pastries
part of the url to your repository full name.
This is not required if you add your (public) repository to Packagist. But at this point, it's not required. If you plan on distributing your Sprinkle, it may however be a good idea to do so.
base
is our sprinkle list. Simply add your sprinkle name to the end of the list. Here we added pastries
, but don't forget to change the name to whatever name you gave your sprinkle. This should be the same name as the one you defined in your sprinkle composer.json
under installer-name
!
Now that our sprinkle is ready to go, we continue the installation process like usual. First, we need to fetch the Composer dependencies:
$ composer install
Now run the final setup by calling the Bakery CLI:
$ php bakery bake
This will run the installation process:
app/.env
That's it! Your UserFrosting installation with your sprinkle should now be done!
This method can also be used with existing installation. Simply edit your
sprinkles.json
file and runcomposer update
andphp bakery bake
to install your sprinkle.
To update an instance of UserFrosting installed with those instructions, simply run from the top directory git pull
. Don't worry about Git complaining about your sprinkle not being in version control. That is totally normal. Don't forget to run composer update
and php bakery bake
afterward too !
To update your sprinkles installed using Composer, simply commit your changes to your Github repository and run composer update
. Don't forget to run php bakery bake
afterward too !
This recipe was spronsored by @jy and USOR. Get in touch with the UserFrosting team if you want to sponsor your own receipe !