committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 158 additions and 70 deletions
-
2src/common/logging/filter.cpp
-
2src/common/logging/types.h
-
4src/core/CMakeLists.txt
-
150src/core/hle/service/ngc/ngc.cpp
-
4src/core/hle/service/ngc/ngc.h
-
62src/core/hle/service/ngct/ngct.cpp
-
4src/core/hle/service/service.cpp
@ -0,0 +1,150 @@ |
|||||
|
// SPDX-FileCopyrightText: Copyright 2021 yuzu Emulator Project
|
||||
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||
|
|
||||
|
#include "common/string_util.h"
|
||||
|
#include "core/core.h"
|
||||
|
#include "core/hle/service/ipc_helpers.h"
|
||||
|
#include "core/hle/service/ngc/ngc.h"
|
||||
|
#include "core/hle/service/server_manager.h"
|
||||
|
#include "core/hle/service/service.h"
|
||||
|
|
||||
|
namespace Service::NGC { |
||||
|
|
||||
|
class NgctServiceImpl final : public ServiceFramework<NgctServiceImpl> { |
||||
|
public: |
||||
|
explicit NgctServiceImpl(Core::System& system_) : ServiceFramework{system_, "ngct:u"} { |
||||
|
// clang-format off
|
||||
|
static const FunctionInfo functions[] = { |
||||
|
{0, &NgctServiceImpl::Match, "Match"}, |
||||
|
{1, &NgctServiceImpl::Filter, "Filter"}, |
||||
|
}; |
||||
|
// clang-format on
|
||||
|
|
||||
|
RegisterHandlers(functions); |
||||
|
} |
||||
|
|
||||
|
private: |
||||
|
void Match(HLERequestContext& ctx) { |
||||
|
const auto buffer = ctx.ReadBuffer(); |
||||
|
const auto text = Common::StringFromFixedZeroTerminatedBuffer( |
||||
|
reinterpret_cast<const char*>(buffer.data()), buffer.size()); |
||||
|
|
||||
|
LOG_WARNING(Service_NGC, "(STUBBED) called, text={}", text); |
||||
|
|
||||
|
IPC::ResponseBuilder rb{ctx, 3}; |
||||
|
rb.Push(ResultSuccess); |
||||
|
// Return false since we don't censor anything
|
||||
|
rb.Push(false); |
||||
|
} |
||||
|
|
||||
|
void Filter(HLERequestContext& ctx) { |
||||
|
const auto buffer = ctx.ReadBuffer(); |
||||
|
const auto text = Common::StringFromFixedZeroTerminatedBuffer( |
||||
|
reinterpret_cast<const char*>(buffer.data()), buffer.size()); |
||||
|
|
||||
|
LOG_WARNING(Service_NGC, "(STUBBED) called, text={}", text); |
||||
|
|
||||
|
// Return the same string since we don't censor anything
|
||||
|
ctx.WriteBuffer(buffer); |
||||
|
|
||||
|
IPC::ResponseBuilder rb{ctx, 2}; |
||||
|
rb.Push(ResultSuccess); |
||||
|
} |
||||
|
}; |
||||
|
|
||||
|
class NgcServiceImpl final : public ServiceFramework<NgcServiceImpl> { |
||||
|
public: |
||||
|
explicit NgcServiceImpl(Core::System& system_) : ServiceFramework(system_, "ngc:u") { |
||||
|
// clang-format off
|
||||
|
static const FunctionInfo functions[] = { |
||||
|
{0, &NgcServiceImpl::GetContentVersion, "GetContentVersion"}, |
||||
|
{1, &NgcServiceImpl::Check, "Check"}, |
||||
|
{2, &NgcServiceImpl::Mask, "Mask"}, |
||||
|
{3, &NgcServiceImpl::Reload, "Reload"}, |
||||
|
}; |
||||
|
// clang-format on
|
||||
|
|
||||
|
RegisterHandlers(functions); |
||||
|
} |
||||
|
|
||||
|
private: |
||||
|
static constexpr u32 NgcContentVersion = 1; |
||||
|
|
||||
|
// This is nn::ngc::detail::ProfanityFilterOption
|
||||
|
struct ProfanityFilterOption { |
||||
|
INSERT_PADDING_BYTES_NOINIT(0x20); |
||||
|
}; |
||||
|
static_assert(sizeof(ProfanityFilterOption) == 0x20, |
||||
|
"ProfanityFilterOption has incorrect size"); |
||||
|
|
||||
|
void GetContentVersion(HLERequestContext& ctx) { |
||||
|
LOG_INFO(Service_NGC, "(STUBBED) called"); |
||||
|
|
||||
|
// This calls nn::ngc::ProfanityFilter::GetContentVersion
|
||||
|
const u32 version = NgcContentVersion; |
||||
|
|
||||
|
IPC::ResponseBuilder rb{ctx, 3}; |
||||
|
rb.Push(ResultSuccess); |
||||
|
rb.Push(version); |
||||
|
} |
||||
|
|
||||
|
void Check(HLERequestContext& ctx) { |
||||
|
LOG_INFO(Service_NGC, "(STUBBED) called"); |
||||
|
|
||||
|
struct InputParameters { |
||||
|
u32 flags; |
||||
|
ProfanityFilterOption option; |
||||
|
}; |
||||
|
|
||||
|
IPC::RequestParser rp{ctx}; |
||||
|
[[maybe_unused]] const auto params = rp.PopRaw<InputParameters>(); |
||||
|
[[maybe_unused]] const auto input = ctx.ReadBuffer(0); |
||||
|
|
||||
|
// This calls nn::ngc::ProfanityFilter::CheckProfanityWords
|
||||
|
const u32 out_flags = 0; |
||||
|
|
||||
|
IPC::ResponseBuilder rb{ctx, 3}; |
||||
|
rb.Push(ResultSuccess); |
||||
|
rb.Push(out_flags); |
||||
|
} |
||||
|
|
||||
|
void Mask(HLERequestContext& ctx) { |
||||
|
LOG_INFO(Service_NGC, "(STUBBED) called"); |
||||
|
|
||||
|
struct InputParameters { |
||||
|
u32 flags; |
||||
|
ProfanityFilterOption option; |
||||
|
}; |
||||
|
|
||||
|
IPC::RequestParser rp{ctx}; |
||||
|
[[maybe_unused]] const auto params = rp.PopRaw<InputParameters>(); |
||||
|
const auto input = ctx.ReadBuffer(0); |
||||
|
|
||||
|
// This calls nn::ngc::ProfanityFilter::MaskProfanityWordsInText
|
||||
|
const u32 out_flags = 0; |
||||
|
ctx.WriteBuffer(input); |
||||
|
|
||||
|
IPC::ResponseBuilder rb{ctx, 3}; |
||||
|
rb.Push(ResultSuccess); |
||||
|
rb.Push(out_flags); |
||||
|
} |
||||
|
|
||||
|
void Reload(HLERequestContext& ctx) { |
||||
|
LOG_INFO(Service_NGC, "(STUBBED) called"); |
||||
|
|
||||
|
// This reloads the database.
|
||||
|
|
||||
|
IPC::ResponseBuilder rb{ctx, 2}; |
||||
|
rb.Push(ResultSuccess); |
||||
|
} |
||||
|
}; |
||||
|
|
||||
|
void LoopProcess(Core::System& system) { |
||||
|
auto server_manager = std::make_unique<ServerManager>(system); |
||||
|
|
||||
|
server_manager->RegisterNamedService("ngct:u", std::make_shared<NgctServiceImpl>(system)); |
||||
|
server_manager->RegisterNamedService("ngc:u", std::make_shared<NgcServiceImpl>(system)); |
||||
|
ServerManager::RunServer(std::move(server_manager)); |
||||
|
} |
||||
|
|
||||
|
} // namespace Service::NGC
|
||||
@ -1,62 +0,0 @@ |
|||||
// SPDX-FileCopyrightText: Copyright 2021 yuzu Emulator Project
|
|
||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
||||
|
|
||||
#include "common/string_util.h"
|
|
||||
#include "core/core.h"
|
|
||||
#include "core/hle/service/ipc_helpers.h"
|
|
||||
#include "core/hle/service/ngct/ngct.h"
|
|
||||
#include "core/hle/service/server_manager.h"
|
|
||||
#include "core/hle/service/service.h"
|
|
||||
|
|
||||
namespace Service::NGCT { |
|
||||
|
|
||||
class IService final : public ServiceFramework<IService> { |
|
||||
public: |
|
||||
explicit IService(Core::System& system_) : ServiceFramework{system_, "ngct:u"} { |
|
||||
// clang-format off
|
|
||||
static const FunctionInfo functions[] = { |
|
||||
{0, &IService::Match, "Match"}, |
|
||||
{1, &IService::Filter, "Filter"}, |
|
||||
}; |
|
||||
// clang-format on
|
|
||||
|
|
||||
RegisterHandlers(functions); |
|
||||
} |
|
||||
|
|
||||
private: |
|
||||
void Match(HLERequestContext& ctx) { |
|
||||
const auto buffer = ctx.ReadBuffer(); |
|
||||
const auto text = Common::StringFromFixedZeroTerminatedBuffer( |
|
||||
reinterpret_cast<const char*>(buffer.data()), buffer.size()); |
|
||||
|
|
||||
LOG_WARNING(Service_NGCT, "(STUBBED) called, text={}", text); |
|
||||
|
|
||||
IPC::ResponseBuilder rb{ctx, 3}; |
|
||||
rb.Push(ResultSuccess); |
|
||||
// Return false since we don't censor anything
|
|
||||
rb.Push(false); |
|
||||
} |
|
||||
|
|
||||
void Filter(HLERequestContext& ctx) { |
|
||||
const auto buffer = ctx.ReadBuffer(); |
|
||||
const auto text = Common::StringFromFixedZeroTerminatedBuffer( |
|
||||
reinterpret_cast<const char*>(buffer.data()), buffer.size()); |
|
||||
|
|
||||
LOG_WARNING(Service_NGCT, "(STUBBED) called, text={}", text); |
|
||||
|
|
||||
// Return the same string since we don't censor anything
|
|
||||
ctx.WriteBuffer(buffer); |
|
||||
|
|
||||
IPC::ResponseBuilder rb{ctx, 2}; |
|
||||
rb.Push(ResultSuccess); |
|
||||
} |
|
||||
}; |
|
||||
|
|
||||
void LoopProcess(Core::System& system) { |
|
||||
auto server_manager = std::make_unique<ServerManager>(system); |
|
||||
|
|
||||
server_manager->RegisterNamedService("ngct:u", std::make_shared<IService>(system)); |
|
||||
ServerManager::RunServer(std::move(server_manager)); |
|
||||
} |
|
||||
|
|
||||
} // namespace Service::NGCT
|
|
||||
Write
Preview
Loading…
Cancel
Save
Reference in new issue