2016-11-26 17:57:08 +00:00
|
|
|
import backendInteractorService from '../services/backend_interactor_service/backend_interactor_service.js'
|
2017-03-08 17:04:21 +00:00
|
|
|
import { compact, map, each, merge } from 'lodash'
|
2017-02-13 22:22:32 +00:00
|
|
|
import { set } from 'vue'
|
2018-12-05 09:43:01 +00:00
|
|
|
import { SIGN_UP } from '../mutation_types'
|
|
|
|
import oauthApi from '../services/new_api/oauth'
|
|
|
|
import {humanizeErrors} from './errors'
|
2016-10-27 16:03:14 +00:00
|
|
|
|
2016-11-30 17:29:44 +00:00
|
|
|
// TODO: Unify with mergeOrAdd in statuses.js
|
2017-03-08 16:59:12 +00:00
|
|
|
export const mergeOrAdd = (arr, obj, item) => {
|
2016-11-30 22:32:22 +00:00
|
|
|
if (!item) { return false }
|
2017-03-08 16:59:12 +00:00
|
|
|
const oldItem = obj[item.id]
|
2016-11-30 17:29:44 +00:00
|
|
|
if (oldItem) {
|
|
|
|
// We already have this, so only merge the new info.
|
|
|
|
merge(oldItem, item)
|
|
|
|
return {item: oldItem, new: false}
|
|
|
|
} else {
|
|
|
|
// This is a new item, prepare it
|
|
|
|
arr.push(item)
|
2017-03-08 16:59:12 +00:00
|
|
|
obj[item.id] = item
|
2016-11-30 17:29:44 +00:00
|
|
|
return {item, new: true}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export const mutations = {
|
2017-02-13 22:22:32 +00:00
|
|
|
setMuted (state, { user: {id}, muted }) {
|
2017-03-08 17:04:21 +00:00
|
|
|
const user = state.usersObject[id]
|
2017-02-13 22:22:32 +00:00
|
|
|
set(user, 'muted', muted)
|
|
|
|
},
|
2016-11-30 17:29:44 +00:00
|
|
|
setCurrentUser (state, user) {
|
2017-07-02 11:07:35 +00:00
|
|
|
state.lastLoginName = user.screen_name
|
2017-04-16 14:05:13 +00:00
|
|
|
state.currentUser = merge(state.currentUser || {}, user)
|
2016-10-27 16:03:14 +00:00
|
|
|
},
|
2017-07-02 10:25:34 +00:00
|
|
|
clearCurrentUser (state) {
|
|
|
|
state.currentUser = false
|
2017-07-02 11:07:35 +00:00
|
|
|
state.lastLoginName = false
|
2017-07-02 10:25:34 +00:00
|
|
|
},
|
2016-11-30 17:29:44 +00:00
|
|
|
beginLogin (state) {
|
|
|
|
state.loggingIn = true
|
|
|
|
},
|
|
|
|
endLogin (state) {
|
|
|
|
state.loggingIn = false
|
2016-10-27 16:03:14 +00:00
|
|
|
},
|
2016-11-30 17:29:44 +00:00
|
|
|
addNewUsers (state, users) {
|
2017-03-08 16:59:12 +00:00
|
|
|
each(users, (user) => mergeOrAdd(state.users, state.usersObject, user))
|
2017-02-16 13:23:59 +00:00
|
|
|
},
|
|
|
|
setUserForStatus (state, status) {
|
2017-03-08 17:04:21 +00:00
|
|
|
status.user = state.usersObject[status.user.id]
|
2018-06-18 08:36:58 +00:00
|
|
|
},
|
|
|
|
setColor (state, { user: {id}, highlighted }) {
|
|
|
|
const user = state.usersObject[id]
|
|
|
|
set(user, 'highlight', highlighted)
|
2018-12-05 09:43:01 +00:00
|
|
|
},
|
|
|
|
[SIGN_UP.PENDING] (state) {
|
|
|
|
state[SIGN_UP.isPending] = true
|
2018-12-05 15:17:29 +00:00
|
|
|
state[SIGN_UP.errors] = []
|
2018-12-05 09:43:01 +00:00
|
|
|
},
|
|
|
|
[SIGN_UP.SUCCESS] (state) {
|
|
|
|
state[SIGN_UP.isPending] = false
|
|
|
|
},
|
|
|
|
[SIGN_UP.FAILURE] (state, errors) {
|
|
|
|
state[SIGN_UP.isPending] = false
|
2018-12-05 15:17:29 +00:00
|
|
|
state[SIGN_UP.errors] = errors
|
2016-11-30 17:29:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export const defaultState = {
|
2017-07-02 11:07:35 +00:00
|
|
|
lastLoginName: false,
|
2016-11-30 17:29:44 +00:00
|
|
|
currentUser: false,
|
2017-03-08 16:59:12 +00:00
|
|
|
users: [],
|
2018-12-05 09:43:01 +00:00
|
|
|
usersObject: {},
|
|
|
|
sign_up_pending: false,
|
|
|
|
sign_up_errors: []
|
2016-11-30 17:29:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const users = {
|
|
|
|
state: defaultState,
|
|
|
|
mutations,
|
2016-10-27 16:03:14 +00:00
|
|
|
actions: {
|
2017-11-14 16:08:03 +00:00
|
|
|
fetchUser (store, id) {
|
|
|
|
store.rootState.api.backendInteractor.fetchUser({id})
|
|
|
|
.then((user) => store.commit('addNewUsers', user))
|
|
|
|
},
|
2016-11-30 17:29:44 +00:00
|
|
|
addNewStatuses (store, { statuses }) {
|
|
|
|
const users = map(statuses, 'user')
|
2016-12-08 08:08:59 +00:00
|
|
|
const retweetedUsers = compact(map(statuses, 'retweeted_status.user'))
|
2016-11-30 17:29:44 +00:00
|
|
|
store.commit('addNewUsers', users)
|
2016-12-08 08:08:59 +00:00
|
|
|
store.commit('addNewUsers', retweetedUsers)
|
2017-02-13 23:01:50 +00:00
|
|
|
|
|
|
|
// Reconnect users to statuses
|
|
|
|
each(statuses, (status) => {
|
2017-02-16 13:23:59 +00:00
|
|
|
store.commit('setUserForStatus', status)
|
2017-02-13 23:01:50 +00:00
|
|
|
})
|
|
|
|
// Reconnect users to retweets
|
|
|
|
each(compact(map(statuses, 'retweeted_status')), (status) => {
|
2017-02-16 13:23:59 +00:00
|
|
|
store.commit('setUserForStatus', status)
|
2017-02-13 23:01:50 +00:00
|
|
|
})
|
2016-11-30 17:29:44 +00:00
|
|
|
},
|
2018-12-05 09:43:01 +00:00
|
|
|
async signUp (store, userInfo) {
|
|
|
|
store.commit(SIGN_UP.PENDING)
|
|
|
|
|
2018-12-05 15:17:29 +00:00
|
|
|
let rootState = store.rootState
|
|
|
|
|
|
|
|
let response = await rootState.api.backendInteractor.register(userInfo)
|
2018-12-05 09:43:01 +00:00
|
|
|
if (response.ok) {
|
|
|
|
const data = {
|
2018-12-05 15:17:29 +00:00
|
|
|
oauth: rootState.oauth,
|
|
|
|
instance: rootState.instance.server
|
2018-12-05 09:43:01 +00:00
|
|
|
}
|
|
|
|
let app = await oauthApi.getOrCreateApp(data)
|
|
|
|
let result = await oauthApi.getTokenWithCredentials({
|
|
|
|
app,
|
|
|
|
instance: data.instance,
|
2018-12-05 15:17:29 +00:00
|
|
|
username: userInfo.username,
|
|
|
|
password: userInfo.password
|
2018-12-05 09:43:01 +00:00
|
|
|
})
|
|
|
|
store.commit(SIGN_UP.SUCCESS)
|
|
|
|
store.commit('setToken', result.access_token)
|
|
|
|
store.dispatch('loginUser', result.access_token)
|
|
|
|
} else {
|
|
|
|
let data = await response.json()
|
|
|
|
let errors = humanizeErrors(JSON.parse(data.error))
|
|
|
|
store.commit(SIGN_UP.FAILURE, errors)
|
2018-12-05 15:17:29 +00:00
|
|
|
throw Error(errors)
|
2018-12-05 09:43:01 +00:00
|
|
|
}
|
|
|
|
},
|
2017-07-02 10:25:34 +00:00
|
|
|
logout (store) {
|
|
|
|
store.commit('clearCurrentUser')
|
2018-10-26 13:16:23 +00:00
|
|
|
store.commit('setToken', false)
|
2017-07-02 10:25:34 +00:00
|
|
|
store.dispatch('stopFetching', 'friends')
|
|
|
|
store.commit('setBackendInteractor', backendInteractorService())
|
|
|
|
},
|
2018-10-26 13:16:23 +00:00
|
|
|
loginUser (store, accessToken) {
|
2017-03-08 17:28:41 +00:00
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
const commit = store.commit
|
|
|
|
commit('beginLogin')
|
2018-10-26 13:16:23 +00:00
|
|
|
store.rootState.api.backendInteractor.verifyCredentials(accessToken)
|
2017-03-08 17:28:41 +00:00
|
|
|
.then((response) => {
|
|
|
|
if (response.ok) {
|
|
|
|
response.json()
|
|
|
|
.then((user) => {
|
2018-10-26 13:16:23 +00:00
|
|
|
// user.credentials = userCredentials
|
|
|
|
user.credentials = accessToken
|
2017-03-08 17:28:41 +00:00
|
|
|
commit('setCurrentUser', user)
|
|
|
|
commit('addNewUsers', [user])
|
2016-11-30 20:27:25 +00:00
|
|
|
|
2017-03-08 17:28:41 +00:00
|
|
|
// Set our new backend interactor
|
2018-10-26 13:16:23 +00:00
|
|
|
commit('setBackendInteractor', backendInteractorService(accessToken))
|
2016-11-30 20:27:25 +00:00
|
|
|
|
2017-12-04 18:08:33 +00:00
|
|
|
if (user.token) {
|
2017-12-05 10:47:10 +00:00
|
|
|
store.dispatch('initializeSocket', user.token)
|
2017-12-04 18:08:33 +00:00
|
|
|
}
|
|
|
|
|
2017-03-08 17:28:41 +00:00
|
|
|
// Start getting fresh tweets.
|
|
|
|
store.dispatch('startFetching', 'friends')
|
2018-08-20 21:21:35 +00:00
|
|
|
// Start getting our own posts, only really needed for mitigating broken favorites
|
|
|
|
store.dispatch('startFetching', ['own', user.id])
|
2017-02-16 10:17:47 +00:00
|
|
|
|
2017-03-08 17:28:41 +00:00
|
|
|
// Get user mutes and follower info
|
|
|
|
store.rootState.api.backendInteractor.fetchMutes().then((mutedUsers) => {
|
|
|
|
each(mutedUsers, (user) => { user.muted = true })
|
|
|
|
store.commit('addNewUsers', mutedUsers)
|
|
|
|
})
|
2017-02-20 17:01:45 +00:00
|
|
|
|
2017-11-12 21:11:55 +00:00
|
|
|
if ('Notification' in window && window.Notification.permission === 'default') {
|
|
|
|
window.Notification.requestPermission()
|
|
|
|
}
|
|
|
|
|
2017-03-08 17:28:41 +00:00
|
|
|
// Fetch our friends
|
2018-09-03 12:01:05 +00:00
|
|
|
store.rootState.api.backendInteractor.fetchFriends({id: user.id})
|
2017-03-08 17:28:41 +00:00
|
|
|
.then((friends) => commit('addNewUsers', friends))
|
|
|
|
})
|
|
|
|
} else {
|
|
|
|
// Authentication failed
|
|
|
|
commit('endLogin')
|
2017-03-08 18:22:56 +00:00
|
|
|
if (response.status === 401) {
|
|
|
|
reject('Wrong username or password')
|
|
|
|
} else {
|
2017-03-08 18:31:39 +00:00
|
|
|
reject('An error occurred, please try again')
|
2017-03-08 18:22:56 +00:00
|
|
|
}
|
2017-03-08 17:28:41 +00:00
|
|
|
}
|
|
|
|
commit('endLogin')
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
.catch((error) => {
|
|
|
|
console.log(error)
|
|
|
|
commit('endLogin')
|
2017-03-08 18:22:56 +00:00
|
|
|
reject('Failed to connect to server, try again')
|
2017-03-08 17:28:41 +00:00
|
|
|
})
|
|
|
|
})
|
2016-10-27 16:03:14 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default users
|