forked from AkkomaGang/akkoma-fe
49 lines
1.6 KiB
JavaScript
49 lines
1.6 KiB
JavaScript
import { delete as del } from 'vue'
|
|
|
|
const oauth = {
|
|
state: {
|
|
clientId: false,
|
|
clientSecret: false,
|
|
/* App token is authentication for app without any user, used mostly for
|
|
* MastoAPI's registration of new users, stored so that we can fall back to
|
|
* it on logout
|
|
*/
|
|
appToken: false,
|
|
/* User token is authentication for app with user, this is for every calls
|
|
* that need authorized user to be successful (i.e. posting, liking etc)
|
|
*/
|
|
userToken: false
|
|
},
|
|
mutations: {
|
|
setClientData (state, { clientId, clientSecret }) {
|
|
state.clientId = clientId
|
|
state.clientSecret = clientSecret
|
|
},
|
|
setAppToken (state, token) {
|
|
state.appToken = token
|
|
},
|
|
setToken (state, token) {
|
|
state.userToken = token
|
|
},
|
|
clearToken (state) {
|
|
state.userToken = false
|
|
// state.token is userToken with older name, coming from persistent state
|
|
// let's clear it as well, since it is being used as a fallback of state.userToken
|
|
del(state, 'token')
|
|
}
|
|
},
|
|
getters: {
|
|
getToken: state => () => {
|
|
// state.token is userToken with older name, coming from persistent state
|
|
// added here for smoother transition, otherwise user will be logged out
|
|
return state.userToken || state.token || state.appToken
|
|
},
|
|
getUserToken: state => () => {
|
|
// state.token is userToken with older name, coming from persistent state
|
|
// added here for smoother transition, otherwise user will be logged out
|
|
return state.userToken || state.token
|
|
}
|
|
}
|
|
}
|
|
|
|
export default oauth
|