aretherecookies-mobile/js/AuthManager.js
2018-12-01 11:04:53 -06:00

70 lines
1.5 KiB
JavaScript

//@flow
// import { authFacebook, type FacebookAuth } from './apis/FacebookAuth';
import { type GoogleUser } from './apis/GoogleAuth';
import { type Auth0User, loginAuth0 } from './apis/Auth0';
import moment from 'moment';
export const AUTH_PROVIDER_FACEBOOK: 'facebook' = 'facebook';
export const AUTH_PROVIDER_GOOGLE: 'google' = 'google';
export const AUTH_PROVIDER_AUTH0: 'auth0' = 'auth0';
export type AUTH_PROVIDER =
| typeof AUTH_PROVIDER_FACEBOOK
| typeof AUTH_PROVIDER_GOOGLE
| typeof AUTH_PROVIDER_AUTH0;
export type User = {
name: string,
token: string,
tokenExpires: number,
email: string,
photo: string,
provider: AUTH_PROVIDER,
};
class AuthManager {
user: ?User;
getToken = () => {
return this.user && this.user.token;
};
getAuthHeader = () => {
const { token, provider } = this.user || {};
switch (provider) {
case AUTH_PROVIDER_FACEBOOK:
return { authorization: `facebook-token ${token}` };
default:
return {};
}
};
isLoggedIn = () => {
if (!this.user) {
return false;
}
const { token, tokenExpires } = this.user;
return token && +moment(tokenExpires) >= +moment();
};
setAuth0User = (auth0User: Auth0User) => {
if (!auth0User) {
return;
}
this.user = {
token: auth0User.accessToken,
tokenExpires: +moment().add(auth0User.expiresIn, 'seconds'),
};
};
authenticate = async () => {
this.setAuth0User(await loginAuth0());
};
deauthenticate = () => {
this.user = null;
};
}
export default new AuthManager();