mirror of
				https://github.com/KevinMidboe/immich.git
				synced 2025-10-29 17:40:28 +00:00 
			
		
		
		
	* refactor(server): delete assets endpoint * fix: formatting * chore: cleanup * chore: open api * chore(mobile): replace DeleteAssetDTO with BulkIdsDTOs * feat: trash an asset * chore(server): formatting * chore: open api * chore: wording * chore: open-api * feat(server): add withDeleted to getAssets queries * WIP: mobile-recycle-bin * feat(server): recycle-bin to system config * feat(web): use recycle-bin system config * chore(server): domain assetcore removed * chore(server): rename recycle-bin to trash * chore(web): rename recycle-bin to trash * chore(server): always send soft deleted assets for getAllByUserId * chore(web): formatting * feat(server): permanent delete assets older than trashed period * feat(web): trash empty placeholder image * feat(server): empty trash * feat(web): empty trash * WIP: mobile-recycle-bin * refactor(server): empty / restore trash to separate endpoint * test(server): handle failures * test(server): fix e2e server-info test * test(server): deletion test refactor * feat(mobile): use map settings from server-config to enable / disable map * feat(mobile): trash asset * fix(server): operations on assets in trash * feat(web): show trash statistics * fix(web): handle trash enabled * fix(mobile): restore updates from trash * fix(server): ignore trashed assets for person * fix(server): add / remove search index when trashed / restored * chore(web): format * fix(server): asset service test * fix(server): include trashed assts for duplicates from uploads * feat(mobile): no dialog for trash, always dialog for permanent delete * refactor(mobile): use isar where instead of dart filter * refactor(mobile): asset provide - handle deletes in single db txn * chore(mobile): review changes * feat(web): confirmation before empty trash * server: review changes * fix(server): handle library changes * fix: filter external assets from getting trashed / deleted * fix(server): empty-bin * feat: broadcast config update events through ws * change order of trash button on mobile * styling * fix(mobile): do not show trashed toast for local only assets --------- Co-authored-by: Jason Rasmussen <jrasm91@gmail.com> Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
		
			
				
	
	
		
			162 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
		
			Generated
		
	
	
			
		
		
	
	
			162 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
		
			Generated
		
	
	
| //
 | |
| // 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 QueryParam {
 | |
|   const QueryParam(this.name, this.value);
 | |
| 
 | |
|   final String name;
 | |
|   final String value;
 | |
| 
 | |
|   @override
 | |
|   String toString() => '${Uri.encodeQueryComponent(name)}=${Uri.encodeQueryComponent(value)}';
 | |
| }
 | |
| 
 | |
| // Ported from the Java version.
 | |
| Iterable<QueryParam> _queryParams(String collectionFormat, String name, dynamic value,) {
 | |
|   // Assertions to run in debug mode only.
 | |
|   assert(name.isNotEmpty, 'Parameter cannot be an empty string.');
 | |
| 
 | |
|   final params = <QueryParam>[];
 | |
| 
 | |
|   if (value is List) {
 | |
|     if (collectionFormat == 'multi') {
 | |
|       return value.map((dynamic v) => QueryParam(name, parameterToString(v)),);
 | |
|     }
 | |
| 
 | |
|     // Default collection format is 'csv'.
 | |
|     if (collectionFormat.isEmpty) {
 | |
|       collectionFormat = 'csv'; // ignore: parameter_assignments
 | |
|     }
 | |
| 
 | |
|     final delimiter = _delimiters[collectionFormat] ?? ',';
 | |
| 
 | |
|     params.add(QueryParam(name, value.map<dynamic>(parameterToString).join(delimiter),));
 | |
|   } else if (value != null) {
 | |
|     params.add(QueryParam(name, parameterToString(value)));
 | |
|   }
 | |
| 
 | |
|   return params;
 | |
| }
 | |
| 
 | |
| /// Format the given parameter object into a [String].
 | |
| String parameterToString(dynamic value) {
 | |
|   if (value == null) {
 | |
|     return '';
 | |
|   }
 | |
|   if (value is DateTime) {
 | |
|     return value.toUtc().toIso8601String();
 | |
|   }
 | |
|   if (value is AssetJobName) {
 | |
|     return AssetJobNameTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is AssetTypeEnum) {
 | |
|     return AssetTypeEnumTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is AudioCodec) {
 | |
|     return AudioCodecTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is CLIPMode) {
 | |
|     return CLIPModeTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is CQMode) {
 | |
|     return CQModeTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is CitiesFile) {
 | |
|     return CitiesFileTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is Colorspace) {
 | |
|     return ColorspaceTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is EntityType) {
 | |
|     return EntityTypeTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is JobCommand) {
 | |
|     return JobCommandTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is JobName) {
 | |
|     return JobNameTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is LibraryType) {
 | |
|     return LibraryTypeTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is ModelType) {
 | |
|     return ModelTypeTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is SharedLinkType) {
 | |
|     return SharedLinkTypeTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is TagTypeEnum) {
 | |
|     return TagTypeEnumTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is ThumbnailFormat) {
 | |
|     return ThumbnailFormatTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is TimeBucketSize) {
 | |
|     return TimeBucketSizeTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is ToneMapping) {
 | |
|     return ToneMappingTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is TranscodeHWAccel) {
 | |
|     return TranscodeHWAccelTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is TranscodePolicy) {
 | |
|     return TranscodePolicyTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   if (value is VideoCodec) {
 | |
|     return VideoCodecTypeTransformer().encode(value).toString();
 | |
|   }
 | |
|   return value.toString();
 | |
| }
 | |
| 
 | |
| /// Returns the decoded body as UTF-8 if the given headers indicate an 'application/json'
 | |
| /// content type. Otherwise, returns the decoded body as decoded by dart:http package.
 | |
| Future<String> _decodeBodyBytes(Response response) async {
 | |
|   final contentType = response.headers['content-type'];
 | |
|   return contentType != null && contentType.toLowerCase().startsWith('application/json')
 | |
|     ? response.bodyBytes.isEmpty ? '' : utf8.decode(response.bodyBytes)
 | |
|     : response.body;
 | |
| }
 | |
| 
 | |
| /// Returns a valid [T] value found at the specified Map [key], null otherwise.
 | |
| T? mapValueOfType<T>(dynamic map, String key) {
 | |
|   final dynamic value = map is Map ? map[key] : null;
 | |
|   return value is T ? value : null;
 | |
| }
 | |
| 
 | |
| /// Returns a valid Map<K, V> found at the specified Map [key], null otherwise.
 | |
| Map<K, V>? mapCastOfType<K, V>(dynamic map, String key) {
 | |
|   final dynamic value = map is Map ? map[key] : null;
 | |
|   return value is Map ? value.cast<K, V>() : null;
 | |
| }
 | |
| 
 | |
| /// Returns a valid [DateTime] found at the specified Map [key], null otherwise.
 | |
| DateTime? mapDateTime(dynamic map, String key, [String? pattern]) {
 | |
|   final dynamic value = map is Map ? map[key] : null;
 | |
|   if (value != null) {
 | |
|     int? millis;
 | |
|     if (value is int) {
 | |
|       millis = value;
 | |
|     } else if (value is String) {
 | |
|       if (pattern == _dateEpochMarker) {
 | |
|         millis = int.tryParse(value);
 | |
|       } else {
 | |
|         return DateTime.tryParse(value);
 | |
|       }
 | |
|     }
 | |
|     if (millis != null) {
 | |
|       return DateTime.fromMillisecondsSinceEpoch(millis, isUtc: true);
 | |
|     }
 | |
|   }
 | |
|   return null;
 | |
| }
 |