UNPKG

@stackend/api

Version:

JS bindings to api.stackend.com

153 lines 6.96 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; var __generator = (this && this.__generator) || function (thisArg, body) { var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; function verb(n) { return function (v) { return step([n, v]); }; } function step(op) { if (f) throw new TypeError("Generator is already executing."); while (_) try { if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; if (y = 0, t) op = [op[0] & 2, t.value]; switch (op[0]) { case 0: case 1: t = op; break; case 4: _.label++; return { value: op[1], done: false }; case 5: _.label++; y = op[1]; op = [0]; continue; case 7: op = _.ops.pop(); _.trys.pop(); continue; default: if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } if (t[2]) _.ops.pop(); _.trys.pop(); continue; } op = body.call(thisArg, _); } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; } }; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.authenticateUsingCredentials = exports.receiveLoginData = exports.refreshLoginData = exports.reduxLogout = exports.reduxLogin = void 0; var loginReducer_1 = require("./loginReducer"); var user_1 = require("../user"); var api_1 = require("../api"); var get_1 = __importDefault(require("lodash/get")); var AccessToken_1 = require("../api/AccessToken"); var LOGIN_TTL = 60 * 1000; function reduxLogin() { return { type: loginReducer_1.LOGIN }; } exports.reduxLogin = reduxLogin; function reduxLogout() { return { type: loginReducer_1.LOGOUT }; } exports.reduxLogout = reduxLogout; function requestLoginData() { return { type: loginReducer_1.REQUEST_LOGIN_DATA }; } /** * Refresh the current user. Cached 1 minute. * @param params { force?:boolean } * @returns */ function refreshLoginData(params) { var _this = this; return function (dispatch, getState) { return __awaiter(_this, void 0, void 0, function () { var currentUser, useCache, now, json, e_1; return __generator(this, function (_a) { switch (_a.label) { case 0: _a.trys.push([0, 2, , 3]); currentUser = getState().currentUser; useCache = !(0, get_1.default)(params, 'force', false); // Don't refresh more than once a minute if logged in if (useCache && typeof currentUser !== 'undefined' && currentUser.isLoggedIn) { now = new Date().getTime(); if (now - currentUser.lastUpdate < LOGIN_TTL) { return [2 /*return*/]; } } dispatch(requestLoginData()); return [4 /*yield*/, dispatch((0, user_1.getCurrentUser)())]; case 1: json = _a.sent(); return [2 /*return*/, dispatch(receiveLoginData(json))]; case 2: e_1 = _a.sent(); console.error("Couldn't refreshLoginData: ", e_1); return [3 /*break*/, 3]; case 3: return [2 /*return*/]; } }); }); }; } exports.refreshLoginData = refreshLoginData; function receiveLoginData(json) { return { type: loginReducer_1.UPDATE_LOGIN_DATA, json: json }; } exports.receiveLoginData = receiveLoginData; /** * Authenticate a user using its credentials. * @param credentials optional credentials * @param community optional community name */ function authenticateUsingCredentials(_a) { var _this = this; var credentials = _a.credentials, community = _a.community; return function (dispatch, getState) { return __awaiter(_this, void 0, void 0, function () { var at, r; return __generator(this, function (_a) { switch (_a.label) { case 0: if (!credentials) { credentials = (0, AccessToken_1.getPersistentData)(); } at = (0, AccessToken_1.getAccessTokenValue)(); if (!at && (!credentials || Object.keys(credentials).length == 0)) { return [2 /*return*/, (0, api_1.newXcapJsonResult)('success', { user: null, authenticatedToCommunities: [] })]; } return [4 /*yield*/, dispatch((0, api_1.post)({ url: '/user/get-current', community: community, parameters: { credentials: JSON.stringify(credentials) } }))]; case 1: r = _a.sent(); if (!r.error) { dispatch(receiveLoginData({ user: r.user })); } return [2 /*return*/, r]; } }); }); }; } exports.authenticateUsingCredentials = authenticateUsingCredentials; //# sourceMappingURL=loginAction.js.map