change to monorepo

This commit is contained in:
rubikscraft
2022-02-21 23:26:40 +01:00
parent eee3ce9e9f
commit 9bb2274366
37 changed files with 399 additions and 398 deletions

View File

@@ -0,0 +1,10 @@
import { Module } from '@nestjs/common';
import { ImageDBModule } from 'src/collections/imagedb/imagedb.module';
import { ImageManagerService } from './imagemanager.service';
@Module({
imports: [ImageDBModule],
providers: [ImageManagerService],
exports: [ImageManagerService],
})
export class ImageManagerModule {}

View File

@@ -0,0 +1,46 @@
import { Injectable } from '@nestjs/common';
import { fileTypeFromBuffer, FileTypeResult } from 'file-type';
import { ImageEntity } from 'src/collections/imagedb/image.entity';
import { ImageDBService } from 'src/collections/imagedb/imagedb.service';
import { FullMime, MimesService } from 'src/collections/imagedb/mimes.service';
import { AsyncFailable, Fail, HasFailed } from 'src/types/failable';
@Injectable()
export class ImageManagerService {
constructor(
private readonly imagesService: ImageDBService,
private readonly mimesService: MimesService,
) {}
async uploadImage(image: Buffer): AsyncFailable<string> {
const mime: FileTypeResult = await fileTypeFromBuffer(image);
const fullMime = await this.mimesService.getFullMime(
mime?.mime ?? 'extra/discard',
);
if (HasFailed(fullMime)) return fullMime;
const processedImage: Buffer = await this.processImage(image, fullMime);
const imageEntity = await this.imagesService.create(
processedImage,
fullMime.mime,
);
if (HasFailed(imageEntity)) return imageEntity;
return imageEntity.hash;
}
private async processImage(image: Buffer, mime: FullMime): Promise<Buffer> {
return image;
}
async retrieveImage(hash: string): AsyncFailable<ImageEntity> {
if (!this.validateHash(hash)) return Fail('Invalid hash');
return await this.imagesService.findOne(hash);
}
validateHash(hash: string): boolean {
return /^[a-f0-9]{64}$/.test(hash);
}
}