mirror of
https://github.com/opelly27/streetmerchant.git
synced 2026-05-20 05:17:35 +00:00
feat(notification): add Streamlabs support (#1872)
This commit is contained in:
@@ -209,3 +209,16 @@ Instructions on how to set up tokens can be found at [d-fischer.github.io/twitch
|
|||||||
| `TWITCH_ACCESS_TOKEN` | Twitch access token |
|
| `TWITCH_ACCESS_TOKEN` | Twitch access token |
|
||||||
| `TWITCH_REFRESH_TOKEN` | Twitch refresh token |
|
| `TWITCH_REFRESH_TOKEN` | Twitch refresh token |
|
||||||
| `TWITCH_CHANNEL` | Twitch channel |
|
| `TWITCH_CHANNEL` | Twitch channel |
|
||||||
|
|
||||||
|
## StreamLabs
|
||||||
|
|
||||||
|
Instructions on how to set up tokens can be found at [dev.streamlabs.com](https://dev.streamlabs.com/docs/register-your-application).
|
||||||
|
You don't need to submit your application for review, just whitelist yourself!
|
||||||
|
|
||||||
|
| Environment variable | Description |
|
||||||
|
|:---:|---|
|
||||||
|
| `STREAMLABS_ACCESS_TOKEN` | StreamLabs access token |
|
||||||
|
| `STREAMLABS_TYPE` | StreamLabs alert type |
|
||||||
|
| `STREAMLABS_IMAGE`| Custom image to display. Leave it blank for default |
|
||||||
|
| `STREAMLABS_SOUND` | Custom image to play. Leave it blank for default |
|
||||||
|
| `STREAMLABS_DURATION` | StreamLabs alert duration (in milliseconds) |
|
||||||
|
|||||||
@@ -116,4 +116,9 @@ TWITTER_ACCESS_TOKEN_SECRET=
|
|||||||
TWITTER_CONSUMER_KEY=
|
TWITTER_CONSUMER_KEY=
|
||||||
TWITTER_CONSUMER_SECRET=
|
TWITTER_CONSUMER_SECRET=
|
||||||
TWITTER_TWEET_TAGS=
|
TWITTER_TWEET_TAGS=
|
||||||
|
STREAMLABS_ACCESS_TOKEN=
|
||||||
|
STREAMLABS_TYPE=
|
||||||
|
STREAMLABS_IMAGE=
|
||||||
|
STREAMLABS_SOUND=
|
||||||
|
STREAMLABS_DURATION=
|
||||||
WEB_PORT=
|
WEB_PORT=
|
||||||
|
|||||||
Generated
+22
-10
@@ -3072,16 +3072,6 @@
|
|||||||
"resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz",
|
"resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz",
|
||||||
"integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE="
|
"integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE="
|
||||||
},
|
},
|
||||||
"form-data": {
|
|
||||||
"version": "2.3.3",
|
|
||||||
"resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz",
|
|
||||||
"integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==",
|
|
||||||
"requires": {
|
|
||||||
"asynckit": "^0.4.0",
|
|
||||||
"combined-stream": "^1.0.6",
|
|
||||||
"mime-types": "^2.1.12"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"fs-constants": {
|
"fs-constants": {
|
||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/fs-constants/-/fs-constants-1.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/fs-constants/-/fs-constants-1.0.0.tgz",
|
||||||
@@ -4927,6 +4917,18 @@
|
|||||||
"tough-cookie": "~2.4.3",
|
"tough-cookie": "~2.4.3",
|
||||||
"tunnel-agent": "^0.6.0",
|
"tunnel-agent": "^0.6.0",
|
||||||
"uuid": "^3.3.2"
|
"uuid": "^3.3.2"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"form-data": {
|
||||||
|
"version": "2.3.3",
|
||||||
|
"resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz",
|
||||||
|
"integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==",
|
||||||
|
"requires": {
|
||||||
|
"asynckit": "^0.4.0",
|
||||||
|
"combined-stream": "^1.0.6",
|
||||||
|
"mime-types": "^2.1.12"
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"request-promise-core": {
|
"request-promise-core": {
|
||||||
@@ -7806,6 +7808,16 @@
|
|||||||
"uuid": "^3.3.2"
|
"uuid": "^3.3.2"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"form-data": {
|
||||||
|
"version": "2.3.3",
|
||||||
|
"resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz",
|
||||||
|
"integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==",
|
||||||
|
"requires": {
|
||||||
|
"asynckit": "^0.4.0",
|
||||||
|
"combined-stream": "^1.0.6",
|
||||||
|
"mime-types": "^2.1.12"
|
||||||
|
}
|
||||||
|
},
|
||||||
"tough-cookie": {
|
"tough-cookie": {
|
||||||
"version": "2.5.0",
|
"version": "2.5.0",
|
||||||
"resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz",
|
"resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz",
|
||||||
|
|||||||
@@ -332,6 +332,13 @@ const notifications = {
|
|||||||
consumerSecret: envOrString(process.env.TWITTER_CONSUMER_SECRET),
|
consumerSecret: envOrString(process.env.TWITTER_CONSUMER_SECRET),
|
||||||
tweetTags: envOrString(process.env.TWITTER_TWEET_TAGS),
|
tweetTags: envOrString(process.env.TWITTER_TWEET_TAGS),
|
||||||
},
|
},
|
||||||
|
streamlabs: {
|
||||||
|
accessToken: envOrString(process.env.STREAMLABS_ACCESS_TOKEN),
|
||||||
|
type: envOrString(process.env.STREAMLABS_TYPE),
|
||||||
|
imageHref: envOrString(process.env.STREAMLABS_IMAGE),
|
||||||
|
soundHref: envOrString(process.env.STREAMLABS_SOUND),
|
||||||
|
duration: envOrNumber(process.env.STREAMLABS_DURATION),
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
const nvidia = {
|
const nvidia = {
|
||||||
|
|||||||
@@ -16,6 +16,7 @@ import {sendTwilioMessage} from './twilio';
|
|||||||
import {sendTwitchMessage} from './twitch';
|
import {sendTwitchMessage} from './twitch';
|
||||||
import {updateRedis} from './redis';
|
import {updateRedis} from './redis';
|
||||||
import {activateSmartthingsSwitch} from './smartthings';
|
import {activateSmartthingsSwitch} from './smartthings';
|
||||||
|
import {sendStreamLabsAlert} from './streamlabs';
|
||||||
|
|
||||||
export function sendNotification(link: Link, store: Store) {
|
export function sendNotification(link: Link, store: Store) {
|
||||||
// Priority
|
// Priority
|
||||||
@@ -37,4 +38,5 @@ export function sendNotification(link: Link, store: Store) {
|
|||||||
sendTwilioMessage(link, store);
|
sendTwilioMessage(link, store);
|
||||||
sendTwitchMessage(link, store);
|
sendTwitchMessage(link, store);
|
||||||
updateRedis(link, store);
|
updateRedis(link, store);
|
||||||
|
sendStreamLabsAlert(link, store);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,42 @@
|
|||||||
|
import {Link, Store} from '../store/model';
|
||||||
|
import {Print, logger} from '../logger';
|
||||||
|
import {config} from '../config';
|
||||||
|
import {URLSearchParams} from 'url';
|
||||||
|
import fetch from 'node-fetch';
|
||||||
|
|
||||||
|
const {streamlabs} = config.notifications;
|
||||||
|
let requestParams: URLSearchParams;
|
||||||
|
|
||||||
|
if (streamlabs.accessToken && streamlabs.type) {
|
||||||
|
requestParams = new URLSearchParams();
|
||||||
|
requestParams.append('access_token', streamlabs.accessToken);
|
||||||
|
requestParams.append('type', streamlabs.type);
|
||||||
|
requestParams.append('image_href', streamlabs.imageHref);
|
||||||
|
requestParams.append('sound_href', streamlabs.soundHref);
|
||||||
|
requestParams.append('duration', streamlabs.duration.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
export function sendStreamLabsAlert(link: Link, store: Store) {
|
||||||
|
if (requestParams) {
|
||||||
|
logger.debug('↗ sending StreamLabs alert');
|
||||||
|
|
||||||
|
(async () => {
|
||||||
|
const message = `${Print.inStock(link, store)}`;
|
||||||
|
requestParams.set('message', message);
|
||||||
|
|
||||||
|
try {
|
||||||
|
const response = await fetch('https://streamlabs.com/api/v1.0/alerts', {
|
||||||
|
method: 'POST',
|
||||||
|
body: requestParams,
|
||||||
|
});
|
||||||
|
|
||||||
|
const json = await response.json();
|
||||||
|
if (!json.success) throw Error(JSON.stringify(json));
|
||||||
|
|
||||||
|
logger.info('✔ StreamLabs alert sent');
|
||||||
|
} catch (error: unknown) {
|
||||||
|
logger.error("✖ couldn't send StreamLabs alert", error);
|
||||||
|
}
|
||||||
|
})();
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user