Home > Internet Marketing | Web Analytics > How to publish your plugin or theme on the Piwik Marketplace – Introducing the Piwik Platform

How to publish your plugin or theme on the Piwik Marketplace – Introducing the Piwik Platform

This is the next post of our blog series where we introduce the capabilities of the Piwik platform. Over the last weeks we have already introduced you to some of the basics on how to create plugins and themes. This time you’ll learn how to publish a plugin or theme on the Piwik Marketplace to share it with all Piwik users.

What is the Piwik Marketplace?

The Marketplace is a showcase for all plugins and themes that can be used in Piwik. You can browse them either on a standalone website or in Piwik itself by going to Settings => Marketplace. There you can install and update them with just one click. Easy as that! While some of those plugins are provided by Piwik or Piwik PRO most of them are created and maintained by our community. Everyone is very welcome to distribute plugins or themes on the Marketplace.


To publish your plugin on the Marketplace you simply need to meet these requirements:

  • The plugin name is not already taken by another plugin
  • The code of the plugin is hosted in a public GitHub repository
  • The GitHub service “Piwik plugins” for this repository is enabled (Repository Settings => Webhooks & Services => Add Service)
  • Push permission for this repository
  • The plugin is free (as in not paid)
  • The license must be compatible with the GNU General Public License v3 or any later version

There is also list of Rules for plugins.

Best practices

Before actually distributing your plugin we recommend to follow a couple of best practices to make sure your plugin looks good on the Marketplace and provides useful information for your future users. If you have used the console to generate a plugin the needed files were already created for you.

Provide a good description

Make sure there is a file named README.md in the root of your plugin. When preparing your plugin for the Marketplace we will search for four sections in this file: Description, FAQ, Changelog and Support. Each of those is optional but it is good practice to provide at least a section Description and Support by prefixing them with ## . Any content of your readme outside of those sections will not be displayed on the Marketplace.

# Piwik Plugin Name ## Description Add your plugin description here. ## Support Please direct any feedback to hello@piwik.org. If you experience any issues feel free to file an issue at https://github.com/piwik/piwik/issues .

A good example can be seen in the README.md of the CustomAlerts plugin and the related CustomAlerts plugin page.

Provide screenshots

This will improve your appearance in the Marketplace a lot and users will be more likely install your plugin. It is as easy as placing “png” or “jpg” files in a folder named screenshots. The filename of each image will be shown in the UI with underscores replaced by a whitespace. This way you can provide a nice description. Have a look at the CustomAlerts plugin to see how it works.

Provide contact details

Your contact details are specified in the plugin.json file of your plugin root folder. Providing at least one author and a link to your homepage is required. If you do not have a website you can use a link to your GitHub profile. This helps your users contact you in case they want to thank you for your great work or if they have any problem with it. An example plugin.json looks like this:

{ "name": "MyPluginName", "homepage": "http://piwik.org", "authors": [ { "name": "Piwik", "email": "hello@piwik.org", "homepage": "http://piwik.org" } ], "support": { "email": "hello@piwik.org", "issues": "https://github.com/piwik/piwik/issues", "forum": "http://forum.piwik.org", "wiki": "https://github.com/piwik/piwik/wiki", "irc": "#piwik-dev" } }

Choose a license

Choosing the right license that works best for you and your users is important. To distribute a plugin via the Piwik Marketplace the license must be compatible with the GNU General Public License v3 or any later version. If you do not specify a license anywhere in your plugin, it is assumed your plugin uses GPLv3 or later. The license must be specified in the plugin.json file using the property license:

{ "name": "MyPluginName", "license": "GPL v3+"

Provide donation links

You can define a donation link or email for PayPal, Flattr and Bitcoin in the plugin.json file. Users that love your work will then be able to donate you money directly from the plugin page.

{ "name": "MyPluginName" "donate": { "paypal": "sponsor@piwik.org", "flattr": "https://flattr.com/profile/piwik", "bitcoin": "1234567890" }

How to publish the first version of your plugin

We are trying to make it as easy as possible for you to publish your plugin on the Marketplace. That’s why we don’t require any logins or packaging. To publish your plugin you only have to create a new tag of your plugin and within a minute your plugin will be ready to be installed on hundreds of thousands of Piwik installations.

To tag your plugin you can use one of the following two suggestions:

Using the command line

git tag 0.1.0 && git push --tags

Where “0.1.0″ is the name of the tag. While you can use any tag name it is best practice to use the current version number as defined in the plugin.json file.

Using GitHub UI

To tag a new version via GitHub click on Releases => Draft a new release.

Now you can enter a tag name (version) and press “Publish release” as shown in this screen. That’s it!

How to provide an update for your plugin

To provide an update you only have to increase the version number in the file plugin.json and create another tag as explained in the previous section. Your new Plugin update will be visible on the Marketplace within a minute or so. It might take a bit longer until the update appears in Piwik itself as each Piwik server only checks for updates every few hours.

For a complete list of information go to our Distributing Your Plugin guide in the Piwik Developer Zone.

If you have any feedback regarding our APIs or our guides in the Developer Zone feel free to let us know.


Visit Us On TwitterVisit Us On FacebookVisit Us On Google PlusVisit Us On Linkedin