![Oracle Drags Its Feet in the JavaScript Trademark Dispute](https://cdn.sanity.io/images/cgdhsj6q/production/919c3b22c24f93884c548d60cbb338e819ff2435-1024x1024.webp?w=400&fit=max&auto=format)
Security News
Oracle Drags Its Feet in the JavaScript Trademark Dispute
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
redux-fire-auth
Advanced tools
Helper to keep the Redux State in sync with the Firebase Auth State.
Helper to keep the Redux State in sync with the Firebase Auth State.
When you start playing with Firebase auth, you will soon realize that when the page refreshes, you loose authentication state until the SDK kicks back in.
Wouldn't it be nice if you could tell if the Firebase SDK have finished initializing and if there's a logged in user? Well :wink:
First, obviously,
$ npm install redux-fire-auth firebase redux --save
Then just initialize it:
import firebase from 'firebase';
import { applyMiddleware, createStore, combineReducers } from 'redux';
// This is us!
import createAuthEnhancer, { authReducer } from 'redux-fire-auth';
import * as yourReducers from './your-reducers.js';
// ...
// Initialize your firebase app.
const app = firebase.initializeApp({/* Firebase Configs */});
const auth = app.auth();
// Combine your reducers with ours \o/
const reducer = combineReducers({
auth: authReducer,
...yourReducers,
});
// Build the middleware.
const authEnhancer = createAuthEnhancer(auth);
// Create your store.
const store = createStore(reducer, applyMiddleware(authEnhancer));
// Yup. That easy.
This enhancer will bind to Firebase's onAuthStateChanged
with action creators. Whenever there's an authStateChanged event, the redux state will sync automatically.
You can listen to actions inside your own reducers by importing the action types import { AUTH_STATE_CHANGED, DONE_LOADING } from 'redux-fire-auth'
. Our actions are FSA compliant.
Note: If you'd want to use something other than auth
to bind the reducer to, you need to pass the key you want to use to createAuthEnhancer(authInstance, key)
as the second argument.
When you call store.getState().auth
you'll get an object with three properties:
True while the Firebase SDK is initializing, then always false.
False while the Firebase SDK is initializing, then if the SDK recovers the session it's true, else it stays false.
null while the Firebase SDK is initializing, then if the SDK recovers the session it's the User.toJSON() object, without the User methods provided by firebase, else it stays null.
I'm assuming you know how to work with React and React-Redux for this example :grin:
import React from 'react';
import { connect } from 'react-redux';
export function App({ isLoading, hasAuth, user }) {
if (isLoading) {
return (
<div> Loading... </div>
);
}
if (hasAuth) {
return (
<div> Hello { user.displayName } </div>
);
}
return (
<div> Please sign in. </div>
);
}
export default connect(({ auth }) => auth)(App);
If you've liked this, consider giving it a :star:!
MIT all the way. Let's create awesome stuff! :rocket:
FAQs
Helper to keep the Redux State in sync with the Firebase Auth State.
We found that redux-fire-auth demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
Security News
The Linux Foundation is warning open source developers that compliance with global sanctions is mandatory, highlighting legal risks and restrictions on contributions.
Security News
Maven Central now validates Sigstore signatures, making it easier for developers to verify the provenance of Java packages.