// // 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 SharedLinkResponseDto { /// Returns a new [SharedLinkResponseDto] instance. SharedLinkResponseDto({ required this.type, required this.id, required this.description, required this.userId, required this.key, required this.createdAt, required this.expiresAt, this.assets = const [], this.album, required this.allowUpload, required this.allowDownload, required this.showExif, }); SharedLinkType type; String id; String? description; String userId; String key; DateTime createdAt; DateTime? expiresAt; List assets; /// /// 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. /// AlbumResponseDto? album; bool allowUpload; bool allowDownload; bool showExif; @override bool operator ==(Object other) => identical(this, other) || other is SharedLinkResponseDto && other.type == type && other.id == id && other.description == description && other.userId == userId && other.key == key && other.createdAt == createdAt && other.expiresAt == expiresAt && other.assets == assets && other.album == album && other.allowUpload == allowUpload && other.allowDownload == allowDownload && other.showExif == showExif; @override int get hashCode => // ignore: unnecessary_parenthesis (type.hashCode) + (id.hashCode) + (description == null ? 0 : description!.hashCode) + (userId.hashCode) + (key.hashCode) + (createdAt.hashCode) + (expiresAt == null ? 0 : expiresAt!.hashCode) + (assets.hashCode) + (album == null ? 0 : album!.hashCode) + (allowUpload.hashCode) + (allowDownload.hashCode) + (showExif.hashCode); @override String toString() => 'SharedLinkResponseDto[type=$type, id=$id, description=$description, userId=$userId, key=$key, createdAt=$createdAt, expiresAt=$expiresAt, assets=$assets, album=$album, allowUpload=$allowUpload, allowDownload=$allowDownload, showExif=$showExif]'; Map toJson() { final json = {}; json[r'type'] = this.type; json[r'id'] = this.id; if (this.description != null) { json[r'description'] = this.description; } else { // json[r'description'] = null; } json[r'userId'] = this.userId; json[r'key'] = this.key; json[r'createdAt'] = this.createdAt.toUtc().toIso8601String(); if (this.expiresAt != null) { json[r'expiresAt'] = this.expiresAt!.toUtc().toIso8601String(); } else { // json[r'expiresAt'] = null; } json[r'assets'] = this.assets; if (this.album != null) { json[r'album'] = this.album; } else { // json[r'album'] = null; } json[r'allowUpload'] = this.allowUpload; json[r'allowDownload'] = this.allowDownload; json[r'showExif'] = this.showExif; return json; } /// Returns a new [SharedLinkResponseDto] instance and imports its values from /// [value] if it's a [Map], null otherwise. // ignore: prefer_constructors_over_static_methods static SharedLinkResponseDto? 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 "SharedLinkResponseDto[$key]" is missing from JSON.'); // assert(json[key] != null, 'Required key "SharedLinkResponseDto[$key]" has a null value in JSON.'); }); return true; }()); return SharedLinkResponseDto( type: SharedLinkType.fromJson(json[r'type'])!, id: mapValueOfType(json, r'id')!, description: mapValueOfType(json, r'description'), userId: mapValueOfType(json, r'userId')!, key: mapValueOfType(json, r'key')!, createdAt: mapDateTime(json, r'createdAt', '')!, expiresAt: mapDateTime(json, r'expiresAt', ''), assets: AssetResponseDto.listFromJson(json[r'assets']), album: AlbumResponseDto.fromJson(json[r'album']), allowUpload: mapValueOfType(json, r'allowUpload')!, allowDownload: mapValueOfType(json, r'allowDownload')!, showExif: mapValueOfType(json, r'showExif')!, ); } 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 = SharedLinkResponseDto.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 = SharedLinkResponseDto.fromJson(entry.value); if (value != null) { map[entry.key] = value; } } } return map; } // maps a json object with a list of SharedLinkResponseDto-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] = SharedLinkResponseDto.listFromJson(entry.value, growable: growable,); } } return map; } /// The list of required keys that must be present in a JSON. static const requiredKeys = { 'type', 'id', 'description', 'userId', 'key', 'createdAt', 'expiresAt', 'assets', 'allowUpload', 'allowDownload', 'showExif', }; }