diff --git a/src/components/Login.vue b/src/components/Login.vue
index b5899cb..1ea77d6 100644
--- a/src/components/Login.vue
+++ b/src/components/Login.vue
@@ -1,26 +1,71 @@
Login
-
-
-
- Entrar
- {{ error }}
+
+
+
+
+
+ Entrar
+
+ {{ error }}
-
diff --git a/src/services/auth.js b/src/services/auth.js
index 8700ff3..600e643 100644
--- a/src/services/auth.js
+++ b/src/services/auth.js
@@ -2,19 +2,34 @@ class AuthService {
static TOKEN_KEY = 'access_token';
static REFRESH_KEY = 'refresh_token';
- static login(credentials) {
+ static async login(credentials) {
const url = `${import.meta.env.VITE_DJANGO_BASE_URL}/api/token/`;
- return fetch(url, {
+
+ const resp = await fetch(url, {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify(credentials),
- })
- .then(r => r.json())
- .then(data => {
- localStorage.setItem(this.TOKEN_KEY, data.access);
- localStorage.setItem(this.REFRESH_KEY, data.refresh);
- return data;
- });
+ });
+
+ if (!resp.ok) {
+ let errMsg = resp.statusText;
+ try {
+ const errData = await resp.json();
+ errMsg = errData?.detail ?? errData?.message ?? errMsg;
+ } catch (_) {
+
+ }
+ throw new Error(errMsg);
+ }
+
+ const data = await resp.json();
+
+ if (data.access && data.refresh) {
+ localStorage.setItem(this.TOKEN_KEY, data.access);
+ localStorage.setItem(this.REFRESH_KEY, data.refresh);
+ }
+
+ return data;
}
static getAccessToken() {
@@ -35,6 +50,12 @@ class AuthService {
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({ refresh }),
});
+
+ if (!resp.ok) {
+ const errData = await resp.json().catch(() => ({}));
+ throw new Error(errData?.detail ?? resp.statusText);
+ }
+
const data = await resp.json();
localStorage.setItem(this.TOKEN_KEY, data.access);
return data.access;