Module astrapy.constants
Expand source code
# Copyright DataStax, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from __future__ import annotations
from typing import Any, Dict, Iterable, Tuple, Union
from astrapy.defaults import (
DATA_API_ENVIRONMENT_CASSANDRA,
DATA_API_ENVIRONMENT_DEV,
DATA_API_ENVIRONMENT_DSE,
DATA_API_ENVIRONMENT_HCD,
DATA_API_ENVIRONMENT_OTHER,
DATA_API_ENVIRONMENT_PROD,
DATA_API_ENVIRONMENT_TEST,
)
DocumentType = Dict[str, Any]
# ["field1", "field2"] allowed, but also:
# {"field": True/False}
# {"array_field": {"$slice": n}
# {"array_field": {"$slice": [n, m]}
ProjectionType = Union[
Iterable[str], Dict[str, Union[bool, Dict[str, Union[int, Iterable[int]]]]]
]
SortType = Dict[str, Any]
FilterType = Dict[str, Any]
VectorType = Iterable[float]
CallerType = Tuple[Union[str, None], Union[str, None]]
def normalize_optional_projection(
projection: ProjectionType | None,
) -> dict[str, bool | dict[str, int | Iterable[int]]] | None:
if projection:
if isinstance(projection, dict):
# already a dictionary
return projection
else:
# an iterable over strings: coerce to allow-list projection
return {field: True for field in projection}
else:
return None
class ReturnDocument:
"""
Admitted values for the `return_document` parameter in
`find_one_and_replace` and `find_one_and_update` collection
methods.
"""
def __init__(self) -> None:
raise NotImplementedError
BEFORE = "before"
AFTER = "after"
class SortDocuments:
"""
Admitted values for the `sort` parameter in the find collection methods,
e.g. `sort={"field": SortDocuments.ASCENDING}`.
"""
def __init__(self) -> None:
raise NotImplementedError
ASCENDING = 1
DESCENDING = -1
class VectorMetric:
"""
Admitted values for the "metric" parameter when creating vector collections
through the database `create_collection` method.
"""
def __init__(self) -> None:
raise NotImplementedError
DOT_PRODUCT = "dot_product"
EUCLIDEAN = "euclidean"
COSINE = "cosine"
class DefaultIdType:
"""
Admitted values for the "default_id_type" parameter when creating collections
through the database `create_collection` method.
"""
def __init__(self) -> None:
raise NotImplementedError
UUID = "uuid"
OBJECTID = "objectId"
UUIDV6 = "uuidv6"
UUIDV7 = "uuidv7"
DEFAULT = "uuid"
class Environment:
"""
Admitted values for `environment` property,
denoting the targeted API deployment type.
"""
def __init__(self) -> None:
raise NotImplementedError
PROD = DATA_API_ENVIRONMENT_PROD
DEV = DATA_API_ENVIRONMENT_DEV
TEST = DATA_API_ENVIRONMENT_TEST
DSE = DATA_API_ENVIRONMENT_DSE
HCD = DATA_API_ENVIRONMENT_HCD
CASSANDRA = DATA_API_ENVIRONMENT_CASSANDRA
OTHER = DATA_API_ENVIRONMENT_OTHER
values = {PROD, DEV, TEST, DSE, HCD, CASSANDRA, OTHER}
astra_db_values = {PROD, DEV, TEST}
__pdoc__ = {
"normalize_optional_projection": False,
}
Classes
class DefaultIdType
-
Admitted values for the "default_id_type" parameter when creating collections through the database
create_collection
method.Expand source code
class DefaultIdType: """ Admitted values for the "default_id_type" parameter when creating collections through the database `create_collection` method. """ def __init__(self) -> None: raise NotImplementedError UUID = "uuid" OBJECTID = "objectId" UUIDV6 = "uuidv6" UUIDV7 = "uuidv7" DEFAULT = "uuid"
Class variables
var DEFAULT
var OBJECTID
var UUID
var UUIDV6
var UUIDV7
class Environment
-
Admitted values for
environment
property, denoting the targeted API deployment type.Expand source code
class Environment: """ Admitted values for `environment` property, denoting the targeted API deployment type. """ def __init__(self) -> None: raise NotImplementedError PROD = DATA_API_ENVIRONMENT_PROD DEV = DATA_API_ENVIRONMENT_DEV TEST = DATA_API_ENVIRONMENT_TEST DSE = DATA_API_ENVIRONMENT_DSE HCD = DATA_API_ENVIRONMENT_HCD CASSANDRA = DATA_API_ENVIRONMENT_CASSANDRA OTHER = DATA_API_ENVIRONMENT_OTHER values = {PROD, DEV, TEST, DSE, HCD, CASSANDRA, OTHER} astra_db_values = {PROD, DEV, TEST}
Class variables
var CASSANDRA
var DEV
var DSE
var HCD
var OTHER
var PROD
var TEST
var astra_db_values
var values
class ReturnDocument
-
Admitted values for the
return_document
parameter infind_one_and_replace
andfind_one_and_update
collection methods.Expand source code
class ReturnDocument: """ Admitted values for the `return_document` parameter in `find_one_and_replace` and `find_one_and_update` collection methods. """ def __init__(self) -> None: raise NotImplementedError BEFORE = "before" AFTER = "after"
Class variables
var AFTER
var BEFORE
class SortDocuments
-
Admitted values for the
sort
parameter in the find collection methods, e.g.sort={"field": SortDocuments.ASCENDING}
.Expand source code
class SortDocuments: """ Admitted values for the `sort` parameter in the find collection methods, e.g. `sort={"field": SortDocuments.ASCENDING}`. """ def __init__(self) -> None: raise NotImplementedError ASCENDING = 1 DESCENDING = -1
Class variables
var ASCENDING
var DESCENDING
class VectorMetric
-
Admitted values for the "metric" parameter when creating vector collections through the database
create_collection
method.Expand source code
class VectorMetric: """ Admitted values for the "metric" parameter when creating vector collections through the database `create_collection` method. """ def __init__(self) -> None: raise NotImplementedError DOT_PRODUCT = "dot_product" EUCLIDEAN = "euclidean" COSINE = "cosine"
Class variables
var COSINE
var DOT_PRODUCT
var EUCLIDEAN