mirror of
https://github.com/nestriness/nestri.git
synced 2025-12-12 16:55:37 +02:00
## Description - [x] Adds support for AWS SSO, which makes us (the team) able to use SST and update the components independently - [x] Splits the webpage into the landing page (Qwik), and Astro (the console) in charge of playing. This allows us to pass in Environment Variables to the console - ~Migrates the docs from Nuxt to Nextjs, and connects them to SST. This allows us to use Fumadocs _citation needed_ that's much more beautiful, and supports OpenApi~ - Cloudflare pages with github integration is not working on our new CF account. So we will have to push the pages deployment manually with Github actions - [x] Moves the current set up from my personal CF and AWS accounts to dedicated Nestri accounts - ## Related Issues <!-- List any related issues (e.g., "Closes #123", "Fixes #456") --> ## Type of Change - [ ] Bug fix (non-breaking change) - [x] New feature (non-breaking change) - [ ] Breaking change (fix or feature that changes existing functionality) - [x] Documentation update - [ ] Other (please describe): ## Checklist - [x] I have updated relevant documentation - [x] My code follows the project's coding style - [x] My changes generate no new warnings/errors ## Notes for Reviewers <!-- Point out areas you'd like reviewers to focus on, questions you have, or decisions that need discussion --> Please approve my PR 🥹 ## Screenshots/Demo <!-- If applicable, add screenshots or a GIF demo of your changes (especially for UI changes) --> ## Additional Context <!-- Add any other context about the pull request here -->
77 lines
2.3 KiB
TypeScript
77 lines
2.3 KiB
TypeScript
export const handleGithub = async (accessKey: string) => {
|
|
console.log("acceskey", accessKey)
|
|
|
|
const headers = {
|
|
Authorization: `token ${accessKey}`,
|
|
Accept: "application/vnd.github.v3+json",
|
|
"User-Agent": "Nestri"
|
|
};
|
|
|
|
try {
|
|
const [emails, user] = await Promise.all([
|
|
fetch("https://api.github.com/user/emails", { headers }).then(r => {
|
|
if (!r.ok) throw new Error(`Failed to fetch emails: ${r.status}`);
|
|
return r.json();
|
|
}),
|
|
fetch("https://api.github.com/user", { headers }).then(r => {
|
|
if (!r.ok) throw new Error(`Failed to fetch user: ${r.status}`);
|
|
return r.json();
|
|
})
|
|
]);
|
|
|
|
const primaryEmail = emails.find((email: { primary: boolean }) => email.primary);
|
|
|
|
if (!primaryEmail.verified) {
|
|
throw new Error("Email not verified");
|
|
}
|
|
// console.log("raw user", user)
|
|
|
|
const { email, primary, verified } = primaryEmail;
|
|
|
|
return {
|
|
primary: { email, primary, verified },
|
|
avatar: user.avatar_url,
|
|
username: user.name ?? user.login
|
|
};
|
|
} catch (error) {
|
|
console.error('GitHub OAuth error:', error);
|
|
throw error;
|
|
}
|
|
}
|
|
|
|
export const handleDiscord = async (accessKey: string) => {
|
|
try {
|
|
const response = await fetch("https://discord.com/api/v10/users/@me", {
|
|
headers: {
|
|
Authorization: `Bearer ${accessKey}`,
|
|
"Content-Type": "application/json",
|
|
},
|
|
});
|
|
|
|
if (!response.ok) {
|
|
throw new Error(`Discord API error: ${response.status}`);
|
|
}
|
|
|
|
const user = await response.json();
|
|
// console.log("raw user", user)
|
|
if (!user.verified) {
|
|
throw new Error("Email not verified");
|
|
}
|
|
|
|
return {
|
|
primary: {
|
|
email: user.email,
|
|
verified: user.verified,
|
|
primary: true
|
|
},
|
|
avatar: user.avatar
|
|
? `https://cdn.discordapp.com/avatars/${user.id}/${user.avatar}.png`
|
|
: null,
|
|
username: user.global_name ?? user.username
|
|
};
|
|
} catch (error) {
|
|
console.error('Discord OAuth error:', error);
|
|
throw error;
|
|
}
|
|
|
|
} |