// // AUTO-GENERATED FILE, DO NOT MODIFY! // // @dart=2.12 // 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.type, required this.id, required this.deviceAssetId, required this.ownerId, required this.deviceId, required this.originalPath, required this.originalFileName, required this.resized, required this.fileCreatedAt, required this.fileModifiedAt, required this.updatedAt, required this.isFavorite, required this.isArchived, required this.mimeType, required this.duration, this.exifInfo, this.smartInfo, this.livePhotoVideoId, this.tags = const [], this.people = const [], required this.checksum, }); AssetTypeEnum type; String id; String deviceAssetId; String ownerId; String deviceId; String originalPath; String originalFileName; bool resized; String fileCreatedAt; String fileModifiedAt; String updatedAt; bool isFavorite; bool isArchived; String? mimeType; 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; /// /// 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. /// SmartInfoResponseDto? smartInfo; String? livePhotoVideoId; List tags; List people; /// base64 encoded sha1 hash String checksum; @override bool operator ==(Object other) => identical(this, other) || other is AssetResponseDto && other.type == type && other.id == id && other.deviceAssetId == deviceAssetId && other.ownerId == ownerId && other.deviceId == deviceId && other.originalPath == originalPath && other.originalFileName == originalFileName && other.resized == resized && other.fileCreatedAt == fileCreatedAt && other.fileModifiedAt == fileModifiedAt && other.updatedAt == updatedAt && other.isFavorite == isFavorite && other.isArchived == isArchived && other.mimeType == mimeType && other.duration == duration && other.exifInfo == exifInfo && other.smartInfo == smartInfo && other.livePhotoVideoId == livePhotoVideoId && other.tags == tags && other.people == people && other.checksum == checksum; @override int get hashCode => // ignore: unnecessary_parenthesis (type.hashCode) + (id.hashCode) + (deviceAssetId.hashCode) + (ownerId.hashCode) + (deviceId.hashCode) + (originalPath.hashCode) + (originalFileName.hashCode) + (resized.hashCode) + (fileCreatedAt.hashCode) + (fileModifiedAt.hashCode) + (updatedAt.hashCode) + (isFavorite.hashCode) + (isArchived.hashCode) + (mimeType == null ? 0 : mimeType!.hashCode) + (duration.hashCode) + (exifInfo == null ? 0 : exifInfo!.hashCode) + (smartInfo == null ? 0 : smartInfo!.hashCode) + (livePhotoVideoId == null ? 0 : livePhotoVideoId!.hashCode) + (tags.hashCode) + (people.hashCode) + (checksum.hashCode); @override String toString() => 'AssetResponseDto[type=$type, id=$id, deviceAssetId=$deviceAssetId, ownerId=$ownerId, deviceId=$deviceId, originalPath=$originalPath, originalFileName=$originalFileName, resized=$resized, fileCreatedAt=$fileCreatedAt, fileModifiedAt=$fileModifiedAt, updatedAt=$updatedAt, isFavorite=$isFavorite, isArchived=$isArchived, mimeType=$mimeType, duration=$duration, exifInfo=$exifInfo, smartInfo=$smartInfo, livePhotoVideoId=$livePhotoVideoId, tags=$tags, people=$people, checksum=$checksum]'; Map toJson() { final json = {}; json[r'type'] = this.type; json[r'id'] = this.id; json[r'deviceAssetId'] = this.deviceAssetId; json[r'ownerId'] = this.ownerId; json[r'deviceId'] = this.deviceId; json[r'originalPath'] = this.originalPath; json[r'originalFileName'] = this.originalFileName; json[r'resized'] = this.resized; json[r'fileCreatedAt'] = this.fileCreatedAt; json[r'fileModifiedAt'] = this.fileModifiedAt; json[r'updatedAt'] = this.updatedAt; json[r'isFavorite'] = this.isFavorite; json[r'isArchived'] = this.isArchived; if (this.mimeType != null) { json[r'mimeType'] = this.mimeType; } else { // json[r'mimeType'] = null; } json[r'duration'] = this.duration; if (this.exifInfo != null) { json[r'exifInfo'] = this.exifInfo; } else { // json[r'exifInfo'] = null; } if (this.smartInfo != null) { json[r'smartInfo'] = this.smartInfo; } else { // json[r'smartInfo'] = null; } if (this.livePhotoVideoId != null) { json[r'livePhotoVideoId'] = this.livePhotoVideoId; } else { // json[r'livePhotoVideoId'] = null; } json[r'tags'] = this.tags; json[r'people'] = this.people; json[r'checksum'] = this.checksum; 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) { if (value is Map) { final json = value.cast(); // Ensure that the map contains the required keys. // Note 1: the values aren't checked for validity beyond being non-null. // Note 2: this code is stripped in release mode! assert(() { requiredKeys.forEach((key) { assert(json.containsKey(key), 'Required key "AssetResponseDto[$key]" is missing from JSON.'); assert(json[key] != null, 'Required key "AssetResponseDto[$key]" has a null value in JSON.'); }); return true; }()); return AssetResponseDto( type: AssetTypeEnum.fromJson(json[r'type'])!, id: mapValueOfType(json, r'id')!, deviceAssetId: mapValueOfType(json, r'deviceAssetId')!, ownerId: mapValueOfType(json, r'ownerId')!, deviceId: mapValueOfType(json, r'deviceId')!, originalPath: mapValueOfType(json, r'originalPath')!, originalFileName: mapValueOfType(json, r'originalFileName')!, resized: mapValueOfType(json, r'resized')!, fileCreatedAt: mapValueOfType(json, r'fileCreatedAt')!, fileModifiedAt: mapValueOfType(json, r'fileModifiedAt')!, updatedAt: mapValueOfType(json, r'updatedAt')!, isFavorite: mapValueOfType(json, r'isFavorite')!, isArchived: mapValueOfType(json, r'isArchived')!, mimeType: mapValueOfType(json, r'mimeType'), duration: mapValueOfType(json, r'duration')!, exifInfo: ExifResponseDto.fromJson(json[r'exifInfo']), smartInfo: SmartInfoResponseDto.fromJson(json[r'smartInfo']), livePhotoVideoId: mapValueOfType(json, r'livePhotoVideoId'), tags: TagResponseDto.listFromJson(json[r'tags']), people: PersonResponseDto.listFromJson(json[r'people']), checksum: mapValueOfType(json, r'checksum')!, ); } return null; } static List listFromJson(dynamic json, {bool growable = false,}) { final result = []; 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 mapFromJson(dynamic json) { final map = {}; if (json is Map && json.isNotEmpty) { json = json.cast(); // 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> mapListFromJson(dynamic json, {bool growable = false,}) { final map = >{}; if (json is Map && json.isNotEmpty) { // ignore: parameter_assignments json = json.cast(); 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 = { 'type', 'id', 'deviceAssetId', 'ownerId', 'deviceId', 'originalPath', 'originalFileName', 'resized', 'fileCreatedAt', 'fileModifiedAt', 'updatedAt', 'isFavorite', 'isArchived', 'mimeType', 'duration', 'checksum', }; }