mirror of
https://github.com/wassname/talk.git
synced 2026-06-27 21:09:01 +08:00
84bbc3d0c3
* feat: initial impl * Create preliminary comment moderation slices CORL-688 * Move slices logic into stacks CORL-688 * Create user comment counts CORL-688 * Create naive mutation that initializes user comment counts CORL-688 * Use bulk updates in user counts migration CORL-688 * fix: review * fix: fixed issue with aggregation * Migrate creating comment into stacks CORL-688 * Migrate editing a comment to the stacks CORL-688 * Break publishing comment status out of updateAllCounts CORL-688 * review: removed variable scoping in favor of export * revert: feb8e8196cd448f5cd24f1ca2eb0b91fe9bd43c7 * review: simplification of stacks implementation This simplifies the stacks implementation to better reuse code related to count management and event publishing. This can be used to great effect with the upcomming events PR #2738. * Consolidate the tenant and common context together CORL-688 * review: removed variable scoping in favor of export * revert: feb8e8196cd448f5cd24f1ca2eb0b91fe9bd43c7 * review: simplification of stacks implementation This simplifies the stacks implementation to better reuse code related to count management and event publishing. This can be used to great effect with the upcomming events PR #2738. * fix: check if authorID is null before update user counts CORL-688 * Consolidate common/tenant context supporting files CORL-688 * feat: renamed TenantContext -> GraphContext Co-authored-by: Wyatt Johnson <accounts+github@wyattjoh.ca>
80 lines
1.9 KiB
JavaScript
80 lines
1.9 KiB
JavaScript
const { generateTSTypesAsString } = require("graphql-schema-typescript");
|
|
const { getGraphQLConfig } = require("graphql-config");
|
|
const path = require("path");
|
|
const fs = require("fs");
|
|
|
|
async function main() {
|
|
const config = getGraphQLConfig(__dirname);
|
|
const projects = config.getProjects();
|
|
|
|
const files = [
|
|
{
|
|
name: "tenant",
|
|
fileName: path.join(
|
|
__dirname,
|
|
"../src/core/server/graph/schema/__generated__/types.ts"
|
|
),
|
|
config: {
|
|
contextType: "GraphContext",
|
|
importStatements: [
|
|
'import GraphContext from "coral-server/graph/context";',
|
|
'import { Cursor } from "coral-server/models/helpers";',
|
|
],
|
|
customScalarType: { Cursor: "Cursor", Time: "Date" },
|
|
},
|
|
},
|
|
{
|
|
name: "tenant",
|
|
fileName: path.join(
|
|
__dirname,
|
|
"../src/core/client/framework/schema/__generated__/types.ts"
|
|
),
|
|
config: {
|
|
smartTResult: true,
|
|
smartTParent: true,
|
|
},
|
|
},
|
|
];
|
|
|
|
for (const file of files) {
|
|
// Load the graph schema.
|
|
const schema = projects[file.name].getSchema();
|
|
|
|
// Create the generated directory.
|
|
const dir = path.dirname(file.fileName);
|
|
if (!fs.existsSync(dir)) {
|
|
fs.mkdirSync(dir);
|
|
}
|
|
|
|
// Create the types for this file.
|
|
const types = await generateTSTypesAsString(schema, {
|
|
tabSpaces: 2,
|
|
typePrefix: "GQL",
|
|
strictNulls: false,
|
|
...file.config,
|
|
});
|
|
|
|
fs.writeFileSync(file.fileName, types);
|
|
}
|
|
|
|
return files;
|
|
}
|
|
|
|
module.exports = main;
|
|
|
|
if (require.main === module) {
|
|
// Only run the main module on file load if this is the main module (we're
|
|
// executing this file directly).
|
|
main()
|
|
.then(files => {
|
|
for (const { fileName } of files) {
|
|
// eslint-disable-next-line no-console
|
|
console.log(`Generated ${fileName}`);
|
|
}
|
|
})
|
|
.catch(err => {
|
|
// eslint-disable-next-line no-console
|
|
console.error(err);
|
|
});
|
|
}
|