mirror of
https://github.com/KevinMidboe/immich.git
synced 2026-01-10 19:26:02 +00:00
* refactor(server): delete assets endpoint * fix: formatting * chore: cleanup * chore: open api * chore(mobile): replace DeleteAssetDTO with BulkIdsDTOs * feat: trash an asset * chore(server): formatting * chore: open api * chore: wording * chore: open-api * feat(server): add withDeleted to getAssets queries * WIP: mobile-recycle-bin * feat(server): recycle-bin to system config * feat(web): use recycle-bin system config * chore(server): domain assetcore removed * chore(server): rename recycle-bin to trash * chore(web): rename recycle-bin to trash * chore(server): always send soft deleted assets for getAllByUserId * chore(web): formatting * feat(server): permanent delete assets older than trashed period * feat(web): trash empty placeholder image * feat(server): empty trash * feat(web): empty trash * WIP: mobile-recycle-bin * refactor(server): empty / restore trash to separate endpoint * test(server): handle failures * test(server): fix e2e server-info test * test(server): deletion test refactor * feat(mobile): use map settings from server-config to enable / disable map * feat(mobile): trash asset * fix(server): operations on assets in trash * feat(web): show trash statistics * fix(web): handle trash enabled * fix(mobile): restore updates from trash * fix(server): ignore trashed assets for person * fix(server): add / remove search index when trashed / restored * chore(web): format * fix(server): asset service test * fix(server): include trashed assts for duplicates from uploads * feat(mobile): no dialog for trash, always dialog for permanent delete * refactor(mobile): use isar where instead of dart filter * refactor(mobile): asset provide - handle deletes in single db txn * chore(mobile): review changes * feat(web): confirmation before empty trash * server: review changes * fix(server): handle library changes * fix: filter external assets from getting trashed / deleted * fix(server): empty-bin * feat: broadcast config update events through ws * change order of trash button on mobile * styling * fix(mobile): do not show trashed toast for local only assets --------- Co-authored-by: Jason Rasmussen <jrasm91@gmail.com> Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
193 lines
4.8 KiB
TypeScript
193 lines
4.8 KiB
TypeScript
import { IAccessRepository } from '@app/domain';
|
|
import { InjectRepository } from '@nestjs/typeorm';
|
|
import { Repository } from 'typeorm';
|
|
import { AlbumEntity, AssetEntity, LibraryEntity, PartnerEntity, PersonEntity, SharedLinkEntity } from '../entities';
|
|
|
|
export class AccessRepository implements IAccessRepository {
|
|
constructor(
|
|
@InjectRepository(AssetEntity) private assetRepository: Repository<AssetEntity>,
|
|
@InjectRepository(AlbumEntity) private albumRepository: Repository<AlbumEntity>,
|
|
@InjectRepository(PartnerEntity) private partnerRepository: Repository<PartnerEntity>,
|
|
@InjectRepository(PersonEntity) private personRepository: Repository<PersonEntity>,
|
|
@InjectRepository(SharedLinkEntity) private sharedLinkRepository: Repository<SharedLinkEntity>,
|
|
@InjectRepository(LibraryEntity) private libraryRepository: Repository<LibraryEntity>,
|
|
) {}
|
|
|
|
library = {
|
|
hasOwnerAccess: (userId: string, libraryId: string): Promise<boolean> => {
|
|
return this.libraryRepository.exist({
|
|
where: {
|
|
id: libraryId,
|
|
ownerId: userId,
|
|
},
|
|
});
|
|
},
|
|
hasPartnerAccess: (userId: string, partnerId: string): Promise<boolean> => {
|
|
return this.partnerRepository.exist({
|
|
where: {
|
|
sharedWithId: userId,
|
|
sharedById: partnerId,
|
|
},
|
|
});
|
|
},
|
|
};
|
|
|
|
timeline = {
|
|
hasPartnerAccess: (userId: string, partnerId: string): Promise<boolean> => {
|
|
return this.partnerRepository.exist({
|
|
where: {
|
|
sharedWithId: userId,
|
|
sharedById: partnerId,
|
|
},
|
|
});
|
|
},
|
|
};
|
|
|
|
asset = {
|
|
hasAlbumAccess: (userId: string, assetId: string): Promise<boolean> => {
|
|
return this.albumRepository.exist({
|
|
where: [
|
|
{
|
|
ownerId: userId,
|
|
assets: {
|
|
id: assetId,
|
|
},
|
|
},
|
|
{
|
|
sharedUsers: {
|
|
id: userId,
|
|
},
|
|
assets: {
|
|
id: assetId,
|
|
},
|
|
},
|
|
// still part of a live photo is in an album
|
|
{
|
|
ownerId: userId,
|
|
assets: {
|
|
livePhotoVideoId: assetId,
|
|
},
|
|
},
|
|
{
|
|
sharedUsers: {
|
|
id: userId,
|
|
},
|
|
assets: {
|
|
livePhotoVideoId: assetId,
|
|
},
|
|
},
|
|
],
|
|
});
|
|
},
|
|
|
|
hasOwnerAccess: (userId: string, assetId: string): Promise<boolean> => {
|
|
return this.assetRepository.exist({
|
|
where: {
|
|
id: assetId,
|
|
ownerId: userId,
|
|
},
|
|
withDeleted: true,
|
|
});
|
|
},
|
|
|
|
hasPartnerAccess: (userId: string, assetId: string): Promise<boolean> => {
|
|
return this.partnerRepository.exist({
|
|
where: {
|
|
sharedWith: {
|
|
id: userId,
|
|
},
|
|
sharedBy: {
|
|
assets: {
|
|
id: assetId,
|
|
},
|
|
},
|
|
},
|
|
relations: {
|
|
sharedWith: true,
|
|
sharedBy: {
|
|
assets: true,
|
|
},
|
|
},
|
|
});
|
|
},
|
|
|
|
hasSharedLinkAccess: async (sharedLinkId: string, assetId: string): Promise<boolean> => {
|
|
return this.sharedLinkRepository.exist({
|
|
where: [
|
|
{
|
|
id: sharedLinkId,
|
|
album: {
|
|
assets: {
|
|
id: assetId,
|
|
},
|
|
},
|
|
},
|
|
{
|
|
id: sharedLinkId,
|
|
assets: {
|
|
id: assetId,
|
|
},
|
|
},
|
|
// still part of a live photo is in a shared link
|
|
{
|
|
id: sharedLinkId,
|
|
album: {
|
|
assets: {
|
|
livePhotoVideoId: assetId,
|
|
},
|
|
},
|
|
},
|
|
{
|
|
id: sharedLinkId,
|
|
assets: {
|
|
livePhotoVideoId: assetId,
|
|
},
|
|
},
|
|
],
|
|
});
|
|
},
|
|
};
|
|
|
|
album = {
|
|
hasOwnerAccess: (userId: string, albumId: string): Promise<boolean> => {
|
|
return this.albumRepository.exist({
|
|
where: {
|
|
id: albumId,
|
|
ownerId: userId,
|
|
},
|
|
});
|
|
},
|
|
|
|
hasSharedAlbumAccess: (userId: string, albumId: string): Promise<boolean> => {
|
|
return this.albumRepository.exist({
|
|
where: {
|
|
id: albumId,
|
|
sharedUsers: {
|
|
id: userId,
|
|
},
|
|
},
|
|
});
|
|
},
|
|
|
|
hasSharedLinkAccess: (sharedLinkId: string, albumId: string): Promise<boolean> => {
|
|
return this.sharedLinkRepository.exist({
|
|
where: {
|
|
id: sharedLinkId,
|
|
albumId,
|
|
},
|
|
});
|
|
},
|
|
};
|
|
|
|
person = {
|
|
hasOwnerAccess: (userId: string, personId: string): Promise<boolean> => {
|
|
return this.personRepository.exist({
|
|
where: {
|
|
id: personId,
|
|
ownerId: userId,
|
|
},
|
|
});
|
|
},
|
|
};
|
|
}
|