add basic login flow

This commit is contained in:
Stanislaw-Golebiewski 2020-01-12 22:02:06 +01:00
parent cbedfbe4fb
commit 6eebfce42a
5 changed files with 65 additions and 50 deletions

View File

@ -33,7 +33,8 @@ REST_FRAMEWORK = {
'rest_framework.permissions.IsAuthenticated', 'rest_framework.permissions.IsAuthenticated',
# 'rest_framework.permissions.AllowAny', # 'rest_framework.permissions.AllowAny',
], ],
'DEFAULT_AUTHENTICATION_CLASSES': ('knox.auth.TokenAuthentication', 'rest_framework.authentication.SessionAuthentication'), 'DEFAULT_AUTHENTICATION_CLASSES': ['knox.auth.TokenAuthentication'],
# 'DEFAULT_AUTHENTICATION_CLASSES': ('knox.auth.TokenAuthentication', 'rest_framework.authentication.SessionAuthentication'),
# 'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination', # 'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination',
# 'PAGE_SIZE': 10 # 'PAGE_SIZE': 10
} }

View File

@ -8038,11 +8038,6 @@
} }
} }
}, },
"js-cookie": {
"version": "2.2.1",
"resolved": "https://registry.npmjs.org/js-cookie/-/js-cookie-2.2.1.tgz",
"integrity": "sha512-HvdH2LzI/EAZcUwA8+0nKNtWHqS+ZmijLA30RwZA0bo7ToCckjK5MkGhjED9KoRcXO6BaGI3I9UIzSA1FKFPOQ=="
},
"js-levenshtein": { "js-levenshtein": {
"version": "1.1.6", "version": "1.1.6",
"resolved": "https://registry.npmjs.org/js-levenshtein/-/js-levenshtein-1.1.6.tgz", "resolved": "https://registry.npmjs.org/js-levenshtein/-/js-levenshtein-1.1.6.tgz",
@ -13304,6 +13299,11 @@
"resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz",
"integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==" "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ=="
}, },
"use-global-hook": {
"version": "0.1.12",
"resolved": "https://registry.npmjs.org/use-global-hook/-/use-global-hook-0.1.12.tgz",
"integrity": "sha512-KhsWfDaa4jXgGHKDSxmBP0GjnIs5ad12y1vhl5mGBDcIiFfj3oB9vdfZZZCCPlZ14gI+tjCKZtb82+bPEwj3Iw=="
},
"util": { "util": {
"version": "0.10.3", "version": "0.10.3",
"resolved": "https://registry.npmjs.org/util/-/util-0.10.3.tgz", "resolved": "https://registry.npmjs.org/util/-/util-0.10.3.tgz",

View File

@ -7,14 +7,14 @@
"@testing-library/react": "^9.3.2", "@testing-library/react": "^9.3.2",
"@testing-library/user-event": "^7.1.2", "@testing-library/user-event": "^7.1.2",
"axios": "^0.19.0", "axios": "^0.19.0",
"js-cookie": "^2.2.1",
"react": "^16.12.0", "react": "^16.12.0",
"react-dom": "^16.12.0", "react-dom": "^16.12.0",
"react-minimal-pie-chart": "^6.0.1", "react-minimal-pie-chart": "^6.0.1",
"react-router-dom": "^5.1.2", "react-router-dom": "^5.1.2",
"react-scripts": "3.3.0", "react-scripts": "3.3.0",
"semantic-ui-calendar-react": "^0.15.3", "semantic-ui-calendar-react": "^0.15.3",
"semantic-ui-react": "^0.88.2" "semantic-ui-react": "^0.88.2",
"use-global-hook": "^0.1.12"
}, },
"scripts": { "scripts": {
"start": "react-scripts start", "start": "react-scripts start",

View File

@ -1,16 +1,17 @@
import React, { useState } from "react"; import React, { useState, useEffect } from "react";
import { import {
Button, Button,
Form, Form,
Grid, Grid,
Segment, Segment,
Container, Container,
Image Image,
Message
} from "semantic-ui-react"; } from "semantic-ui-react";
import { useHistory } from "react-router-dom"; import { useHistory } from "react-router-dom";
import axios from "axios"; import axios from "axios";
import Cookies from "js-cookie";
import useGlobal from "../../utils/global_state";
import logo from "../../img/logo_project.svg"; import logo from "../../img/logo_project.svg";
import "./Login.css"; import "./Login.css";
@ -18,49 +19,18 @@ function Login() {
const [username, setUsername] = useState(""); const [username, setUsername] = useState("");
const [password, setPassword] = useState(""); const [password, setPassword] = useState("");
const history = useHistory(); const history = useHistory();
const [globalState, globalActions] = useGlobal();
const handleSubmit = () => { const handleSubmit = () => {
// console.log(process.env); globalActions.login({ username, password });
const bodyFormData = new FormData();
bodyFormData.set("username", username);
bodyFormData.set("password", password);
axios({
method: "get",
url: "http://api.app.localhost.pl/api-auth/login/",
withCredentials: true
// data: bodyFormData,
// headers: { "Content-Type": "multipart/form-data" }
})
.then(function(response) {
//handle success
console.log("success");
const csrfToken = Cookies.get("csrftoken");
console.log(csrfToken);
axios({
method: "post",
url: "http://api.app.localhost.pl/api-auth/login/",
withCredentials: true,
data: bodyFormData,
// headers: { "X-CSRFToken": csrfToken },
xsrfCookieName: "XSRF-TOKEN",
xsrfHeaderName: "X-CSRFToken"
})
.then(resp => {
console.log("success x 2!!!");
console.log(resp);
})
.catch(err => {
console.log(err);
});
})
.catch(function(response) {
//handle error
console.log("error");
console.log(response);
});
}; };
useEffect(() => {
if (globalState.is_authenticated) {
history.push("/home");
}
});
return ( return (
<Container className="login-container"> <Container className="login-container">
<Grid columns={1} verticalAlign="middle" style={{ height: "100%" }}> <Grid columns={1} verticalAlign="middle" style={{ height: "100%" }}>
@ -98,6 +68,11 @@ function Login() {
</Button> </Button>
</Form> </Form>
</Segment> </Segment>
{globalState.auth_error != "" && (
<Message>
<p>Błąd: {globalState.auth_error}</p>
</Message>
)}
</Grid.Column> </Grid.Column>
</Grid> </Grid>
</Container> </Container>

View File

@ -0,0 +1,39 @@
import React from "react";
import globalHook from "use-global-hook";
import axios from "axios";
const initialState = {
auth_token: "",
auth_error: "",
is_authenticated: false
};
const actions = {
login: (store, { username, password }) => {
console.log("Try to login...");
axios
.post("/api/auth/login/", { username: username, password: password })
.then(resp => {
console.log(resp.data);
const newToken = resp.data.token;
store.setState({
auth_token: newToken,
is_authenticated: true,
auth_error: ""
});
})
.catch(err => {
console.log(err);
store.setState({
auth_error: "Podany login i/lub hasło są nieprawidłowe.",
is_authenticated: false
});
});
},
logout: store => {
console("logout");
}
};
const useGlobal = globalHook(React, initialState, actions);
export default useGlobal;