forked from eden-emu/eden
		
	GetProfileBase and GetProfileBaseAndData added
This commit is contained in:
		
							parent
							
								
									1aad022de2
								
							
						
					
					
						commit
						c908d31bbf
					
				
					 3 changed files with 106 additions and 44 deletions
				
			
		|  | @ -27,19 +27,13 @@ struct UserData { | |||
| }; | ||||
| static_assert(sizeof(UserData) == 0x80, "UserData structure has incorrect size"); | ||||
| 
 | ||||
| struct ProfileBase { | ||||
|     UUID user_id; | ||||
|     u64 timestamp; | ||||
|     std::array<u8, 0x20> username; | ||||
| }; | ||||
| static_assert(sizeof(ProfileBase) == 0x38, "ProfileBase structure has incorrect size"); | ||||
| 
 | ||||
| // TODO(ogniK): Generate a real user id based on username, md5(username) maybe?
 | ||||
| static UUID DEFAULT_USER_ID{1ull, 0ull}; | ||||
| 
 | ||||
| class IProfile final : public ServiceFramework<IProfile> { | ||||
| public: | ||||
|     explicit IProfile(UUID user_id) : ServiceFramework("IProfile"), user_id(user_id) { | ||||
|     explicit IProfile(UUID user_id, ProfileManager& profile_manager) | ||||
|         : ServiceFramework("IProfile"), user_id(user_id), profile_manager(profile_manager) { | ||||
|         static const FunctionInfo functions[] = { | ||||
|             {0, &IProfile::Get, "Get"}, | ||||
|             {1, &IProfile::GetBase, "GetBase"}, | ||||
|  | @ -51,40 +45,41 @@ public: | |||
| 
 | ||||
| private: | ||||
|     void Get(Kernel::HLERequestContext& ctx) { | ||||
|         LOG_WARNING(Service_ACC, "(STUBBED) called"); | ||||
|         LOG_INFO(Service_ACC, "called user_id={}", user_id.Format()); | ||||
|         ProfileBase profile_base{}; | ||||
|         profile_base.user_id = user_id; | ||||
|         if (Settings::values.username.size() > profile_base.username.size()) { | ||||
|         std::array<u8, MAX_DATA> data{}; | ||||
|         /*if (Settings::values.username.size() > profile_base.username.size()) {
 | ||||
|             std::copy_n(Settings::values.username.begin(), profile_base.username.size(), | ||||
|                         profile_base.username.begin()); | ||||
|         } else { | ||||
|             std::copy(Settings::values.username.begin(), Settings::values.username.end(), | ||||
|                       profile_base.username.begin()); | ||||
|         }*/ | ||||
|         if (profile_manager.GetProfileBaseAndData(user_id, profile_base, data)) { | ||||
|             ctx.WriteBuffer(data); | ||||
|             IPC::ResponseBuilder rb{ctx, 16}; | ||||
|             rb.Push(RESULT_SUCCESS); | ||||
|             rb.PushRaw(profile_base); | ||||
|         } else { | ||||
|             IPC::ResponseBuilder rb{ctx, 2}; | ||||
|             rb.Push(ResultCode(-1)); // TODO(ogniK): Get actual error code
 | ||||
|         } | ||||
| 
 | ||||
|         IPC::ResponseBuilder rb{ctx, 16}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushRaw(profile_base); | ||||
|     } | ||||
| 
 | ||||
|     void GetBase(Kernel::HLERequestContext& ctx) { | ||||
|         LOG_WARNING(Service_ACC, "(STUBBED) called"); | ||||
| 
 | ||||
|         // TODO(Subv): Retrieve this information from somewhere.
 | ||||
|         LOG_INFO(Service_ACC, "called user_id={}", user_id.Format()); | ||||
|         ProfileBase profile_base{}; | ||||
|         profile_base.user_id = user_id; | ||||
|         if (Settings::values.username.size() > profile_base.username.size()) { | ||||
|             std::copy_n(Settings::values.username.begin(), profile_base.username.size(), | ||||
|                         profile_base.username.begin()); | ||||
|         if (profile_manager.GetProfileBase(user_id, profile_base)) { | ||||
|             IPC::ResponseBuilder rb{ctx, 16}; | ||||
|             rb.Push(RESULT_SUCCESS); | ||||
|             rb.PushRaw(profile_base); | ||||
|         } else { | ||||
|             std::copy(Settings::values.username.begin(), Settings::values.username.end(), | ||||
|                       profile_base.username.begin()); | ||||
|             IPC::ResponseBuilder rb{ctx, 2}; | ||||
|             rb.Push(ResultCode(-1)); // TODO(ogniK): Get actual error code
 | ||||
|         } | ||||
|         IPC::ResponseBuilder rb{ctx, 16}; | ||||
|         rb.Push(RESULT_SUCCESS); | ||||
|         rb.PushRaw(profile_base); | ||||
|     } | ||||
| 
 | ||||
|     ProfileManager& profile_manager; | ||||
|     UUID user_id; ///< The user id this profile refers to.
 | ||||
| }; | ||||
| 
 | ||||
|  | @ -139,29 +134,32 @@ void Module::Interface::GetUserExistence(Kernel::HLERequestContext& ctx) { | |||
| } | ||||
| 
 | ||||
| void Module::Interface::ListAllUsers(Kernel::HLERequestContext& ctx) { | ||||
|     LOG_WARNING(Service_ACC, "(STUBBED) called"); | ||||
|     // TODO(Subv): There is only one user for now.
 | ||||
|     const std::vector<UUID> user_ids = {DEFAULT_USER_ID}; | ||||
|     ctx.WriteBuffer(user_ids); | ||||
|     LOG_INFO(Service_ACC, "called"); | ||||
|     ctx.WriteBuffer(profile_manager->GetAllUsers()); | ||||
|     IPC::ResponseBuilder rb{ctx, 2}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
| } | ||||
| 
 | ||||
| void Module::Interface::ListOpenUsers(Kernel::HLERequestContext& ctx) { | ||||
|     LOG_WARNING(Service_ACC, "(STUBBED) called"); | ||||
|     // TODO(Subv): There is only one user for now.
 | ||||
|     const std::vector<UUID> user_ids = {DEFAULT_USER_ID}; | ||||
|     ctx.WriteBuffer(user_ids); | ||||
|     LOG_INFO(Service_ACC, "called"); | ||||
|     ctx.WriteBuffer(profile_manager->GetOpenUsers()); | ||||
|     IPC::ResponseBuilder rb{ctx, 2}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
| } | ||||
| 
 | ||||
| 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()); | ||||
| } | ||||
| 
 | ||||
| void Module::Interface::GetProfile(Kernel::HLERequestContext& ctx) { | ||||
|     IPC::RequestParser rp{ctx}; | ||||
|     UUID user_id = rp.PopRaw<UUID>(); | ||||
|     IPC::ResponseBuilder rb{ctx, 2, 0, 1}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushIpcInterface<IProfile>(user_id); | ||||
|     rb.PushIpcInterface<IProfile>(user_id, *profile_manager); | ||||
|     LOG_DEBUG(Service_ACC, "called user_id={}", user_id.Format()); | ||||
| } | ||||
| 
 | ||||
|  | @ -178,13 +176,6 @@ void Module::Interface::GetBaasAccountManagerForApplication(Kernel::HLERequestCo | |||
|     LOG_DEBUG(Service_ACC, "called"); | ||||
| } | ||||
| 
 | ||||
| void Module::Interface::GetLastOpenedUser(Kernel::HLERequestContext& ctx) { | ||||
|     LOG_WARNING(Service_ACC, "(STUBBED) called"); | ||||
|     IPC::ResponseBuilder rb{ctx, 6}; | ||||
|     rb.Push(RESULT_SUCCESS); | ||||
|     rb.PushRaw(DEFAULT_USER_ID); | ||||
| } | ||||
| 
 | ||||
| Module::Interface::Interface(std::shared_ptr<Module> module, const char* name) | ||||
|     : ServiceFramework(name), module(std::move(module)) {} | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 David Marcec
						David Marcec