mirror of
https://github.com/Azure/cosmos-explorer.git
synced 2025-12-22 10:21:37 +00:00
66 lines
2.2 KiB
TypeScript
66 lines
2.2 KiB
TypeScript
import { Resource, TriggerDefinition } from "@azure/cosmos";
|
|
import { AuthType } from "../../AuthType";
|
|
import { userContext } from "../../UserContext";
|
|
import { createUpdateSqlTrigger, getSqlTrigger } from "../../Utils/arm/generatedClients/2020-04-01/sqlResources";
|
|
import {
|
|
SqlTriggerCreateUpdateParameters,
|
|
SqlTriggerResource,
|
|
} from "../../Utils/arm/generatedClients/2020-04-01/types";
|
|
import { logConsoleProgress } from "../../Utils/NotificationConsoleUtils";
|
|
import { client } from "../CosmosClient";
|
|
import { handleError } from "../ErrorHandlingUtils";
|
|
|
|
export async function createTrigger(
|
|
databaseId: string,
|
|
collectionId: string,
|
|
trigger: TriggerDefinition
|
|
): Promise<TriggerDefinition & Resource> {
|
|
const clearMessage = logConsoleProgress(`Creating trigger ${trigger.id}`);
|
|
try {
|
|
if (userContext.authType === AuthType.AAD && !userContext.useSDKOperations && userContext.apiType === "SQL") {
|
|
try {
|
|
const getResponse = await getSqlTrigger(
|
|
userContext.subscriptionId,
|
|
userContext.resourceGroup,
|
|
userContext.databaseAccount.name,
|
|
databaseId,
|
|
collectionId,
|
|
trigger.id
|
|
);
|
|
if (getResponse?.properties?.resource) {
|
|
throw new Error(`Create trigger failed: ${trigger.id} already exists`);
|
|
}
|
|
} catch (error) {
|
|
if (error.code !== "NotFound") {
|
|
throw error;
|
|
}
|
|
}
|
|
|
|
const createTriggerParams: SqlTriggerCreateUpdateParameters = {
|
|
properties: {
|
|
resource: trigger as SqlTriggerResource,
|
|
options: {},
|
|
},
|
|
};
|
|
const rpResponse = await createUpdateSqlTrigger(
|
|
userContext.subscriptionId,
|
|
userContext.resourceGroup,
|
|
userContext.databaseAccount.name,
|
|
databaseId,
|
|
collectionId,
|
|
trigger.id,
|
|
createTriggerParams
|
|
);
|
|
return rpResponse && (rpResponse.properties?.resource as TriggerDefinition & Resource);
|
|
}
|
|
|
|
const response = await client().database(databaseId).container(collectionId).scripts.triggers.create(trigger);
|
|
return response.resource;
|
|
} catch (error) {
|
|
handleError(error, "CreateTrigger", `Error while creating trigger ${trigger.id}`);
|
|
throw error;
|
|
} finally {
|
|
clearMessage();
|
|
}
|
|
}
|