mirror of
https://github.com/CorentinTh/it-tools.git
synced 2025-05-05 22:07:10 -04:00
feat(new tool): IPv6 Subnet Calculator
IPv6 Subnet Calculator Fix #354 and #924
This commit is contained in:
parent
d7a8c65067
commit
1f67ba15e9
10 changed files with 285 additions and 111 deletions
|
@ -6,6 +6,7 @@ import { tool as asciiTextDrawer } from './ascii-text-drawer';
|
|||
|
||||
import { tool as textToUnicode } from './text-to-unicode';
|
||||
import { tool as safelinkDecoder } from './safelink-decoder';
|
||||
import { tool as ipv6SubnetCalculator } from './ipv6-subnet-calculator';
|
||||
import { tool as pdfSignatureChecker } from './pdf-signature-checker';
|
||||
import { tool as numeronymGenerator } from './numeronym-generator';
|
||||
import { tool as macAddressGenerator } from './mac-address-generator';
|
||||
|
@ -152,7 +153,15 @@ export const toolsByCategory: ToolCategory[] = [
|
|||
},
|
||||
{
|
||||
name: 'Network',
|
||||
components: [ipv4SubnetCalculator, ipv4AddressConverter, ipv4RangeExpander, macAddressLookup, macAddressGenerator, ipv6UlaGenerator],
|
||||
components: [
|
||||
ipv4SubnetCalculator,
|
||||
ipv6SubnetCalculator,
|
||||
ipv4AddressConverter,
|
||||
ipv4RangeExpander,
|
||||
macAddressLookup,
|
||||
macAddressGenerator,
|
||||
ipv6UlaGenerator,
|
||||
],
|
||||
},
|
||||
{
|
||||
name: 'Math',
|
||||
|
|
12
src/tools/ipv6-subnet-calculator/index.ts
Normal file
12
src/tools/ipv6-subnet-calculator/index.ts
Normal file
|
@ -0,0 +1,12 @@
|
|||
import { RouterOutlined } from '@vicons/material';
|
||||
import { defineTool } from '../tool';
|
||||
|
||||
export const tool = defineTool({
|
||||
name: 'Ipv6 subnet calculator',
|
||||
path: '/ipv6-subnet-calculator',
|
||||
description: 'Parse your IPv6 CIDR blocks and get all the info you need about your sub network.',
|
||||
keywords: ['ipv6', 'subnet', 'calculator', 'mask', 'network', 'cidr', 'netmask', 'bitmask', 'broadcast', 'address'],
|
||||
component: () => import('./ipv6-subnet-calculator.vue'),
|
||||
icon: RouterOutlined,
|
||||
createdAt: new Date('2024-02-25'),
|
||||
});
|
126
src/tools/ipv6-subnet-calculator/ipv6-subnet-calculator.vue
Normal file
126
src/tools/ipv6-subnet-calculator/ipv6-subnet-calculator.vue
Normal file
|
@ -0,0 +1,126 @@
|
|||
<script setup lang="ts">
|
||||
import isCidr from 'is-cidr';
|
||||
import { useStorage } from '@vueuse/core';
|
||||
import Network from '@/libs/ip_calculator/network';
|
||||
import { withDefaultOnError } from '@/utils/defaults';
|
||||
import SpanCopyable from '@/components/SpanCopyable.vue';
|
||||
|
||||
const ip = useStorage('ipv6-subnet-calculator:ip', '2001:db8:0:85a3:0:0:ac1f:8001/32');
|
||||
|
||||
function getNetworkInfo(address: string) {
|
||||
const [ip, mask] = address.split('/');
|
||||
return new Network(ip.trim(), Number(mask?.trim() || '32'));
|
||||
}
|
||||
|
||||
const networkInfo = computed(() => withDefaultOnError(() =>
|
||||
isCidr(ip.value.trim()) === 6 ? getNetworkInfo(ip.value) : undefined, undefined));
|
||||
|
||||
const ipValidationRules = [
|
||||
{
|
||||
message: 'We cannot parse this address, check the format',
|
||||
validator: (value: string) => isCidr(value.trim()) === 6,
|
||||
},
|
||||
];
|
||||
|
||||
const sections: {
|
||||
label: string
|
||||
getValue: (net: Network) => string | undefined
|
||||
undefinedFallback?: string
|
||||
}[] = [
|
||||
{
|
||||
label: 'Full address',
|
||||
getValue: net => net.address.toString(),
|
||||
},
|
||||
{
|
||||
label: 'Short address',
|
||||
getValue: net => net.toCompressed(net.address || '', net.version || 4)?.toString(),
|
||||
},
|
||||
{
|
||||
label: 'Address as binary',
|
||||
getValue: (net) => {
|
||||
const binary = net.toBinary();
|
||||
const hBin = binary.length / 2;
|
||||
return `${binary.substring(0, hBin)} ${
|
||||
binary.substring(hBin, binary.length)}`;
|
||||
},
|
||||
},
|
||||
{
|
||||
label: 'Address as integer',
|
||||
getValue: net => net.toInteger().toString(),
|
||||
},
|
||||
{
|
||||
label: 'Address as hex',
|
||||
getValue: net => net.toHEX().toString(),
|
||||
},
|
||||
{
|
||||
label: 'Network address',
|
||||
getValue: net => net.getNetwork().toString(),
|
||||
},
|
||||
{
|
||||
label: 'Network address as integer',
|
||||
getValue: net => net.networkToInteger().toString(),
|
||||
},
|
||||
{
|
||||
label: 'Network mask size',
|
||||
getValue: net => net.prefix.toString(),
|
||||
},
|
||||
{
|
||||
label: 'Network mask',
|
||||
getValue: net => net.getMask().toString(),
|
||||
},
|
||||
{
|
||||
label: 'Network mask as integer',
|
||||
getValue: net => net.maskToInteger().toString(),
|
||||
},
|
||||
{
|
||||
label: 'Network size',
|
||||
getValue: net => net.networkSize().toString(),
|
||||
},
|
||||
{
|
||||
label: 'Networks count',
|
||||
getValue: net => net.networkCount().toString(),
|
||||
},
|
||||
{
|
||||
label: 'First address',
|
||||
getValue: net => net.hostRange()[0],
|
||||
},
|
||||
{
|
||||
label: 'Last address',
|
||||
getValue: net => net.hostRange()[1],
|
||||
},
|
||||
{
|
||||
label: 'Type',
|
||||
getValue: net => net.printInfo()?.toString(),
|
||||
},
|
||||
];
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<div>
|
||||
<c-input-text
|
||||
v-model:value="ip"
|
||||
label="An IPv6 address with or without mask"
|
||||
placeholder="The ipv6 address..."
|
||||
:validation-rules="ipValidationRules"
|
||||
mb-4
|
||||
/>
|
||||
|
||||
<div v-if="networkInfo">
|
||||
<n-table>
|
||||
<tbody>
|
||||
<tr v-for="{ getValue, label, undefinedFallback } in sections" :key="label">
|
||||
<td font-bold>
|
||||
{{ label }}
|
||||
</td>
|
||||
<td>
|
||||
<SpanCopyable v-if="networkInfo" :value="getValue(networkInfo)" />
|
||||
<span v-else op-70>
|
||||
{{ undefinedFallback }}
|
||||
</span>
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</n-table>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
Loading…
Add table
Add a link
Reference in a new issue