From a9f30bda05be3ec015add29dac9afd966733f6a7 Mon Sep 17 00:00:00 2001 From: Lucas Bubner Date: Wed, 16 Aug 2023 22:07:19 +0930 Subject: [PATCH] GitHub login support --- src/Firebase.ts | 14 ++++++++------ src/chat/Chat.tsx | 2 +- src/chat/Login.tsx | 6 +++++- src/css/Login.css | 19 ++++++++++++++----- 4 files changed, 28 insertions(+), 13 deletions(-) diff --git a/src/Firebase.ts b/src/Firebase.ts index 36dc0cd..c614bac 100755 --- a/src/Firebase.ts +++ b/src/Firebase.ts @@ -7,7 +7,7 @@ // https://firebase.google.com/docs/web/setup#available-libraries import { useEffect } from "react"; import { getApp, initializeApp } from "firebase/app"; -import { getAuth, GoogleAuthProvider, onAuthStateChanged, signInWithPopup } from "firebase/auth"; +import { getAuth, GoogleAuthProvider, GithubAuthProvider, onAuthStateChanged, signInWithPopup } from "firebase/auth"; import { child, get, @@ -156,10 +156,6 @@ export async function startMonitoring(email: string): Promise { export async function signOut(): Promise { if (!window.confirm("Sign out account: " + auth.currentUser?.email + "?")) return; - const onlineStatus = ref(db, `users/${toCommas(auth.currentUser?.email!)}/online`); - // Manually update user presence to be offline - await set(onlineStatus, false); - // Update last seen timestamp await set(ref(db, `users/${toCommas(auth.currentUser?.email!)}/online/lastseen`), serverTimestamp()); await auth.signOut(); @@ -175,7 +171,7 @@ export async function validateUsers(): Promise { userData.forEach((child) => { if (child.val().online === true) { // Set online value of child to offline if they are currently set to online - set(ref(db, `users/${child.key}/online`), serverTimestamp()); + set(ref(db, `users/${child.key}/online/lastseen`), serverTimestamp()); } }); } @@ -187,6 +183,12 @@ export function signInWithGoogle(): void { }); } +export function signInWithGitHub(): void { + signInWithPopup(auth, new GithubAuthProvider()).catch((error) => { + console.error(`GitHub OAuth Failure: ${error.message}`); + }); +} + // Change dots to commas, db names that are supported export function toCommas(str: string): string { return str.replace(/\./g, ","); diff --git a/src/chat/Chat.tsx b/src/chat/Chat.tsx index 2cf4f2b..b82b7a2 100644 --- a/src/chat/Chat.tsx +++ b/src/chat/Chat.tsx @@ -33,7 +33,7 @@ function Chat() { if (!auth.currentUser) return; // Block unauthorised users from accessing the application getData("users", toCommas(auth.currentUser.email!)).then((userData) => { - if (!userData.read) { + if (!userData || !userData.read) { try { alert( `Access denied to ${ diff --git a/src/chat/Login.tsx b/src/chat/Login.tsx index 36b29f3..966fd9c 100755 --- a/src/chat/Login.tsx +++ b/src/chat/Login.tsx @@ -5,7 +5,7 @@ * @author Lachlan Paul, 2023 */ -import { signInWithGoogle } from "../Firebase"; +import { signInWithGoogle, signInWithGitHub } from "../Firebase"; import "../css/Login.css"; function Login() { @@ -36,6 +36,10 @@ function Login() { +     +

Application developed by
diff --git a/src/css/Login.css b/src/css/Login.css index 7823fd3..4f1aade 100644 --- a/src/css/Login.css +++ b/src/css/Login.css @@ -1,9 +1,10 @@ /* - * Styling for initial user landing page, with app name and Google sign in prompt. + * Styling for initial user landing page, with app name and Google/GitHub sign in prompt. * Author: Lachlan Paul, 2023 */ -.googlebtn { +.googlebtn, +.githubbtn { transition: background-color 0.3s, box-shadow 0.3s; padding: 12px 16px 12px 42px; border: none; @@ -18,6 +19,11 @@ background-position: 12px 14px; } +.githubbtn { + background-image: url(); + background-size: 16px; +} + .center { display: flex; flex-direction: column; @@ -27,16 +33,19 @@ min-height: 100vh; } -.googlebtn:hover { +.googlebtn:hover, +.githubbtn:hover { box-shadow: 0 -1px 0 rgba(0, 0, 0, 0.04), 0 2px 4px rgba(0, 0, 0, 0.25); cursor: pointer; } -.googlebtn:active { +.googlebtn:active, +.githubbtn:active { background-color: #999999; } -.googlebtn:focus { +.googlebtn:focus, +.githubbtn:focus { outline: none; box-shadow: 0 -1px 0 rgba(0, 0, 0, 0.04), 0 2px 4px rgba(0, 0, 0, 0.25), 0 0 0 3px #c8dafc; }