From d6485f121531267ed68fe54882864908a5732e21 Mon Sep 17 00:00:00 2001 From: Lei Xu Date: Thu, 27 Jun 2024 21:32:34 -0700 Subject: [PATCH] docs: add openapi rest api page (#1413) --- docs/mkdocs.yml | 4 + docs/openapi.yml | 347 +++++++++++++++++++++++++++++++++++++++++ docs/requirements.txt | 3 +- docs/src/cloud/rest.md | 1 + 4 files changed, 354 insertions(+), 1 deletion(-) create mode 100644 docs/openapi.yml create mode 100644 docs/src/cloud/rest.md diff --git a/docs/mkdocs.yml b/docs/mkdocs.yml index c14b0dff12..0f5a449075 100644 --- a/docs/mkdocs.yml +++ b/docs/mkdocs.yml @@ -57,6 +57,8 @@ plugins: - https://arrow.apache.org/docs/objects.inv - https://pandas.pydata.org/docs/objects.inv - mkdocs-jupyter + - render_swagger: + allow_arbitrary_locations : true markdown_extensions: - admonition @@ -158,6 +160,7 @@ nav: - API reference: - 🐍 Python: python/saas-python.md - 👾 JavaScript: javascript/modules.md + - REST API: cloud/rest.md - Quick start: basic.md - Concepts: @@ -228,6 +231,7 @@ nav: - API reference: - 🐍 Python: python/saas-python.md - 👾 JavaScript: javascript/modules.md + - REST API: cloud/rest.md extra_css: - styles/global.css diff --git a/docs/openapi.yml b/docs/openapi.yml new file mode 100644 index 0000000000..e014d61ec4 --- /dev/null +++ b/docs/openapi.yml @@ -0,0 +1,347 @@ +openapi: 3.1.0 +info: + version: 1.0.0 + title: LanceDB Cloud API + description: | + LanceDB Cloud API is a RESTful API that allows users to access and modify data stored in LanceDB Cloud. + Table actions are considered temporary resource creations and all use POST method. + contact: + name: LanceDB support + url: https://lancedb.com + email: contact@lancedb.com + +servers: + - url: https://{db}.{region}.api.lancedb.com + description: LanceDB + variables: + db: + default: "" + description: the name of DB + region: + default: "us-east-1" + description: the service region of the DB + +security: + - key_auth: [] + +components: + securitySchemes: + key_auth: + name: x-api-key + type: apiKey + in: header + parameters: + table_name: + name: name + in: path + description: name of the table + required: true + schema: + type: string + responses: + invalid_request: + description: Invalid request + content: + text/plain: + schema: + type: string + not_found: + description: Not found + content: + text/plain: + schema: + type: string + unauthorized: + description: Unauthorized + content: + text/plain: + schema: + type: string + requestBodies: + arrow_stream_buffer: + description: Arrow IPC stream buffer + required: true + content: + application/vnd.apache.arrow.stream: + schema: + type: string + format: binary + +paths: + /v1/table/: + get: + description: List tables, optionally, with pagination. + tags: + - Tables + summary: List Tables + operationId: listTables + parameters: + - name: limit + in: query + description: Limits the number of items to return. + schema: + type: integer + - name: page_token + in: query + description: Specifies the starting position of the next query + schema: + type: string + responses: + "200": + description: Successfully returned a list of tables in the DB + content: + application/json: + schema: + type: object + properties: + tables: + type: array + items: + type: string + page_token: + type: string + + "400": + $ref: "#/components/responses/invalid_request" + "401": + $ref: "#/components/responses/unauthorized" + "404": + $ref: "#/components/responses/not_found" + + /v1/table/{name}/create/: + post: + description: Create a new table + summary: Create a new table + operationId: createTable + tags: + - Tables + parameters: + - $ref: "#/components/parameters/table_name" + requestBody: + $ref: "#/components/requestBodies/arrow_stream_buffer" + responses: + "200": + description: Table successfully created + "400": + $ref: "#/components/responses/invalid_request" + "401": + $ref: "#/components/responses/unauthorized" + "404": + $ref: "#/components/responses/not_found" + + /v1/table/{name}/query/: + post: + description: Vector Query + url: https://{db-uri}.{aws-region}.api.lancedb.com/v1/table/{name}/query/ + tags: + - Data + summary: Vector Query + parameters: + - $ref: "#/components/parameters/table_name" + requestBody: + required: true + content: + application/json: + schema: + type: object + properties: + vector: + type: FixedSizeList + description: | + The targetted vector to search for. Required. + vector_column: + type: string + description: | + The column to query, it can be inferred from the schema if there is only one vector column. + prefilter: + type: boolean + description: | + Whether to prefilter the data. Optional. + k: + type: integer + description: | + The number of search results to return. Default is 10. + distance_type: + type: string + description: | + The distance metric to use for search. L2, Cosine, Dot and Hamming are supported. Default is L2. + bypass_vector_index: + type: boolean + description: | + Whether to bypass vector index. Optional. + filter: + type: string + description: | + A filter expression that specifies the rows to query. Optional. + columns: + type: array + items: + type: string + description: | + The columns to return. Optional. + nprobe: + type: integer + description: | + The number of probes to use for search. Optional. + refine_factor: + type: integer + description: | + The refine factor to use for search. Optional. + + responses: + "200": + description: top k results if query is successfully executed + content: + application/json: + schema: + type: object + properties: + results: + type: array + items: + type: object + properties: + id: + type: integer + selected_col_1_to_return: + type: col_1_type + selected_col_n_to_return: + type: col_n_type + _distance: + type: float + + "400": + $ref: "#/components/responses/invalid_request" + "401": + $ref: "#/components/responses/unauthorized" + "404": + $ref: "#/components/responses/not_found" + + /v1/table/{name}/insert/: + post: + description: Insert data to a table + tags: + - Data + operationId: insertData + summary: Insert data to a table + parameters: + - $ref: "#/components/parameters/table_name" + requestBody: + $ref: "#/components/requestBodies/arrow_stream_buffer" + + responses: + "200": + description: Insert successful + + "400": + $ref: "#/components/responses/invalid_request" + "401": + $ref: "#/components/responses/unauthorized" + "404": + $ref: "#/components/responses/not_found" + /v1/table/{name}/delete/: + post: + description: Delete rows from a table. + tags: + - Data + summary: Delete rows from a table + operationId: deleteData + parameters: + - $ref: "#/components/parameters/table_name" + requestBody: + required: true + content: + application/json: + schema: + type: object + properties: + predicate: + type: string + description: | + A filter expression that specifies the rows to delete. + responses: + "200": + description: Delete successful + "401": + $ref: "#/components/responses/unauthorized" + /v1/table/{name}/drop/: + post: + description: Drop a table + tags: + - Tables + summary: Drop a table + operationId: dropTable + parameters: + - $ref: "#/components/parameters/table_name" + requestBody: + $ref: "#/components/requestBodies/arrow_stream_buffer" + responses: + "200": + description: Drop successful + "401": + $ref: "#/components/responses/unauthorized" + + /v1/table/{name}/describe/: + post: + description: Describe a table and return Table Information. + tags: + - Tables + summary: Describe a table + operationId: describeTable + parameters: + - $ref: "#/components/parameters/table_name" + responses: + "200": + description: Table information + content: + application/json: + schema: + type: object + properties: + table: + type: string + version: + type: integer + schema: + type: string + stats: + type: object + "401": + $ref: "#/components/responses/unauthorized" + "404": + $ref: "#/components/responses/not_found" + + /v1/table/{name}/index/list/: + post: + description: List indexes of a table + tags: + - Tables + summary: List indexes of a table + operationId: listIndexes + parameters: + - $ref: "#/components/parameters/table_name" + responses: + "200": + description: Available list of indexes on the table. + content: + application/json: + schema: + type: object + properties: + indexes: + type: array + items: + type: object + properties: + columns: + type: array + items: + type: string + index_name: + type: string + index_uuid: + type: string + "401": + $ref: "#/components/responses/unauthorized" + "404": + $ref: "#/components/responses/not_found" diff --git a/docs/requirements.txt b/docs/requirements.txt index e5b8bbd320..bc463706a0 100644 --- a/docs/requirements.txt +++ b/docs/requirements.txt @@ -2,4 +2,5 @@ mkdocs==1.5.3 mkdocs-jupyter==0.24.1 mkdocs-material==9.5.3 mkdocstrings[python]==0.20.0 -pydantic \ No newline at end of file +mkdocs-render-swagger-plugin +pydantic diff --git a/docs/src/cloud/rest.md b/docs/src/cloud/rest.md new file mode 100644 index 0000000000..12e4bd06bc --- /dev/null +++ b/docs/src/cloud/rest.md @@ -0,0 +1 @@ +!!swagger ../../openapi.yml!!