2024-04-02 16:23:17 +02:00
|
|
|
import { Injectable } from '@nestjs/common';
|
|
|
|
import { InjectDataSource, InjectRepository } from '@nestjs/typeorm';
|
|
|
|
import { Chunked, ChunkedSet, DummyValue, GenerateSql } from 'src/decorators';
|
|
|
|
import { MemoryEntity } from 'src/entities/memory.entity';
|
|
|
|
import { IMemoryRepository } from 'src/interfaces/memory.interface';
|
|
|
|
import { DataSource, In, Repository } from 'typeorm';
|
|
|
|
|
|
|
|
@Injectable()
|
|
|
|
export class MemoryRepository implements IMemoryRepository {
|
|
|
|
constructor(
|
|
|
|
@InjectRepository(MemoryEntity) private repository: Repository<MemoryEntity>,
|
|
|
|
@InjectDataSource() private dataSource: DataSource,
|
|
|
|
) {}
|
|
|
|
|
|
|
|
search(ownerId: string): Promise<MemoryEntity[]> {
|
|
|
|
return this.repository.find({
|
|
|
|
where: {
|
|
|
|
ownerId,
|
|
|
|
},
|
|
|
|
order: {
|
|
|
|
memoryAt: 'DESC',
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
get(id: string): Promise<MemoryEntity | null> {
|
|
|
|
return this.repository.findOne({
|
|
|
|
where: {
|
|
|
|
id,
|
|
|
|
},
|
|
|
|
relations: {
|
|
|
|
assets: true,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
create(memory: Partial<MemoryEntity>): Promise<MemoryEntity> {
|
|
|
|
return this.save(memory);
|
|
|
|
}
|
|
|
|
|
|
|
|
update(memory: Partial<MemoryEntity>): Promise<MemoryEntity> {
|
|
|
|
return this.save(memory);
|
|
|
|
}
|
|
|
|
|
|
|
|
async delete(id: string): Promise<void> {
|
|
|
|
await this.repository.delete({ id });
|
|
|
|
}
|
|
|
|
|
|
|
|
@GenerateSql({ params: [DummyValue.UUID, [DummyValue.UUID]] })
|
|
|
|
@ChunkedSet({ paramIndex: 1 })
|
|
|
|
async getAssetIds(id: string, assetIds: string[]): Promise<Set<string>> {
|
|
|
|
if (assetIds.length === 0) {
|
|
|
|
return new Set();
|
|
|
|
}
|
|
|
|
|
|
|
|
const results = await this.dataSource
|
|
|
|
.createQueryBuilder()
|
|
|
|
.select('memories_assets.assetsId', 'assetId')
|
|
|
|
.from('memories_assets_assets', 'memories_assets')
|
|
|
|
.where('"memories_assets"."memoriesId" = :memoryId', { memoryId: id })
|
|
|
|
.andWhere('memories_assets.assetsId IN (:...assetIds)', { assetIds })
|
2024-07-05 20:58:34 +02:00
|
|
|
.getRawMany<{ assetId: string }>();
|
2024-04-02 16:23:17 +02:00
|
|
|
|
2024-07-05 20:58:34 +02:00
|
|
|
return new Set(results.map(({ assetId }) => assetId));
|
2024-04-02 16:23:17 +02:00
|
|
|
}
|
|
|
|
|
2024-05-25 12:15:07 +02:00
|
|
|
@GenerateSql({ params: [DummyValue.UUID, [DummyValue.UUID]] })
|
2024-04-02 16:23:17 +02:00
|
|
|
async addAssetIds(id: string, assetIds: string[]): Promise<void> {
|
|
|
|
await this.dataSource
|
|
|
|
.createQueryBuilder()
|
|
|
|
.insert()
|
|
|
|
.into('memories_assets_assets', ['memoriesId', 'assetsId'])
|
|
|
|
.values(assetIds.map((assetId) => ({ memoriesId: id, assetsId: assetId })))
|
|
|
|
.execute();
|
|
|
|
}
|
|
|
|
|
|
|
|
@GenerateSql({ params: [DummyValue.UUID, [DummyValue.UUID]] })
|
|
|
|
@Chunked({ paramIndex: 1 })
|
|
|
|
async removeAssetIds(id: string, assetIds: string[]): Promise<void> {
|
|
|
|
await this.dataSource
|
|
|
|
.createQueryBuilder()
|
|
|
|
.delete()
|
|
|
|
.from('memories_assets_assets')
|
|
|
|
.where({
|
|
|
|
memoriesId: id,
|
|
|
|
assetsId: In(assetIds),
|
|
|
|
})
|
|
|
|
.execute();
|
|
|
|
}
|
|
|
|
|
|
|
|
private async save(memory: Partial<MemoryEntity>): Promise<MemoryEntity> {
|
|
|
|
const { id } = await this.repository.save(memory);
|
|
|
|
return this.repository.findOneOrFail({
|
|
|
|
where: { id },
|
|
|
|
relations: {
|
|
|
|
assets: true,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|