mirror of
https://github.com/lnbits/lnbits.git
synced 2025-08-03 15:32:22 +02:00
fix: nostr login (#2975)
This commit is contained in:
2
lnbits/static/bundle-components.min.js
vendored
2
lnbits/static/bundle-components.min.js
vendored
File diff suppressed because one or more lines are too long
@@ -592,6 +592,80 @@ window.app.component('username-password', {
|
||||
'^(?=[a-zA-Z0-9._]{2,20}$)(?!.*[_.]{2})[^_.].*[^_.]$'
|
||||
)
|
||||
return usernameRegex.test(val)
|
||||
},
|
||||
async signInWithNostr() {
|
||||
try {
|
||||
console.log('### signInWithNostr')
|
||||
const nostrToken = await this.createNostrToken()
|
||||
if (!nostrToken) {
|
||||
return
|
||||
}
|
||||
resp = await LNbits.api.loginByProvider(
|
||||
'nostr',
|
||||
{Authorization: nostrToken},
|
||||
{}
|
||||
)
|
||||
window.location.href = '/wallet'
|
||||
} catch (error) {
|
||||
console.warn(error)
|
||||
const details = error?.response?.data?.detail || `${error}`
|
||||
Quasar.Notify.create({
|
||||
type: 'negative',
|
||||
message: 'Failed to sign in with Nostr.',
|
||||
caption: details
|
||||
})
|
||||
}
|
||||
},
|
||||
async createNostrToken() {
|
||||
try {
|
||||
async function _signEvent(e) {
|
||||
try {
|
||||
const {data} = await LNbits.api.getServerHealth()
|
||||
e.created_at = data.server_time
|
||||
return await window.nostr.signEvent(e)
|
||||
} catch (error) {
|
||||
console.error(error)
|
||||
Quasar.Notify.create({
|
||||
type: 'negative',
|
||||
message: 'Failed to sign nostr event.',
|
||||
caption: `${error}`
|
||||
})
|
||||
}
|
||||
}
|
||||
if (!window.nostr?.signEvent) {
|
||||
Quasar.Notify.create({
|
||||
type: 'negative',
|
||||
message: 'No Nostr signing app detected.',
|
||||
caption: 'Is "window.nostr" present?'
|
||||
})
|
||||
return
|
||||
}
|
||||
const tagU = `${window.location}nostr`
|
||||
const tagMethod = 'POST'
|
||||
const nostrToken = await NostrTools.nip98.getToken(
|
||||
tagU,
|
||||
tagMethod,
|
||||
e => _signEvent(e),
|
||||
true
|
||||
)
|
||||
const isTokenValid = await NostrTools.nip98.validateToken(
|
||||
nostrToken,
|
||||
tagU,
|
||||
tagMethod
|
||||
)
|
||||
if (!isTokenValid) {
|
||||
throw new Error('Invalid signed token!')
|
||||
}
|
||||
|
||||
return nostrToken
|
||||
} catch (error) {
|
||||
console.warn(error)
|
||||
Quasar.Notify.create({
|
||||
type: 'negative',
|
||||
message: 'Failed create Nostr event.',
|
||||
caption: `${error}`
|
||||
})
|
||||
}
|
||||
}
|
||||
},
|
||||
computed: {
|
||||
|
@@ -45,79 +45,7 @@ window.app = Vue.createApp({
|
||||
this.authAction = 'register'
|
||||
this.authMethod = authMethod
|
||||
},
|
||||
async signInWithNostr() {
|
||||
try {
|
||||
const nostrToken = await this.createNostrToken()
|
||||
if (!nostrToken) {
|
||||
return
|
||||
}
|
||||
resp = await LNbits.api.loginByProvider(
|
||||
'nostr',
|
||||
{Authorization: nostrToken},
|
||||
{}
|
||||
)
|
||||
window.location.href = '/wallet'
|
||||
} catch (error) {
|
||||
console.warn(error)
|
||||
const details = error?.response?.data?.detail || `${error}`
|
||||
Quasar.Notify.create({
|
||||
type: 'negative',
|
||||
message: 'Failed to sign in with Nostr.',
|
||||
caption: details
|
||||
})
|
||||
}
|
||||
},
|
||||
async createNostrToken() {
|
||||
try {
|
||||
async function _signEvent(e) {
|
||||
try {
|
||||
const {data} = await LNbits.api.getServerHealth()
|
||||
e.created_at = data.server_time
|
||||
return await window.nostr.signEvent(e)
|
||||
} catch (error) {
|
||||
console.error(error)
|
||||
Quasar.Notify.create({
|
||||
type: 'negative',
|
||||
message: 'Failed to sign nostr event.',
|
||||
caption: `${error}`
|
||||
})
|
||||
}
|
||||
}
|
||||
if (!window.nostr?.signEvent) {
|
||||
Quasar.Notify.create({
|
||||
type: 'negative',
|
||||
message: 'No Nostr signing app detected.',
|
||||
caption: 'Is "window.nostr" present?'
|
||||
})
|
||||
return
|
||||
}
|
||||
const tagU = `${window.location}nostr`
|
||||
const tagMethod = 'POST'
|
||||
const nostrToken = await NostrTools.nip98.getToken(
|
||||
tagU,
|
||||
tagMethod,
|
||||
e => _signEvent(e),
|
||||
true
|
||||
)
|
||||
const isTokenValid = await NostrTools.nip98.validateToken(
|
||||
nostrToken,
|
||||
tagU,
|
||||
tagMethod
|
||||
)
|
||||
if (!isTokenValid) {
|
||||
throw new Error('Invalid signed token!')
|
||||
}
|
||||
|
||||
return nostrToken
|
||||
} catch (error) {
|
||||
console.warn(error)
|
||||
Quasar.Notify.create({
|
||||
type: 'negative',
|
||||
message: 'Failed create Nostr event.',
|
||||
caption: `${error}`
|
||||
})
|
||||
}
|
||||
},
|
||||
async register() {
|
||||
try {
|
||||
await LNbits.api.register(
|
||||
|
@@ -1312,7 +1312,7 @@
|
||||
<div class="flex justify-center q-mt-md" style="gap: 1rem">
|
||||
<q-btn
|
||||
v-if="authMethods.includes('nostr-auth-nip98')"
|
||||
@click="signInWithNostr"
|
||||
@click="signInWithNostr()"
|
||||
outline
|
||||
no-caps
|
||||
color="grey"
|
||||
|
Reference in New Issue
Block a user