You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
105 lines
2.9 KiB
105 lines
2.9 KiB
4 years ago
|
import axios from 'axios';
|
||
|
import { hasNotificationType, Notification } from '..';
|
||
|
import { MediaStatus } from '../../../constants/media';
|
||
|
import logger from '../../../logger';
|
||
|
import { getSettings, NotificationAgentLunaSea } from '../../settings';
|
||
|
import { BaseAgent, NotificationAgent, NotificationPayload } from './agent';
|
||
|
|
||
|
class LunaSeaAgent
|
||
|
extends BaseAgent<NotificationAgentLunaSea>
|
||
|
implements NotificationAgent {
|
||
|
protected getSettings(): NotificationAgentLunaSea {
|
||
|
if (this.settings) {
|
||
|
return this.settings;
|
||
|
}
|
||
|
|
||
|
const settings = getSettings();
|
||
|
|
||
|
return settings.notifications.agents.lunasea;
|
||
|
}
|
||
|
|
||
|
private buildPayload(type: Notification, payload: NotificationPayload) {
|
||
|
return {
|
||
|
notification_type: Notification[type],
|
||
|
subject: payload.subject,
|
||
|
message: payload.message,
|
||
|
image: payload.image ?? null,
|
||
|
email: payload.notifyUser?.email,
|
||
|
username: payload.notifyUser?.username,
|
||
|
avatar: payload.notifyUser?.avatar,
|
||
|
media: payload.media
|
||
|
? {
|
||
|
media_type: payload.media.mediaType,
|
||
|
tmdbId: payload.media.tmdbId,
|
||
|
imdbId: payload.media.imdbId,
|
||
|
tvdbId: payload.media.tvdbId,
|
||
|
status: MediaStatus[payload.media.status],
|
||
|
status4k: MediaStatus[payload.media.status4k],
|
||
|
}
|
||
|
: null,
|
||
|
extra: payload.extra ?? [],
|
||
|
request: payload.request
|
||
|
? {
|
||
|
request_id: payload.request.id,
|
||
|
requestedBy_email: payload.request.requestedBy.email,
|
||
|
requestedBy_username: payload.request.requestedBy.displayName,
|
||
|
requestedBy_avatar: payload.request.requestedBy.avatar,
|
||
|
}
|
||
|
: null,
|
||
|
};
|
||
|
}
|
||
|
|
||
|
public shouldSend(type: Notification): boolean {
|
||
|
if (
|
||
|
this.getSettings().enabled &&
|
||
|
this.getSettings().options.webhookUrl &&
|
||
|
hasNotificationType(type, this.getSettings().types)
|
||
|
) {
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
public async send(
|
||
|
type: Notification,
|
||
|
payload: NotificationPayload
|
||
|
): Promise<boolean> {
|
||
|
logger.debug('Sending LunaSea notification', {
|
||
|
label: 'Notifications',
|
||
|
type: Notification[type],
|
||
|
subject: payload.subject,
|
||
|
});
|
||
|
|
||
|
try {
|
||
|
const { webhookUrl, profileName } = this.getSettings().options;
|
||
|
|
||
|
if (!webhookUrl) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
await axios.post(webhookUrl, this.buildPayload(type, payload), {
|
||
|
headers: {
|
||
|
Authorization: `Basic ${Buffer.from(`${profileName}:`).toString(
|
||
|
'base64'
|
||
|
)}`,
|
||
|
},
|
||
|
});
|
||
|
|
||
|
return true;
|
||
|
} catch (e) {
|
||
|
logger.error('Error sending LunaSea notification', {
|
||
|
label: 'Notifications',
|
||
|
type: Notification[type],
|
||
|
subject: payload.subject,
|
||
|
errorMessage: e.message,
|
||
|
response: e.response.data,
|
||
|
});
|
||
|
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
export default LunaSeaAgent;
|