@nerimity/nerimity.js 1.15.2 → 1.16.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.vscode/settings.json +2 -1
- package/build/Attachment.d.ts +6 -6
- package/build/Client.d.ts +222 -202
- package/build/EventNames.d.ts +7 -2
- package/build/EventNames.d.ts.map +1 -1
- package/build/EventNames.js.map +1 -1
- package/build/bitwise.d.ts.map +1 -1
- package/build/classes/Attachment.d.ts +8 -0
- package/build/classes/Attachment.d.ts.map +1 -0
- package/{src/Attachment.ts → build/classes/Attachment.js} +41 -50
- package/build/classes/Attachment.js.map +1 -0
- package/build/classes/Button.d.ts +19 -0
- package/build/classes/Button.d.ts.map +1 -0
- package/build/classes/Button.js +29 -0
- package/build/classes/Button.js.map +1 -0
- package/build/classes/Channel.d.ts +30 -0
- package/build/classes/Channel.d.ts.map +1 -0
- package/build/classes/Channel.js +61 -0
- package/build/classes/Channel.js.map +1 -0
- package/build/classes/Client.d.ts +42 -0
- package/build/classes/Client.d.ts.map +1 -0
- package/build/classes/Client.js +220 -0
- package/build/classes/Client.js.map +1 -0
- package/build/classes/ClientUser.d.ts +18 -0
- package/build/classes/ClientUser.d.ts.map +1 -0
- package/build/classes/ClientUser.js +15 -0
- package/build/classes/ClientUser.js.map +1 -0
- package/build/classes/Collection.d.ts +4 -0
- package/build/classes/Collection.d.ts.map +1 -0
- package/build/classes/Collection.js +10 -0
- package/build/classes/Collection.js.map +1 -0
- package/build/classes/Message.d.ts +36 -0
- package/build/classes/Message.d.ts.map +1 -0
- package/build/classes/Message.js +72 -0
- package/build/classes/Message.js.map +1 -0
- package/build/classes/MessageButton.d.ts +19 -0
- package/build/classes/MessageButton.d.ts.map +1 -0
- package/build/classes/MessageButton.js +29 -0
- package/build/classes/MessageButton.js.map +1 -0
- package/build/classes/Post.d.ts +50 -0
- package/build/classes/Post.d.ts.map +1 -0
- package/build/classes/Post.js +64 -0
- package/build/classes/Post.js.map +1 -0
- package/build/classes/RPCClient.d.ts +24 -0
- package/build/classes/RPCClient.d.ts.map +1 -0
- package/build/classes/RPCClient.js +72 -0
- package/build/classes/RPCClient.js.map +1 -0
- package/build/classes/Server.d.ts +26 -0
- package/build/classes/Server.d.ts.map +1 -0
- package/build/classes/Server.js +42 -0
- package/build/classes/Server.js.map +1 -0
- package/build/classes/ServerChannel.d.ts +14 -0
- package/build/classes/ServerChannel.d.ts.map +1 -0
- package/build/classes/ServerChannel.js +17 -0
- package/build/classes/ServerChannel.js.map +1 -0
- package/build/classes/ServerMember.d.ts +29 -0
- package/build/classes/ServerMember.d.ts.map +1 -0
- package/build/classes/ServerMember.js +69 -0
- package/build/classes/ServerMember.js.map +1 -0
- package/build/classes/ServerRole.d.ts +22 -0
- package/build/classes/ServerRole.d.ts.map +1 -0
- package/build/classes/ServerRole.js +30 -0
- package/build/classes/ServerRole.js.map +1 -0
- package/build/classes/User.d.ts +24 -0
- package/build/classes/User.d.ts.map +1 -0
- package/build/classes/User.js +35 -0
- package/build/classes/User.js.map +1 -0
- package/build/classes/Webhooks.d.ts +73 -0
- package/build/classes/Webhooks.d.ts.map +1 -0
- package/{src/Webhooks.ts → build/classes/Webhooks.js} +122 -148
- package/build/classes/Webhooks.js.map +1 -0
- package/build/example.js +9 -9
- package/build/example.js.map +1 -1
- package/build/index.d.ts +4 -4
- package/build/index.d.ts.map +1 -1
- package/build/index.js +4 -4
- package/build/index.js.map +1 -1
- package/build/services/ApplicationService.js +1 -2
- package/build/services/ApplicationService.js.map +1 -1
- package/build/services/MessageService.d.ts +1 -1
- package/build/services/MessageService.d.ts.map +1 -1
- package/build/services/MessageService.js +6 -7
- package/build/services/MessageService.js.map +1 -1
- package/build/services/PostsService.d.ts +2 -2
- package/build/services/PostsService.d.ts.map +1 -1
- package/build/services/PostsService.js +17 -14
- package/build/services/PostsService.js.map +1 -1
- package/build/services/ServerService.d.ts +3 -1
- package/build/services/ServerService.d.ts.map +1 -1
- package/build/services/ServerService.js +23 -2
- package/build/services/ServerService.js.map +1 -1
- package/build/services/serviceEndpoints.d.ts +1 -0
- package/build/services/serviceEndpoints.d.ts.map +1 -1
- package/build/services/serviceEndpoints.js +2 -0
- package/build/services/serviceEndpoints.js.map +1 -1
- package/eslint.config.mjs +37 -0
- package/package.json +11 -10
- package/src/EventNames.ts +7 -10
- package/src/classes/Attachment.ts +50 -0
- package/src/classes/Channel.ts +74 -0
- package/src/classes/Client.ts +338 -0
- package/src/classes/ClientUser.ts +26 -0
- package/src/classes/Collection.ts +5 -0
- package/src/classes/Message.ts +102 -0
- package/src/classes/MessageButton.ts +48 -0
- package/src/classes/Post.ts +100 -0
- package/src/{RPCClient.ts → classes/RPCClient.ts} +4 -4
- package/src/classes/Server.ts +57 -0
- package/src/classes/ServerChannel.ts +24 -0
- package/src/classes/ServerMember.ts +95 -0
- package/src/classes/ServerRole.ts +40 -0
- package/src/classes/User.ts +46 -0
- package/src/classes/Webhooks.ts +144 -0
- package/src/example.ts +15 -17
- package/src/index.ts +4 -4
- package/src/services/MessageService.ts +2 -2
- package/src/services/PostsService.ts +55 -51
- package/src/services/ServerService.ts +30 -1
- package/src/services/serviceEndpoints.ts +4 -0
- package/.eslintrc.js +0 -21
- package/src/Client.ts +0 -875
|
@@ -0,0 +1,338 @@
|
|
|
1
|
+
import EventEmitter from "eventemitter3";
|
|
2
|
+
import { Socket, io } from "socket.io-client";
|
|
3
|
+
import {
|
|
4
|
+
ClientEventMap,
|
|
5
|
+
ClientEvents,
|
|
6
|
+
SocketClientEvents,
|
|
7
|
+
SocketServerEvents,
|
|
8
|
+
} from "../EventNames";
|
|
9
|
+
import {
|
|
10
|
+
AuthenticatedPayload,
|
|
11
|
+
MessageButtonClickPayload,
|
|
12
|
+
RawBotCommand,
|
|
13
|
+
RawChannel,
|
|
14
|
+
RawMessage,
|
|
15
|
+
RawServer,
|
|
16
|
+
RawServerMember,
|
|
17
|
+
RawServerRole,
|
|
18
|
+
} from "../RawData";
|
|
19
|
+
|
|
20
|
+
import { path, updatePath } from "../services/serviceEndpoints";
|
|
21
|
+
|
|
22
|
+
import { updateCommands as postUpdateCommands } from "../services/ApplicationService";
|
|
23
|
+
import { MessageButton } from "./MessageButton";
|
|
24
|
+
import { ClientUser } from "./ClientUser";
|
|
25
|
+
import { Users } from "./User";
|
|
26
|
+
import { Channels } from "./Channel";
|
|
27
|
+
import { Servers } from "./Server";
|
|
28
|
+
import { Posts } from "./Post";
|
|
29
|
+
import { ServerMember } from "./ServerMember";
|
|
30
|
+
import { ServerChannel } from "./ServerChannel";
|
|
31
|
+
import { Message } from "./Message";
|
|
32
|
+
import { ServerRole } from "./ServerRole";
|
|
33
|
+
|
|
34
|
+
export const Events = ClientEvents;
|
|
35
|
+
|
|
36
|
+
export class Client extends EventEmitter<ClientEventMap> {
|
|
37
|
+
socket: Socket;
|
|
38
|
+
token: string | undefined;
|
|
39
|
+
user: ClientUser | undefined;
|
|
40
|
+
users: Users;
|
|
41
|
+
channels: Channels;
|
|
42
|
+
servers: Servers;
|
|
43
|
+
posts: Posts;
|
|
44
|
+
|
|
45
|
+
constructor(opts?: { urlOverride?: string }) {
|
|
46
|
+
super();
|
|
47
|
+
if (opts?.urlOverride) {
|
|
48
|
+
updatePath(opts.urlOverride);
|
|
49
|
+
}
|
|
50
|
+
this.socket = io(path, {
|
|
51
|
+
transports: ["websocket"],
|
|
52
|
+
autoConnect: false,
|
|
53
|
+
});
|
|
54
|
+
this.channels = new Channels(this);
|
|
55
|
+
this.users = new Users(this);
|
|
56
|
+
this.servers = new Servers(this);
|
|
57
|
+
this.posts = new Posts(this);
|
|
58
|
+
new EventHandlers(this);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
updateCommands(token: string, commands: Omit<RawBotCommand, "botUserId">[]) {
|
|
62
|
+
return postUpdateCommands(token, commands);
|
|
63
|
+
}
|
|
64
|
+
public login(token: string) {
|
|
65
|
+
this.token = token;
|
|
66
|
+
this.socket.connect();
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
class EventHandlers {
|
|
71
|
+
client: Client;
|
|
72
|
+
socket: Socket;
|
|
73
|
+
constructor(client: Client) {
|
|
74
|
+
this.client = client;
|
|
75
|
+
this.socket = client.socket;
|
|
76
|
+
|
|
77
|
+
client.socket.on(SocketServerEvents.CONNECT, this.onConnect.bind(this));
|
|
78
|
+
client.socket.on(
|
|
79
|
+
SocketServerEvents.USER_AUTHENTICATED,
|
|
80
|
+
this.onAuthenticated.bind(this)
|
|
81
|
+
);
|
|
82
|
+
|
|
83
|
+
client.socket.on(
|
|
84
|
+
SocketServerEvents.SERVER_MEMBER_JOINED,
|
|
85
|
+
this.onServerMemberJoined.bind(this)
|
|
86
|
+
);
|
|
87
|
+
client.socket.on(
|
|
88
|
+
SocketServerEvents.SERVER_MEMBER_UPDATED,
|
|
89
|
+
this.onServerMemberUpdated.bind(this)
|
|
90
|
+
);
|
|
91
|
+
client.socket.on(
|
|
92
|
+
SocketServerEvents.SERVER_MEMBER_LEFT,
|
|
93
|
+
this.onServerMemberLeft.bind(this)
|
|
94
|
+
);
|
|
95
|
+
|
|
96
|
+
client.socket.on(
|
|
97
|
+
SocketServerEvents.SERVER_JOINED,
|
|
98
|
+
this.onServerJoined.bind(this)
|
|
99
|
+
);
|
|
100
|
+
client.socket.on(
|
|
101
|
+
SocketServerEvents.SERVER_CHANNEL_CREATED,
|
|
102
|
+
this.onServerChannelCreated.bind(this)
|
|
103
|
+
);
|
|
104
|
+
client.socket.on(
|
|
105
|
+
SocketServerEvents.SERVER_CHANNEL_UPDATED,
|
|
106
|
+
this.onServerChannelUpdated.bind(this)
|
|
107
|
+
);
|
|
108
|
+
client.socket.on(
|
|
109
|
+
SocketServerEvents.SERVER_CHANNEL_DELETED,
|
|
110
|
+
this.onServerChannelDeleted.bind(this)
|
|
111
|
+
);
|
|
112
|
+
|
|
113
|
+
client.socket.on(
|
|
114
|
+
SocketServerEvents.SERVER_LEFT,
|
|
115
|
+
this.onServerLeft.bind(this)
|
|
116
|
+
);
|
|
117
|
+
|
|
118
|
+
client.socket.on(
|
|
119
|
+
SocketServerEvents.MESSAGE_CREATED,
|
|
120
|
+
this.onMessageCreated.bind(this)
|
|
121
|
+
);
|
|
122
|
+
|
|
123
|
+
client.socket.on(
|
|
124
|
+
SocketServerEvents.MESSAGE_BUTTON_CLICKED,
|
|
125
|
+
this.onMessageButtonClicked.bind(this)
|
|
126
|
+
);
|
|
127
|
+
client.socket.on(
|
|
128
|
+
SocketServerEvents.SERVER_ROLE_CREATED,
|
|
129
|
+
this.onServerRoleCreated.bind(this)
|
|
130
|
+
);
|
|
131
|
+
client.socket.on(
|
|
132
|
+
SocketServerEvents.SERVER_ROLE_DELETED,
|
|
133
|
+
this.onServerRoleDeleted.bind(this)
|
|
134
|
+
);
|
|
135
|
+
client.socket.on(
|
|
136
|
+
SocketServerEvents.SERVER_ROLE_UPDATED,
|
|
137
|
+
this.onServerRoleUpdated.bind(this)
|
|
138
|
+
);
|
|
139
|
+
client.socket.on(
|
|
140
|
+
SocketServerEvents.SERVER_ROLE_ORDER_UPDATED,
|
|
141
|
+
this.onServerRoleOrderUpdated.bind(this)
|
|
142
|
+
);
|
|
143
|
+
}
|
|
144
|
+
onConnect() {
|
|
145
|
+
this.socket.emit(SocketClientEvents.AUTHENTICATE, {
|
|
146
|
+
token: this.client.token,
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
onAuthenticated(payload: AuthenticatedPayload) {
|
|
150
|
+
this.client.user = new ClientUser(this.client, payload.user);
|
|
151
|
+
|
|
152
|
+
for (let i = 0; i < payload.servers.length; i++) {
|
|
153
|
+
const server = payload.servers[i];
|
|
154
|
+
this.client.servers.setCache(server);
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
for (let i = 0; i < payload.channels.length; i++) {
|
|
158
|
+
const rawChannel = payload.channels[i];
|
|
159
|
+
this.client.channels.setCache(rawChannel);
|
|
160
|
+
}
|
|
161
|
+
for (let i = 0; i < payload.serverMembers.length; i++) {
|
|
162
|
+
const member = payload.serverMembers[i];
|
|
163
|
+
this.client.users.setCache(member.user);
|
|
164
|
+
const server = this.client.servers.cache.get(member.serverId);
|
|
165
|
+
server?.members.setCache(member);
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
for (let i = 0; i < payload.serverRoles.length; i++) {
|
|
169
|
+
const role = payload.serverRoles[i];
|
|
170
|
+
const server = this.client.servers.cache.get(role.serverId);
|
|
171
|
+
server?.roles.setCache(role);
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
this.client.emit(ClientEvents.Ready);
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
onServerMemberJoined(payload: { serverId: string; member: RawServerMember }) {
|
|
178
|
+
const server = this.client.servers.cache.get(payload.serverId);
|
|
179
|
+
this.client.users.setCache(payload.member.user);
|
|
180
|
+
const member = server?.members.setCache(payload.member);
|
|
181
|
+
if (!member) return;
|
|
182
|
+
this.client.emit(ClientEvents.ServerMemberJoined, member);
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
onServerMemberUpdated(payload: {
|
|
186
|
+
serverId: string;
|
|
187
|
+
userId: string;
|
|
188
|
+
updated: {
|
|
189
|
+
roleIds: string[];
|
|
190
|
+
};
|
|
191
|
+
}) {
|
|
192
|
+
const server = this.client.servers.cache.get(payload.serverId);
|
|
193
|
+
const member = server?.members.cache.get(payload.userId);
|
|
194
|
+
if (!member) return;
|
|
195
|
+
|
|
196
|
+
updateClass<ServerMember>(member, payload.updated);
|
|
197
|
+
|
|
198
|
+
this.client.emit(ClientEvents.ServerMemberUpdated, member);
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
onServerJoined(payload: {
|
|
202
|
+
server: RawServer;
|
|
203
|
+
members: RawServerMember[];
|
|
204
|
+
channels: RawChannel[];
|
|
205
|
+
roles: RawServerRole[];
|
|
206
|
+
// memberPresences: any[]
|
|
207
|
+
// voiceChannelUsers: any[];
|
|
208
|
+
}) {
|
|
209
|
+
const server = this.client.servers.setCache(payload.server);
|
|
210
|
+
|
|
211
|
+
for (let i = 0; i < payload.members.length; i++) {
|
|
212
|
+
const member = payload.members[i];
|
|
213
|
+
this.client.users.setCache(member.user);
|
|
214
|
+
server?.members.setCache(member);
|
|
215
|
+
}
|
|
216
|
+
for (let i = 0; i < payload.roles.length; i++) {
|
|
217
|
+
const role = payload.roles[i];
|
|
218
|
+
server?.roles.setCache(role);
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
for (let i = 0; i < payload.channels.length; i++) {
|
|
222
|
+
const channel = payload.channels[i];
|
|
223
|
+
this.client.channels.setCache(channel);
|
|
224
|
+
}
|
|
225
|
+
this.client.emit(ClientEvents.ServerJoined, server);
|
|
226
|
+
}
|
|
227
|
+
onServerChannelCreated(payload: { serverId: string; channel: RawChannel }) {
|
|
228
|
+
const channel = this.client.channels.setCache(payload.channel);
|
|
229
|
+
this.client.emit(
|
|
230
|
+
ClientEvents.ServerChannelCreated,
|
|
231
|
+
channel as ServerChannel
|
|
232
|
+
);
|
|
233
|
+
}
|
|
234
|
+
onServerChannelUpdated(payload: {
|
|
235
|
+
serverId: string;
|
|
236
|
+
channelId: string;
|
|
237
|
+
updated: Partial<RawChannel>;
|
|
238
|
+
}) {
|
|
239
|
+
const channel = this.client.channels.cache.get(payload.channelId);
|
|
240
|
+
const updated = payload.updated;
|
|
241
|
+
if (channel) {
|
|
242
|
+
updateClass<ServerChannel>(channel as ServerChannel, updated);
|
|
243
|
+
this.client.emit(
|
|
244
|
+
ClientEvents.ServerChannelUpdated,
|
|
245
|
+
channel as ServerChannel
|
|
246
|
+
);
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
onServerChannelDeleted(payload: { serverId: string; channelId: string }) {
|
|
250
|
+
const channel = this.client.channels.cache.has(payload.channelId);
|
|
251
|
+
if (channel) {
|
|
252
|
+
this.client.channels.cache.delete(payload.channelId);
|
|
253
|
+
this.client.emit(ClientEvents.ServerChannelDeleted, {
|
|
254
|
+
channelId: payload.channelId,
|
|
255
|
+
serverId: payload.serverId,
|
|
256
|
+
});
|
|
257
|
+
}
|
|
258
|
+
}
|
|
259
|
+
onServerLeft(payload: { serverId: string }) {
|
|
260
|
+
const server = this.client.servers.cache.get(payload.serverId);
|
|
261
|
+
if (!server) return;
|
|
262
|
+
this.client.emit(ClientEvents.ServerLeft, server);
|
|
263
|
+
this.client.servers.cache.delete(payload.serverId);
|
|
264
|
+
|
|
265
|
+
this.client.channels.cache.forEach((channel) => {
|
|
266
|
+
if (
|
|
267
|
+
channel instanceof ServerChannel &&
|
|
268
|
+
channel.serverId === payload.serverId
|
|
269
|
+
) {
|
|
270
|
+
this.client.channels.cache.delete(channel.id);
|
|
271
|
+
}
|
|
272
|
+
});
|
|
273
|
+
server.members.cache.clear();
|
|
274
|
+
}
|
|
275
|
+
onServerMemberLeft(payload: { userId: string; serverId: string }) {
|
|
276
|
+
const server = this.client.servers.cache.get(payload.serverId);
|
|
277
|
+
const member = server?.members.cache.get(payload.userId);
|
|
278
|
+
if (!member) return;
|
|
279
|
+
this.client.emit(ClientEvents.ServerMemberLeft, member);
|
|
280
|
+
server?.members.cache.delete(payload.userId);
|
|
281
|
+
}
|
|
282
|
+
onMessageCreated(payload: { message: RawMessage }) {
|
|
283
|
+
const message = new Message(this.client, payload.message);
|
|
284
|
+
this.client.emit(ClientEvents.MessageCreate, message);
|
|
285
|
+
}
|
|
286
|
+
onMessageButtonClicked(payload: MessageButtonClickPayload) {
|
|
287
|
+
const button = new MessageButton(this.client, payload);
|
|
288
|
+
this.client.emit(ClientEvents.MessageButtonClick, button);
|
|
289
|
+
}
|
|
290
|
+
onServerRoleCreated(payload: RawServerRole) {
|
|
291
|
+
const server = this.client.servers.cache.get(payload.serverId);
|
|
292
|
+
const role = server?.roles.setCache(payload);
|
|
293
|
+
if (!role) return;
|
|
294
|
+
this.client.emit(ClientEvents.ServerRoleCreated, role);
|
|
295
|
+
}
|
|
296
|
+
onServerRoleDeleted(payload: { serverId: string; roleId: string }) {
|
|
297
|
+
const server = this.client.servers.cache.get(payload.serverId);
|
|
298
|
+
const role = server?.roles.cache.get(payload.roleId);
|
|
299
|
+
if (!role) return;
|
|
300
|
+
server?.roles.cache.delete(payload.roleId);
|
|
301
|
+
|
|
302
|
+
this.client.emit(ClientEvents.ServerRoleDeleted, role);
|
|
303
|
+
}
|
|
304
|
+
onServerRoleUpdated(payload: {
|
|
305
|
+
serverId: string;
|
|
306
|
+
roleId: string;
|
|
307
|
+
updated: Partial<RawServerRole>;
|
|
308
|
+
}) {
|
|
309
|
+
const server = this.client.servers.cache.get(payload.serverId);
|
|
310
|
+
const role = server?.roles.cache.get(payload.roleId);
|
|
311
|
+
if (!role) return;
|
|
312
|
+
|
|
313
|
+
updateClass<ServerRole>(role, payload.updated);
|
|
314
|
+
|
|
315
|
+
this.client.emit(ClientEvents.ServerRoleUpdated, role);
|
|
316
|
+
}
|
|
317
|
+
onServerRoleOrderUpdated(payload: { serverId: string; roleIds: string[] }) {
|
|
318
|
+
const server = this.client.servers.cache.get(payload.serverId);
|
|
319
|
+
|
|
320
|
+
for (let i = 0; i < payload.roleIds.length; i++) {
|
|
321
|
+
const roleId = payload.roleIds[i];
|
|
322
|
+
const role = server?.roles.cache.get(roleId);
|
|
323
|
+
if (!role) continue;
|
|
324
|
+
role.order = i + 1;
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
this.client.emit(ClientEvents.ServerRoleOrderUpdated, server?.roles!);
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
|
|
331
|
+
function updateClass<T extends object>(classInstance: T, update: Partial<T>) {
|
|
332
|
+
for (const [key, value] of Object.entries(update) as [
|
|
333
|
+
keyof T,
|
|
334
|
+
T[keyof T]
|
|
335
|
+
][]) {
|
|
336
|
+
classInstance[key] = value;
|
|
337
|
+
}
|
|
338
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { SocketClientEvents } from "../EventNames";
|
|
2
|
+
import { RawUser } from "../RawData";
|
|
3
|
+
import { Client } from "./Client";
|
|
4
|
+
import { User } from "./User";
|
|
5
|
+
|
|
6
|
+
export interface ActivityOpts {
|
|
7
|
+
action: string;
|
|
8
|
+
name: string;
|
|
9
|
+
startedAt: number;
|
|
10
|
+
endsAt?: number;
|
|
11
|
+
|
|
12
|
+
imgSrc?: string;
|
|
13
|
+
title?: string;
|
|
14
|
+
subtitle?: string;
|
|
15
|
+
link?: string;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
export class ClientUser extends User {
|
|
19
|
+
setActivity(activity?: ActivityOpts | null) {
|
|
20
|
+
this.client.socket.emit(SocketClientEvents.UPDATE_ACTIVITY, activity);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
constructor(client: Client, user: RawUser) {
|
|
24
|
+
super(client, user);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import {
|
|
2
|
+
ChannelType,
|
|
3
|
+
MessageType,
|
|
4
|
+
RawMessage,
|
|
5
|
+
RawMessageButton,
|
|
6
|
+
} from "../RawData";
|
|
7
|
+
import { deleteMessage, editMessage } from "../services/MessageService";
|
|
8
|
+
import { AllChannel } from "./Channel";
|
|
9
|
+
import { Client } from "./Client";
|
|
10
|
+
import { User } from "./User";
|
|
11
|
+
|
|
12
|
+
const UserMentionRegex = /\[@:([0-9]+)\]/gm;
|
|
13
|
+
const CommandRegex = /^(\/[^:\s]*):(\d+)( .*)?$/m;
|
|
14
|
+
|
|
15
|
+
export interface MessageOpts {
|
|
16
|
+
htmlEmbed?: string;
|
|
17
|
+
nerimityCdnFileId?: string;
|
|
18
|
+
buttons?: RawMessageButton[];
|
|
19
|
+
silent?: boolean;
|
|
20
|
+
replyToMessageIds?: string[];
|
|
21
|
+
mentionReplies?: boolean;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export class Message {
|
|
25
|
+
client: Client;
|
|
26
|
+
id: string;
|
|
27
|
+
content?: string;
|
|
28
|
+
type: MessageType;
|
|
29
|
+
createdAt: number;
|
|
30
|
+
channelId: string;
|
|
31
|
+
channel: AllChannel;
|
|
32
|
+
user: User;
|
|
33
|
+
mentions: User[] = [];
|
|
34
|
+
command?: { name: string; args: string[] };
|
|
35
|
+
constructor(client: Client, message: RawMessage) {
|
|
36
|
+
this.client = client;
|
|
37
|
+
|
|
38
|
+
this.id = message.id;
|
|
39
|
+
this.channelId = message.channelId;
|
|
40
|
+
this.channel = client.channels.cache.get(this.channelId)!;
|
|
41
|
+
this.content = message.content;
|
|
42
|
+
this.type = message.type;
|
|
43
|
+
this.createdAt = message.createdAt;
|
|
44
|
+
this.user = this.client.users.cache.get(message.createdBy.id)!;
|
|
45
|
+
|
|
46
|
+
const cmd = message.content?.match(CommandRegex);
|
|
47
|
+
if (cmd?.[2] === this.client.user?.id) {
|
|
48
|
+
this.command = {
|
|
49
|
+
name: cmd?.[1]!.substring(1)!,
|
|
50
|
+
args: message.content!.split(" ").slice(1),
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
if (!this.user) {
|
|
55
|
+
this.user = this.client.users.setCache(message.createdBy);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
if (!this.channel) {
|
|
59
|
+
this.channel = this.client.channels.setCache({
|
|
60
|
+
id: this.channelId,
|
|
61
|
+
type: ChannelType.DM_TEXT,
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if (this.content) {
|
|
66
|
+
const mentionIds = [...this.content.matchAll(UserMentionRegex)].map(
|
|
67
|
+
(exp) => exp[1]
|
|
68
|
+
);
|
|
69
|
+
this.mentions = mentionIds
|
|
70
|
+
.map((id) => this.client.users.cache.get(id)!)
|
|
71
|
+
.filter((u) => u);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
get member() {
|
|
75
|
+
return this.channel.server?.members.cache.get(this.user.id);
|
|
76
|
+
}
|
|
77
|
+
reply(content: string, _opts?: MessageOpts) {
|
|
78
|
+
const opts: MessageOpts = _opts || {};
|
|
79
|
+
opts.replyToMessageIds = [this.id];
|
|
80
|
+
return this.channel.send(content, opts);
|
|
81
|
+
}
|
|
82
|
+
async edit(content: string) {
|
|
83
|
+
const RawMessage = await editMessage({
|
|
84
|
+
client: this.client,
|
|
85
|
+
channelId: this.channel.id,
|
|
86
|
+
messageId: this.id,
|
|
87
|
+
content: content,
|
|
88
|
+
});
|
|
89
|
+
const message = new Message(this.client, RawMessage);
|
|
90
|
+
return message;
|
|
91
|
+
}
|
|
92
|
+
async delete() {
|
|
93
|
+
return deleteMessage({
|
|
94
|
+
channelId: this.channel.id,
|
|
95
|
+
client: this.client,
|
|
96
|
+
messageId: this.id,
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
toString() {
|
|
100
|
+
return `[q:${this.id}]`;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { MessageButtonClickPayload } from "../RawData";
|
|
2
|
+
import {
|
|
3
|
+
ButtonCallback,
|
|
4
|
+
buttonClickCallback,
|
|
5
|
+
} from "../services/MessageService";
|
|
6
|
+
import { Channel } from "./Channel";
|
|
7
|
+
import { Client } from "./Client";
|
|
8
|
+
import { User } from "./User";
|
|
9
|
+
|
|
10
|
+
export class MessageButton {
|
|
11
|
+
client: Client;
|
|
12
|
+
id: string;
|
|
13
|
+
|
|
14
|
+
userId: string;
|
|
15
|
+
messageId: string;
|
|
16
|
+
channelId: string;
|
|
17
|
+
|
|
18
|
+
user?: User;
|
|
19
|
+
channel: Channel;
|
|
20
|
+
|
|
21
|
+
data?: Record<string, string>;
|
|
22
|
+
type: "modal_click" | "button_click";
|
|
23
|
+
|
|
24
|
+
constructor(client: Client, payload: MessageButtonClickPayload) {
|
|
25
|
+
this.client = client;
|
|
26
|
+
|
|
27
|
+
this.id = payload.buttonId;
|
|
28
|
+
this.userId = payload.userId;
|
|
29
|
+
this.channelId = payload.channelId;
|
|
30
|
+
this.messageId = payload.messageId;
|
|
31
|
+
this.user = this.client.users.cache.get(this.userId);
|
|
32
|
+
|
|
33
|
+
this.channel = client.channels.cache.get(this.channelId)!;
|
|
34
|
+
this.data = payload.data;
|
|
35
|
+
this.type = payload.type;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
async respond(opts?: ButtonCallback) {
|
|
39
|
+
await buttonClickCallback({
|
|
40
|
+
client: this.client,
|
|
41
|
+
buttonId: this.id,
|
|
42
|
+
channelId: this.channelId,
|
|
43
|
+
messageId: this.messageId,
|
|
44
|
+
userId: this.userId,
|
|
45
|
+
data: opts,
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import { RawPost, RawUser } from "../RawData";
|
|
2
|
+
import {
|
|
3
|
+
deletePost,
|
|
4
|
+
editPost,
|
|
5
|
+
getPosts,
|
|
6
|
+
postPost,
|
|
7
|
+
} from "../services/PostsService";
|
|
8
|
+
import { Client } from "./Client";
|
|
9
|
+
|
|
10
|
+
export interface PostOpts {
|
|
11
|
+
nerimityCdnFileId?: string;
|
|
12
|
+
poll?: {
|
|
13
|
+
choices: string[];
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
export class Posts {
|
|
17
|
+
client: Client;
|
|
18
|
+
constructor(client: Client) {
|
|
19
|
+
this.client = client;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
async get(id?: string) {
|
|
23
|
+
const RawPosts = await getPosts(this.client);
|
|
24
|
+
const posts = RawPosts.map((post) => new Post(this.client, post));
|
|
25
|
+
return id ? posts.find((p) => p.id === id) : posts;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
async create(content: string, opts?: PostOpts) {
|
|
29
|
+
const RawPost = await postPost({
|
|
30
|
+
client: this.client,
|
|
31
|
+
content: content,
|
|
32
|
+
nerimityCdnFileId: opts?.nerimityCdnFileId,
|
|
33
|
+
poll: opts?.poll,
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
const post = new Post(this.client, RawPost);
|
|
37
|
+
|
|
38
|
+
return post;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
export class Post {
|
|
43
|
+
client: Client;
|
|
44
|
+
id: string;
|
|
45
|
+
content?: string;
|
|
46
|
+
attachments?: Array<any>;
|
|
47
|
+
deleted: boolean;
|
|
48
|
+
block?: boolean;
|
|
49
|
+
commentToId: string;
|
|
50
|
+
commentTo?: RawPost;
|
|
51
|
+
createdBy: RawUser;
|
|
52
|
+
createdAt: number;
|
|
53
|
+
editedAt: number;
|
|
54
|
+
likedBy: { id: string }[]; // if you liked this post, array will not be empty
|
|
55
|
+
reposts: { id: string; createdBy: { id: string; username: string } }[];
|
|
56
|
+
repost?: RawPost;
|
|
57
|
+
_count: { likedBy: number; comments: number; reposts: number };
|
|
58
|
+
views: number;
|
|
59
|
+
announcement: any;
|
|
60
|
+
poll?: any;
|
|
61
|
+
|
|
62
|
+
constructor(client: Client, post: RawPost) {
|
|
63
|
+
this.client = client;
|
|
64
|
+
this.id = post.id;
|
|
65
|
+
this.content = post.content;
|
|
66
|
+
this.attachments = post.attachments;
|
|
67
|
+
this.deleted = post.deleted;
|
|
68
|
+
this.block = post.block;
|
|
69
|
+
this.commentToId = post.commentToId;
|
|
70
|
+
this.commentTo = post.commentTo;
|
|
71
|
+
this.createdBy = post.createdBy;
|
|
72
|
+
this.createdAt = post.createdAt;
|
|
73
|
+
this.editedAt = post.editedAt;
|
|
74
|
+
this.likedBy = post.likedBy;
|
|
75
|
+
this.reposts = post.reposts;
|
|
76
|
+
this.repost = post.repost;
|
|
77
|
+
this._count = post._count;
|
|
78
|
+
this.views = post.views;
|
|
79
|
+
this.announcement = post.announcement;
|
|
80
|
+
this.poll = post.poll;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
async edit(content: string) {
|
|
84
|
+
const RawPost = await editPost({
|
|
85
|
+
client: this.client,
|
|
86
|
+
content: content,
|
|
87
|
+
postId: this.id,
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
const post = new Post(this.client, RawPost);
|
|
91
|
+
return post;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
async delete() {
|
|
95
|
+
await deletePost({
|
|
96
|
+
client: this.client,
|
|
97
|
+
postId: this.id,
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
}
|
|
@@ -19,8 +19,8 @@ export interface EmitPayload {
|
|
|
19
19
|
}
|
|
20
20
|
function findRunningServer(appId: string) {
|
|
21
21
|
return new Promise<null | WebSocket>((res) => {
|
|
22
|
-
|
|
23
|
-
|
|
22
|
+
const servers: WebSocket[] = [];
|
|
23
|
+
const id = setTimeout(() => {
|
|
24
24
|
res(null);
|
|
25
25
|
}, 5000);
|
|
26
26
|
for (let port = PORT_RANGES[0]; port < PORT_RANGES[1] + 1; port++) {
|
|
@@ -42,7 +42,7 @@ function findRunningServer(appId: string) {
|
|
|
42
42
|
}
|
|
43
43
|
});
|
|
44
44
|
|
|
45
|
-
server.on("error", (
|
|
45
|
+
server.on("error", () => {});
|
|
46
46
|
}
|
|
47
47
|
});
|
|
48
48
|
}
|
|
@@ -79,7 +79,7 @@ export class RPCClient extends EventEmitter<EventMap> {
|
|
|
79
79
|
const jsonParseCatch = (json: string) => {
|
|
80
80
|
try {
|
|
81
81
|
return JSON.parse(json);
|
|
82
|
-
} catch
|
|
82
|
+
} catch {
|
|
83
83
|
return null;
|
|
84
84
|
}
|
|
85
85
|
};
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { RawServer } from "../RawData";
|
|
2
|
+
import {
|
|
3
|
+
banServerMember,
|
|
4
|
+
kickServerMember,
|
|
5
|
+
unbanServerMember,
|
|
6
|
+
} from "../services/ServerService";
|
|
7
|
+
import { Client } from "./Client";
|
|
8
|
+
import { Collection } from "./Collection";
|
|
9
|
+
import { ServerMembers } from "./ServerMember";
|
|
10
|
+
import { ServerRoles } from "./ServerRole";
|
|
11
|
+
|
|
12
|
+
export class Servers {
|
|
13
|
+
client: Client;
|
|
14
|
+
cache: Collection<string, Server>;
|
|
15
|
+
constructor(client: Client) {
|
|
16
|
+
this.client = client;
|
|
17
|
+
this.cache = new Collection();
|
|
18
|
+
}
|
|
19
|
+
setCache(rawServer: RawServer) {
|
|
20
|
+
const server = new Server(this.client, rawServer);
|
|
21
|
+
this.cache.set(server.id, server);
|
|
22
|
+
return server;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export class Server {
|
|
27
|
+
client: Client;
|
|
28
|
+
id: string;
|
|
29
|
+
name: string;
|
|
30
|
+
avatar?: string;
|
|
31
|
+
defaultRoleId: string;
|
|
32
|
+
createdById: string;
|
|
33
|
+
|
|
34
|
+
members: ServerMembers;
|
|
35
|
+
roles: ServerRoles;
|
|
36
|
+
constructor(client: Client, server: RawServer) {
|
|
37
|
+
this.client = client;
|
|
38
|
+
|
|
39
|
+
this.id = server.id;
|
|
40
|
+
this.name = server.name;
|
|
41
|
+
this.avatar = server.avatar;
|
|
42
|
+
this.members = new ServerMembers(this.client);
|
|
43
|
+
this.roles = new ServerRoles(this.client);
|
|
44
|
+
this.defaultRoleId = server.defaultRoleId;
|
|
45
|
+
this.createdById = server.createdById;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
async banMember(userId: string) {
|
|
49
|
+
return banServerMember(this.client, this.id, userId);
|
|
50
|
+
}
|
|
51
|
+
async unbanMember(userId: string) {
|
|
52
|
+
return unbanServerMember(this.client, this.id, userId);
|
|
53
|
+
}
|
|
54
|
+
async kickMember(userId: string) {
|
|
55
|
+
return kickServerMember(this.client, this.id, userId);
|
|
56
|
+
}
|
|
57
|
+
}
|