2024-04-15 18:29:09 +02:00
|
|
|
import type { RegisterServerOptions } from '@peertube/peertube-types'
|
|
|
|
import { newResult, TestResult } from './utils'
|
2024-04-22 13:03:31 +02:00
|
|
|
import { ExternalAuthOIDC, ExternalAuthOIDCType } from '../external-auth/oidc'
|
2024-04-15 18:29:09 +02:00
|
|
|
|
2024-04-22 13:03:31 +02:00
|
|
|
export async function diagExternalAuthOIDC (
|
|
|
|
test: string,
|
|
|
|
_options: RegisterServerOptions,
|
|
|
|
singletonType: ExternalAuthOIDCType,
|
|
|
|
next: TestResult['next']
|
|
|
|
): Promise<TestResult> {
|
2024-04-15 18:29:09 +02:00
|
|
|
const result = newResult(test)
|
2024-04-22 13:03:31 +02:00
|
|
|
result.label = 'Test External Auth OIDC: ' + singletonType
|
|
|
|
result.next = next
|
2024-04-15 18:29:09 +02:00
|
|
|
|
|
|
|
try {
|
2024-04-22 13:03:31 +02:00
|
|
|
const oidc = ExternalAuthOIDC.singleton(singletonType)
|
2024-04-15 18:29:09 +02:00
|
|
|
|
|
|
|
if (oidc.isDisabledBySettings()) {
|
|
|
|
result.ok = true
|
|
|
|
result.messages.push('Feature disabled in plugins settings.')
|
|
|
|
return result
|
|
|
|
}
|
|
|
|
|
2024-04-16 11:43:38 +02:00
|
|
|
result.messages.push('Discovery URL: ' + (oidc.getDiscoveryUrl() ?? 'undefined'))
|
|
|
|
|
|
|
|
const oidcErrors = await oidc.check()
|
|
|
|
if (oidcErrors.length) {
|
2024-04-15 18:29:09 +02:00
|
|
|
result.messages.push({
|
|
|
|
level: 'error',
|
|
|
|
message: 'The ExternalAuthOIDC singleton got some errors:'
|
|
|
|
})
|
2024-04-16 11:43:38 +02:00
|
|
|
for (const oidcError of oidcErrors) {
|
|
|
|
result.messages.push({
|
|
|
|
level: 'error',
|
|
|
|
message: oidcError
|
|
|
|
})
|
|
|
|
}
|
2024-04-15 18:29:09 +02:00
|
|
|
return result
|
|
|
|
}
|
|
|
|
} catch (err) {
|
|
|
|
result.messages.push({
|
|
|
|
level: 'error',
|
|
|
|
message: 'Error while retrieving the ExternalAuthOIDC singleton:' + (err as string)
|
|
|
|
})
|
|
|
|
return result
|
|
|
|
}
|
|
|
|
|
2024-04-22 13:03:31 +02:00
|
|
|
const oidc = ExternalAuthOIDC.singleton(singletonType)
|
2024-04-16 17:18:14 +02:00
|
|
|
const oidcClient = await oidc.load()
|
|
|
|
if (oidcClient) {
|
|
|
|
result.messages.push('Discovery URL loaded: ' + JSON.stringify(oidcClient.issuer.metadata))
|
2024-04-16 11:43:38 +02:00
|
|
|
} else {
|
|
|
|
result.messages.push({
|
|
|
|
level: 'error',
|
|
|
|
message: 'Failed to load the Discovery URL.'
|
|
|
|
})
|
|
|
|
return result
|
|
|
|
}
|
|
|
|
|
2024-04-15 18:29:09 +02:00
|
|
|
result.ok = true
|
|
|
|
result.messages.push('Configuration OK.')
|
|
|
|
return result
|
|
|
|
}
|