Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

zapoj (new) #168

Draft
wants to merge 12 commits into
base: dev
Choose a base branch
from
76 changes: 76 additions & 0 deletions src/appmixer/zapoj/auth.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
'use strict';

module.exports = {

type: 'pwd',

definition: {

tokenType: 'authentication-token',

auth: {
subdomain: {
type: 'text',
name: 'Subdomain',
tooltip: 'Your Zapoj subdomain. For example, if your Zapoj URL is https://mycompany.zapoj.com, then the subdomain is mycompany.'
},
email: {
type: 'text',
name: 'Email'
},
password: {
type: 'password',
name: 'Password'
}
},

accountNameFromProfileInfo: async context => {

const { email, subdomain } = context;

return subdomain + ' - ' + email;
},

requestProfileInfo: async context => {

return {
email: context.email,
subdomain: context.subdomain
};
},

validate: async context => {

const { data, status, statusText } = await context.httpRequest({
method: 'POST',
url: `https://zapi.${context.subdomain}.zapoj.com/api/login`,
headers: {
'Content-Type': 'application/json'
},
data: {
email: context.email,
password: context.password
}
});

if (status === 200 && data?.authorization?.token) {

return {
token: data.authorization.token,
// number/string with seconds representing a token lifetime
expires: data.token_lifetime
};
}

// Currently POST to a URL with invalid domain returns 200 and HTML of the login page.
let error = {
subdomain: context.subdomain,
status,
statusText,
data
};

throw new Error(JSON.stringify(error, null, 2));
}
}
};
9 changes: 9 additions & 0 deletions src/appmixer/zapoj/bundle.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
{
"name": "appmixer.zapoj",
"version": "1.0.0",
"changelog": {
"1.0.0": [
"Initial release"
]
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
'use strict';

module.exports = {

async receive(context) {

const { notificationId } = context.messages.in.content;

const { data } = await context.httpRequest({
url: `https://messagetemplate.${context.auth?.subdomain}.zapoj.com/api/incidentAlerts/details/${notificationId}`,
headers: {
authorization: `Bearer ${context.auth?.token}`
}
});

const metadata = data?.messages;

await context.sendJson(metadata, 'out');
}
};
149 changes: 149 additions & 0 deletions src/appmixer/zapoj/core/GetIncidentAlertDetails/component.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,149 @@
{
"name": "appmixer.zapoj.core.GetIncidentAlertDetails",
"author": "Appmixer <[email protected]>",
"label": "Get Incident Alert Details",
"description": "Get the IT incident alert details.",
"private": false,
"version": "1.0.0",
"auth": {
"service": "appmixer:zapoj"
},
"quota": {
"manager": "appmixer:zapoj",
"resources": "request",
"scope": {
"userId": "{{userId}}"
}
},
"inPorts": [
{
"name": "in",
"schema": {
"type": "object",
"properties": {
"notificationId": {
"type": "string"
}
},
"required": ["notificationId"]
},
"inspector": {
"inputs": {
"notificationId": {
"type": "text",
"label": "Incident ID",
"index": 1,
"tooltip": "Example: ITA240819103043424."
}
}
}
}
],
"outPorts": [
{
"name": "out",
"options": [
{
"label": "_id",
"value": "_id"
},
{
"label": "Organization ID",
"value": "organizationId"
},
{
"label": "It Alert Service ID",
"value": "ItAlertServiceId"
},
{
"label": "It Alert Summary",
"value": "ItAlertSummery"
},
{
"label": "It Alert Severity",
"value": "ItAlertSeverity"
},
{
"label": "It Alert Body",
"value": "ItAlertBody"
},
{
"label": "It Alert Integration Type",
"value": "ItAlertIntegrationType"
},
{
"label": "It Alert From",
"value": "ItAlertFrom"
},
{
"label": "It Alert To",
"value": "ItAlertTo"
},
{
"label": "It Incident ID",
"value": "ItIncidentId"
},
{
"label": "It Alert Generated By",
"value": "ItAlertGeneratedBy"
},
{
"label": "It Alert Integrated By",
"value": "ItAlertIntegratedBy"
},
{
"label": "It Alert Status",
"value": "ItAlertStatus"
},
{
"label": "Created By ID",
"value": "createdById"
},
{
"label": "Created By Name",
"value": "createdByName"
},
{
"label": "Last Modified ID",
"value": "lastModifiedId"
},
{
"label": "Last Modified Name",
"value": "lastModifiedName"
},
{
"label": "Is Master",
"value": "isMaster"
},
{
"label": "Updated At",
"value": "updated_at"
},
{
"label": "Created At",
"value": "created_at"
},
{
"label": "Siblings Count",
"value": "siblingsCount"
},
{
"label": "Severity",
"value": "severity"
},
{
"label": "Siblings",
"value": "siblings",
"schema": {
"type": "array",
"items": {
"type": "object",
"properties": {}
}
}
}
]
}
],
"icon": ""
}
20 changes: 20 additions & 0 deletions src/appmixer/zapoj/core/GetIncidentMetadata/GetIncidentMetadata.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
'use strict';

module.exports = {

async receive(context) {

const { notificationId } = context.messages.in.content;

const { data } = await context.httpRequest({
url: `https://messagetemplate.${context.auth?.subdomain}.zapoj.com/api/notification/list/NE/details/${notificationId}`,
headers: {
authorization: `Bearer ${context.auth?.token}`
}
});

const metadata = data?.messages;

await context.sendJson(metadata, 'out');
}
};
Loading
Loading