mirror of
https://github.com/immich-app/immich.git
synced 2026-02-04 17:01:13 +03:00
* faces * add openapi descriptions * remove dto descriptions * gen openapi * dtos * fix dtos * fix more * fix build * more * complete dtos * descriptions on rebase * gen rebase * revert correct integer type conversion * gen after revert * revert correct nullables * regen after revert * actually incorrect adding default here * revert correct number type conversion * regen after revert * revert nullable usage * regen fully * readd some comments * one more * one more * use enum * add missing * add missing controllers * add missing dtos * complete it * more * describe global key and slug * add remaining body and param descriptions * lint and format * cleanup * response and schema descriptions * test patch according to suggestion * revert added api response objects * revert added api body objects * revert added api param object * revert added api query objects * revert reorganized http code objects * revert reorganize ApiOkResponse objects * revert added api response objects (2) * revert added api tag object * revert added api schema objects * migrate missing asset.dto.ts * regenerate openapi builds * delete generated mustache files * remove descriptions from properties that are schemas * lint * revert nullable type changes * revert int/num type changes * remove explicit default * readd comment * lint * pr fixes * last bits and pieces * lint and format * chore: remove rejected patches * fix: deleting asset from asset-viewer on search results (#25596) * fix: escape handling in search asset viewer (#25621) * fix: correctly show owner in album options modal (#25618) * fix: validation issues * fix: validation issues --------- Co-authored-by: Jason Rasmussen <jason@rasm.me> Co-authored-by: Min Idzelis <min123@gmail.com> Co-authored-by: Daniel Dietzler <36593685+danieldietzler@users.noreply.github.com> Co-authored-by: Paul Makles <me@insrt.uk>
462 lines
16 KiB
Dart
Generated
462 lines
16 KiB
Dart
Generated
//
|
|
// AUTO-GENERATED FILE, DO NOT MODIFY!
|
|
//
|
|
// @dart=2.18
|
|
|
|
// ignore_for_file: unused_element, unused_import
|
|
// ignore_for_file: always_put_required_named_parameters_first
|
|
// ignore_for_file: constant_identifier_names
|
|
// ignore_for_file: lines_longer_than_80_chars
|
|
|
|
part of openapi.api;
|
|
|
|
class AssetResponseDto {
|
|
/// Returns a new [AssetResponseDto] instance.
|
|
AssetResponseDto({
|
|
required this.checksum,
|
|
required this.createdAt,
|
|
required this.deviceAssetId,
|
|
required this.deviceId,
|
|
this.duplicateId,
|
|
required this.duration,
|
|
this.exifInfo,
|
|
required this.fileCreatedAt,
|
|
required this.fileModifiedAt,
|
|
required this.hasMetadata,
|
|
required this.height,
|
|
required this.id,
|
|
required this.isArchived,
|
|
required this.isEdited,
|
|
required this.isFavorite,
|
|
required this.isOffline,
|
|
required this.isTrashed,
|
|
this.libraryId,
|
|
this.livePhotoVideoId,
|
|
required this.localDateTime,
|
|
required this.originalFileName,
|
|
this.originalMimeType,
|
|
required this.originalPath,
|
|
this.owner,
|
|
required this.ownerId,
|
|
this.people = const [],
|
|
this.resized,
|
|
this.stack,
|
|
this.tags = const [],
|
|
required this.thumbhash,
|
|
required this.type,
|
|
this.unassignedFaces = const [],
|
|
required this.updatedAt,
|
|
required this.visibility,
|
|
required this.width,
|
|
});
|
|
|
|
/// Base64 encoded SHA1 hash
|
|
String checksum;
|
|
|
|
/// The UTC timestamp when the asset was originally uploaded to Immich.
|
|
DateTime createdAt;
|
|
|
|
/// Device asset ID
|
|
String deviceAssetId;
|
|
|
|
/// Device ID
|
|
String deviceId;
|
|
|
|
/// Duplicate group ID
|
|
String? duplicateId;
|
|
|
|
/// Video duration (for videos)
|
|
String duration;
|
|
|
|
///
|
|
/// Please note: This property should have been non-nullable! Since the specification file
|
|
/// does not include a default value (using the "default:" property), however, the generated
|
|
/// source code must fall back to having a nullable type.
|
|
/// Consider adding a "default:" property in the specification file to hide this note.
|
|
///
|
|
ExifResponseDto? exifInfo;
|
|
|
|
/// The actual UTC timestamp when the file was created/captured, preserving timezone information. This is the authoritative timestamp for chronological sorting within timeline groups. Combined with timezone data, this can be used to determine the exact moment the photo was taken.
|
|
DateTime fileCreatedAt;
|
|
|
|
/// The UTC timestamp when the file was last modified on the filesystem. This reflects the last time the physical file was changed, which may be different from when the photo was originally taken.
|
|
DateTime fileModifiedAt;
|
|
|
|
/// Whether asset has metadata
|
|
bool hasMetadata;
|
|
|
|
/// Asset height
|
|
num? height;
|
|
|
|
/// Asset ID
|
|
String id;
|
|
|
|
/// Is archived
|
|
bool isArchived;
|
|
|
|
/// Is edited
|
|
bool isEdited;
|
|
|
|
/// Is favorite
|
|
bool isFavorite;
|
|
|
|
/// Is offline
|
|
bool isOffline;
|
|
|
|
/// Is trashed
|
|
bool isTrashed;
|
|
|
|
/// Library ID
|
|
String? libraryId;
|
|
|
|
/// Live photo video ID
|
|
String? livePhotoVideoId;
|
|
|
|
/// The local date and time when the photo/video was taken, derived from EXIF metadata. This represents the photographer's local time regardless of timezone, stored as a timezone-agnostic timestamp. Used for timeline grouping by \"local\" days and months.
|
|
DateTime localDateTime;
|
|
|
|
/// Original file name
|
|
String originalFileName;
|
|
|
|
/// Original MIME type
|
|
///
|
|
/// Please note: This property should have been non-nullable! Since the specification file
|
|
/// does not include a default value (using the "default:" property), however, the generated
|
|
/// source code must fall back to having a nullable type.
|
|
/// Consider adding a "default:" property in the specification file to hide this note.
|
|
///
|
|
String? originalMimeType;
|
|
|
|
/// Original file path
|
|
String originalPath;
|
|
|
|
///
|
|
/// Please note: This property should have been non-nullable! Since the specification file
|
|
/// does not include a default value (using the "default:" property), however, the generated
|
|
/// source code must fall back to having a nullable type.
|
|
/// Consider adding a "default:" property in the specification file to hide this note.
|
|
///
|
|
UserResponseDto? owner;
|
|
|
|
/// Owner user ID
|
|
String ownerId;
|
|
|
|
List<PersonWithFacesResponseDto> people;
|
|
|
|
/// Is resized
|
|
///
|
|
/// Please note: This property should have been non-nullable! Since the specification file
|
|
/// does not include a default value (using the "default:" property), however, the generated
|
|
/// source code must fall back to having a nullable type.
|
|
/// Consider adding a "default:" property in the specification file to hide this note.
|
|
///
|
|
bool? resized;
|
|
|
|
AssetStackResponseDto? stack;
|
|
|
|
List<TagResponseDto> tags;
|
|
|
|
/// Thumbhash for thumbnail generation
|
|
String? thumbhash;
|
|
|
|
/// Asset type
|
|
AssetTypeEnum type;
|
|
|
|
List<AssetFaceWithoutPersonResponseDto> unassignedFaces;
|
|
|
|
/// The UTC timestamp when the asset record was last updated in the database. This is automatically maintained by the database and reflects when any field in the asset was last modified.
|
|
DateTime updatedAt;
|
|
|
|
/// Asset visibility
|
|
AssetVisibility visibility;
|
|
|
|
/// Asset width
|
|
num? width;
|
|
|
|
@override
|
|
bool operator ==(Object other) => identical(this, other) || other is AssetResponseDto &&
|
|
other.checksum == checksum &&
|
|
other.createdAt == createdAt &&
|
|
other.deviceAssetId == deviceAssetId &&
|
|
other.deviceId == deviceId &&
|
|
other.duplicateId == duplicateId &&
|
|
other.duration == duration &&
|
|
other.exifInfo == exifInfo &&
|
|
other.fileCreatedAt == fileCreatedAt &&
|
|
other.fileModifiedAt == fileModifiedAt &&
|
|
other.hasMetadata == hasMetadata &&
|
|
other.height == height &&
|
|
other.id == id &&
|
|
other.isArchived == isArchived &&
|
|
other.isEdited == isEdited &&
|
|
other.isFavorite == isFavorite &&
|
|
other.isOffline == isOffline &&
|
|
other.isTrashed == isTrashed &&
|
|
other.libraryId == libraryId &&
|
|
other.livePhotoVideoId == livePhotoVideoId &&
|
|
other.localDateTime == localDateTime &&
|
|
other.originalFileName == originalFileName &&
|
|
other.originalMimeType == originalMimeType &&
|
|
other.originalPath == originalPath &&
|
|
other.owner == owner &&
|
|
other.ownerId == ownerId &&
|
|
_deepEquality.equals(other.people, people) &&
|
|
other.resized == resized &&
|
|
other.stack == stack &&
|
|
_deepEquality.equals(other.tags, tags) &&
|
|
other.thumbhash == thumbhash &&
|
|
other.type == type &&
|
|
_deepEquality.equals(other.unassignedFaces, unassignedFaces) &&
|
|
other.updatedAt == updatedAt &&
|
|
other.visibility == visibility &&
|
|
other.width == width;
|
|
|
|
@override
|
|
int get hashCode =>
|
|
// ignore: unnecessary_parenthesis
|
|
(checksum.hashCode) +
|
|
(createdAt.hashCode) +
|
|
(deviceAssetId.hashCode) +
|
|
(deviceId.hashCode) +
|
|
(duplicateId == null ? 0 : duplicateId!.hashCode) +
|
|
(duration.hashCode) +
|
|
(exifInfo == null ? 0 : exifInfo!.hashCode) +
|
|
(fileCreatedAt.hashCode) +
|
|
(fileModifiedAt.hashCode) +
|
|
(hasMetadata.hashCode) +
|
|
(height == null ? 0 : height!.hashCode) +
|
|
(id.hashCode) +
|
|
(isArchived.hashCode) +
|
|
(isEdited.hashCode) +
|
|
(isFavorite.hashCode) +
|
|
(isOffline.hashCode) +
|
|
(isTrashed.hashCode) +
|
|
(libraryId == null ? 0 : libraryId!.hashCode) +
|
|
(livePhotoVideoId == null ? 0 : livePhotoVideoId!.hashCode) +
|
|
(localDateTime.hashCode) +
|
|
(originalFileName.hashCode) +
|
|
(originalMimeType == null ? 0 : originalMimeType!.hashCode) +
|
|
(originalPath.hashCode) +
|
|
(owner == null ? 0 : owner!.hashCode) +
|
|
(ownerId.hashCode) +
|
|
(people.hashCode) +
|
|
(resized == null ? 0 : resized!.hashCode) +
|
|
(stack == null ? 0 : stack!.hashCode) +
|
|
(tags.hashCode) +
|
|
(thumbhash == null ? 0 : thumbhash!.hashCode) +
|
|
(type.hashCode) +
|
|
(unassignedFaces.hashCode) +
|
|
(updatedAt.hashCode) +
|
|
(visibility.hashCode) +
|
|
(width == null ? 0 : width!.hashCode);
|
|
|
|
@override
|
|
String toString() => 'AssetResponseDto[checksum=$checksum, createdAt=$createdAt, deviceAssetId=$deviceAssetId, deviceId=$deviceId, duplicateId=$duplicateId, duration=$duration, exifInfo=$exifInfo, fileCreatedAt=$fileCreatedAt, fileModifiedAt=$fileModifiedAt, hasMetadata=$hasMetadata, height=$height, id=$id, isArchived=$isArchived, isEdited=$isEdited, isFavorite=$isFavorite, isOffline=$isOffline, isTrashed=$isTrashed, libraryId=$libraryId, livePhotoVideoId=$livePhotoVideoId, localDateTime=$localDateTime, originalFileName=$originalFileName, originalMimeType=$originalMimeType, originalPath=$originalPath, owner=$owner, ownerId=$ownerId, people=$people, resized=$resized, stack=$stack, tags=$tags, thumbhash=$thumbhash, type=$type, unassignedFaces=$unassignedFaces, updatedAt=$updatedAt, visibility=$visibility, width=$width]';
|
|
|
|
Map<String, dynamic> toJson() {
|
|
final json = <String, dynamic>{};
|
|
json[r'checksum'] = this.checksum;
|
|
json[r'createdAt'] = this.createdAt.toUtc().toIso8601String();
|
|
json[r'deviceAssetId'] = this.deviceAssetId;
|
|
json[r'deviceId'] = this.deviceId;
|
|
if (this.duplicateId != null) {
|
|
json[r'duplicateId'] = this.duplicateId;
|
|
} else {
|
|
// json[r'duplicateId'] = null;
|
|
}
|
|
json[r'duration'] = this.duration;
|
|
if (this.exifInfo != null) {
|
|
json[r'exifInfo'] = this.exifInfo;
|
|
} else {
|
|
// json[r'exifInfo'] = null;
|
|
}
|
|
json[r'fileCreatedAt'] = this.fileCreatedAt.toUtc().toIso8601String();
|
|
json[r'fileModifiedAt'] = this.fileModifiedAt.toUtc().toIso8601String();
|
|
json[r'hasMetadata'] = this.hasMetadata;
|
|
if (this.height != null) {
|
|
json[r'height'] = this.height;
|
|
} else {
|
|
// json[r'height'] = null;
|
|
}
|
|
json[r'id'] = this.id;
|
|
json[r'isArchived'] = this.isArchived;
|
|
json[r'isEdited'] = this.isEdited;
|
|
json[r'isFavorite'] = this.isFavorite;
|
|
json[r'isOffline'] = this.isOffline;
|
|
json[r'isTrashed'] = this.isTrashed;
|
|
if (this.libraryId != null) {
|
|
json[r'libraryId'] = this.libraryId;
|
|
} else {
|
|
// json[r'libraryId'] = null;
|
|
}
|
|
if (this.livePhotoVideoId != null) {
|
|
json[r'livePhotoVideoId'] = this.livePhotoVideoId;
|
|
} else {
|
|
// json[r'livePhotoVideoId'] = null;
|
|
}
|
|
json[r'localDateTime'] = this.localDateTime.toUtc().toIso8601String();
|
|
json[r'originalFileName'] = this.originalFileName;
|
|
if (this.originalMimeType != null) {
|
|
json[r'originalMimeType'] = this.originalMimeType;
|
|
} else {
|
|
// json[r'originalMimeType'] = null;
|
|
}
|
|
json[r'originalPath'] = this.originalPath;
|
|
if (this.owner != null) {
|
|
json[r'owner'] = this.owner;
|
|
} else {
|
|
// json[r'owner'] = null;
|
|
}
|
|
json[r'ownerId'] = this.ownerId;
|
|
json[r'people'] = this.people;
|
|
if (this.resized != null) {
|
|
json[r'resized'] = this.resized;
|
|
} else {
|
|
// json[r'resized'] = null;
|
|
}
|
|
if (this.stack != null) {
|
|
json[r'stack'] = this.stack;
|
|
} else {
|
|
// json[r'stack'] = null;
|
|
}
|
|
json[r'tags'] = this.tags;
|
|
if (this.thumbhash != null) {
|
|
json[r'thumbhash'] = this.thumbhash;
|
|
} else {
|
|
// json[r'thumbhash'] = null;
|
|
}
|
|
json[r'type'] = this.type;
|
|
json[r'unassignedFaces'] = this.unassignedFaces;
|
|
json[r'updatedAt'] = this.updatedAt.toUtc().toIso8601String();
|
|
json[r'visibility'] = this.visibility;
|
|
if (this.width != null) {
|
|
json[r'width'] = this.width;
|
|
} else {
|
|
// json[r'width'] = null;
|
|
}
|
|
return json;
|
|
}
|
|
|
|
/// Returns a new [AssetResponseDto] instance and imports its values from
|
|
/// [value] if it's a [Map], null otherwise.
|
|
// ignore: prefer_constructors_over_static_methods
|
|
static AssetResponseDto? fromJson(dynamic value) {
|
|
upgradeDto(value, "AssetResponseDto");
|
|
if (value is Map) {
|
|
final json = value.cast<String, dynamic>();
|
|
|
|
return AssetResponseDto(
|
|
checksum: mapValueOfType<String>(json, r'checksum')!,
|
|
createdAt: mapDateTime(json, r'createdAt', r'')!,
|
|
deviceAssetId: mapValueOfType<String>(json, r'deviceAssetId')!,
|
|
deviceId: mapValueOfType<String>(json, r'deviceId')!,
|
|
duplicateId: mapValueOfType<String>(json, r'duplicateId'),
|
|
duration: mapValueOfType<String>(json, r'duration')!,
|
|
exifInfo: ExifResponseDto.fromJson(json[r'exifInfo']),
|
|
fileCreatedAt: mapDateTime(json, r'fileCreatedAt', r'')!,
|
|
fileModifiedAt: mapDateTime(json, r'fileModifiedAt', r'')!,
|
|
hasMetadata: mapValueOfType<bool>(json, r'hasMetadata')!,
|
|
height: json[r'height'] == null
|
|
? null
|
|
: num.parse('${json[r'height']}'),
|
|
id: mapValueOfType<String>(json, r'id')!,
|
|
isArchived: mapValueOfType<bool>(json, r'isArchived')!,
|
|
isEdited: mapValueOfType<bool>(json, r'isEdited')!,
|
|
isFavorite: mapValueOfType<bool>(json, r'isFavorite')!,
|
|
isOffline: mapValueOfType<bool>(json, r'isOffline')!,
|
|
isTrashed: mapValueOfType<bool>(json, r'isTrashed')!,
|
|
libraryId: mapValueOfType<String>(json, r'libraryId'),
|
|
livePhotoVideoId: mapValueOfType<String>(json, r'livePhotoVideoId'),
|
|
localDateTime: mapDateTime(json, r'localDateTime', r'')!,
|
|
originalFileName: mapValueOfType<String>(json, r'originalFileName')!,
|
|
originalMimeType: mapValueOfType<String>(json, r'originalMimeType'),
|
|
originalPath: mapValueOfType<String>(json, r'originalPath')!,
|
|
owner: UserResponseDto.fromJson(json[r'owner']),
|
|
ownerId: mapValueOfType<String>(json, r'ownerId')!,
|
|
people: PersonWithFacesResponseDto.listFromJson(json[r'people']),
|
|
resized: mapValueOfType<bool>(json, r'resized'),
|
|
stack: AssetStackResponseDto.fromJson(json[r'stack']),
|
|
tags: TagResponseDto.listFromJson(json[r'tags']),
|
|
thumbhash: mapValueOfType<String>(json, r'thumbhash'),
|
|
type: AssetTypeEnum.fromJson(json[r'type'])!,
|
|
unassignedFaces: AssetFaceWithoutPersonResponseDto.listFromJson(json[r'unassignedFaces']),
|
|
updatedAt: mapDateTime(json, r'updatedAt', r'')!,
|
|
visibility: AssetVisibility.fromJson(json[r'visibility'])!,
|
|
width: json[r'width'] == null
|
|
? null
|
|
: num.parse('${json[r'width']}'),
|
|
);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
static List<AssetResponseDto> listFromJson(dynamic json, {bool growable = false,}) {
|
|
final result = <AssetResponseDto>[];
|
|
if (json is List && json.isNotEmpty) {
|
|
for (final row in json) {
|
|
final value = AssetResponseDto.fromJson(row);
|
|
if (value != null) {
|
|
result.add(value);
|
|
}
|
|
}
|
|
}
|
|
return result.toList(growable: growable);
|
|
}
|
|
|
|
static Map<String, AssetResponseDto> mapFromJson(dynamic json) {
|
|
final map = <String, AssetResponseDto>{};
|
|
if (json is Map && json.isNotEmpty) {
|
|
json = json.cast<String, dynamic>(); // ignore: parameter_assignments
|
|
for (final entry in json.entries) {
|
|
final value = AssetResponseDto.fromJson(entry.value);
|
|
if (value != null) {
|
|
map[entry.key] = value;
|
|
}
|
|
}
|
|
}
|
|
return map;
|
|
}
|
|
|
|
// maps a json object with a list of AssetResponseDto-objects as value to a dart map
|
|
static Map<String, List<AssetResponseDto>> mapListFromJson(dynamic json, {bool growable = false,}) {
|
|
final map = <String, List<AssetResponseDto>>{};
|
|
if (json is Map && json.isNotEmpty) {
|
|
// ignore: parameter_assignments
|
|
json = json.cast<String, dynamic>();
|
|
for (final entry in json.entries) {
|
|
map[entry.key] = AssetResponseDto.listFromJson(entry.value, growable: growable,);
|
|
}
|
|
}
|
|
return map;
|
|
}
|
|
|
|
/// The list of required keys that must be present in a JSON.
|
|
static const requiredKeys = <String>{
|
|
'checksum',
|
|
'createdAt',
|
|
'deviceAssetId',
|
|
'deviceId',
|
|
'duration',
|
|
'fileCreatedAt',
|
|
'fileModifiedAt',
|
|
'hasMetadata',
|
|
'height',
|
|
'id',
|
|
'isArchived',
|
|
'isEdited',
|
|
'isFavorite',
|
|
'isOffline',
|
|
'isTrashed',
|
|
'localDateTime',
|
|
'originalFileName',
|
|
'originalPath',
|
|
'ownerId',
|
|
'thumbhash',
|
|
'type',
|
|
'updatedAt',
|
|
'visibility',
|
|
'width',
|
|
};
|
|
}
|
|
|