mirror of
https://github.com/DrizzleTime/Foxel.git
synced 2026-05-12 11:32:56 +08:00
94 lines
3.2 KiB
C#
94 lines
3.2 KiB
C#
using Foxel.Models;
|
||
using Foxel.Models.DataBase;
|
||
using Foxel.Models.Response.Picture;
|
||
|
||
namespace Foxel.Services.Media;
|
||
|
||
public interface IPictureService
|
||
{
|
||
Task<PaginatedResult<PictureResponse>> GetPicturesAsync(
|
||
int page = 1,
|
||
int pageSize = 8,
|
||
string? searchQuery = null,
|
||
List<string>? tags = null,
|
||
DateTime? startDate = null,
|
||
DateTime? endDate = null,
|
||
int? userId = null,
|
||
string? sortBy = "newest",
|
||
bool? onlyWithGps = false,
|
||
bool useVectorSearch = false,
|
||
double similarityThreshold = 0.36,
|
||
int? excludeAlbumId = null,
|
||
int? albumId = null,
|
||
bool onlyFavorites = false,
|
||
int? ownerId = null,
|
||
bool includeAllPublic = false
|
||
);
|
||
|
||
Task<(PictureResponse Picture, int Id)> UploadPictureAsync(
|
||
string fileName,
|
||
Stream fileStream,
|
||
string contentType,
|
||
int? userId,
|
||
PermissionType permission = PermissionType.Public,
|
||
int? albumId = null,
|
||
int? storageModeId = null
|
||
);
|
||
|
||
Task<ExifInfo> GetPictureExifInfoAsync(int pictureId);
|
||
|
||
/// <summary>
|
||
/// 批量删除多张图片
|
||
/// </summary>
|
||
/// <param name="pictureIds">要删除的图片ID列表</param>
|
||
/// <returns>每个图片ID对应的删除结果、可能的错误信息和所有者ID</returns>
|
||
Task<Dictionary<int, (bool Success, string? ErrorMessage, int? UserId)>> DeleteMultiplePicturesAsync(
|
||
List<int> pictureIds);
|
||
|
||
/// <summary>
|
||
/// 更新图片信息
|
||
/// </summary>
|
||
/// <param name="pictureId">图片ID</param>
|
||
/// <param name="name">新标题(可选)</param>
|
||
/// <param name="description">新描述(可选)</param>
|
||
/// <param name="tags">新标签(可选)</param>
|
||
/// <param name="permission">权限</param>
|
||
/// <returns>更新后的图片视图模型和所有者ID</returns>
|
||
Task<(PictureResponse Picture, int? UserId)> UpdatePictureAsync(
|
||
int pictureId,
|
||
string? name = null,
|
||
string? description = null,
|
||
List<string>? tags = null,
|
||
PermissionType? permission = null);
|
||
|
||
/// <summary>
|
||
/// 收藏图片
|
||
/// </summary>
|
||
/// <param name="pictureId">图片ID</param>
|
||
/// <param name="userId">用户ID</param>
|
||
/// <returns>成功/失败</returns>
|
||
Task<bool> FavoritePictureAsync(int pictureId, int userId);
|
||
|
||
/// <summary>
|
||
/// 取消收藏图片
|
||
/// </summary>
|
||
/// <param name="pictureId">图片ID</param>
|
||
/// <param name="userId">用户ID</param>
|
||
/// <returns>成功/失败</returns>
|
||
Task<bool> UnfavoritePictureAsync(int pictureId, int userId);
|
||
|
||
/// <summary>
|
||
/// 检查图片是否被特定用户收藏
|
||
/// </summary>
|
||
/// <param name="pictureId">图片ID</param>
|
||
/// <param name="userId">用户ID</param>
|
||
/// <returns>是否收藏</returns>
|
||
Task<bool> IsPictureFavoritedByUserAsync(int pictureId, int userId);
|
||
|
||
/// <summary>
|
||
/// 根据ID获取图片详情
|
||
/// </summary>
|
||
/// <param name="pictureId">图片ID</param>
|
||
/// <returns>图片响应对象,如果未找到则返回null</returns>
|
||
Task<Picture?> GetPictureByIdAsync(int pictureId);
|
||
} |