diff options
| author | Yukai Huang | 2017-01-13 22:51:44 +0800 | 
|---|---|---|
| committer | Yukai Huang | 2017-01-13 23:06:31 +0800 | 
| commit | 0fca629c34b83617b2d72e42aa0edb66fd2e71f6 (patch) | |
| tree | 10cb832e1349c1eee884b2f9234b83b47a1a8684 /public/js/lib/common | |
| parent | c2a8911b9c7872ea0d085020aa17e82162130f3d (diff) | |
Rename common.js to login.js
Diffstat (limited to 'public/js/lib/common')
| -rw-r--r-- | public/js/lib/common/login.js | 92 | 
1 files changed, 92 insertions, 0 deletions
| diff --git a/public/js/lib/common/login.js b/public/js/lib/common/login.js new file mode 100644 index 00000000..12cc41fc --- /dev/null +++ b/public/js/lib/common/login.js @@ -0,0 +1,92 @@ +import { serverurl } from '../config'; + +let checkAuth = false; +let profile = null; +let lastLoginState = getLoginState(); +let lastUserId = getUserId(); +let loginStateChangeEvent = null; + +export function setloginStateChangeEvent(func) { +    loginStateChangeEvent = func; +} + +export function resetCheckAuth() { +    checkAuth = false; +} + +export function setLoginState(bool, id) { +    Cookies.set('loginstate', bool, { +        expires: 365 +    }); +    if (id) { +        Cookies.set('userid', id, { +            expires: 365 +        }); +    } else { +        Cookies.remove('userid'); +    } +    lastLoginState = bool; +    lastUserId = id; +    checkLoginStateChanged(); +} + +export function checkLoginStateChanged() { +    if (getLoginState() != lastLoginState || getUserId() != lastUserId) { +        if(loginStateChangeEvent) { +            loginStateChangeEvent(); +        } +        return true; +    } else { +        return false; +    } +} + +export function getLoginState() { +    const state = Cookies.get('loginstate'); +    return state === "true" || state === true; +} + +export function getUserId() { +    return Cookies.get('userid'); +} + +export function clearLoginState() { +    Cookies.remove('loginstate'); +} + +export function checkIfAuth(yesCallback, noCallback) { +    const cookieLoginState = getLoginState(); +    if (checkLoginStateChanged()) +        checkAuth = false; +    if (!checkAuth || typeof cookieLoginState == 'undefined') { +        $.get(`${serverurl}/me`) +            .done(data => { +                if (data && data.status == 'ok') { +                    profile = data; +                    yesCallback(profile); +                    setLoginState(true, data.id); +                } else { +                    noCallback(); +                    setLoginState(false); +                } +            }) +            .fail(() => { +                noCallback(); +            }) +            .always(() => { +                checkAuth = true; +            }); +    } else if (cookieLoginState) { +        yesCallback(profile); +    } else { +        noCallback(); +    } +} + +export default { +    checkAuth, +    profile, +    lastLoginState, +    lastUserId, +    loginStateChangeEvent +}; | 
