mirror of
https://github.com/CorentinTh/it-tools.git
synced 2025-04-20 23:06:14 -04:00
64 lines
1.9 KiB
Vue
64 lines
1.9 KiB
Vue
![]() |
<template>
|
||
|
<n-card>
|
||
|
<n-form-item label="JWT to decode" :feedback="validation.message" :validation-status="validation.status">
|
||
|
<n-input v-model:value="rawJwt" type="textarea" placeholder="Put your token here..." rows="5" />
|
||
|
</n-form-item>
|
||
|
|
||
|
<n-table>
|
||
|
<tbody>
|
||
|
<td colspan="2" class="table-header"><strong>Header</strong></td>
|
||
|
<tr v-for="[key, value] in Object.entries(decodedJWT.header)" :key="key">
|
||
|
<td class="claims"><claim-vue :claim="key" /></td>
|
||
|
<td>
|
||
|
<value-vue :claim="key" :value="value" />
|
||
|
</td>
|
||
|
</tr>
|
||
|
<td colspan="2" class="table-header"><strong>Payload</strong></td>
|
||
|
<tr v-for="[key, value] in Object.entries(decodedJWT.payload)" :key="key">
|
||
|
<td class="claims"><claim-vue :claim="key" /></td>
|
||
|
<td>
|
||
|
<value-vue :claim="key" :value="value" />
|
||
|
</td>
|
||
|
</tr>
|
||
|
</tbody>
|
||
|
</n-table>
|
||
|
</n-card>
|
||
|
</template>
|
||
|
|
||
|
<script setup lang="ts">
|
||
|
import { computed, ref } from 'vue';
|
||
|
import jwt_decode from 'jwt-decode';
|
||
|
import { useValidation } from '@/composable/validation';
|
||
|
import { isNotThrowing } from '@/utils/boolean';
|
||
|
import { safeJwtDecode } from './jwt-parser.service';
|
||
|
import claimVue from './claim.vue';
|
||
|
import valueVue from './value.vue';
|
||
|
|
||
|
const rawJwt = ref(
|
||
|
'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c',
|
||
|
);
|
||
|
|
||
|
const decodedJWT = computed(() => {
|
||
|
return safeJwtDecode(rawJwt.value);
|
||
|
});
|
||
|
const validation = useValidation({
|
||
|
source: rawJwt,
|
||
|
rules: [
|
||
|
{
|
||
|
validator: (value) => value.length > 0 && isNotThrowing(() => jwt_decode(value, { header: true })),
|
||
|
message: 'Invalid JWT',
|
||
|
},
|
||
|
],
|
||
|
});
|
||
|
</script>
|
||
|
|
||
|
<style lang="less" scoped>
|
||
|
.table-header {
|
||
|
text-align: center;
|
||
|
}
|
||
|
|
||
|
.claims {
|
||
|
width: 20%;
|
||
|
}
|
||
|
</style>
|