// // 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 AssetsApi { AssetsApi([ApiClient? apiClient]) : apiClient = apiClient ?? defaultApiClient; final ApiClient apiClient; /// Checks if assets exist by checksums /// /// Note: This method returns the HTTP [Response]. /// /// Parameters: /// /// * [AssetBulkUploadCheckDto] assetBulkUploadCheckDto (required): Future checkBulkUploadWithHttpInfo(AssetBulkUploadCheckDto assetBulkUploadCheckDto,) async { // ignore: prefer_const_declarations final path = r'/assets/bulk-upload-check'; // ignore: prefer_final_locals Object? postBody = assetBulkUploadCheckDto; final queryParams = []; final headerParams = {}; final formParams = {}; const contentTypes = ['application/json']; return apiClient.invokeAPI( path, 'POST', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Checks if assets exist by checksums /// /// Parameters: /// /// * [AssetBulkUploadCheckDto] assetBulkUploadCheckDto (required): Future checkBulkUpload(AssetBulkUploadCheckDto assetBulkUploadCheckDto,) async { final response = await checkBulkUploadWithHttpInfo(assetBulkUploadCheckDto,); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } // When a remote server returns no body with a status of 204, we shall not decode it. // At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // FormatException when trying to decode an empty string. if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'AssetBulkUploadCheckResponseDto',) as AssetBulkUploadCheckResponseDto; } return null; } /// Checks if multiple assets exist on the server and returns all existing - used by background backup /// /// Note: This method returns the HTTP [Response]. /// /// Parameters: /// /// * [CheckExistingAssetsDto] checkExistingAssetsDto (required): Future checkExistingAssetsWithHttpInfo(CheckExistingAssetsDto checkExistingAssetsDto,) async { // ignore: prefer_const_declarations final path = r'/assets/exist'; // ignore: prefer_final_locals Object? postBody = checkExistingAssetsDto; final queryParams = []; final headerParams = {}; final formParams = {}; const contentTypes = ['application/json']; return apiClient.invokeAPI( path, 'POST', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Checks if multiple assets exist on the server and returns all existing - used by background backup /// /// Parameters: /// /// * [CheckExistingAssetsDto] checkExistingAssetsDto (required): Future checkExistingAssets(CheckExistingAssetsDto checkExistingAssetsDto,) async { final response = await checkExistingAssetsWithHttpInfo(checkExistingAssetsDto,); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } // When a remote server returns no body with a status of 204, we shall not decode it. // At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // FormatException when trying to decode an empty string. if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'CheckExistingAssetsResponseDto',) as CheckExistingAssetsResponseDto; } return null; } /// Performs an HTTP 'DELETE /assets' operation and returns the [Response]. /// Parameters: /// /// * [AssetBulkDeleteDto] assetBulkDeleteDto (required): Future deleteAssetsWithHttpInfo(AssetBulkDeleteDto assetBulkDeleteDto,) async { // ignore: prefer_const_declarations final path = r'/assets'; // ignore: prefer_final_locals Object? postBody = assetBulkDeleteDto; final queryParams = []; final headerParams = {}; final formParams = {}; const contentTypes = ['application/json']; return apiClient.invokeAPI( path, 'DELETE', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Parameters: /// /// * [AssetBulkDeleteDto] assetBulkDeleteDto (required): Future deleteAssets(AssetBulkDeleteDto assetBulkDeleteDto,) async { final response = await deleteAssetsWithHttpInfo(assetBulkDeleteDto,); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } } /// Performs an HTTP 'GET /assets/{id}/original' operation and returns the [Response]. /// Parameters: /// /// * [String] id (required): /// /// * [String] key: Future downloadAssetWithHttpInfo(String id, { String? key, }) async { // ignore: prefer_const_declarations final path = r'/assets/{id}/original' .replaceAll('{id}', id); // ignore: prefer_final_locals Object? postBody; final queryParams = []; final headerParams = {}; final formParams = {}; if (key != null) { queryParams.addAll(_queryParams('', 'key', key)); } const contentTypes = []; return apiClient.invokeAPI( path, 'GET', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Parameters: /// /// * [String] id (required): /// /// * [String] key: Future downloadAsset(String id, { String? key, }) async { final response = await downloadAssetWithHttpInfo(id, key: key, ); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } // When a remote server returns no body with a status of 204, we shall not decode it. // At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // FormatException when trying to decode an empty string. if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'MultipartFile',) as MultipartFile; } return null; } /// Get all asset of a device that are in the database, ID only. /// /// Note: This method returns the HTTP [Response]. /// /// Parameters: /// /// * [String] deviceId (required): Future getAllUserAssetsByDeviceIdWithHttpInfo(String deviceId,) async { // ignore: prefer_const_declarations final path = r'/assets/device/{deviceId}' .replaceAll('{deviceId}', deviceId); // ignore: prefer_final_locals Object? postBody; final queryParams = []; final headerParams = {}; final formParams = {}; const contentTypes = []; return apiClient.invokeAPI( path, 'GET', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Get all asset of a device that are in the database, ID only. /// /// Parameters: /// /// * [String] deviceId (required): Future?> getAllUserAssetsByDeviceId(String deviceId,) async { final response = await getAllUserAssetsByDeviceIdWithHttpInfo(deviceId,); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } // When a remote server returns no body with a status of 204, we shall not decode it. // At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // FormatException when trying to decode an empty string. if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { final responseBody = await _decodeBodyBytes(response); return (await apiClient.deserializeAsync(responseBody, 'List') as List) .cast() .toList(growable: false); } return null; } /// Performs an HTTP 'GET /assets/{id}' operation and returns the [Response]. /// Parameters: /// /// * [String] id (required): /// /// * [String] key: Future getAssetInfoWithHttpInfo(String id, { String? key, }) async { // ignore: prefer_const_declarations final path = r'/assets/{id}' .replaceAll('{id}', id); // ignore: prefer_final_locals Object? postBody; final queryParams = []; final headerParams = {}; final formParams = {}; if (key != null) { queryParams.addAll(_queryParams('', 'key', key)); } const contentTypes = []; return apiClient.invokeAPI( path, 'GET', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Parameters: /// /// * [String] id (required): /// /// * [String] key: Future getAssetInfo(String id, { String? key, }) async { final response = await getAssetInfoWithHttpInfo(id, key: key, ); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } // When a remote server returns no body with a status of 204, we shall not decode it. // At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // FormatException when trying to decode an empty string. if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'AssetResponseDto',) as AssetResponseDto; } return null; } /// Performs an HTTP 'GET /assets/statistics' operation and returns the [Response]. /// Parameters: /// /// * [bool] isArchived: /// /// * [bool] isFavorite: /// /// * [bool] isTrashed: Future getAssetStatisticsWithHttpInfo({ bool? isArchived, bool? isFavorite, bool? isTrashed, }) async { // ignore: prefer_const_declarations final path = r'/assets/statistics'; // ignore: prefer_final_locals Object? postBody; final queryParams = []; final headerParams = {}; final formParams = {}; if (isArchived != null) { queryParams.addAll(_queryParams('', 'isArchived', isArchived)); } if (isFavorite != null) { queryParams.addAll(_queryParams('', 'isFavorite', isFavorite)); } if (isTrashed != null) { queryParams.addAll(_queryParams('', 'isTrashed', isTrashed)); } const contentTypes = []; return apiClient.invokeAPI( path, 'GET', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Parameters: /// /// * [bool] isArchived: /// /// * [bool] isFavorite: /// /// * [bool] isTrashed: Future getAssetStatistics({ bool? isArchived, bool? isFavorite, bool? isTrashed, }) async { final response = await getAssetStatisticsWithHttpInfo( isArchived: isArchived, isFavorite: isFavorite, isTrashed: isTrashed, ); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } // When a remote server returns no body with a status of 204, we shall not decode it. // At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // FormatException when trying to decode an empty string. if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'AssetStatsResponseDto',) as AssetStatsResponseDto; } return null; } /// Performs an HTTP 'GET /assets/memory-lane' operation and returns the [Response]. /// Parameters: /// /// * [int] day (required): /// /// * [int] month (required): Future getMemoryLaneWithHttpInfo(int day, int month,) async { // ignore: prefer_const_declarations final path = r'/assets/memory-lane'; // ignore: prefer_final_locals Object? postBody; final queryParams = []; final headerParams = {}; final formParams = {}; queryParams.addAll(_queryParams('', 'day', day)); queryParams.addAll(_queryParams('', 'month', month)); const contentTypes = []; return apiClient.invokeAPI( path, 'GET', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Parameters: /// /// * [int] day (required): /// /// * [int] month (required): Future?> getMemoryLane(int day, int month,) async { final response = await getMemoryLaneWithHttpInfo(day, month,); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } // When a remote server returns no body with a status of 204, we shall not decode it. // At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // FormatException when trying to decode an empty string. if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { final responseBody = await _decodeBodyBytes(response); return (await apiClient.deserializeAsync(responseBody, 'List') as List) .cast() .toList(growable: false); } return null; } /// Performs an HTTP 'GET /assets/random' operation and returns the [Response]. /// Parameters: /// /// * [num] count: Future getRandomWithHttpInfo({ num? count, }) async { // ignore: prefer_const_declarations final path = r'/assets/random'; // ignore: prefer_final_locals Object? postBody; final queryParams = []; final headerParams = {}; final formParams = {}; if (count != null) { queryParams.addAll(_queryParams('', 'count', count)); } const contentTypes = []; return apiClient.invokeAPI( path, 'GET', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Parameters: /// /// * [num] count: Future?> getRandom({ num? count, }) async { final response = await getRandomWithHttpInfo( count: count, ); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } // When a remote server returns no body with a status of 204, we shall not decode it. // At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // FormatException when trying to decode an empty string. if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { final responseBody = await _decodeBodyBytes(response); return (await apiClient.deserializeAsync(responseBody, 'List') as List) .cast() .toList(growable: false); } return null; } /// Performs an HTTP 'GET /assets/{id}/video/playback' operation and returns the [Response]. /// Parameters: /// /// * [String] id (required): /// /// * [String] key: Future playAssetVideoWithHttpInfo(String id, { String? key, }) async { // ignore: prefer_const_declarations final path = r'/assets/{id}/video/playback' .replaceAll('{id}', id); // ignore: prefer_final_locals Object? postBody; final queryParams = []; final headerParams = {}; final formParams = {}; if (key != null) { queryParams.addAll(_queryParams('', 'key', key)); } const contentTypes = []; return apiClient.invokeAPI( path, 'GET', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Parameters: /// /// * [String] id (required): /// /// * [String] key: Future playAssetVideo(String id, { String? key, }) async { final response = await playAssetVideoWithHttpInfo(id, key: key, ); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } // When a remote server returns no body with a status of 204, we shall not decode it. // At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // FormatException when trying to decode an empty string. if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'MultipartFile',) as MultipartFile; } return null; } /// Replace the asset with new file, without changing its id /// /// Note: This method returns the HTTP [Response]. /// /// Parameters: /// /// * [String] id (required): /// /// * [MultipartFile] assetData (required): /// /// * [String] deviceAssetId (required): /// /// * [String] deviceId (required): /// /// * [DateTime] fileCreatedAt (required): /// /// * [DateTime] fileModifiedAt (required): /// /// * [String] key: /// /// * [String] duration: Future replaceAssetWithHttpInfo(String id, MultipartFile assetData, String deviceAssetId, String deviceId, DateTime fileCreatedAt, DateTime fileModifiedAt, { String? key, String? duration, }) async { // ignore: prefer_const_declarations final path = r'/assets/{id}/original' .replaceAll('{id}', id); // ignore: prefer_final_locals Object? postBody; final queryParams = []; final headerParams = {}; final formParams = {}; if (key != null) { queryParams.addAll(_queryParams('', 'key', key)); } const contentTypes = ['multipart/form-data']; bool hasFields = false; final mp = MultipartRequest('PUT', Uri.parse(path)); if (assetData != null) { hasFields = true; mp.fields[r'assetData'] = assetData.field; mp.files.add(assetData); } if (deviceAssetId != null) { hasFields = true; mp.fields[r'deviceAssetId'] = parameterToString(deviceAssetId); } if (deviceId != null) { hasFields = true; mp.fields[r'deviceId'] = parameterToString(deviceId); } if (duration != null) { hasFields = true; mp.fields[r'duration'] = parameterToString(duration); } if (fileCreatedAt != null) { hasFields = true; mp.fields[r'fileCreatedAt'] = parameterToString(fileCreatedAt); } if (fileModifiedAt != null) { hasFields = true; mp.fields[r'fileModifiedAt'] = parameterToString(fileModifiedAt); } if (hasFields) { postBody = mp; } return apiClient.invokeAPI( path, 'PUT', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Replace the asset with new file, without changing its id /// /// Parameters: /// /// * [String] id (required): /// /// * [MultipartFile] assetData (required): /// /// * [String] deviceAssetId (required): /// /// * [String] deviceId (required): /// /// * [DateTime] fileCreatedAt (required): /// /// * [DateTime] fileModifiedAt (required): /// /// * [String] key: /// /// * [String] duration: Future replaceAsset(String id, MultipartFile assetData, String deviceAssetId, String deviceId, DateTime fileCreatedAt, DateTime fileModifiedAt, { String? key, String? duration, }) async { final response = await replaceAssetWithHttpInfo(id, assetData, deviceAssetId, deviceId, fileCreatedAt, fileModifiedAt, key: key, duration: duration, ); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } // When a remote server returns no body with a status of 204, we shall not decode it. // At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // FormatException when trying to decode an empty string. if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'AssetMediaResponseDto',) as AssetMediaResponseDto; } return null; } /// Performs an HTTP 'POST /assets/jobs' operation and returns the [Response]. /// Parameters: /// /// * [AssetJobsDto] assetJobsDto (required): Future runAssetJobsWithHttpInfo(AssetJobsDto assetJobsDto,) async { // ignore: prefer_const_declarations final path = r'/assets/jobs'; // ignore: prefer_final_locals Object? postBody = assetJobsDto; final queryParams = []; final headerParams = {}; final formParams = {}; const contentTypes = ['application/json']; return apiClient.invokeAPI( path, 'POST', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Parameters: /// /// * [AssetJobsDto] assetJobsDto (required): Future runAssetJobs(AssetJobsDto assetJobsDto,) async { final response = await runAssetJobsWithHttpInfo(assetJobsDto,); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } } /// Performs an HTTP 'PUT /assets/{id}' operation and returns the [Response]. /// Parameters: /// /// * [String] id (required): /// /// * [UpdateAssetDto] updateAssetDto (required): Future updateAssetWithHttpInfo(String id, UpdateAssetDto updateAssetDto,) async { // ignore: prefer_const_declarations final path = r'/assets/{id}' .replaceAll('{id}', id); // ignore: prefer_final_locals Object? postBody = updateAssetDto; final queryParams = []; final headerParams = {}; final formParams = {}; const contentTypes = ['application/json']; return apiClient.invokeAPI( path, 'PUT', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Parameters: /// /// * [String] id (required): /// /// * [UpdateAssetDto] updateAssetDto (required): Future updateAsset(String id, UpdateAssetDto updateAssetDto,) async { final response = await updateAssetWithHttpInfo(id, updateAssetDto,); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } // When a remote server returns no body with a status of 204, we shall not decode it. // At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // FormatException when trying to decode an empty string. if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'AssetResponseDto',) as AssetResponseDto; } return null; } /// Performs an HTTP 'PUT /assets' operation and returns the [Response]. /// Parameters: /// /// * [AssetBulkUpdateDto] assetBulkUpdateDto (required): Future updateAssetsWithHttpInfo(AssetBulkUpdateDto assetBulkUpdateDto,) async { // ignore: prefer_const_declarations final path = r'/assets'; // ignore: prefer_final_locals Object? postBody = assetBulkUpdateDto; final queryParams = []; final headerParams = {}; final formParams = {}; const contentTypes = ['application/json']; return apiClient.invokeAPI( path, 'PUT', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Parameters: /// /// * [AssetBulkUpdateDto] assetBulkUpdateDto (required): Future updateAssets(AssetBulkUpdateDto assetBulkUpdateDto,) async { final response = await updateAssetsWithHttpInfo(assetBulkUpdateDto,); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } } /// Performs an HTTP 'PUT /assets/stack/parent' operation and returns the [Response]. /// Parameters: /// /// * [UpdateStackParentDto] updateStackParentDto (required): Future updateStackParentWithHttpInfo(UpdateStackParentDto updateStackParentDto,) async { // ignore: prefer_const_declarations final path = r'/assets/stack/parent'; // ignore: prefer_final_locals Object? postBody = updateStackParentDto; final queryParams = []; final headerParams = {}; final formParams = {}; const contentTypes = ['application/json']; return apiClient.invokeAPI( path, 'PUT', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Parameters: /// /// * [UpdateStackParentDto] updateStackParentDto (required): Future updateStackParent(UpdateStackParentDto updateStackParentDto,) async { final response = await updateStackParentWithHttpInfo(updateStackParentDto,); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } } /// Performs an HTTP 'POST /assets' operation and returns the [Response]. /// Parameters: /// /// * [MultipartFile] assetData (required): /// /// * [String] deviceAssetId (required): /// /// * [String] deviceId (required): /// /// * [DateTime] fileCreatedAt (required): /// /// * [DateTime] fileModifiedAt (required): /// /// * [String] key: /// /// * [String] xImmichChecksum: /// sha1 checksum that can be used for duplicate detection before the file is uploaded /// /// * [String] duration: /// /// * [bool] isArchived: /// /// * [bool] isFavorite: /// /// * [bool] isOffline: /// /// * [bool] isVisible: /// /// * [String] livePhotoVideoId: /// /// * [MultipartFile] sidecarData: Future uploadAssetWithHttpInfo(MultipartFile assetData, String deviceAssetId, String deviceId, DateTime fileCreatedAt, DateTime fileModifiedAt, { String? key, String? xImmichChecksum, String? duration, bool? isArchived, bool? isFavorite, bool? isOffline, bool? isVisible, String? livePhotoVideoId, MultipartFile? sidecarData, }) async { // ignore: prefer_const_declarations final path = r'/assets'; // ignore: prefer_final_locals Object? postBody; final queryParams = []; final headerParams = {}; final formParams = {}; if (key != null) { queryParams.addAll(_queryParams('', 'key', key)); } if (xImmichChecksum != null) { headerParams[r'x-immich-checksum'] = parameterToString(xImmichChecksum); } const contentTypes = ['multipart/form-data']; bool hasFields = false; final mp = MultipartRequest('POST', Uri.parse(path)); if (assetData != null) { hasFields = true; mp.fields[r'assetData'] = assetData.field; mp.files.add(assetData); } if (deviceAssetId != null) { hasFields = true; mp.fields[r'deviceAssetId'] = parameterToString(deviceAssetId); } if (deviceId != null) { hasFields = true; mp.fields[r'deviceId'] = parameterToString(deviceId); } if (duration != null) { hasFields = true; mp.fields[r'duration'] = parameterToString(duration); } if (fileCreatedAt != null) { hasFields = true; mp.fields[r'fileCreatedAt'] = parameterToString(fileCreatedAt); } if (fileModifiedAt != null) { hasFields = true; mp.fields[r'fileModifiedAt'] = parameterToString(fileModifiedAt); } if (isArchived != null) { hasFields = true; mp.fields[r'isArchived'] = parameterToString(isArchived); } if (isFavorite != null) { hasFields = true; mp.fields[r'isFavorite'] = parameterToString(isFavorite); } if (isOffline != null) { hasFields = true; mp.fields[r'isOffline'] = parameterToString(isOffline); } if (isVisible != null) { hasFields = true; mp.fields[r'isVisible'] = parameterToString(isVisible); } if (livePhotoVideoId != null) { hasFields = true; mp.fields[r'livePhotoVideoId'] = parameterToString(livePhotoVideoId); } if (sidecarData != null) { hasFields = true; mp.fields[r'sidecarData'] = sidecarData.field; mp.files.add(sidecarData); } if (hasFields) { postBody = mp; } return apiClient.invokeAPI( path, 'POST', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Parameters: /// /// * [MultipartFile] assetData (required): /// /// * [String] deviceAssetId (required): /// /// * [String] deviceId (required): /// /// * [DateTime] fileCreatedAt (required): /// /// * [DateTime] fileModifiedAt (required): /// /// * [String] key: /// /// * [String] xImmichChecksum: /// sha1 checksum that can be used for duplicate detection before the file is uploaded /// /// * [String] duration: /// /// * [bool] isArchived: /// /// * [bool] isFavorite: /// /// * [bool] isOffline: /// /// * [bool] isVisible: /// /// * [String] livePhotoVideoId: /// /// * [MultipartFile] sidecarData: Future uploadAsset(MultipartFile assetData, String deviceAssetId, String deviceId, DateTime fileCreatedAt, DateTime fileModifiedAt, { String? key, String? xImmichChecksum, String? duration, bool? isArchived, bool? isFavorite, bool? isOffline, bool? isVisible, String? livePhotoVideoId, MultipartFile? sidecarData, }) async { final response = await uploadAssetWithHttpInfo(assetData, deviceAssetId, deviceId, fileCreatedAt, fileModifiedAt, key: key, xImmichChecksum: xImmichChecksum, duration: duration, isArchived: isArchived, isFavorite: isFavorite, isOffline: isOffline, isVisible: isVisible, livePhotoVideoId: livePhotoVideoId, sidecarData: sidecarData, ); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } // When a remote server returns no body with a status of 204, we shall not decode it. // At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // FormatException when trying to decode an empty string. if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'AssetMediaResponseDto',) as AssetMediaResponseDto; } return null; } /// Performs an HTTP 'GET /assets/{id}/thumbnail' operation and returns the [Response]. /// Parameters: /// /// * [String] id (required): /// /// * [String] key: /// /// * [AssetMediaSize] size: Future viewAssetWithHttpInfo(String id, { String? key, AssetMediaSize? size, }) async { // ignore: prefer_const_declarations final path = r'/assets/{id}/thumbnail' .replaceAll('{id}', id); // ignore: prefer_final_locals Object? postBody; final queryParams = []; final headerParams = {}; final formParams = {}; if (key != null) { queryParams.addAll(_queryParams('', 'key', key)); } if (size != null) { queryParams.addAll(_queryParams('', 'size', size)); } const contentTypes = []; return apiClient.invokeAPI( path, 'GET', queryParams, postBody, headerParams, formParams, contentTypes.isEmpty ? null : contentTypes.first, ); } /// Parameters: /// /// * [String] id (required): /// /// * [String] key: /// /// * [AssetMediaSize] size: Future viewAsset(String id, { String? key, AssetMediaSize? size, }) async { final response = await viewAssetWithHttpInfo(id, key: key, size: size, ); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); } // When a remote server returns no body with a status of 204, we shall not decode it. // At the time of writing this, `dart:convert` will throw an "Unexpected end of input" // FormatException when trying to decode an empty string. if (response.body.isNotEmpty && response.statusCode != HttpStatus.noContent) { return await apiClient.deserializeAsync(await _decodeBodyBytes(response), 'MultipartFile',) as MultipartFile; } return null; } }