| 
									
										
										
										
											2018-09-11 20:46:49 -04:00
										 |  |  | // Copyright 2018 yuzu emulator team
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-17 21:49:21 -04:00
										 |  |  | #include "common/hex_util.h"
 | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  | #include "common/logging/log.h"
 | 
					
						
							| 
									
										
										
										
											2020-11-08 15:49:45 -05:00
										 |  |  | #include "core/core.h"
 | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  | #include "core/hle/ipc_helpers.h"
 | 
					
						
							| 
									
										
										
										
											2019-05-17 21:49:21 -04:00
										 |  |  | #include "core/hle/service/acc/profile_manager.h"
 | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  | #include "core/hle/service/prepo/prepo.h"
 | 
					
						
							| 
									
										
										
										
											2018-09-11 20:46:49 -04:00
										 |  |  | #include "core/hle/service/service.h"
 | 
					
						
							| 
									
										
										
										
											2019-05-17 21:49:21 -04:00
										 |  |  | #include "core/reporter.h"
 | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-22 19:02:18 -07:00
										 |  |  | namespace Service::PlayReport { | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-11 20:46:49 -04:00
										 |  |  | class PlayReport final : public ServiceFramework<PlayReport> { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2020-11-26 15:19:08 -05:00
										 |  |  |     explicit PlayReport(const char* name, Core::System& system_) : ServiceFramework{system_, name} { | 
					
						
							| 
									
										
										
										
											2018-09-11 20:46:49 -04:00
										 |  |  |         // clang-format off
 | 
					
						
							|  |  |  |         static const FunctionInfo functions[] = { | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  |             {10100, &PlayReport::SaveReport<Core::Reporter::PlayReportType::Old>, "SaveReportOld"}, | 
					
						
							|  |  |  |             {10101, &PlayReport::SaveReportWithUser<Core::Reporter::PlayReportType::Old>, "SaveReportWithUserOld"}, | 
					
						
							| 
									
										
										
										
											2020-04-20 15:18:23 -04:00
										 |  |  |             {10102, &PlayReport::SaveReport<Core::Reporter::PlayReportType::Old2>, "SaveReportOld2"}, | 
					
						
							|  |  |  |             {10103, &PlayReport::SaveReportWithUser<Core::Reporter::PlayReportType::Old2>, "SaveReportWithUserOld2"}, | 
					
						
							| 
									
										
										
										
											2021-01-28 01:23:29 -05:00
										 |  |  |             {10104, &PlayReport::SaveReport<Core::Reporter::PlayReportType::New>, "SaveReport"}, | 
					
						
							|  |  |  |             {10105, &PlayReport::SaveReportWithUser<Core::Reporter::PlayReportType::New>, "SaveReportWithUser"}, | 
					
						
							| 
									
										
										
										
											2021-01-31 07:04:35 -05:00
										 |  |  |             {10200, &PlayReport::RequestImmediateTransmission, "RequestImmediateTransmission"}, | 
					
						
							| 
									
										
										
										
											2021-01-31 07:06:48 -05:00
										 |  |  |             {10300, &PlayReport::GetTransmissionStatus, "GetTransmissionStatus"}, | 
					
						
							| 
									
										
										
										
											2021-01-27 23:08:52 -06:00
										 |  |  |             {10400, &PlayReport::GetSystemSessionId, "GetSystemSessionId"}, | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  |             {20100, &PlayReport::SaveSystemReport, "SaveSystemReport"}, | 
					
						
							|  |  |  |             {20101, &PlayReport::SaveSystemReportWithUser, "SaveSystemReportWithUser"}, | 
					
						
							| 
									
										
										
										
											2018-10-21 16:21:02 -04:00
										 |  |  |             {20200, nullptr, "SetOperationMode"}, | 
					
						
							| 
									
										
										
										
											2018-09-11 20:46:49 -04:00
										 |  |  |             {30100, nullptr, "ClearStorage"}, | 
					
						
							| 
									
										
										
										
											2018-10-21 16:21:02 -04:00
										 |  |  |             {30200, nullptr, "ClearStatistics"}, | 
					
						
							|  |  |  |             {30300, nullptr, "GetStorageUsage"}, | 
					
						
							|  |  |  |             {30400, nullptr, "GetStatistics"}, | 
					
						
							|  |  |  |             {30401, nullptr, "GetThroughputHistory"}, | 
					
						
							|  |  |  |             {30500, nullptr, "GetLastUploadError"}, | 
					
						
							| 
									
										
										
										
											2020-04-20 15:18:23 -04:00
										 |  |  |             {30600, nullptr, "GetApplicationUploadSummary"}, | 
					
						
							| 
									
										
										
										
											2018-09-11 20:46:49 -04:00
										 |  |  |             {40100, nullptr, "IsUserAgreementCheckEnabled"}, | 
					
						
							|  |  |  |             {40101, nullptr, "SetUserAgreementCheckEnabled"}, | 
					
						
							| 
									
										
										
										
											2020-04-20 15:18:23 -04:00
										 |  |  |             {50100, nullptr, "ReadAllApplicationReportFiles"}, | 
					
						
							| 
									
										
										
										
											2018-10-21 16:21:02 -04:00
										 |  |  |             {90100, nullptr, "ReadAllReportFiles"}, | 
					
						
							| 
									
										
										
										
											2020-06-29 04:01:34 +02:00
										 |  |  |             {90101, nullptr, "Unknown90101"}, | 
					
						
							|  |  |  |             {90102, nullptr, "Unknown90102"}, | 
					
						
							|  |  |  |             {90200, nullptr, "GetStatistics"}, | 
					
						
							|  |  |  |             {90201, nullptr, "GetThroughputHistory"}, | 
					
						
							|  |  |  |             {90300, nullptr, "GetLastUploadError"}, | 
					
						
							| 
									
										
										
										
											2018-09-11 20:46:49 -04:00
										 |  |  |         }; | 
					
						
							|  |  |  |         // clang-format on
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         RegisterHandlers(functions); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  |     template <Core::Reporter::PlayReportType Type> | 
					
						
							|  |  |  |     void SaveReport(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         const auto process_id = rp.PopRaw<u64>(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-28 01:23:29 -05:00
										 |  |  |         const auto data1 = ctx.ReadBuffer(0); | 
					
						
							| 
									
										
										
										
											2021-04-02 18:02:10 -07:00
										 |  |  |         const auto data2 = [&ctx] { | 
					
						
							| 
									
										
										
										
											2021-01-28 01:23:29 -05:00
										 |  |  |             if (ctx.CanReadBuffer(1)) { | 
					
						
							|  |  |  |                 return ctx.ReadBuffer(1); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return std::vector<u8>{}; | 
					
						
							|  |  |  |         }(); | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-28 01:23:29 -05:00
										 |  |  |         LOG_DEBUG(Service_PREPO, | 
					
						
							|  |  |  |                   "called, type={:02X}, process_id={:016X}, data1_size={:016X}, data2_size={:016X}", | 
					
						
							|  |  |  |                   Type, process_id, data1.size(), data2.size()); | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-21 19:14:15 -04:00
										 |  |  |         const auto& reporter{system.GetReporter()}; | 
					
						
							| 
									
										
										
										
											2021-11-03 20:32:26 -04:00
										 |  |  |         reporter.SavePlayReport(Type, system.GetCurrentProcessProgramID(), {data1, data2}, | 
					
						
							| 
									
										
										
										
											2021-01-28 01:23:29 -05:00
										 |  |  |                                 process_id); | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     template <Core::Reporter::PlayReportType Type> | 
					
						
							|  |  |  |     void SaveReportWithUser(Kernel::HLERequestContext& ctx) { | 
					
						
							| 
									
										
										
										
											2019-05-17 21:49:21 -04:00
										 |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         const auto user_id = rp.PopRaw<u128>(); | 
					
						
							| 
									
										
										
										
											2019-05-26 11:40:41 -04:00
										 |  |  |         const auto process_id = rp.PopRaw<u64>(); | 
					
						
							| 
									
										
										
										
											2020-06-24 23:01:00 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-28 01:23:29 -05:00
										 |  |  |         const auto data1 = ctx.ReadBuffer(0); | 
					
						
							| 
									
										
										
										
											2021-04-02 18:02:10 -07:00
										 |  |  |         const auto data2 = [&ctx] { | 
					
						
							| 
									
										
										
										
											2021-01-28 01:23:29 -05:00
										 |  |  |             if (ctx.CanReadBuffer(1)) { | 
					
						
							|  |  |  |                 return ctx.ReadBuffer(1); | 
					
						
							| 
									
										
										
										
											2020-06-24 23:01:00 +10:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2019-05-17 21:49:21 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-28 01:23:29 -05:00
										 |  |  |             return std::vector<u8>{}; | 
					
						
							|  |  |  |         }(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         LOG_DEBUG(Service_PREPO, | 
					
						
							|  |  |  |                   "called, type={:02X}, user_id={:016X}{:016X}, process_id={:016X}, " | 
					
						
							|  |  |  |                   "data1_size={:016X}, data2_size={:016X}", | 
					
						
							|  |  |  |                   Type, user_id[1], user_id[0], process_id, data1.size(), data2.size()); | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-21 19:14:15 -04:00
										 |  |  |         const auto& reporter{system.GetReporter()}; | 
					
						
							| 
									
										
										
										
											2021-11-03 20:32:26 -04:00
										 |  |  |         reporter.SavePlayReport(Type, system.GetCurrentProcessProgramID(), {data1, data2}, | 
					
						
							| 
									
										
										
										
											2021-01-28 01:23:29 -05:00
										 |  |  |                                 process_id, user_id); | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-31 07:04:35 -05:00
										 |  |  |     void RequestImmediateTransmission(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         LOG_WARNING(Service_PREPO, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2021-01-31 07:04:35 -05:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-31 07:06:48 -05:00
										 |  |  |     void GetTransmissionStatus(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         LOG_WARNING(Service_PREPO, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         constexpr s32 status = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 3}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2021-01-31 07:06:48 -05:00
										 |  |  |         rb.Push(status); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-27 23:08:52 -06:00
										 |  |  |     void GetSystemSessionId(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         LOG_WARNING(Service_PREPO, "(STUBBED) called"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         constexpr u64 system_session_id = 0; | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 4}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2021-01-27 23:08:52 -06:00
										 |  |  |         rb.Push(system_session_id); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  |     void SaveSystemReport(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         const auto title_id = rp.PopRaw<u64>(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const auto data1 = ctx.ReadBuffer(0); | 
					
						
							| 
									
										
										
										
											2021-04-02 18:02:10 -07:00
										 |  |  |         const auto data2 = [&ctx] { | 
					
						
							| 
									
										
										
										
											2021-01-28 01:23:29 -05:00
										 |  |  |             if (ctx.CanReadBuffer(1)) { | 
					
						
							|  |  |  |                 return ctx.ReadBuffer(1); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return std::vector<u8>{}; | 
					
						
							|  |  |  |         }(); | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         LOG_DEBUG(Service_PREPO, "called, title_id={:016X}, data1_size={:016X}, data2_size={:016X}", | 
					
						
							|  |  |  |                   title_id, data1.size(), data2.size()); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-21 19:14:15 -04:00
										 |  |  |         const auto& reporter{system.GetReporter()}; | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  |         reporter.SavePlayReport(Core::Reporter::PlayReportType::System, title_id, {data1, data2}); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void SaveSystemReportWithUser(Kernel::HLERequestContext& ctx) { | 
					
						
							|  |  |  |         IPC::RequestParser rp{ctx}; | 
					
						
							|  |  |  |         const auto user_id = rp.PopRaw<u128>(); | 
					
						
							|  |  |  |         const auto title_id = rp.PopRaw<u64>(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const auto data1 = ctx.ReadBuffer(0); | 
					
						
							| 
									
										
										
										
											2021-04-02 18:02:10 -07:00
										 |  |  |         const auto data2 = [&ctx] { | 
					
						
							| 
									
										
										
										
											2021-01-28 01:23:29 -05:00
										 |  |  |             if (ctx.CanReadBuffer(1)) { | 
					
						
							|  |  |  |                 return ctx.ReadBuffer(1); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return std::vector<u8>{}; | 
					
						
							|  |  |  |         }(); | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         LOG_DEBUG(Service_PREPO, | 
					
						
							|  |  |  |                   "called, user_id={:016X}{:016X}, title_id={:016X}, data1_size={:016X}, " | 
					
						
							|  |  |  |                   "data2_size={:016X}", | 
					
						
							|  |  |  |                   user_id[1], user_id[0], title_id, data1.size(), data2.size()); | 
					
						
							| 
									
										
										
										
											2019-05-17 21:49:21 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-21 19:14:15 -04:00
										 |  |  |         const auto& reporter{system.GetReporter()}; | 
					
						
							| 
									
										
										
										
											2019-06-26 18:02:36 -04:00
										 |  |  |         reporter.SavePlayReport(Core::Reporter::PlayReportType::System, title_id, {data1, data2}, | 
					
						
							|  |  |  |                                 std::nullopt, user_id); | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-11 20:46:49 -04:00
										 |  |  |         IPC::ResponseBuilder rb{ctx, 2}; | 
					
						
							| 
									
										
										
										
											2021-05-21 01:05:04 -04:00
										 |  |  |         rb.Push(ResultSuccess); | 
					
						
							| 
									
										
										
										
											2018-09-11 20:46:49 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-22 16:37:59 +10:00
										 |  |  | void InstallInterfaces(SM::ServiceManager& service_manager, Core::System& system) { | 
					
						
							|  |  |  |     std::make_shared<PlayReport>("prepo:a", system)->InstallAsService(service_manager); | 
					
						
							|  |  |  |     std::make_shared<PlayReport>("prepo:a2", system)->InstallAsService(service_manager); | 
					
						
							|  |  |  |     std::make_shared<PlayReport>("prepo:m", system)->InstallAsService(service_manager); | 
					
						
							|  |  |  |     std::make_shared<PlayReport>("prepo:s", system)->InstallAsService(service_manager); | 
					
						
							|  |  |  |     std::make_shared<PlayReport>("prepo:u", system)->InstallAsService(service_manager); | 
					
						
							| 
									
										
										
										
											2018-04-21 22:04:24 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-22 19:02:18 -07:00
										 |  |  | } // namespace Service::PlayReport
 |