mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-03-01 03:04:11 +00:00
- Create TelemetryService with multi-provider support and hook-based context resolution - Add TelemetryProviderBase abstract class for consistent provider implementation - Update MixpanelTelemetryProvider to use new architecture, remove legacy onboarding code - Register execution context hooks in workflowStore with real node metrics calculation - Eliminate circular dependencies through dependency inversion pattern
163 lines
4.2 KiB
TypeScript
163 lines
4.2 KiB
TypeScript
import { whenever } from '@vueuse/core'
|
|
import { computed, watch } from 'vue'
|
|
|
|
import { useFirebaseAuthActions } from '@/composables/auth/useFirebaseAuthActions'
|
|
import { t } from '@/i18n'
|
|
import { useTelemetryService } from '@/platform/telemetry'
|
|
import { useDialogService } from '@/services/dialogService'
|
|
import { useApiKeyAuthStore } from '@/stores/apiKeyAuthStore'
|
|
import { useCommandStore } from '@/stores/commandStore'
|
|
import { useFirebaseAuthStore } from '@/stores/firebaseAuthStore'
|
|
import type { AuthUserInfo } from '@/types/authTypes'
|
|
|
|
export const useCurrentUser = () => {
|
|
const authStore = useFirebaseAuthStore()
|
|
const commandStore = useCommandStore()
|
|
const apiKeyStore = useApiKeyAuthStore()
|
|
const dialogService = useDialogService()
|
|
const { deleteAccount } = useFirebaseAuthActions()
|
|
|
|
const firebaseUser = computed(() => authStore.currentUser)
|
|
const isApiKeyLogin = computed(() => apiKeyStore.isAuthenticated)
|
|
const isLoggedIn = computed(
|
|
() => !!isApiKeyLogin.value || firebaseUser.value !== null
|
|
)
|
|
|
|
const resolvedUserInfo = computed<AuthUserInfo | null>(() => {
|
|
if (isApiKeyLogin.value && apiKeyStore.currentUser) {
|
|
return { id: apiKeyStore.currentUser.id }
|
|
}
|
|
|
|
if (firebaseUser.value) {
|
|
return { id: firebaseUser.value.uid }
|
|
}
|
|
|
|
return null
|
|
})
|
|
|
|
const onUserResolved = (callback: (user: AuthUserInfo) => void) =>
|
|
whenever(resolvedUserInfo, callback, { immediate: true })
|
|
|
|
const onTokenRefreshed = (callback: () => void) =>
|
|
whenever(() => authStore.tokenRefreshTrigger, callback)
|
|
|
|
const onUserLogout = (callback: () => void) => {
|
|
watch(resolvedUserInfo, (user) => {
|
|
if (!user) callback()
|
|
})
|
|
}
|
|
|
|
const userDisplayName = computed(() => {
|
|
if (isApiKeyLogin.value) {
|
|
return apiKeyStore.currentUser?.name
|
|
}
|
|
return firebaseUser.value?.displayName
|
|
})
|
|
|
|
const userEmail = computed(() => {
|
|
if (isApiKeyLogin.value) {
|
|
return apiKeyStore.currentUser?.email
|
|
}
|
|
return firebaseUser.value?.email
|
|
})
|
|
|
|
const providerName = computed(() => {
|
|
if (isApiKeyLogin.value) {
|
|
return 'Comfy API Key'
|
|
}
|
|
|
|
const providerId = firebaseUser.value?.providerData[0]?.providerId
|
|
if (providerId?.includes('google')) {
|
|
return 'Google'
|
|
}
|
|
if (providerId?.includes('github')) {
|
|
return 'GitHub'
|
|
}
|
|
return providerId
|
|
})
|
|
|
|
const providerIcon = computed(() => {
|
|
if (isApiKeyLogin.value) {
|
|
return 'pi pi-key'
|
|
}
|
|
|
|
const providerId = firebaseUser.value?.providerData[0]?.providerId
|
|
if (providerId?.includes('google')) {
|
|
return 'pi pi-google'
|
|
}
|
|
if (providerId?.includes('github')) {
|
|
return 'pi pi-github'
|
|
}
|
|
return 'pi pi-user'
|
|
})
|
|
|
|
const isEmailProvider = computed(() => {
|
|
if (isApiKeyLogin.value) {
|
|
return false
|
|
}
|
|
|
|
const providerId = firebaseUser.value?.providerData[0]?.providerId
|
|
return providerId === 'password'
|
|
})
|
|
|
|
const userPhotoUrl = computed(() => {
|
|
if (isApiKeyLogin.value) return null
|
|
return firebaseUser.value?.photoURL
|
|
})
|
|
|
|
const handleSignOut = async () => {
|
|
if (isApiKeyLogin.value) {
|
|
await apiKeyStore.clearStoredApiKey()
|
|
} else {
|
|
await commandStore.execute('Comfy.User.SignOut')
|
|
}
|
|
}
|
|
|
|
const handleSignIn = async () => {
|
|
await commandStore.execute('Comfy.User.OpenSignInDialog')
|
|
}
|
|
|
|
const handleDeleteAccount = async () => {
|
|
const confirmed = await dialogService.confirm({
|
|
title: t('auth.deleteAccount.confirmTitle'),
|
|
message: t('auth.deleteAccount.confirmMessage'),
|
|
type: 'delete'
|
|
})
|
|
|
|
if (confirmed) {
|
|
await deleteAccount()
|
|
}
|
|
}
|
|
|
|
// Register telemetry hooks
|
|
const telemetryService = useTelemetryService()
|
|
telemetryService?.registerHooks({
|
|
getCurrentUser: () =>
|
|
resolvedUserInfo.value
|
|
? {
|
|
id: resolvedUserInfo.value.id,
|
|
tier: 'free' // This will be enhanced when we add subscription data
|
|
}
|
|
: null
|
|
})
|
|
|
|
return {
|
|
loading: authStore.loading,
|
|
isLoggedIn,
|
|
isApiKeyLogin,
|
|
isEmailProvider,
|
|
userDisplayName,
|
|
userEmail,
|
|
userPhotoUrl,
|
|
providerName,
|
|
providerIcon,
|
|
resolvedUserInfo,
|
|
handleSignOut,
|
|
handleSignIn,
|
|
handleDeleteAccount,
|
|
onUserResolved,
|
|
onTokenRefreshed,
|
|
onUserLogout
|
|
}
|
|
}
|