2022-02-16 16:33:00 +00:00
|
|
|
using VoidCat.Model;
|
2023-05-09 13:56:57 +00:00
|
|
|
using File = VoidCat.Database.File;
|
2022-02-16 16:33:00 +00:00
|
|
|
|
|
|
|
namespace VoidCat.Services.Abstractions;
|
|
|
|
|
2022-06-08 16:17:53 +00:00
|
|
|
/// <summary>
|
|
|
|
/// File metadata contains all data about a file except for the file data itself
|
|
|
|
/// </summary>
|
2023-05-09 13:56:57 +00:00
|
|
|
public interface IFileMetadataStore
|
2022-02-16 16:33:00 +00:00
|
|
|
{
|
2022-06-08 16:17:53 +00:00
|
|
|
/// <summary>
|
|
|
|
/// Get metadata for a single file
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="id"></param>
|
|
|
|
/// <returns></returns>
|
2023-05-09 13:56:57 +00:00
|
|
|
ValueTask<File?> Get(Guid id);
|
2022-06-08 16:17:53 +00:00
|
|
|
|
2023-11-20 15:22:12 +00:00
|
|
|
/// <summary>
|
|
|
|
/// Get metadata for a single file by its hash
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="digest"></param>
|
|
|
|
/// <returns></returns>
|
|
|
|
ValueTask<File?> GetHash(string digest);
|
|
|
|
|
2022-06-08 16:17:53 +00:00
|
|
|
/// <summary>
|
|
|
|
/// Get metadata for multiple files
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="ids"></param>
|
|
|
|
/// <returns></returns>
|
2023-05-09 13:56:57 +00:00
|
|
|
ValueTask<IReadOnlyList<File>> Get(Guid[] ids);
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Add new file metadata to this store
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="f"></param>
|
|
|
|
/// <returns></returns>
|
|
|
|
ValueTask Add(File f);
|
2022-06-08 16:17:53 +00:00
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Update file metadata
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="id"></param>
|
|
|
|
/// <param name="meta"></param>
|
|
|
|
/// <returns></returns>
|
2023-05-09 13:56:57 +00:00
|
|
|
ValueTask Update(Guid id, File meta);
|
2022-06-08 16:17:53 +00:00
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// List all files in the store
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="request"></param>
|
|
|
|
/// <returns></returns>
|
2023-05-09 13:56:57 +00:00
|
|
|
ValueTask<PagedResult<File>> ListFiles(PagedRequest request);
|
2022-06-06 21:51:25 +00:00
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Returns basic stats about the file store
|
|
|
|
/// </summary>
|
|
|
|
/// <returns></returns>
|
|
|
|
ValueTask<StoreStats> Stats();
|
|
|
|
|
2023-05-09 13:56:57 +00:00
|
|
|
/// <summary>
|
|
|
|
/// Delete metadata object from the store
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="id"></param>
|
|
|
|
/// <returns></returns>
|
|
|
|
ValueTask Delete(Guid id);
|
|
|
|
|
2022-06-08 16:17:53 +00:00
|
|
|
/// <summary>
|
|
|
|
/// Simple stats of the current store
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="Files"></param>
|
|
|
|
/// <param name="Size"></param>
|
2022-06-06 21:51:25 +00:00
|
|
|
public sealed record StoreStats(long Files, ulong Size);
|
|
|
|
}
|