remove cryptography class and use aes256 class
This commit is contained in:
parent
9cda42ea4a
commit
72b68b97b6
@ -3,7 +3,6 @@
|
|||||||
|
|
||||||
struct LoginInfoPointer;
|
struct LoginInfoPointer;
|
||||||
class Buffer;
|
class Buffer;
|
||||||
class Cryptography;
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <optional>
|
#include <optional>
|
||||||
|
|
||||||
@ -28,23 +27,23 @@ Arg get_args(int argc, char **argv, char **label);
|
|||||||
|
|
||||||
std::optional<LoginInfoPointer> arg_get(Buffer &decrypted_buffer, const char *label);
|
std::optional<LoginInfoPointer> arg_get(Buffer &decrypted_buffer, const char *label);
|
||||||
|
|
||||||
std::optional<LoginInfoPointer> arg_new_password(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, Cryptography &crypto, bool generate);
|
std::optional<LoginInfoPointer> arg_new_password(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, std::string &key, bool generate);
|
||||||
|
|
||||||
void arg_username(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, Cryptography &crypto);
|
void arg_username(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, std::string &key);
|
||||||
|
|
||||||
void arg_label_name(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, Cryptography &crypto);
|
void arg_label_name(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, std::string &key);
|
||||||
|
|
||||||
void arg_list(Buffer &decrypted_buffer);
|
void arg_list(Buffer &decrypted_buffer);
|
||||||
|
|
||||||
void arg_delete(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, Cryptography &crypto);
|
void arg_delete(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, std::string &key);
|
||||||
|
|
||||||
void arg_print_all_p(Buffer &decrypted_buffer, std::string &user_pass);
|
void arg_print_all_p(Buffer &decrypted_buffer, std::string &user_pass);
|
||||||
|
|
||||||
void arg_change(Buffer &decrypted_buffer, Buffer &encrypted_buffer, std::string &user_pass, Cryptography &crypto);
|
void arg_change(Buffer &decrypted_buffer, Buffer &encrypted_buffer, std::string &user_pass);
|
||||||
|
|
||||||
void arg_show(Buffer &decrypted_buffer, const char *label);
|
void arg_show(Buffer &decrypted_buffer, const char *label);
|
||||||
|
|
||||||
void arg_file(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, Cryptography &crypto, std::string &save_location_path);
|
void arg_file(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, std::string &key, std::string &save_location_path);
|
||||||
|
|
||||||
void arg_size(Buffer &encrypted_buffer);
|
void arg_size(Buffer &encrypted_buffer);
|
||||||
|
|
||||||
|
@ -1,21 +0,0 @@
|
|||||||
#ifndef CRYPTOGRAPHY_HPP
|
|
||||||
#define CRYPTOGRAPHY_HPP
|
|
||||||
|
|
||||||
#include <cstdint>
|
|
||||||
|
|
||||||
class Buffer;
|
|
||||||
|
|
||||||
class Cryptography
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
Cryptography(std::string password);
|
|
||||||
~Cryptography();
|
|
||||||
void change_pass(std::string password);
|
|
||||||
bool encrypt(Buffer &plain, Buffer &encrypted);
|
|
||||||
bool decrypt(Buffer &encrypted, Buffer &decrypted);
|
|
||||||
|
|
||||||
private:
|
|
||||||
std::string key;
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
21
main.cpp
21
main.cpp
@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
#include "sys.hpp"
|
#include "sys.hpp"
|
||||||
#include "buffer.hpp"
|
#include "buffer.hpp"
|
||||||
#include "cryptography.hpp"
|
#include "aes256.hpp"
|
||||||
#include "func.hpp"
|
#include "func.hpp"
|
||||||
#include "arg_func.hpp"
|
#include "arg_func.hpp"
|
||||||
|
|
||||||
@ -74,13 +74,10 @@ int main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
#endif // !1
|
#endif // !1
|
||||||
|
|
||||||
Cryptography crypto(user_pass);
|
|
||||||
|
|
||||||
Buffer decrypted_buffer;
|
Buffer decrypted_buffer;
|
||||||
// check if encrypted buffer is empty if not, decrypt it
|
// check if encrypted buffer is empty if not, decrypt it
|
||||||
if (encrypted_buffer.taken > 0)
|
if (encrypted_buffer.taken > 0)
|
||||||
if (!crypto.decrypt(encrypted_buffer, decrypted_buffer))
|
Aes256::decrypt(user_pass, encrypted_buffer, decrypted_buffer);
|
||||||
return 1;
|
|
||||||
|
|
||||||
// if decrypted buffer is empty, add index
|
// if decrypted buffer is empty, add index
|
||||||
if (decrypted_buffer.taken < sizeof(Index))
|
if (decrypted_buffer.taken < sizeof(Index))
|
||||||
@ -107,7 +104,7 @@ int main(int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case Arg::Generate:
|
case Arg::Generate:
|
||||||
login_info = arg_new_password(decrypted_buffer, encrypted_buffer, label, crypto, true);
|
login_info = arg_new_password(decrypted_buffer, encrypted_buffer, label, user_pass, true);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Arg::List:
|
case Arg::List:
|
||||||
@ -115,7 +112,7 @@ int main(int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case Arg::Delete:
|
case Arg::Delete:
|
||||||
arg_delete(decrypted_buffer, encrypted_buffer, label, crypto);
|
arg_delete(decrypted_buffer, encrypted_buffer, label, user_pass);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Arg::Print_all_p:
|
case Arg::Print_all_p:
|
||||||
@ -123,19 +120,19 @@ int main(int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case Arg::Input:
|
case Arg::Input:
|
||||||
login_info = arg_new_password(decrypted_buffer, encrypted_buffer, label, crypto, false);
|
login_info = arg_new_password(decrypted_buffer, encrypted_buffer, label, user_pass, false);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Arg::Username:
|
case Arg::Username:
|
||||||
arg_username(decrypted_buffer, encrypted_buffer, label, crypto);
|
arg_username(decrypted_buffer, encrypted_buffer, label, user_pass);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Arg::Name:
|
case Arg::Name:
|
||||||
arg_label_name(decrypted_buffer, encrypted_buffer, label, crypto);
|
arg_label_name(decrypted_buffer, encrypted_buffer, label, user_pass);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Arg::Change:
|
case Arg::Change:
|
||||||
arg_change(decrypted_buffer, encrypted_buffer, user_pass, crypto);
|
arg_change(decrypted_buffer, encrypted_buffer, user_pass);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Arg::Show:
|
case Arg::Show:
|
||||||
@ -143,7 +140,7 @@ int main(int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case Arg::File:
|
case Arg::File:
|
||||||
arg_file(decrypted_buffer, encrypted_buffer, label, crypto, save_location_path.value());
|
arg_file(decrypted_buffer, encrypted_buffer, label, user_pass, save_location_path.value());
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Arg::Size:
|
case Arg::Size:
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
#include "sys.hpp"
|
#include "sys.hpp"
|
||||||
#include "func.hpp"
|
#include "func.hpp"
|
||||||
#include "buffer.hpp"
|
#include "buffer.hpp"
|
||||||
#include "cryptography.hpp"
|
#include "aes256.hpp"
|
||||||
|
|
||||||
void print_args()
|
void print_args()
|
||||||
{
|
{
|
||||||
@ -104,7 +104,7 @@ std::optional<LoginInfoPointer> arg_get(Buffer &decrypted_buffer, const char *la
|
|||||||
return get_logininfo_pointer_from_buffer(decrypted_buffer, pass);
|
return get_logininfo_pointer_from_buffer(decrypted_buffer, pass);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::optional<LoginInfoPointer> arg_new_password(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, Cryptography &crypto, bool generate)
|
std::optional<LoginInfoPointer> arg_new_password(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, std::string &key, bool generate)
|
||||||
{
|
{
|
||||||
int pass = find_logininfo_in_buffer(decrypted_buffer, label);
|
int pass = find_logininfo_in_buffer(decrypted_buffer, label);
|
||||||
std::string username = "";
|
std::string username = "";
|
||||||
@ -156,13 +156,13 @@ std::optional<LoginInfoPointer> arg_new_password(Buffer &decrypted_buffer, Buffe
|
|||||||
}
|
}
|
||||||
|
|
||||||
add_logininfo_to_buffer(decrypted_buffer, name.c_str(), username.c_str(), password.c_str());
|
add_logininfo_to_buffer(decrypted_buffer, name.c_str(), username.c_str(), password.c_str());
|
||||||
crypto.encrypt(decrypted_buffer, encrypted_buffer);
|
Aes256::encrypt(key, decrypted_buffer, encrypted_buffer);
|
||||||
encrypted_buffer.save_to_file();
|
encrypted_buffer.save_to_file();
|
||||||
Index *index = (Index *)decrypted_buffer.buffer;
|
Index *index = (Index *)decrypted_buffer.buffer;
|
||||||
return get_logininfo_pointer_from_buffer(decrypted_buffer, index->count - 1);
|
return get_logininfo_pointer_from_buffer(decrypted_buffer, index->count - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void arg_username(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, Cryptography &crypto)
|
void arg_username(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, std::string &key)
|
||||||
{
|
{
|
||||||
int pass = find_logininfo_in_buffer(decrypted_buffer, label);
|
int pass = find_logininfo_in_buffer(decrypted_buffer, label);
|
||||||
if (pass < 0)
|
if (pass < 0)
|
||||||
@ -181,11 +181,11 @@ void arg_username(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char
|
|||||||
|
|
||||||
delete_logininfo_from_buffer(decrypted_buffer, pass);
|
delete_logininfo_from_buffer(decrypted_buffer, pass);
|
||||||
add_logininfo_to_buffer(decrypted_buffer, name.c_str(), username.c_str(), password.c_str());
|
add_logininfo_to_buffer(decrypted_buffer, name.c_str(), username.c_str(), password.c_str());
|
||||||
crypto.encrypt(decrypted_buffer, encrypted_buffer);
|
Aes256::encrypt(key, decrypted_buffer, encrypted_buffer);
|
||||||
encrypted_buffer.save_to_file();
|
encrypted_buffer.save_to_file();
|
||||||
}
|
}
|
||||||
|
|
||||||
void arg_label_name(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, Cryptography &crypto)
|
void arg_label_name(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, std::string &key)
|
||||||
{
|
{
|
||||||
int pass = find_logininfo_in_buffer(decrypted_buffer, label);
|
int pass = find_logininfo_in_buffer(decrypted_buffer, label);
|
||||||
|
|
||||||
@ -205,7 +205,7 @@ void arg_label_name(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const ch
|
|||||||
|
|
||||||
delete_logininfo_from_buffer(decrypted_buffer, pass);
|
delete_logininfo_from_buffer(decrypted_buffer, pass);
|
||||||
add_logininfo_to_buffer(decrypted_buffer, name.c_str(), username.c_str(), password.c_str());
|
add_logininfo_to_buffer(decrypted_buffer, name.c_str(), username.c_str(), password.c_str());
|
||||||
crypto.encrypt(decrypted_buffer, encrypted_buffer);
|
Aes256::encrypt(key, decrypted_buffer, encrypted_buffer);
|
||||||
encrypted_buffer.save_to_file();
|
encrypted_buffer.save_to_file();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -229,7 +229,7 @@ void arg_list(Buffer &decrypted_buffer)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void arg_delete(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label_to_del, Cryptography &crypto)
|
void arg_delete(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label_to_del, std::string &key)
|
||||||
{
|
{
|
||||||
printf("Deleting password for %s\n", label_to_del);
|
printf("Deleting password for %s\n", label_to_del);
|
||||||
int pass = find_logininfo_in_buffer(decrypted_buffer, label_to_del);
|
int pass = find_logininfo_in_buffer(decrypted_buffer, label_to_del);
|
||||||
@ -241,7 +241,7 @@ void arg_delete(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *
|
|||||||
|
|
||||||
delete_logininfo_from_buffer(decrypted_buffer, pass);
|
delete_logininfo_from_buffer(decrypted_buffer, pass);
|
||||||
|
|
||||||
crypto.encrypt(decrypted_buffer, encrypted_buffer);
|
Aes256::encrypt(key, decrypted_buffer, encrypted_buffer);
|
||||||
encrypted_buffer.save_to_file();
|
encrypted_buffer.save_to_file();
|
||||||
printf("Password deleted\n");
|
printf("Password deleted\n");
|
||||||
}
|
}
|
||||||
@ -273,7 +273,7 @@ void arg_print_all_p(Buffer &decrypted_buffer, std::string &user_pass)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void arg_change(Buffer &decrypted_buffer, Buffer &encrypted_buffer, std::string &user_pass, Cryptography &crypto)
|
void arg_change(Buffer &decrypted_buffer, Buffer &encrypted_buffer, std::string &user_pass)
|
||||||
{
|
{
|
||||||
printf("Input main password for confirmation:");
|
printf("Input main password for confirmation:");
|
||||||
|
|
||||||
@ -312,8 +312,7 @@ void arg_change(Buffer &decrypted_buffer, Buffer &encrypted_buffer, std::string
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
crypto.change_pass(new_string);
|
Aes256::encrypt(new_string, decrypted_buffer, encrypted_buffer);
|
||||||
crypto.encrypt(decrypted_buffer, encrypted_buffer);
|
|
||||||
encrypted_buffer.save_to_file();
|
encrypted_buffer.save_to_file();
|
||||||
printf("Password changed\n");
|
printf("Password changed\n");
|
||||||
}
|
}
|
||||||
@ -333,7 +332,7 @@ void arg_show(Buffer &decrypted_buffer, const char *label)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void arg_file(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, Cryptography &crypto, std::string &save_location_path)
|
void arg_file(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *label, std::string &key, std::string &save_location_path)
|
||||||
{
|
{
|
||||||
|
|
||||||
namespace fs = std::filesystem;
|
namespace fs = std::filesystem;
|
||||||
@ -348,7 +347,7 @@ void arg_file(Buffer &decrypted_buffer, Buffer &encrypted_buffer, const char *la
|
|||||||
if (decrypted_buffer.taken <= sizeof(Index))
|
if (decrypted_buffer.taken <= sizeof(Index))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
crypto.encrypt(decrypted_buffer, encrypted_buffer);
|
Aes256::encrypt(key, decrypted_buffer, encrypted_buffer);
|
||||||
encrypted_buffer.save_to_file(save.string());
|
encrypted_buffer.save_to_file(save.string());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,36 +0,0 @@
|
|||||||
#include <string>
|
|
||||||
#include <iostream>
|
|
||||||
#include <fstream>
|
|
||||||
#include <cstring>
|
|
||||||
|
|
||||||
#include "cryptography.hpp"
|
|
||||||
#include "buffer.hpp"
|
|
||||||
#include "aes256.hpp"
|
|
||||||
|
|
||||||
Cryptography::Cryptography(std::string password)
|
|
||||||
{
|
|
||||||
key = password;
|
|
||||||
}
|
|
||||||
|
|
||||||
Cryptography::~Cryptography()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
void Cryptography::change_pass(std::string password)
|
|
||||||
{
|
|
||||||
key = password;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool Cryptography::encrypt(Buffer &plain, Buffer &encrypted)
|
|
||||||
{
|
|
||||||
|
|
||||||
Aes256::encrypt(key, plain, encrypted);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool Cryptography::decrypt(Buffer &encrypted, Buffer &decrypted)
|
|
||||||
{
|
|
||||||
Aes256::decrypt(key, encrypted, decrypted);
|
|
||||||
return true;
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user