Set TypeScript to strict mode and fix issues related to server types (#261)

* Fix lint issues and some other TS issues

- set TypeScript in strict mode
- add npm commands to lint / check code
- fix all lint issues
- fix some TS issues
- rename User reponse DTO to make it consistent with the other ones
- override Express/User interface to use UserResponseDto interface
 This is for when the accessing the `user` from a Express Request,
 like in `asset-upload-config`

* Fix the rest of TS issues

- fix all the remaining TypeScript errors
- add missing `@types/mapbox__mapbox-sdk` package

* Move global.d.ts to server `src` folder

* Update AssetReponseDto duration type

This is now of type `string` that defaults to '0:00:00.00000' if not set
which is what the mobile app currently expects

* Set context when logging error in asset.service

Use `ServeFile` as the context for logging an error when
asset.resizePath is not set

* Fix wrong AppController merge conflict resolution

`redirectToWebpage` was removed in main as is no longer used.
This commit is contained in:
Jaime Baez 2022-06-25 19:53:06 +02:00 committed by GitHub
parent cca2f7d178
commit c918f5b001
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
64 changed files with 415 additions and 273 deletions

View file

@ -7,70 +7,70 @@ import { AssetEntity } from './asset.entity';
@Entity('exif')
export class ExifEntity {
@PrimaryGeneratedColumn()
id: string;
id!: string;
@Index({ unique: true })
@Column({ type: 'uuid' })
assetId: string;
assetId!: string;
@Column({ nullable: true })
make: string;
@Column({ type: 'varchar', nullable: true })
make!: string | null;
@Column({ nullable: true })
model: string;
@Column({ type: 'varchar', nullable: true })
model!: string | null;
@Column({ nullable: true })
imageName: string;
@Column({ type: 'varchar', nullable: true })
imageName!: string | null;
@Column({ nullable: true })
exifImageWidth: number;
@Column({ type: 'integer', nullable: true })
exifImageWidth!: number | null;
@Column({ nullable: true })
exifImageHeight: number;
@Column({ type: 'integer', nullable: true })
exifImageHeight!: number | null;
@Column({ nullable: true })
fileSizeInByte: number;
@Column({ type: 'integer', nullable: true })
fileSizeInByte!: number | null;
@Column({ nullable: true })
orientation: string;
@Column({ type: 'varchar', nullable: true })
orientation!: string | null;
@Column({ type: 'timestamptz', nullable: true })
dateTimeOriginal: Date;
dateTimeOriginal!: Date | null;
@Column({ type: 'timestamptz', nullable: true })
modifyDate: Date;
modifyDate!: Date | null;
@Column({ nullable: true })
lensModel: string;
@Column({ type: 'varchar', nullable: true })
lensModel!: string | null;
@Column({ type: 'float8', nullable: true })
fNumber: number;
fNumber!: number | null;
@Column({ type: 'float8', nullable: true })
focalLength: number;
focalLength!: number | null;
@Column({ nullable: true })
iso: number;
@Column({ type: 'integer', nullable: true })
iso!: number | null;
@Column({ type: 'float', nullable: true })
exposureTime: number;
exposureTime!: number | null;
@Column({ type: 'float', nullable: true })
latitude: number;
latitude!: number | null;
@Column({ type: 'float', nullable: true })
longitude: number;
longitude!: number | null;
@Column({ nullable: true })
city: string;
@Column({ type: 'varchar', nullable: true })
city!: string | null;
@Column({ nullable: true })
state: string;
@Column({ type: 'varchar', nullable: true })
state!: string | null;
@Column({ nullable: true })
country: string;
@Column({ type: 'varchar', nullable: true })
country!: string | null;
@OneToOne(() => AssetEntity, { onDelete: 'CASCADE', nullable: true })
@JoinColumn({ name: 'assetId', referencedColumnName: 'id' })
asset: ExifEntity;
asset?: ExifEntity;
}