//common var domain = ''; // domain name var urlpath = ''; // sub url path, like: www.example.com/ //settings var debug = false; var GOOGLE_API_KEY = ''; var GOOGLE_CLIENT_ID = ''; var DROPBOX_APP_KEY = ''; var port = window.location.port; var serverurl = window.location.protocol + '//' + (domain ? domain : window.location.hostname) + (port ? ':' + port : '') + (urlpath ? '/' + urlpath : ''); var noteid = urlpath ? window.location.pathname.slice(urlpath.length + 1, window.location.pathname.length).split('/')[1] : window.location.pathname.split('/')[1]; var noteurl = serverurl + '/' + noteid; var version = '0.4.4'; var checkAuth = false; var profile = null; var lastLoginState = getLoginState(); var lastUserId = getUserId(); var loginStateChangeEvent = null; function resetCheckAuth() { checkAuth = false; } 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(); } function checkLoginStateChanged() { if (getLoginState() != lastLoginState || getUserId() != lastUserId) { if(loginStateChangeEvent) loginStateChangeEvent(); return true; } else { return false; } } function getLoginState() { var state = Cookies.get('loginstate'); return state === "true" || state === true; } function getUserId() { return Cookies.get('userid'); } function clearLoginState() { Cookies.remove('loginstate'); } function checkIfAuth(yesCallback, noCallback) { var cookieLoginState = getLoginState(); if (checkLoginStateChanged()) checkAuth = false; if (!checkAuth || typeof cookieLoginState == 'undefined') { $.get(serverurl + '/me') .done(function (data) { if (data && data.status == 'ok') { profile = data; yesCallback(profile); setLoginState(true, data.id); } else { noCallback(); setLoginState(false); } }) .fail(function () { noCallback(); }) .always(function () { checkAuth = true; }); } else if (cookieLoginState) { yesCallback(profile); } else { noCallback(); } }