diff --git a/README.md b/README.md
index 06e236b..f2220e1 100644
--- a/README.md
+++ b/README.md
@@ -2,25 +2,25 @@ This is a TOTP (Time-Based One-Time Password) authenticator that adheres to [RFC
## Build
-Before building, ensure that you have OpenSSL library 3.0 or higher installed and that your compiler supports C++20 standards. By default, the executable is located in the `build` folder.
+Before building, ensure that you have OpenSSL library 3.0 or higher installed and that your compiler supports C++20. By default, the executable is located in the `build` folder.
### Windows
If you're on Windows, you can install OpenSSL using vcpkg. Follow these steps:
1. Install OpenSSL using vcpkg:
- ```bat
- vcpkg.exe install openssl:x64-windows
- ```
- or
- ```bat
- vcpkg.exe install openssl
- ```
+ ```bat
+ vcpkg.exe install openssl:x64-windows
+ ```
+ or
+ ```bat
+ vcpkg.exe install openssl
+ ```
2. Integrate vcpkg with Visual Studio:
- ```bat
- vcpkg integrate install
- ```
+ ```bat
+ vcpkg.exe integrate install
+ ```
3. Build the Visual Studio solution located in the `VisualStudio` folder.
diff --git a/VisualStudio/Authenticator.vcxproj b/VisualStudio/Authenticator.vcxproj
index 9f93b6f..859251a 100644
--- a/VisualStudio/Authenticator.vcxproj
+++ b/VisualStudio/Authenticator.vcxproj
@@ -133,6 +133,7 @@
true
stdc17
stdcpp20
+ Full
Console
diff --git a/src/Authenticator.cpp b/src/Authenticator.cpp
index 0ea3dc8..f2f3b36 100644
--- a/src/Authenticator.cpp
+++ b/src/Authenticator.cpp
@@ -18,11 +18,10 @@
int main(int argc, char* argv[]) {
std::cout << "=========================== PI Authenticator ===========================\n"
- "= Last Updated: 2024-06-05 =\n"
+ "= Last Updated: 2024-06-10 =\n"
"= License: MIT =\n"
"= GitHub Repository: github.com/pi-314159/Authenticator =\n"
- "========================================================================\n\n"
- "Note: Sometimes you may need to hit Enter TWICE after input to continue.\n"<< std::endl;
+ "========================================================================\n\n" << std::endl;
std::string action = "l";
std::vector tOTPObjects;
diff --git a/src/actions/add.cpp b/src/actions/add.cpp
index a8e7a49..99ebd33 100644
--- a/src/actions/add.cpp
+++ b/src/actions/add.cpp
@@ -9,57 +9,58 @@
#include
namespace ACTIONS {
- void Add(std::vector& tOTPObjects) {
- auto str = std::make_unique_for_overwrite();
- std::string inputBuffer, tag, secret;
- char alg = '1';
- unsigned int period;
- unsigned short digits;
- while (inputBuffer.empty()) {
- str->Input(inputBuffer, "Please enter the issuer (e.g., GitHub), then hit Enter TWICE to proceed:", true);
- str->FormatInput(inputBuffer, inputBuffer);
- }
- tag = inputBuffer + "::";
- inputBuffer = "";
- while (inputBuffer.empty()) {
- str->Input(inputBuffer, "Please enter the account (e.g., user@example.com), \nthen hit Enter TWICE to proceed:", true);
- str->FormatInput(inputBuffer, inputBuffer);
- }
- tag += inputBuffer;
- inputBuffer = "";
- std::regex base32Pattern("[^a-zA-Z2-7]");
- while (inputBuffer.empty()) {
- str->Input(inputBuffer, "Please enter the secret:");
- str->FormatInput(inputBuffer, inputBuffer);
- inputBuffer = std::regex_replace(inputBuffer, base32Pattern, "");
- }
- secret = inputBuffer;
- std::transform(secret.begin(), secret.end(), secret.begin(), ::toupper);
- str->Input(inputBuffer, "Please enter the period (default 30):");
- if (str->FormatInput(inputBuffer, period, '2')) {
- if (period < 1) period = 30;
- }
- else {
- period = 30;
- }
- str->Input(inputBuffer, "Please select the hash algorithm:\n[1] SHA-1\n[2] SHA-256\n[3] SHA-384\n[5] SHA-512\nEnter your choice (default 1):");
- if (inputBuffer == "2") {
- alg = '2';
- } else if (inputBuffer == "3") {
- alg = '3';
- } else if (inputBuffer == "5") {
- alg = '5';
- }
- str->Input(inputBuffer, "Please enter the digits (between 6 - 10, default 6):");
- if (str->FormatInput(inputBuffer, digits, '2')) {
- if ((digits < 6) || digits > 10) digits = 6;
- }
- else {
- digits = 6;
- }
- tOTP_object tOTPInstance;
- tOTPInstance.tag = tag; tOTPInstance.secret = secret; tOTPInstance.period = period; tOTPInstance.alg = alg; tOTPInstance.digits = digits;
- tOTPObjects += tOTPInstance;
- return;
- }
+ void Add(std::vector& tOTPObjects) {
+ auto str = std::make_unique_for_overwrite();
+ std::string inputBuffer, tag, secret;
+ char alg = '1';
+ unsigned int period;
+ unsigned short digits;
+ while (inputBuffer.empty()) {
+ str->Input(inputBuffer, "Please enter the issuer (e.g., GitHub), then hit Enter TWICE to proceed:", true);
+ str->FormatInput(inputBuffer, inputBuffer);
+ }
+ tag = inputBuffer + "::";
+ inputBuffer = "";
+ while (inputBuffer.empty()) {
+ str->Input(inputBuffer, "Please enter the account (e.g., user@example.com), \nthen hit Enter TWICE to proceed:", true);
+ str->FormatInput(inputBuffer, inputBuffer);
+ }
+ tag += inputBuffer;
+ inputBuffer = "";
+ std::regex base32Pattern("[^a-zA-Z2-7]");
+ while (inputBuffer.empty()) {
+ str->Input(inputBuffer, "Please enter the secret:");
+ str->FormatInput(inputBuffer, inputBuffer);
+ inputBuffer = std::regex_replace(inputBuffer, base32Pattern, "");
+ }
+ secret = inputBuffer;
+ std::transform(secret.begin(), secret.end(), secret.begin(), ::toupper);
+ str->Input(inputBuffer, "Please enter the period (default 30):");
+ if (str->FormatInput(inputBuffer, period, '2')) {
+ if (period < 1) period = 30;
+ }
+ else {
+ period = 30;
+ }
+ str->Input(inputBuffer, "Please select the hash algorithm:\n[1] SHA-1\n[2] SHA-256\n[3] SHA-384\n[5] SHA-512\nEnter your choice (default 1):");
+ if (inputBuffer == "2") {
+ alg = '2';
+ } else if (inputBuffer == "3") {
+ alg = '3';
+ } else if (inputBuffer == "5") {
+ alg = '5';
+ }
+ str->Input(inputBuffer, "Please enter the digits (between 6 - 10, default 6):");
+ if (str->FormatInput(inputBuffer, digits, '2')) {
+ if ((digits < 6) || digits > 10) digits = 6;
+ }
+ else {
+ digits = 6;
+ }
+ str.reset();
+ tOTP_object tOTPInstance;
+ tOTPInstance.tag = tag; tOTPInstance.secret = secret; tOTPInstance.period = period; tOTPInstance.alg = alg; tOTPInstance.digits = digits;
+ tOTPObjects += tOTPInstance;
+ return;
+ }
}
\ No newline at end of file
diff --git a/src/actions/generatetotp.cpp b/src/actions/generatetotp.cpp
index 60a334f..58bfe74 100644
--- a/src/actions/generatetotp.cpp
+++ b/src/actions/generatetotp.cpp
@@ -11,7 +11,7 @@
#include
namespace ACTIONS {
- std::string GenerateTOTP(tOTP_object& tOTP) {
+ std::string GenerateTOTP(tOTP_object& tOTP) {
auto secretSize = static_cast(floor(tOTP.secret.size() / 1.6));
unsigned char* decodedSecret = new unsigned char[secretSize];
TOOLS::Base32Decode(tOTP.secret, decodedSecret);
@@ -25,5 +25,5 @@ namespace ACTIONS {
delete[] HMACDigest; delete HMACDigestSize;
std::string paddedResult = "0000000000" + std::to_string(result);
return paddedResult.substr(paddedResult.length() - tOTP.digits);
- }
+ }
}
\ No newline at end of file
diff --git a/src/include/actions/add.h b/src/include/actions/add.h
index fb8c5aa..b64b1d8 100644
--- a/src/include/actions/add.h
+++ b/src/include/actions/add.h
@@ -8,7 +8,7 @@
#include
namespace ACTIONS {
- void Add(std::vector& tOTPObjects);
+ void Add(std::vector& tOTPObjects);
}
#endif
diff --git a/src/include/actions/generatetotp.h b/src/include/actions/generatetotp.h
index 916814b..5c3d557 100644
--- a/src/include/actions/generatetotp.h
+++ b/src/include/actions/generatetotp.h
@@ -8,7 +8,7 @@
#include
namespace ACTIONS {
- std::string GenerateTOTP(tOTP_object& tOTP);
+ std::string GenerateTOTP(tOTP_object& tOTP);
}
#endif