Skip to content

Instantly share code, notes, and snippets.

View heytulsiprasad's full-sized avatar
⚛️
Overreacting

Tulsi Prasad heytulsiprasad

⚛️
Overreacting
View GitHub Profile
@heytulsiprasad
heytulsiprasad / redirectOnResponse.js
Created June 11, 2021 16:29
Redirect user to route passing custom token as URL param
// Web: React
import { auth } from "./config/firebase";
auth.onAuthStateChanged((user) => {
if (user) {
user.getIdToken(true).then((idToken) => {
// This is where to call the API
const requestOptions = {
@heytulsiprasad
heytulsiprasad / obtainCustomToken.js
Created June 11, 2021 16:14
Express backed that sends out customtoken for verified users
// Backend: Node - Express
const express = require("express");
const admin = require("firebase-admin");
// Setup firebase admin [HERE]
// Route that handles GET request
app.post("/verify-token", (req, res) => {
@heytulsiprasad
heytulsiprasad / sendIdToken.js
Created June 11, 2021 16:04
Send the idToken after authentication to server to generate customToken
// Web: React
import { auth } from "./config/firebase";
auth.onAuthStateChanged((user) => {
if (user) {
user.getIdToken(true).then((idToken) => {
// This is where to call the API
const requestOptions = {
@heytulsiprasad
heytulsiprasad / WebViewInApp.js
Created June 11, 2021 15:58
Basic usage of React Native Webview
// Mobile: React Native
import React, {useState, useEffect} from 'react';
import { View } from 'react-native';
import {Button} from 'react-native-paper';
import { WebView } from 'react-native-webview';
const App = () => {
const [show, setShow] = useState({isOpen: false, url: null});
@heytulsiprasad
heytulsiprasad / FirstWebViewComponent.js
Last active June 14, 2021 13:03
Basic usage of React Native Webview inside a component
import React from 'react';
import {SafeAreaView, StatusBar} from 'react-native';
import {WebView} from 'react-native-webview';
const App = () => {
return (
<>
<StatusBar barStyle="dark-content" />
<SafeAreaView style={{flex: 1}}>
<WebView source={{uri: 'https://medium.com/'}} />
@heytulsiprasad
heytulsiprasad / signInWithAuthProvider.js
Last active June 11, 2021 16:55
Basic sign in using third party auth provider using Firebase
export const signInUserWithAuthProvider = async (
authProvider: AuthProvider
) => {
firebase.auth().tenantId = authProvider.tenantId;
const provider = new firebase.auth.SAMLAuthProvider(authProvider.provider);
firebase.auth().signInWithRedirect(provider);
const authResult = await firebase.auth().getRedirectResult();
return authResult;
@heytulsiprasad
heytulsiprasad / signInUserWithFirebase.js
Last active June 11, 2021 16:55
Basic email and password signin with Firebase
const signInUser = () => {
return firebase.auth().signInWithEmailAndPassword(email, password);
}
@heytulsiprasad
heytulsiprasad / getAuthProviderResponse.json
Last active June 14, 2021 12:47
Response given by Auth Provider API
{ "tenantId": "some-random-tenant", "provider": "third.party" }
@heytulsiprasad
heytulsiprasad / getAuthProvider.js
Last active June 11, 2021 16:54
API to get the right auth provider for each user
export const getAuthProvider = async (email: string) => {
const response = await fetch(`${backendUrl}/auth-provider?email=${email}`, {
method: "GET",
headers: {
"Content-type": "application/json"
},
credentials: "include"
});
return response.json();
@heytulsiprasad
heytulsiprasad / data_structure.js
Created February 10, 2021 11:23
For lazzzy app
///////////////////////////////////////////////////////////////////
/**
* currentPages is an array of objects which holds each active page
* on the browser.
*
* page: {
* id: <string>,
* url: <string>,
* author: <string>,