2017-09-14 07:20:26 +02:00
|
|
|
# slackme
|
2018-09-15 22:23:05 +02:00
|
|
|
|
2017-09-14 07:20:26 +02:00
|
|
|
API abstraction for mojoio
|
|
|
|
|
|
|
|
## Availabililty
|
2018-09-15 22:23:05 +02:00
|
|
|
|
2017-09-14 07:20:26 +02:00
|
|
|
[data:image/s3,"s3://crabby-images/34c15/34c15b9d3f861db5ae4f5a5887c7f8da11d31473" alt="npm"](https://www.npmjs.com/package/slackme)
|
|
|
|
[data:image/s3,"s3://crabby-images/8cc23/8cc239d11c7181e11f70f3e79d90379741beda40" alt="git"](https://GitLab.com/mojoio/slackme)
|
|
|
|
[data:image/s3,"s3://crabby-images/8fa56/8fa561f60b4cc14350f6e1ad0bb4ee488f69a65e" alt="git"](https://github.com/mojoio/slackme)
|
|
|
|
[data:image/s3,"s3://crabby-images/cd9d5/cd9d5a1966110b15ceb387b20cf0701dbaa93979" alt="docs"](https://mojoio.gitlab.io/slackme/)
|
|
|
|
|
|
|
|
## Status for master
|
2018-09-15 22:23:05 +02:00
|
|
|
|
2017-09-14 07:20:26 +02:00
|
|
|
[data:image/s3,"s3://crabby-images/53ecb/53ecb5ddd8a133f4b678ec57074e056ee82ac16b" alt="build status"](https://GitLab.com/mojoio/slackme/commits/master)
|
|
|
|
[data:image/s3,"s3://crabby-images/e1768/e17687645d25d0a67e96e4ff6631695d346d1577" alt="coverage report"](https://GitLab.com/mojoio/slackme/commits/master)
|
|
|
|
[data:image/s3,"s3://crabby-images/86034/86034bd223e502b35c7652b0709dc5e36daa5743" alt="npm downloads per month"](https://www.npmjs.com/package/slackme)
|
|
|
|
[data:image/s3,"s3://crabby-images/05473/05473d68205e3a01755fef4135c1449e1b6bb147" alt="Dependency Status"](https://david-dm.org/mojoio/slackme)
|
|
|
|
[data:image/s3,"s3://crabby-images/25a52/25a52774ca8fc7707e7b96d7ec0215090a9470d3" alt="bitHound Dependencies"](https://www.bithound.io/github/mojoio/slackme/master/dependencies/npm)
|
|
|
|
[data:image/s3,"s3://crabby-images/a4138/a413891f5a0c4b6584a0b9b25c75c69024f8680f" alt="bitHound Code"](https://www.bithound.io/github/mojoio/slackme)
|
2018-01-10 22:10:09 +01:00
|
|
|
[data:image/s3,"s3://crabby-images/07bb2/07bb2d42065014895dfd9cd732e4b6af531408ee" alt="Known Vulnerabilities"](https://snyk.io/test/npm/slackme)
|
2017-09-14 07:20:26 +02:00
|
|
|
[data:image/s3,"s3://crabby-images/dd660/dd660bca73822ab1222a6804545a981361b4e318" alt="TypeScript"](https://nodejs.org/dist/latest-v6.x/docs/api/)
|
|
|
|
[data:image/s3,"s3://crabby-images/59eae/59eae184d611f740ae83e8d829ef38c461b76602" alt="node"](https://nodejs.org/dist/latest-v6.x/docs/api/)
|
2018-01-10 22:10:09 +01:00
|
|
|
[data:image/s3,"s3://crabby-images/d4b3b/d4b3b3a3d8edcb4fd0a55804ef2dd85c0bd11bbc" alt="JavaScript Style Guide"](https://standardjs.com/)
|
2017-09-14 07:20:26 +02:00
|
|
|
|
|
|
|
## Usage
|
2018-09-15 22:23:05 +02:00
|
|
|
|
2017-09-14 07:20:26 +02:00
|
|
|
Use TypeScript for best in class instellisense.
|
|
|
|
|
2018-01-10 21:45:25 +01:00
|
|
|
```javascript
|
|
|
|
import * as slackme from 'slackme'
|
|
|
|
|
|
|
|
// First setup the hook
|
|
|
|
const mySlackme = new Slackme('https://some.slack.webhook.url')
|
|
|
|
mySlackme.sendMessage:{{
|
|
|
|
// MessageOptions here
|
|
|
|
}, 'myAwesomeChannel'}
|
|
|
|
```
|
|
|
|
|
2018-01-10 22:17:30 +01:00
|
|
|
The message interface follows [Slack's docs (click here)](https://api.slack.com/docs/message-formatting) and looks like this:
|
2018-01-10 21:45:25 +01:00
|
|
|
|
|
|
|
```javascript
|
|
|
|
interface IAttachmentField {
|
|
|
|
title: string
|
|
|
|
value: string
|
|
|
|
short?: boolean
|
|
|
|
}
|
|
|
|
|
|
|
|
interface IMessageOptions {
|
|
|
|
/**
|
|
|
|
* "Required plain-text summary of the attachment."
|
|
|
|
*/
|
|
|
|
fallback?: string,
|
|
|
|
/**
|
|
|
|
* a side color
|
|
|
|
*/
|
|
|
|
color?: string,
|
|
|
|
/**
|
|
|
|
* a message to show above
|
|
|
|
*/
|
|
|
|
pretext?: string,
|
|
|
|
/**
|
|
|
|
* author name of the attachment
|
|
|
|
*/
|
|
|
|
author_name?: string,
|
|
|
|
/**
|
|
|
|
* a link to the author
|
|
|
|
*/
|
|
|
|
author_link?: string,
|
|
|
|
/**
|
|
|
|
* a string to the author
|
|
|
|
*/
|
|
|
|
author_icon?: string,
|
|
|
|
/**
|
|
|
|
* a title for the attachment
|
|
|
|
*/
|
|
|
|
title?: string,
|
|
|
|
/**
|
|
|
|
* a link for the title
|
|
|
|
*/
|
|
|
|
title_link?: string,
|
|
|
|
/**
|
|
|
|
* the main text of the message
|
|
|
|
*/
|
|
|
|
text?: string,
|
|
|
|
fields?: IAttachmentField[],
|
|
|
|
image_url?: string,
|
|
|
|
thumb_url?: string,
|
|
|
|
footer?: string,
|
|
|
|
footer_icon?: string,
|
|
|
|
/**
|
|
|
|
* timestamp as epoch time
|
|
|
|
*/
|
|
|
|
ts?: number
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Alternatively, there is the option of specifying a SlackMessage class
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
const mySlackMessage = new SlackMessage({ /* message options here } */, mySlackme)
|
|
|
|
mySlackMessage.title = 'new Title' // modify message options
|
|
|
|
mySlackMessage.sendToRoom('general')
|
|
|
|
mySlackMessage.title = 'another Title'
|
|
|
|
mySlackMessage.sendToRoom('anotherroom')
|
|
|
|
```
|
|
|
|
|
2017-09-14 07:20:26 +02:00
|
|
|
For further information read the linked docs at the top of this README.
|
|
|
|
|
|
|
|
> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
|
2018-09-15 22:23:05 +02:00
|
|
|
> | By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy.html)
|
2017-09-14 07:20:26 +02:00
|
|
|
|
|
|
|
[data:image/s3,"s3://crabby-images/73a8d/73a8d9f409f3cd24f0e03e1b45d8d799c709b58c" alt="repo-footer"](https://mojo.io)
|