doc/packaging_apps.md

92 lines
4.6 KiB
Markdown
Raw Normal View History

2015-11-17 21:57:23 +01:00
# App packaging <img src="https://yunohost.org/images/yunohost_package.png" width=100/>
2013-11-27 13:08:12 +01:00
2015-06-18 20:00:03 +02:00
This document aimed to learn you how to package an application for YunoHost.
### Requirements
To package an application, here are the requirements:
2016-02-25 13:15:31 +01:00
* An account on a git server (e.g. [GitHub](https://github.com/)) to publish the application;
2016-02-25 13:19:49 +01:00
* Basic knowledge of `git`, bash shell and other programming stuff;
2015-06-18 20:00:03 +02:00
* A testing [virtual machine or a distant server](/install_en) to package and test the package.
2013-11-27 13:08:12 +01:00
### Content
2014-11-04 09:39:30 +01:00
A YunoHost package is composed of:
2013-11-27 13:08:12 +01:00
2015-06-18 20:00:03 +02:00
* A `manifest.json` file
* A `scripts` directory, which contains five Shell scripts: `install`, `remove`, `upgrade`, `backup` and `restore`
* Optional directories, containing `sources` or `conf` files
* A `LICENSE` file containing the license of the package
* A presentation page of your package in a `README.md` file
2014-11-04 09:39:30 +01:00
2016-02-19 12:10:40 +01:00
<a class="btn btn-lg btn-default" href="https://github.com/YunoHost/example_ynh"> A basic package</a>
feel free to use it as a framework.
2013-11-27 13:08:12 +01:00
2016-01-26 17:33:28 +01:00
## Manifest
<a class="btn btn-lg btn-default" href="packaging_apps_manifest_en">Manifest</a>
2013-11-27 13:08:12 +01:00
## Scripts
2016-02-19 12:28:09 +01:00
<a class="btn btn-lg btn-default" href="packaging_apps_scripts_en">Scripts</a>
2013-11-27 13:08:12 +01:00
2013-11-27 13:32:06 +01:00
### Architecture and arguments
2014-01-01 16:28:01 +01:00
Since YunoHost has a unified architecture, you will be able to guess most of the settings you need. But if you need variable ones, like the domain or web path, you will have to ask the administrator at installation (see `arguments` section in the manifest above).
2013-11-27 13:08:12 +01:00
2016-01-26 20:25:32 +01:00
<a class="btn btn-lg btn-default" href="packaging_apps_arguments_management_en">Arguments management</a>
2013-11-27 13:08:12 +01:00
2016-01-30 19:46:54 +01:00
### Nginx configuration
<a class="btn btn-lg btn-default" href="packaging_apps_nginx_conf_en">Nginx configuration</a>
2016-02-24 23:23:31 +01:00
### Multi-instance
<a class="btn btn-lg btn-default" href="packaging_apps_multiinstance_en">Multi-instance</a>
2013-12-12 18:11:03 +01:00
### Hooks
2014-01-01 16:28:01 +01:00
YunoHost provides a hook system, which is accessible via the packager's script callbacks in moulinette (CLI).
The scripts have to be placed in the `hooks` repository at the root of the YunoHost package, and must be named `priority-hook_name`, for example: `hooks/50-post_user_create` will be executed after each user creation.
2013-12-12 18:11:03 +01:00
2013-12-12 18:12:30 +01:00
**Note**: `priority` is optional, default is `50`.
2014-01-01 16:28:01 +01:00
Take a look at the [ownCloud package](https://github.com/Kloadut/owncloud_ynh) for a working example.
2013-12-12 18:11:03 +01:00
2013-11-27 13:32:06 +01:00
### Helpers
2016-02-24 21:40:21 +01:00
<a class="btn btn-lg btn-default" href="packaging_apps_helpers_en">Helpers</a>
2013-11-27 13:29:05 +01:00
2014-01-01 16:28:01 +01:00
### Test it!
In order to test your package, you can execute your script standalone as `admin` (do not forget to append required arguments):
2013-11-27 13:29:05 +01:00
```bash
su - admin -c "/bin/bash /path/to/my/script my_arg1 my_arg2"
```
2015-06-18 20:00:03 +02:00
Or you can use [moulinette](/moulinette_en):
2013-11-27 13:29:05 +01:00
```bash
yunohost app install /path/to/my/app/package
```
Note that it also works with a Git URL:
```bash
yunohost app install https://github.com/author/my_app_package.git
```
2015-08-10 18:46:45 +02:00
### Enhance package
2016-02-25 13:19:49 +01:00
Here is a list of best practices for application install scripts :
2015-08-10 18:46:45 +02:00
* scripts should use `sudo cp -a ../sources/. $final_path` instead of `sudo cp -a ../sources/* $final_path`;
* install script must contain support in case of script errors to delete residuals files thanks to `set -e` and `trap`;
* install script should use command line method instead of curl call through web install form;
* install script should save install answers;
* application sources should be checked with a control sum (sha256, sha1 or md5) or a PGP signature;
2016-02-25 13:19:49 +01:00
* scripts should be tested on Debian Jessie as well as 32 bits, 64 bits and ARM architectures;
* backup and restore scripts should be present and functional.
2015-08-10 18:46:45 +02:00
2016-02-24 21:34:31 +01:00
### Package script checker
<a class="btn btn-lg btn-default" href="https://github.com/YunoHost/package_checker">Package checker</a>
This is a Python script which check:
* that the package is up to date wich last specifications
* that all files are present
* that the manifest don't have syntax error
* that scripts exit well before modifing the system during verifications.
2015-06-18 20:00:03 +02:00
### Publish and ask for testing your application
2015-10-06 00:21:54 +02:00
* Publishing a [post on the Forum](https://forum.yunohost.org/) with the [`App integration` category](https://forum.yunohost.org/c/app-integration), to ask tests and returns on your application.
2015-06-18 20:00:03 +02:00
2015-12-03 11:56:56 +01:00
* Ask to add your application in the [app repository](https://github.com/YunoHost/apps) to be displayed in the [non-official apps list](https://yunohost.org/#/apps_in_progress_en). Precise his progress state: `notworking`, `inprogress`, or `working`.
2014-11-09 13:16:25 +01:00
2015-06-18 20:00:03 +02:00
### Officalization of an application
2016-02-25 13:15:04 +01:00
To become an official application, it must be enough tested, stable and should work on 64 bits, 32 bits et ARM processor architectures, and on Debian Jessie. If you think those conditions are met, ask for [official integration](https://github.com/YunoHost/apps) of your application.