From 03ecf8c5760c085ae8ce049c46a9cfa499cfb0c1 Mon Sep 17 00:00:00 2001 From: nadavsteindler Date: Mon, 16 Dec 2024 12:57:19 +0200 Subject: [PATCH] api --- api/swagger.yml | 28 ++-- clients/java/api/openapi.yaml | 17 +++ clients/java/docs/RepositoriesApi.md | 5 +- .../lakefs/clients/sdk/RepositoriesApi.java | 37 +++-- .../clients/sdk/RepositoriesApiTest.java | 2 + clients/python/docs/RepositoriesApi.md | 6 +- .../python/lakefs_sdk/api/repositories_api.py | 20 ++- clients/rust/docs/RepositoriesApi.md | 3 +- clients/rust/src/apis/repositories_api.rs | 5 +- docs/assets/js/swagger.yml | 130 ++++++++++-------- pkg/api/controller.go | 9 +- 11 files changed, 168 insertions(+), 94 deletions(-) diff --git a/api/swagger.yml b/api/swagger.yml index e4e16d94b0f..0f7c07ba8c4 100644 --- a/api/swagger.yml +++ b/api/swagger.yml @@ -70,6 +70,13 @@ components: description: delimiter used to group common prefixes by schema: type: string + + PaginationSearchString: + in: query + name: search + description: string for searching relevant entries + schema: + type: string IfNoneMatch: in: header @@ -695,7 +702,7 @@ components: default: false hidden: type: boolean - description: When set, branch will not show up when listing branches by default. *EXPERIMENTAL* + description: When set, branch will not show up when listing branches by default. *EXPERIMENTAL* default: false TagCreation: @@ -1705,7 +1712,7 @@ components: - installation_id - reports - ExternalPrincipalList: + ExternalPrincipalList: type: object required: - pagination @@ -2668,11 +2675,11 @@ paths: - experimental operationId: createUserExternalPrincipal summary: attach external principal to user - requestBody: + requestBody: required: false - content: - application/json: - schema: + content: + application/json: + schema: $ref: "#/components/schemas/ExternalPrincipalCreation" responses: 201: @@ -2753,7 +2760,7 @@ paths: - external - experimental operationId: getExternalPrincipal - summary: describe external principal by id + summary: describe external principal by id responses: 200: description: external principal @@ -2899,7 +2906,7 @@ paths: description: too many requests default: $ref: "#/components/responses/ServerError" - + /repositories: get: tags: @@ -2908,6 +2915,7 @@ paths: - $ref: "#/components/parameters/PaginationPrefix" - $ref: "#/components/parameters/PaginationAfter" - $ref: "#/components/parameters/PaginationAmount" + - $ref: "#/components/parameters/PaginationSearchString" operationId: listRepositories summary: list repositories responses: @@ -4564,10 +4572,10 @@ paths: application/json: schema: $ref: "#/components/schemas/StagingMetadata" - + parameters: - $ref: "#/components/parameters/IfNoneMatch" - + responses: 200: # This actually violates HTTP, which requires returning 201 if a new object was diff --git a/clients/java/api/openapi.yaml b/clients/java/api/openapi.yaml index 01b85b7b499..c423aae7df4 100644 --- a/clients/java/api/openapi.yaml +++ b/clients/java/api/openapi.yaml @@ -1965,6 +1965,14 @@ paths: minimum: -1 type: integer style: form + - description: string for searching relevant entries + explode: true + in: query + name: search + required: false + schema: + type: string + style: form responses: "200": content: @@ -7387,6 +7395,15 @@ components: schema: type: string style: form + PaginationSearchString: + description: string for searching relevant entries + explode: true + in: query + name: search + required: false + schema: + type: string + style: form IfNoneMatch: description: Set to "*" to atomically allow the upload only if the key has no object yet. Other values are not supported. diff --git a/clients/java/docs/RepositoriesApi.md b/clients/java/docs/RepositoriesApi.md index 664fcc4ef43..6312770cd96 100644 --- a/clients/java/docs/RepositoriesApi.md +++ b/clients/java/docs/RepositoriesApi.md @@ -868,7 +868,7 @@ public class Example { # **listRepositories** -> RepositoryList listRepositories().prefix(prefix).after(after).amount(amount).execute(); +> RepositoryList listRepositories().prefix(prefix).after(after).amount(amount).search(search).execute(); list repositories @@ -918,11 +918,13 @@ public class Example { String prefix = "prefix_example"; // String | return items prefixed with this value String after = "after_example"; // String | return items after this value Integer amount = 100; // Integer | how many items to return + String search = "search_example"; // String | string for searching relevant entries try { RepositoryList result = apiInstance.listRepositories() .prefix(prefix) .after(after) .amount(amount) + .search(search) .execute(); System.out.println(result); } catch (ApiException e) { @@ -943,6 +945,7 @@ public class Example { | **prefix** | **String**| return items prefixed with this value | [optional] | | **after** | **String**| return items after this value | [optional] | | **amount** | **Integer**| how many items to return | [optional] [default to 100] | +| **search** | **String**| string for searching relevant entries | [optional] | ### Return type diff --git a/clients/java/src/main/java/io/lakefs/clients/sdk/RepositoriesApi.java b/clients/java/src/main/java/io/lakefs/clients/sdk/RepositoriesApi.java index 2b45a54a744..03277973622 100644 --- a/clients/java/src/main/java/io/lakefs/clients/sdk/RepositoriesApi.java +++ b/clients/java/src/main/java/io/lakefs/clients/sdk/RepositoriesApi.java @@ -1678,7 +1678,7 @@ public okhttp3.Call executeAsync(final ApiCallback> _callbac public APIgetRepositoryMetadataRequest getRepositoryMetadata(String repository) { return new APIgetRepositoryMetadataRequest(repository); } - private okhttp3.Call listRepositoriesCall(String prefix, String after, Integer amount, final ApiCallback _callback) throws ApiException { + private okhttp3.Call listRepositoriesCall(String prefix, String after, Integer amount, String search, final ApiCallback _callback) throws ApiException { String basePath = null; // Operation Servers String[] localBasePaths = new String[] { }; @@ -1715,6 +1715,10 @@ private okhttp3.Call listRepositoriesCall(String prefix, String after, Integer a localVarQueryParams.addAll(localVarApiClient.parameterToPair("amount", amount)); } + if (search != null) { + localVarQueryParams.addAll(localVarApiClient.parameterToPair("search", search)); + } + final String[] localVarAccepts = { "application/json" }; @@ -1735,21 +1739,21 @@ private okhttp3.Call listRepositoriesCall(String prefix, String after, Integer a } @SuppressWarnings("rawtypes") - private okhttp3.Call listRepositoriesValidateBeforeCall(String prefix, String after, Integer amount, final ApiCallback _callback) throws ApiException { - return listRepositoriesCall(prefix, after, amount, _callback); + private okhttp3.Call listRepositoriesValidateBeforeCall(String prefix, String after, Integer amount, String search, final ApiCallback _callback) throws ApiException { + return listRepositoriesCall(prefix, after, amount, search, _callback); } - private ApiResponse listRepositoriesWithHttpInfo(String prefix, String after, Integer amount) throws ApiException { - okhttp3.Call localVarCall = listRepositoriesValidateBeforeCall(prefix, after, amount, null); + private ApiResponse listRepositoriesWithHttpInfo(String prefix, String after, Integer amount, String search) throws ApiException { + okhttp3.Call localVarCall = listRepositoriesValidateBeforeCall(prefix, after, amount, search, null); Type localVarReturnType = new TypeToken(){}.getType(); return localVarApiClient.execute(localVarCall, localVarReturnType); } - private okhttp3.Call listRepositoriesAsync(String prefix, String after, Integer amount, final ApiCallback _callback) throws ApiException { + private okhttp3.Call listRepositoriesAsync(String prefix, String after, Integer amount, String search, final ApiCallback _callback) throws ApiException { - okhttp3.Call localVarCall = listRepositoriesValidateBeforeCall(prefix, after, amount, _callback); + okhttp3.Call localVarCall = listRepositoriesValidateBeforeCall(prefix, after, amount, search, _callback); Type localVarReturnType = new TypeToken(){}.getType(); localVarApiClient.executeAsync(localVarCall, localVarReturnType, _callback); return localVarCall; @@ -1759,6 +1763,7 @@ public class APIlistRepositoriesRequest { private String prefix; private String after; private Integer amount; + private String search; private APIlistRepositoriesRequest() { } @@ -1793,6 +1798,16 @@ public APIlistRepositoriesRequest amount(Integer amount) { return this; } + /** + * Set search + * @param search string for searching relevant entries (optional) + * @return APIlistRepositoriesRequest + */ + public APIlistRepositoriesRequest search(String search) { + this.search = search; + return this; + } + /** * Build call for listRepositories * @param _callback ApiCallback API callback @@ -1808,7 +1823,7 @@ public APIlistRepositoriesRequest amount(Integer amount) { */ public okhttp3.Call buildCall(final ApiCallback _callback) throws ApiException { - return listRepositoriesCall(prefix, after, amount, _callback); + return listRepositoriesCall(prefix, after, amount, search, _callback); } /** @@ -1825,7 +1840,7 @@ public okhttp3.Call buildCall(final ApiCallback _callback) throws ApiException { */ public RepositoryList execute() throws ApiException { - ApiResponse localVarResp = listRepositoriesWithHttpInfo(prefix, after, amount); + ApiResponse localVarResp = listRepositoriesWithHttpInfo(prefix, after, amount, search); return localVarResp.getData(); } @@ -1843,7 +1858,7 @@ public RepositoryList execute() throws ApiException { */ public ApiResponse executeWithHttpInfo() throws ApiException { - return listRepositoriesWithHttpInfo(prefix, after, amount); + return listRepositoriesWithHttpInfo(prefix, after, amount, search); } /** @@ -1861,7 +1876,7 @@ public ApiResponse executeWithHttpInfo() throws ApiException { */ public okhttp3.Call executeAsync(final ApiCallback _callback) throws ApiException { - return listRepositoriesAsync(prefix, after, amount, _callback); + return listRepositoriesAsync(prefix, after, amount, search, _callback); } } diff --git a/clients/java/src/test/java/io/lakefs/clients/sdk/RepositoriesApiTest.java b/clients/java/src/test/java/io/lakefs/clients/sdk/RepositoriesApiTest.java index 836119642ef..81882064f68 100644 --- a/clients/java/src/test/java/io/lakefs/clients/sdk/RepositoriesApiTest.java +++ b/clients/java/src/test/java/io/lakefs/clients/sdk/RepositoriesApiTest.java @@ -170,10 +170,12 @@ public void listRepositoriesTest() throws ApiException { String prefix = null; String after = null; Integer amount = null; + String search = null; RepositoryList response = api.listRepositories() .prefix(prefix) .after(after) .amount(amount) + .search(search) .execute(); // TODO: test validations } diff --git a/clients/python/docs/RepositoriesApi.md b/clients/python/docs/RepositoriesApi.md index 6db6216fc8d..2d640e50392 100644 --- a/clients/python/docs/RepositoriesApi.md +++ b/clients/python/docs/RepositoriesApi.md @@ -1013,7 +1013,7 @@ Name | Type | Description | Notes [[Back to top]](#) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to Model list]](../README.md#documentation-for-models) [[Back to README]](../README.md) # **list_repositories** -> RepositoryList list_repositories(prefix=prefix, after=after, amount=amount) +> RepositoryList list_repositories(prefix=prefix, after=after, amount=amount, search=search) list repositories @@ -1080,10 +1080,11 @@ with lakefs_sdk.ApiClient(configuration) as api_client: prefix = 'prefix_example' # str | return items prefixed with this value (optional) after = 'after_example' # str | return items after this value (optional) amount = 100 # int | how many items to return (optional) (default to 100) + search = 'search_example' # str | string for searching relevant entries (optional) try: # list repositories - api_response = api_instance.list_repositories(prefix=prefix, after=after, amount=amount) + api_response = api_instance.list_repositories(prefix=prefix, after=after, amount=amount, search=search) print("The response of RepositoriesApi->list_repositories:\n") pprint(api_response) except Exception as e: @@ -1100,6 +1101,7 @@ Name | Type | Description | Notes **prefix** | **str**| return items prefixed with this value | [optional] **after** | **str**| return items after this value | [optional] **amount** | **int**| how many items to return | [optional] [default to 100] + **search** | **str**| string for searching relevant entries | [optional] ### Return type diff --git a/clients/python/lakefs_sdk/api/repositories_api.py b/clients/python/lakefs_sdk/api/repositories_api.py index f31d2c1d818..8f717b953bb 100644 --- a/clients/python/lakefs_sdk/api/repositories_api.py +++ b/clients/python/lakefs_sdk/api/repositories_api.py @@ -1344,13 +1344,13 @@ def get_repository_metadata_with_http_info(self, repository : StrictStr, **kwarg _request_auth=_params.get('_request_auth')) @validate_arguments - def list_repositories(self, prefix : Annotated[Optional[StrictStr], Field(description="return items prefixed with this value")] = None, after : Annotated[Optional[StrictStr], Field(description="return items after this value")] = None, amount : Annotated[Optional[conint(strict=True, le=1000, ge=-1)], Field(description="how many items to return")] = None, **kwargs) -> RepositoryList: # noqa: E501 + def list_repositories(self, prefix : Annotated[Optional[StrictStr], Field(description="return items prefixed with this value")] = None, after : Annotated[Optional[StrictStr], Field(description="return items after this value")] = None, amount : Annotated[Optional[conint(strict=True, le=1000, ge=-1)], Field(description="how many items to return")] = None, search : Annotated[Optional[StrictStr], Field(description="string for searching relevant entries")] = None, **kwargs) -> RepositoryList: # noqa: E501 """list repositories # noqa: E501 This method makes a synchronous HTTP request by default. To make an asynchronous HTTP request, please pass async_req=True - >>> thread = api.list_repositories(prefix, after, amount, async_req=True) + >>> thread = api.list_repositories(prefix, after, amount, search, async_req=True) >>> result = thread.get() :param prefix: return items prefixed with this value @@ -1359,6 +1359,8 @@ def list_repositories(self, prefix : Annotated[Optional[StrictStr], Field(descri :type after: str :param amount: how many items to return :type amount: int + :param search: string for searching relevant entries + :type search: str :param async_req: Whether to execute the request asynchronously. :type async_req: bool, optional :param _request_timeout: timeout setting for this request. If one @@ -1373,16 +1375,16 @@ def list_repositories(self, prefix : Annotated[Optional[StrictStr], Field(descri kwargs['_return_http_data_only'] = True if '_preload_content' in kwargs: raise ValueError("Error! Please call the list_repositories_with_http_info method with `_preload_content` instead and obtain raw data from ApiResponse.raw_data") - return self.list_repositories_with_http_info(prefix, after, amount, **kwargs) # noqa: E501 + return self.list_repositories_with_http_info(prefix, after, amount, search, **kwargs) # noqa: E501 @validate_arguments - def list_repositories_with_http_info(self, prefix : Annotated[Optional[StrictStr], Field(description="return items prefixed with this value")] = None, after : Annotated[Optional[StrictStr], Field(description="return items after this value")] = None, amount : Annotated[Optional[conint(strict=True, le=1000, ge=-1)], Field(description="how many items to return")] = None, **kwargs) -> ApiResponse: # noqa: E501 + def list_repositories_with_http_info(self, prefix : Annotated[Optional[StrictStr], Field(description="return items prefixed with this value")] = None, after : Annotated[Optional[StrictStr], Field(description="return items after this value")] = None, amount : Annotated[Optional[conint(strict=True, le=1000, ge=-1)], Field(description="how many items to return")] = None, search : Annotated[Optional[StrictStr], Field(description="string for searching relevant entries")] = None, **kwargs) -> ApiResponse: # noqa: E501 """list repositories # noqa: E501 This method makes a synchronous HTTP request by default. To make an asynchronous HTTP request, please pass async_req=True - >>> thread = api.list_repositories_with_http_info(prefix, after, amount, async_req=True) + >>> thread = api.list_repositories_with_http_info(prefix, after, amount, search, async_req=True) >>> result = thread.get() :param prefix: return items prefixed with this value @@ -1391,6 +1393,8 @@ def list_repositories_with_http_info(self, prefix : Annotated[Optional[StrictStr :type after: str :param amount: how many items to return :type amount: int + :param search: string for searching relevant entries + :type search: str :param async_req: Whether to execute the request asynchronously. :type async_req: bool, optional :param _preload_content: if False, the ApiResponse.data will @@ -1421,7 +1425,8 @@ def list_repositories_with_http_info(self, prefix : Annotated[Optional[StrictStr _all_params = [ 'prefix', 'after', - 'amount' + 'amount', + 'search' ] _all_params.extend( [ @@ -1461,6 +1466,9 @@ def list_repositories_with_http_info(self, prefix : Annotated[Optional[StrictStr if _params.get('amount') is not None: # noqa: E501 _query_params.append(('amount', _params['amount'])) + if _params.get('search') is not None: # noqa: E501 + _query_params.append(('search', _params['search'])) + # process the header parameters _header_params = dict(_params.get('_headers', {})) # process the form parameters diff --git a/clients/rust/docs/RepositoriesApi.md b/clients/rust/docs/RepositoriesApi.md index 01567f9637a..3ac3c845855 100644 --- a/clients/rust/docs/RepositoriesApi.md +++ b/clients/rust/docs/RepositoriesApi.md @@ -278,7 +278,7 @@ Name | Type | Description | Required | Notes ## list_repositories -> models::RepositoryList list_repositories(prefix, after, amount) +> models::RepositoryList list_repositories(prefix, after, amount, search) list repositories ### Parameters @@ -289,6 +289,7 @@ Name | Type | Description | Required | Notes **prefix** | Option<**String**> | return items prefixed with this value | | **after** | Option<**String**> | return items after this value | | **amount** | Option<**i32**> | how many items to return | |[default to 100] +**search** | Option<**String**> | string for searching relevant entries | | ### Return type diff --git a/clients/rust/src/apis/repositories_api.rs b/clients/rust/src/apis/repositories_api.rs index 87217f1235c..8f895e2408f 100644 --- a/clients/rust/src/apis/repositories_api.rs +++ b/clients/rust/src/apis/repositories_api.rs @@ -483,7 +483,7 @@ pub async fn get_repository_metadata(configuration: &configuration::Configuratio } } -pub async fn list_repositories(configuration: &configuration::Configuration, prefix: Option<&str>, after: Option<&str>, amount: Option) -> Result> { +pub async fn list_repositories(configuration: &configuration::Configuration, prefix: Option<&str>, after: Option<&str>, amount: Option, search: Option<&str>) -> Result> { let local_var_configuration = configuration; let local_var_client = &local_var_configuration.client; @@ -500,6 +500,9 @@ pub async fn list_repositories(configuration: &configuration::Configuration, pre if let Some(ref local_var_str) = amount { local_var_req_builder = local_var_req_builder.query(&[("amount", &local_var_str.to_string())]); } + if let Some(ref local_var_str) = search { + local_var_req_builder = local_var_req_builder.query(&[("search", &local_var_str.to_string())]); + } if let Some(ref local_var_user_agent) = local_var_configuration.user_agent { local_var_req_builder = local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone()); } diff --git a/docs/assets/js/swagger.yml b/docs/assets/js/swagger.yml index e4e16d94b0f..2a5f0cde7d6 100644 --- a/docs/assets/js/swagger.yml +++ b/docs/assets/js/swagger.yml @@ -12,11 +12,11 @@ servers: - url: "/api/v1" description: lakeFS server endpoint security: - - jwt_token: [] - - basic_auth: [] - - cookie_auth: [] - - oidc_auth: [] - - saml_auth: [] + - jwt_token: [ ] + - basic_auth: [ ] + - cookie_auth: [ ] + - oidc_auth: [ ] + - saml_auth: [ ] components: securitySchemes: basic_auth: @@ -70,6 +70,13 @@ components: description: delimiter used to group common prefixes by schema: type: string + + PaginationSearchString: + in: query + name: search + description: string for searching relevant entries + schema: + type: string IfNoneMatch: in: header @@ -298,7 +305,7 @@ components: type: string path_type: type: string - enum: [common_prefix, object] + enum: [ common_prefix, object ] physical_address: type: string description: | @@ -442,12 +449,12 @@ components: properties: type: type: string - enum: [added, removed, changed, conflict, prefix_changed] + enum: [ added, removed, changed, conflict, prefix_changed ] path: type: string path_type: type: string - enum: [common_prefix, object] + enum: [ common_prefix, object ] size_bytes: type: integer description: represents the size of the added/changed/deleted entry @@ -473,7 +480,7 @@ components: properties: type: type: string - enum: [object, common_prefix, reset] + enum: [ object, common_prefix, reset ] description: What to reset according to path. path: type: string @@ -695,7 +702,7 @@ components: default: false hidden: type: boolean - description: When set, branch will not show up when listing branches by default. *EXPERIMENTAL* + description: When set, branch will not show up when listing branches by default. *EXPERIMENTAL* default: false TagCreation: @@ -742,7 +749,7 @@ components: error: type: string refs: - $ref: "#/components/schemas/RefsDump" + $ref: "#/components/schemas/RefsDump" RepositoryRestoreStatus: type: object @@ -901,7 +908,7 @@ components: RBAC will remain enabled on GUI if "external". That only works with an external auth service. type: string - enum: [none, simplified, external] + enum: [ none, simplified, external ] login_url: description: primary URL to use for login. type: string @@ -934,7 +941,7 @@ components: properties: state: type: string - enum: [initialized, not_initialized] + enum: [ initialized, not_initialized ] comm_prefs_missing: type: boolean description: true if the comm prefs are missing. @@ -1148,7 +1155,7 @@ components: properties: effect: type: string - enum: [allow, deny] + enum: [ allow, deny ] resource: type: string action: @@ -1278,7 +1285,7 @@ components: type: string status: type: string - enum: [failed, completed] + enum: [ failed, completed ] commit_id: type: string @@ -1318,7 +1325,7 @@ components: format: date-time status: type: string - enum: [failed, completed] + enum: [ failed, completed ] HookRunList: type: object @@ -1705,7 +1712,7 @@ components: - installation_id - reports - ExternalPrincipalList: + ExternalPrincipalList: type: object required: - pagination @@ -1760,36 +1767,36 @@ components: PullRequest: allOf: - - $ref: '#/components/schemas/PullRequestBasic' - - required: + - $ref: '#/components/schemas/PullRequestBasic' + - required: - status - title - description - - type: object - required: - - id - - creation_date - - author - - source_branch - - destination_branch - properties: - id: - type: string - creation_date: - type: string - format: date-time - author: - type: string - source_branch: - type: string - destination_branch: - type: string - merged_commit_id: - type: string - description: the commit id of merged PRs - closed_date: - type: string - format: date-time + - type: object + required: + - id + - creation_date + - author + - source_branch + - destination_branch + properties: + id: + type: string + creation_date: + type: string + format: date-time + author: + type: string + source_branch: + type: string + destination_branch: + type: string + merged_commit_id: + type: string + description: the commit id of merged PRs + closed_date: + type: string + format: date-time PullRequestsList: type: object @@ -1836,7 +1843,7 @@ paths: - internal operationId: setupCommPrefs summary: setup communications preferences - security: [] + security: [ ] requestBody: required: true content: @@ -1869,7 +1876,7 @@ paths: - internal operationId: getSetupState summary: check if the lakeFS installation is already set up - security: [] + security: [ ] responses: 200: description: lakeFS setup state @@ -1886,7 +1893,7 @@ paths: - internal operationId: setup summary: setup lakeFS and create a first user - security: [] + security: [ ] requestBody: required: true content: @@ -1933,7 +1940,7 @@ paths: - auth operationId: login summary: perform a login - security: [] # No authentication + security: [ ] # No authentication requestBody: content: application/json: @@ -1966,7 +1973,7 @@ paths: - auth operationId: externalPrincipalLogin summary: perform a login using an external authenticator - security: [] + security: [ ] requestBody: content: application/json: @@ -1998,7 +2005,7 @@ paths: - experimental operationId: stsLogin # change to stsLogin summary: perform a login with STS - security: [] + security: [ ] requestBody: required: true content: @@ -2025,7 +2032,7 @@ paths: - internal operationId: getAuthCapabilities summary: list authentication capabilities supported - security: [] + security: [ ] responses: 200: description: auth capabilities @@ -2668,11 +2675,11 @@ paths: - experimental operationId: createUserExternalPrincipal summary: attach external principal to user - requestBody: + requestBody: required: false - content: - application/json: - schema: + content: + application/json: + schema: $ref: "#/components/schemas/ExternalPrincipalCreation" responses: 201: @@ -2753,7 +2760,7 @@ paths: - external - experimental operationId: getExternalPrincipal - summary: describe external principal by id + summary: describe external principal by id responses: 200: description: external principal @@ -2899,7 +2906,7 @@ paths: description: too many requests default: $ref: "#/components/responses/ServerError" - + /repositories: get: tags: @@ -2908,6 +2915,7 @@ paths: - $ref: "#/components/parameters/PaginationPrefix" - $ref: "#/components/parameters/PaginationAfter" - $ref: "#/components/parameters/PaginationAmount" + - $ref: "#/components/parameters/PaginationSearchString" operationId: listRepositories summary: list repositories responses: @@ -4142,7 +4150,7 @@ paths: name: type schema: type: string - enum: [two_dot, three_dot] + enum: [ two_dot, three_dot ] default: three_dot get: @@ -4564,10 +4572,10 @@ paths: application/json: schema: $ref: "#/components/schemas/StagingMetadata" - + parameters: - $ref: "#/components/parameters/IfNoneMatch" - + responses: 200: # This actually violates HTTP, which requires returning 201 if a new object was @@ -5927,7 +5935,7 @@ paths: /healthcheck: get: operationId: healthCheck - security: [] + security: [ ] tags: - healthCheck description: check that the API server is up and running diff --git a/pkg/api/controller.go b/pkg/api/controller.go index d7e78eb38a6..c5d8ee963d3 100644 --- a/pkg/api/controller.go +++ b/pkg/api/controller.go @@ -1893,7 +1893,7 @@ func (c *Controller) ListRepositories(w http.ResponseWriter, r *http.Request, pa ctx := r.Context() c.LogAction(ctx, "list_repos", r, "", "", "") - repos, hasMore, err := c.Catalog.ListRepositories(ctx, paginationAmount(params.Amount), paginationPrefix(params.Prefix), "", paginationAfter(params.After)) + repos, hasMore, err := c.Catalog.ListRepositories(ctx, paginationAmount(params.Amount), paginationPrefix(params.Prefix), paginationSearch(params.Search), paginationAfter(params.After)) if c.handleAPIError(ctx, w, r, err) { return } @@ -5470,6 +5470,13 @@ func paginationDelimiter(v *apigen.PaginationDelimiter) string { return string(*v) } +func paginationSearch(v *apigen.PaginationSearchString) string { + if v == nil { + return "" + } + return string(*v) +} + func paginationAmount(v *apigen.PaginationAmount) int { if v == nil { return DefaultPerPage