ea14a95524
* Fix inconsistencies with UserId The account user id isn't an UUID. This PR adds a new UserId type with the correct value ordering to avoid mismatch with LibHac's Uid. This also fix an hardcoded value of the UserId. As the userid has been invalid for quite some time (and to avoid forcing users to their recreate saves), the userid has been changed to "00000000000000010000000000000000". Also implement a stub for IApplicationFunctions::GetSaveDataSize. (see the sources for the reason) Fix #626 * Address jd's & Ac_k's comments
169 lines
No EOL
5.9 KiB
C#
169 lines
No EOL
5.9 KiB
C#
using Ryujinx.Common;
|
|
using Ryujinx.Common.Logging;
|
|
using Ryujinx.HLE.HOS.Services.Account.Acc;
|
|
using Ryujinx.HLE.HOS.Services.Friend.ServiceCreator.FriendService;
|
|
using System.IO;
|
|
using System.Runtime.InteropServices;
|
|
|
|
namespace Ryujinx.HLE.HOS.Services.Friend.ServiceCreator
|
|
{
|
|
class IFriendService : IpcService
|
|
{
|
|
private FriendServicePermissionLevel _permissionLevel;
|
|
|
|
public IFriendService(FriendServicePermissionLevel permissionLevel)
|
|
{
|
|
_permissionLevel = permissionLevel;
|
|
}
|
|
|
|
[Command(10100)]
|
|
// nn::friends::GetFriendListIds(int offset, nn::account::Uid userId, nn::friends::detail::ipc::SizedFriendFilter friendFilter, ulong pidPlaceHolder, pid)
|
|
// -> int outCount, array<nn::account::NetworkServiceAccountId, 0xa>
|
|
public ResultCode GetFriendListIds(ServiceCtx context)
|
|
{
|
|
int offset = context.RequestData.ReadInt32();
|
|
|
|
// Padding
|
|
context.RequestData.ReadInt32();
|
|
|
|
UserId userId = context.RequestData.ReadStruct<UserId>();
|
|
FriendFilter filter = context.RequestData.ReadStruct<FriendFilter>();
|
|
|
|
// Pid placeholder
|
|
context.RequestData.ReadInt64();
|
|
|
|
if (userId.IsNull)
|
|
{
|
|
return ResultCode.InvalidArgument;
|
|
}
|
|
|
|
// There are no friends online, so we return 0 because the nn::account::NetworkServiceAccountId array is empty.
|
|
context.ResponseData.Write(0);
|
|
|
|
Logger.PrintStub(LogClass.ServiceFriend, new
|
|
{
|
|
UserId = userId.ToString(),
|
|
offset,
|
|
filter.PresenceStatus,
|
|
filter.IsFavoriteOnly,
|
|
filter.IsSameAppPresenceOnly,
|
|
filter.IsSameAppPlayedOnly,
|
|
filter.IsArbitraryAppPlayedOnly,
|
|
filter.PresenceGroupId,
|
|
});
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(10101)]
|
|
// nn::friends::GetFriendList(int offset, nn::account::Uid userId, nn::friends::detail::ipc::SizedFriendFilter friendFilter, ulong pidPlaceHolder, pid)
|
|
// -> int outCount, array<nn::friends::detail::FriendImpl, 0x6>
|
|
public ResultCode GetFriendList(ServiceCtx context)
|
|
{
|
|
int offset = context.RequestData.ReadInt32();
|
|
|
|
// Padding
|
|
context.RequestData.ReadInt32();
|
|
|
|
UserId userId = context.RequestData.ReadStruct<UserId>();
|
|
FriendFilter filter = context.RequestData.ReadStruct<FriendFilter>();
|
|
|
|
// Pid placeholder
|
|
context.RequestData.ReadInt64();
|
|
|
|
if (userId.IsNull)
|
|
{
|
|
return ResultCode.InvalidArgument;
|
|
}
|
|
|
|
// There are no friends online, so we return 0 because the nn::account::NetworkServiceAccountId array is empty.
|
|
context.ResponseData.Write(0);
|
|
|
|
Logger.PrintStub(LogClass.ServiceFriend, new {
|
|
UserId = userId.ToString(),
|
|
offset,
|
|
filter.PresenceStatus,
|
|
filter.IsFavoriteOnly,
|
|
filter.IsSameAppPresenceOnly,
|
|
filter.IsSameAppPlayedOnly,
|
|
filter.IsArbitraryAppPlayedOnly,
|
|
filter.PresenceGroupId,
|
|
});
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(10600)]
|
|
// nn::friends::DeclareOpenOnlinePlaySession(nn::account::Uid userId)
|
|
public ResultCode DeclareOpenOnlinePlaySession(ServiceCtx context)
|
|
{
|
|
UserId userId = context.RequestData.ReadStruct<UserId>();
|
|
|
|
if (userId.IsNull)
|
|
{
|
|
return ResultCode.InvalidArgument;
|
|
}
|
|
|
|
if (context.Device.System.State.Account.TryGetUser(userId, out UserProfile profile))
|
|
{
|
|
profile.OnlinePlayState = AccountState.Open;
|
|
}
|
|
|
|
Logger.PrintStub(LogClass.ServiceFriend, new { UserId = userId.ToString(), profile.OnlinePlayState });
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(10601)]
|
|
// nn::friends::DeclareCloseOnlinePlaySession(nn::account::Uid userId)
|
|
public ResultCode DeclareCloseOnlinePlaySession(ServiceCtx context)
|
|
{
|
|
UserId userId = context.RequestData.ReadStruct<UserId>();
|
|
|
|
if (userId.IsNull)
|
|
{
|
|
return ResultCode.InvalidArgument;
|
|
}
|
|
|
|
if (context.Device.System.State.Account.TryGetUser(userId, out UserProfile profile))
|
|
{
|
|
profile.OnlinePlayState = AccountState.Closed;
|
|
}
|
|
|
|
Logger.PrintStub(LogClass.ServiceFriend, new { UserId = userId.ToString(), profile.OnlinePlayState });
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[Command(10610)]
|
|
// nn::friends::UpdateUserPresence(nn::account::Uid, u64, pid, buffer<nn::friends::detail::UserPresenceImpl, 0x19>)
|
|
public ResultCode UpdateUserPresence(ServiceCtx context)
|
|
{
|
|
UserId uuid = context.RequestData.ReadStruct<UserId>();
|
|
|
|
// Pid placeholder
|
|
context.RequestData.ReadInt64();
|
|
|
|
long position = context.Request.PtrBuff[0].Position;
|
|
long size = context.Request.PtrBuff[0].Size;
|
|
|
|
byte[] bufferContent = context.Memory.ReadBytes(position, size);
|
|
|
|
if (uuid.IsNull)
|
|
{
|
|
return ResultCode.InvalidArgument;
|
|
}
|
|
|
|
int elementCount = bufferContent.Length / Marshal.SizeOf<UserPresence>();
|
|
|
|
using (BinaryReader bufferReader = new BinaryReader(new MemoryStream(bufferContent)))
|
|
{
|
|
UserPresence[] userPresenceInputArray = bufferReader.ReadStructArray<UserPresence>(elementCount);
|
|
|
|
Logger.PrintStub(LogClass.ServiceFriend, new { UserId = uuid.ToString(), userPresenceInputArray });
|
|
}
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
}
|
|
} |