1
0
mirror of https://github.com/spacebarchat/server.git synced 2024-11-13 14:12:41 +01:00

Merge branch 'fosscord:master' into master

This commit is contained in:
Paul Munteanu 2021-05-28 03:36:40 +03:00
commit dd24e49be1
8 changed files with 149 additions and 2208 deletions

4
.env.example Normal file
View File

@ -0,0 +1,4 @@
MONGO_URL=mongodb://localhost/fosscord
PORT=3002
PRODUCTION=TRUE
THREADS=# automatically use all available cores, only available if production = true

View File

@ -1,11 +1,12 @@
FROM node:lts-alpine FROM node:lts-alpine
WORKDIR /usr/src/fosscord-gateway WORKDIR /usr/src/fosscord-gateway
COPY . . COPY package.json .
RUN apk --no-cache --virtual build-dependencies add \ RUN apk --no-cache --virtual build-dependencies add \
python \ python \
make \ make \
g++ g++
RUN npm install RUN npm install
RUN apk del build-dependencies RUN apk del build-dependencies
COPY . .
EXPOSE 3002 EXPOSE 3002
CMD ["npm", "start"] CMD ["npm", "start"]

2267
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -13,7 +13,8 @@
"author": "Fosscord", "author": "Fosscord",
"license": "ISC", "license": "ISC",
"dependencies": { "dependencies": {
"@fosscord/server-util": "^1.2.6", "@fosscord/server-util": "^1.3.7",
"ajv": "^8.5.0",
"dotenv": "^8.2.0", "dotenv": "^8.2.0",
"jsonwebtoken": "^8.5.1", "jsonwebtoken": "^8.5.1",
"lambert-server": "^1.1.7", "lambert-server": "^1.1.7",

View File

@ -1,10 +1,9 @@
import "missing-native-js-functions"; import "missing-native-js-functions";
import dotenv from "dotenv"; import dotenv from "dotenv";
dotenv.config(); dotenv.config();
import { db } from "@fosscord/server-util"; import { Config, db } from "@fosscord/server-util";
import { Server as WebSocketServer } from "ws"; import { Server as WebSocketServer } from "ws";
import { Connection } from "./events/Connection"; import { Connection } from "./events/Connection";
import Config from "./util/Config";
// TODO: only listen/start the server if everything got initalized // TODO: only listen/start the server if everything got initalized
// https://www.npmjs.com/package/ws use "External HTTP/S server" and listen manually at the end of listen() // https://www.npmjs.com/package/ws use "External HTTP/S server" and listen manually at the end of listen()
@ -37,8 +36,8 @@ export class Server {
// @ts-ignore // @ts-ignore
await (db as Promise<Connection>); await (db as Promise<Connection>);
await this.setupSchema(); await this.setupSchema();
console.log("[DB] connected");
await Config.init(); await Config.init();
console.log("[DB] connected");
console.log(`[Gateway] online on 0.0.0.0:${port}`); console.log(`[Gateway] online on 0.0.0.0:${port}`);
} }
} }

View File

@ -11,6 +11,7 @@ import {
UserModel, UserModel,
toObject, toObject,
EVENTEnum, EVENTEnum,
Config,
} from "@fosscord/server-util"; } from "@fosscord/server-util";
import { setupListener } from "../listener/listener"; import { setupListener } from "../listener/listener";
import { IdentifySchema } from "../schema/Identify"; import { IdentifySchema } from "../schema/Identify";
@ -29,7 +30,8 @@ export async function onIdentify(this: WebSocket, data: Payload) {
const identify: IdentifySchema = data.d; const identify: IdentifySchema = data.d;
try { try {
var decoded = await checkToken(identify.token); // will throw an error if invalid const { jwtSecret } = Config.get().security;
var decoded = await checkToken(identify.token, jwtSecret); // will throw an error if invalid
} catch (error) { } catch (error) {
console.error("invalid token", error); console.error("invalid token", error);
return this.close(CLOSECODES.Authentication_failed); return this.close(CLOSECODES.Authentication_failed);

View File

@ -70,15 +70,16 @@ export async function onLazyRequest(this: WebSocket, { d }: Payload) {
const items = []; const items = [];
for (const role of roles) { for (const role of roles) {
items.push({ items.push({
group: { group: {
count: role.members.length, count: role.members.length,
id: role.id, id: role.id === guild_id ? "online" : role.name
}, }
}); });
for (const member of role.members) { for (const member of role.members) {
items.push({ member }); member.roles.remove(guild_id);
} items.push({ member });
}
} }
return Send(this, { return Send(this, {
@ -90,7 +91,7 @@ export async function onLazyRequest(this: WebSocket, { d }: Payload) {
{ {
range: [0, 99], range: [0, 99],
op: "SYNC", op: "SYNC",
items: items, items,
}, },
], ],
online_count: member_count, // TODO count online count online_count: member_count, // TODO count online count

View File

@ -1,21 +1,41 @@
// @ts-nocheck
import { Config } from "@fosscord/server-util"; import { Config } from "@fosscord/server-util";
import { getConfigPathForFile } from "@fosscord/server-util/dist/util/Config";
export default { import Ajv, { JSONSchemaType } from "ajv";
init() {
return Config.init({ gateway: DefaultOptions });
},
get() {
return Config.getAll().gateway;
},
set(val: any) {
return Config.setAll({ gateway: val });
},
getAll: Config.getAll,
setAll: Config.setAll,
};
export interface DefaultOptions { export interface DefaultOptions {
endpoint?: string; endpoint?: string;
security: {
jwtSecret: string;
};
} }
export const DefaultOptions: DefaultOptions = {}; const schema: JSONSchemaType<DefaultOptions> = {
type: "object",
properties: {
endpoint: {
type: "string",
nullable: true,
},
security: {
type: "object",
properties: {
jwtSecret: {
type: "string",
},
},
required: ["jwtSecret"],
},
},
required: ["security"],
};
const ajv = new Ajv();
const validator = ajv.compile(schema);
const configPath = getConfigPathForFile("fosscord", "gateway", ".json");
export const gatewayConfig = new Config<DefaultOptions>({
path: configPath,
schemaValidator: validator,
schema: schema,
});