UNPKG

@azure/cosmos

Version:
105 lines 4.38 kB
import { getIdFromLink, getPathFromLink, isResourceValid, ResourceType, } from "../../common/index.js"; import { QueryIterator } from "../../queryIterator.js"; import { UserDefinedFunction } from "./UserDefinedFunction.js"; import { UserDefinedFunctionResponse } from "./UserDefinedFunctionResponse.js"; import { getEmptyCosmosDiagnostics, withDiagnostics } from "../../utils/diagnostics.js"; /** * Used to create, upsert, query, or read all User Defined Functions. * * @see {@link UserDefinedFunction} to read, replace, or delete a given User Defined Function by id. */ export class UserDefinedFunctions { container; clientContext; /** * @hidden * @param container - The parent {@link Container}. */ constructor(container, clientContext) { this.container = container; this.clientContext = clientContext; } query(query, options) { const path = getPathFromLink(this.container.url, ResourceType.udf); const id = getIdFromLink(this.container.url); return new QueryIterator(this.clientContext, query, options, (diagnosticNode, innerOptions) => { return this.clientContext.queryFeed({ path, resourceType: ResourceType.udf, resourceId: id, resultFn: (result) => result.UserDefinedFunctions, query, options: innerOptions, diagnosticNode, }); }); } /** * Read all User Defined Functions. * @example Read all User Defined Functions to array. * ```ts snippet:UserDefinedFunctionsReadAll * import { CosmosClient } from "@azure/cosmos"; * * const endpoint = "https://your-account.documents.azure.com"; * const key = "<database account masterkey>"; * const client = new CosmosClient({ endpoint, key }); * * const { database } = await client.databases.createIfNotExists({ id: "Test Database" }); * * const { container } = await database.containers.createIfNotExists({ id: "Test Container" }); * * const { resources: udfList } = await container.scripts.userDefinedFunctions.readAll().fetchAll(); * ``` */ readAll(options) { return this.query(undefined, options); } /** * Create a UserDefinedFunction. * * Azure Cosmos DB supports JavaScript UDFs which can be used inside queries, stored procedures and triggers. * * For additional details, refer to the server-side JavaScript API documentation. * @example * ```ts snippet:UserDefinedFunctionsCreate * import { CosmosClient, UserDefinedFunctionDefinition } from "@azure/cosmos"; * * const endpoint = "https://your-account.documents.azure.com"; * const key = "<database account masterkey>"; * const client = new CosmosClient({ endpoint, key }); * const { database } = await client.databases.createIfNotExists({ id: "Test Database" }); * const { container } = await database.containers.createIfNotExists({ id: "Test Container" }); * * const udfDefinition: UserDefinedFunctionDefinition = { * id: "sample udf", * body: "function () { const x = 10; }", * }; * * const { resource: udf } = await container.scripts.userDefinedFunctions.create(udfDefinition); * ``` */ async create(body, options) { return withDiagnostics(async (diagnosticNode) => { if (body.body) { body.body = body.body.toString(); } const err = {}; if (!isResourceValid(body, err)) { throw err; } const path = getPathFromLink(this.container.url, ResourceType.udf); const id = getIdFromLink(this.container.url); const response = await this.clientContext.create({ body, path, resourceType: ResourceType.udf, resourceId: id, options, diagnosticNode, }); const ref = new UserDefinedFunction(this.container, response.result.id, this.clientContext); return new UserDefinedFunctionResponse(response.result, response.headers, response.code, ref, getEmptyCosmosDiagnostics()); }, this.clientContext); } } //# sourceMappingURL=UserDefinedFunctions.js.map