2016-06-23 22:29:55 +00:00
|
|
|
import * as ActionTypes from '../../constants';
|
|
|
|
import { browserHistory } from 'react-router';
|
|
|
|
import axios from 'axios';
|
2016-06-09 20:28:21 +00:00
|
|
|
|
|
|
|
|
2016-06-20 17:29:32 +00:00
|
|
|
const ROOT_URL = location.href.indexOf('localhost') > 0 ? 'http://localhost:8000/api' : '/api';
|
2016-06-09 20:28:21 +00:00
|
|
|
|
2016-06-23 22:29:55 +00:00
|
|
|
export function authError(error) {
|
|
|
|
return {
|
|
|
|
type: ActionTypes.AUTH_ERROR,
|
|
|
|
payload: error
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2016-06-09 20:28:21 +00:00
|
|
|
export function signUpUser(formValues) {
|
2016-06-23 22:29:55 +00:00
|
|
|
return (dispatch) => {
|
|
|
|
axios.post(`${ROOT_URL}/signup`, formValues, { withCredentials: true })
|
2016-06-09 20:28:21 +00:00
|
|
|
.then(response => {
|
2016-06-14 18:46:40 +00:00
|
|
|
dispatch({ type: ActionTypes.AUTH_USER,
|
|
|
|
user: response.data
|
|
|
|
});
|
2016-06-09 20:28:21 +00:00
|
|
|
browserHistory.push('/');
|
|
|
|
})
|
|
|
|
.catch(response => dispatch(authError(response.data.error)));
|
2016-06-23 22:29:55 +00:00
|
|
|
};
|
2016-06-09 22:41:40 +00:00
|
|
|
}
|
|
|
|
|
2016-09-02 21:31:07 +00:00
|
|
|
// export function loginUser(formValues) {
|
|
|
|
// return (dispatch) => {
|
|
|
|
// axios.post(`${ROOT_URL}/login`, formValues, { withCredentials: true })
|
|
|
|
// .then(response => {
|
|
|
|
// dispatch({ type: ActionTypes.AUTH_USER,
|
|
|
|
// user: response.data
|
|
|
|
// });
|
|
|
|
// browserHistory.push('/');
|
|
|
|
// })
|
|
|
|
// .catch(response => {
|
|
|
|
// return Promise.reject({ email: response.data.message, _error: 'Login failed!' });
|
|
|
|
// });
|
|
|
|
// };
|
|
|
|
// }
|
|
|
|
|
2016-06-14 20:48:16 +00:00
|
|
|
export function loginUser(formValues) {
|
2016-09-02 21:31:07 +00:00
|
|
|
return axios.post(`${ROOT_URL}/login`, formValues, { withCredentials: true });
|
|
|
|
}
|
|
|
|
|
|
|
|
export function loginUserSuccess(user) {
|
|
|
|
return {
|
|
|
|
type: ActionTypes.AUTH_USER,
|
|
|
|
user
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function loginUserFailure(error) {
|
|
|
|
return {
|
|
|
|
type: ActionTypes.AUTH_ERROR,
|
|
|
|
error
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function validateAndLoginUser(formProps, dispatch) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
loginUser(formProps)
|
2016-06-14 20:48:16 +00:00
|
|
|
.then(response => {
|
|
|
|
dispatch({ type: ActionTypes.AUTH_USER,
|
2016-09-02 21:31:07 +00:00
|
|
|
user: response.data
|
2016-06-14 20:48:16 +00:00
|
|
|
});
|
|
|
|
browserHistory.push('/');
|
2016-09-02 21:31:07 +00:00
|
|
|
resolve();
|
2016-06-14 20:48:16 +00:00
|
|
|
})
|
2016-09-02 21:31:07 +00:00
|
|
|
.catch(response => {
|
2016-09-30 02:02:06 +00:00
|
|
|
reject({ password: response.data.message, _error: 'Login failed!' });
|
2016-09-02 21:31:07 +00:00
|
|
|
});
|
|
|
|
});
|
2016-06-14 20:48:16 +00:00
|
|
|
}
|
2016-06-09 22:41:40 +00:00
|
|
|
|
2016-06-14 23:11:42 +00:00
|
|
|
export function getUser() {
|
2016-06-23 22:29:55 +00:00
|
|
|
return (dispatch) => {
|
|
|
|
axios.get(`${ROOT_URL}/session`, { withCredentials: true })
|
2016-06-14 23:11:42 +00:00
|
|
|
.then(response => {
|
2016-06-23 22:29:55 +00:00
|
|
|
dispatch({
|
|
|
|
type: ActionTypes.AUTH_USER,
|
2016-06-14 23:11:42 +00:00
|
|
|
user: response.data
|
|
|
|
});
|
2016-08-09 21:50:45 +00:00
|
|
|
dispatch({
|
|
|
|
type: ActionTypes.SET_PREFERENCES,
|
|
|
|
preferences: response.data.preferences
|
|
|
|
});
|
2016-06-14 23:11:42 +00:00
|
|
|
})
|
2016-08-09 22:45:59 +00:00
|
|
|
.catch(response => {
|
|
|
|
dispatch(authError(response.data.error));
|
|
|
|
});
|
2016-06-09 22:41:40 +00:00
|
|
|
};
|
2016-06-23 22:29:55 +00:00
|
|
|
}
|
2016-08-28 00:46:20 +00:00
|
|
|
|
|
|
|
export function logoutUser() {
|
|
|
|
return (dispatch) => {
|
|
|
|
axios.get(`${ROOT_URL}/logout`, { withCredentials: true })
|
|
|
|
.then(() => {
|
|
|
|
dispatch({
|
|
|
|
type: ActionTypes.UNAUTH_USER
|
|
|
|
});
|
|
|
|
})
|
|
|
|
.catch(response => dispatch(authError(response.data.error)));
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2016-10-12 21:19:43 +00:00
|
|
|
export function initiateResetPassword(formValues) {
|
2016-10-12 18:25:24 +00:00
|
|
|
return (dispatch) => {
|
2016-10-19 15:34:08 +00:00
|
|
|
dispatch({
|
|
|
|
type: ActionTypes.RESET_PASSWORD_INITIATE
|
|
|
|
});
|
2016-10-12 21:19:43 +00:00
|
|
|
axios.post(`${ROOT_URL}/reset-password`, formValues, { withCredentials: true })
|
|
|
|
.then(() => {
|
2016-10-19 15:34:08 +00:00
|
|
|
// do nothing
|
2016-10-12 18:25:24 +00:00
|
|
|
})
|
2016-10-12 21:19:43 +00:00
|
|
|
.catch(response => dispatch({
|
|
|
|
type: ActionTypes.ERROR,
|
|
|
|
message: response.data
|
|
|
|
}));
|
|
|
|
};
|
2016-10-12 18:25:24 +00:00
|
|
|
}
|
|
|
|
|
2016-10-12 21:19:43 +00:00
|
|
|
export function resetPasswordReset() {
|
|
|
|
return {
|
|
|
|
type: ActionTypes.RESET_PASSWORD_RESET
|
|
|
|
};
|
|
|
|
}
|
2016-10-18 20:07:25 +00:00
|
|
|
|
|
|
|
export function validateResetPasswordToken(token) {
|
|
|
|
return (dispatch) => {
|
|
|
|
axios.get(`${ROOT_URL}/reset-password/${token}`)
|
|
|
|
.then(() => {
|
|
|
|
// do nothing if the token is valid
|
|
|
|
})
|
|
|
|
.catch(() => dispatch({
|
|
|
|
type: ActionTypes.INVALID_RESET_PASSWORD_TOKEN
|
|
|
|
}));
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function updatePassword(token, formValues) {
|
|
|
|
return (dispatch) => {
|
|
|
|
axios.post(`${ROOT_URL}/reset-password/${token}`, formValues)
|
|
|
|
.then((response) => {
|
|
|
|
dispatch(loginUserSuccess(response.data));
|
|
|
|
browserHistory.push('/');
|
|
|
|
})
|
|
|
|
.catch(() => dispatch({
|
|
|
|
type: ActionTypes.INVALID_RESET_PASSWORD_TOKEN
|
|
|
|
}));
|
|
|
|
};
|
|
|
|
}
|