mirror of
https://github.com/immich-app/immich.git
synced 2025-12-25 17:24:58 +03:00
* feat: add OCR functionality and related configurations * chore: update labeler configuration for machine learning files * feat(i18n): enhance OCR model descriptions and add orientation classification and unwarping features * chore: update Dockerfile to include ccache for improved build performance * feat(ocr): enhance OCR model configuration with orientation classification and unwarping options, update PaddleOCR integration, and improve response structure * refactor(ocr): remove OCR_CLEANUP job from enum and type definitions * refactor(ocr): remove obsolete OCR entity and migration files, and update asset job status and schema to accommodate new OCR table structure * refactor(ocr): update OCR schema and response structure to use individual coordinates instead of bounding box, and adjust related service and repository files * feat: enhance OCR configuration and functionality - Updated OCR settings to include minimum detection box score, minimum detection score, and minimum recognition score. - Refactored PaddleOCRecognizer to utilize new scoring parameters. - Introduced new database tables for asset OCR data and search functionality. - Modified related services and repositories to support the new OCR features. - Updated translations for improved clarity in settings UI. * sql changes * use rapidocr * change dto * update web * update lock * update api * store positions as normalized floats * match column order in db * update admin ui settings descriptions fix max resolution key set min threshold to 0.1 fix bind * apply config correctly, adjust defaults * unnecessary model type * unnecessary sources * fix(ocr): switch RapidOCR lang type from LangDet to LangRec * fix(ocr): expose lang_type (LangRec.CH) and font_path on OcrOptions for RapidOCR * fix(ocr): make OCR text search case- and accent-insensitive using ILIKE + unaccent * fix(ocr): add OCR search fields * fix: Add OCR database migration and update ML prediction logic. * trigrams are already case insensitive * add tests * format * update migrations * wrong uuid function * linting * maybe fix medium tests * formatting * fix weblate check * openapi * sql * minor fixes * maybe fix medium tests part 2 * passing medium tests * format web * readd sql * format dart * disabled in e2e * chore: translation ordering --------- Co-authored-by: mertalev <101130780+mertalev@users.noreply.github.com> Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
184 lines
4.1 KiB
TypeScript
184 lines
4.1 KiB
TypeScript
import { ApiProperty, ApiResponseProperty } from '@nestjs/swagger';
|
|
import { SemVer } from 'semver';
|
|
import { SystemConfigThemeDto } from 'src/dtos/system-config.dto';
|
|
|
|
export class ServerPingResponse {
|
|
@ApiResponseProperty({ type: String, example: 'pong' })
|
|
res!: string;
|
|
}
|
|
|
|
export class ServerAboutResponseDto {
|
|
version!: string;
|
|
versionUrl!: string;
|
|
|
|
repository?: string;
|
|
repositoryUrl?: string;
|
|
|
|
sourceRef?: string;
|
|
sourceCommit?: string;
|
|
sourceUrl?: string;
|
|
|
|
build?: string;
|
|
buildUrl?: string;
|
|
buildImage?: string;
|
|
buildImageUrl?: string;
|
|
|
|
nodejs?: string;
|
|
ffmpeg?: string;
|
|
imagemagick?: string;
|
|
libvips?: string;
|
|
exiftool?: string;
|
|
|
|
licensed!: boolean;
|
|
|
|
thirdPartySourceUrl?: string;
|
|
thirdPartyBugFeatureUrl?: string;
|
|
thirdPartyDocumentationUrl?: string;
|
|
thirdPartySupportUrl?: string;
|
|
}
|
|
|
|
export class ServerApkLinksDto {
|
|
arm64v8a!: string;
|
|
armeabiv7a!: string;
|
|
universal!: string;
|
|
x86_64!: string;
|
|
}
|
|
|
|
export class ServerStorageResponseDto {
|
|
diskSize!: string;
|
|
diskUse!: string;
|
|
diskAvailable!: string;
|
|
|
|
@ApiProperty({ type: 'integer', format: 'int64' })
|
|
diskSizeRaw!: number;
|
|
|
|
@ApiProperty({ type: 'integer', format: 'int64' })
|
|
diskUseRaw!: number;
|
|
|
|
@ApiProperty({ type: 'integer', format: 'int64' })
|
|
diskAvailableRaw!: number;
|
|
|
|
@ApiProperty({ type: 'number', format: 'double' })
|
|
diskUsagePercentage!: number;
|
|
}
|
|
|
|
export class ServerVersionResponseDto {
|
|
@ApiProperty({ type: 'integer' })
|
|
major!: number;
|
|
@ApiProperty({ type: 'integer' })
|
|
minor!: number;
|
|
@ApiProperty({ type: 'integer' })
|
|
patch!: number;
|
|
|
|
static fromSemVer(value: SemVer) {
|
|
return { major: value.major, minor: value.minor, patch: value.patch };
|
|
}
|
|
}
|
|
|
|
export class ServerVersionHistoryResponseDto {
|
|
id!: string;
|
|
createdAt!: Date;
|
|
version!: string;
|
|
}
|
|
|
|
export class UsageByUserDto {
|
|
@ApiProperty({ type: 'string' })
|
|
userId!: string;
|
|
@ApiProperty({ type: 'string' })
|
|
userName!: string;
|
|
@ApiProperty({ type: 'integer' })
|
|
photos!: number;
|
|
@ApiProperty({ type: 'integer' })
|
|
videos!: number;
|
|
@ApiProperty({ type: 'integer', format: 'int64' })
|
|
usage!: number;
|
|
@ApiProperty({ type: 'integer', format: 'int64' })
|
|
usagePhotos!: number;
|
|
@ApiProperty({ type: 'integer', format: 'int64' })
|
|
usageVideos!: number;
|
|
@ApiProperty({ type: 'integer', format: 'int64' })
|
|
quotaSizeInBytes!: number | null;
|
|
}
|
|
|
|
export class ServerStatsResponseDto {
|
|
@ApiProperty({ type: 'integer' })
|
|
photos = 0;
|
|
|
|
@ApiProperty({ type: 'integer' })
|
|
videos = 0;
|
|
|
|
@ApiProperty({ type: 'integer', format: 'int64' })
|
|
usage = 0;
|
|
|
|
@ApiProperty({ type: 'integer', format: 'int64' })
|
|
usagePhotos = 0;
|
|
|
|
@ApiProperty({ type: 'integer', format: 'int64' })
|
|
usageVideos = 0;
|
|
|
|
@ApiProperty({
|
|
isArray: true,
|
|
type: UsageByUserDto,
|
|
title: 'Array of usage for each user',
|
|
example: [
|
|
{
|
|
photos: 1,
|
|
videos: 1,
|
|
diskUsageRaw: 2,
|
|
usagePhotos: 1,
|
|
usageVideos: 1,
|
|
},
|
|
],
|
|
})
|
|
usageByUser: UsageByUserDto[] = [];
|
|
}
|
|
|
|
export class ServerMediaTypesResponseDto {
|
|
video!: string[];
|
|
image!: string[];
|
|
sidecar!: string[];
|
|
}
|
|
|
|
export class ServerThemeDto extends SystemConfigThemeDto {}
|
|
|
|
export class ServerConfigDto {
|
|
oauthButtonText!: string;
|
|
loginPageMessage!: string;
|
|
@ApiProperty({ type: 'integer' })
|
|
trashDays!: number;
|
|
@ApiProperty({ type: 'integer' })
|
|
userDeleteDelay!: number;
|
|
isInitialized!: boolean;
|
|
isOnboarded!: boolean;
|
|
externalDomain!: string;
|
|
publicUsers!: boolean;
|
|
mapDarkStyleUrl!: string;
|
|
mapLightStyleUrl!: string;
|
|
}
|
|
|
|
export class ServerFeaturesDto {
|
|
smartSearch!: boolean;
|
|
duplicateDetection!: boolean;
|
|
configFile!: boolean;
|
|
facialRecognition!: boolean;
|
|
map!: boolean;
|
|
trash!: boolean;
|
|
reverseGeocoding!: boolean;
|
|
importFaces!: boolean;
|
|
oauth!: boolean;
|
|
oauthAutoLaunch!: boolean;
|
|
passwordLogin!: boolean;
|
|
sidecar!: boolean;
|
|
search!: boolean;
|
|
email!: boolean;
|
|
ocr!: boolean;
|
|
}
|
|
|
|
export interface ReleaseNotification {
|
|
isAvailable: boolean;
|
|
/** ISO8601 */
|
|
checkedAt: string;
|
|
serverVersion: ServerVersionResponseDto;
|
|
releaseVersion: ServerVersionResponseDto;
|
|
}
|