forked from eden-emu/eden
		
	First round of account changes
This commit is contained in:
		
					parent
					
						
							
								40c5aa6284
							
						
					
				
			
			
				commit
				
					
						41aa6154ce
					
				
			
		
					 3 changed files with 55 additions and 49 deletions
				
			
		|  | @ -165,7 +165,7 @@ void Module::Interface::GetLastOpenedUser(Kernel::HLERequestContext& ctx) { | |||
|     LOG_INFO(Service_ACC, "called"); | ||||
|     IPC::ResponseBuilder rb{ctx, 6}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushRaw<UUID>(profile_manager->GetLastOpennedUser()); | ||||
|     rb.PushRaw<UUID>(profile_manager->GetLastOpenedUser()); | ||||
| } | ||||
| 
 | ||||
| void Module::Interface::GetProfile(Kernel::HLERequestContext& ctx) { | ||||
|  |  | |||
|  | @ -1,3 +1,7 @@ | |||
| // Copyright 2018 yuzu emulator team
 | ||||
| // Licensed under GPLv2 or any later version
 | ||||
| // Refer to the license.txt file included.
 | ||||
| 
 | ||||
| #include "core/settings.h" | ||||
| #include "profile_manager.h" | ||||
| 
 | ||||
|  | @ -15,14 +19,14 @@ ProfileManager::ProfileManager() { | |||
| 
 | ||||
| size_t ProfileManager::AddToProfiles(const ProfileInfo& user) { | ||||
|     if (user_count >= MAX_USERS) { | ||||
|         return -1; | ||||
|         return std::numeric_limits<size_t>::max(); | ||||
|     } | ||||
|     profiles[user_count] = std::move(user); | ||||
|     return user_count++; | ||||
| } | ||||
| 
 | ||||
| bool ProfileManager::RemoveProfileAtIdx(size_t index) { | ||||
|     if (index >= MAX_USERS || index < 0 || index >= user_count) | ||||
|     if (index >= MAX_USERS || index >= user_count) | ||||
|         return false; | ||||
|     profiles[index] = ProfileInfo{}; | ||||
|     if (index < user_count - 1) | ||||
|  | @ -33,13 +37,13 @@ bool ProfileManager::RemoveProfileAtIdx(size_t index) { | |||
| } | ||||
| 
 | ||||
| ResultCode ProfileManager::AddUser(ProfileInfo user) { | ||||
|     if (AddToProfiles(user) == -1) { | ||||
|     if (AddToProfiles(user) == std::numeric_limits<size_t>::max()) { | ||||
|         return ERROR_TOO_MANY_USERS; | ||||
|     } | ||||
|     return RESULT_SUCCESS; | ||||
| } | ||||
| 
 | ||||
| ResultCode ProfileManager::CreateNewUser(UUID uuid, std::array<u8, 0x20> username) { | ||||
| ResultCode ProfileManager::CreateNewUser(UUID uuid, std::array<u8, 0x20>& username) { | ||||
|     if (user_count == MAX_USERS) | ||||
|         return ERROR_TOO_MANY_USERS; | ||||
|     if (!uuid) | ||||
|  | @ -64,67 +68,67 @@ ResultCode ProfileManager::CreateNewUser(UUID uuid, std::string username) { | |||
|         std::copy_n(username.begin(), username_output.size(), username_output.begin()); | ||||
|     else | ||||
|         std::copy(username.begin(), username.end(), username_output.begin()); | ||||
|     return CreateNewUser(uuid, std::move(username_output)); | ||||
|     return CreateNewUser(uuid, username_output); | ||||
| } | ||||
| 
 | ||||
| size_t ProfileManager::GetUserIndex(UUID uuid) { | ||||
| size_t ProfileManager::GetUserIndex(const UUID& uuid) const { | ||||
|     if (!uuid) | ||||
|         return -1; | ||||
|         return std::numeric_limits<size_t>::max(); | ||||
|     for (unsigned i = 0; i < user_count; i++) | ||||
|         if (profiles[i].user_uuid == uuid) | ||||
|             return i; | ||||
|     return -1; | ||||
|     return std::numeric_limits<size_t>::max(); | ||||
| } | ||||
| 
 | ||||
| size_t ProfileManager::GetUserIndex(ProfileInfo user) { | ||||
| size_t ProfileManager::GetUserIndex(ProfileInfo user) const { | ||||
|     return GetUserIndex(user.user_uuid); | ||||
| } | ||||
| 
 | ||||
| bool ProfileManager::GetProfileBase(size_t index, ProfileBase& profile) { | ||||
| bool ProfileManager::GetProfileBase(size_t index, ProfileBase& profile) const { | ||||
|     if (index >= MAX_USERS) { | ||||
|         profile.Invalidate(); | ||||
|         return false; | ||||
|     } | ||||
|     auto prof_info = profiles[index]; | ||||
|     const auto& prof_info = profiles[index]; | ||||
|     profile.user_uuid = prof_info.user_uuid; | ||||
|     profile.username = prof_info.username; | ||||
|     profile.timestamp = prof_info.creation_time; | ||||
|     return true; | ||||
| } | ||||
| 
 | ||||
| bool ProfileManager::GetProfileBase(UUID uuid, ProfileBase& profile) { | ||||
| bool ProfileManager::GetProfileBase(UUID uuid, ProfileBase& profile) const { | ||||
|     auto idx = GetUserIndex(uuid); | ||||
|     return GetProfileBase(idx, profile); | ||||
| } | ||||
| 
 | ||||
| bool ProfileManager::GetProfileBase(ProfileInfo user, ProfileBase& profile) { | ||||
| bool ProfileManager::GetProfileBase(ProfileInfo user, ProfileBase& profile) const { | ||||
|     return GetProfileBase(user.user_uuid, profile); | ||||
| } | ||||
| 
 | ||||
| size_t ProfileManager::GetUserCount() { | ||||
| size_t ProfileManager::GetUserCount() const { | ||||
|     return user_count; | ||||
| } | ||||
| 
 | ||||
| bool ProfileManager::UserExists(UUID uuid) { | ||||
|     return (GetUserIndex(uuid) != -1); | ||||
| bool ProfileManager::UserExists(UUID uuid) const { | ||||
|     return (GetUserIndex(uuid) != std::numeric_limits<size_t>::max()); | ||||
| } | ||||
| 
 | ||||
| void ProfileManager::OpenUser(UUID uuid) { | ||||
|     auto idx = GetUserIndex(uuid); | ||||
|     if (idx == -1) | ||||
|     if (idx == std::numeric_limits<size_t>::max()) | ||||
|         return; | ||||
|     profiles[idx].is_open = true; | ||||
|     last_openned_user = uuid; | ||||
|     last_opened_user = uuid; | ||||
| } | ||||
| 
 | ||||
| void ProfileManager::CloseUser(UUID uuid) { | ||||
|     auto idx = GetUserIndex(uuid); | ||||
|     if (idx == -1) | ||||
|     if (idx == std::numeric_limits<size_t>::max()) | ||||
|         return; | ||||
|     profiles[idx].is_open = false; | ||||
| } | ||||
| 
 | ||||
| std::array<UUID, MAX_USERS> ProfileManager::GetAllUsers() { | ||||
| std::array<UUID, MAX_USERS> ProfileManager::GetAllUsers() const { | ||||
|     std::array<UUID, MAX_USERS> output; | ||||
|     for (unsigned i = 0; i < user_count; i++) { | ||||
|         output[i] = profiles[i].user_uuid; | ||||
|  | @ -132,7 +136,7 @@ std::array<UUID, MAX_USERS> ProfileManager::GetAllUsers() { | |||
|     return output; | ||||
| } | ||||
| 
 | ||||
| std::array<UUID, MAX_USERS> ProfileManager::GetOpenUsers() { | ||||
| std::array<UUID, MAX_USERS> ProfileManager::GetOpenUsers() const { | ||||
|     std::array<UUID, MAX_USERS> output; | ||||
|     unsigned user_idx = 0; | ||||
|     for (unsigned i = 0; i < user_count; i++) { | ||||
|  | @ -143,8 +147,8 @@ std::array<UUID, MAX_USERS> ProfileManager::GetOpenUsers() { | |||
|     return output; | ||||
| } | ||||
| 
 | ||||
| const UUID& ProfileManager::GetLastOpennedUser() { | ||||
|     return last_openned_user; | ||||
| UUID ProfileManager::GetLastOpenedUser() const { | ||||
|     return last_opened_user; | ||||
| } | ||||
| 
 | ||||
| bool ProfileManager::GetProfileBaseAndData(size_t index, ProfileBase& profile, | ||||
|  | @ -166,7 +170,7 @@ bool ProfileManager::GetProfileBaseAndData(ProfileInfo user, ProfileBase& profil | |||
|     return GetProfileBaseAndData(user.user_uuid, profile, data); | ||||
| } | ||||
| 
 | ||||
| bool ProfileManager::CanSystemRegisterUser() { | ||||
| bool ProfileManager::CanSystemRegisterUser() const { | ||||
|     return false; // TODO(ogniK): Games shouldn't have
 | ||||
|                   // access to user registration, when we
 | ||||
|     // emulate qlaunch. Update this to dynamically change.
 | ||||
|  |  | |||
|  | @ -1,4 +1,9 @@ | |||
| // Copyright 2018 yuzu emulator team
 | ||||
| // Licensed under GPLv2 or any later version
 | ||||
| // Refer to the license.txt file included.
 | ||||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| #include <array> | ||||
| #include "common/common_types.h" | ||||
| #include "common/swap.h" | ||||
|  | @ -12,24 +17,21 @@ struct UUID { | |||
|     // UUIDs which are 0 are considered invalid!
 | ||||
|     u128 uuid{0, 0}; | ||||
|     UUID() = default; | ||||
|     explicit UUID(const u128& id) { | ||||
|         uuid[0] = id[0]; | ||||
|         uuid[1] = id[1]; | ||||
|     }; | ||||
|     explicit UUID(const u64& lo, const u64& hi) { | ||||
|     explicit UUID(const u128& id) : uuid{id} {} | ||||
|     explicit UUID(const u64 lo, const u64 hi) { | ||||
|         uuid[0] = lo; | ||||
|         uuid[1] = hi; | ||||
|     }; | ||||
|     operator bool() const { | ||||
|     explicit operator bool() const { | ||||
|         return uuid[0] != 0x0 || uuid[1] != 0x0; | ||||
|     } | ||||
| 
 | ||||
|     bool operator==(const UUID& rhs) { | ||||
|         return uuid[0] == rhs.uuid[0] && uuid[1] == rhs.uuid[1]; | ||||
|     bool operator==(const UUID& rhs) const { | ||||
|         return std::tie(uuid[0], uuid[1]) == std::tie(rhs.uuid[0], rhs.uuid[1]); | ||||
|     } | ||||
| 
 | ||||
|     bool operator!=(const UUID& rhs) { | ||||
|         return uuid[0] != rhs.uuid[0] || uuid[1] != rhs.uuid[1]; | ||||
|     bool operator!=(const UUID& rhs) const { | ||||
|         return !operator==(rhs); | ||||
|     } | ||||
| 
 | ||||
|     // TODO(ogniK): Properly generate uuids based on RFC-4122
 | ||||
|  | @ -42,7 +44,7 @@ struct UUID { | |||
|         uuid[0] = 0; | ||||
|         uuid[1] = 0; | ||||
|     } | ||||
|     std::string Format() { | ||||
|     std::string Format() const { | ||||
|         return fmt::format("0x{:016X}{:016X}", uuid[1], uuid[0]); | ||||
|     } | ||||
| }; | ||||
|  | @ -78,33 +80,33 @@ class ProfileManager { | |||
| public: | ||||
|     ProfileManager(); // TODO(ogniK): Load from system save
 | ||||
|     ResultCode AddUser(ProfileInfo user); | ||||
|     ResultCode CreateNewUser(UUID uuid, std::array<u8, 0x20> username); | ||||
|     ResultCode CreateNewUser(UUID uuid, std::array<u8, 0x20>& username); | ||||
|     ResultCode CreateNewUser(UUID uuid, std::string username); | ||||
|     size_t GetUserIndex(UUID uuid); | ||||
|     size_t GetUserIndex(ProfileInfo user); | ||||
|     bool GetProfileBase(size_t index, ProfileBase& profile); | ||||
|     bool GetProfileBase(UUID uuid, ProfileBase& profile); | ||||
|     bool GetProfileBase(ProfileInfo user, ProfileBase& profile); | ||||
|     size_t GetUserIndex(const UUID& uuid) const; | ||||
|     size_t GetUserIndex(ProfileInfo user) const; | ||||
|     bool GetProfileBase(size_t index, ProfileBase& profile) const; | ||||
|     bool GetProfileBase(UUID uuid, ProfileBase& profile) const; | ||||
|     bool GetProfileBase(ProfileInfo user, ProfileBase& profile) const; | ||||
|     bool GetProfileBaseAndData(size_t index, ProfileBase& profile, std::array<u8, MAX_DATA>& data); | ||||
|     bool GetProfileBaseAndData(UUID uuid, ProfileBase& profile, std::array<u8, MAX_DATA>& data); | ||||
|     bool GetProfileBaseAndData(ProfileInfo user, ProfileBase& profile, | ||||
|                                std::array<u8, MAX_DATA>& data); | ||||
|     size_t GetUserCount(); | ||||
|     bool UserExists(UUID uuid); | ||||
|     size_t GetUserCount() const; | ||||
|     bool UserExists(UUID uuid) const; | ||||
|     void OpenUser(UUID uuid); | ||||
|     void CloseUser(UUID uuid); | ||||
|     std::array<UUID, MAX_USERS> GetOpenUsers(); | ||||
|     std::array<UUID, MAX_USERS> GetAllUsers(); | ||||
|     const UUID& GetLastOpennedUser(); | ||||
|     std::array<UUID, MAX_USERS> GetOpenUsers() const; | ||||
|     std::array<UUID, MAX_USERS> GetAllUsers() const; | ||||
|     UUID GetLastOpenedUser() const; | ||||
| 
 | ||||
|     bool CanSystemRegisterUser(); | ||||
|     bool CanSystemRegisterUser() const; | ||||
| 
 | ||||
| private: | ||||
|     std::array<ProfileInfo, MAX_USERS> profiles{}; | ||||
|     size_t user_count = 0; | ||||
|     size_t AddToProfiles(const ProfileInfo& profile); | ||||
|     bool RemoveProfileAtIdx(size_t index); | ||||
|     UUID last_openned_user{0, 0}; | ||||
|     UUID last_opened_user{0, 0}; | ||||
| }; | ||||
| using ProfileManagerPtr = std::unique_ptr<ProfileManager>; | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 David Marcec
				David Marcec