2016-11-26 17:57:08 +00:00
|
|
|
import backendInteractorService from '../services/backend_interactor_service/backend_interactor_service.js'
|
2019-04-11 19:46:44 +00:00
|
|
|
import userSearchApi from '../services/new_api/user_search.js'
|
2019-04-10 17:49:39 +00:00
|
|
|
import { compact, map, each, merge, last, concat, uniq } from 'lodash'
|
2017-02-13 22:22:32 +00:00
|
|
|
import { set } from 'vue'
|
2018-12-20 06:17:59 +00:00
|
|
|
import { registerPushNotifications, unregisterPushNotifications } from '../services/push/push.js'
|
2018-12-05 09:43:01 +00:00
|
|
|
import oauthApi from '../services/new_api/oauth'
|
2018-12-13 11:22:15 +00:00
|
|
|
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)
|
2018-12-13 11:22:15 +00:00
|
|
|
return { item: oldItem, new: false }
|
2016-11-30 17:29:44 +00:00
|
|
|
} else {
|
|
|
|
// This is a new item, prepare it
|
|
|
|
arr.push(item)
|
2019-03-21 22:05:20 +00:00
|
|
|
set(obj, item.id, item)
|
2018-12-13 12:34:51 +00:00
|
|
|
if (item.screen_name && !item.screen_name.includes('@')) {
|
2019-03-21 22:05:20 +00:00
|
|
|
set(obj, item.screen_name.toLowerCase(), item)
|
2018-12-13 12:34:51 +00:00
|
|
|
}
|
2018-12-13 11:22:15 +00:00
|
|
|
return { item, new: true }
|
2016-11-30 17:29:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-12-13 11:04:09 +00:00
|
|
|
const getNotificationPermission = () => {
|
|
|
|
const Notification = window.Notification
|
|
|
|
|
|
|
|
if (!Notification) return Promise.resolve(null)
|
|
|
|
if (Notification.permission === 'default') return Notification.requestPermission()
|
|
|
|
return Promise.resolve(Notification.permission)
|
|
|
|
}
|
|
|
|
|
2019-04-04 18:02:46 +00:00
|
|
|
const blockUser = (store, id) => {
|
|
|
|
return store.rootState.api.backendInteractor.blockUser(id)
|
2019-04-04 17:54:52 +00:00
|
|
|
.then((relationship) => {
|
|
|
|
store.commit('updateUserRelationship', [relationship])
|
2019-04-04 18:02:46 +00:00
|
|
|
store.commit('addBlockId', id)
|
|
|
|
store.commit('removeStatus', { timeline: 'friends', userId: id })
|
|
|
|
store.commit('removeStatus', { timeline: 'public', userId: id })
|
|
|
|
store.commit('removeStatus', { timeline: 'publicAndExternal', userId: id })
|
2019-04-04 17:54:52 +00:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2019-04-04 18:02:46 +00:00
|
|
|
const unblockUser = (store, id) => {
|
|
|
|
return store.rootState.api.backendInteractor.unblockUser(id)
|
|
|
|
.then((relationship) => store.commit('updateUserRelationship', [relationship]))
|
|
|
|
}
|
|
|
|
|
|
|
|
const muteUser = (store, id) => {
|
|
|
|
return store.rootState.api.backendInteractor.muteUser(id)
|
|
|
|
.then((relationship) => {
|
|
|
|
store.commit('updateUserRelationship', [relationship])
|
|
|
|
store.commit('addMuteId', id)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
const unmuteUser = (store, id) => {
|
|
|
|
return store.rootState.api.backendInteractor.unmuteUser(id)
|
2019-04-04 17:54:52 +00:00
|
|
|
.then((relationship) => store.commit('updateUserRelationship', [relationship]))
|
|
|
|
}
|
|
|
|
|
2016-11-30 17:29:44 +00:00
|
|
|
export const mutations = {
|
2018-12-13 11:22:15 +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)
|
|
|
|
},
|
2019-02-18 14:49:32 +00:00
|
|
|
tagUser (state, { user: { id }, tag }) {
|
|
|
|
const user = state.usersObject[id]
|
|
|
|
const tags = user.tags || []
|
|
|
|
const newTags = tags.concat([tag])
|
|
|
|
set(user, 'tags', newTags)
|
|
|
|
},
|
|
|
|
untagUser (state, { user: { id }, tag }) {
|
|
|
|
const user = state.usersObject[id]
|
|
|
|
const tags = user.tags || []
|
|
|
|
const newTags = tags.filter(t => t !== tag)
|
|
|
|
set(user, 'tags', newTags)
|
|
|
|
},
|
|
|
|
updateRight (state, { user: { id }, right, value }) {
|
|
|
|
const user = state.usersObject[id]
|
|
|
|
let newRights = user.rights
|
|
|
|
newRights[right] = value
|
|
|
|
set(user, 'rights', newRights)
|
|
|
|
},
|
|
|
|
updateActivationStatus (state, { user: { id }, status }) {
|
|
|
|
const user = state.usersObject[id]
|
|
|
|
set(user, 'deactivated', !status)
|
|
|
|
},
|
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
|
|
|
},
|
2019-04-10 17:49:39 +00:00
|
|
|
saveFriendIds (state, { id, friendIds }) {
|
2018-12-17 16:14:38 +00:00
|
|
|
const user = state.usersObject[id]
|
2019-04-10 17:49:39 +00:00
|
|
|
user.friendIds = uniq(concat(user.friendIds, friendIds))
|
2018-12-17 16:14:38 +00:00
|
|
|
},
|
2019-04-10 17:49:39 +00:00
|
|
|
saveFollowerIds (state, { id, followerIds }) {
|
2018-12-17 16:14:38 +00:00
|
|
|
const user = state.usersObject[id]
|
2019-04-10 17:49:39 +00:00
|
|
|
user.followerIds = uniq(concat(user.followerIds, followerIds))
|
2019-02-02 20:29:10 +00:00
|
|
|
},
|
|
|
|
// Because frontend doesn't have a reason to keep these stuff in memory
|
|
|
|
// outside of viewing someones user profile.
|
2019-02-25 09:51:23 +00:00
|
|
|
clearFriends (state, userId) {
|
|
|
|
const user = state.usersObject[userId]
|
2019-04-10 17:49:39 +00:00
|
|
|
if (user) {
|
|
|
|
set(user, 'friendIds', [])
|
2019-02-02 20:29:10 +00:00
|
|
|
}
|
2019-02-25 09:51:23 +00:00
|
|
|
},
|
|
|
|
clearFollowers (state, userId) {
|
|
|
|
const user = state.usersObject[userId]
|
2019-04-10 17:49:39 +00:00
|
|
|
if (user) {
|
|
|
|
set(user, 'followerIds', [])
|
2019-02-25 09:51:23 +00:00
|
|
|
}
|
2018-12-17 16:14:38 +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
|
|
|
},
|
2019-03-07 22:35:30 +00:00
|
|
|
updateUserRelationship (state, relationships) {
|
|
|
|
relationships.forEach((relationship) => {
|
|
|
|
const user = state.usersObject[relationship.id]
|
2019-03-14 16:50:51 +00:00
|
|
|
if (user) {
|
|
|
|
user.follows_you = relationship.followed_by
|
|
|
|
user.following = relationship.following
|
|
|
|
user.muted = relationship.muting
|
|
|
|
user.statusnet_blocking = relationship.blocking
|
|
|
|
}
|
2019-03-07 22:35:30 +00:00
|
|
|
})
|
|
|
|
},
|
2019-03-02 13:20:56 +00:00
|
|
|
updateBlocks (state, blockedUsers) {
|
|
|
|
// Reset statusnet_blocking of all fetched users
|
|
|
|
each(state.users, (user) => { user.statusnet_blocking = false })
|
|
|
|
each(blockedUsers, (user) => mergeOrAdd(state.users, state.usersObject, user))
|
|
|
|
},
|
2019-03-01 18:30:01 +00:00
|
|
|
saveBlockIds (state, blockIds) {
|
2019-02-14 03:24:09 +00:00
|
|
|
state.currentUser.blockIds = blockIds
|
2019-02-13 17:05:23 +00:00
|
|
|
},
|
2019-04-02 18:56:37 +00:00
|
|
|
addBlockId (state, blockId) {
|
|
|
|
if (state.currentUser.blockIds.indexOf(blockId) === -1) {
|
|
|
|
state.currentUser.blockIds.push(blockId)
|
|
|
|
}
|
|
|
|
},
|
2019-03-01 18:30:01 +00:00
|
|
|
updateMutes (state, mutedUsers) {
|
2019-03-02 13:21:15 +00:00
|
|
|
// Reset muted of all fetched users
|
2019-03-01 18:30:01 +00:00
|
|
|
each(state.users, (user) => { user.muted = false })
|
2019-03-22 01:31:16 +00:00
|
|
|
each(mutedUsers, (user) => mergeOrAdd(state.users, state.usersObject, user))
|
2019-03-01 18:30:01 +00:00
|
|
|
},
|
|
|
|
saveMuteIds (state, muteIds) {
|
2019-02-14 03:24:09 +00:00
|
|
|
state.currentUser.muteIds = muteIds
|
2019-02-14 03:04:28 +00:00
|
|
|
},
|
2019-04-02 20:23:12 +00:00
|
|
|
addMuteId (state, muteId) {
|
|
|
|
if (state.currentUser.muteIds.indexOf(muteId) === -1) {
|
|
|
|
state.currentUser.muteIds.push(muteId)
|
|
|
|
}
|
|
|
|
},
|
2019-04-30 12:20:19 +00:00
|
|
|
setPinned (state, status) {
|
|
|
|
const user = state.usersObject[status.user.id]
|
|
|
|
const index = user.pinnedStatuseIds.indexOf(status.id)
|
|
|
|
if (status.pinned && index === -1) {
|
|
|
|
user.pinnedStatuseIds.push(status.id)
|
|
|
|
} else if (!status.pinned && index !== -1) {
|
|
|
|
user.pinnedStatuseIds.splice(index, 1)
|
|
|
|
}
|
|
|
|
},
|
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
|
|
|
},
|
2018-12-26 09:19:25 +00:00
|
|
|
setUserForNotification (state, notification) {
|
2019-04-01 01:59:18 +00:00
|
|
|
if (notification.type !== 'follow') {
|
|
|
|
notification.action.user = state.usersObject[notification.action.user.id]
|
|
|
|
}
|
2019-03-31 18:50:34 +00:00
|
|
|
notification.from_profile = state.usersObject[notification.from_profile.id]
|
2018-12-26 09:19:25 +00:00
|
|
|
},
|
2018-12-13 11:22:15 +00:00
|
|
|
setColor (state, { user: { id }, highlighted }) {
|
2018-06-18 08:36:58 +00:00
|
|
|
const user = state.usersObject[id]
|
|
|
|
set(user, 'highlight', highlighted)
|
2018-12-05 09:43:01 +00:00
|
|
|
},
|
2018-12-05 19:07:58 +00:00
|
|
|
signUpPending (state) {
|
|
|
|
state.signUpPending = true
|
|
|
|
state.signUpErrors = []
|
2018-12-05 09:43:01 +00:00
|
|
|
},
|
2018-12-05 19:07:58 +00:00
|
|
|
signUpSuccess (state) {
|
|
|
|
state.signUpPending = false
|
2018-12-05 09:43:01 +00:00
|
|
|
},
|
2018-12-05 19:07:58 +00:00
|
|
|
signUpFailure (state, errors) {
|
|
|
|
state.signUpPending = false
|
|
|
|
state.signUpErrors = errors
|
2016-11-30 17:29:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-12-31 01:57:22 +00:00
|
|
|
export const getters = {
|
2019-03-14 21:04:13 +00:00
|
|
|
findUser: state => query => {
|
|
|
|
const result = state.usersObject[query]
|
|
|
|
// In case it's a screen_name, we can try searching case-insensitive
|
|
|
|
if (!result && typeof query === 'string') {
|
|
|
|
return state.usersObject[query.toLowerCase()]
|
|
|
|
}
|
|
|
|
return result
|
|
|
|
}
|
2018-12-31 01:57:22 +00:00
|
|
|
}
|
|
|
|
|
2016-11-30 17:29:44 +00:00
|
|
|
export const defaultState = {
|
2018-12-05 19:07:58 +00:00
|
|
|
loggingIn: false,
|
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: {},
|
2018-12-05 19:07:58 +00:00
|
|
|
signUpPending: false,
|
|
|
|
signUpErrors: []
|
2016-11-30 17:29:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const users = {
|
|
|
|
state: defaultState,
|
|
|
|
mutations,
|
2018-12-31 01:57:22 +00:00
|
|
|
getters,
|
2016-10-27 16:03:14 +00:00
|
|
|
actions: {
|
2017-11-14 16:08:03 +00:00
|
|
|
fetchUser (store, id) {
|
2019-02-21 18:32:47 +00:00
|
|
|
return store.rootState.api.backendInteractor.fetchUser({ id })
|
2019-03-12 20:10:22 +00:00
|
|
|
.then((user) => {
|
|
|
|
store.commit('addNewUsers', [user])
|
|
|
|
return user
|
|
|
|
})
|
2019-03-08 20:40:57 +00:00
|
|
|
},
|
2019-03-07 22:35:30 +00:00
|
|
|
fetchUserRelationship (store, id) {
|
2019-04-18 02:47:56 +00:00
|
|
|
if (store.state.currentUser) {
|
|
|
|
store.rootState.api.backendInteractor.fetchUserRelationship({ id })
|
|
|
|
.then((relationships) => store.commit('updateUserRelationship', relationships))
|
|
|
|
}
|
2017-11-14 16:08:03 +00:00
|
|
|
},
|
2019-02-13 17:05:23 +00:00
|
|
|
fetchBlocks (store) {
|
2019-02-14 02:08:14 +00:00
|
|
|
return store.rootState.api.backendInteractor.fetchBlocks()
|
2019-02-13 17:05:23 +00:00
|
|
|
.then((blocks) => {
|
2019-03-01 18:30:01 +00:00
|
|
|
store.commit('saveBlockIds', map(blocks, 'id'))
|
2019-03-02 13:20:56 +00:00
|
|
|
store.commit('updateBlocks', blocks)
|
2019-02-13 17:05:23 +00:00
|
|
|
return blocks
|
|
|
|
})
|
|
|
|
},
|
2019-04-04 18:02:46 +00:00
|
|
|
blockUser (store, id) {
|
|
|
|
return blockUser(store, id)
|
2019-04-04 17:54:52 +00:00
|
|
|
},
|
2019-04-04 18:02:46 +00:00
|
|
|
unblockUser (store, id) {
|
|
|
|
return unblockUser(store, id)
|
2019-04-04 17:54:52 +00:00
|
|
|
},
|
2019-04-04 18:02:46 +00:00
|
|
|
blockUsers (store, ids = []) {
|
|
|
|
return Promise.all(ids.map(id => blockUser(store, id)))
|
2019-02-13 20:31:20 +00:00
|
|
|
},
|
2019-04-04 18:02:46 +00:00
|
|
|
unblockUsers (store, ids = []) {
|
|
|
|
return Promise.all(ids.map(id => unblockUser(store, id)))
|
2019-02-13 20:31:20 +00:00
|
|
|
},
|
2019-02-14 03:04:28 +00:00
|
|
|
fetchMutes (store) {
|
|
|
|
return store.rootState.api.backendInteractor.fetchMutes()
|
2019-03-01 18:30:01 +00:00
|
|
|
.then((mutes) => {
|
|
|
|
store.commit('updateMutes', mutes)
|
|
|
|
store.commit('saveMuteIds', map(mutes, 'id'))
|
|
|
|
return mutes
|
2019-02-14 03:04:28 +00:00
|
|
|
})
|
|
|
|
},
|
|
|
|
muteUser (store, id) {
|
2019-04-04 18:02:46 +00:00
|
|
|
return muteUser(store, id)
|
2019-02-14 03:04:28 +00:00
|
|
|
},
|
|
|
|
unmuteUser (store, id) {
|
2019-04-04 18:02:46 +00:00
|
|
|
return unmuteUser(store, id)
|
|
|
|
},
|
|
|
|
muteUsers (store, ids = []) {
|
|
|
|
return Promise.all(ids.map(id => muteUser(store, id)))
|
|
|
|
},
|
|
|
|
unmuteUsers (store, ids = []) {
|
|
|
|
return Promise.all(ids.map(id => unmuteUser(store, id)))
|
2019-02-14 03:04:28 +00:00
|
|
|
},
|
2019-04-10 17:49:39 +00:00
|
|
|
fetchFriends ({ rootState, commit }, id) {
|
|
|
|
const user = rootState.users.usersObject[id]
|
|
|
|
const maxId = last(user.friendIds)
|
|
|
|
return rootState.api.backendInteractor.fetchFriends({ id, maxId })
|
|
|
|
.then((friends) => {
|
|
|
|
commit('addNewUsers', friends)
|
|
|
|
commit('saveFriendIds', { id, friendIds: map(friends, 'id') })
|
|
|
|
return friends
|
|
|
|
})
|
2019-02-02 20:29:10 +00:00
|
|
|
},
|
2019-04-10 17:49:39 +00:00
|
|
|
fetchFollowers ({ rootState, commit }, id) {
|
|
|
|
const user = rootState.users.usersObject[id]
|
|
|
|
const maxId = last(user.followerIds)
|
|
|
|
return rootState.api.backendInteractor.fetchFollowers({ id, maxId })
|
2019-02-25 07:11:39 +00:00
|
|
|
.then((followers) => {
|
2019-04-10 17:49:39 +00:00
|
|
|
commit('addNewUsers', followers)
|
|
|
|
commit('saveFollowerIds', { id, followerIds: map(followers, 'id') })
|
2019-02-25 07:11:39 +00:00
|
|
|
return followers
|
|
|
|
})
|
2018-12-17 16:14:38 +00:00
|
|
|
},
|
2019-02-25 09:51:23 +00:00
|
|
|
clearFriends ({ commit }, userId) {
|
|
|
|
commit('clearFriends', userId)
|
|
|
|
},
|
|
|
|
clearFollowers ({ commit }, userId) {
|
|
|
|
commit('clearFollowers', userId)
|
2018-12-17 16:14:38 +00:00
|
|
|
},
|
2018-12-10 15:36:25 +00:00
|
|
|
registerPushNotifications (store) {
|
|
|
|
const token = store.state.currentUser.credentials
|
|
|
|
const vapidPublicKey = store.rootState.instance.vapidPublicKey
|
|
|
|
const isEnabled = store.rootState.config.webPushNotifications
|
2018-12-25 13:43:18 +00:00
|
|
|
const notificationVisibility = store.rootState.config.notificationVisibility
|
2018-12-10 15:36:25 +00:00
|
|
|
|
2018-12-25 13:43:18 +00:00
|
|
|
registerPushNotifications(isEnabled, vapidPublicKey, token, notificationVisibility)
|
2018-12-10 15:36:25 +00:00
|
|
|
},
|
2018-12-20 06:17:59 +00:00
|
|
|
unregisterPushNotifications (store) {
|
2018-12-25 00:46:19 +00:00
|
|
|
const token = store.state.currentUser.credentials
|
|
|
|
|
|
|
|
unregisterPushNotifications(token)
|
2018-12-20 06:17:59 +00:00
|
|
|
},
|
2019-04-02 17:49:48 +00:00
|
|
|
addNewUsers ({ commit }, users) {
|
|
|
|
commit('addNewUsers', users)
|
|
|
|
},
|
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
|
|
|
|
|
|
|
each(statuses, (status) => {
|
2019-04-30 12:20:19 +00:00
|
|
|
// Reconnect users to statuses
|
2017-02-16 13:23:59 +00:00
|
|
|
store.commit('setUserForStatus', status)
|
2019-04-30 12:20:19 +00:00
|
|
|
// Set pinned statuses to user
|
|
|
|
store.commit('setPinned', status)
|
2017-02-13 23:01:50 +00:00
|
|
|
})
|
|
|
|
each(compact(map(statuses, 'retweeted_status')), (status) => {
|
2019-04-30 12:20:19 +00:00
|
|
|
// Reconnect users to retweets
|
2017-02-16 13:23:59 +00:00
|
|
|
store.commit('setUserForStatus', status)
|
2019-04-30 12:20:19 +00:00
|
|
|
// Set pinned retweets to user
|
|
|
|
store.commit('setPinned', status)
|
2017-02-13 23:01:50 +00:00
|
|
|
})
|
2016-11-30 17:29:44 +00:00
|
|
|
},
|
2018-12-26 09:19:25 +00:00
|
|
|
addNewNotifications (store, { notifications }) {
|
2019-01-14 19:38:37 +00:00
|
|
|
const users = map(notifications, 'from_profile')
|
2019-01-17 20:08:44 +00:00
|
|
|
const notificationIds = notifications.map(_ => _.id)
|
2018-12-26 09:19:25 +00:00
|
|
|
store.commit('addNewUsers', users)
|
|
|
|
|
|
|
|
const notificationsObject = store.rootState.statuses.notifications.idStore
|
|
|
|
const relevantNotifications = Object.entries(notificationsObject)
|
|
|
|
.filter(([k, val]) => notificationIds.includes(k))
|
|
|
|
.map(([k, val]) => val)
|
|
|
|
|
|
|
|
// Reconnect users to notifications
|
|
|
|
each(relevantNotifications, (notification) => {
|
|
|
|
store.commit('setUserForNotification', notification)
|
|
|
|
})
|
|
|
|
},
|
2019-04-11 19:46:44 +00:00
|
|
|
searchUsers (store, query) {
|
|
|
|
// TODO: Move userSearch api into api.service
|
|
|
|
return userSearchApi.search({query, store: { state: store.rootState }})
|
|
|
|
.then((users) => {
|
|
|
|
store.commit('addNewUsers', users)
|
|
|
|
return users
|
|
|
|
})
|
|
|
|
},
|
2018-12-05 09:43:01 +00:00
|
|
|
async signUp (store, userInfo) {
|
2018-12-05 19:07:58 +00:00
|
|
|
store.commit('signUpPending')
|
2018-12-05 09:43:01 +00:00
|
|
|
|
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
|
|
|
})
|
2018-12-05 19:07:58 +00:00
|
|
|
store.commit('signUpSuccess')
|
2018-12-05 09:43:01 +00:00
|
|
|
store.commit('setToken', result.access_token)
|
|
|
|
store.dispatch('loginUser', result.access_token)
|
|
|
|
} else {
|
2019-02-19 14:22:42 +00:00
|
|
|
const data = await response.json()
|
|
|
|
let errors = JSON.parse(data.error)
|
|
|
|
// replace ap_id with username
|
|
|
|
if (errors.ap_id) {
|
|
|
|
errors.username = errors.ap_id
|
|
|
|
delete errors.ap_id
|
|
|
|
}
|
|
|
|
errors = humanizeErrors(errors)
|
2018-12-05 19:07:58 +00:00
|
|
|
store.commit('signUpFailure', errors)
|
2018-12-05 15:17:29 +00:00
|
|
|
throw Error(errors)
|
2018-12-05 09:43:01 +00:00
|
|
|
}
|
|
|
|
},
|
2018-12-16 17:53:41 +00:00
|
|
|
async getCaptcha (store) {
|
|
|
|
return await store.rootState.api.backendInteractor.getCaptcha()
|
|
|
|
},
|
|
|
|
|
2017-07-02 10:25:34 +00:00
|
|
|
logout (store) {
|
|
|
|
store.commit('clearCurrentUser')
|
2019-03-10 18:23:27 +00:00
|
|
|
store.dispatch('disconnectFromChat')
|
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())
|
2019-04-03 16:04:46 +00:00
|
|
|
store.dispatch('stopFetching', 'notifications')
|
|
|
|
store.commit('clearNotifications')
|
2019-02-28 19:03:44 +00:00
|
|
|
store.commit('resetStatuses')
|
2017-07-02 10:25:34 +00:00
|
|
|
},
|
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)
|
2019-01-17 19:11:51 +00:00
|
|
|
.then((data) => {
|
|
|
|
if (!data.error) {
|
2019-01-17 20:01:38 +00:00
|
|
|
const user = data
|
2019-01-17 19:11:51 +00:00
|
|
|
// user.credentials = userCredentials
|
|
|
|
user.credentials = accessToken
|
2019-02-14 03:14:46 +00:00
|
|
|
user.blockIds = []
|
|
|
|
user.muteIds = []
|
2019-01-17 19:11:51 +00:00
|
|
|
commit('setCurrentUser', user)
|
|
|
|
commit('addNewUsers', [user])
|
2016-11-30 20:27:25 +00:00
|
|
|
|
2019-01-17 19:11:51 +00:00
|
|
|
getNotificationPermission()
|
|
|
|
.then(permission => commit('setNotificationPermission', permission))
|
2018-12-13 11:04:09 +00:00
|
|
|
|
2019-01-17 19:11:51 +00:00
|
|
|
// Set our new backend interactor
|
|
|
|
commit('setBackendInteractor', backendInteractorService(accessToken))
|
2016-11-30 20:27:25 +00:00
|
|
|
|
2019-01-17 19:11:51 +00:00
|
|
|
if (user.token) {
|
2019-01-29 15:16:25 +00:00
|
|
|
store.dispatch('setWsToken', user.token)
|
2019-03-10 18:23:27 +00:00
|
|
|
|
|
|
|
// Initialize the chat socket.
|
|
|
|
store.dispatch('initializeSocket')
|
2019-01-17 19:11:51 +00:00
|
|
|
}
|
2017-12-04 18:08:33 +00:00
|
|
|
|
2019-01-29 15:16:25 +00:00
|
|
|
// Start getting fresh posts.
|
2019-04-04 16:03:56 +00:00
|
|
|
store.dispatch('startFetchingTimeline', { timeline: 'friends' })
|
2017-02-16 10:17:47 +00:00
|
|
|
|
2019-04-03 16:04:46 +00:00
|
|
|
// Start fetching notifications
|
2019-04-04 16:03:56 +00:00
|
|
|
store.dispatch('startFetchingNotifications')
|
2017-02-16 10:17:47 +00:00
|
|
|
|
2019-02-14 03:14:46 +00:00
|
|
|
// Get user mutes
|
2019-02-14 03:04:28 +00:00
|
|
|
store.dispatch('fetchMutes')
|
2017-02-20 17:01:45 +00:00
|
|
|
|
2019-01-17 19:11:51 +00:00
|
|
|
// Fetch our friends
|
|
|
|
store.rootState.api.backendInteractor.fetchFriends({ id: user.id })
|
|
|
|
.then((friends) => commit('addNewUsers', friends))
|
2017-03-08 17:28:41 +00:00
|
|
|
} else {
|
2019-01-17 19:11:51 +00:00
|
|
|
const response = data.error
|
2017-03-08 17:28:41 +00:00
|
|
|
// 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()
|
|
|
|
})
|
2019-01-17 19:11:51 +00:00
|
|
|
.catch((error) => {
|
|
|
|
console.log(error)
|
|
|
|
commit('endLogin')
|
|
|
|
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
|