2023-03-24 05:55:15 +01:00
|
|
|
import { BadRequestException } from '@nestjs/common';
|
2023-06-08 17:01:07 +02:00
|
|
|
import pkg from 'src/../../package.json';
|
2023-01-24 04:46:37 +01:00
|
|
|
|
|
|
|
const [major, minor, patch] = pkg.version.split('.');
|
2022-03-22 07:22:04 +01:00
|
|
|
|
2022-07-09 04:26:50 +02:00
|
|
|
export interface IServerVersion {
|
|
|
|
major: number;
|
|
|
|
minor: number;
|
|
|
|
patch: number;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const serverVersion: IServerVersion = {
|
2023-01-24 04:46:37 +01:00
|
|
|
major: Number(major),
|
|
|
|
minor: Number(minor),
|
|
|
|
patch: Number(patch),
|
2022-03-22 07:22:04 +01:00
|
|
|
};
|
2022-12-08 16:53:18 +01:00
|
|
|
|
|
|
|
export const SERVER_VERSION = `${serverVersion.major}.${serverVersion.minor}.${serverVersion.patch}`;
|
2023-03-22 03:49:19 +01:00
|
|
|
|
2023-03-25 15:50:57 +01:00
|
|
|
export const APP_MEDIA_LOCATION = process.env.IMMICH_MEDIA_LOCATION || './upload';
|
2023-03-24 05:55:15 +01:00
|
|
|
|
|
|
|
export const MACHINE_LEARNING_URL = process.env.IMMICH_MACHINE_LEARNING_URL || 'http://immich-machine-learning:3003';
|
|
|
|
export const MACHINE_LEARNING_ENABLED = MACHINE_LEARNING_URL !== 'false';
|
|
|
|
|
|
|
|
export function assertMachineLearningEnabled() {
|
|
|
|
if (!MACHINE_LEARNING_ENABLED) {
|
|
|
|
throw new BadRequestException('Machine learning is not enabled.');
|
|
|
|
}
|
|
|
|
}
|
feat(server): support for read-only assets and importing existing items in the filesystem (#2715)
* Added read-only flag for assets, endpoint to trigger file import vs upload
* updated fixtures with new property
* if upload is 'read-only', ensure there is no existing asset at the designated originalPath
* added test for file import as well as detecting existing image at read-only destination location
* Added storage service test for a case where it should not move read-only assets
* upload doesn't need the read-only flag available, just importing
* default isReadOnly on import endpoint to true
* formatting fixes
* create-asset dto needs isReadOnly, so set it to false by default on create, updated api generation
* updated code to reflect changes in MR
* fixed read stream promise return type
* new index for originalPath, check for existing path on import, reglardless of user, to prevent duplicates
* refactor: import asset
* chore: open api
* chore: tests
* Added externalPath support for individual users, updated UI to allow this to be set by admin
* added missing var for externalPath in ui
* chore: open api
* fix: compilation issues
* fix: server test
* built api, fixed user-response dto to include externalPath
* reverted accidental commit
* bad commit of duplicate externalPath in user response dto
* fixed tests to include externalPath on expected result
* fix: unit tests
* centralized supported filetypes, perform file type checking of asset and sidecar during file import process
* centralized supported filetype check method to keep regex DRY
* fixed typo
* combined migrations into one
* update api
* Removed externalPath from shared-link code, added column to admin user page whether external paths / import is enabled or not
* update mimetype
* Fixed detect correct mimetype
* revert asset-upload config
* reverted domain.constant
* refactor
* fix mime-type issue
* fix format
---------
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
2023-06-22 04:33:20 +02:00
|
|
|
|
|
|
|
const validMimeTypes = [
|
|
|
|
'image/avif',
|
2023-06-23 18:12:11 +02:00
|
|
|
'image/cr3',
|
feat(server): support for read-only assets and importing existing items in the filesystem (#2715)
* Added read-only flag for assets, endpoint to trigger file import vs upload
* updated fixtures with new property
* if upload is 'read-only', ensure there is no existing asset at the designated originalPath
* added test for file import as well as detecting existing image at read-only destination location
* Added storage service test for a case where it should not move read-only assets
* upload doesn't need the read-only flag available, just importing
* default isReadOnly on import endpoint to true
* formatting fixes
* create-asset dto needs isReadOnly, so set it to false by default on create, updated api generation
* updated code to reflect changes in MR
* fixed read stream promise return type
* new index for originalPath, check for existing path on import, reglardless of user, to prevent duplicates
* refactor: import asset
* chore: open api
* chore: tests
* Added externalPath support for individual users, updated UI to allow this to be set by admin
* added missing var for externalPath in ui
* chore: open api
* fix: compilation issues
* fix: server test
* built api, fixed user-response dto to include externalPath
* reverted accidental commit
* bad commit of duplicate externalPath in user response dto
* fixed tests to include externalPath on expected result
* fix: unit tests
* centralized supported filetypes, perform file type checking of asset and sidecar during file import process
* centralized supported filetype check method to keep regex DRY
* fixed typo
* combined migrations into one
* update api
* Removed externalPath from shared-link code, added column to admin user page whether external paths / import is enabled or not
* update mimetype
* Fixed detect correct mimetype
* revert asset-upload config
* reverted domain.constant
* refactor
* fix mime-type issue
* fix format
---------
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
2023-06-22 04:33:20 +02:00
|
|
|
'image/gif',
|
|
|
|
'image/heic',
|
|
|
|
'image/heif',
|
|
|
|
'image/jpeg',
|
|
|
|
'image/jxl',
|
|
|
|
'image/png',
|
2023-06-25 04:50:01 +02:00
|
|
|
'image/dng',
|
feat(server): support for read-only assets and importing existing items in the filesystem (#2715)
* Added read-only flag for assets, endpoint to trigger file import vs upload
* updated fixtures with new property
* if upload is 'read-only', ensure there is no existing asset at the designated originalPath
* added test for file import as well as detecting existing image at read-only destination location
* Added storage service test for a case where it should not move read-only assets
* upload doesn't need the read-only flag available, just importing
* default isReadOnly on import endpoint to true
* formatting fixes
* create-asset dto needs isReadOnly, so set it to false by default on create, updated api generation
* updated code to reflect changes in MR
* fixed read stream promise return type
* new index for originalPath, check for existing path on import, reglardless of user, to prevent duplicates
* refactor: import asset
* chore: open api
* chore: tests
* Added externalPath support for individual users, updated UI to allow this to be set by admin
* added missing var for externalPath in ui
* chore: open api
* fix: compilation issues
* fix: server test
* built api, fixed user-response dto to include externalPath
* reverted accidental commit
* bad commit of duplicate externalPath in user response dto
* fixed tests to include externalPath on expected result
* fix: unit tests
* centralized supported filetypes, perform file type checking of asset and sidecar during file import process
* centralized supported filetype check method to keep regex DRY
* fixed typo
* combined migrations into one
* update api
* Removed externalPath from shared-link code, added column to admin user page whether external paths / import is enabled or not
* update mimetype
* Fixed detect correct mimetype
* revert asset-upload config
* reverted domain.constant
* refactor
* fix mime-type issue
* fix format
---------
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
2023-06-22 04:33:20 +02:00
|
|
|
'image/tiff',
|
|
|
|
'image/webp',
|
|
|
|
'image/x-adobe-dng',
|
|
|
|
'image/x-arriflex-ari',
|
|
|
|
'image/x-canon-cr2',
|
|
|
|
'image/x-canon-cr3',
|
|
|
|
'image/x-canon-crw',
|
|
|
|
'image/x-epson-erf',
|
|
|
|
'image/x-fuji-raf',
|
|
|
|
'image/x-hasselblad-3fr',
|
|
|
|
'image/x-hasselblad-fff',
|
|
|
|
'image/x-kodak-dcr',
|
|
|
|
'image/x-kodak-k25',
|
|
|
|
'image/x-kodak-kdc',
|
|
|
|
'image/x-leica-rwl',
|
|
|
|
'image/x-minolta-mrw',
|
|
|
|
'image/x-nikon-nef',
|
|
|
|
'image/x-olympus-orf',
|
|
|
|
'image/x-olympus-ori',
|
|
|
|
'image/x-panasonic-raw',
|
|
|
|
'image/x-pentax-pef',
|
|
|
|
'image/x-phantom-cin',
|
|
|
|
'image/x-phaseone-cap',
|
|
|
|
'image/x-phaseone-iiq',
|
|
|
|
'image/x-samsung-srw',
|
|
|
|
'image/x-sigma-x3f',
|
|
|
|
'image/x-sony-arw',
|
|
|
|
'image/x-sony-sr2',
|
|
|
|
'image/x-sony-srf',
|
2023-06-25 20:10:39 +02:00
|
|
|
'image/dng',
|
|
|
|
'image/ari',
|
|
|
|
'image/cr2',
|
|
|
|
'image/cr3',
|
|
|
|
'image/crw',
|
|
|
|
'image/erf',
|
|
|
|
'image/raf',
|
|
|
|
'image/3fr',
|
|
|
|
'image/fff',
|
|
|
|
'image/dcr',
|
|
|
|
'image/k25',
|
|
|
|
'image/kdc',
|
|
|
|
'image/rwl',
|
|
|
|
'image/mrw',
|
|
|
|
'image/nef',
|
|
|
|
'image/orf',
|
|
|
|
'image/ori',
|
|
|
|
'image/raw',
|
|
|
|
'image/pef',
|
|
|
|
'image/cin',
|
|
|
|
'image/cap',
|
|
|
|
'image/iiq',
|
|
|
|
'image/srw',
|
|
|
|
'image/x3f',
|
|
|
|
'image/arw',
|
|
|
|
'image/sr2',
|
|
|
|
'image/srf',
|
feat(server): support for read-only assets and importing existing items in the filesystem (#2715)
* Added read-only flag for assets, endpoint to trigger file import vs upload
* updated fixtures with new property
* if upload is 'read-only', ensure there is no existing asset at the designated originalPath
* added test for file import as well as detecting existing image at read-only destination location
* Added storage service test for a case where it should not move read-only assets
* upload doesn't need the read-only flag available, just importing
* default isReadOnly on import endpoint to true
* formatting fixes
* create-asset dto needs isReadOnly, so set it to false by default on create, updated api generation
* updated code to reflect changes in MR
* fixed read stream promise return type
* new index for originalPath, check for existing path on import, reglardless of user, to prevent duplicates
* refactor: import asset
* chore: open api
* chore: tests
* Added externalPath support for individual users, updated UI to allow this to be set by admin
* added missing var for externalPath in ui
* chore: open api
* fix: compilation issues
* fix: server test
* built api, fixed user-response dto to include externalPath
* reverted accidental commit
* bad commit of duplicate externalPath in user response dto
* fixed tests to include externalPath on expected result
* fix: unit tests
* centralized supported filetypes, perform file type checking of asset and sidecar during file import process
* centralized supported filetype check method to keep regex DRY
* fixed typo
* combined migrations into one
* update api
* Removed externalPath from shared-link code, added column to admin user page whether external paths / import is enabled or not
* update mimetype
* Fixed detect correct mimetype
* revert asset-upload config
* reverted domain.constant
* refactor
* fix mime-type issue
* fix format
---------
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
2023-06-22 04:33:20 +02:00
|
|
|
'video/3gpp',
|
|
|
|
'video/mp2t',
|
|
|
|
'video/mp4',
|
|
|
|
'video/mpeg',
|
|
|
|
'video/quicktime',
|
|
|
|
'video/webm',
|
|
|
|
'video/x-flv',
|
|
|
|
'video/x-matroska',
|
|
|
|
'video/x-ms-wmv',
|
|
|
|
'video/x-msvideo',
|
|
|
|
];
|
|
|
|
|
|
|
|
export function isSupportedFileType(mimetype: string): boolean {
|
|
|
|
return validMimeTypes.includes(mimetype);
|
|
|
|
}
|
|
|
|
|
|
|
|
export function isSidecarFileType(mimeType: string): boolean {
|
|
|
|
return ['application/xml', 'text/xml'].includes(mimeType);
|
|
|
|
}
|