Skip to content

Commit

Permalink
feat: added support for websocket subscriptions
Browse files Browse the repository at this point in the history
  • Loading branch information
acaldas committed Jun 18, 2024
1 parent a3ae46b commit 968588a
Show file tree
Hide file tree
Showing 10 changed files with 763 additions and 402 deletions.
7 changes: 5 additions & 2 deletions api/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -28,9 +28,9 @@
"body-parser": "^1.20.2",
"cookie-parser": "^1.4.6",
"cors": "^2.8.5",
"document-drive": "1.0.0-alpha.74",
"document-drive": "1.0.0-alpha.76",
"document-model": "1.5.0",
"document-model-libs": "^1.58.0",
"document-model-libs": "^1.60.1",
"dotenv": "^16.4.5",
"esbuild": "^0.21.2",
"ethers": "^5.7.2",
Expand All @@ -41,6 +41,7 @@
"graphql-playground-html": "^1.6.30",
"graphql-playground-middleware-express": "^1.7.23",
"graphql-request": "^7.0.1",
"graphql-ws": "^5.16.0",
"json-stringify-deterministic": "^1.0.12",
"jsonwebtoken": "^9.0.2",
"ms": "^2.1.3",
Expand All @@ -56,6 +57,7 @@
"vite-node": "^0.29.8",
"vitest": "^0.32.4",
"wildcard-match": "^5.1.3",
"ws": "^8.17.1",
"zod": "^3.22.4"
},
"devDependencies": {
Expand All @@ -68,6 +70,7 @@
"@types/jsonwebtoken": "^9.0.6",
"@types/ms": "^0.7.34",
"@types/node": "^20.12.12",
"@types/ws": "^8.5.10",
"@typescript-eslint/eslint-plugin": "^5.62.0",
"@typescript-eslint/parser": "^5.62.0",
"@vitest/coverage-istanbul": "^0.29.8",
Expand Down
79 changes: 67 additions & 12 deletions api/pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

72 changes: 44 additions & 28 deletions api/src/app.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,28 +2,31 @@ import type { Express } from 'express';
import express from 'express';
import { getChildLogger } from './logger';
import basePrisma from './database';
import {
renderPlaygroundPage,
} from 'graphql-playground-html'
import * as Sentry from "@sentry/node";
import { nodeProfilingIntegration } from "@sentry/profiling-node";
import { renderPlaygroundPage } from 'graphql-playground-html';
import * as Sentry from '@sentry/node';
import { nodeProfilingIntegration } from '@sentry/profiling-node';
import bodyParser from 'body-parser';
import prisma from './database';

import { dependencies } from "../package.json"

import { dependencies } from '../package.json';

const logger = getChildLogger({ msgPrefix: 'APP' });
const startupTime = new Date();

export const createApp = (): { app: Express, router: express.Router } => {
export const createApp = (): { app: Express; router: express.Router } => {
logger.debug('Creating app');
const app = express();
const router = express.Router();

// fixes request entity too large
app.use(bodyParser.json({ limit: "50mb" }));
app.use(bodyParser.urlencoded({ limit: "50mb", extended: true, parameterLimit: 50000 }));
app.use(bodyParser.json({ limit: '50mb' }));
app.use(
bodyParser.urlencoded({
limit: '50mb',
extended: true,
parameterLimit: 50000,
})
);

if (process.env.SENTRY_DSN) {
Sentry.init({
Expand All @@ -42,6 +45,7 @@ export const createApp = (): { app: Express, router: express.Router } => {
/Drive with id .+ not found/,
/Document with id .+ not found/,
/Drive not found/,
/Invalid listener id/,
],
});

Expand All @@ -67,41 +71,53 @@ export const createApp = (): { app: Express, router: express.Router } => {
});

app.get('/versions', async (req, res) => {
const { "document-drive": docDrive, "document-model": docModel, "document-model-libs": docModelLibs } = dependencies
res.send({ "document-drive": docDrive, "document-model": docModel, "document-model-libs": docModelLibs })
})

router.get(
'/explorer/:driveId?',
(req, res) => {
res.setHeader('Content-Type', 'text/html')
const basePath = process.env.BASE_PATH === "/" ? "" : process.env.BASE_PATH || '';
const endpoint = `${basePath}${req.params.driveId !== undefined ? `/d/${req.params.driveId}` : '/drives'}`
res.send(renderPlaygroundPage({
const {
'document-drive': docDrive,
'document-model': docModel,
'document-model-libs': docModelLibs,
} = dependencies;
res.send({
'document-drive': docDrive,
'document-model': docModel,
'document-model-libs': docModelLibs,
});
});

router.get('/explorer/:driveId?', (req, res) => {
res.setHeader('Content-Type', 'text/html');
const basePath =
process.env.BASE_PATH === '/' ? '' : process.env.BASE_PATH || '';
const endpoint = `${basePath}${
req.params.driveId !== undefined ? `/d/${req.params.driveId}` : '/drives'
}`;
res.send(
renderPlaygroundPage({
endpoint: endpoint,
settings: {
'request.credentials': 'include',
},
}))
}
);
})
);
});

// Hooks
router.post('/h/github', async (req, res) => {
const issueId = req.body?.issue?.number;
const action = req.body?.action;

if (action !== "closed") {
if (action !== 'closed') {
return res.sendStatus(200);
}

if (!issueId) {
throw new Error('Issue number not found in request body')
throw new Error('Issue number not found in request body');
}

const result = await prisma.document.closeScopeOfWorkIssue(req.body.issue.number)
const result = await prisma.document.closeScopeOfWorkIssue(
req.body.issue.number
);
if (!result) {
throw new Error('Failed to close issue')
throw new Error('Failed to close issue');
}

return res.sendStatus(200).send(result);
Expand Down
Loading

0 comments on commit 968588a

Please sign in to comment.