mirror of
https://github.com/snltty/linker.git
synced 2025-10-05 09:06:54 +08:00
165
This commit is contained in:
93
src/linker.messenger.access/AccessApiController.cs
Normal file
93
src/linker.messenger.access/AccessApiController.cs
Normal file
@@ -0,0 +1,93 @@
|
||||
using linker.libs.api;
|
||||
using linker.libs.extends;
|
||||
using linker.libs;
|
||||
using linker.messenger.signin;
|
||||
using linker.messenger.api;
|
||||
|
||||
namespace linker.messenger.access
|
||||
{
|
||||
public sealed class AccessApiController : IApiController
|
||||
{
|
||||
private readonly IMessengerSender sender;
|
||||
private readonly SignInClientState signInClientState;
|
||||
private readonly AccessDecenter accessDecenter;
|
||||
private readonly ISignInClientStore signInClientStore;
|
||||
private readonly ISerializer serializer;
|
||||
private readonly IAccessStore accessStore;
|
||||
private readonly IApiStore apiStore;
|
||||
|
||||
public AccessApiController(IMessengerSender sender, SignInClientState signInClientState, AccessDecenter accessDecenter, ISignInClientStore signInClientStore, ISerializer serializer, IAccessStore accessStore, IApiStore apiStore)
|
||||
{
|
||||
this.sender = sender;
|
||||
this.signInClientState = signInClientState;
|
||||
this.accessDecenter = accessDecenter;
|
||||
this.signInClientStore = signInClientStore;
|
||||
this.serializer = serializer;
|
||||
this.accessStore = accessStore;
|
||||
this.apiStore = apiStore;
|
||||
}
|
||||
|
||||
public void Refresh(ApiControllerParamsInfo param)
|
||||
{
|
||||
accessDecenter.Refresh();
|
||||
}
|
||||
|
||||
public AccessListInfo GetAccesss(ApiControllerParamsInfo param)
|
||||
{
|
||||
ulong hashCode = ulong.Parse(param.Content);
|
||||
if (accessDecenter.DataVersion.Eq(hashCode, out ulong version) == false)
|
||||
{
|
||||
return new AccessListInfo
|
||||
{
|
||||
HashCode = version,
|
||||
List = accessDecenter.Accesss
|
||||
};
|
||||
}
|
||||
return new AccessListInfo { HashCode = version };
|
||||
}
|
||||
|
||||
[Access(AccessValue.Access)]
|
||||
public async Task<bool> SetAccess(ApiControllerParamsInfo param)
|
||||
{
|
||||
AccessUpdateInfo configUpdateAccessInfo = param.Content.DeJson<AccessUpdateInfo>();
|
||||
if (configUpdateAccessInfo.ToMachineId == signInClientStore.Id)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
configUpdateAccessInfo.FromMachineId = signInClientStore.Id;
|
||||
MessageResponeInfo resp = await sender.SendReply(new MessageRequestWrap
|
||||
{
|
||||
Connection = signInClientState.Connection,
|
||||
MessengerId = (ushort)AccessMessengerIds.AccessUpdateForward,
|
||||
Payload = serializer.Serialize(configUpdateAccessInfo)
|
||||
});
|
||||
return resp.Code == MessageResponeCodes.OK && resp.Data.Span.SequenceEqual(Helper.TrueArray);
|
||||
}
|
||||
|
||||
public async Task<bool> SetApiPassword(ApiControllerParamsInfo param)
|
||||
{
|
||||
ApiPasswordUpdateInfo info = param.Content.DeJson<ApiPasswordUpdateInfo>();
|
||||
if (info.MachineId == signInClientStore.Id)
|
||||
{
|
||||
if (accessStore.HasAccess(AccessValue.SetApiPassword) == false) return false;
|
||||
apiStore.SetApiPassword(info.Password);
|
||||
return true;
|
||||
}
|
||||
if (accessStore.HasAccess(AccessValue.SetApiPasswordOther) == false) return false;
|
||||
MessageResponeInfo resp = await sender.SendReply(new MessageRequestWrap
|
||||
{
|
||||
Connection = signInClientState.Connection,
|
||||
MessengerId = (ushort)AccessMessengerIds.SetApiPasswordForward,
|
||||
Payload = serializer.Serialize(info)
|
||||
});
|
||||
return resp.Code == MessageResponeCodes.OK && resp.Data.Span.SequenceEqual(Helper.TrueArray);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public sealed class AccessListInfo
|
||||
{
|
||||
public Dictionary<string, AccessValue> List { get; set; }
|
||||
public ulong HashCode { get; set; }
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user