Skip to content

Commit

Permalink
Merge branch 'feature/gitlab' into dependabot/npm_and_yarn/extensions…
Browse files Browse the repository at this point in the history
…/github1s/browserify-sign-4.2.2
  • Loading branch information
BTCRob1993 committed Nov 13, 2023
2 parents 84f2b11 + 42749de commit 637d294
Show file tree
Hide file tree
Showing 28 changed files with 3,054 additions and 74 deletions.
59 changes: 0 additions & 59 deletions api/github-auth-callback/index.js

This file was deleted.

71 changes: 71 additions & 0 deletions api/github-auth-callback/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
/**
* @file github auth callback
* @author netcon
*/

import got from 'got';
import type { VercelRequest, VercelResponse } from '@vercel/node';

const CLIENT_ID = process.env.GITHUB_OAUTH_ID || '';
const CLIENT_SECRET = process.env.GITHUB_OAUTH_SECRET || '';
// allow origins should split by ','
const ALLOWED_ORIGINS = process.env.GITHUB1S_ALLOWED_ORIGINS || '';

const createResponseHtml = (text: string, script: string) => `
<!DOCTYPE html>
<html lang="en">
<head>
<title>Connect to GitHub</title>
</head>
<body>
<h1>${text}</h1>
<script>${script}</script>
</body>
</html>
`;

// return the data to the opener window by postMessage API,
// and close current window if successfully connected
const createAuthorizeResultHtml = (data: Record<any, any>) => {
const errorText = 'Failed! You can close this window and retry.';
const successText = 'Connected! You can now close this window.';
const resultStr = `{ type: 'authorizing', payload: ${JSON.stringify(data)} }`;
const script = `
'${ALLOWED_ORIGINS}'.split(',').forEach(function(allowedOrigin) {
window.opener.postMessage(${resultStr}, allowedOrigin);
});
${data.error ? '' : 'setTimeout(() => window.close(), 50);'}`;
return createResponseHtml(data.error ? errorText : successText, script);
};

const MISSING_CODE_ERROR = {
error: 'request_invalid',
error_description: 'Missing code',
};
const UNKNOWN_ERROR = {
error: 'internal_error',
error_description: 'Unknown error',
};

export default async (req: VercelRequest, res: VercelResponse) => {
const code = req.query.code;
const sendResponseHtml = (status, data) => {
res.status(status);
res.send(createAuthorizeResultHtml(data));
};

if (!code) {
return sendResponseHtml(401, MISSING_CODE_ERROR);
}

try {
// https://docs.github.com/en/developers/apps/authorizing-oauth-apps#2-users-are-redirected-back-to-your-site-by-github
const response = await got.post('https://github.com/login/oauth/access_token', {
json: { client_id: CLIENT_ID, client_secret: CLIENT_SECRET, code },
responseType: 'json',
});
return sendResponseHtml(response.statusCode, response.body);
} catch (e) {
return sendResponseHtml(500, UNKNOWN_ERROR);
}
};
3 changes: 3 additions & 0 deletions api/github-auth-callback/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,5 +6,8 @@
"private": true,
"dependencies": {
"got": "^11.8.5"
},
"devDependencies": {
"@vercel/node": "^2.9.10"
}
}
Loading

0 comments on commit 637d294

Please sign in to comment.