@pipedream/zendesk 0.5.0 → 0.6.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -3,9 +3,9 @@ import app from "../../zendesk.app.mjs";
3
3
  export default {
4
4
  key: "zendesk-create-ticket",
5
5
  name: "Create Ticket",
6
- description: "Creates a ticket. [See the docs](https://developer.zendesk.com/api-reference/ticketing/tickets/tickets/#create-ticket).",
6
+ description: "Creates a ticket. [See the documentation](https://developer.zendesk.com/api-reference/ticketing/tickets/tickets/#create-ticket).",
7
7
  type: "action",
8
- version: "0.1.0",
8
+ version: "0.1.2",
9
9
  props: {
10
10
  app,
11
11
  ticketCommentBody: {
@@ -3,9 +3,9 @@ import app from "../../zendesk.app.mjs";
3
3
  export default {
4
4
  key: "zendesk-delete-ticket",
5
5
  name: "Delete Ticket",
6
- description: "Deletes a ticket. [See the docs](https://developer.zendesk.com/api-reference/ticketing/tickets/tickets/#delete-ticket).",
6
+ description: "Deletes a ticket. [See the documentation](https://developer.zendesk.com/api-reference/ticketing/tickets/tickets/#delete-ticket).",
7
7
  type: "action",
8
- version: "0.1.0",
8
+ version: "0.1.2",
9
9
  props: {
10
10
  app,
11
11
  ticketId: {
@@ -3,9 +3,9 @@ import app from "../../zendesk.app.mjs";
3
3
  export default {
4
4
  key: "zendesk-update-ticket",
5
5
  name: "Update Ticket",
6
- description: "Updates a ticket. [See the docs](https://developer.zendesk.com/api-reference/ticketing/tickets/tickets/#update-ticket).",
6
+ description: "Updates a ticket. [See the documentation](https://developer.zendesk.com/api-reference/ticketing/tickets/tickets/#update-ticket).",
7
7
  type: "action",
8
- version: "0.1.0",
8
+ version: "0.1.2",
9
9
  props: {
10
10
  app,
11
11
  ticketId: {
@@ -31,6 +31,197 @@ const TICKET_STATUS_OPTIONS = {
31
31
  CLOSED: "closed",
32
32
  };
33
33
 
34
+ const TICKET_FIELD_OPTIONS = [
35
+ {
36
+ label: "Current User Details",
37
+ value: "{{current_user.details}}",
38
+ },
39
+ {
40
+ label: "Current User Email",
41
+ value: "{{current_user.email}}",
42
+ },
43
+ {
44
+ label: "Current User External ID",
45
+ value: "{{current_user.external_id}}",
46
+ },
47
+ {
48
+ label: "Current User First Name",
49
+ value: "{{current_user.first_name}}",
50
+ },
51
+ {
52
+ label: "Current User Language",
53
+ value: "{{current_user.language}}",
54
+ },
55
+ {
56
+ label: "Current User Name",
57
+ value: "{{current_user.name}}",
58
+ },
59
+ {
60
+ label: "Current User Notes",
61
+ value: "{{current_user.notes}}",
62
+ },
63
+ {
64
+ label: "Current User Organization Details",
65
+ value: "{{current_user.organization.details}}",
66
+ },
67
+ {
68
+ label: "Current User Organization Name",
69
+ value: "{{current_user.organization.name}}",
70
+ },
71
+ {
72
+ label: "Current User Organization Notes",
73
+ value: "{{current_user.organization.notes}}",
74
+ },
75
+ {
76
+ label: "Current User Phone",
77
+ value: "{{current_user.phone}}",
78
+ },
79
+ {
80
+ label: "Satisfaction Current Comment",
81
+ value: "{{satisfaction.current_comment",
82
+ },
83
+ {
84
+ label: "Satisfaction Current Rating",
85
+ value: "{{satisfaction.current_rating}}",
86
+ },
87
+ {
88
+ label: "Ticket Account",
89
+ value: "{{ticket.account}}",
90
+ },
91
+ {
92
+ label: "Ticket Assignee Email",
93
+ value: "{{ticket.assignee.email}}",
94
+ },
95
+ {
96
+ label: "Ticket Assignee First Name",
97
+ value: "{{ticket.assignee.first_name}}",
98
+ },
99
+ {
100
+ label: "Ticket Assignee Last Name",
101
+ value: "{{ticket.assignee.last_name}}",
102
+ },
103
+ {
104
+ label: "Ticket Name",
105
+ value: "{{ticket.name}}",
106
+ },
107
+ {
108
+ label: "Ticket Brand Name",
109
+ value: "{{ticket.brand.name}}",
110
+ },
111
+ {
112
+ label: "Ticket CC Names",
113
+ value: "{{ticket.cc_names}}",
114
+ },
115
+ {
116
+ label: "Ticket CSS",
117
+ value: "{{ticket.css}}",
118
+ },
119
+ {
120
+ label: "Ticket Current Holiday Name",
121
+ value: "{{ticket.current_holiday_name}}",
122
+ },
123
+ {
124
+ label: "Ticket Description",
125
+ value: "{{ticket.description}}",
126
+ },
127
+ {
128
+ label: "Ticket Due Date",
129
+ value: "{{ticket.due_date}}",
130
+ },
131
+ {
132
+ label: "Ticket External ID",
133
+ value: "{{ticket.external_id}}",
134
+ },
135
+ {
136
+ label: "Ticket Group Name",
137
+ value: "{{ticket.group.name}}",
138
+ },
139
+ {
140
+ label: "Ticket Latest Comment HTML",
141
+ value: "{{ticket.latest_comment_html}}",
142
+ },
143
+ {
144
+ label: "Ticket Latest Public Comment HTML",
145
+ value: "{{ticket.latest_public_comment_html}}",
146
+ },
147
+ {
148
+ label: "Ticket Organization Details",
149
+ value: "{{ticket.organization.details}}",
150
+ },
151
+ {
152
+ label: "Ticket Organization External ID",
153
+ value: "{{ticket.organization.external_id}}",
154
+ },
155
+ {
156
+ label: "Ticket Organization Name",
157
+ value: "{{ticket.organization.name}}",
158
+ },
159
+ {
160
+ label: "Ticket Organization Notes",
161
+ value: "{{ticket.organization.notes}}",
162
+ },
163
+ {
164
+ label: "Ticket Priority",
165
+ value: "{{ticket.priority}}",
166
+ },
167
+ {
168
+ label: "Ticket Requester Details",
169
+ value: "{{ticket.requester.details}}",
170
+ },
171
+ {
172
+ label: "Ticket Requester Email",
173
+ value: "{{ticket.requester.email}}",
174
+ },
175
+ {
176
+ label: "Ticket Requester External ID",
177
+ value: "{{ticket.requester.external_id}}",
178
+ },
179
+ {
180
+ label: "Ticket Requester First Name",
181
+ value: "{{ticket.requester.first_name}}",
182
+ },
183
+ {
184
+ label: "Ticket Requester Language",
185
+ value: "{{ticket.requester.language}}",
186
+ },
187
+ {
188
+ label: "Ticket Requester Last Name",
189
+ value: "{{ticket.requester.last_name}}",
190
+ },
191
+ {
192
+ label: "Ticket Requester Name",
193
+ value: "{{ticket.requester.name}}",
194
+ },
195
+ {
196
+ label: "Ticket Requester Phone",
197
+ value: "{{ticket.requester.phone}}",
198
+ },
199
+ {
200
+ label: "Ticket Status",
201
+ value: "{{ticket.status}}",
202
+ },
203
+ {
204
+ label: "Ticket Tags",
205
+ value: "{{ticket.tags}}",
206
+ },
207
+ {
208
+ label: "Ticket Title",
209
+ value: "{{ticket.title}}",
210
+ },
211
+ {
212
+ label: "Ticket Type",
213
+ value: "{{ticket.ticket_type}}",
214
+ },
215
+ {
216
+ label: "Ticket URL",
217
+ value: "{{ticket.url}}",
218
+ },
219
+ {
220
+ label: "Ticket Via",
221
+ value: "{{ticket.via}}",
222
+ },
223
+ ];
224
+
34
225
  export default {
35
226
  SUBDOMAIN_PLACEHOLDER,
36
227
  BASE_URL,
@@ -50,4 +241,5 @@ export default {
50
241
  DEFAULT_TIMEOUT,
51
242
  TICKET_PRIORITY_OPTIONS,
52
243
  TICKET_STATUS_OPTIONS,
244
+ TICKET_FIELD_OPTIONS,
53
245
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pipedream/zendesk",
3
- "version": "0.5.0",
3
+ "version": "0.6.1",
4
4
  "description": "Pipedream Zendesk Components",
5
5
  "main": "zendesk.app.mjs",
6
6
  "keywords": [
@@ -4,7 +4,29 @@ export default {
4
4
  ...common,
5
5
  methods: {
6
6
  ...common.methods,
7
+ convertToCamelCase(str) {
8
+ return str.replace(/(?:^\w|[A-Z]|\b\w)/g, function(match, index) {
9
+ return index === 0
10
+ ? match.toLowerCase()
11
+ : match.toUpperCase();
12
+ }).replace(/\s+/g, "");
13
+ },
7
14
  getTriggerPayload() {
15
+ if (this.jsonBody) {
16
+ return JSON.parse(this.jsonBody);
17
+ }
18
+ if (this.fields?.length) {
19
+ const payload = {
20
+ ticketId: "{{ticket.id}}",
21
+ createdAt: "{{ticket.created_at_with_timestamp}}",
22
+ updatedAt: "{{ticket.updated_at_with_timestamp}}",
23
+ };
24
+ for (const field of this.fields) {
25
+ const key = this.convertToCamelCase(field.label);
26
+ payload[key] = field.value;
27
+ }
28
+ return payload;
29
+ }
8
30
  return {
9
31
  ticketId: "{{ticket.id}}",
10
32
  title: "{{ticket.title}}",
@@ -19,6 +19,18 @@ export default {
19
19
  "customSubdomain",
20
20
  ],
21
21
  },
22
+ fields: {
23
+ propDefinition: [
24
+ app,
25
+ "fields",
26
+ ],
27
+ },
28
+ jsonBody: {
29
+ type: "string",
30
+ label: "JSON Body",
31
+ description: "Custom JSON Body of the incoming payload. Setting `jsonBody` will overwrite the `fields` prop",
32
+ optional: true,
33
+ },
22
34
  },
23
35
  hooks: {
24
36
  async activate() {
@@ -197,6 +209,9 @@ export default {
197
209
  ) === 0
198
210
  );
199
211
  },
212
+ isRelevant() {
213
+ return true;
214
+ },
200
215
  },
201
216
  async run(event) {
202
217
  const {
@@ -221,12 +236,17 @@ export default {
221
236
  return;
222
237
  }
223
238
 
239
+ const isRelevant = await this.isRelevant(payload);
240
+ if (!isRelevant) {
241
+ return;
242
+ }
243
+
224
244
  const ts = Date.parse(payload.updatedAt);
225
245
  const id = `${payload.ticketId}-${ts}`;
226
246
 
227
247
  this.$emit(payload, {
228
248
  id,
229
- summary: payload.title,
249
+ summary: payload.title || payload.ticketId,
230
250
  ts,
231
251
  });
232
252
  },
@@ -6,7 +6,7 @@ export default {
6
6
  key: "zendesk-new-ticket",
7
7
  type: "source",
8
8
  description: "Emit new event when a ticket is created",
9
- version: "0.2.0",
9
+ version: "0.2.2",
10
10
  dedupe: "unique",
11
11
  methods: {
12
12
  ...common.methods,
@@ -0,0 +1,50 @@
1
+ import common from "../common/ticket.mjs";
2
+
3
+ export default {
4
+ ...common,
5
+ key: "zendesk-ticket-added-to-view",
6
+ name: "New Ticket Added to View (Instant)",
7
+ description: "Emit new event when a ticket is added to the specified view",
8
+ version: "0.0.2",
9
+ type: "source",
10
+ dedupe: "unique",
11
+ props: {
12
+ ...common.props,
13
+ viewId: {
14
+ propDefinition: [
15
+ common.props.app,
16
+ "viewId",
17
+ ],
18
+ },
19
+ },
20
+ methods: {
21
+ ...common.methods,
22
+ getWebhookName() {
23
+ return "Ticket Added To View Webhook";
24
+ },
25
+ getTriggerTitle() {
26
+ return "Ticket Added To View Trigger";
27
+ },
28
+ getTriggerConditions() {
29
+ return {
30
+ any: [
31
+ {
32
+ field: "update_type",
33
+ value: "Change",
34
+ },
35
+ {
36
+ field: "update_type",
37
+ value: "Create",
38
+ },
39
+ ],
40
+ };
41
+ },
42
+ async isRelevant(payload) {
43
+ const { tickets } = await this.app.listTicketsInView({
44
+ viewId: this.viewId,
45
+ });
46
+ const foundTicket = tickets.find(({ id }) => id == payload.ticketId);
47
+ return foundTicket;
48
+ },
49
+ },
50
+ };
@@ -6,7 +6,7 @@ export default {
6
6
  key: "zendesk-ticket-closed",
7
7
  type: "source",
8
8
  description: "Emit new event when a ticket has changed to closed status",
9
- version: "0.2.0",
9
+ version: "0.2.2",
10
10
  dedupe: "unique",
11
11
  methods: {
12
12
  ...common.methods,
@@ -2,19 +2,19 @@ import common from "../common/ticket.mjs";
2
2
 
3
3
  export default {
4
4
  ...common,
5
- name: "Ticket Pended (Instant)",
5
+ name: "Ticket Pending (Instant)",
6
6
  key: "zendesk-ticket-pended",
7
7
  type: "source",
8
8
  description: "Emit new event when a ticket has changed to pending status",
9
- version: "0.2.0",
9
+ version: "0.2.2",
10
10
  dedupe: "unique",
11
11
  methods: {
12
12
  ...common.methods,
13
13
  getWebhookName() {
14
- return "Ticket Pended Webhook";
14
+ return "Ticket Pending Webhook";
15
15
  },
16
16
  getTriggerTitle() {
17
- return "Ticket Pended Trigger";
17
+ return "Ticket Pending Trigger";
18
18
  },
19
19
  getTriggerConditions() {
20
20
  return {
@@ -6,7 +6,7 @@ export default {
6
6
  key: "zendesk-ticket-solved",
7
7
  type: "source",
8
8
  description: "Emit new event when a ticket has changed to solved status",
9
- version: "0.2.0",
9
+ version: "0.2.2",
10
10
  dedupe: "unique",
11
11
  methods: {
12
12
  ...common.methods,
@@ -6,7 +6,7 @@ export default {
6
6
  key: "zendesk-ticket-updated",
7
7
  type: "source",
8
8
  description: "Emit new event when a ticket has been updated",
9
- version: "0.2.0",
9
+ version: "0.2.2",
10
10
  dedupe: "unique",
11
11
  methods: {
12
12
  ...common.methods,
package/zendesk.app.mjs CHANGED
@@ -7,7 +7,7 @@ export default {
7
7
  propDefinitions: {
8
8
  categoryId: {
9
9
  type: "string",
10
- label: "Trigger category ID",
10
+ label: "Trigger Category ID",
11
11
  description: "The ID of the trigger category. [See the docs here](https://developer.zendesk.com/api-reference/ticketing/business-rules/trigger_categories/#list-trigger-categories)",
12
12
  async options({ prevContext }) {
13
13
  const { afterCursor } = prevContext;
@@ -69,6 +69,56 @@ export default {
69
69
  };
70
70
  },
71
71
  },
72
+ viewId: {
73
+ type: "string",
74
+ label: "View ID",
75
+ description: "The ID of the view",
76
+ async options({ prevContext }) {
77
+ const { afterCursor } = prevContext;
78
+
79
+ const {
80
+ views,
81
+ meta,
82
+ } =
83
+ await this.listViews({
84
+ params: {
85
+ [constants.PAGE_SIZE_PARAM]: constants.DEFAULT_LIMIT,
86
+ [constants.PAGE_AFTER_PARAM]: afterCursor,
87
+ },
88
+ });
89
+
90
+ return {
91
+ context: {
92
+ afterCursor: meta.after_cursor,
93
+ },
94
+ options: views.map(({
95
+ id, title,
96
+ }) => ({
97
+ label: title || `View #${id}`,
98
+ value: id,
99
+ })),
100
+ };
101
+ },
102
+ },
103
+ fields: {
104
+ type: "string[]",
105
+ label: "Fields",
106
+ description: "Ticket fields to be included in the incoming webhook payload",
107
+ withLabel: true,
108
+ optional: true,
109
+ async options() {
110
+ // placehoders reference - https://support.zendesk.com/hc/en-us/articles/4408886858138
111
+ const { ticket_fields: customFields } = await this.listTicketFields();
112
+ const fields = customFields.reverse().map(({
113
+ id, title,
114
+ }) => ({
115
+ label: title,
116
+ value: `{{ticket.ticket_field_${id}}}`,
117
+ }));
118
+ fields.push(...constants.TICKET_FIELD_OPTIONS);
119
+ return fields;
120
+ },
121
+ },
72
122
  ticketCommentBody: {
73
123
  type: "string",
74
124
  label: "Comment body",
@@ -161,5 +211,25 @@ export default {
161
211
  ...args,
162
212
  });
163
213
  },
214
+ listViews(args = {}) {
215
+ return this.makeRequest({
216
+ path: "/views",
217
+ ...args,
218
+ });
219
+ },
220
+ listTicketsInView({
221
+ viewId, ...args
222
+ } = {}) {
223
+ return this.makeRequest({
224
+ path: `/views/${viewId}/tickets`,
225
+ ...args,
226
+ });
227
+ },
228
+ listTicketFields(args = {}) {
229
+ return this.makeRequest({
230
+ path: "/ticket_fields",
231
+ ...args,
232
+ });
233
+ },
164
234
  },
165
235
  };