mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-01-06 22:40:26 -05:00
169 lines
5.4 KiB
Markdown
169 lines
5.4 KiB
Markdown
|
---
|
||
|
id: notifications
|
||
|
title: "Notifications"
|
||
|
---
|
||
|
|
||
|
Notify was built primarily to use with Slack's Incoming
|
||
|
webhooks, but will also deliver a simple payload to
|
||
|
any endpoint. This is currently only active for the `npm publish`
|
||
|
command.
|
||
|
|
||
|
## Usage {#usage}
|
||
|
|
||
|
An example with a **HipChat**, **Stride** and **Google Hangouts Chat** hook:
|
||
|
|
||
|
> Verdaccio supports any API, feel free to add more examples.
|
||
|
|
||
|
#### Single notification {#single-notification}
|
||
|
|
||
|
```yaml
|
||
|
notify:
|
||
|
method: POST
|
||
|
headers: [{'Content-Type': 'application/json'}]
|
||
|
endpoint: https://usagge.hipchat.com/v2/room/3729485/notification?auth_token=mySecretToken
|
||
|
content: '{"color":"green","message":"New package published: * {{ name }}*","notify":true,"message_format":"text"}'
|
||
|
```
|
||
|
|
||
|
#### Multiple notification {#multiple-notification}
|
||
|
|
||
|
```yaml
|
||
|
notify:
|
||
|
'example-google-chat':
|
||
|
method: POST
|
||
|
headers: [{'Content-Type': 'application/json'}]
|
||
|
endpoint: https://chat.googleapis.com/v1/spaces/AAAAB_TcJYs/messages?key=myKey&token=myToken
|
||
|
content: '{"text":"New package published: `{{ name }}{{#each versions}} v{{version}}{{/each}}`"}'
|
||
|
'example-hipchat':
|
||
|
method: POST
|
||
|
headers: [{'Content-Type': 'application/json'}]
|
||
|
endpoint: https://usagge.hipchat.com/v2/room/3729485/notification?auth_token=mySecretToken
|
||
|
content: '{"color":"green","message":"New package published: * {{ name }}*","notify":true,"message_format":"text"}'
|
||
|
'example-stride':
|
||
|
method: POST
|
||
|
headers: [{'Content-Type': 'application/json'}, {'authorization': 'Bearer secretToken'}]
|
||
|
endpoint: https://api.atlassian.com/site/{cloudId}/conversation/{conversationId}/message
|
||
|
content: '{"body": {"version": 1,"type": "doc","content": [{"type": "paragraph","content": [{"type": "text","text": "New package published: * {{ name }}* Publisher name: * {{ publisher.name }}"}]}]}}'
|
||
|
```
|
||
|
|
||
|
## Template {#template}
|
||
|
|
||
|
We use [Handlebars](https://handlebarsjs.com/) as main template engine.
|
||
|
|
||
|
### Format Examples {#format-examples}
|
||
|
|
||
|
```
|
||
|
# iterate all versions
|
||
|
{{ name }}{{#each versions}} v{{version}}{{/each}}
|
||
|
|
||
|
# publisher and `dist-tag` package published
|
||
|
{{ publisher.name }} has published {{ publishedPackage }}
|
||
|
```
|
||
|
|
||
|
### Properties {#properties}
|
||
|
|
||
|
List of properties accesible via template
|
||
|
|
||
|
* Metadata
|
||
|
* Publisher (who is publishing)
|
||
|
* Package Published (package@1.0.0)
|
||
|
|
||
|
### Metadata {#metadata}
|
||
|
|
||
|
Package metadata that the template has access
|
||
|
|
||
|
```
|
||
|
{
|
||
|
"_id": "@test/pkg1",
|
||
|
"name": "@test/pkg1",
|
||
|
"description": "",
|
||
|
"dist-tags": {
|
||
|
"beta": "1.0.54"
|
||
|
},
|
||
|
"versions": {
|
||
|
"1.0.54": {
|
||
|
"name": "@test/pkg1",
|
||
|
"version": "1.0.54",
|
||
|
"description": "some description",
|
||
|
"main": "index.js",
|
||
|
"scripts": {
|
||
|
"test": "echo \"Error: no test specified\" && exit 1"
|
||
|
},
|
||
|
"keywords": [],
|
||
|
"author": {
|
||
|
"name": "Author Name",
|
||
|
"email": "author@domain.com"
|
||
|
},
|
||
|
"license": "MIT",
|
||
|
"dependencies": {
|
||
|
"webpack": "4.12.0"
|
||
|
},
|
||
|
"readmeFilename": "README.md",
|
||
|
"_id": "@ test/pkg1@1.0.54",
|
||
|
"_npmVersion": "6.1.0",
|
||
|
"_nodeVersion": "9.9.0",
|
||
|
"_npmUser": {},
|
||
|
"dist": {
|
||
|
"integrity": "sha512-JlXWpLtMUBAqvVZBvH7UVLhXkGE1ctmXbDjbH/l0zMuG7wVzQ7GshTYvD/b5C+G2vOL2oiIS1RtayA/kKkTwKw==",
|
||
|
"shasum": "29c55c52c1e76e966e706165e5b9f22e32aa9f22",
|
||
|
"tarball": "http://localhost:4873/@test/pkg1/-/@test/pkg1-1.0.54.tgz"
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
"readme": "# test",
|
||
|
"_attachments": {
|
||
|
"@test/pkg1-1.0.54.tgz": {
|
||
|
"content_type": "application/octet-stream",
|
||
|
"data": "H4sIAAAAAAAAE+y9Z5PjyJIgOJ ...",
|
||
|
"length": 33112
|
||
|
}
|
||
|
},
|
||
|
"time": {}
|
||
|
}
|
||
|
```
|
||
|
|
||
|
|
||
|
### Publisher {#publisher}
|
||
|
|
||
|
You can get access to the package publisher information in the `content` of a webhook using the `publisher` object.
|
||
|
|
||
|
See below the `publisher` object type:
|
||
|
|
||
|
```
|
||
|
{
|
||
|
name: string,
|
||
|
groups: string[],
|
||
|
real_groups: string[]
|
||
|
}
|
||
|
```
|
||
|
|
||
|
An example:
|
||
|
|
||
|
```
|
||
|
notify:
|
||
|
method: POST
|
||
|
headers: [{'Content-Type': 'application/json'}]
|
||
|
endpoint: https://usagge.hipchat.com/v2/room/3729485/notification?auth_token=mySecretToken
|
||
|
content: '{"color":"green","message":"New package published: * {{ name }}*. Publisher name: * {{ publisher.name }} *.","notify":true,"message_format":"text"}'
|
||
|
```
|
||
|
|
||
|
**Note:** it's not possible to get the publisher information if the `package.json` file already has the `publisher` property.
|
||
|
|
||
|
### Package Published {#package-published}
|
||
|
|
||
|
You can access to the package is being published with the keyword `{{publishedPackage}}` as follows.
|
||
|
|
||
|
```
|
||
|
{{ publisher.name }} has published {{ publishedPackage }}
|
||
|
```
|
||
|
|
||
|
## Configuration {#configuration}
|
||
|
|
||
|
Property | Type | Required | Support | Default | Description
|
||
|
--- | --- | --- | --- | --- | ---
|
||
|
method| string | No | all | | HTTP verb
|
||
|
packagePattern| string | No | all | | Only run this notification if the package name matches the regular expression
|
||
|
packagePatternFlags| string | No | all | | Any flags to be used with the regular expression
|
||
|
headers| array/object | Yes | all | | If this endpoint requires specific headers, set them here as an array of key: value objects.
|
||
|
endpoint| string | Yes | all | | set the URL endpoint for this call
|
||
|
content| string | Yes | all | | any [Handlebar](https://handlebarsjs.com/) expressions
|