aboutsummaryrefslogtreecommitdiffstats
path: root/apps/settings/src/service/WebAuthnRegistrationSerice.ts
blob: 7e881ce61e2d38f0b8e8bd12e54885785b2bc4d9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/**
 * SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors
 * SPDX-License-Identifier: AGPL-3.0-or-later
 */

import type { RegistrationResponseJSON } from '@simplewebauthn/types'

import { translate as t } from '@nextcloud/l10n'
import { generateUrl } from '@nextcloud/router'
import { startRegistration as registerWebAuthn } from '@simplewebauthn/browser'

import axios, { isAxiosError } from '@nextcloud/axios'
import logger from '../logger'

/**
 * Start registering a new device
 * @return The device attributes
 */
export async function startRegistration() {
	const url = generateUrl('/settings/api/personal/webauthn/registration')

	try {
		logger.debug('Fetching webauthn registration data')
		const { data } = await axios.get(url)
		logger.debug('Start webauthn registration')
		const attrs = await registerWebAuthn(data)
		return attrs
	} catch (e) {
		logger.error(e as Error)
		if (isAxiosError(e)) {
			throw new Error(t('settings', 'Could not register device: Network error'))
		} else if ((e as Error).name === 'InvalidStateError') {
			throw new Error(t('settings', 'Could not register device: Probably already registered'))
		}
		throw new Error(t('settings', 'Could not register device'))
	}
}

/**
 * @param name Name of the device
 * @param data Device attributes
 */
export async function finishRegistration(name: string, data: RegistrationResponseJSON) {
	const url = generateUrl('/settings/api/personal/webauthn/registration')

	const resp = await axios.post(url, { name, data: JSON.stringify(data) })
	return resp.data
}

/**
 * @param id Remove registered device with that id
 */
export async function removeRegistration(id: string | number) {
	const url = generateUrl(`/settings/api/personal/webauthn/registration/${id}`)

	await axios.delete(url)
}