mirror of
https://github.com/IT4Change/gradido.git
synced 2026-02-06 09:56:05 +00:00
71 lines
2.7 KiB
TypeScript
71 lines
2.7 KiB
TypeScript
import { FederatedCommunity as DbFederatedCommunity } from '@entity/FederatedCommunity'
|
|
import { GraphQLClient } from 'graphql-request'
|
|
import { federationLogger as logger } from '@/server/logger'
|
|
|
|
import { OpenConnectionCallbackArgs } from '@/graphql/api/1_0/model/OpenConnectionCallbackArgs'
|
|
import { openConnectionCallback } from './query/openConnectionCallback'
|
|
import { AuthenticationArgs } from '@/graphql/api/1_0/model/AuthenticationArgs'
|
|
import { authenticate } from './query/authenticate'
|
|
|
|
export class AuthenticationClient {
|
|
dbCom: DbFederatedCommunity
|
|
endpoint: string
|
|
client: GraphQLClient
|
|
|
|
constructor(dbCom: DbFederatedCommunity) {
|
|
this.dbCom = dbCom
|
|
this.endpoint = `${dbCom.endPoint.endsWith('/') ? dbCom.endPoint : dbCom.endPoint + '/'}${
|
|
dbCom.apiVersion
|
|
}/`
|
|
this.client = new GraphQLClient(this.endpoint, {
|
|
method: 'POST',
|
|
jsonSerializer: {
|
|
parse: JSON.parse,
|
|
stringify: JSON.stringify,
|
|
},
|
|
})
|
|
}
|
|
|
|
async openConnectionCallback(args: OpenConnectionCallbackArgs): Promise<boolean> {
|
|
logger.debug('Authentication: openConnectionCallback with endpoint', this.endpoint, args)
|
|
try {
|
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-explicit-any
|
|
const { data } = await this.client.rawRequest<any>(openConnectionCallback, { args })
|
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
|
|
if (data && data.openConnectionCallback) {
|
|
logger.warn(
|
|
'Authentication: openConnectionCallback without response data from endpoint',
|
|
this.endpoint,
|
|
)
|
|
return false
|
|
}
|
|
logger.debug(
|
|
'Authentication: openConnectionCallback successfully started with endpoint',
|
|
this.endpoint,
|
|
)
|
|
return true
|
|
} catch (err) {
|
|
logger.error('Authentication: error on openConnectionCallback', err)
|
|
}
|
|
return false
|
|
}
|
|
|
|
async authenticate(args: AuthenticationArgs): Promise<string | null> {
|
|
logger.debug('Authentication: authenticate with endpoint=', this.endpoint)
|
|
try {
|
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-explicit-any
|
|
const { data } = await this.client.rawRequest<any>(authenticate, { args })
|
|
logger.debug('Authentication: after authenticate: data:', data)
|
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
|
|
const authUuid: string = data?.authenticate
|
|
if (authUuid) {
|
|
logger.debug('Authentication: received authenticated uuid', authUuid)
|
|
return authUuid
|
|
}
|
|
} catch (err) {
|
|
logger.error('Authentication: authenticate failed for endpoint', this.endpoint)
|
|
}
|
|
return null
|
|
}
|
|
}
|