void.cat/VoidCat/Services/Abstractions/IFileMetadataStore.cs

73 lines
1.9 KiB
C#
Raw Normal View History

2022-02-16 16:33:00 +00:00
using VoidCat.Model;
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>
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>
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>
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>
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>
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();
/// <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);
}