Credit card checker was overide by mysterious_organism and is now back to normal

This commit is contained in:
gauvainboiche
2025-07-21 11:52:44 +02:00
parent 9f1683e998
commit 23e9964cb0

View File

@@ -1,101 +1,80 @@
// Returns a random DNA base
function returnRandBase() {
const dnaBases = ['A', 'T', 'C', 'G'];
return dnaBases[Math.floor(Math.random() * 4)];
}
// All valid credit card numbers
const valid1 = [4, 5, 3, 9, 6, 7, 7, 9, 0, 8, 0, 1, 6, 8, 0, 8];
const valid2 = [5, 5, 3, 5, 7, 6, 6, 7, 6, 8, 7, 5, 1, 4, 3, 9];
const valid3 = [3, 7, 1, 6, 1, 2, 0, 1, 9, 9, 8, 5, 2, 3, 6];
const valid4 = [6, 0, 1, 1, 1, 4, 4, 3, 4, 0, 6, 8, 2, 9, 0, 5];
const valid5 = [4, 5, 3, 9, 4, 0, 4, 9, 6, 7, 8, 6, 9, 6, 6, 6];
// Returns a random single strand of DNA containing 15 bases
function mockUpStrand() {
const newStrand = [];
for (let i = 0; i < 15; i++) {
newStrand.push(returnRandBase());
// All invalid credit card numbers
const invalid1 = [4, 5, 3, 2, 7, 7, 8, 7, 7, 1, 0, 9, 1, 7, 9, 5];
const invalid2 = [5, 7, 9, 5, 5, 9, 3, 3, 9, 2, 1, 3, 4, 6, 4, 3];
const invalid3 = [3, 7, 5, 7, 9, 6, 0, 8, 4, 4, 5, 9, 9, 1, 4];
const invalid4 = [6, 0, 1, 1, 1, 2, 7, 9, 6, 1, 7, 7, 7, 9, 3, 5];
const invalid5 = [5, 3, 8, 2, 0, 1, 9, 7, 7, 2, 8, 8, 3, 8, 5, 4];
// Can be either valid or invalid
const mystery1 = [3, 4, 4, 8, 0, 1, 9, 6, 8, 3, 0, 5, 4, 1, 4];
const mystery2 = [5, 4, 6, 6, 1, 0, 0, 8, 6, 1, 6, 2, 0, 2, 3, 9];
const mystery3 = [6, 0, 1, 1, 3, 7, 7, 0, 2, 0, 9, 6, 2, 6, 5, 6, 2, 0, 3];
const mystery4 = [4, 9, 2, 9, 8, 7, 7, 1, 6, 9, 2, 1, 7, 0, 9, 3];
const mystery5 = [4, 9, 1, 3, 5, 4, 0, 4, 6, 3, 0, 7, 2, 5, 2, 3];
// An array of all the arrays above
const batch = [valid1, valid2, valid3, valid4, valid5, invalid1, invalid2, invalid3, invalid4, invalid5, mystery1, mystery2, mystery3, mystery4, mystery5];
// Add your functions below:
function validateCred(array) {
let newArray = [];
let cardIssuer = "";
switch (array[0]) {
case 3 :
cardIssuer = "American Express";
break;
case 4 :
cardIssuer = "Visa";
break;
case 5 :
cardIssuer = "Mastercard";
break;
case 6 :
cardIssuer = "Discover";
break;
default :
cardIssuer = "[UNKNOWN]";
break;
}
return newStrand;
}
// Factory function to create a DNA specimen object
function pAequorFactory(specimenNumber, dnaArray) {
if (dnaArray.length !== 15) throw new Error('DNA array must be 15 bases long');
return {
_specimenNum: specimenNumber,
_dna: dnaArray,
get dna() {
return this._dna;
},
get specimenNum() {
return this._specimenNum;
},
mutate() {
const dnaBases = ['A', 'T', 'C', 'G'];
let indexToMutate = Math.floor(Math.random() * this._dna.length);
const currentBase = this._dna[indexToMutate];
// Filter out the current base to select a different one
const otherBases = dnaBases.filter(base => base !== currentBase);
const newBase = otherBases[Math.floor(Math.random() * otherBases.length)];
// Update DNA at the selected index
this._dna[indexToMutate] = newBase;
return this._dna;
},
compareDNA(secondDNA) {
let DNAsimilarities = 0;
for (let i = 0; i < this._dna.length; i++) {
if (this._dna[i] === secondDNA.dna[i]) {
DNAsimilarities++;
}
}
const commonDNA = DNAsimilarities / this._dna.length * 100; // the *100 is to calculate %age
return(`The two DNA threads of specimens numbers ${this._specimenNum} and ${secondDNA.specimenNum} are ${commonDNA.toFixed(2)}% similar.`);
},
willLikelySurvive() {
let survivalChances = 0;
for (let i = 0; i < this._dna.length; i++) {
if (this._dna[i] === "G" || this._dna[i] === "C") {
survivalChances++;
}
}
const totalChances = survivalChances / this._dna.length * 100; // the *100 is to calculate %age
const willSurvive = totalChances >= 60;
//console.log(`The specimen #${this._specimenNum} has a DNA composed at ${totalChances}% of C and G bases and thus will likely ${willSurvive ? "survive" : "not survive"}.`);
return willSurvive;
for (let i = array.length - 1; i >= 0; i--) {
let currentPlace = array[i];
// to see if the [i] is an even number in the array - so that the 2nd, 4th, 6th element of the array etc - and if so => Double the number
if (i % 2 !== 0) {
newArray.push(currentPlace);
continue;
}
// if the double of the number is superior to 9, take the sum of the two numbers. Which is equivalent to substracting 9 to it curriously
};
}
function pAequorLaboratory(number) {
let pAequorLab = [];
let i = 0;
while (i < number) {
let pAequor = mockUpStrand();
let pAequorSpecimen = pAequorFactory(i+1, pAequor);
if (pAequorSpecimen.willLikelySurvive()) {
pAequorLab.push(pAequorSpecimen);
i++;
if (currentPlace * 2 > 9) {
let twoNum = currentPlace * 2 - 9;
newArray.push(twoNum);
} else {
newArray.push(currentPlace * 2);
}
// add all the numbers
}
return pAequorLab;
const sumUp = newArray.reduce((accumulator, currentValue) => accumulator + currentValue);
const isValid = sumUp % 10 === 0;
const cardID = `${array.at(0)}${array.at(1)}${array.at(2)}X-XXXX-XXXX-X${array.at(-3)}${array.at(-2)}${array.at(-1)}`;
console.log(`The credit card ${cardID} is issued by ${cardIssuer}.
It is ${isValid ? "a VALID" : "an INVALID"} credit card.
----------`);
return isValid;
}
const pAequor1DNA = mockUpStrand();
const pAequor2DNA = mockUpStrand();
const pAequor1 = pAequorFactory(1, pAequor1DNA);
const pAequor2 = pAequorFactory(2, pAequor2DNA);
function findInvalidCards(nestedArray) {
for (const array of nestedArray) {
validateCred(array);
}
}
console.log(`
${pAequor1.dna}
${pAequor2.dna}`);
console.log(pAequor1.compareDNA(pAequor2));
pAequor1.willLikelySurvive();
const pAequorLab1 = pAequorLaboratory(30);
console.log(pAequorLab1.map(p => p.dna));
findInvalidCards(batch);