From e7573bdec628ee42950db3c3db16aa412b21bd06 Mon Sep 17 00:00:00 2001 From: Johan le stickman Date: Tue, 20 Aug 2024 21:09:32 +0200 Subject: [PATCH] =?UTF-8?q?Nvl=20algorithme=20pour=20g=C3=A9n=C3=A9rer=20d?= =?UTF-8?q?es=20code?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit + rapide (90ms --> 40ms sur 100k gens) + propre et rapide à écrire sur un clavier AZERTY --- package.json | 2 +- utils/generateCode.js | 96 +++++++++++++++++++-------------------- utils/generateCode.old.js | 61 +++++++++++++++++++++++++ 3 files changed, 109 insertions(+), 50 deletions(-) create mode 100644 utils/generateCode.old.js diff --git a/package.json b/package.json index 484cfd3..c2f13ed 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "private": true, "name": "stend-api", - "version": "2.2.0", + "version": "2.2.1", "description": "Télécharger et envoyer des fichiers via Stend", "main": "index.js", "scripts": { diff --git a/utils/generateCode.js b/utils/generateCode.js index a246a6f..69e75c5 100644 --- a/utils/generateCode.js +++ b/utils/generateCode.js @@ -1,59 +1,57 @@ - -// Liste de tout les caractères qu'on utilisera pour générer le code, ainsi que les caractères qui les entourent -const alphabet = [ - { char: 'a', surrounding: ['z', 'q'] }, { char: 'b', surrounding: ['v', 'n'] }, { char: 'c', surrounding: ['v', 'd'] }, - { char: 'd', surrounding: ['s', 'e', 'f', 'c'] }, { char: 'e', surrounding: ['z', 'r'] }, { char: 'f', surrounding: ['d', 'r', 'g'] }, - { char: 'g', surrounding: ['f', 'h'] }, { char: 'h', surrounding: ['g', 'y'] }, { char: 'i', surrounding: ['u', 'o'] }, - { char: 'k', surrounding: ['l', 'i'] }, { char: 'l', surrounding: ['k', 'o'] }, { char: 'n', surrounding: ['b', 'h'] }, - { char: 'o', surrounding: ['i', 'l'] }, { char: 'q', surrounding: ['a', 's'] }, { char: 'r', surrounding: ['e', 't'] }, - { char: 's', surrounding: ['q', 'd'] }, { char: 't', surrounding: ['r', 'y'] }, { char: 'u', surrounding: ['y', 'i'] }, - { char: 'v', surrounding: ['c', 'b'] }, { char: 'y', surrounding: ['t', 'u'] }, - { char: 'z', surrounding: ['a', 'e'] } // IMPORTANT: toujours garder au moins 2 éléments uniques dans surrounding - /*, { char: '1', surrounding: ['2'] }, { char: '2', surrounding: ['1','3'] }, - { char: '3', surrounding: ['2','4'] }, { char: '4', surrounding: ['3','5'] }, { char: '5', surrounding: ['4','6'] }, - { char: '6', surrounding: ['5','7'] }, { char: '7', surrounding: ['6','8'] }, { char: '8', surrounding: ['7','9'] }, - { char: '9', surrounding: ['8','0'] }, { char: '0', surrounding: ['9'] },*/ // j'ai tenté de rendre le code plus propre ptdrr +const charsGroups = [ + 'df', + 'az', + 'iu', + 'li', + 'rt', + 're', + 'er', + 'nn', + 'po', + 'oi', + 'tu', + 'tr', + 'es', + 'ed', + 'as', + 'de', + 'mo', + 'se', + 'op', + 'lo', + 'zq', + 'tg', + 'cv', + 'pl', + 'sc', + 'om', + 'sdf', + 'oui', + 'jkl', + 'aze', + 'fer', + 'ser', ] +function chooseRandomCharGroup(lastChar){ + var random = charsGroups[Math.floor(Math.random() * charsGroups.length)] + if(lastChar && (random.endsWith(lastChar) || random.startsWith(lastChar))) return chooseRandomCharGroup(lastChar) + return random +} + // Fonction qui génère un code aléatoire -function generateCode(length){ - // Générer tout les caractères +function generateCode(length = 8){ var code = '' - for(var i = 0; i < length; i++){ - // Si on a pas de caractère, on en génère un aléatoire - if(code.length < 1){ - code += alphabet[Math.floor(Math.random() * alphabet.length)].char - continue - } else { - // Sinon, on prend le précédent caractère et on lui ajoute un caractère assez proche - var lastChar = code[code.length - 1] - var lastCharIndex = alphabet.findIndex(char => char.char === lastChar) - var surrounding = alphabet[lastCharIndex].surrounding - var char = surrounding[Math.floor(Math.random() * surrounding.length)] - // On évite que le caractère soit le même que le précédent - while(char === lastChar) char = surrounding[Math.floor(Math.random() * surrounding.length)] // si le caractère est le même, on en génère un autre - - // On évite à moitié que le caractère soit le même que l'avant dernier - if(code.length > 1){ - var beforeLastChar = code[code.length - 2] - if(char === beforeLastChar) char = surrounding[Math.floor(Math.random() * surrounding.length)] - } - - // On ajoute le caractère au code - code += char - } + // Répéter jusque la longueur voulu soit atteinte + while (code.length < length){ + var random = chooseRandomCharGroup(code[code.length - 1]) + if(code.length > 1 && code.endsWith(random)) continue + code += random } - // On veut pas beaucoup de chiffres dans les codes, donc si on en a plus de deux, on les remplace par des lettres - var numbers = code.match(/[0-9]/g) - var alphabetWithoutNumbers = alphabet.filter(char => !char.char.match(/[0-9]/g)) - if(numbers && numbers.length > (length - 4)){ - numbers.forEach(number => { - var index = code.indexOf(number) - code = code.slice(0, index) + alphabetWithoutNumbers[Math.floor(Math.random() * alphabetWithoutNumbers.length)].char + code.slice(index + 1) - }) - } + // Cut le code s'il est trop long + code = code.slice(0, length) // On retourne le code return code diff --git a/utils/generateCode.old.js b/utils/generateCode.old.js new file mode 100644 index 0000000..88d4ad8 --- /dev/null +++ b/utils/generateCode.old.js @@ -0,0 +1,61 @@ +// Liste de tout les caractères qu'on utilisera pour générer le code, ainsi que les caractères qui les entourent +const alphabet = [ + { char: 'a', surrounding: ['z', 'q'] }, { char: 'b', surrounding: ['v', 'n'] }, { char: 'c', surrounding: ['v', 'd'] }, + { char: 'd', surrounding: ['s', 'e', 'f', 'c'] }, { char: 'e', surrounding: ['z', 'r'] }, { char: 'f', surrounding: ['d', 'r', 'g'] }, + { char: 'g', surrounding: ['f', 'h'] }, { char: 'h', surrounding: ['g', 'y'] }, { char: 'i', surrounding: ['u', 'o'] }, + { char: 'k', surrounding: ['l', 'i'] }, { char: 'l', surrounding: ['k', 'o'] }, { char: 'n', surrounding: ['b', 'h'] }, + { char: 'o', surrounding: ['i', 'l'] }, { char: 'q', surrounding: ['a', 's'] }, { char: 'r', surrounding: ['e', 't'] }, + { char: 's', surrounding: ['q', 'd'] }, { char: 't', surrounding: ['r', 'y'] }, { char: 'u', surrounding: ['y', 'i'] }, + { char: 'v', surrounding: ['c', 'b'] }, { char: 'y', surrounding: ['t', 'u'] }, + { char: 'z', surrounding: ['a', 'e'] } // IMPORTANT: toujours garder au moins 2 éléments uniques dans surrounding + /*, { char: '1', surrounding: ['2'] }, { char: '2', surrounding: ['1','3'] }, + { char: '3', surrounding: ['2','4'] }, { char: '4', surrounding: ['3','5'] }, { char: '5', surrounding: ['4','6'] }, + { char: '6', surrounding: ['5','7'] }, { char: '7', surrounding: ['6','8'] }, { char: '8', surrounding: ['7','9'] }, + { char: '9', surrounding: ['8','0'] }, { char: '0', surrounding: ['9'] },*/ // j'ai tenté de rendre le code plus propre ptdrr +] + +// Fonction qui génère un code aléatoire +function generateCode(length){ + // Générer tout les caractères + var code = '' + for(var i = 0; i < length; i++){ + // Si on a pas de caractère, on en génère un aléatoire + if(code.length < 1){ + code += alphabet[Math.floor(Math.random() * alphabet.length)].char + continue + } else { + // Sinon, on prend le précédent caractère et on lui ajoute un caractère assez proche + var lastChar = code[code.length - 1] + var lastCharIndex = alphabet.findIndex(char => char.char === lastChar) + var surrounding = alphabet[lastCharIndex].surrounding + var char = surrounding[Math.floor(Math.random() * surrounding.length)] + + // On évite que le caractère soit le même que le précédent + while(char === lastChar) char = surrounding[Math.floor(Math.random() * surrounding.length)] // si le caractère est le même, on en génère un autre + + // On évite à moitié que le caractère soit le même que l'avant dernier + if(code.length > 1){ + var beforeLastChar = code[code.length - 2] + if(char === beforeLastChar) char = surrounding[Math.floor(Math.random() * surrounding.length)] + } + + // On ajoute le caractère au code + code += char + } + } + + // On veut pas beaucoup de chiffres dans les codes, donc si on en a plus de deux, on les remplace par des lettres + var numbers = code.match(/[0-9]/g) + var alphabetWithoutNumbers = alphabet.filter(char => !char.char.match(/[0-9]/g)) + if(numbers && numbers.length > (length - 4)){ + numbers.forEach(number => { + var index = code.indexOf(number) + code = code.slice(0, index) + alphabetWithoutNumbers[Math.floor(Math.random() * alphabetWithoutNumbers.length)].char + code.slice(index + 1) + }) + } + + // On retourne le code + return code +} + +module.exports = generateCode \ No newline at end of file