UNPKG

@itwin/core-backend

Version:
41 lines 2.39 kB
/*--------------------------------------------------------------------------------------------- * Copyright (c) Bentley Systems, Incorporated. All rights reserved. * See LICENSE.md in the project root for license terms and full copyright notice. *--------------------------------------------------------------------------------------------*/ /** @packageDocumentation * @module RpcInterface */ import { Logger } from "@itwin/core-bentley"; import { CommonLoggerCategory, RpcProtocolEvent, WebAppRpcLogging } from "@itwin/core-common"; import * as os from "os"; /* eslint-disable @typescript-eslint/no-deprecated */ export class WebAppRpcLoggingBackend extends WebAppRpcLogging { async logProtocolEvent(event, object) { switch (event) { case RpcProtocolEvent.RequestReceived: return this.logRequest(CommonLoggerCategory.RpcInterfaceBackend, "RpcInterface.backend.request", object.request); case RpcProtocolEvent.BackendErrorOccurred: return this.logErrorBackend("RpcInterface.backend.error", object); case RpcProtocolEvent.BackendResponseCreated: return this.logResponse(CommonLoggerCategory.RpcInterfaceBackend, "RpcInterface.backend.response", object.request, object.status, object.elapsed); } } getHostname() { return os.hostname(); } async logErrorBackend(message, invocation) { const operationDescriptor = this.buildOperationDescriptor(invocation.operation); const pathIds = this.findPathIds(invocation.request.path); const result = await invocation.result; const errorMessage = result.message ? result.message : result.objects; // Can be an error or an RpcSerializedValue const metadata = { method: invocation.request.method, path: invocation.request.path, status: invocation.status, errorMessage, // Alert! The following properties are required by Bentley DevOps standards. Do not change their names! ActivityId: invocation.request.id, // eslint-disable-line @typescript-eslint/naming-convention MachineName: this.getHostname(), // eslint-disable-line @typescript-eslint/naming-convention ...pathIds, }; Logger.logError(CommonLoggerCategory.RpcInterfaceBackend, `${message}.${operationDescriptor}`, metadata); } } //# sourceMappingURL=logging.js.map