-
Notifications
You must be signed in to change notification settings - Fork 0
/
VideoConferenceSchedulerApp.ts
108 lines (95 loc) · 3.26 KB
/
VideoConferenceSchedulerApp.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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
import {
IAppAccessors,
IConfigurationExtend,
IHttp,
ILogger,
IModify,
IPersistence,
IRead,
} from '@rocket.chat/apps-engine/definition/accessors';
import { App } from '@rocket.chat/apps-engine/definition/App';
import { IAppInfo } from '@rocket.chat/apps-engine/definition/metadata';
import {
UIKitBlockInteractionContext,
} from '@rocket.chat/apps-engine/definition/uikit';
import {
IMessage,
IPostMessageSent,
} from '@rocket.chat/apps-engine/definition/messages';
import { ScheduleCommand } from './commands/schedule';
// import { initiatorMessage } from './lib/initiatorMessage';
import {generateJwtForUser} from './lib/generateJwtForUser';
export class VideoConferenceSchedulerApp extends App implements IPostMessageSent {
constructor(info: IAppInfo, logger: ILogger, accessors: IAppAccessors) {
super(info, logger, accessors);
}
public async executeBlockActionHandler(
context: UIKitBlockInteractionContext,
read: IRead,
http: IHttp,
persistence: IPersistence,
modify: IModify,
) {
const data = context.getInteractionData();
const { actionId } = data;
switch (actionId) {
case 'participate': {
try {
if ( ! data.room) {
return {
success: false,
};
}
const sender = await modify
.getCreator()
.startMessage();
const token = await generateJwtForUser(data.user);
const link = `${data.value}?jwt=${token}`;
sender.setRoom(data.room);
sender.setText(`${data.user.name}, here's your participation link: ${link}`);
// Notifier not applicable to LiveChat Rooms
if (data.room.type !== 'l') {
await modify
.getNotifier()
.notifyUser(data.user, sender.getMessage());
} else {
await modify.getCreator().finish(sender);
}
return {
success: true,
};
} catch (err) {
console.error(err);
return {
success: false,
};
}
}
}
return {
success: false,
};
}
public async executePostMessageSent(
message: IMessage,
read: IRead,
http: IHttp,
persistence: IPersistence,
modify: IModify,
): Promise<void> {
// if (message.room.type !== 'l') {
// return;
// }
//
// if (message.text === ':meme:') {
// const data = {
// room: message.room,
// sender: message.sender,
// };
// await initiatorMessage({ data, read, persistence, modify, http });
// }
}
protected async extendConfiguration(configuration: IConfigurationExtend): Promise<void> {
await configuration.slashCommands.provideSlashCommand(new ScheduleCommand(this));
}
}