diff --git a/Trenser.Zenvy/Trenser.Zenvy/Trenser.Zenvy.vcxproj b/Trenser.Zenvy/Trenser.Zenvy/Trenser.Zenvy.vcxproj
index a90e70f..d128542 100644
--- a/Trenser.Zenvy/Trenser.Zenvy/Trenser.Zenvy.vcxproj
+++ b/Trenser.Zenvy/Trenser.Zenvy/Trenser.Zenvy.vcxproj
@@ -146,6 +146,7 @@
+
@@ -199,6 +200,7 @@
+
diff --git a/Trenser.Zenvy/Trenser.Zenvy/controllers/ZenvyController.cpp b/Trenser.Zenvy/Trenser.Zenvy/controllers/ZenvyController.cpp
index aa50123..c1b4287 100644
--- a/Trenser.Zenvy/Trenser.Zenvy/controllers/ZenvyController.cpp
+++ b/Trenser.Zenvy/Trenser.Zenvy/controllers/ZenvyController.cpp
@@ -1 +1,15 @@
#include "ZenvyController.h"
+
+//Authentication
+AuthenticationContext ZenvyController::login(const std::string& email, const std::string& password)
+{
+ return m_authenticationManagementService->login(email, password);
+}
+
+void ZenvyController::logout()
+{
+}
+
+void AuthenticationManagementService::changePassword()
+{
+}
diff --git a/Trenser.Zenvy/Trenser.Zenvy/controllers/ZenvyController.h b/Trenser.Zenvy/Trenser.Zenvy/controllers/ZenvyController.h
index 956e962..3dc3575 100644
--- a/Trenser.Zenvy/Trenser.Zenvy/controllers/ZenvyController.h
+++ b/Trenser.Zenvy/Trenser.Zenvy/controllers/ZenvyController.h
@@ -11,6 +11,9 @@
#include "TalentAcquisitionManagementService.h"
#include "TeamManagementService.h"
#include "TicketManagementService.h"
+#include "Enums.h"
+
+using AuthenticationContext = std::tuple;
class ZenvyController
{
@@ -37,5 +40,9 @@ public:
m_talentAcquisitionManagementService(std::make_shared()),
m_teamManagementService(std::make_shared()),
m_ticketManagementService(std::make_shared()) {};
+
+ //Authentication
+ AuthenticationContext login(const std::string& email, const std::string& password);
+ void logout();
};
diff --git a/Trenser.Zenvy/Trenser.Zenvy/datastores/DataStore.cpp b/Trenser.Zenvy/Trenser.Zenvy/datastores/DataStore.cpp
index 80f370f..7fcd993 100644
--- a/Trenser.Zenvy/Trenser.Zenvy/datastores/DataStore.cpp
+++ b/Trenser.Zenvy/Trenser.Zenvy/datastores/DataStore.cpp
@@ -11,6 +11,11 @@ logMap& DataStore::getLogs()
return m_logs;
}
+void DataStore::setAuthenticatedEmployee(std::shared_ptr authenticatedEmployee)
+{
+ m_authenticatedEmployee = authenticatedEmployee;
+}
+
employeeMap& DataStore::getEmployees()
{
return m_employees;
diff --git a/Trenser.Zenvy/Trenser.Zenvy/datastores/DataStore.h b/Trenser.Zenvy/Trenser.Zenvy/datastores/DataStore.h
index b89e335..ca2bd63 100644
--- a/Trenser.Zenvy/Trenser.Zenvy/datastores/DataStore.h
+++ b/Trenser.Zenvy/Trenser.Zenvy/datastores/DataStore.h
@@ -37,4 +37,5 @@ public:
DataStore& operator=(DataStore&&) = delete;
employeeMap& getEmployees();
logMap& getLogs();
+ void setAuthenticatedEmployee(std::shared_ptr < Employee>);
};
\ No newline at end of file
diff --git a/Trenser.Zenvy/Trenser.Zenvy/services/ApplicationConfig.cpp b/Trenser.Zenvy/Trenser.Zenvy/services/ApplicationConfig.cpp
new file mode 100644
index 0000000..cb68b98
--- /dev/null
+++ b/Trenser.Zenvy/Trenser.Zenvy/services/ApplicationConfig.cpp
@@ -0,0 +1 @@
+#include "ApplicationConfig.h"
diff --git a/Trenser.Zenvy/Trenser.Zenvy/services/ApplicationConfig.h b/Trenser.Zenvy/Trenser.Zenvy/services/ApplicationConfig.h
new file mode 100644
index 0000000..4d7db21
--- /dev/null
+++ b/Trenser.Zenvy/Trenser.Zenvy/services/ApplicationConfig.h
@@ -0,0 +1,6 @@
+#pragma once
+
+namespace Config
+{
+ constexpr const char* DEFAULT_PASSWORD = "password";
+}
diff --git a/Trenser.Zenvy/Trenser.Zenvy/services/AuthenticationManagementService.cpp b/Trenser.Zenvy/Trenser.Zenvy/services/AuthenticationManagementService.cpp
index 7225c9d..9f60c05 100644
--- a/Trenser.Zenvy/Trenser.Zenvy/services/AuthenticationManagementService.cpp
+++ b/Trenser.Zenvy/Trenser.Zenvy/services/AuthenticationManagementService.cpp
@@ -1,2 +1,48 @@
+#include
#include "AuthenticationManagementService.h"
+#include "ApplicationConfig.h"
+std::tuple AuthenticationManagementService::login(const std::string& email, const std::string& password)
+{
+ employeeMap& employees = m_dataStore.getEmployees();
+ Enums::LoginStatus loginStatus = Enums::LoginStatus::USER_NOT_FOUND;
+ Enums::EmployeeType employeeType = Enums::EmployeeType::INVALID;
+ Enums::EmployeeDesignation employeeDesignation = Enums::EmployeeDesignation::INVALID;
+ for (const auto& employee : employees)
+ {
+ if (employee.second->getEmployeeEmail() == email)
+ {
+ if (employee.second->getEmployeePassword() == password)
+ {
+ if (password == Config::DEFAULT_PASSWORD)
+ {
+ loginStatus = Enums::LoginStatus::FIRST_LOGIN;
+ }
+ else
+ {
+ loginStatus = Enums::LoginStatus::SUCCESS;
+ }
+ employeeType = employee.second->getEmployeeType();
+ if (employeeType == Enums::EmployeeType::GENERAL)
+ {
+ std::shared_ptr generalEmployee = std::dynamic_pointer_cast(employee.second);
+ if (generalEmployee)
+ {
+ employeeDesignation = generalEmployee->getDesignation();
+ }
+ else
+ {
+ throw std::runtime_error("Invalid Employee Type");
+ }
+ }
+ m_dataStore.setAuthenticatedEmployee(employee.second);
+ }
+ else
+ {
+ loginStatus = Enums::LoginStatus::INVALID_PASSWORD;
+ }
+ break;
+ }
+ }
+ return std::make_tuple(loginStatus, employeeType, employeeDesignation);
+}
diff --git a/Trenser.Zenvy/Trenser.Zenvy/services/AuthenticationManagementService.h b/Trenser.Zenvy/Trenser.Zenvy/services/AuthenticationManagementService.h
index b7d6463..5790978 100644
--- a/Trenser.Zenvy/Trenser.Zenvy/services/AuthenticationManagementService.h
+++ b/Trenser.Zenvy/Trenser.Zenvy/services/AuthenticationManagementService.h
@@ -3,6 +3,7 @@
#include