2018-05-09 21:13:09 +01:00
/ * *
* @ author Matt C [ matt @ artemisbot . uk ]
* @ copyright Crown Copyright 2018
* @ license Apache - 2.0
* /
2019-07-09 12:23:59 +01:00
import Operation from "../Operation.mjs" ;
import OperationError from "../errors/OperationError.mjs" ;
2024-09-24 10:13:47 +05:30
2018-05-09 21:13:09 +01:00
/ * *
* Vigenère Decode operation
* /
class VigenèreDecode extends Operation {
/ * *
* VigenèreDecode constructor
* /
constructor ( ) {
super ( ) ;
this . name = "Vigenère Decode" ;
this . module = "Ciphers" ;
this . description = "The Vigenere cipher is a method of encrypting alphabetic text by using a series of different Caesar ciphers based on the letters of a keyword. It is a simple form of polyalphabetic substitution." ;
2018-08-21 19:07:13 +01:00
this . infoURL = "https://wikipedia.org/wiki/Vigenère_cipher" ;
2018-05-09 21:13:09 +01:00
this . inputType = "string" ;
this . outputType = "string" ;
this . args = [
{
"name" : "Key" ,
"type" : "string" ,
"value" : ""
}
] ;
}
/ * *
* @ param { string } input
* @ param { Object [ ] } args
* @ returns { string }
* /
run ( input , args ) {
2024-09-24 10:13:47 +05:30
const alphabet = "abcdefghijklmnopqrstuvwxyz0123456789" ;
const key = args [ 0 ] . toLowerCase ( ) ;
let output = "" ;
let fail = 0 ;
let keyIndex , msgIndex , chr ;
2018-05-09 21:13:09 +01:00
2018-05-11 16:32:19 +01:00
if ( ! key ) throw new OperationError ( "No key entered" ) ;
2024-09-24 10:13:47 +05:30
if ( ! /^[a-zA-Z0-9]+$/ . test ( key ) ) throw new OperationError ( "The key must consist only of letters and numbers" ) ;
2018-05-09 21:13:09 +01:00
for ( let i = 0 ; i < input . length ; i ++ ) {
2024-09-24 10:13:47 +05:30
const currentChar = input [ i ] ;
const lowerChar = currentChar . toLowerCase ( ) ;
if ( alphabet . indexOf ( lowerChar ) >= 0 ) {
2018-05-09 21:13:09 +01:00
chr = key [ ( i - fail ) % key . length ] ;
keyIndex = alphabet . indexOf ( chr ) ;
2024-09-24 10:13:47 +05:30
msgIndex = alphabet . indexOf ( lowerChar ) ;
// Decode character using the Vigenère formula
const decodedChar = alphabet [ ( msgIndex - keyIndex + alphabet . length ) % alphabet . length ] ;
// Preserve case for letters and add to output
output += currentChar === lowerChar ? decodedChar : decodedChar . toUpperCase ( ) ;
2018-05-09 21:13:09 +01:00
} else {
2024-09-24 10:13:47 +05:30
output += currentChar ; // Keep non-alphabetic characters as is
2018-05-09 21:13:09 +01:00
fail ++ ;
}
}
return output ;
}
/ * *
* Highlight Vigenère Decode
*
* @ param { Object [ ] } pos
* @ param { number } pos [ ] . start
* @ param { number } pos [ ] . end
* @ param { Object [ ] } args
* @ returns { Object [ ] } pos
* /
highlight ( pos , args ) {
return pos ;
}
/ * *
* Highlight Vigenère Decode in reverse
*
* @ param { Object [ ] } pos
* @ param { number } pos [ ] . start
* @ param { number } pos [ ] . end
* @ param { Object [ ] } args
* @ returns { Object [ ] } pos
* /
highlightReverse ( pos , args ) {
return pos ;
}
}
2024-10-01 09:17:27 +05:30
export default VigenèreDecode ;