2024-05-23 11:42:14 +02:00
|
|
|
// SPDX-FileCopyrightText: 2024 John Livingston <https://www.john-livingston.fr/>
|
|
|
|
//
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2024-06-16 19:48:02 +02:00
|
|
|
import type { ProsodyAuthentInfos } from 'shared/lib/types'
|
2024-03-26 15:38:22 +01:00
|
|
|
|
2024-09-09 20:01:25 +02:00
|
|
|
type AuthHeader = Record<string, string>
|
2024-03-26 15:38:22 +01:00
|
|
|
|
|
|
|
async function getLocalAuthentInfos (
|
|
|
|
authenticationUrl: string,
|
2024-04-19 09:53:23 +02:00
|
|
|
tryExternalAuth: boolean,
|
2024-03-26 15:38:22 +01:00
|
|
|
peertubeAuthHeader?: AuthHeader | null
|
2024-06-16 19:48:02 +02:00
|
|
|
): Promise<false | ProsodyAuthentInfos> {
|
2023-05-04 19:14:23 +02:00
|
|
|
try {
|
|
|
|
if (authenticationUrl === '') {
|
|
|
|
console.error('Missing authenticationUrl')
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
if (!window.fetch) {
|
|
|
|
console.error('Your browser has not the fetch api, we cant log you in')
|
|
|
|
return false
|
|
|
|
}
|
2024-03-26 15:38:22 +01:00
|
|
|
|
|
|
|
if (peertubeAuthHeader === undefined) { // parameter not given.
|
|
|
|
// We must be in a page without PeertubeHelpers, so we must get authent token manualy.
|
|
|
|
if (!window.localStorage) {
|
|
|
|
// FIXME: is the Peertube token always in localStorage?
|
|
|
|
console.error('Your browser has no localStorage, we cant log you in')
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
const tokenType = window.localStorage.getItem('token_type') ?? ''
|
|
|
|
const accessToken = window.localStorage.getItem('access_token') ?? ''
|
|
|
|
const refreshToken = window.localStorage.getItem('refresh_token') ?? ''
|
|
|
|
if (tokenType === '' && accessToken === '' && refreshToken === '') {
|
|
|
|
console.info('User seems not to be logged in.')
|
2024-04-19 09:53:23 +02:00
|
|
|
// We must continue, for External Auth workflow.
|
2024-04-18 11:06:04 +02:00
|
|
|
peertubeAuthHeader = null
|
|
|
|
} else {
|
|
|
|
peertubeAuthHeader = {
|
|
|
|
Authorization: tokenType + ' ' + accessToken
|
|
|
|
}
|
2024-03-26 15:38:22 +01:00
|
|
|
}
|
2023-05-04 19:14:23 +02:00
|
|
|
}
|
|
|
|
|
2024-04-19 09:53:23 +02:00
|
|
|
let externalAuthHeaders: any
|
|
|
|
// When user has used the External Authentication mechanism to create an account, we got a token in sessionStorage.
|
|
|
|
if (tryExternalAuth && !peertubeAuthHeader && window.sessionStorage) {
|
|
|
|
const token = window.sessionStorage.getItem('peertube-plugin-livechat-external-auth-oidc-token')
|
2024-04-17 18:30:39 +02:00
|
|
|
if (token && (typeof token === 'string')) {
|
2024-04-19 09:53:23 +02:00
|
|
|
externalAuthHeaders = { 'X-Peertube-Plugin-Livechat-External-Auth-OIDC-Token': token }
|
2024-04-17 18:30:39 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-04-19 09:53:23 +02:00
|
|
|
if (peertubeAuthHeader === null && externalAuthHeaders === undefined) {
|
2024-04-17 18:30:39 +02:00
|
|
|
console.info('User is not logged in.')
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2023-05-04 19:14:23 +02:00
|
|
|
const response = await window.fetch(authenticationUrl, {
|
|
|
|
method: 'GET',
|
2024-03-26 15:38:22 +01:00
|
|
|
headers: new Headers(
|
|
|
|
Object.assign(
|
|
|
|
{},
|
2024-04-17 18:30:39 +02:00
|
|
|
peertubeAuthHeader ?? {},
|
2024-04-19 09:53:23 +02:00
|
|
|
externalAuthHeaders ?? {},
|
2024-03-26 15:38:22 +01:00
|
|
|
{
|
|
|
|
'content-type': 'application/json;charset=UTF-8'
|
|
|
|
}
|
2024-09-09 20:01:25 +02:00
|
|
|
) as HeadersInit
|
2024-03-26 15:38:22 +01:00
|
|
|
)
|
2023-05-04 19:14:23 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
if (!response.ok) {
|
|
|
|
console.error('Failed fetching user informations')
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
const data = await response.json()
|
|
|
|
if ((typeof data) !== 'object') {
|
|
|
|
console.error('Failed reading user informations')
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!data.jid || !data.password) {
|
|
|
|
console.error('User informations does not contain required fields')
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return {
|
|
|
|
jid: data.jid,
|
|
|
|
password: data.password,
|
2024-04-18 16:24:09 +02:00
|
|
|
nickname: data.nickname,
|
|
|
|
type: data.type ?? 'peertube'
|
2023-05-04 19:14:23 +02:00
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
console.error(error)
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-06-16 19:48:02 +02:00
|
|
|
/**
|
|
|
|
* Reads the livechat-token if relevant.
|
|
|
|
* This token can be passed to the page by adding the following hash to the window.location:
|
|
|
|
* `?j=the_xmpp_id&p=XXXXXXX&n=MyNickname`
|
|
|
|
*/
|
|
|
|
function getLivechatTokenAuthInfos (): ProsodyAuthentInfos | undefined {
|
|
|
|
try {
|
|
|
|
const hash = window.location.hash
|
2024-09-09 20:01:25 +02:00
|
|
|
if (!hash?.startsWith('#?')) { return undefined }
|
2024-06-16 19:48:02 +02:00
|
|
|
// We try to read the hash as a queryString.
|
|
|
|
const u = new URL('http://localhost' + hash.substring(1))
|
|
|
|
const jid = u.searchParams.get('j')
|
|
|
|
const password = u.searchParams.get('p')
|
|
|
|
if (!jid || !password) { return undefined }
|
|
|
|
|
|
|
|
const nickname = u.searchParams.get('n') ?? undefined
|
|
|
|
|
|
|
|
return {
|
|
|
|
type: 'livechat-token',
|
|
|
|
jid,
|
|
|
|
password,
|
|
|
|
nickname
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
console.error(error)
|
|
|
|
return undefined
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-05-04 19:14:23 +02:00
|
|
|
export {
|
2024-06-16 19:48:02 +02:00
|
|
|
ProsodyAuthentInfos,
|
|
|
|
getLocalAuthentInfos,
|
|
|
|
getLivechatTokenAuthInfos
|
2023-05-04 19:14:23 +02:00
|
|
|
}
|