Skip to content

Commit

Permalink
Merge pull request #553 from conwnet/master
Browse files Browse the repository at this point in the history
release 0.22.0
  • Loading branch information
conwnet authored Feb 25, 2024
2 parents 14dca90 + 85217b7 commit 6bef173
Show file tree
Hide file tree
Showing 75 changed files with 4,758 additions and 7,647 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);
}
};
5 changes: 4 additions & 1 deletion api/github-auth-callback/package.json
Original file line number Diff line number Diff line change
@@ -1,10 +1,13 @@
{
"name": "github-auth-callback",
"version": "0.0.0",
"main": "index.js",
"main": "index.ts",
"license": "MIT",
"private": true,
"dependencies": {
"got": "^11.8.5"
},
"devDependencies": {
"@vercel/node": "^3.0.20"
}
}
Loading

0 comments on commit 6bef173

Please sign in to comment.