From c58d6e34232e199406b39cb258e8106dc6b2f9c1 Mon Sep 17 00:00:00 2001 From: Corentin THOMASSET Date: Wed, 16 Aug 2023 23:43:45 +0200 Subject: feat(new tool): string obfuscator (#575) --- src/tools/string-obfuscator/index.ts | 12 ++++++ .../string-obfuscator.model.test.ts | 20 +++++++++ .../string-obfuscator/string-obfuscator.model.ts | 35 ++++++++++++++++ src/tools/string-obfuscator/string-obfuscator.vue | 47 ++++++++++++++++++++++ 4 files changed, 114 insertions(+) create mode 100644 src/tools/string-obfuscator/index.ts create mode 100644 src/tools/string-obfuscator/string-obfuscator.model.test.ts create mode 100644 src/tools/string-obfuscator/string-obfuscator.model.ts create mode 100644 src/tools/string-obfuscator/string-obfuscator.vue (limited to 'src/tools/string-obfuscator') diff --git a/src/tools/string-obfuscator/index.ts b/src/tools/string-obfuscator/index.ts new file mode 100644 index 0000000..d5b4531 --- /dev/null +++ b/src/tools/string-obfuscator/index.ts @@ -0,0 +1,12 @@ +import { EyeOff } from '@vicons/tabler'; +import { defineTool } from '../tool'; + +export const tool = defineTool({ + name: 'String obfuscator', + path: '/string-obfuscator', + description: 'Obfuscate a string (like a secret, an IBAN, or a token) to make it shareable and identifiable without revealing its content.', + keywords: ['string', 'obfuscator', 'secret', 'token', 'hide', 'obscure', 'mask', 'masking'], + component: () => import('./string-obfuscator.vue'), + icon: EyeOff, + createdAt: new Date('2023-08-16'), +}); diff --git a/src/tools/string-obfuscator/string-obfuscator.model.test.ts b/src/tools/string-obfuscator/string-obfuscator.model.test.ts new file mode 100644 index 0000000..08d3fc2 --- /dev/null +++ b/src/tools/string-obfuscator/string-obfuscator.model.test.ts @@ -0,0 +1,20 @@ +import { describe, expect, it } from 'vitest'; +import { obfuscateString } from './string-obfuscator.model'; + +describe('string-obfuscator model', () => { + describe('obfuscateString', () => { + it('the characters in the middle of the string are replaced by the replacement character', () => { + expect(obfuscateString('1234567890')).toBe('1234******'); + expect(obfuscateString('1234567890', { replacementChar: 'x' })).toBe('1234xxxxxx'); + expect(obfuscateString('1234567890', { keepFirst: 5 })).toBe('12345*****'); + expect(obfuscateString('1234567890', { keepFirst: 0, keepLast: 5 })).toBe('*****67890'); + expect(obfuscateString('1234567890', { keepFirst: 5, keepLast: 5 })).toBe('1234567890'); + expect(obfuscateString('1234567890', { keepFirst: 2, keepLast: 2, replacementChar: 'x' })).toBe('12xxxxxx90'); + }); + + it('by default, the spaces are kept, they can be removed with the keepSpace option', () => { + expect(obfuscateString('12345 67890')).toBe('1234* *****'); + expect(obfuscateString('12345 67890', { keepSpace: false })).toBe('1234*******'); + }); + }); +}); diff --git a/src/tools/string-obfuscator/string-obfuscator.model.ts b/src/tools/string-obfuscator/string-obfuscator.model.ts new file mode 100644 index 0000000..7f56dd1 --- /dev/null +++ b/src/tools/string-obfuscator/string-obfuscator.model.ts @@ -0,0 +1,35 @@ +import { get } from '@vueuse/core'; +import { type MaybeRef, computed } from 'vue'; + +export { obfuscateString, useObfuscateString }; + +function obfuscateString( + str: string, + { replacementChar = '*', keepFirst = 4, keepLast = 0, keepSpace = true }: { replacementChar?: string; keepFirst?: number; keepLast?: number; keepSpace?: boolean } = {}): string { + return str + .split('') + .map((char, index, array) => { + if (keepSpace && char === ' ') { + return char; + } + + return (index < keepFirst || index >= array.length - keepLast) ? char : replacementChar; + }) + .join(''); +} + +function useObfuscateString( + str: MaybeRef, + config: { replacementChar?: MaybeRef; keepFirst?: MaybeRef; keepLast?: MaybeRef; keepSpace?: MaybeRef } = {}, + +) { + return computed(() => obfuscateString( + get(str), + { + replacementChar: get(config.replacementChar), + keepFirst: get(config.keepFirst), + keepLast: get(config.keepLast), + keepSpace: get(config.keepSpace), + }, + )); +} diff --git a/src/tools/string-obfuscator/string-obfuscator.vue b/src/tools/string-obfuscator/string-obfuscator.vue new file mode 100644 index 0000000..0f11fca --- /dev/null +++ b/src/tools/string-obfuscator/string-obfuscator.vue @@ -0,0 +1,47 @@ + + + -- cgit v1.2.3