fix: getting all users, refactored session code
This commit is contained in:
parent
8e18312d78
commit
ea505a2228
@ -2,6 +2,18 @@ import frappe
|
|||||||
|
|
||||||
|
|
||||||
@frappe.whitelist()
|
@frappe.whitelist()
|
||||||
def get_user_info():
|
def get_users():
|
||||||
user = frappe.db.get_value("User", frappe.session.user, ["name", "full_name", "first_name", "last_name", "user_image", ], as_dict=1)
|
if frappe.session.user == "Guest":
|
||||||
return user
|
frappe.throw("Authentication failed", exc=frappe.AuthenticationError)
|
||||||
|
|
||||||
|
users = frappe.qb.get_query(
|
||||||
|
"User",
|
||||||
|
fields=["name", "email", "enabled", "user_image", "full_name", "user_type"],
|
||||||
|
order_by="full_name asc",
|
||||||
|
distinct=True,
|
||||||
|
).run(as_dict=1)
|
||||||
|
|
||||||
|
for user in users:
|
||||||
|
if frappe.session.user == user.name:
|
||||||
|
user.session_user = True
|
||||||
|
return users
|
||||||
@ -27,16 +27,19 @@
|
|||||||
<script setup>
|
<script setup>
|
||||||
import { Dropdown, Avatar, FeatherIcon } from 'frappe-ui'
|
import { Dropdown, Avatar, FeatherIcon } from 'frappe-ui'
|
||||||
import { sessionStore } from '@/stores/session'
|
import { sessionStore } from '@/stores/session'
|
||||||
|
import { usersStore } from '../stores/users';
|
||||||
import { computed } from 'vue'
|
import { computed } from 'vue'
|
||||||
|
|
||||||
const session = sessionStore()
|
const { logout } = sessionStore()
|
||||||
const user = computed(() => session.user || {})
|
const { getUser } = usersStore()
|
||||||
|
|
||||||
|
const user = computed(() => getUser() || {})
|
||||||
|
|
||||||
const userDropdownOptions = [
|
const userDropdownOptions = [
|
||||||
{
|
{
|
||||||
icon: 'log-out',
|
icon: 'log-out',
|
||||||
label: 'Log out',
|
label: 'Log out',
|
||||||
onClick: () => session.logout.submit(),
|
onClick: () => logout.submit(),
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
@ -1,4 +1,5 @@
|
|||||||
import { createRouter, createWebHistory } from 'vue-router'
|
import { createRouter, createWebHistory } from 'vue-router'
|
||||||
|
import { usersStore } from '@/stores/users'
|
||||||
import { sessionStore } from '@/stores/session'
|
import { sessionStore } from '@/stores/session'
|
||||||
|
|
||||||
const routes = [
|
const routes = [
|
||||||
@ -49,14 +50,14 @@ let router = createRouter({
|
|||||||
})
|
})
|
||||||
|
|
||||||
router.beforeEach(async (to, from, next) => {
|
router.beforeEach(async (to, from, next) => {
|
||||||
const session = sessionStore()
|
const { users } = usersStore()
|
||||||
|
const { isLoggedIn } = sessionStore()
|
||||||
|
|
||||||
// Initialize session
|
await users.promise
|
||||||
await session.init()
|
|
||||||
|
|
||||||
if (to.name === 'Login' && session.isLoggedIn) {
|
if (to.name === 'Login' && isLoggedIn) {
|
||||||
next({ name: 'Leads' })
|
next({ name: 'Leads' })
|
||||||
} else if (to.name !== 'Login' && !session.isLoggedIn) {
|
} else if (to.name !== 'Login' && !isLoggedIn) {
|
||||||
next({ name: 'Login' })
|
next({ name: 'Login' })
|
||||||
} else if (to.matched.length === 0) {
|
} else if (to.matched.length === 0) {
|
||||||
next({ name: 'Invalid Page' })
|
next({ name: 'Invalid Page' })
|
||||||
|
|||||||
@ -1,14 +1,22 @@
|
|||||||
import { defineStore } from 'pinia'
|
import { defineStore } from 'pinia'
|
||||||
import { createResource } from 'frappe-ui'
|
import { createResource } from 'frappe-ui'
|
||||||
|
import { usersStore } from './users'
|
||||||
import router from '@/router'
|
import router from '@/router'
|
||||||
import { computed } from 'vue'
|
import { ref, computed } from 'vue'
|
||||||
|
|
||||||
export const sessionStore = defineStore('crm-session', () => {
|
export const sessionStore = defineStore('crm-session', () => {
|
||||||
const sessionUser = createResource({
|
const { users } = usersStore()
|
||||||
url: 'crm.api.session.get_user_info',
|
|
||||||
})
|
|
||||||
|
|
||||||
const user = computed(() => sessionUser.data || null)
|
function sessionUser() {
|
||||||
|
let cookies = new URLSearchParams(document.cookie.split('; ').join('&'))
|
||||||
|
let _sessionUser = cookies.get('user_id')
|
||||||
|
if (_sessionUser === 'Guest') {
|
||||||
|
_sessionUser = null
|
||||||
|
}
|
||||||
|
return _sessionUser
|
||||||
|
}
|
||||||
|
|
||||||
|
let user = ref(sessionUser())
|
||||||
const isLoggedIn = computed(() => !!user.value)
|
const isLoggedIn = computed(() => !!user.value)
|
||||||
|
|
||||||
const login = createResource({
|
const login = createResource({
|
||||||
@ -17,6 +25,9 @@ export const sessionStore = defineStore('crm-session', () => {
|
|||||||
throw new Error('Invalid email or password')
|
throw new Error('Invalid email or password')
|
||||||
},
|
},
|
||||||
onSuccess() {
|
onSuccess() {
|
||||||
|
users.reload()
|
||||||
|
user.value = sessionUser()
|
||||||
|
login.reset()
|
||||||
router.replace({ path: '/' })
|
router.replace({ path: '/' })
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
@ -24,23 +35,16 @@ export const sessionStore = defineStore('crm-session', () => {
|
|||||||
const logout = createResource({
|
const logout = createResource({
|
||||||
url: 'logout',
|
url: 'logout',
|
||||||
onSuccess() {
|
onSuccess() {
|
||||||
|
users.reset()
|
||||||
|
user.value = null
|
||||||
router.replace({ name: 'Login' })
|
router.replace({ name: 'Login' })
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
async function init() {
|
|
||||||
try {
|
|
||||||
await sessionUser.fetch()
|
|
||||||
} catch {
|
|
||||||
sessionUser.data = null
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
user,
|
user,
|
||||||
isLoggedIn,
|
isLoggedIn,
|
||||||
login,
|
login,
|
||||||
logout,
|
logout,
|
||||||
init,
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|||||||
48
frontend/src/stores/users.js
Normal file
48
frontend/src/stores/users.js
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
import { defineStore } from 'pinia'
|
||||||
|
import { createResource } from 'frappe-ui'
|
||||||
|
import { sessionStore } from './session'
|
||||||
|
import { reactive } from 'vue'
|
||||||
|
|
||||||
|
export const usersStore = defineStore('crm-users', () => {
|
||||||
|
const session = sessionStore()
|
||||||
|
|
||||||
|
let usersByName = reactive({})
|
||||||
|
|
||||||
|
const users = createResource({
|
||||||
|
url: 'crm.api.session.get_users',
|
||||||
|
cache: 'Users',
|
||||||
|
initialData: [],
|
||||||
|
transform(users) {
|
||||||
|
for (let user of users) {
|
||||||
|
usersByName[user.name] = user
|
||||||
|
}
|
||||||
|
return users
|
||||||
|
},
|
||||||
|
onError(error) {
|
||||||
|
if (error && error.exc_type === 'AuthenticationError') {
|
||||||
|
router.push('/login')
|
||||||
|
}
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
function getUser(email) {
|
||||||
|
if (!email || email === 'sessionUser') {
|
||||||
|
email = session.user
|
||||||
|
}
|
||||||
|
if (!usersByName[email]) {
|
||||||
|
usersByName[email] = {
|
||||||
|
name: email,
|
||||||
|
email: email,
|
||||||
|
full_name: email.split('@')[0],
|
||||||
|
user_image: null,
|
||||||
|
role: null,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return usersByName[email]
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
users,
|
||||||
|
getUser,
|
||||||
|
}
|
||||||
|
})
|
||||||
Loading…
x
Reference in New Issue
Block a user