feat(airbrake): add new errors trigger
This commit is contained in:
3
packages/backend/src/apps/airbrake/dynamic-data/index.js
Normal file
3
packages/backend/src/apps/airbrake/dynamic-data/index.js
Normal file
@@ -0,0 +1,3 @@
|
||||
import listProjects from './list-projects/index.js';
|
||||
|
||||
export default [listProjects];
|
@@ -0,0 +1,23 @@
|
||||
export default {
|
||||
name: 'List projects',
|
||||
key: 'listProjects',
|
||||
|
||||
async run($) {
|
||||
const projects = {
|
||||
data: [],
|
||||
};
|
||||
|
||||
const { data } = await $.http.get('/api/v4/projects');
|
||||
|
||||
if (data.projects.length) {
|
||||
for (const project of data.projects) {
|
||||
projects.data.push({
|
||||
value: project.id,
|
||||
name: project.name,
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
return projects;
|
||||
},
|
||||
};
|
@@ -2,6 +2,8 @@ import defineApp from '../../helpers/define-app.js';
|
||||
import setBaseUrl from './common/set-base-url.js';
|
||||
import auth from './auth/index.js';
|
||||
import addAuthToken from './common/add-auth-token.js';
|
||||
import triggers from './triggers/index.js';
|
||||
import dynamicData from './dynamic-data/index.js';
|
||||
|
||||
export default defineApp({
|
||||
name: 'Airbrake',
|
||||
@@ -14,4 +16,6 @@ export default defineApp({
|
||||
primaryColor: 'f58c54',
|
||||
beforeRequest: [setBaseUrl, addAuthToken],
|
||||
auth,
|
||||
triggers,
|
||||
dynamicData,
|
||||
});
|
||||
|
3
packages/backend/src/apps/airbrake/triggers/index.js
Normal file
3
packages/backend/src/apps/airbrake/triggers/index.js
Normal file
@@ -0,0 +1,3 @@
|
||||
import newErrors from './new-errors/index.js';
|
||||
|
||||
export default [newErrors];
|
@@ -0,0 +1,66 @@
|
||||
//import { URLSearchParams } from 'node:url';
|
||||
import defineTrigger from '../../../../helpers/define-trigger.js';
|
||||
|
||||
export default defineTrigger({
|
||||
name: 'New errors',
|
||||
key: 'newErrors',
|
||||
pollInterval: 15,
|
||||
description: 'Triggers when a new error occurs.',
|
||||
arguments: [
|
||||
{
|
||||
label: 'Project',
|
||||
key: 'projectId',
|
||||
type: 'dropdown',
|
||||
required: true,
|
||||
description: '',
|
||||
variables: true,
|
||||
source: {
|
||||
type: 'query',
|
||||
name: 'getDynamicData',
|
||||
arguments: [
|
||||
{
|
||||
name: 'key',
|
||||
value: 'listProjects',
|
||||
},
|
||||
],
|
||||
},
|
||||
},
|
||||
],
|
||||
|
||||
async run($) {
|
||||
const projectId = $.step.parameters.projectId;
|
||||
|
||||
const params = {
|
||||
limit: 100,
|
||||
page: 1,
|
||||
};
|
||||
|
||||
let next = false;
|
||||
do {
|
||||
const { data } = await $.http.get(
|
||||
`/api/v4/projects/${projectId}/groups`,
|
||||
{ params }
|
||||
);
|
||||
|
||||
if (data.count > params.limit) {
|
||||
params.page = params.page + 1;
|
||||
next = true;
|
||||
} else {
|
||||
next = false;
|
||||
}
|
||||
|
||||
if (!data?.groups?.length) {
|
||||
return;
|
||||
}
|
||||
|
||||
for (const group of data.groups) {
|
||||
$.pushTriggerItem({
|
||||
raw: group,
|
||||
meta: {
|
||||
internalId: group.id,
|
||||
},
|
||||
});
|
||||
}
|
||||
} while (next);
|
||||
},
|
||||
});
|
Reference in New Issue
Block a user