4 Commits

Author SHA1 Message Date
4a0b6c3e4d Merge branch 'main' into lightfinder-rewrite 2025-10-10 00:55:37 +02:00
azyges
89ac34235d cdn url downloads 2025-10-10 07:36:34 +09:00
azyges
f3c6064892 update methods, bump api 2025-10-08 07:58:29 +09:00
167508d27b Merge pull request '1.12.0-server' (#6) from 1.12.0-server into main
Reviewed-on: #6
2025-10-04 20:48:16 +02:00
3 changed files with 28 additions and 25 deletions

View File

@@ -8,6 +8,7 @@ public record DownloadFileDto : ITransferFileDto
public bool FileExists { get; set; } = true; public bool FileExists { get; set; } = true;
public string Hash { get; set; } = string.Empty; public string Hash { get; set; } = string.Empty;
public string Url { get; set; } = string.Empty; public string Url { get; set; } = string.Empty;
public string CDNDownloadUrl { get; set; } = string.Empty;
public long Size { get; set; } = 0; public long Size { get; set; } = 0;
public bool IsForbidden { get; set; } = false; public bool IsForbidden { get; set; } = false;
public string ForbiddenBy { get; set; } = string.Empty; public string ForbiddenBy { get; set; } = string.Empty;

View File

@@ -18,6 +18,7 @@ public class LightlessFiles
public const string ServerFiles_Upload = "upload"; public const string ServerFiles_Upload = "upload";
public const string ServerFiles_UploadMunged = "uploadMunged"; public const string ServerFiles_UploadMunged = "uploadMunged";
public const string ServerFiles_DownloadServers = "downloadServers"; public const string ServerFiles_DownloadServers = "downloadServers";
public const string ServerFiles_DirectDownload = "direct";
public const string Distribution = "/dist"; public const string Distribution = "/dist";
public const string Distribution_Get = "get"; public const string Distribution_Get = "get";
@@ -41,6 +42,7 @@ public class LightlessFiles
public static Uri ServerFilesUploadFullPath(Uri baseUri, string hash) => new(baseUri, ServerFiles + "/" + ServerFiles_Upload + "/" + hash); public static Uri ServerFilesUploadFullPath(Uri baseUri, string hash) => new(baseUri, ServerFiles + "/" + ServerFiles_Upload + "/" + hash);
public static Uri ServerFilesUploadMunged(Uri baseUri, string hash) => new(baseUri, ServerFiles + "/" + ServerFiles_UploadMunged + "/" + hash); public static Uri ServerFilesUploadMunged(Uri baseUri, string hash) => new(baseUri, ServerFiles + "/" + ServerFiles_UploadMunged + "/" + hash);
public static Uri ServerFilesGetDownloadServersFullPath(Uri baseUri) => new(baseUri, ServerFiles + "/" + ServerFiles_DownloadServers); public static Uri ServerFilesGetDownloadServersFullPath(Uri baseUri) => new(baseUri, ServerFiles + "/" + ServerFiles_DownloadServers);
public static Uri ServerFilesDirectDownloadFullPath(Uri baseUri, string hash) => new(baseUri, ServerFiles + "/" + ServerFiles_DirectDownload + "/" + hash);
public static Uri DistributionGetFullPath(Uri baseUri, string hash) => new(baseUri, Distribution + "/" + Distribution_Get + "?file=" + hash); public static Uri DistributionGetFullPath(Uri baseUri, string hash) => new(baseUri, Distribution + "/" + Distribution_Get + "?file=" + hash);
public static Uri SpeedtestRunFullPath(Uri baseUri) => new(baseUri, Speedtest + "/" + Speedtest_Run); public static Uri SpeedtestRunFullPath(Uri baseUri) => new(baseUri, Speedtest + "/" + Speedtest_Run);
public static Uri MainSendReadyFullPath(Uri baseUri, string uid, Guid request) => new(baseUri, Main + "/" + Main_SendReady + "/" + "?uid=" + uid + "&requestId=" + request.ToString()); public static Uri MainSendReadyFullPath(Uri baseUri, string uid, Guid request) => new(baseUri, Main + "/" + Main_SendReady + "/" + "?uid=" + uid + "&requestId=" + request.ToString());

View File

@@ -9,7 +9,7 @@ namespace LightlessSync.API.SignalR;
public interface ILightlessHub public interface ILightlessHub
{ {
const int ApiVersion = 33; const int ApiVersion = 34;
const string Path = "/lightless"; const string Path = "/lightless";
Task<bool> CheckClientHealth(); Task<bool> CheckClientHealth();
@@ -69,14 +69,14 @@ public interface ILightlessHub
Task<int> GroupPrune(GroupDto group, int days, bool execute); Task<int> GroupPrune(GroupDto group, int days, bool execute);
Task UserAddPair(UserDto user); Task UserAddPair(UserDto user);
Task TryPairWithContentId(string otherCid, string myCid); Task TryPairWithContentId(string otherCid);
Task SetBroadcastStatus(string hashedCid, bool enabled, GroupBroadcastRequestDto? groupDto = null); Task SetBroadcastStatus(bool enabled, GroupBroadcastRequestDto? groupDto = null);
Task<bool> SetGroupBroadcastStatus(GroupBroadcastRequestDto dto); Task<bool> SetGroupBroadcastStatus(GroupBroadcastRequestDto dto);
Task<List<GroupJoinDto>> GetBroadcastedGroups(List<BroadcastStatusInfoDto> broadcastEntries); Task<List<GroupJoinDto>> GetBroadcastedGroups(List<BroadcastStatusInfoDto> broadcastEntries);
Task<BroadcastStatusInfoDto?> IsUserBroadcasting(string hashedCid); Task<BroadcastStatusInfoDto?> IsUserBroadcasting(string hashedCid);
Task<BroadcastStatusBatchDto?> AreUsersBroadcasting(List<string> hashedCids); Task<BroadcastStatusBatchDto?> AreUsersBroadcasting(List<string> hashedCids);
Task<TimeSpan?> GetBroadcastTtl(string hashedCid); Task<TimeSpan?> GetBroadcastTtl();
Task UserDelete(); Task UserDelete();
Task<List<OnlineUserIdentDto>> UserGetOnlinePairs(CensusDataDto? censusDataDto); Task<List<OnlineUserIdentDto>> UserGetOnlinePairs(CensusDataDto? censusDataDto);