2023-06-16 15:54:17 -04:00
|
|
|
import {
|
|
|
|
AlbumResponseDto,
|
|
|
|
AssetResponseDto,
|
|
|
|
AudioStreamInfo,
|
|
|
|
AuthUserDto,
|
|
|
|
ExifResponseDto,
|
|
|
|
mapUser,
|
|
|
|
QueueName,
|
|
|
|
SearchResult,
|
|
|
|
SharedLinkResponseDto,
|
|
|
|
TagResponseDto,
|
|
|
|
VideoFormat,
|
|
|
|
VideoInfo,
|
|
|
|
VideoStreamInfo,
|
|
|
|
} from '@app/domain';
|
2023-01-27 20:50:07 +00:00
|
|
|
import {
|
2023-03-02 21:47:08 -05:00
|
|
|
AlbumEntity,
|
2023-01-31 13:11:49 -05:00
|
|
|
APIKeyEntity,
|
2023-02-18 20:58:55 +00:00
|
|
|
AssetEntity,
|
2023-05-31 21:51:28 -04:00
|
|
|
AssetFaceEntity,
|
2023-01-27 20:50:07 +00:00
|
|
|
AssetType,
|
2023-05-31 21:51:28 -04:00
|
|
|
ExifEntity,
|
2023-05-15 20:30:53 +03:00
|
|
|
PartnerEntity,
|
2023-05-31 21:51:28 -04:00
|
|
|
PersonEntity,
|
2023-01-27 20:50:07 +00:00
|
|
|
SharedLinkEntity,
|
|
|
|
SharedLinkType,
|
|
|
|
SystemConfig,
|
2023-05-31 21:51:28 -04:00
|
|
|
TagEntity,
|
|
|
|
TagType,
|
2023-03-28 22:03:43 +03:00
|
|
|
TranscodePreset,
|
2023-01-27 20:50:07 +00:00
|
|
|
UserEntity,
|
|
|
|
UserTokenEntity,
|
2023-03-30 15:38:55 -04:00
|
|
|
} from '@app/infra/entities';
|
2023-01-25 11:35:28 -05:00
|
|
|
|
|
|
|
const today = new Date();
|
|
|
|
const tomorrow = new Date();
|
|
|
|
const yesterday = new Date();
|
|
|
|
tomorrow.setDate(today.getDate() + 1);
|
|
|
|
yesterday.setDate(yesterday.getDate() - 1);
|
|
|
|
|
2023-06-01 16:56:37 -04:00
|
|
|
const sharedLinkBytes = Buffer.from(
|
|
|
|
'2c2b646895f84753bff43fb696ad124f3b0faf2a0bd547406f26fa4a76b5c71990092baa536275654b2ab7a191fb21a6d6cd',
|
|
|
|
'hex',
|
|
|
|
);
|
|
|
|
|
2023-01-18 09:40:15 -05:00
|
|
|
export const authStub = {
|
|
|
|
admin: Object.freeze<AuthUserDto>({
|
|
|
|
id: 'admin_id',
|
|
|
|
email: 'admin@test.com',
|
|
|
|
isAdmin: true,
|
|
|
|
isPublicUser: false,
|
|
|
|
isAllowUpload: true,
|
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-21 22:33:20 -04:00
|
|
|
externalPath: null,
|
2023-01-18 09:40:15 -05:00
|
|
|
}),
|
|
|
|
user1: Object.freeze<AuthUserDto>({
|
2023-05-21 23:18:10 -04:00
|
|
|
id: 'user-id',
|
2023-01-18 09:40:15 -05:00
|
|
|
email: 'immich@test.com',
|
|
|
|
isAdmin: false,
|
|
|
|
isPublicUser: false,
|
|
|
|
isAllowUpload: true,
|
2023-01-27 20:50:07 +00:00
|
|
|
isAllowDownload: true,
|
|
|
|
isShowExif: true,
|
2023-02-05 23:31:16 -06:00
|
|
|
accessTokenId: 'token-id',
|
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-21 22:33:20 -04:00
|
|
|
externalPath: null,
|
2023-01-18 09:40:15 -05:00
|
|
|
}),
|
2023-06-07 10:37:25 -04:00
|
|
|
user2: Object.freeze<AuthUserDto>({
|
|
|
|
id: 'user-2',
|
|
|
|
email: 'user2@immich.app',
|
|
|
|
isAdmin: false,
|
|
|
|
isPublicUser: false,
|
|
|
|
isAllowUpload: true,
|
|
|
|
isAllowDownload: true,
|
|
|
|
isShowExif: true,
|
|
|
|
accessTokenId: 'token-id',
|
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-21 22:33:20 -04:00
|
|
|
externalPath: null,
|
|
|
|
}),
|
|
|
|
external1: Object.freeze<AuthUserDto>({
|
|
|
|
id: 'user-id',
|
|
|
|
email: 'immich@test.com',
|
|
|
|
isAdmin: false,
|
|
|
|
isPublicUser: false,
|
|
|
|
isAllowUpload: true,
|
|
|
|
isAllowDownload: true,
|
|
|
|
isShowExif: true,
|
|
|
|
accessTokenId: 'token-id',
|
|
|
|
externalPath: '/data/user1',
|
2023-06-07 10:37:25 -04:00
|
|
|
}),
|
2023-01-25 11:35:28 -05:00
|
|
|
adminSharedLink: Object.freeze<AuthUserDto>({
|
|
|
|
id: 'admin_id',
|
|
|
|
email: 'admin@test.com',
|
|
|
|
isAdmin: true,
|
|
|
|
isAllowUpload: true,
|
|
|
|
isAllowDownload: true,
|
|
|
|
isPublicUser: true,
|
|
|
|
isShowExif: true,
|
|
|
|
sharedLinkId: '123',
|
|
|
|
}),
|
2023-06-01 22:09:57 -04:00
|
|
|
adminSharedLinkNoExif: Object.freeze<AuthUserDto>({
|
|
|
|
id: 'admin_id',
|
|
|
|
email: 'admin@test.com',
|
|
|
|
isAdmin: true,
|
|
|
|
isAllowUpload: true,
|
|
|
|
isAllowDownload: true,
|
|
|
|
isPublicUser: true,
|
|
|
|
isShowExif: false,
|
|
|
|
sharedLinkId: '123',
|
|
|
|
}),
|
2023-01-25 11:35:28 -05:00
|
|
|
readonlySharedLink: Object.freeze<AuthUserDto>({
|
|
|
|
id: 'admin_id',
|
|
|
|
email: 'admin@test.com',
|
|
|
|
isAdmin: true,
|
|
|
|
isAllowUpload: false,
|
|
|
|
isAllowDownload: false,
|
|
|
|
isPublicUser: true,
|
|
|
|
isShowExif: true,
|
|
|
|
sharedLinkId: '123',
|
2023-02-05 23:31:16 -06:00
|
|
|
accessTokenId: 'token-id',
|
2023-01-25 11:35:28 -05:00
|
|
|
}),
|
2023-01-18 09:40:15 -05:00
|
|
|
};
|
|
|
|
|
2023-01-27 20:50:07 +00:00
|
|
|
export const userEntityStub = {
|
2023-01-18 09:40:15 -05:00
|
|
|
admin: Object.freeze<UserEntity>({
|
|
|
|
...authStub.admin,
|
|
|
|
password: 'admin_password',
|
|
|
|
firstName: 'admin_first_name',
|
|
|
|
lastName: 'admin_last_name',
|
2023-05-21 23:18:10 -04:00
|
|
|
storageLabel: 'admin',
|
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-21 22:33:20 -04:00
|
|
|
externalPath: null,
|
2023-01-18 09:40:15 -05:00
|
|
|
oauthId: '',
|
|
|
|
shouldChangePassword: false,
|
|
|
|
profileImagePath: '',
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: new Date('2021-01-01'),
|
|
|
|
deletedAt: null,
|
|
|
|
updatedAt: new Date('2021-01-01'),
|
2023-01-18 09:40:15 -05:00
|
|
|
tags: [],
|
2023-02-26 20:57:34 +01:00
|
|
|
assets: [],
|
2023-01-18 09:40:15 -05:00
|
|
|
}),
|
|
|
|
user1: Object.freeze<UserEntity>({
|
|
|
|
...authStub.user1,
|
|
|
|
password: 'immich_password',
|
|
|
|
firstName: 'immich_first_name',
|
|
|
|
lastName: 'immich_last_name',
|
2023-05-21 23:18:10 -04:00
|
|
|
storageLabel: null,
|
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-21 22:33:20 -04:00
|
|
|
externalPath: null,
|
2023-05-21 23:18:10 -04:00
|
|
|
oauthId: '',
|
|
|
|
shouldChangePassword: false,
|
|
|
|
profileImagePath: '',
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: new Date('2021-01-01'),
|
|
|
|
deletedAt: null,
|
|
|
|
updatedAt: new Date('2021-01-01'),
|
2023-05-21 23:18:10 -04:00
|
|
|
tags: [],
|
|
|
|
assets: [],
|
|
|
|
}),
|
2023-06-07 10:37:25 -04:00
|
|
|
user2: Object.freeze<UserEntity>({
|
|
|
|
...authStub.user2,
|
|
|
|
password: 'immich_password',
|
|
|
|
firstName: 'immich_first_name',
|
|
|
|
lastName: 'immich_last_name',
|
|
|
|
storageLabel: null,
|
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-21 22:33:20 -04:00
|
|
|
externalPath: null,
|
2023-06-07 10:37:25 -04:00
|
|
|
oauthId: '',
|
|
|
|
shouldChangePassword: false,
|
|
|
|
profileImagePath: '',
|
|
|
|
createdAt: new Date('2021-01-01'),
|
|
|
|
deletedAt: null,
|
|
|
|
updatedAt: new Date('2021-01-01'),
|
|
|
|
tags: [],
|
|
|
|
assets: [],
|
|
|
|
}),
|
2023-05-21 23:18:10 -04:00
|
|
|
storageLabel: Object.freeze<UserEntity>({
|
|
|
|
...authStub.user1,
|
|
|
|
password: 'immich_password',
|
|
|
|
firstName: 'immich_first_name',
|
|
|
|
lastName: 'immich_last_name',
|
|
|
|
storageLabel: 'label-1',
|
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-21 22:33:20 -04:00
|
|
|
externalPath: null,
|
2023-01-18 09:40:15 -05:00
|
|
|
oauthId: '',
|
|
|
|
shouldChangePassword: false,
|
|
|
|
profileImagePath: '',
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: new Date('2021-01-01'),
|
|
|
|
deletedAt: null,
|
|
|
|
updatedAt: new Date('2021-01-01'),
|
2023-01-18 09:40:15 -05:00
|
|
|
tags: [],
|
2023-02-26 20:57:34 +01:00
|
|
|
assets: [],
|
2023-01-18 09:40:15 -05:00
|
|
|
}),
|
|
|
|
};
|
2023-01-21 11:11:55 -05:00
|
|
|
|
2023-02-25 09:12:03 -05:00
|
|
|
export const fileStub = {
|
|
|
|
livePhotoStill: Object.freeze({
|
|
|
|
originalPath: 'fake_path/asset_1.jpeg',
|
|
|
|
mimeType: 'image/jpg',
|
|
|
|
checksum: Buffer.from('file hash', 'utf8'),
|
|
|
|
originalName: 'asset_1.jpeg',
|
|
|
|
}),
|
|
|
|
livePhotoMotion: Object.freeze({
|
|
|
|
originalPath: 'fake_path/asset_1.mp4',
|
|
|
|
mimeType: 'image/jpeg',
|
|
|
|
checksum: Buffer.from('live photo file hash', 'utf8'),
|
|
|
|
originalName: 'asset_1.mp4',
|
|
|
|
}),
|
|
|
|
};
|
|
|
|
|
2023-02-18 20:58:55 +00:00
|
|
|
export const assetEntityStub = {
|
2023-03-23 22:40:46 -04:00
|
|
|
noResizePath: Object.freeze<AssetEntity>({
|
2023-02-18 20:58:55 +00:00
|
|
|
id: 'asset-id',
|
2023-06-30 12:24:28 -04:00
|
|
|
originalFileName: 'IMG_123',
|
2023-02-18 20:58:55 +00:00
|
|
|
deviceAssetId: 'device-asset-id',
|
2023-05-29 16:05:14 +02:00
|
|
|
fileModifiedAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
fileCreatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
2023-02-19 16:44:53 +00:00
|
|
|
owner: userEntityStub.user1,
|
|
|
|
ownerId: 'user-id',
|
2023-02-18 20:58:55 +00:00
|
|
|
deviceId: 'device-id',
|
2023-06-30 12:24:28 -04:00
|
|
|
originalPath: 'upload/library/IMG_123.jpg',
|
2023-02-18 20:58:55 +00:00
|
|
|
resizePath: null,
|
2023-05-24 23:08:21 +02:00
|
|
|
checksum: Buffer.from('file hash', 'utf8'),
|
2023-02-18 20:58:55 +00:00
|
|
|
type: AssetType.IMAGE,
|
2023-06-17 23:22:31 -04:00
|
|
|
webpPath: '/uploads/user-id/webp/path.ext',
|
|
|
|
thumbhash: Buffer.from('blablabla', 'base64'),
|
|
|
|
encodedVideoPath: null,
|
|
|
|
createdAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
updatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
mimeType: null,
|
|
|
|
isFavorite: true,
|
|
|
|
isArchived: false,
|
|
|
|
duration: null,
|
|
|
|
isVisible: true,
|
|
|
|
livePhotoVideo: null,
|
|
|
|
livePhotoVideoId: null,
|
|
|
|
tags: [],
|
|
|
|
sharedLinks: [],
|
|
|
|
faces: [],
|
|
|
|
sidecarPath: null,
|
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-21 22:33:20 -04:00
|
|
|
isReadOnly: false,
|
2023-06-17 23:22:31 -04:00
|
|
|
}),
|
|
|
|
noWebpPath: Object.freeze<AssetEntity>({
|
|
|
|
id: 'asset-id',
|
|
|
|
deviceAssetId: 'device-asset-id',
|
|
|
|
fileModifiedAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
fileCreatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
owner: userEntityStub.user1,
|
|
|
|
ownerId: 'user-id',
|
|
|
|
deviceId: 'device-id',
|
2023-06-30 12:24:28 -04:00
|
|
|
originalPath: 'upload/library/IMG_456.jpg',
|
2023-06-17 23:22:31 -04:00
|
|
|
resizePath: '/uploads/user-id/thumbs/path.ext',
|
|
|
|
checksum: Buffer.from('file hash', 'utf8'),
|
|
|
|
type: AssetType.IMAGE,
|
2023-02-18 20:58:55 +00:00
|
|
|
webpPath: null,
|
2023-06-17 23:22:31 -04:00
|
|
|
thumbhash: Buffer.from('blablabla', 'base64'),
|
2023-02-18 20:58:55 +00:00
|
|
|
encodedVideoPath: null,
|
2023-05-29 16:05:14 +02:00
|
|
|
createdAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
updatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
2023-02-18 20:58:55 +00:00
|
|
|
mimeType: null,
|
|
|
|
isFavorite: true,
|
2023-04-12 18:37:52 +03:00
|
|
|
isArchived: false,
|
2023-02-18 20:58:55 +00:00
|
|
|
duration: null,
|
|
|
|
isVisible: true,
|
2023-02-19 16:44:53 +00:00
|
|
|
livePhotoVideo: null,
|
2023-02-18 20:58:55 +00:00
|
|
|
livePhotoVideoId: null,
|
|
|
|
tags: [],
|
2023-03-23 22:40:46 -04:00
|
|
|
sharedLinks: [],
|
2023-06-30 12:24:28 -04:00
|
|
|
originalFileName: 'IMG_456',
|
2023-06-17 23:22:31 -04:00
|
|
|
faces: [],
|
|
|
|
sidecarPath: null,
|
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-21 22:33:20 -04:00
|
|
|
isReadOnly: false,
|
2023-06-30 12:24:28 -04:00
|
|
|
exifInfo: {
|
|
|
|
fileSizeInByte: 123_000,
|
|
|
|
} as ExifEntity,
|
2023-06-17 23:22:31 -04:00
|
|
|
}),
|
|
|
|
noThumbhash: Object.freeze<AssetEntity>({
|
|
|
|
id: 'asset-id',
|
|
|
|
deviceAssetId: 'device-asset-id',
|
|
|
|
fileModifiedAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
fileCreatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
owner: userEntityStub.user1,
|
|
|
|
ownerId: 'user-id',
|
|
|
|
deviceId: 'device-id',
|
|
|
|
originalPath: '/original/path.ext',
|
|
|
|
resizePath: '/uploads/user-id/thumbs/path.ext',
|
|
|
|
checksum: Buffer.from('file hash', 'utf8'),
|
|
|
|
type: AssetType.IMAGE,
|
|
|
|
webpPath: '/uploads/user-id/webp/path.ext',
|
|
|
|
thumbhash: null,
|
|
|
|
encodedVideoPath: null,
|
|
|
|
createdAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
updatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
mimeType: null,
|
|
|
|
isFavorite: true,
|
|
|
|
isArchived: false,
|
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-21 22:33:20 -04:00
|
|
|
isReadOnly: false,
|
2023-06-17 23:22:31 -04:00
|
|
|
duration: null,
|
|
|
|
isVisible: true,
|
|
|
|
livePhotoVideo: null,
|
|
|
|
livePhotoVideoId: null,
|
|
|
|
tags: [],
|
|
|
|
sharedLinks: [],
|
|
|
|
originalFileName: 'asset-id.ext',
|
2023-05-17 13:07:17 -04:00
|
|
|
faces: [],
|
feat(server): xmp sidecar metadata (#2466)
* initial commit for XMP sidecar support
* Added support for 'missing' metadata files to include those without sidecar files, now detects sidecar files in the filesystem for media already ingested but the sidecar was created afterwards
* didn't mean to commit default log level during testing
* new sidecar logic for video metadata as well
* Added xml mimetype for sidecars only
* don't need capture group for this regex
* wrong default value reverted
* simplified the move here - keep it in the same try catch since the outcome is to move the media back anyway
* simplified setter logic
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
* simplified logic per suggestions
* sidecar is now its own queue with a discover and sync, updated UI for the new job queueing
* queue a sidecar job for every asset based on discovery or sync, though the logic is almost identical aside from linking the sidecar
* now queue sidecar jobs for each assset, though logic is mostly the same between discovery and sync
* simplified logic of filename extraction and asset instantiation
* not sure how that got deleted..
* updated code per suggestions and comments in the PR
* stat was not being used, removed the variable set
* better type checking, using in-scope variables for exif getter instead of passing in every time
* removed commented out test
* ran and resolved all lints, formats, checks, and tests
* resolved suggested change in PR
* made getExifProperty more dynamic with multiple possible args for fallbacks, fixed typo, used generic in function for better type checking
* better error handling and moving files back to positions on move or save failure
* regenerated api
* format fixes
* Added XMP documentation
* documentation typo
* Merged in main
* missed merge conflict
* more changes due to a merge
* Resolving conflicts
* added icon for sidecar jobs
---------
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
2023-05-24 21:59:30 -04:00
|
|
|
sidecarPath: null,
|
2023-03-23 22:40:46 -04:00
|
|
|
}),
|
|
|
|
image: Object.freeze<AssetEntity>({
|
|
|
|
id: 'asset-id',
|
|
|
|
deviceAssetId: 'device-asset-id',
|
2023-05-29 16:05:14 +02:00
|
|
|
fileModifiedAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
fileCreatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
2023-03-23 22:40:46 -04:00
|
|
|
owner: userEntityStub.user1,
|
|
|
|
ownerId: 'user-id',
|
|
|
|
deviceId: 'device-id',
|
|
|
|
originalPath: '/original/path.ext',
|
|
|
|
resizePath: '/uploads/user-id/thumbs/path.ext',
|
2023-05-24 23:08:21 +02:00
|
|
|
checksum: Buffer.from('file hash', 'utf8'),
|
2023-03-23 22:40:46 -04:00
|
|
|
type: AssetType.IMAGE,
|
2023-06-17 23:22:31 -04:00
|
|
|
webpPath: '/uploads/user-id/webp/path.ext',
|
|
|
|
thumbhash: Buffer.from('blablabla', 'base64'),
|
2023-03-23 22:40:46 -04:00
|
|
|
encodedVideoPath: null,
|
2023-05-29 16:05:14 +02:00
|
|
|
createdAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
updatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
2023-03-23 22:40:46 -04:00
|
|
|
mimeType: null,
|
|
|
|
isFavorite: true,
|
2023-04-12 18:37:52 +03:00
|
|
|
isArchived: false,
|
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-21 22:33:20 -04:00
|
|
|
isReadOnly: false,
|
2023-03-23 22:40:46 -04:00
|
|
|
duration: null,
|
|
|
|
isVisible: true,
|
|
|
|
livePhotoVideo: null,
|
|
|
|
livePhotoVideoId: null,
|
|
|
|
tags: [],
|
|
|
|
sharedLinks: [],
|
2023-04-11 05:23:39 -05:00
|
|
|
originalFileName: 'asset-id.ext',
|
2023-05-17 13:07:17 -04:00
|
|
|
faces: [],
|
feat(server): xmp sidecar metadata (#2466)
* initial commit for XMP sidecar support
* Added support for 'missing' metadata files to include those without sidecar files, now detects sidecar files in the filesystem for media already ingested but the sidecar was created afterwards
* didn't mean to commit default log level during testing
* new sidecar logic for video metadata as well
* Added xml mimetype for sidecars only
* don't need capture group for this regex
* wrong default value reverted
* simplified the move here - keep it in the same try catch since the outcome is to move the media back anyway
* simplified setter logic
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
* simplified logic per suggestions
* sidecar is now its own queue with a discover and sync, updated UI for the new job queueing
* queue a sidecar job for every asset based on discovery or sync, though the logic is almost identical aside from linking the sidecar
* now queue sidecar jobs for each assset, though logic is mostly the same between discovery and sync
* simplified logic of filename extraction and asset instantiation
* not sure how that got deleted..
* updated code per suggestions and comments in the PR
* stat was not being used, removed the variable set
* better type checking, using in-scope variables for exif getter instead of passing in every time
* removed commented out test
* ran and resolved all lints, formats, checks, and tests
* resolved suggested change in PR
* made getExifProperty more dynamic with multiple possible args for fallbacks, fixed typo, used generic in function for better type checking
* better error handling and moving files back to positions on move or save failure
* regenerated api
* format fixes
* Added XMP documentation
* documentation typo
* Merged in main
* missed merge conflict
* more changes due to a merge
* Resolving conflicts
* added icon for sidecar jobs
---------
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
2023-05-24 21:59:30 -04:00
|
|
|
sidecarPath: null,
|
2023-06-30 12:24:28 -04:00
|
|
|
exifInfo: {
|
|
|
|
fileSizeInByte: 5_000,
|
|
|
|
} as ExifEntity,
|
2023-03-23 22:40:46 -04:00
|
|
|
}),
|
|
|
|
video: Object.freeze<AssetEntity>({
|
|
|
|
id: 'asset-id',
|
2023-04-11 05:23:39 -05:00
|
|
|
originalFileName: 'asset-id.ext',
|
2023-03-23 22:40:46 -04:00
|
|
|
deviceAssetId: 'device-asset-id',
|
2023-05-29 16:05:14 +02:00
|
|
|
fileModifiedAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
fileCreatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
2023-03-23 22:40:46 -04:00
|
|
|
owner: userEntityStub.user1,
|
|
|
|
ownerId: 'user-id',
|
|
|
|
deviceId: 'device-id',
|
|
|
|
originalPath: '/original/path.ext',
|
|
|
|
resizePath: '/uploads/user-id/thumbs/path.ext',
|
2023-05-24 23:08:21 +02:00
|
|
|
checksum: Buffer.from('file hash', 'utf8'),
|
2023-03-23 22:40:46 -04:00
|
|
|
type: AssetType.VIDEO,
|
|
|
|
webpPath: null,
|
2023-06-17 23:22:31 -04:00
|
|
|
thumbhash: null,
|
2023-03-23 22:40:46 -04:00
|
|
|
encodedVideoPath: null,
|
2023-05-29 16:05:14 +02:00
|
|
|
createdAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
updatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
2023-03-23 22:40:46 -04:00
|
|
|
mimeType: null,
|
|
|
|
isFavorite: true,
|
2023-04-12 18:37:52 +03:00
|
|
|
isArchived: false,
|
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-21 22:33:20 -04:00
|
|
|
isReadOnly: false,
|
2023-03-23 22:40:46 -04:00
|
|
|
duration: null,
|
|
|
|
isVisible: true,
|
|
|
|
livePhotoVideo: null,
|
|
|
|
livePhotoVideoId: null,
|
|
|
|
tags: [],
|
2023-02-18 20:58:55 +00:00
|
|
|
sharedLinks: [],
|
2023-05-17 13:07:17 -04:00
|
|
|
faces: [],
|
feat(server): xmp sidecar metadata (#2466)
* initial commit for XMP sidecar support
* Added support for 'missing' metadata files to include those without sidecar files, now detects sidecar files in the filesystem for media already ingested but the sidecar was created afterwards
* didn't mean to commit default log level during testing
* new sidecar logic for video metadata as well
* Added xml mimetype for sidecars only
* don't need capture group for this regex
* wrong default value reverted
* simplified the move here - keep it in the same try catch since the outcome is to move the media back anyway
* simplified setter logic
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
* simplified logic per suggestions
* sidecar is now its own queue with a discover and sync, updated UI for the new job queueing
* queue a sidecar job for every asset based on discovery or sync, though the logic is almost identical aside from linking the sidecar
* now queue sidecar jobs for each assset, though logic is mostly the same between discovery and sync
* simplified logic of filename extraction and asset instantiation
* not sure how that got deleted..
* updated code per suggestions and comments in the PR
* stat was not being used, removed the variable set
* better type checking, using in-scope variables for exif getter instead of passing in every time
* removed commented out test
* ran and resolved all lints, formats, checks, and tests
* resolved suggested change in PR
* made getExifProperty more dynamic with multiple possible args for fallbacks, fixed typo, used generic in function for better type checking
* better error handling and moving files back to positions on move or save failure
* regenerated api
* format fixes
* Added XMP documentation
* documentation typo
* Merged in main
* missed merge conflict
* more changes due to a merge
* Resolving conflicts
* added icon for sidecar jobs
---------
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
2023-05-24 21:59:30 -04:00
|
|
|
sidecarPath: null,
|
2023-06-30 12:24:28 -04:00
|
|
|
exifInfo: {
|
|
|
|
fileSizeInByte: 100_000,
|
|
|
|
} as ExifEntity,
|
2023-02-18 20:58:55 +00:00
|
|
|
}),
|
2023-02-25 09:12:03 -05:00
|
|
|
livePhotoMotionAsset: Object.freeze({
|
|
|
|
id: 'live-photo-motion-asset',
|
|
|
|
originalPath: fileStub.livePhotoMotion.originalPath,
|
|
|
|
ownerId: authStub.user1.id,
|
|
|
|
type: AssetType.VIDEO,
|
|
|
|
isVisible: false,
|
2023-05-29 16:05:14 +02:00
|
|
|
fileModifiedAt: new Date('2022-06-19T23:41:36.910Z'),
|
|
|
|
fileCreatedAt: new Date('2022-06-19T23:41:36.910Z'),
|
2023-06-30 12:24:28 -04:00
|
|
|
exifInfo: {
|
|
|
|
fileSizeInByte: 100_000,
|
|
|
|
},
|
2023-02-25 09:12:03 -05:00
|
|
|
} as AssetEntity),
|
|
|
|
|
|
|
|
livePhotoStillAsset: Object.freeze({
|
|
|
|
id: 'live-photo-still-asset',
|
|
|
|
originalPath: fileStub.livePhotoStill.originalPath,
|
|
|
|
ownerId: authStub.user1.id,
|
|
|
|
type: AssetType.IMAGE,
|
|
|
|
livePhotoVideoId: 'live-photo-motion-asset',
|
|
|
|
isVisible: true,
|
2023-05-29 16:05:14 +02:00
|
|
|
fileModifiedAt: new Date('2022-06-19T23:41:36.910Z'),
|
|
|
|
fileCreatedAt: new Date('2022-06-19T23:41:36.910Z'),
|
2023-06-30 12:24:28 -04:00
|
|
|
exifInfo: {
|
|
|
|
fileSizeInByte: 25_000,
|
|
|
|
},
|
2023-02-25 09:12:03 -05:00
|
|
|
} as AssetEntity),
|
2023-05-21 08:26:06 +02:00
|
|
|
|
|
|
|
withLocation: Object.freeze<AssetEntity>({
|
|
|
|
id: 'asset-with-favorite-id',
|
|
|
|
deviceAssetId: 'device-asset-id',
|
2023-05-29 16:05:14 +02:00
|
|
|
fileModifiedAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
fileCreatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
2023-05-21 08:26:06 +02:00
|
|
|
owner: userEntityStub.user1,
|
|
|
|
ownerId: 'user-id',
|
|
|
|
deviceId: 'device-id',
|
2023-05-24 23:08:21 +02:00
|
|
|
checksum: Buffer.from('file hash', 'utf8'),
|
2023-05-21 08:26:06 +02:00
|
|
|
originalPath: '/original/path.ext',
|
|
|
|
resizePath: '/uploads/user-id/thumbs/path.ext',
|
feat(server): xmp sidecar metadata (#2466)
* initial commit for XMP sidecar support
* Added support for 'missing' metadata files to include those without sidecar files, now detects sidecar files in the filesystem for media already ingested but the sidecar was created afterwards
* didn't mean to commit default log level during testing
* new sidecar logic for video metadata as well
* Added xml mimetype for sidecars only
* don't need capture group for this regex
* wrong default value reverted
* simplified the move here - keep it in the same try catch since the outcome is to move the media back anyway
* simplified setter logic
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
* simplified logic per suggestions
* sidecar is now its own queue with a discover and sync, updated UI for the new job queueing
* queue a sidecar job for every asset based on discovery or sync, though the logic is almost identical aside from linking the sidecar
* now queue sidecar jobs for each assset, though logic is mostly the same between discovery and sync
* simplified logic of filename extraction and asset instantiation
* not sure how that got deleted..
* updated code per suggestions and comments in the PR
* stat was not being used, removed the variable set
* better type checking, using in-scope variables for exif getter instead of passing in every time
* removed commented out test
* ran and resolved all lints, formats, checks, and tests
* resolved suggested change in PR
* made getExifProperty more dynamic with multiple possible args for fallbacks, fixed typo, used generic in function for better type checking
* better error handling and moving files back to positions on move or save failure
* regenerated api
* format fixes
* Added XMP documentation
* documentation typo
* Merged in main
* missed merge conflict
* more changes due to a merge
* Resolving conflicts
* added icon for sidecar jobs
---------
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
2023-05-24 21:59:30 -04:00
|
|
|
sidecarPath: null,
|
2023-05-21 08:26:06 +02:00
|
|
|
type: AssetType.IMAGE,
|
|
|
|
webpPath: null,
|
2023-06-17 23:22:31 -04:00
|
|
|
thumbhash: null,
|
2023-05-21 08:26:06 +02:00
|
|
|
encodedVideoPath: null,
|
2023-05-29 16:05:14 +02:00
|
|
|
createdAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
updatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
2023-05-21 08:26:06 +02:00
|
|
|
mimeType: null,
|
|
|
|
isFavorite: false,
|
|
|
|
isArchived: false,
|
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-21 22:33:20 -04:00
|
|
|
isReadOnly: false,
|
2023-05-21 08:26:06 +02:00
|
|
|
duration: null,
|
|
|
|
isVisible: true,
|
|
|
|
livePhotoVideo: null,
|
|
|
|
livePhotoVideoId: null,
|
|
|
|
tags: [],
|
|
|
|
sharedLinks: [],
|
|
|
|
originalFileName: 'asset-id.ext',
|
|
|
|
faces: [],
|
|
|
|
exifInfo: {
|
|
|
|
latitude: 100,
|
|
|
|
longitude: 100,
|
2023-06-30 12:24:28 -04:00
|
|
|
fileSizeInByte: 23_456,
|
2023-05-21 08:26:06 +02:00
|
|
|
} as ExifEntity,
|
|
|
|
}),
|
2023-05-26 08:52:52 -04:00
|
|
|
sidecar: Object.freeze<AssetEntity>({
|
|
|
|
id: 'asset-id',
|
|
|
|
deviceAssetId: 'device-asset-id',
|
2023-05-29 16:05:14 +02:00
|
|
|
fileModifiedAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
fileCreatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
2023-05-26 08:52:52 -04:00
|
|
|
owner: userEntityStub.user1,
|
|
|
|
ownerId: 'user-id',
|
|
|
|
deviceId: 'device-id',
|
|
|
|
originalPath: '/original/path.ext',
|
|
|
|
resizePath: '/uploads/user-id/thumbs/path.ext',
|
2023-06-17 23:22:31 -04:00
|
|
|
thumbhash: null,
|
2023-05-26 08:52:52 -04:00
|
|
|
checksum: Buffer.from('file hash', 'utf8'),
|
|
|
|
type: AssetType.IMAGE,
|
|
|
|
webpPath: null,
|
|
|
|
encodedVideoPath: null,
|
2023-05-29 16:05:14 +02:00
|
|
|
createdAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
updatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
2023-05-26 08:52:52 -04:00
|
|
|
mimeType: null,
|
|
|
|
isFavorite: true,
|
|
|
|
isArchived: false,
|
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-21 22:33:20 -04:00
|
|
|
isReadOnly: false,
|
2023-05-26 08:52:52 -04:00
|
|
|
duration: null,
|
|
|
|
isVisible: true,
|
|
|
|
livePhotoVideo: null,
|
|
|
|
livePhotoVideoId: null,
|
|
|
|
tags: [],
|
|
|
|
sharedLinks: [],
|
|
|
|
originalFileName: 'asset-id.ext',
|
|
|
|
faces: [],
|
|
|
|
sidecarPath: '/original/path.ext.xmp',
|
|
|
|
}),
|
2023-02-18 20:58:55 +00:00
|
|
|
};
|
|
|
|
|
2023-03-02 21:47:08 -05:00
|
|
|
export const albumStub = {
|
|
|
|
empty: Object.freeze<AlbumEntity>({
|
|
|
|
id: 'album-1',
|
|
|
|
albumName: 'Empty album',
|
|
|
|
ownerId: authStub.admin.id,
|
|
|
|
owner: userEntityStub.admin,
|
|
|
|
assets: [],
|
2023-03-04 15:16:48 +01:00
|
|
|
albumThumbnailAsset: null,
|
2023-03-02 21:47:08 -05:00
|
|
|
albumThumbnailAssetId: null,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: new Date(),
|
|
|
|
updatedAt: new Date(),
|
2023-03-26 04:46:48 +02:00
|
|
|
sharedLinks: [],
|
|
|
|
sharedUsers: [],
|
|
|
|
}),
|
|
|
|
sharedWithUser: Object.freeze<AlbumEntity>({
|
|
|
|
id: 'album-2',
|
|
|
|
albumName: 'Empty album shared with user',
|
|
|
|
ownerId: authStub.admin.id,
|
|
|
|
owner: userEntityStub.admin,
|
|
|
|
assets: [],
|
|
|
|
albumThumbnailAsset: null,
|
|
|
|
albumThumbnailAssetId: null,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: new Date(),
|
|
|
|
updatedAt: new Date(),
|
2023-03-26 04:46:48 +02:00
|
|
|
sharedLinks: [],
|
|
|
|
sharedUsers: [userEntityStub.user1],
|
|
|
|
}),
|
2023-06-07 10:37:25 -04:00
|
|
|
sharedWithMultiple: Object.freeze<AlbumEntity>({
|
|
|
|
id: 'album-3',
|
|
|
|
albumName: 'Empty album shared with users',
|
|
|
|
ownerId: authStub.admin.id,
|
|
|
|
owner: userEntityStub.admin,
|
|
|
|
assets: [],
|
|
|
|
albumThumbnailAsset: null,
|
|
|
|
albumThumbnailAssetId: null,
|
|
|
|
createdAt: new Date(),
|
|
|
|
updatedAt: new Date(),
|
|
|
|
sharedLinks: [],
|
|
|
|
sharedUsers: [userEntityStub.user1, userEntityStub.user2],
|
|
|
|
}),
|
2023-03-26 04:46:48 +02:00
|
|
|
sharedWithAdmin: Object.freeze<AlbumEntity>({
|
|
|
|
id: 'album-3',
|
|
|
|
albumName: 'Empty album shared with admin',
|
|
|
|
ownerId: authStub.user1.id,
|
|
|
|
owner: userEntityStub.user1,
|
|
|
|
assets: [],
|
|
|
|
albumThumbnailAsset: null,
|
|
|
|
albumThumbnailAssetId: null,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: new Date(),
|
|
|
|
updatedAt: new Date(),
|
2023-03-26 04:46:48 +02:00
|
|
|
sharedLinks: [],
|
|
|
|
sharedUsers: [userEntityStub.admin],
|
|
|
|
}),
|
|
|
|
oneAsset: Object.freeze<AlbumEntity>({
|
|
|
|
id: 'album-4',
|
|
|
|
albumName: 'Album with one asset',
|
|
|
|
ownerId: authStub.admin.id,
|
|
|
|
owner: userEntityStub.admin,
|
|
|
|
assets: [assetEntityStub.image],
|
|
|
|
albumThumbnailAsset: null,
|
|
|
|
albumThumbnailAssetId: null,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: new Date(),
|
|
|
|
updatedAt: new Date(),
|
2023-03-26 04:46:48 +02:00
|
|
|
sharedLinks: [],
|
|
|
|
sharedUsers: [],
|
|
|
|
}),
|
|
|
|
emptyWithInvalidThumbnail: Object.freeze<AlbumEntity>({
|
|
|
|
id: 'album-5',
|
|
|
|
albumName: 'Empty album with invalid thumbnail',
|
|
|
|
ownerId: authStub.admin.id,
|
|
|
|
owner: userEntityStub.admin,
|
|
|
|
assets: [],
|
|
|
|
albumThumbnailAsset: assetEntityStub.image,
|
|
|
|
albumThumbnailAssetId: assetEntityStub.image.id,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: new Date(),
|
|
|
|
updatedAt: new Date(),
|
2023-03-26 04:46:48 +02:00
|
|
|
sharedLinks: [],
|
|
|
|
sharedUsers: [],
|
|
|
|
}),
|
|
|
|
emptyWithValidThumbnail: Object.freeze<AlbumEntity>({
|
|
|
|
id: 'album-5',
|
|
|
|
albumName: 'Empty album with invalid thumbnail',
|
|
|
|
ownerId: authStub.admin.id,
|
|
|
|
owner: userEntityStub.admin,
|
|
|
|
assets: [],
|
|
|
|
albumThumbnailAsset: null,
|
|
|
|
albumThumbnailAssetId: null,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: new Date(),
|
|
|
|
updatedAt: new Date(),
|
2023-03-26 04:46:48 +02:00
|
|
|
sharedLinks: [],
|
|
|
|
sharedUsers: [],
|
|
|
|
}),
|
|
|
|
oneAssetInvalidThumbnail: Object.freeze<AlbumEntity>({
|
|
|
|
id: 'album-6',
|
|
|
|
albumName: 'Album with one asset and invalid thumbnail',
|
|
|
|
ownerId: authStub.admin.id,
|
|
|
|
owner: userEntityStub.admin,
|
|
|
|
assets: [assetEntityStub.image],
|
|
|
|
albumThumbnailAsset: assetEntityStub.livePhotoMotionAsset,
|
|
|
|
albumThumbnailAssetId: assetEntityStub.livePhotoMotionAsset.id,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: new Date(),
|
|
|
|
updatedAt: new Date(),
|
2023-03-26 04:46:48 +02:00
|
|
|
sharedLinks: [],
|
|
|
|
sharedUsers: [],
|
|
|
|
}),
|
|
|
|
oneAssetValidThumbnail: Object.freeze<AlbumEntity>({
|
|
|
|
id: 'album-6',
|
|
|
|
albumName: 'Album with one asset and invalid thumbnail',
|
|
|
|
ownerId: authStub.admin.id,
|
|
|
|
owner: userEntityStub.admin,
|
|
|
|
assets: [assetEntityStub.image],
|
|
|
|
albumThumbnailAsset: assetEntityStub.image,
|
|
|
|
albumThumbnailAssetId: assetEntityStub.image.id,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: new Date(),
|
|
|
|
updatedAt: new Date(),
|
2023-03-02 21:47:08 -05:00
|
|
|
sharedLinks: [],
|
|
|
|
sharedUsers: [],
|
|
|
|
}),
|
|
|
|
};
|
|
|
|
|
2023-02-06 20:47:06 -06:00
|
|
|
const assetInfo: ExifResponseDto = {
|
|
|
|
make: 'camera-make',
|
|
|
|
model: 'camera-model',
|
|
|
|
exifImageWidth: 500,
|
|
|
|
exifImageHeight: 500,
|
|
|
|
fileSizeInByte: 100,
|
|
|
|
orientation: 'orientation',
|
|
|
|
dateTimeOriginal: today,
|
|
|
|
modifyDate: today,
|
2023-04-02 21:11:24 +02:00
|
|
|
timeZone: 'America/Los_Angeles',
|
2023-02-06 20:47:06 -06:00
|
|
|
lensModel: 'fancy',
|
|
|
|
fNumber: 100,
|
|
|
|
focalLength: 100,
|
|
|
|
iso: 100,
|
|
|
|
exposureTime: '1/16',
|
|
|
|
latitude: 100,
|
|
|
|
longitude: 100,
|
|
|
|
city: 'city',
|
|
|
|
state: 'state',
|
|
|
|
country: 'country',
|
2023-04-13 10:22:06 -05:00
|
|
|
description: 'description',
|
2023-02-06 20:47:06 -06:00
|
|
|
};
|
|
|
|
|
|
|
|
const assetResponse: AssetResponseDto = {
|
|
|
|
id: 'id_1',
|
|
|
|
deviceAssetId: 'device_asset_id_1',
|
|
|
|
ownerId: 'user_id_1',
|
|
|
|
deviceId: 'device_id_1',
|
|
|
|
type: AssetType.VIDEO,
|
|
|
|
originalPath: 'fake_path/jpeg',
|
2023-04-11 05:23:39 -05:00
|
|
|
originalFileName: 'asset_1.jpeg',
|
2023-05-27 21:56:17 -04:00
|
|
|
resized: false,
|
2023-06-17 23:22:31 -04:00
|
|
|
thumbhash: null,
|
2023-05-29 16:05:14 +02:00
|
|
|
fileModifiedAt: today,
|
|
|
|
fileCreatedAt: today,
|
|
|
|
updatedAt: today,
|
2023-02-06 20:47:06 -06:00
|
|
|
isFavorite: false,
|
2023-04-12 18:37:52 +03:00
|
|
|
isArchived: false,
|
2023-02-06 20:47:06 -06:00
|
|
|
mimeType: 'image/jpeg',
|
|
|
|
smartInfo: {
|
|
|
|
tags: [],
|
|
|
|
objects: ['a', 'b', 'c'],
|
|
|
|
},
|
|
|
|
duration: '0:00:00.00000',
|
|
|
|
exifInfo: assetInfo,
|
|
|
|
livePhotoVideoId: null,
|
|
|
|
tags: [],
|
2023-05-17 13:07:17 -04:00
|
|
|
people: [],
|
2023-05-27 21:56:17 -04:00
|
|
|
checksum: 'ZmlsZSBoYXNo',
|
2023-02-06 20:47:06 -06:00
|
|
|
};
|
|
|
|
|
|
|
|
const albumResponse: AlbumResponseDto = {
|
|
|
|
albumName: 'Test Album',
|
|
|
|
albumThumbnailAssetId: null,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: today,
|
|
|
|
updatedAt: today,
|
2023-02-06 20:47:06 -06:00
|
|
|
id: 'album-123',
|
|
|
|
ownerId: 'admin_id',
|
|
|
|
owner: mapUser(userEntityStub.admin),
|
|
|
|
sharedUsers: [],
|
|
|
|
shared: false,
|
|
|
|
assets: [],
|
|
|
|
assetCount: 1,
|
|
|
|
};
|
|
|
|
|
2023-01-27 20:50:07 +00:00
|
|
|
export const userTokenEntityStub = {
|
|
|
|
userToken: Object.freeze<UserTokenEntity>({
|
|
|
|
id: 'token-id',
|
|
|
|
token: 'auth_token',
|
2023-04-25 22:19:23 -04:00
|
|
|
userId: userEntityStub.user1.id,
|
2023-01-27 20:50:07 +00:00
|
|
|
user: userEntityStub.user1,
|
2023-04-25 22:19:23 -04:00
|
|
|
createdAt: new Date('2021-01-01'),
|
|
|
|
updatedAt: new Date(),
|
|
|
|
deviceType: '',
|
|
|
|
deviceOS: '',
|
|
|
|
}),
|
|
|
|
inactiveToken: Object.freeze<UserTokenEntity>({
|
|
|
|
id: 'not_active',
|
|
|
|
token: 'auth_token',
|
|
|
|
userId: userEntityStub.user1.id,
|
|
|
|
user: userEntityStub.user1,
|
|
|
|
createdAt: new Date('2021-01-01'),
|
|
|
|
updatedAt: new Date('2021-01-01'),
|
|
|
|
deviceType: 'Mobile',
|
|
|
|
deviceOS: 'Android',
|
2023-01-27 20:50:07 +00:00
|
|
|
}),
|
|
|
|
};
|
|
|
|
|
2023-01-31 13:11:49 -05:00
|
|
|
export const keyStub = {
|
|
|
|
admin: Object.freeze({
|
2023-02-18 20:58:55 +00:00
|
|
|
id: 'my-random-guid',
|
2023-01-31 13:11:49 -05:00
|
|
|
name: 'My Key',
|
|
|
|
key: 'my-api-key (hashed)',
|
|
|
|
userId: authStub.admin.id,
|
|
|
|
user: userEntityStub.admin,
|
|
|
|
} as APIKeyEntity),
|
|
|
|
};
|
|
|
|
|
2023-01-21 11:11:55 -05:00
|
|
|
export const systemConfigStub = {
|
|
|
|
defaults: Object.freeze({
|
|
|
|
ffmpeg: {
|
2023-05-22 14:07:43 -04:00
|
|
|
crf: 23,
|
|
|
|
threads: 0,
|
2023-01-21 11:11:55 -05:00
|
|
|
preset: 'ultrafast',
|
2023-01-22 02:09:02 +00:00
|
|
|
targetAudioCodec: 'aac',
|
2023-04-04 02:42:53 +01:00
|
|
|
targetResolution: '720',
|
2023-01-22 02:09:02 +00:00
|
|
|
targetVideoCodec: 'h264',
|
2023-05-22 14:07:43 -04:00
|
|
|
maxBitrate: '0',
|
|
|
|
twoPass: false,
|
2023-03-28 22:03:43 +03:00
|
|
|
transcode: TranscodePreset.REQUIRED,
|
2023-01-21 11:11:55 -05:00
|
|
|
},
|
2023-06-01 06:32:51 -04:00
|
|
|
job: {
|
|
|
|
[QueueName.BACKGROUND_TASK]: { concurrency: 5 },
|
|
|
|
[QueueName.CLIP_ENCODING]: { concurrency: 2 },
|
|
|
|
[QueueName.METADATA_EXTRACTION]: { concurrency: 5 },
|
|
|
|
[QueueName.OBJECT_TAGGING]: { concurrency: 2 },
|
|
|
|
[QueueName.RECOGNIZE_FACES]: { concurrency: 2 },
|
|
|
|
[QueueName.SEARCH]: { concurrency: 5 },
|
|
|
|
[QueueName.SIDECAR]: { concurrency: 5 },
|
|
|
|
[QueueName.STORAGE_TEMPLATE_MIGRATION]: { concurrency: 5 },
|
|
|
|
[QueueName.THUMBNAIL_GENERATION]: { concurrency: 5 },
|
|
|
|
[QueueName.VIDEO_CONVERSION]: { concurrency: 1 },
|
|
|
|
},
|
2023-01-21 11:11:55 -05:00
|
|
|
oauth: {
|
|
|
|
autoLaunch: false,
|
|
|
|
autoRegister: true,
|
|
|
|
buttonText: 'Login with OAuth',
|
|
|
|
clientId: '',
|
|
|
|
clientSecret: '',
|
|
|
|
enabled: false,
|
|
|
|
issuerUrl: '',
|
|
|
|
mobileOverrideEnabled: false,
|
|
|
|
mobileRedirectUri: '',
|
|
|
|
scope: 'openid email profile',
|
|
|
|
},
|
|
|
|
passwordLogin: {
|
|
|
|
enabled: true,
|
|
|
|
},
|
|
|
|
storageTemplate: {
|
|
|
|
template: '{{y}}/{{y}}-{{MM}}-{{dd}}/{{filename}}',
|
|
|
|
},
|
|
|
|
} as SystemConfig),
|
2023-01-23 23:13:42 -05:00
|
|
|
enabled: Object.freeze({
|
|
|
|
passwordLogin: {
|
|
|
|
enabled: true,
|
|
|
|
},
|
|
|
|
oauth: {
|
|
|
|
enabled: true,
|
|
|
|
autoRegister: true,
|
|
|
|
buttonText: 'OAuth',
|
|
|
|
autoLaunch: false,
|
|
|
|
},
|
|
|
|
} as SystemConfig),
|
|
|
|
disabled: Object.freeze({
|
|
|
|
passwordLogin: {
|
|
|
|
enabled: false,
|
|
|
|
},
|
|
|
|
oauth: {
|
|
|
|
enabled: false,
|
|
|
|
buttonText: 'OAuth',
|
|
|
|
issuerUrl: 'http://issuer,',
|
|
|
|
autoLaunch: false,
|
|
|
|
},
|
|
|
|
} as SystemConfig),
|
|
|
|
noAutoRegister: {
|
|
|
|
oauth: {
|
|
|
|
enabled: true,
|
|
|
|
autoRegister: false,
|
|
|
|
autoLaunch: false,
|
|
|
|
},
|
|
|
|
passwordLogin: { enabled: true },
|
|
|
|
} as SystemConfig,
|
|
|
|
override: {
|
|
|
|
oauth: {
|
|
|
|
enabled: true,
|
|
|
|
autoRegister: true,
|
|
|
|
autoLaunch: false,
|
|
|
|
buttonText: 'OAuth',
|
|
|
|
mobileOverrideEnabled: true,
|
|
|
|
mobileRedirectUri: 'http://mobile-redirect',
|
|
|
|
},
|
|
|
|
passwordLogin: { enabled: true },
|
|
|
|
} as SystemConfig,
|
|
|
|
};
|
|
|
|
|
|
|
|
export const loginResponseStub = {
|
|
|
|
user1oauth: {
|
|
|
|
response: {
|
2023-01-27 20:50:07 +00:00
|
|
|
accessToken: 'cmFuZG9tLWJ5dGVz',
|
2023-05-21 23:18:10 -04:00
|
|
|
userId: 'user-id',
|
2023-01-23 23:13:42 -05:00
|
|
|
userEmail: 'immich@test.com',
|
|
|
|
firstName: 'immich_first_name',
|
|
|
|
lastName: 'immich_last_name',
|
|
|
|
profileImagePath: '',
|
|
|
|
isAdmin: false,
|
|
|
|
shouldChangePassword: false,
|
|
|
|
},
|
|
|
|
cookie: [
|
2023-03-08 17:26:49 +01:00
|
|
|
'immich_access_token=cmFuZG9tLWJ5dGVz; HttpOnly; Secure; Path=/; Max-Age=34560000; SameSite=Lax;',
|
|
|
|
'immich_auth_type=oauth; HttpOnly; Secure; Path=/; Max-Age=34560000; SameSite=Lax;',
|
2023-01-23 23:13:42 -05:00
|
|
|
],
|
|
|
|
},
|
|
|
|
user1password: {
|
|
|
|
response: {
|
2023-01-27 20:50:07 +00:00
|
|
|
accessToken: 'cmFuZG9tLWJ5dGVz',
|
2023-05-21 23:18:10 -04:00
|
|
|
userId: 'user-id',
|
2023-01-23 23:13:42 -05:00
|
|
|
userEmail: 'immich@test.com',
|
|
|
|
firstName: 'immich_first_name',
|
|
|
|
lastName: 'immich_last_name',
|
|
|
|
profileImagePath: '',
|
|
|
|
isAdmin: false,
|
|
|
|
shouldChangePassword: false,
|
|
|
|
},
|
|
|
|
cookie: [
|
2023-03-08 17:26:49 +01:00
|
|
|
'immich_access_token=cmFuZG9tLWJ5dGVz; HttpOnly; Secure; Path=/; Max-Age=34560000; SameSite=Lax;',
|
|
|
|
'immich_auth_type=password; HttpOnly; Secure; Path=/; Max-Age=34560000; SameSite=Lax;',
|
2023-01-23 23:13:42 -05:00
|
|
|
],
|
|
|
|
},
|
|
|
|
user1insecure: {
|
|
|
|
response: {
|
2023-01-27 20:50:07 +00:00
|
|
|
accessToken: 'cmFuZG9tLWJ5dGVz',
|
2023-05-21 23:18:10 -04:00
|
|
|
userId: 'user-id',
|
2023-01-23 23:13:42 -05:00
|
|
|
userEmail: 'immich@test.com',
|
|
|
|
firstName: 'immich_first_name',
|
|
|
|
lastName: 'immich_last_name',
|
|
|
|
profileImagePath: '',
|
|
|
|
isAdmin: false,
|
|
|
|
shouldChangePassword: false,
|
|
|
|
},
|
|
|
|
cookie: [
|
2023-03-08 17:26:49 +01:00
|
|
|
'immich_access_token=cmFuZG9tLWJ5dGVz; HttpOnly; Path=/; Max-Age=34560000; SameSite=Lax;',
|
|
|
|
'immich_auth_type=password; HttpOnly; Path=/; Max-Age=34560000; SameSite=Lax;',
|
2023-01-23 23:13:42 -05:00
|
|
|
],
|
|
|
|
},
|
2023-01-21 11:11:55 -05:00
|
|
|
};
|
2023-01-25 11:35:28 -05:00
|
|
|
|
|
|
|
export const sharedLinkStub = {
|
2023-06-20 21:08:43 -04:00
|
|
|
individual: Object.freeze({
|
|
|
|
id: '123',
|
|
|
|
userId: authStub.admin.id,
|
|
|
|
user: userEntityStub.admin,
|
|
|
|
key: sharedLinkBytes,
|
|
|
|
type: SharedLinkType.INDIVIDUAL,
|
|
|
|
createdAt: today,
|
|
|
|
expiresAt: tomorrow,
|
|
|
|
allowUpload: true,
|
|
|
|
allowDownload: true,
|
|
|
|
showExif: true,
|
|
|
|
album: undefined,
|
|
|
|
description: null,
|
|
|
|
assets: [assetEntityStub.image],
|
|
|
|
} as SharedLinkEntity),
|
2023-01-25 11:35:28 -05:00
|
|
|
valid: Object.freeze({
|
|
|
|
id: '123',
|
|
|
|
userId: authStub.admin.id,
|
2023-01-31 13:11:49 -05:00
|
|
|
user: userEntityStub.admin,
|
2023-06-01 16:56:37 -04:00
|
|
|
key: sharedLinkBytes,
|
2023-01-25 11:35:28 -05:00
|
|
|
type: SharedLinkType.ALBUM,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: today,
|
|
|
|
expiresAt: tomorrow,
|
2023-01-25 11:35:28 -05:00
|
|
|
allowUpload: true,
|
|
|
|
allowDownload: true,
|
|
|
|
showExif: true,
|
|
|
|
album: undefined,
|
2023-06-20 21:08:43 -04:00
|
|
|
albumId: null,
|
|
|
|
description: null,
|
2023-01-25 11:35:28 -05:00
|
|
|
assets: [],
|
|
|
|
} as SharedLinkEntity),
|
|
|
|
expired: Object.freeze({
|
|
|
|
id: '123',
|
|
|
|
userId: authStub.admin.id,
|
2023-01-31 13:11:49 -05:00
|
|
|
user: userEntityStub.admin,
|
2023-06-01 16:56:37 -04:00
|
|
|
key: sharedLinkBytes,
|
2023-01-25 11:35:28 -05:00
|
|
|
type: SharedLinkType.ALBUM,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: today,
|
|
|
|
expiresAt: yesterday,
|
2023-01-25 11:35:28 -05:00
|
|
|
allowUpload: true,
|
|
|
|
allowDownload: true,
|
|
|
|
showExif: true,
|
2023-06-20 21:08:43 -04:00
|
|
|
description: null,
|
|
|
|
albumId: null,
|
2023-01-25 11:35:28 -05:00
|
|
|
assets: [],
|
|
|
|
} as SharedLinkEntity),
|
2023-06-01 22:09:57 -04:00
|
|
|
readonlyNoExif: Object.freeze<SharedLinkEntity>({
|
2023-01-25 11:35:28 -05:00
|
|
|
id: '123',
|
|
|
|
userId: authStub.admin.id,
|
2023-01-31 13:11:49 -05:00
|
|
|
user: userEntityStub.admin,
|
2023-06-01 16:56:37 -04:00
|
|
|
key: sharedLinkBytes,
|
2023-01-25 11:35:28 -05:00
|
|
|
type: SharedLinkType.ALBUM,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: today,
|
|
|
|
expiresAt: tomorrow,
|
2023-01-25 11:35:28 -05:00
|
|
|
allowUpload: false,
|
|
|
|
allowDownload: false,
|
2023-06-01 22:09:57 -04:00
|
|
|
showExif: false,
|
2023-06-20 21:08:43 -04:00
|
|
|
description: null,
|
2023-01-25 11:35:28 -05:00
|
|
|
assets: [],
|
2023-06-20 21:08:43 -04:00
|
|
|
albumId: 'album-123',
|
2023-01-25 11:35:28 -05:00
|
|
|
album: {
|
|
|
|
id: 'album-123',
|
|
|
|
ownerId: authStub.admin.id,
|
2023-02-06 20:47:06 -06:00
|
|
|
owner: userEntityStub.admin,
|
2023-01-25 11:35:28 -05:00
|
|
|
albumName: 'Test Album',
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: today,
|
|
|
|
updatedAt: today,
|
2023-03-04 15:16:48 +01:00
|
|
|
albumThumbnailAsset: null,
|
2023-01-25 11:35:28 -05:00
|
|
|
albumThumbnailAssetId: null,
|
|
|
|
sharedUsers: [],
|
|
|
|
sharedLinks: [],
|
|
|
|
assets: [
|
|
|
|
{
|
2023-02-18 20:58:55 +00:00
|
|
|
id: 'id_1',
|
2023-02-19 16:44:53 +00:00
|
|
|
owner: userEntityStub.user1,
|
|
|
|
ownerId: 'user_id_1',
|
2023-02-18 20:58:55 +00:00
|
|
|
deviceAssetId: 'device_asset_id_1',
|
|
|
|
deviceId: 'device_id_1',
|
|
|
|
type: AssetType.VIDEO,
|
|
|
|
originalPath: 'fake_path/jpeg',
|
|
|
|
resizePath: '',
|
2023-05-24 23:08:21 +02:00
|
|
|
checksum: Buffer.from('file hash', 'utf8'),
|
2023-05-29 16:05:14 +02:00
|
|
|
fileModifiedAt: today,
|
|
|
|
fileCreatedAt: today,
|
|
|
|
createdAt: today,
|
|
|
|
updatedAt: today,
|
2023-02-18 20:58:55 +00:00
|
|
|
isFavorite: false,
|
2023-04-12 18:37:52 +03:00
|
|
|
isArchived: false,
|
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-21 22:33:20 -04:00
|
|
|
isReadOnly: false,
|
2023-02-18 20:58:55 +00:00
|
|
|
mimeType: 'image/jpeg',
|
|
|
|
smartInfo: {
|
|
|
|
assetId: 'id_1',
|
2023-01-25 11:35:28 -05:00
|
|
|
tags: [],
|
2023-02-18 20:58:55 +00:00
|
|
|
objects: ['a', 'b', 'c'],
|
|
|
|
asset: null as any,
|
2023-03-18 08:44:42 -05:00
|
|
|
clipEmbedding: [0.12, 0.13, 0.14],
|
2023-02-18 20:58:55 +00:00
|
|
|
},
|
|
|
|
webpPath: '',
|
2023-06-17 23:22:31 -04:00
|
|
|
thumbhash: null,
|
2023-02-18 20:58:55 +00:00
|
|
|
encodedVideoPath: '',
|
|
|
|
duration: null,
|
|
|
|
isVisible: true,
|
2023-02-19 16:44:53 +00:00
|
|
|
livePhotoVideo: null,
|
2023-02-18 20:58:55 +00:00
|
|
|
livePhotoVideoId: null,
|
2023-04-11 05:23:39 -05:00
|
|
|
originalFileName: 'asset_1.jpeg',
|
2023-02-18 20:58:55 +00:00
|
|
|
exifInfo: {
|
|
|
|
livePhotoCID: null,
|
|
|
|
assetId: 'id_1',
|
|
|
|
description: 'description',
|
|
|
|
exifImageWidth: 500,
|
|
|
|
exifImageHeight: 500,
|
|
|
|
fileSizeInByte: 100,
|
|
|
|
orientation: 'orientation',
|
|
|
|
dateTimeOriginal: today,
|
|
|
|
modifyDate: today,
|
2023-04-02 21:11:24 +02:00
|
|
|
timeZone: 'America/Los_Angeles',
|
2023-02-18 20:58:55 +00:00
|
|
|
latitude: 100,
|
|
|
|
longitude: 100,
|
|
|
|
city: 'city',
|
|
|
|
state: 'state',
|
|
|
|
country: 'country',
|
|
|
|
make: 'camera-make',
|
|
|
|
model: 'camera-model',
|
|
|
|
lensModel: 'fancy',
|
|
|
|
fNumber: 100,
|
|
|
|
focalLength: 100,
|
|
|
|
iso: 100,
|
|
|
|
exposureTime: '1/16',
|
|
|
|
fps: 100,
|
|
|
|
asset: null as any,
|
|
|
|
exifTextSearchableColumn: '',
|
2023-01-25 11:35:28 -05:00
|
|
|
},
|
2023-02-18 20:58:55 +00:00
|
|
|
tags: [],
|
|
|
|
sharedLinks: [],
|
2023-05-17 13:07:17 -04:00
|
|
|
faces: [],
|
feat(server): xmp sidecar metadata (#2466)
* initial commit for XMP sidecar support
* Added support for 'missing' metadata files to include those without sidecar files, now detects sidecar files in the filesystem for media already ingested but the sidecar was created afterwards
* didn't mean to commit default log level during testing
* new sidecar logic for video metadata as well
* Added xml mimetype for sidecars only
* don't need capture group for this regex
* wrong default value reverted
* simplified the move here - keep it in the same try catch since the outcome is to move the media back anyway
* simplified setter logic
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
* simplified logic per suggestions
* sidecar is now its own queue with a discover and sync, updated UI for the new job queueing
* queue a sidecar job for every asset based on discovery or sync, though the logic is almost identical aside from linking the sidecar
* now queue sidecar jobs for each assset, though logic is mostly the same between discovery and sync
* simplified logic of filename extraction and asset instantiation
* not sure how that got deleted..
* updated code per suggestions and comments in the PR
* stat was not being used, removed the variable set
* better type checking, using in-scope variables for exif getter instead of passing in every time
* removed commented out test
* ran and resolved all lints, formats, checks, and tests
* resolved suggested change in PR
* made getExifProperty more dynamic with multiple possible args for fallbacks, fixed typo, used generic in function for better type checking
* better error handling and moving files back to positions on move or save failure
* regenerated api
* format fixes
* Added XMP documentation
* documentation typo
* Merged in main
* missed merge conflict
* more changes due to a merge
* Resolving conflicts
* added icon for sidecar jobs
---------
Co-authored-by: Jason Rasmussen <jrasm91@gmail.com>
Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
2023-05-24 21:59:30 -04:00
|
|
|
sidecarPath: null,
|
2023-01-25 11:35:28 -05:00
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
};
|
|
|
|
|
|
|
|
export const sharedLinkResponseStub = {
|
|
|
|
valid: Object.freeze<SharedLinkResponseDto>({
|
|
|
|
allowDownload: true,
|
|
|
|
allowUpload: true,
|
|
|
|
assets: [],
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: today,
|
2023-06-20 21:08:43 -04:00
|
|
|
description: null,
|
2023-05-30 15:15:56 +02:00
|
|
|
expiresAt: tomorrow,
|
2023-01-25 11:35:28 -05:00
|
|
|
id: '123',
|
2023-06-01 16:56:37 -04:00
|
|
|
key: sharedLinkBytes.toString('base64url'),
|
2023-01-25 11:35:28 -05:00
|
|
|
showExif: true,
|
|
|
|
type: SharedLinkType.ALBUM,
|
|
|
|
userId: 'admin_id',
|
|
|
|
}),
|
|
|
|
expired: Object.freeze<SharedLinkResponseDto>({
|
|
|
|
album: undefined,
|
|
|
|
allowDownload: true,
|
|
|
|
allowUpload: true,
|
|
|
|
assets: [],
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: today,
|
2023-06-20 21:08:43 -04:00
|
|
|
description: null,
|
2023-05-30 15:15:56 +02:00
|
|
|
expiresAt: yesterday,
|
2023-01-25 11:35:28 -05:00
|
|
|
id: '123',
|
2023-06-01 16:56:37 -04:00
|
|
|
key: sharedLinkBytes.toString('base64url'),
|
2023-01-25 11:35:28 -05:00
|
|
|
showExif: true,
|
|
|
|
type: SharedLinkType.ALBUM,
|
|
|
|
userId: 'admin_id',
|
|
|
|
}),
|
|
|
|
readonly: Object.freeze<SharedLinkResponseDto>({
|
|
|
|
id: '123',
|
|
|
|
userId: 'admin_id',
|
2023-06-01 16:56:37 -04:00
|
|
|
key: sharedLinkBytes.toString('base64url'),
|
2023-01-25 11:35:28 -05:00
|
|
|
type: SharedLinkType.ALBUM,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: today,
|
|
|
|
expiresAt: tomorrow,
|
2023-06-20 21:08:43 -04:00
|
|
|
description: null,
|
2023-01-25 11:35:28 -05:00
|
|
|
allowUpload: false,
|
|
|
|
allowDownload: false,
|
|
|
|
showExif: true,
|
|
|
|
album: albumResponse,
|
|
|
|
assets: [assetResponse],
|
|
|
|
}),
|
|
|
|
readonlyNoExif: Object.freeze<SharedLinkResponseDto>({
|
|
|
|
id: '123',
|
|
|
|
userId: 'admin_id',
|
2023-06-01 16:56:37 -04:00
|
|
|
key: sharedLinkBytes.toString('base64url'),
|
2023-01-25 11:35:28 -05:00
|
|
|
type: SharedLinkType.ALBUM,
|
2023-05-30 15:15:56 +02:00
|
|
|
createdAt: today,
|
|
|
|
expiresAt: tomorrow,
|
2023-06-20 21:08:43 -04:00
|
|
|
description: null,
|
2023-01-25 11:35:28 -05:00
|
|
|
allowUpload: false,
|
|
|
|
allowDownload: false,
|
2023-06-01 22:09:57 -04:00
|
|
|
showExif: false,
|
2023-01-25 11:35:28 -05:00
|
|
|
album: albumResponse,
|
|
|
|
assets: [{ ...assetResponse, exifInfo: undefined }],
|
|
|
|
}),
|
|
|
|
};
|
|
|
|
|
|
|
|
// TODO - the constructor isn't used anywhere, so not test coverage
|
|
|
|
new ExifResponseDto();
|
2023-03-18 08:44:42 -05:00
|
|
|
|
|
|
|
export const searchStub = {
|
|
|
|
emptyResults: Object.freeze<SearchResult<any>>({
|
|
|
|
total: 0,
|
|
|
|
count: 0,
|
|
|
|
page: 1,
|
|
|
|
items: [],
|
|
|
|
facets: [],
|
2023-05-17 13:07:17 -04:00
|
|
|
distances: [],
|
2023-03-18 08:44:42 -05:00
|
|
|
}),
|
|
|
|
};
|
2023-04-04 10:48:02 -04:00
|
|
|
|
2023-04-06 04:32:59 +01:00
|
|
|
const probeStubDefaultFormat: VideoFormat = {
|
|
|
|
formatName: 'mov,mp4,m4a,3gp,3g2,mj2',
|
|
|
|
formatLongName: 'QuickTime / MOV',
|
|
|
|
duration: 0,
|
|
|
|
};
|
|
|
|
|
|
|
|
const probeStubDefaultVideoStream: VideoStreamInfo[] = [
|
|
|
|
{ height: 1080, width: 1920, codecName: 'h265', codecType: 'video', frameCount: 100, rotation: 0 },
|
|
|
|
];
|
|
|
|
|
|
|
|
const probeStubDefaultAudioStream: AudioStreamInfo[] = [{ codecName: 'aac', codecType: 'audio' }];
|
|
|
|
|
|
|
|
const probeStubDefault: VideoInfo = {
|
|
|
|
format: probeStubDefaultFormat,
|
|
|
|
videoStreams: probeStubDefaultVideoStream,
|
|
|
|
audioStreams: probeStubDefaultAudioStream,
|
|
|
|
};
|
|
|
|
|
2023-04-04 10:48:02 -04:00
|
|
|
export const probeStub = {
|
2023-04-06 04:32:59 +01:00
|
|
|
noVideoStreams: Object.freeze<VideoInfo>({ ...probeStubDefault, videoStreams: [] }),
|
|
|
|
multipleVideoStreams: Object.freeze<VideoInfo>({
|
|
|
|
...probeStubDefault,
|
|
|
|
videoStreams: [
|
2023-04-04 10:48:02 -04:00
|
|
|
{
|
|
|
|
height: 1080,
|
|
|
|
width: 400,
|
|
|
|
codecName: 'h265',
|
|
|
|
codecType: 'video',
|
|
|
|
frameCount: 100,
|
|
|
|
rotation: 0,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
height: 1080,
|
|
|
|
width: 400,
|
|
|
|
codecName: 'h7000',
|
|
|
|
codecType: 'video',
|
|
|
|
frameCount: 99,
|
|
|
|
rotation: 0,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}),
|
|
|
|
noHeight: Object.freeze<VideoInfo>({
|
2023-04-06 04:32:59 +01:00
|
|
|
...probeStubDefault,
|
|
|
|
videoStreams: [
|
2023-04-04 10:48:02 -04:00
|
|
|
{
|
|
|
|
height: 0,
|
|
|
|
width: 400,
|
|
|
|
codecName: 'h265',
|
|
|
|
codecType: 'video',
|
|
|
|
frameCount: 100,
|
|
|
|
rotation: 0,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}),
|
2023-04-06 04:32:59 +01:00
|
|
|
videoStream2160p: Object.freeze<VideoInfo>({
|
|
|
|
...probeStubDefault,
|
|
|
|
videoStreams: [
|
2023-04-04 10:48:02 -04:00
|
|
|
{
|
2023-04-06 04:32:59 +01:00
|
|
|
height: 2160,
|
|
|
|
width: 3840,
|
2023-04-04 10:48:02 -04:00
|
|
|
codecName: 'h264',
|
|
|
|
codecType: 'video',
|
|
|
|
frameCount: 100,
|
|
|
|
rotation: 0,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}),
|
2023-04-06 04:32:59 +01:00
|
|
|
videoStreamVertical2160p: Object.freeze<VideoInfo>({
|
|
|
|
...probeStubDefault,
|
|
|
|
videoStreams: [
|
|
|
|
{
|
|
|
|
height: 2160,
|
|
|
|
width: 3840,
|
|
|
|
codecName: 'h264',
|
|
|
|
codecType: 'video',
|
|
|
|
frameCount: 100,
|
|
|
|
rotation: 90,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}),
|
|
|
|
audioStreamMp3: Object.freeze<VideoInfo>({
|
|
|
|
...probeStubDefault,
|
|
|
|
audioStreams: [{ codecType: 'audio', codecName: 'aac' }],
|
|
|
|
}),
|
|
|
|
matroskaContainer: Object.freeze<VideoInfo>({
|
|
|
|
...probeStubDefault,
|
|
|
|
format: {
|
|
|
|
formatName: 'matroska,webm',
|
|
|
|
formatLongName: 'Matroska / WebM',
|
|
|
|
duration: 0,
|
|
|
|
},
|
|
|
|
}),
|
2023-04-04 10:48:02 -04:00
|
|
|
};
|
2023-05-15 20:30:53 +03:00
|
|
|
|
2023-05-17 13:07:17 -04:00
|
|
|
export const personStub = {
|
|
|
|
noName: Object.freeze<PersonEntity>({
|
|
|
|
id: 'person-1',
|
|
|
|
createdAt: new Date('2021-01-01'),
|
|
|
|
updatedAt: new Date('2021-01-01'),
|
|
|
|
ownerId: userEntityStub.admin.id,
|
|
|
|
owner: userEntityStub.admin,
|
|
|
|
name: '',
|
|
|
|
thumbnailPath: '/path/to/thumbnail',
|
|
|
|
faces: [],
|
|
|
|
}),
|
|
|
|
withName: Object.freeze<PersonEntity>({
|
|
|
|
id: 'person-1',
|
|
|
|
createdAt: new Date('2021-01-01'),
|
|
|
|
updatedAt: new Date('2021-01-01'),
|
|
|
|
ownerId: userEntityStub.admin.id,
|
|
|
|
owner: userEntityStub.admin,
|
|
|
|
name: 'Person 1',
|
|
|
|
thumbnailPath: '/path/to/thumbnail',
|
|
|
|
faces: [],
|
|
|
|
}),
|
|
|
|
noThumbnail: Object.freeze<PersonEntity>({
|
|
|
|
id: 'person-1',
|
|
|
|
createdAt: new Date('2021-01-01'),
|
|
|
|
updatedAt: new Date('2021-01-01'),
|
|
|
|
ownerId: userEntityStub.admin.id,
|
|
|
|
owner: userEntityStub.admin,
|
|
|
|
name: '',
|
|
|
|
thumbnailPath: '',
|
|
|
|
faces: [],
|
|
|
|
}),
|
|
|
|
};
|
|
|
|
|
2023-05-15 20:30:53 +03:00
|
|
|
export const partnerStub = {
|
|
|
|
adminToUser1: Object.freeze<PartnerEntity>({
|
|
|
|
createdAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
updatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
sharedById: userEntityStub.admin.id,
|
|
|
|
sharedBy: userEntityStub.admin,
|
|
|
|
sharedWith: userEntityStub.user1,
|
|
|
|
sharedWithId: userEntityStub.user1.id,
|
|
|
|
}),
|
|
|
|
user1ToAdmin1: Object.freeze<PartnerEntity>({
|
|
|
|
createdAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
updatedAt: new Date('2023-02-23T05:06:29.716Z'),
|
|
|
|
sharedBy: userEntityStub.user1,
|
|
|
|
sharedById: userEntityStub.user1.id,
|
|
|
|
sharedWithId: userEntityStub.admin.id,
|
|
|
|
sharedWith: userEntityStub.admin,
|
|
|
|
}),
|
|
|
|
};
|
2023-05-17 13:07:17 -04:00
|
|
|
|
|
|
|
export const faceStub = {
|
|
|
|
face1: Object.freeze<AssetFaceEntity>({
|
|
|
|
assetId: assetEntityStub.image.id,
|
|
|
|
asset: assetEntityStub.image,
|
|
|
|
personId: personStub.withName.id,
|
|
|
|
person: personStub.withName,
|
|
|
|
embedding: [1, 2, 3, 4],
|
|
|
|
}),
|
|
|
|
};
|
2023-05-31 21:51:28 -04:00
|
|
|
|
|
|
|
export const tagStub = {
|
|
|
|
tag1: Object.freeze<TagEntity>({
|
|
|
|
id: 'tag-1',
|
|
|
|
name: 'Tag1',
|
|
|
|
type: TagType.CUSTOM,
|
|
|
|
userId: userEntityStub.admin.id,
|
|
|
|
user: userEntityStub.admin,
|
|
|
|
renameTagId: null,
|
|
|
|
assets: [],
|
|
|
|
}),
|
|
|
|
};
|
|
|
|
|
|
|
|
export const tagResponseStub = {
|
|
|
|
tag1: Object.freeze<TagResponseDto>({
|
|
|
|
id: 'tag-1',
|
|
|
|
name: 'Tag1',
|
|
|
|
type: 'CUSTOM',
|
|
|
|
userId: 'admin_id',
|
|
|
|
}),
|
|
|
|
};
|