mirror of
https://github.com/Bubka/2FAuth.git
synced 2024-11-29 19:53:11 +01:00
127 lines
4.7 KiB
Vue
127 lines
4.7 KiB
Vue
<template>
|
|
<div class="modal is-active">
|
|
<div class="modal-background"></div>
|
|
<div class="modal-content">
|
|
<section class="section">
|
|
<div class="columns is-centered">
|
|
<div class="column is-three-quarters">
|
|
<div class="modal-slot box has-text-centered is-shadowless">
|
|
<div v-if="errorText">
|
|
<p class="block is-size-5">{{ $t('twofaccounts.stream.live_scan_cant_start') }}</p>
|
|
<p class="block" :class="{'has-text-light': $root.showDarkMode}">{{ $t('twofaccounts.stream.' + errorText + '.reason') }}</p>
|
|
<p class="is-size-7">{{ $t('twofaccounts.stream.' + errorText + '.solution') }}</p>
|
|
</div>
|
|
<span v-else class="is-size-4" :class="$root.showDarkMode ? 'has-text-light':'has-text-grey-dark'">
|
|
<font-awesome-icon :icon="['fas', 'spinner']" size="2x" spin />
|
|
</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
</div>
|
|
<div class="fullscreen-streamer">
|
|
<qrcode-stream @decode="submitUri" @init="onStreamerInit" camera="auto" />
|
|
</div>
|
|
<div class="fullscreen-footer">
|
|
<!-- Cancel button -->
|
|
<button class="button is-large is-warning is-rounded" @click="exitStream()">
|
|
{{ $t('commons.cancel') }}
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
|
|
import { QrcodeStream } from 'vue-qrcode-reader'
|
|
import Form from './../components/Form'
|
|
|
|
export default {
|
|
data(){
|
|
return {
|
|
showStream: true,
|
|
errorText: '',
|
|
form: new Form({
|
|
qrcode: null,
|
|
uri: '',
|
|
}),
|
|
}
|
|
},
|
|
|
|
components: {
|
|
QrcodeStream,
|
|
},
|
|
|
|
methods: {
|
|
|
|
exitStream() {
|
|
|
|
this.camera = 'off'
|
|
this.$router.go(-1)
|
|
|
|
},
|
|
|
|
async onStreamerInit (promise) {
|
|
|
|
try {
|
|
await promise
|
|
}
|
|
catch (error) {
|
|
|
|
if (error.name === 'NotAllowedError') {
|
|
this.errorText = 'need_grant_permission'
|
|
|
|
} else if (error.name === 'NotReadableError') {
|
|
this.errorText = 'not_readable'
|
|
|
|
} else if (error.name === 'NotFoundError') {
|
|
this.errorText = 'no_cam_on_device'
|
|
|
|
} else if (error.name === 'NotSupportedError' || error.name === 'InsecureContextError') {
|
|
this.errorText = 'secured_context_required'
|
|
|
|
} else if (error.name === 'OverconstrainedError') {
|
|
this.errorText = 'camera_not_suitable'
|
|
|
|
} else if (error.name === 'StreamApiNotSupportedError') {
|
|
this.errorText = 'stream_api_not_supported'
|
|
}
|
|
}
|
|
},
|
|
|
|
/**
|
|
* Push a decoded URI to the Create or Import form
|
|
*
|
|
* The basicQRcodeReader option is Off, so qrcode decoding has already be done by vue-qrcode-reader, whether
|
|
* from livescan or file input.
|
|
* We simply check the uri validity to prevent useless push to the form, but the form will check uri validity too.
|
|
*/
|
|
async submitUri(event) {
|
|
|
|
this.form.uri = event
|
|
|
|
if( !this.form.uri ) {
|
|
this.$notify({type: 'is-warning', text: this.$t('errors.qrcode_cannot_be_read') })
|
|
}
|
|
else if( this.form.uri.slice(0, 33).toLowerCase() == "otpauth-migration://offline?data=" ) {
|
|
this.pushUriToImportForm(this.form.uri)
|
|
}
|
|
else if( this.form.uri.slice(0, 15).toLowerCase() !== "otpauth://totp/" && this.form.uri.slice(0, 15).toLowerCase() !== "otpauth://hotp/" ) {
|
|
this.$notify({type: 'is-warning', text: this.$t('errors.no_valid_otp') })
|
|
}
|
|
else {
|
|
this.pushUriToCreateForm(this.form.uri)
|
|
}
|
|
},
|
|
|
|
pushUriToCreateForm(data) {
|
|
this.$router.push({ name: 'createAccount', params: { decodedUri: data } });
|
|
},
|
|
|
|
pushUriToImportForm(data) {
|
|
this.$router.push({ name: 'importAccounts', params: { migrationUri: data } });
|
|
}
|
|
}
|
|
}
|
|
|
|
</script> |