in azure/functions/decorators/function_app.py [0:0]
def cosmos_db_output(self,
arg_name: str,
connection: str,
database_name: str,
container_name: str,
create_if_not_exists: Optional[bool] = None,
partition_key: Optional[str] = None,
container_throughput: Optional[int] = None,
preferred_locations: Optional[str] = None,
data_type: Optional[
Union[DataType, str]] = None,
**kwargs) \
-> Callable[..., Any]:
"""The cosmos_db_output decorator adds
:class:`CosmosDBOutput` to the :class:`FunctionBuilder` object
for building :class:`Function` object used in worker function
indexing model. This decorator will work only with extension bundle 4.x
and above. For additional details, please refer
https://aka.ms/cosmosdb-v4-update.
This is equivalent to defining CosmosDBOutput
in the function.json which enables function to write to the CosmosDB.
All optional fields will be given default value by function host when
they are parsed by function host.
Ref: https://aka.ms/azure-function-binding-cosmosdb-v4
:param arg_name: The name of the variable that represents CosmosDB
output object in function code.
:param connection: The name of an app setting or
setting collection that specifies how to connect to the Azure Cosmos
DB account being monitored
:param database_name: The name of the Azure Cosmos DB database with
the collection being monitored
:param container_name: The name of the container being monitored
:param create_if_not_exists: A boolean value to indicate whether the
collection is created when it doesn't exist
:param partition_key: When CreateIfNotExists is true, it defines the
partition key path for the created collection
:param container_throughput: When createIfNotExists is true, it defines
the throughput of the created container
PreferredLocations, it can leverage multi-region writes in the Azure
Cosmos DB service
:param preferred_locations: Defines preferred locations (regions)
for geo-replicated database accounts in the Azure Cosmos DB service
:param data_type: Defines how Functions runtime should treat the
parameter value
:param kwargs: Keyword arguments for specifying additional binding
fields to include in the binding json
:return: Decorator function.
"""
@self._configure_function_builder
def wrap(fb):
def decorator():
fb.add_binding(
binding=CosmosDBOutput(
name=arg_name,
connection=connection,
database_name=database_name,
container_name=container_name,
create_if_not_exists=create_if_not_exists,
partition_key=partition_key,
container_throughput=container_throughput,
preferred_locations=preferred_locations,
data_type=parse_singular_param_to_enum(data_type,
DataType),
**kwargs))
return fb
return decorator()
return wrap