navidrome/ui/src/authProvider.js

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

89 lines
2.5 KiB
JavaScript
Raw Normal View History

2020-01-20 15:54:29 +01:00
import jwtDecode from 'jwt-decode'
import md5 from 'md5-hex'
2020-04-03 23:50:42 +02:00
import baseUrl from './utils/baseUrl'
import config from './config'
2020-01-20 15:54:29 +01:00
const authProvider = {
login: ({ username, password }) => {
2020-04-03 23:50:42 +02:00
let url = baseUrl('/app/login')
if (config.firstTime) {
2020-04-03 23:50:42 +02:00
url = baseUrl('/app/createAdmin')
}
const request = new Request(url, {
2020-01-20 15:54:29 +01:00
method: 'POST',
body: JSON.stringify({ username, password }),
2020-04-26 20:50:44 +02:00
headers: new Headers({ 'Content-Type': 'application/json' }),
2020-01-20 15:54:29 +01:00
})
return fetch(request)
.then((response) => {
if (response.status < 200 || response.status >= 300) {
throw new Error(response.statusText)
}
return response.json()
})
.then((response) => {
// Validate token
jwtDecode(response.token)
localStorage.setItem('token', response.token)
localStorage.setItem('name', response.name)
localStorage.setItem('username', response.username)
localStorage.setItem('role', response.isAdmin ? 'admin' : 'regular')
const salt = new Date().getTime().toString()
localStorage.setItem('subsonic-salt', salt)
localStorage.setItem(
'subsonic-token',
generateSubsonicToken(password, salt)
)
2020-04-08 19:20:02 +02:00
// Avoid going to create admin dialog after logout/login without a refresh
config.firstTime = false
2020-01-20 15:54:29 +01:00
return response
})
.catch((error) => {
if (
error.message === 'Failed to fetch' ||
error.stack === 'TypeError: Failed to fetch'
) {
throw new Error('errors.network_error')
}
throw new Error(error)
})
},
logout: () => {
removeItems()
return Promise.resolve()
},
checkAuth: () =>
localStorage.getItem('token') ? Promise.resolve() : Promise.reject(),
2020-01-20 15:54:29 +01:00
checkError: ({ status }) => {
2020-01-20 15:54:29 +01:00
if (status === 401 || status === 403) {
removeItems()
return Promise.reject()
}
return Promise.resolve()
},
getPermissions: () => {
const role = localStorage.getItem('role')
return role ? Promise.resolve(role) : Promise.reject()
2020-04-26 20:50:44 +02:00
},
2020-01-20 15:54:29 +01:00
}
const removeItems = () => {
localStorage.removeItem('token')
localStorage.removeItem('name')
localStorage.removeItem('username')
localStorage.removeItem('role')
localStorage.removeItem('subsonic-salt')
localStorage.removeItem('subsonic-token')
}
const generateSubsonicToken = (password, salt) => {
return md5(password + salt)
2020-01-20 15:54:29 +01:00
}
export default authProvider