So, I’m delighted to say that what I consider to be an important landmark towards Known 1.0 has been reached, and that is that Composer Installers now supports Known plugins, themes and console plugins!
Currently support is only available in the development build, but support now should be included in the next release, which will hopefully come out soon!
This is a big deal for two important reasons; firstly it now becomes super easy to roll your own builds of Known, by simply supplying your own composer.json
, and second, it solves the frustrating “checkout repository, move and rename” problem.
Making your plugin Composer ready
If you’re a plugin developer, there’s a few things you need to do in order to take advantage of this:
Create a composer.json
file
Firstly you need to create a composer.json
file. This file can contain a bunch of things, but at the very least you need to give your package a name, a version, and include the relevant composer installers instructions.
Here’s an example from my IPFS plugin, with the important parts in bold.
{
"name": "mapkyca/known-ipfs",
"type": "known-plugin",
"description": "Adds IPFS support to Known",
"version": "0.1.4",
"homepage": "https://www.marcus-povey.co.uk",
"keywords": [
"known",
"plugin",
"ipfs"
],
"license": "GPL-2.0",
"authors": [
{
"name": "Marcus Povey",
"email": "marcus@marcus-povey.co.uk"
}
],
"require": {
"php": ">=7.1",
"cloutier/php-ipfs-api": "^0.0.6",
"composer/installers": "~1.0"
},
"extra": {
"installer-name": "IPFS"
},
"require-dev": {
"mapkyca/known-language-tools": "^1.0",
"mapkyca/known-dev-scripts": "^1.0",
"mapkyca/known-phpcs": "^1.0"
}
}
- name: the name of the repository (used for packagist)
- type: should either be
known-plugin
known-console
orknown-theme
- version: version of the plugin, again for packagist
- “composer/installers”: “~1.0” in require composer your plugin needs to require the installers plugin. This is also included by Known core, so don’t worry too much if you forget!
- “installer-name”: “IPFS” this tells installers that your plugin should be installed in the named directory. So in this case instead of installing the plugin as the repo name (known-ipfs), it’ll install as ‘IPFS’. This is of course the correct plugin name according to its class hierarchy… so no more renaming!
Create a tagged release
Write your code, and then create a tagged release matching the version value in your composer.json
.
Submit to packagists.org
Finally, submit your plugin to packagists.org in order to make it available for other Known installations to use!
Enjoy!