-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTldrApp.ts
74 lines (68 loc) · 3.2 KB
/
TldrApp.ts
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
import {
IAppAccessors,
IConfigurationExtend,
IConfigurationModify,
IEnvironmentRead,
IHttp,
ILogger,
IModify,
IPersistence,
IRead,
} from '@rocket.chat/apps-engine/definition/accessors';
import { ApiSecurity, ApiVisibility } from '@rocket.chat/apps-engine/definition/api';
import { App } from '@rocket.chat/apps-engine/definition/App';
import { IMessage, IPostMessageSent } from '@rocket.chat/apps-engine/definition/messages';
import { IAppInfo } from '@rocket.chat/apps-engine/definition/metadata';
import { ISetting } from '@rocket.chat/apps-engine/definition/settings';
import { Commands } from './src/commands/commands';
import { CronJobSetup } from './src/config/cron-job-setup';
import { AppSetting, settings } from './src/config/settings';
import { SummarizationEndpoint } from './src/endpoints/summarization';
import { SettingsHelper } from './src/helpers/settings.helper';
export class TldrApp extends App implements IPostMessageSent {
private cronJobSetup: CronJobSetup;
constructor(info: IAppInfo, logger: ILogger, accessors: IAppAccessors) {
super(info, logger, accessors);
}
public async executePostMessageSent(message: IMessage, read: IRead, http: IHttp, persistence: IPersistence, modify: IModify): Promise<void> {
if (message.sender.id !== 'rocket.cat' && message.room.type === 'c') {
const baseUrl = (await read.getEnvironmentReader().getSettings().getById(AppSetting.summarizationServiceUrl)).value;
await http.post(`${baseUrl}/save-message`, { data: { text: message.text, createdAt: message.createdAt, updatedAt: message.updatedAt, room: message.room.id } });
}
}
public async onSettingUpdated(setting: ISetting, configurationModify: IConfigurationModify, read: IRead, http: IHttp): Promise<void> {
try {
if (setting.id !== AppSetting.cronJobServiceUrl && setting.id !== AppSetting.cronJobServiceFrequency) {
return;
}
const cronJobUrl = (await read.getEnvironmentReader().getSettings().getById(AppSetting.cronJobServiceUrl)).value;
const cronJobFrequency = (await read.getEnvironmentReader().getSettings().getById(AppSetting.cronJobServiceFrequency)).value;
if (!cronJobUrl || !cronJobFrequency) {
return;
}
this.cronJobSetup = new CronJobSetup(this.getAccessors().http, new SettingsHelper(read));
const endpoint = this.getAccessors().providedApiEndpoints && this.getAccessors().providedApiEndpoints.length && this.getAccessors().providedApiEndpoints[0].computedPath;
if (endpoint) {
const siteUrl = (await this.getAccessors().environmentReader.getServerSettings().getOneById('Site_Url')).value;
this.cronJobSetup.setup(`${siteUrl}${endpoint}`, cronJobFrequency);
}
} catch (error) {
this.getLogger().error(error);
}
}
protected async extendConfiguration(configuration: IConfigurationExtend, environmentRead: IEnvironmentRead): Promise<void> {
try {
await Promise.all(settings.map((setting) => configuration.settings.provideSetting(setting)));
await configuration.api.provideApi({
visibility: ApiVisibility.PRIVATE,
security: ApiSecurity.UNSECURE,
endpoints: [
new SummarizationEndpoint(this),
],
});
await configuration.slashCommands.provideSlashCommand(new Commands());
} catch (error) {
this.getLogger().error(error);
}
}
}