From 10c2bda3a9633685a8880acd11ed0d04db3d2986 Mon Sep 17 00:00:00 2001 From: Jason Rasmussen Date: Thu, 24 Aug 2023 21:45:54 -0400 Subject: [PATCH] chore: remove without thumbs (#3529) * refactor(server): remove withoutThumbs * chore: open api * fix: bad merge --- cli/src/api/open-api/api.ts | 23 ++++-------------- mobile/lib/shared/services/asset.service.dart | 1 - mobile/lib/utils/openapi_extensions.dart | 2 -- mobile/openapi/doc/AssetApi.md | Bin 58856 -> 58675 bytes mobile/openapi/lib/api/asset_api.dart | Bin 53913 -> 53570 bytes mobile/openapi/test/asset_api_test.dart | Bin 5498 -> 5478 bytes server/immich-openapi-specs.json | 9 ------- .../immich/api-v1/asset/asset-repository.ts | 3 +-- .../api-v1/asset/dto/asset-search.dto.ts | 8 ------ web/src/api/open-api/api.ts | 23 ++++-------------- 10 files changed, 11 insertions(+), 58 deletions(-) diff --git a/cli/src/api/open-api/api.ts b/cli/src/api/open-api/api.ts index f73b6bcdf7..48fbad95d0 100644 --- a/cli/src/api/open-api/api.ts +++ b/cli/src/api/open-api/api.ts @@ -5151,14 +5151,13 @@ export const AssetApiAxiosParamCreator = function (configuration?: Configuration * @param {string} [userId] * @param {boolean} [isFavorite] * @param {boolean} [isArchived] - * @param {boolean} [withoutThumbs] Include assets without thumbnails * @param {number} [skip] * @param {string} [updatedAfter] * @param {string} [ifNoneMatch] ETag of data already cached on the client * @param {*} [options] Override http request option. * @throws {RequiredError} */ - getAllAssets: async (userId?: string, isFavorite?: boolean, isArchived?: boolean, withoutThumbs?: boolean, skip?: number, updatedAfter?: string, ifNoneMatch?: string, options: AxiosRequestConfig = {}): Promise => { + getAllAssets: async (userId?: string, isFavorite?: boolean, isArchived?: boolean, skip?: number, updatedAfter?: string, ifNoneMatch?: string, options: AxiosRequestConfig = {}): Promise => { const localVarPath = `/asset`; // use dummy base URL string because the URL constructor only accepts absolute URLs. const localVarUrlObj = new URL(localVarPath, DUMMY_BASE_URL); @@ -5192,10 +5191,6 @@ export const AssetApiAxiosParamCreator = function (configuration?: Configuration localVarQueryParameter['isArchived'] = isArchived; } - if (withoutThumbs !== undefined) { - localVarQueryParameter['withoutThumbs'] = withoutThumbs; - } - if (skip !== undefined) { localVarQueryParameter['skip'] = skip; } @@ -6312,15 +6307,14 @@ export const AssetApiFp = function(configuration?: Configuration) { * @param {string} [userId] * @param {boolean} [isFavorite] * @param {boolean} [isArchived] - * @param {boolean} [withoutThumbs] Include assets without thumbnails * @param {number} [skip] * @param {string} [updatedAfter] * @param {string} [ifNoneMatch] ETag of data already cached on the client * @param {*} [options] Override http request option. * @throws {RequiredError} */ - async getAllAssets(userId?: string, isFavorite?: boolean, isArchived?: boolean, withoutThumbs?: boolean, skip?: number, updatedAfter?: string, ifNoneMatch?: string, options?: AxiosRequestConfig): Promise<(axios?: AxiosInstance, basePath?: string) => AxiosPromise>> { - const localVarAxiosArgs = await localVarAxiosParamCreator.getAllAssets(userId, isFavorite, isArchived, withoutThumbs, skip, updatedAfter, ifNoneMatch, options); + async getAllAssets(userId?: string, isFavorite?: boolean, isArchived?: boolean, skip?: number, updatedAfter?: string, ifNoneMatch?: string, options?: AxiosRequestConfig): Promise<(axios?: AxiosInstance, basePath?: string) => AxiosPromise>> { + const localVarAxiosArgs = await localVarAxiosParamCreator.getAllAssets(userId, isFavorite, isArchived, skip, updatedAfter, ifNoneMatch, options); return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** @@ -6617,7 +6611,7 @@ export const AssetApiFactory = function (configuration?: Configuration, basePath * @throws {RequiredError} */ getAllAssets(requestParameters: AssetApiGetAllAssetsRequest = {}, options?: AxiosRequestConfig): AxiosPromise> { - return localVarFp.getAllAssets(requestParameters.userId, requestParameters.isFavorite, requestParameters.isArchived, requestParameters.withoutThumbs, requestParameters.skip, requestParameters.updatedAfter, requestParameters.ifNoneMatch, options).then((request) => request(axios, basePath)); + return localVarFp.getAllAssets(requestParameters.userId, requestParameters.isFavorite, requestParameters.isArchived, requestParameters.skip, requestParameters.updatedAfter, requestParameters.ifNoneMatch, options).then((request) => request(axios, basePath)); }, /** * Get a single asset\'s information @@ -6922,13 +6916,6 @@ export interface AssetApiGetAllAssetsRequest { */ readonly isArchived?: boolean - /** - * Include assets without thumbnails - * @type {boolean} - * @memberof AssetApiGetAllAssets - */ - readonly withoutThumbs?: boolean - /** * * @type {number} @@ -7508,7 +7495,7 @@ export class AssetApi extends BaseAPI { * @memberof AssetApi */ public getAllAssets(requestParameters: AssetApiGetAllAssetsRequest = {}, options?: AxiosRequestConfig) { - return AssetApiFp(this.configuration).getAllAssets(requestParameters.userId, requestParameters.isFavorite, requestParameters.isArchived, requestParameters.withoutThumbs, requestParameters.skip, requestParameters.updatedAfter, requestParameters.ifNoneMatch, options).then((request) => request(this.axios, this.basePath)); + return AssetApiFp(this.configuration).getAllAssets(requestParameters.userId, requestParameters.isFavorite, requestParameters.isArchived, requestParameters.skip, requestParameters.updatedAfter, requestParameters.ifNoneMatch, options).then((request) => request(this.axios, this.basePath)); } /** diff --git a/mobile/lib/shared/services/asset.service.dart b/mobile/lib/shared/services/asset.service.dart index 9165e6308f..8e0fc1847f 100644 --- a/mobile/lib/shared/services/asset.service.dart +++ b/mobile/lib/shared/services/asset.service.dart @@ -69,7 +69,6 @@ class AssetService { await _apiService.assetApi.getAllAssetsWithETag( eTag: etag, userId: user.id, - withoutThumbs: true, ); if (assets == null) { return null; diff --git a/mobile/lib/utils/openapi_extensions.dart b/mobile/lib/utils/openapi_extensions.dart index 0fd3f2be5d..bd4458e4a5 100644 --- a/mobile/lib/utils/openapi_extensions.dart +++ b/mobile/lib/utils/openapi_extensions.dart @@ -17,14 +17,12 @@ extension WithETag on AssetApi { String? userId, bool? isFavorite, bool? isArchived, - bool? withoutThumbs, }) async { final response = await getAllAssetsWithHttpInfo( ifNoneMatch: eTag, userId: userId, isFavorite: isFavorite, isArchived: isArchived, - withoutThumbs: withoutThumbs, ); if (response.statusCode >= HttpStatus.badRequest) { throw ApiException(response.statusCode, await _decodeBodyBytes(response)); diff --git a/mobile/openapi/doc/AssetApi.md b/mobile/openapi/doc/AssetApi.md index 140f509b0b05fa67eb0a9054bf04d13042aef001..4bec9fa2ac7986ed8027eecdd07f77f852377fc0 100644 GIT binary patch delta 33 pcmaEHntAgn<_*Huo0Y7;uxyTV;AEVvWUa7ynqxfUW*6rriva3O4H5tV delta 174 zcmdmdiuuK9<_*HuyyclC8Tq9pAsMB)NyVE5t-rCL3Qbm=Bdq9|mz-0YlB$qcT%1}` ztN_)cPy*7FmzbGTyvad;5lx?&XThJ)18W7%^@xHM+nAl$|(P#ViJ> LV#nrebG_LBp(+<+ delta 287 zcmX@Khfr55{rvd zONtessuW5<%JLF3bBZU&n=G7stB!Z_RXv}{_FinfCbIY7wFU^V~%XKeof diff --git a/mobile/openapi/test/asset_api_test.dart b/mobile/openapi/test/asset_api_test.dart index 076521b0e8e8ba98e90b561dc17ee7b7d9ad3d0e..ea45fc7d19acb6cc86bde3c0d52773a5ec4c387f 100644 GIT binary patch delta 12 TcmeyR^-ODn7yITob{ReZB?<(1 delta 30 lcmaE+^-F7m7yIP>BCNdSnI#$dr6nO5rMXGPn?2a&_yEDH3u6EP diff --git a/server/immich-openapi-specs.json b/server/immich-openapi-specs.json index dfbfe66cef..e12c50da46 100644 --- a/server/immich-openapi-specs.json +++ b/server/immich-openapi-specs.json @@ -752,15 +752,6 @@ "type": "boolean" } }, - { - "name": "withoutThumbs", - "required": false, - "in": "query", - "description": "Include assets without thumbnails", - "schema": { - "type": "boolean" - } - }, { "name": "skip", "required": false, diff --git a/server/src/immich/api-v1/asset/asset-repository.ts b/server/src/immich/api-v1/asset/asset-repository.ts index b19b33632f..a87a115e97 100644 --- a/server/src/immich/api-v1/asset/asset-repository.ts +++ b/server/src/immich/api-v1/asset/asset-repository.ts @@ -1,7 +1,7 @@ import { AssetEntity, ExifEntity } from '@app/infra/entities'; import { Injectable } from '@nestjs/common'; import { InjectRepository } from '@nestjs/typeorm'; -import { IsNull, MoreThan, Not } from 'typeorm'; +import { MoreThan } from 'typeorm'; import { In } from 'typeorm/find-options/operator/In'; import { Repository } from 'typeorm/repository/Repository'; import { AssetSearchDto } from './dto/asset-search.dto'; @@ -127,7 +127,6 @@ export class AssetRepository implements IAssetRepository { return this.assetRepository.find({ where: { ownerId, - resizePath: dto.withoutThumbs ? undefined : Not(IsNull()), isVisible: true, isFavorite: dto.isFavorite, isArchived: dto.isArchived, diff --git a/server/src/immich/api-v1/asset/dto/asset-search.dto.ts b/server/src/immich/api-v1/asset/dto/asset-search.dto.ts index 72d16edbed..52aee7c373 100644 --- a/server/src/immich/api-v1/asset/dto/asset-search.dto.ts +++ b/server/src/immich/api-v1/asset/dto/asset-search.dto.ts @@ -16,14 +16,6 @@ export class AssetSearchDto { @Transform(toBoolean) isArchived?: boolean; - /** - * Include assets without thumbnails - */ - @IsOptional() - @IsBoolean() - @Transform(toBoolean) - withoutThumbs?: boolean; - @IsOptional() @IsNumber() skip?: number; diff --git a/web/src/api/open-api/api.ts b/web/src/api/open-api/api.ts index f73b6bcdf7..48fbad95d0 100644 --- a/web/src/api/open-api/api.ts +++ b/web/src/api/open-api/api.ts @@ -5151,14 +5151,13 @@ export const AssetApiAxiosParamCreator = function (configuration?: Configuration * @param {string} [userId] * @param {boolean} [isFavorite] * @param {boolean} [isArchived] - * @param {boolean} [withoutThumbs] Include assets without thumbnails * @param {number} [skip] * @param {string} [updatedAfter] * @param {string} [ifNoneMatch] ETag of data already cached on the client * @param {*} [options] Override http request option. * @throws {RequiredError} */ - getAllAssets: async (userId?: string, isFavorite?: boolean, isArchived?: boolean, withoutThumbs?: boolean, skip?: number, updatedAfter?: string, ifNoneMatch?: string, options: AxiosRequestConfig = {}): Promise => { + getAllAssets: async (userId?: string, isFavorite?: boolean, isArchived?: boolean, skip?: number, updatedAfter?: string, ifNoneMatch?: string, options: AxiosRequestConfig = {}): Promise => { const localVarPath = `/asset`; // use dummy base URL string because the URL constructor only accepts absolute URLs. const localVarUrlObj = new URL(localVarPath, DUMMY_BASE_URL); @@ -5192,10 +5191,6 @@ export const AssetApiAxiosParamCreator = function (configuration?: Configuration localVarQueryParameter['isArchived'] = isArchived; } - if (withoutThumbs !== undefined) { - localVarQueryParameter['withoutThumbs'] = withoutThumbs; - } - if (skip !== undefined) { localVarQueryParameter['skip'] = skip; } @@ -6312,15 +6307,14 @@ export const AssetApiFp = function(configuration?: Configuration) { * @param {string} [userId] * @param {boolean} [isFavorite] * @param {boolean} [isArchived] - * @param {boolean} [withoutThumbs] Include assets without thumbnails * @param {number} [skip] * @param {string} [updatedAfter] * @param {string} [ifNoneMatch] ETag of data already cached on the client * @param {*} [options] Override http request option. * @throws {RequiredError} */ - async getAllAssets(userId?: string, isFavorite?: boolean, isArchived?: boolean, withoutThumbs?: boolean, skip?: number, updatedAfter?: string, ifNoneMatch?: string, options?: AxiosRequestConfig): Promise<(axios?: AxiosInstance, basePath?: string) => AxiosPromise>> { - const localVarAxiosArgs = await localVarAxiosParamCreator.getAllAssets(userId, isFavorite, isArchived, withoutThumbs, skip, updatedAfter, ifNoneMatch, options); + async getAllAssets(userId?: string, isFavorite?: boolean, isArchived?: boolean, skip?: number, updatedAfter?: string, ifNoneMatch?: string, options?: AxiosRequestConfig): Promise<(axios?: AxiosInstance, basePath?: string) => AxiosPromise>> { + const localVarAxiosArgs = await localVarAxiosParamCreator.getAllAssets(userId, isFavorite, isArchived, skip, updatedAfter, ifNoneMatch, options); return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** @@ -6617,7 +6611,7 @@ export const AssetApiFactory = function (configuration?: Configuration, basePath * @throws {RequiredError} */ getAllAssets(requestParameters: AssetApiGetAllAssetsRequest = {}, options?: AxiosRequestConfig): AxiosPromise> { - return localVarFp.getAllAssets(requestParameters.userId, requestParameters.isFavorite, requestParameters.isArchived, requestParameters.withoutThumbs, requestParameters.skip, requestParameters.updatedAfter, requestParameters.ifNoneMatch, options).then((request) => request(axios, basePath)); + return localVarFp.getAllAssets(requestParameters.userId, requestParameters.isFavorite, requestParameters.isArchived, requestParameters.skip, requestParameters.updatedAfter, requestParameters.ifNoneMatch, options).then((request) => request(axios, basePath)); }, /** * Get a single asset\'s information @@ -6922,13 +6916,6 @@ export interface AssetApiGetAllAssetsRequest { */ readonly isArchived?: boolean - /** - * Include assets without thumbnails - * @type {boolean} - * @memberof AssetApiGetAllAssets - */ - readonly withoutThumbs?: boolean - /** * * @type {number} @@ -7508,7 +7495,7 @@ export class AssetApi extends BaseAPI { * @memberof AssetApi */ public getAllAssets(requestParameters: AssetApiGetAllAssetsRequest = {}, options?: AxiosRequestConfig) { - return AssetApiFp(this.configuration).getAllAssets(requestParameters.userId, requestParameters.isFavorite, requestParameters.isArchived, requestParameters.withoutThumbs, requestParameters.skip, requestParameters.updatedAfter, requestParameters.ifNoneMatch, options).then((request) => request(this.axios, this.basePath)); + return AssetApiFp(this.configuration).getAllAssets(requestParameters.userId, requestParameters.isFavorite, requestParameters.isArchived, requestParameters.skip, requestParameters.updatedAfter, requestParameters.ifNoneMatch, options).then((request) => request(this.axios, this.basePath)); } /**