2023-01-18 03:05:49 +01:00
|
|
|
/*
|
2023-03-30 16:51:15 +02:00
|
|
|
Spacebar: A FOSS re-implementation and extension of the Discord.com backend.
|
2023-03-30 17:15:42 +02:00
|
|
|
Copyright (C) 2023 Spacebar and Spacebar Contributors
|
2023-01-18 03:05:49 +01:00
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU Affero General Public License as published
|
|
|
|
by the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU Affero General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2022-12-17 07:14:49 +01:00
|
|
|
/*
|
2023-03-31 06:52:33 +02:00
|
|
|
Regenerates the `spacebarchat/server/assets/schemas.json` file, used for API/Gateway input validation.
|
2022-12-17 07:14:49 +01:00
|
|
|
*/
|
|
|
|
|
2021-09-26 11:34:06 +02:00
|
|
|
const path = require("path");
|
|
|
|
const fs = require("fs");
|
|
|
|
const TJS = require("typescript-json-schema");
|
2023-01-18 03:05:49 +01:00
|
|
|
const walk = require("./util/walk");
|
2021-09-21 22:52:30 +02:00
|
|
|
const schemaPath = path.join(__dirname, "..", "assets", "schemas.json");
|
2021-09-18 01:49:36 +02:00
|
|
|
|
2021-09-21 22:52:30 +02:00
|
|
|
const settings = {
|
2021-09-18 01:49:36 +02:00
|
|
|
required: true,
|
|
|
|
ignoreErrors: true,
|
|
|
|
excludePrivate: true,
|
|
|
|
defaultNumberType: "integer",
|
|
|
|
noExtraProps: true,
|
2022-09-26 14:29:30 +02:00
|
|
|
defaultProps: false,
|
2021-09-18 01:49:36 +02:00
|
|
|
};
|
2021-09-21 22:52:30 +02:00
|
|
|
const compilerOptions = {
|
2022-09-26 14:29:30 +02:00
|
|
|
strictNullChecks: true,
|
2021-09-18 01:49:36 +02:00
|
|
|
};
|
2021-09-21 22:52:30 +02:00
|
|
|
const Excluded = [
|
|
|
|
"DefaultSchema",
|
|
|
|
"Schema",
|
|
|
|
"EntitySchema",
|
2021-09-18 01:49:36 +02:00
|
|
|
"ServerResponse",
|
|
|
|
"Http2ServerResponse",
|
|
|
|
"global.Express.Response",
|
|
|
|
"Response",
|
|
|
|
"e.Response",
|
|
|
|
"request.Response",
|
2022-07-02 12:41:40 +02:00
|
|
|
"supertest.Response",
|
|
|
|
|
|
|
|
// TODO: Figure out how to exclude schemas from node_modules?
|
|
|
|
"SomeJSONSchema",
|
|
|
|
"UncheckedPartialSchema",
|
|
|
|
"PartialSchema",
|
|
|
|
"UncheckedPropertiesSchema",
|
|
|
|
"PropertiesSchema",
|
|
|
|
"AsyncSchema",
|
|
|
|
"AnySchema",
|
2023-03-24 23:14:47 +01:00
|
|
|
"SMTPConnection.CustomAuthenticationResponse",
|
|
|
|
"TransportMakeRequestResponse",
|
2021-09-18 01:49:36 +02:00
|
|
|
];
|
|
|
|
|
2021-10-01 21:30:36 +02:00
|
|
|
function modify(obj) {
|
|
|
|
for (var k in obj) {
|
|
|
|
if (typeof obj[k] === "object" && obj[k] !== null) {
|
|
|
|
modify(obj[k]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-18 01:49:36 +02:00
|
|
|
function main() {
|
2022-10-24 10:46:33 +02:00
|
|
|
const program = TJS.programFromConfig(
|
2022-12-22 04:30:03 +01:00
|
|
|
path.join(__dirname, "..", "tsconfig.json"),
|
2023-01-05 07:12:21 +01:00
|
|
|
walk(path.join(__dirname, "..", "src", "util", "schemas")),
|
2022-10-24 10:46:33 +02:00
|
|
|
);
|
2021-09-18 01:49:36 +02:00
|
|
|
const generator = TJS.buildGenerator(program, settings);
|
|
|
|
if (!generator || !program) return;
|
|
|
|
|
2022-09-26 14:29:30 +02:00
|
|
|
let schemas = generator
|
|
|
|
.getUserSymbols()
|
|
|
|
.filter(
|
|
|
|
(x) =>
|
|
|
|
(x.endsWith("Schema") || x.endsWith("Response")) &&
|
|
|
|
!Excluded.includes(x),
|
|
|
|
);
|
2021-09-18 01:49:36 +02:00
|
|
|
console.log(schemas);
|
|
|
|
|
2021-09-21 22:52:30 +02:00
|
|
|
var definitions = {};
|
2021-09-18 01:49:36 +02:00
|
|
|
|
|
|
|
for (const name of schemas) {
|
2021-09-21 22:52:30 +02:00
|
|
|
const part = TJS.generateSchema(program, name, settings, [], generator);
|
2021-09-18 01:49:36 +02:00
|
|
|
if (!part) continue;
|
|
|
|
|
2023-01-06 08:05:26 +01:00
|
|
|
// this is a hack. want some want to check if its a @column, instead
|
2023-03-23 18:16:58 +01:00
|
|
|
if (part.properties) {
|
|
|
|
for (let key in part.properties) {
|
|
|
|
if (
|
2023-01-06 08:05:26 +01:00
|
|
|
[
|
|
|
|
// BaseClass methods
|
|
|
|
"toJSON",
|
|
|
|
"hasId",
|
|
|
|
"save",
|
|
|
|
"remove",
|
|
|
|
"softRemove",
|
|
|
|
"recover",
|
|
|
|
"reload",
|
|
|
|
"assign",
|
2023-03-23 18:16:58 +01:00
|
|
|
].includes(key)
|
|
|
|
) {
|
|
|
|
delete part.properties[key];
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2023-03-25 09:24:00 +01:00
|
|
|
// if (part.properties[key].anyOf) {
|
|
|
|
// const nullIndex = part.properties[key].anyOf.findIndex(
|
|
|
|
// (x) => x.type == "null",
|
|
|
|
// );
|
|
|
|
// if (nullIndex != -1) {
|
|
|
|
// part.properties[key].nullable = true;
|
|
|
|
// part.properties[key].anyOf.splice(nullIndex, 1);
|
|
|
|
|
|
|
|
// if (part.properties[key].anyOf.length == 1) {
|
|
|
|
// Object.assign(
|
|
|
|
// part.properties[key],
|
|
|
|
// part.properties[key].anyOf[0],
|
|
|
|
// );
|
|
|
|
// delete part.properties[key].anyOf;
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
2023-03-23 18:16:58 +01:00
|
|
|
}
|
|
|
|
}
|
2023-01-06 08:05:26 +01:00
|
|
|
|
2021-09-18 01:49:36 +02:00
|
|
|
definitions = { ...definitions, [name]: { ...part } };
|
|
|
|
}
|
|
|
|
|
2021-10-01 21:30:36 +02:00
|
|
|
modify(definitions);
|
|
|
|
|
2021-10-02 15:12:47 +02:00
|
|
|
fs.writeFileSync(schemaPath, JSON.stringify(definitions, null, 4));
|
2021-09-18 01:49:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
main();
|