ENEI2019-Public/App/app/store/actions/api.js

1078 lines
25 KiB
JavaScript
Raw Normal View History

2019-03-10 00:00:54 +00:00
import { AsyncStorage } from "react-native";
2019-03-12 03:34:40 +00:00
import { NetInfo, Alert } from "react-native";
2019-03-10 00:00:54 +00:00
var _ = require("lodash");
import {
TIMERWAIT_CHANGE,
SESSION_BLOCKS,
DATA_AVAILABLE,
API_LOGIN,
CHECK_USER,
LOGOUT_USER,
USER_INFO,
HOLD,
GET_EVENTS,
GET_CAREERS,
GET_SESSIONS,
CHANGE_GUEST,
WAIT_CHANGE,
SIGN_SESSION,
2019-03-11 16:15:51 +00:00
OPEN_MODAL,
2019-03-12 03:34:40 +00:00
LOADINGLOGIN,
REMOVE_SESSION
2019-03-10 00:00:54 +00:00
} from "./actionTypes"; //Import the actions types constant we defined in our actions
import moment from "moment";
import { compose } from "redux";
2019-03-08 18:24:01 +00:00
import tap from "lodash/fp/tap";
import flow from "lodash/fp/flow";
import groupBy from "lodash/fp/groupBy";
2019-03-10 18:28:14 +00:00
import { colors } from "react-native-elements";
2019-03-08 18:24:01 +00:00
2019-03-10 00:00:54 +00:00
const axios = require("axios");
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
axios.defaults.baseURL = "http://enei2019.uingress.com/internal/api";
2019-03-04 23:57:08 +00:00
//http://enei2019.uingress.com/internal/api/Attendee/Edit
2019-03-10 00:00:54 +00:00
const map = require("lodash/fp/map").convert({ cap: false });
2019-03-04 23:57:08 +00:00
2019-03-12 03:34:40 +00:00
export function waitLogin() {
return dispatch => {
2019-03-11 16:15:51 +00:00
dispatch({
2019-03-12 03:34:40 +00:00
type: LOADINGLOGIN
2019-03-11 16:15:51 +00:00
});
2019-03-12 03:34:40 +00:00
};
2019-03-11 16:15:51 +00:00
}
2019-03-12 03:34:40 +00:00
//faz autenticação com API interna
export function loginInternal(userDetails) {
2019-03-11 16:15:51 +00:00
axios.defaults.baseURL = "http://127.0.0.1:5000";
return dispatch => {
2019-03-12 03:34:40 +00:00
axios
.post("/api/login", {
username: "cena",
password: "password"
})
.then(a => {
console.log("sucesso!");
console.log(a);
})
.catch(p => {
console.log(p);
});
2019-03-11 16:15:51 +00:00
dispatch({
2019-03-12 03:34:40 +00:00
type: OPEN_MODAL
2019-03-11 16:15:51 +00:00
});
};
}
2019-03-10 00:00:54 +00:00
export function openModal(info, t) {
return dispatch => {
dispatch({
type: OPEN_MODAL,
modalInfo: info,
modalType: t
2019-03-04 23:57:08 +00:00
});
2019-03-10 00:00:54 +00:00
};
2019-03-04 23:57:08 +00:00
}
2019-03-10 00:00:54 +00:00
export function closeModal() {
return dispatch => {
dispatch({
type: OPEN_MODAL,
modalInfo: info
});
};
2019-03-04 23:57:08 +00:00
}
2019-03-10 00:00:54 +00:00
export function updateUser(token, user) {
axios.defaults.headers.common = {
Authorization: `bearer ${token.access_token}`
};
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
return dispatch => {
axios
.post("/Attendee/Edit", user)
.then(a => {
console.log(a);
alert("guardado com sucesso");
2019-03-08 18:24:01 +00:00
dispatch({
2019-03-10 00:00:54 +00:00
type: UPDATE_USER
// guests: response.data
});
})
.catch(b => {
alert("Erro a guardar os dados");
});
};
2019-03-01 19:35:36 +00:00
}
2019-03-10 18:28:14 +00:00
function getCareerPath(sessions) {
careerPath = "Sem Career Path";
careerColor = "white";
for (let key in sessions) {
if (sessions[key].Name == "IA") {
careerPath = "Artificial Inteligence";
2019-03-12 03:34:40 +00:00
careerColor = "#CC1A17";
2019-03-10 18:28:14 +00:00
}
if (sessions[key].Name == "IOT") {
careerPath = "Internet of Things";
2019-03-12 03:34:40 +00:00
careerColor = "green";
2019-03-10 18:28:14 +00:00
}
if (sessions[key].Name == "WEB") {
careerPath = "Web Development";
2019-03-12 03:34:40 +00:00
careerColor = "purple";
2019-03-10 18:28:14 +00:00
}
if (sessions[key].Name == "NET") {
careerPath = "Networking and Security";
2019-03-12 03:34:40 +00:00
careerColor = "blue";
2019-03-10 18:28:14 +00:00
}
if (sessions[key].Name == "MOB") {
careerPath = "Mobile Development";
2019-03-12 03:34:40 +00:00
careerColor = "orange";
2019-03-10 18:28:14 +00:00
}
2019-03-12 03:34:40 +00:00
if (sessions[key].Name == "DS") {
careerPath = "Data Science";
careerColor = "yellow";
2019-03-10 18:28:14 +00:00
}
}
return { name: careerPath, color: careerColor };
}
2019-03-10 00:00:54 +00:00
export const waitChangeGuest = () => {
return dispatch => {
dispatch({
type: WAIT_CHANGE
});
2019-02-22 23:38:34 +00:00
};
2019-03-10 00:00:54 +00:00
};
export const timerChangeGuest = () => {
return dispatch => {
dispatch({
type: TIMERWAIT_CHANGE
});
};
};
2019-02-22 23:38:34 +00:00
2019-03-10 00:00:54 +00:00
export const connectionState = status => {
console.log(status);
return { type: "CHANGE_CONNECTION_STATUS", isConnected: status };
};
2019-02-22 23:38:34 +00:00
2019-03-12 03:34:40 +00:00
export function removeSession(user,token, idSession) {
2019-03-10 00:00:54 +00:00
axios.defaults.headers.common = {
Authorization: `bearer ${token.access_token}`
};
2019-02-22 23:38:34 +00:00
2019-03-10 00:00:54 +00:00
var obj = {
IdSession: idSession,
Direction: 0
};
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
return dispatch => {
//adiciona participante a uma palestra
axios
2019-03-12 03:34:40 +00:00
.post("/Session/RemoveAttendee", obj)
2019-03-10 00:00:54 +00:00
//se não existir erro na chamada...
.then(a => {
2019-03-12 03:34:40 +00:00
console.log(a)
2019-03-10 18:28:14 +00:00
if (a.data.Success) {
2019-03-10 00:00:54 +00:00
axios
.get("/Attendee/AvailableSessions")
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
.then(function(response) {
console.log(response);
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
var sessions = response.data;
2019-03-10 18:28:14 +00:00
var careerPath = getCareerPath(sessions);
2019-03-10 00:00:54 +00:00
var cenas = [];
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
const result = flow(groupBy("SessionStart"))(response.data);
2019-03-08 18:24:01 +00:00
2019-03-10 00:00:54 +00:00
for (let key in result) {
result[key].option = 0;
2019-03-08 18:24:01 +00:00
cenas.push(result[key]);
}
2019-03-12 03:34:40 +00:00
Alert.alert("Sucesso","A inscrição na sessão foi removida com sucesso!");
2019-03-08 18:24:01 +00:00
2019-03-10 18:28:14 +00:00
//obter informações pessoais:
axios
.get("/Attendee/Detail")
.catch(error => {
alert(error);
})
.then(sucess => {
dispatch({
2019-03-12 03:34:40 +00:00
type: REMOVE_SESSION,
2019-03-10 18:28:14 +00:00
sessions: response.data,
Blocks: cenas,
changeGuestList: false,
careerPath: careerPath,
user: sucess.data
});
2019-03-12 03:34:40 +00:00
getEvents(user);
2019-03-10 18:28:14 +00:00
});
2019-03-10 00:00:54 +00:00
})
.catch(function(error) {
2019-03-10 18:28:14 +00:00
alert("Erro a obter sessões disponíveis!!");
2019-03-08 18:24:01 +00:00
2019-03-10 00:00:54 +00:00
console.log(error);
});
} else {
2019-03-12 03:34:40 +00:00
2019-03-10 00:00:54 +00:00
alert("Erro a inscrever na palestra");
2019-03-10 18:28:14 +00:00
dispatch({
2019-03-12 03:34:40 +00:00
type: REMOVE_SESSION,
2019-03-10 18:28:14 +00:00
waitChangeGuest: false
});
2019-03-10 00:00:54 +00:00
}
})
.catch(b => {
alert("Erro a inscrever na palestra");
});
};
}
2019-02-28 23:52:58 +00:00
2019-03-12 03:34:40 +00:00
//inscrição em palestra através de ID
export function signSession(user,token, idSession) {
axios.defaults.headers.common = {
Authorization: `bearer ${token.access_token}`
};
var obj = {
IdSession: idSession,
Direction: 0
};
return dispatch => {
//adiciona participante a uma palestra
axios
.post("/Session/AddAttendee", obj)
//se não existir erro na chamada...
.then(a => {
if (a.data.Success) {
axios
.get("/Attendee/AvailableSessions")
.then(function(response) {
console.log(response);
var sessions = response.data;
var careerPath = getCareerPath(sessions);
var cenas = [];
const result = flow(groupBy("SessionStart"))(response.data);
for (let key in result) {
result[key].option = 0;
cenas.push(result[key]);
}
Alert.alert("Sucesso","Inscrição na sessão efectuada com sucesso");
//obter informações pessoais:
axios
.get("/Attendee/Detail")
.catch(error => {
alert(error);
})
.then(sucess => {
dispatch({
type: SIGN_SESSION,
sessions: response.data,
Blocks: cenas,
changeGuestList: false,
careerPath: careerPath,
user: sucess.data
});
getEvents(user);
});
})
.catch(function(error) {
console.log(error);
});
} else {
Alert.alert("ERRO!!",a.data.Error);
dispatch({
type: SIGN_SESSION,
waitChangeGuest: false
});
}
})
.catch(b => {
// alert("Erro a inscrever na palestra");
});
};
}
2019-03-10 00:00:54 +00:00
export function getSessions(token) {
axios.defaults.headers.common = {
Authorization: `bearer ${token.access_token}`
};
2019-03-08 18:24:01 +00:00
2019-03-10 00:00:54 +00:00
return dispatch => {
axios.defaults.baseURL = "http://enei2019.uingress.com/internal/api";
2019-03-08 18:24:01 +00:00
2019-03-10 00:00:54 +00:00
axios.defaults.headers.common = {
Authorization: `bearer ${token.access_token}`
};
2019-03-08 18:24:01 +00:00
2019-03-10 00:00:54 +00:00
axios
.get("/Attendee/AvailableSessions")
.then(function(response) {
var sessions = response.data;
2019-03-10 18:28:14 +00:00
var careerPath = getCareerPath(sessions);
console.log(careerPath);
2019-03-10 00:00:54 +00:00
var cenas = [];
2019-03-10 18:28:14 +00:00
2019-03-10 00:00:54 +00:00
const result = flow(
groupBy("SessionStart")
// map((Id) => ({Id})),
//tap(console.log)
)(response.data);
for (let key in result) {
result[key].option = 0;
cenas.push(result[key]);
}
dispatch({
type: GET_SESSIONS,
sessions: response.data,
Blocks: cenas,
careerPath: careerPath
//guests: response.data
2019-02-28 23:52:58 +00:00
});
2019-03-10 00:00:54 +00:00
})
.catch(function(error) {
alert("Error a obter sessões disponíveis!!");
console.log(error);
});
};
2019-02-28 23:52:58 +00:00
}
2019-03-01 17:36:52 +00:00
2019-03-10 00:00:54 +00:00
export function getAvailableGuestlists(token) {
axios.defaults.headers.common = {
Authorization: `bearer ${token.access_token}`
};
2019-03-01 17:36:52 +00:00
2019-03-10 00:00:54 +00:00
return dispatch => {
axios
.get("/Attendee/AvailableGuestlists")
.then(function(response) {
// handle success
console.log(response);
dispatch({
type: GET_CAREERS,
guests: response.data
});
})
.catch(function(error) {
// handle error
console.log(error);
})
.then(function() {
// always executed
});
};
}
2019-03-01 17:36:52 +00:00
/*
8 - group
9 - IA
10 - NET
11 - MOB
12 - IOT
14 - WB
15 - DS
*/
2019-03-10 00:00:54 +00:00
export function changeGuestList(token, guestID) {
//http://enei2019.uingress.com/internal/api/Attendee/ChangeGuestlist/
2019-03-08 18:24:01 +00:00
2019-03-10 00:00:54 +00:00
axios.defaults.headers.common = {
Authorization: `bearer ${token.access_token}`
};
2019-03-08 18:24:01 +00:00
2019-03-10 00:00:54 +00:00
return dispatch => {
var full = `/Attendee/ChangeGuestlist/${guestID}`;
2019-03-08 18:24:01 +00:00
2019-03-10 00:00:54 +00:00
axios
.get(full)
.then(function(response) {
2019-03-12 03:34:40 +00:00
console.log(response);
2019-03-10 00:00:54 +00:00
axios.defaults.baseURL = "http://enei2019.uingress.com/internal/api";
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
axios.defaults.headers.common = {
Authorization: `bearer ${token.access_token}`
};
2019-03-01 17:36:52 +00:00
2019-03-10 00:00:54 +00:00
axios
.get("/Attendee/AvailableSessions")
2019-03-01 17:36:52 +00:00
2019-03-10 00:00:54 +00:00
.then(function(response) {
2019-03-01 17:36:52 +00:00
// handle success
2019-03-10 00:00:54 +00:00
//console.log(response);
var cenas = [];
2019-03-12 03:34:40 +00:00
c = getCareerPath(response.data);
2019-03-08 18:24:01 +00:00
const result = flow(
2019-03-10 00:00:54 +00:00
groupBy("SessionStart")
// map((Id) => ({Id})),
//tap(console.log)
)(response.data);
2019-03-10 18:28:14 +00:00
2019-03-10 00:00:54 +00:00
for (let key in result) {
result[key].option = 0;
cenas.push(result[key]);
console.log();
2019-03-08 18:24:01 +00:00
}
2019-03-10 00:00:54 +00:00
console.log(cenas);
2019-03-01 17:36:52 +00:00
dispatch({
2019-03-10 00:00:54 +00:00
type: CHANGE_GUEST,
sessions: response.data,
2019-03-10 18:28:14 +00:00
Blocks: cenas,
careerPath: c
2019-03-10 00:00:54 +00:00
//guests: response.data
});
})
.catch(function(error) {
2019-03-04 16:46:29 +00:00
alert("Error a obter sessões disponíveis!!");
2019-03-01 17:36:52 +00:00
console.log(error);
2019-03-10 00:00:54 +00:00
});
})
.catch(function(error) {
// handle error
console.log(response);
console.log(error);
alert("Erro a mudar de career path");
})
.then(function() {
// always executed
});
};
}
export function getSessionBlocks(sessions) {
var a;
var cenas = [];
const result = flow(
groupBy("SessionStart")
// map((Id) => ({Id})),
//tap(console.log)
)(sessions);
return dispatch => {
for (let key in result) {
cenas.push(result[key]);
console.log();
2019-03-01 17:36:52 +00:00
}
2019-03-10 00:00:54 +00:00
console.log(cenas);
2019-03-01 17:36:52 +00:00
2019-03-10 00:00:54 +00:00
dispatch({
type: SESSION_BLOCKS,
Blocks: cenas
});
};
2019-03-01 17:36:52 +00:00
}
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
export function getAvailableSessions(token) {
//http://enei2019.uingress.com/internal/api/Attendee/AvailableSessions
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
axios.defaults.baseURL = "http://enei2019.uingress.com/internal/api";
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
axios.defaults.headers.common = {
Authorization: `bearer ${token.access_token}`
};
2019-02-06 23:24:00 +00:00
2019-03-10 00:00:54 +00:00
return dispatch => {
axios
.get("/Attendee/AvailableSessions")
.then(function(response) {
// handle success
console.log(response);
var cenas = [];
const result = flow(
groupBy("SessionStart")
// map((Id) => ({Id})),
//tap(console.log)
)(response.data);
for (let key in result) {
cenas.push(result[key]);
console.log();
}
2019-02-06 23:24:00 +00:00
2019-03-10 00:00:54 +00:00
dispatch({
type: GET_SESSIONS,
sessions: response.data,
2019-02-08 18:56:38 +00:00
2019-03-10 00:00:54 +00:00
Blocks: cenas
});
2019-02-06 23:24:00 +00:00
})
2019-03-10 00:00:54 +00:00
.catch(function(error) {
alert("Error a obter sessões disponíveis!!");
console.log(error);
});
};
}
export function getEvents(user) {
return dispatch => {
let events = [];
console.log("chegou aqui");
2019-03-12 03:34:40 +00:00
var i = 0;
2019-03-10 00:00:54 +00:00
for (let key in user.Sessions) {
events.push({
2019-03-12 03:34:40 +00:00
key: i++,
2019-03-10 00:00:54 +00:00
time: moment(user.Sessions[key].SessionStart).format("HH:mm"),
timeEnd: moment(user.Sessions[key].SessionEnd).format("HH:mm"),
//lineColor:'#009688',
imageUrl:
"https://d2v9y0dukr6mq2.cloudfront.net/video/thumbnail/Vjkyj2hBg/welcome-white-sign-with-falling-colorful-confetti-animation-on-white-background_sglmmh3qm__F0013.png",
description: user.Sessions[key].Description,
name: user.Sessions[key].Name,
Enrolled: user.Sessions[key].Enrolled,
2019-03-10 20:17:58 +00:00
MaxAttendees: user.Sessions[key].MaxAttendees,
day: moment(user.Sessions[key].SessionStart).format("DD")
2019-03-10 00:00:54 +00:00
});
2019-02-28 23:52:58 +00:00
}
2019-03-10 20:17:58 +00:00
2019-03-12 03:34:40 +00:00
const result = flow(groupBy("day"))(events);
2019-02-06 23:24:00 +00:00
2019-03-12 03:34:40 +00:00
var cenas = [];
2019-03-10 20:17:58 +00:00
for (let key in result) {
cenas.push(result[key]);
console.log();
}
2019-03-12 03:34:40 +00:00
console.log(".--------");
2019-03-10 20:17:58 +00:00
console.log(cenas);
2019-03-12 03:34:40 +00:00
console.log(".--------");
var a = [],
b = [],
c = [],
d = [];
2019-03-10 20:17:58 +00:00
for (let key in cenas[0]) {
a.push({
2019-03-12 03:34:40 +00:00
time: cenas[0][key].time,
2019-03-10 20:17:58 +00:00
timeEnd: cenas[0][key].timeEnd,
2019-03-12 03:34:40 +00:00
imageUrl: cenas[0][key].imageUrl,
2019-03-10 20:17:58 +00:00
description: cenas[0][key].description,
2019-03-12 03:34:40 +00:00
name: cenas[0][key].name,
2019-03-10 20:17:58 +00:00
Enrolled: cenas[0][key].Enrolled,
MaxAttendees: cenas[0][key].MaxAttendees,
day: cenas[0][key].day
});
}
2019-03-12 03:34:40 +00:00
2019-03-10 20:17:58 +00:00
for (let key in cenas[1]) {
b.push({
2019-03-12 03:34:40 +00:00
time: cenas[1][key].time,
2019-03-10 20:17:58 +00:00
timeEnd: cenas[1][key].timeEnd,
2019-03-12 03:34:40 +00:00
imageUrl: cenas[1][key].imageUrl,
2019-03-10 20:17:58 +00:00
description: cenas[1][key].description,
2019-03-12 03:34:40 +00:00
name: cenas[1][key].name,
2019-03-10 20:17:58 +00:00
Enrolled: cenas[1][key].Enrolled,
MaxAttendees: cenas[1][key].MaxAttendees,
day: cenas[1][key].day
});
}
for (let key in cenas[2]) {
c.push({
2019-03-12 03:34:40 +00:00
time: cenas[2][key].time,
2019-03-10 20:17:58 +00:00
timeEnd: cenas[2][key].timeEnd,
2019-03-12 03:34:40 +00:00
imageUrl: cenas[2][key].imageUrl,
2019-03-10 20:17:58 +00:00
description: cenas[2][key].description,
2019-03-12 03:34:40 +00:00
name: cenas[2][key].name,
2019-03-10 20:17:58 +00:00
Enrolled: cenas[2][key].Enrolled,
MaxAttendees: cenas[2][key].MaxAttendees,
day: cenas[2][key].day
});
}
for (let key in cenas[3]) {
d.push({
2019-03-12 03:34:40 +00:00
time: cenas[3][key].time,
2019-03-10 20:17:58 +00:00
timeEnd: cenas[3][key].timeEnd,
2019-03-12 03:34:40 +00:00
imageUrl: cenas[3][key].imageUrl,
2019-03-10 20:17:58 +00:00
description: cenas[3][key].description,
2019-03-12 03:34:40 +00:00
name: cenas[3][key].name,
2019-03-10 20:17:58 +00:00
Enrolled: cenas[3][key].Enrolled,
MaxAttendees: cenas[3][key].MaxAttendees,
day: cenas[3][key].day
});
}
2019-03-12 03:34:40 +00:00
a = _.sortBy(a, function(o) {
return o.time;
});
b = _.sortBy(b, function(o) {
return o.time;
});
c = _.sortBy(c, function(o) {
return o.time;
});
d = _.sortBy(d, function(o) {
return o.time;
});
2019-02-28 23:52:58 +00:00
dispatch({
2019-03-10 00:00:54 +00:00
type: GET_EVENTS,
2019-03-12 03:34:40 +00:00
events: a,
day1: a,
day2: b,
day3: c,
day4: d
2019-02-28 23:52:58 +00:00
});
2019-03-10 00:00:54 +00:00
};
2019-02-06 23:24:00 +00:00
}
2019-01-31 00:46:49 +00:00
const saveToken = async token => {
2019-03-10 00:00:54 +00:00
try {
await AsyncStorage.setItem("refreshToken", token.refreshToken).catch(
a => {}
);
await AsyncStorage.setItem("userToken", token.access_token).catch(a => {});
await AsyncStorage.setItem(
"expirationDateToken",
token.expirationDateToken.toString()
).catch(a => {});
} catch (error) {
// Error retrieving data
console.log(error.message);
}
};
const getToken = async () => {
obj = {};
try {
obj.access_token = (await AsyncStorage.getItem("userToken")) || "none";
obj.expirationDateToken =
(await AsyncStorage.getItem("expirationDateToken")) || "none";
obj.refreshToken = (await AsyncStorage.getItem("refreshToken")) || "none";
} catch (error) {
// Error retrieving data
console.log(error.message);
}
return obj;
};
2019-01-31 00:46:49 +00:00
2019-03-10 00:00:54 +00:00
const deleteToken = async () => {
try {
await AsyncStorage.removeItem("userToken");
await AsyncStorage.removeItem("expirationDateToken");
await AsyncStorage.removeItem("refreshToken");
} catch (error) {
// Error retrieving data
console.log(error.message);
}
};
2019-01-31 00:46:49 +00:00
2019-03-10 00:00:54 +00:00
const renewToken = refresh => {};
2019-02-03 20:54:27 +00:00
2019-03-10 00:00:54 +00:00
export function login(user, pass) {
return dispatch => {
console.log("user: " + user + " password: " + pass);
2019-02-03 20:54:27 +00:00
2019-03-10 00:00:54 +00:00
var details = {
username: user,
password: pass,
grant_type: "password"
};
2019-02-03 20:54:27 +00:00
2019-03-10 00:00:54 +00:00
var formBody = [];
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
for (var property in details) {
var encodedKey = encodeURIComponent(property);
2019-01-31 00:46:49 +00:00
2019-03-10 00:00:54 +00:00
var encodedValue = encodeURIComponent(details[property]);
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
formBody.push(encodedKey + "=" + encodedValue);
2019-01-31 00:46:49 +00:00
}
2019-03-10 00:00:54 +00:00
formBody = formBody.join("&");
2019-02-06 23:24:00 +00:00
2019-03-10 00:00:54 +00:00
fetch("http://enei2019.uingress.com/internal/api/token", {
method: "POST",
2019-02-06 23:24:00 +00:00
2019-03-10 00:00:54 +00:00
headers: {
"Content-Type": "application/x-www-form-urlencoded;charset=UTF-8"
},
2019-01-31 00:46:49 +00:00
2019-03-10 00:00:54 +00:00
body: formBody
})
.catch(err => {
console.log(err);
alert("Erro no login!!");
2019-01-31 00:46:49 +00:00
2019-03-10 00:00:54 +00:00
alert("error");
co;
dispatch({
type: API_LOGIN,
logged: false,
failedAttempt: true,
2019-03-11 16:15:51 +00:00
tokenData: "error",
2019-03-12 03:34:40 +00:00
user: { Name: "" }
2019-03-10 00:00:54 +00:00
});
})
2019-03-12 03:34:40 +00:00
.catch(err => {
console.log("error");
2019-03-11 16:15:51 +00:00
})
2019-03-10 00:00:54 +00:00
.then(res => res.json())
.then(parsed => {
2019-03-12 03:34:40 +00:00
console.log(parsed);
2019-03-10 00:00:54 +00:00
if (
parsed.error_description ==
"Provided username and password is incorrect"
) {
2019-03-12 03:34:40 +00:00
Alert.alert(
"Dados Inválidos",
"Podes sempre fazer reset da password para o email."
);
2019-03-10 00:00:54 +00:00
dispatch({
type: API_LOGIN,
logged: false,
failedAttempt: true,
token: obj,
2019-03-11 16:15:51 +00:00
user: { Name: "Henrique" },
2019-03-12 03:34:40 +00:00
userDetails: {},
waitLogin: false,
onHold: false
2019-03-10 00:00:54 +00:00
});
2019-03-11 16:15:51 +00:00
return;
2019-03-12 03:34:40 +00:00
} else {
var obj = {
access_token: parsed.access_token,
expirationDateToken: Math.round(new Date().getTime() / 1000) + 3598,
refreshToken: parsed.refresh_token,
valid: true
};
var details = {
username: user,
password: pass
};
dispatch({
type: API_LOGIN,
logged: true,
failedAttempt: false,
token: obj,
user: { Name: "Henrique" },
userDetails: details
});
2019-03-10 00:00:54 +00:00
}
});
};
}
export function hold() {
return dispatch => {
dispatch({
type: HOLD,
onHold: true
});
};
2019-02-03 20:54:27 +00:00
}
2019-03-10 00:00:54 +00:00
export function getUserInfo(token) {
return dispatch => {
//TODO: verificar validade do token
2019-02-06 23:24:00 +00:00
2019-03-10 00:00:54 +00:00
console.log('Chamada "getUserInfo"');
2019-02-06 23:24:00 +00:00
2019-03-10 00:00:54 +00:00
var obj = {
method: "GET",
headers: {
Authorization: `Bearer ${token.access_token}`
}
};
2019-02-22 23:38:34 +00:00
2019-03-10 00:00:54 +00:00
fetch("http://enei2019.uingress.com/internal/api/Attendee/Detail", obj)
.then(function(res) {
console.log(res);
let obj = JSON.parse(res._bodyText);
2019-02-03 20:54:27 +00:00
2019-03-10 00:00:54 +00:00
dispatch({ type: USER_INFO, user: obj, onHold: false, logged: true });
})
.catch(function(res) {
console.log("erro");
// dispatch({ type: USER_INFO,onHold:false});
alert("Erro a obter a informação pessoal.");
});
};
2019-01-31 00:46:49 +00:00
}
2019-03-10 00:00:54 +00:00
export function logoutUser() {
return dispatch => {
deleteToken()
.then(a => {
console.log("token apagado");
dispatch({
type: LOGOUT_USER,
loggedIn: false,
tokenData: "error",
token: false
});
})
.catch(err => {
console.log("errors");
});
};
2019-01-31 00:46:49 +00:00
}
2019-02-03 20:54:27 +00:00
//
2019-03-10 00:00:54 +00:00
function refreshToken() {
refresh = a.refreshToken;
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
//chamar funçao para renovar
console.log("expirou");
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
var details = {
grant_type: "refresh_token",
refresh_token: refresh
};
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
var formBody = [];
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
for (var property in details) {
var encodedKey = encodeURIComponent(property);
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
var encodedValue = encodeURIComponent(details[property]);
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
formBody.push(encodedKey + "=" + encodedValue);
}
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
formBody = formBody.join("&");
fetch("http://enei2019.uingress.com/internal/api/token", {
method: "POST",
headers: {
"Content-Type": "application/x-www-form-urlencoded;charset=UTF-8"
},
body: formBody
})
.then(res => res.json())
.then(parsed => {
console.log(parsed);
if (parsed.error == "invalid_grant") {
console.log(formBody);
dispatch({ type: CHECK_USER, token: "", logged: false, onHold: false });
} else {
var obj = {
access_token: parsed.access_token,
expirationDateToken: Math.round(new Date().getTime() / 1000) + 3598,
refreshToken: parsed.refresh_token,
valid: true
2019-02-27 11:22:43 +00:00
};
2019-03-10 00:00:54 +00:00
// deleteToken();
saveToken(obj).then(a => {
console.log("Token guardado");
console.log(obj);
dispatch({
type: CHECK_USER,
token: obj,
logged: true,
onHold: false
});
});
}
2019-02-27 11:22:43 +00:00
})
2019-03-10 00:00:54 +00:00
.catch(a => {
console.log("erro na api");
dispatch({ type: CHECK_USER, token: "", logged: false, onHold: false });
});
2019-02-27 11:22:43 +00:00
}
2019-03-10 00:00:54 +00:00
refreshLogin = async (user, pass) => {
console.log("login");
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
console.log("user: " + user + " password: " + pass);
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
var details = {
username: user,
password: pass,
grant_type: "password"
};
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
var formBody = [];
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
for (var property in details) {
var encodedKey = encodeURIComponent(property);
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
var encodedValue = encodeURIComponent(details[property]);
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
formBody.push(encodedKey + "=" + encodedValue);
}
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
formBody = formBody.join("&");
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
fetch("http://enei2019.uingress.com/internal/api/token", {
method: "POST",
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
headers: {
"Content-Type": "application/x-www-form-urlencoded;charset=UTF-8"
},
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
body: formBody
})
.catch(err => {
console.log(err);
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
alert("error");
})
.then(res => res.json())
.then(parsed => {
if (
parsed.error_description ==
"Provided username and password is incorrect"
) {
console.error("cenas da vida");
} else {
console.log(parsed);
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
var obj = {
access_token: parsed.access_token,
expirationDateToken: Math.round(new Date().getTime() / 1000) + 3598,
refreshToken: parsed.refresh_token,
valid: true
};
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
go();
return obj;
}
});
};
go = t => {
dispatch({
type: CHECK_USER,
logged: true,
onHold: false,
user: { Name: "Henrique" },
token: t
});
};
export function checkUser(userDetails) {
var u = userDetails;
return dispatch => {
//verifica se existe utilizador em memória
if (
userDetails.username != undefined &&
userDetails.username != "" &&
userDetails.password != undefined &&
userDetails.password != ""
) {
//verifica a validade do token
if (
Math.round(new Date().getTime() / 1000) >=
userDetails.token.expirationDateToken
) {
var details = {
username: userDetails.username,
password: userDetails.password,
grant_type: "password"
};
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
var formBody = [];
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
for (var property in details) {
var encodedKey = encodeURIComponent(property);
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
var encodedValue = encodeURIComponent(details[property]);
2019-02-28 23:52:58 +00:00
2019-03-10 00:00:54 +00:00
formBody.push(encodedKey + "=" + encodedValue);
2019-02-27 11:22:43 +00:00
}
2019-03-10 00:00:54 +00:00
formBody = formBody.join("&");
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
fetch("http://enei2019.uingress.com/internal/api/token", {
method: "POST",
2019-02-27 11:22:43 +00:00
2019-03-10 00:00:54 +00:00
headers: {
"Content-Type": "application/x-www-form-urlencoded;charset=UTF-8"
},
body: formBody
})
.catch(err => {
alert("Erro a validar o utilizador");
})
.then(res => res.json())
.then(parsed => {
if (
parsed.error_description ==
"Provided username and password is incorrect"
) {
alert("Ups, password ou utilizador errada");
} else {
console.log(parsed);
var obj = {
access_token: parsed.access_token,
expirationDateToken:
Math.round(new Date().getTime() / 1000) + 3598,
refreshToken: parsed.refresh_token,
valid: true
};
dispatch({
type: CHECK_USER,
logged: true,
onHold: false,
userDetails: u,
token: obj
});
2019-02-27 11:22:43 +00:00
}
2019-03-10 00:00:54 +00:00
});
} else {
console.log(
"Tempo restante token: " +
Math.round(
(userDetails.token.expirationDateToken -
Math.round(new Date().getTime() / 1000)) /
60
) +
" Minutos"
);
//dispatch home
dispatch({
type: CHECK_USER,
logged: true,
onHold: false,
user: { Name: "Henrique" },
userDetails: u
});
}
}
//utilizador não existe em memória
else {
dispatch({
type: CHECK_USER,
logged: false,
onHold: false,
userDetails: u
});
//dispatch menu de login
}
};
}