Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
23 changes: 22 additions & 1 deletion app/zadanie01.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,24 @@
//Twój kod

const crypto = require('crypto');

const MY_PWD_HASH = '5dca0fc4e306d92b2077ad85e7c4bd87a3e8648e';
const password = [
'??TegoHasła',
'CodersLab',
'Node.js Szyfruje Pliki',
'Zaźółć Gęślą Jaźń',
'Moje Haslo 1@3!',
'111#$((@)n',
'Dzisiaj Szyfruje 83'
];
const algorithm = ['sha256', 'sha512', 'md5', 'rmd160'];

password.forEach( passwordElem => {
algorithm.forEach( algorithmElem => {
const hash = crypto.createHmac(algorithmElem, passwordElem)
.digest('hex');
hash === MY_PWD_HASH ? console.log(`password: ${passwordElem}; algorithm: ${algorithmElem}`) : null;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Bardzo fajne rozwiązanie. Mała podpowiedź: nieco czytelniejszy były tu if.

});
});

//Twój kod
17 changes: 16 additions & 1 deletion app/zadanieDnia1.js
Original file line number Diff line number Diff line change
@@ -1 +1,16 @@
//Twój kod
//Twój kod

const fs = require('fs');
const crypto = require('crypto');

const file = process.argv[2];

fs.readFile(file, 'utf8', (err, data) => {
if (err === null){
const hash = crypto.createHmac('sha256', data)
.digest('hex');
console.log(hash); // d5b1c451f5a44e4fcce7af164b6470f4ebd06b16c8b65adda696c6c7f328289b
} else {
console.log('Błąd podczas odczytu pliku!', err);
}
});
23 changes: 22 additions & 1 deletion app/zadanieDnia2.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,24 @@
//Twój kod

const crypto = require('crypto');
const ENCRYPTED_TEXT = '4f9fa8f98650091c4910f5b597773c0a48278cfb001fe4eb3ff47ada85cbf0ed3dc17016b031e1459e6e4d9b001ab6e102c11e834a98dce9530c9668c47b76ee6f09d075d19a38e48b415e067c6ddcfad0d3526c405a4f4f2fb1e7502f303c40';
const algorithm = ['aes192', 'aes-256-cbc', 'aes-256-ecb'];
const text = 'Pobawmy się jak komputerowy Detektyw';
let password = '';

text.split(' ').forEach( textElem => {
password += textElem[0] + textElem[textElem.length-1];
});

algorithm.forEach( algorithmElem => {
const decipher = crypto.createDecipher(algorithmElem, password);

let decrypted = decipher.update(ENCRYPTED_TEXT, 'hex', 'utf8');
try {
decrypted += decipher.final('utf8');
console.log(`Good hacking! Decrypted text: \n ${decrypted}`);
} catch(err) {
console.log("You are a weak hacker.");
}
});
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Bardzo elegancko!


//Twój kod