Show activation error details for trigger nodes (#1787)

*  Implement error details in toast notification

*  Refactor error notification

*  Pipe activation error in prod mode to FE

*  Add node name to activation error details

*  Disable ignoring with ts-check

* 📝 fix spelling

Co-authored-by: Ben Hesseldieck <b.hesseldieck@gmail.com>
This commit is contained in:
Iván Ovejero 2021-06-12 17:06:56 +02:00 committed by GitHub
parent 6ade0a00f5
commit c0ec1ed606
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 48 additions and 11 deletions

View file

@ -313,7 +313,6 @@ export class ActiveWorkflowRunner {
try { try {
await Db.collections.Webhook?.insert(webhook); await Db.collections.Webhook?.insert(webhook);
const webhookExists = await workflow.runWebhookMethod('checkExists', webhookData, NodeExecuteFunctions, mode, activation, false); const webhookExists = await workflow.runWebhookMethod('checkExists', webhookData, NodeExecuteFunctions, mode, activation, false);
if (webhookExists !== true) { if (webhookExists !== true) {
// If webhook does not exist yet create it // If webhook does not exist yet create it
@ -341,7 +340,7 @@ export class ActiveWorkflowRunner {
errorMessage = error.message; errorMessage = error.message;
} }
throw new Error(errorMessage); throw error;
} }
} }
// Save static data! // Save static data!

View file

@ -93,6 +93,10 @@ export function sendErrorResponse(res: Response, error: ResponseError) {
message: 'Unknown error', message: 'Unknown error',
}; };
if (error.name === 'NodeApiError') {
Object.assign(response, error);
}
if (error.errorCode) { if (error.errorCode) {
response.code = error.errorCode; response.code = error.errorCode;
} }

View file

@ -68,6 +68,11 @@ export async function makeRestApiRequest(context: IRestApiContext, method: Metho
const errorResponseData = error.response.data; const errorResponseData = error.response.data;
if (errorResponseData !== undefined && errorResponseData.message !== undefined) { if (errorResponseData !== undefined && errorResponseData.message !== undefined) {
if (errorResponseData.name === 'NodeApiError') {
errorResponseData.httpStatusCode = error.response.status;
throw errorResponseData;
}
throw new ResponseError(errorResponseData.message, {errorCode: errorResponseData.code, httpStatusCode: error.response.status, stack: errorResponseData.stack}); throw new ResponseError(errorResponseData.message, {errorCode: errorResponseData.code, httpStatusCode: error.response.status, stack: errorResponseData.stack});
} }

View file

@ -1,16 +1,12 @@
import Vue from 'vue';
import { Notification } from 'element-ui'; import { Notification } from 'element-ui';
import { ElNotificationOptions } from 'element-ui/types/notification'; import { ElNotificationOptions } from 'element-ui/types/notification';
import mixins from 'vue-typed-mixins'; import mixins from 'vue-typed-mixins';
import { externalHooks } from '@/components/mixins/externalHooks'; import { externalHooks } from '@/components/mixins/externalHooks';
// export const showMessage = {
export const showMessage = mixins(externalHooks).extend({ export const showMessage = mixins(externalHooks).extend({
methods: { methods: {
$showMessage (messageData: ElNotificationOptions) { $showMessage(messageData: ElNotificationOptions) {
messageData.dangerouslyUseHTMLString = true; messageData.dangerouslyUseHTMLString = true;
if (messageData.position === undefined) { if (messageData.position === undefined) {
messageData.position = 'bottom-right'; messageData.position = 'bottom-right';
@ -18,14 +14,47 @@ export const showMessage = mixins(externalHooks).extend({
return Notification(messageData); return Notification(messageData);
}, },
$showError (error: Error, title: string, message: string) {
$showError(error: Error, title: string, message: string) {
this.$showMessage({ this.$showMessage({
title, title,
message: `${message}<br /><i>${error.message}</i>`, message: `
${message}
<br>
<i>${error.message}</i>
${this.collapsableDetails(error)}`,
type: 'error', type: 'error',
duration: 0, duration: 0,
}); });
this.$externalHooks().run('showMessage.showError', { title, message, errorMessage: error.message });
this.$externalHooks().run('showMessage.showError', {
title,
message,
errorMessage: error.message,
});
},
// @ts-ignore
collapsableDetails({ description, node }: Error) {
if (!description) return '';
const errorDescription =
description.length > 500
? `${description.slice(0, 500)}...`
: description;
return `
<br>
<br>
<details>
<summary
style="color: #ff6d5a; font-weight: bold; cursor: pointer;"
>
Show Details
</summary>
<p>${node.name}: ${errorDescription}</p>
</details>
`;
}, },
}, },
}); });