summaryrefslogtreecommitdiff
path: root/doc/en_US/plugin-external-tasks.markdown
blob: 0701ea38f7e4718c10f444a46a88e36b04facfd0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
External Task Providers
=======================

Kanboard can be used to manage tasks stored in another system.
For example, an external system can be a bug tracker or any kind of ticketing software.
In this way, you can use Kanboard to manage external tasks in the same way as native tasks.

Workflow
--------

Creation:

1. The end-user select an alternative task provider during the task creation
2. The external task provider expose a form to the user to be able to fetch the external task
3. The external task is retrieved from the other system
4. A customized form is shown to the user

Visualization:

When the task detail page is opened, Kanboard will load asynchronously the remote task.
This information might be cached by the plugin to improve the loading time.

Modification:

Optionally, the plugin can offer a custom form to save extra information to the external system.

Interfaces
----------

External task providers must implements at least two interfaces:

- `Kanboard\Core\ExternalTask\ExternalTaskProviderInterface`
- `Kanboard\Core\ExternalTask\ExternalTaskInterface`

### ExternalTaskProviderInterface

| Method                                             | Usage                                                           |
|----------------------------------------------------|-----------------------------------------------------------------|
| `getName()`                                        | Get provider name (label)                                       |
| `fetch()`                                          | Retrieve task from external system or cache                     |
| `save($uri, array $formValues, array &$formErrors)`| Save external task to another system                            |
| `getImportFormTemplate()`                          | Get task import template name                                   |
| `getCreationFormTemplate()`                        | Get creation form template                                      |
| `getModificationFormTemplate()`                    | Get modification form template                                  |
| `getViewTemplate()`                                | Get task view template name                                     |
| `buildTaskUri(array $formValues)`                  | Build external task URI based on import form values             |

### ExternalTaskInterface

| Method                                            | Usage                                                           |
|---------------------------------------------------|-----------------------------------------------------------------|
| `getUri()`                                        | Return Uniform Resource Identifier for the task                 |
| `getFormValues()`                                 | Return a dict to populate the task form                         |


Exceptions
----------

The plugin may raise an exception if something goes wrong:

- `Kanboard\Core\ExternalTask\ExternalTaskException`: Generic error related to the external system
- `Kanboard\Core\ExternalTask\AccessForbiddenException`: Access not allowed by the external system
- `Kanboard\Core\ExternalTask\NotFoundException`: External task not found

Provider Registration
---------------------

```php
class Plugin extends Base
{
    public function initialize()
    {
        $this->externalTaskManager->register(new MyExternalTaskProvider());
    }
}
```