opencode-skills-collection 1.0.185 → 1.0.187

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.
Files changed (71) hide show
  1. package/bundled-skills/.antigravity-install-manifest.json +5 -1
  2. package/bundled-skills/3d-web-experience/SKILL.md +152 -37
  3. package/bundled-skills/agent-evaluation/SKILL.md +1088 -26
  4. package/bundled-skills/agent-memory-systems/SKILL.md +1037 -25
  5. package/bundled-skills/agent-tool-builder/SKILL.md +668 -16
  6. package/bundled-skills/ai-agents-architect/SKILL.md +271 -31
  7. package/bundled-skills/ai-product/SKILL.md +716 -26
  8. package/bundled-skills/ai-wrapper-product/SKILL.md +450 -44
  9. package/bundled-skills/algolia-search/SKILL.md +867 -15
  10. package/bundled-skills/autonomous-agents/SKILL.md +1033 -26
  11. package/bundled-skills/aws-serverless/SKILL.md +1046 -35
  12. package/bundled-skills/azure-functions/SKILL.md +1318 -19
  13. package/bundled-skills/browser-automation/SKILL.md +1065 -28
  14. package/bundled-skills/browser-extension-builder/SKILL.md +159 -32
  15. package/bundled-skills/bullmq-specialist/SKILL.md +347 -16
  16. package/bundled-skills/clerk-auth/SKILL.md +796 -15
  17. package/bundled-skills/computer-use-agents/SKILL.md +1870 -28
  18. package/bundled-skills/context-window-management/SKILL.md +271 -18
  19. package/bundled-skills/conversation-memory/SKILL.md +453 -24
  20. package/bundled-skills/crewai/SKILL.md +252 -46
  21. package/bundled-skills/discord-bot-architect/SKILL.md +1207 -34
  22. package/bundled-skills/docs/integrations/jetski-cortex.md +3 -3
  23. package/bundled-skills/docs/integrations/jetski-gemini-loader/README.md +1 -1
  24. package/bundled-skills/docs/maintainers/repo-growth-seo.md +3 -3
  25. package/bundled-skills/docs/maintainers/skills-update-guide.md +1 -1
  26. package/bundled-skills/docs/users/bundles.md +1 -1
  27. package/bundled-skills/docs/users/claude-code-skills.md +1 -1
  28. package/bundled-skills/docs/users/gemini-cli-skills.md +1 -1
  29. package/bundled-skills/docs/users/getting-started.md +1 -1
  30. package/bundled-skills/docs/users/kiro-integration.md +1 -1
  31. package/bundled-skills/docs/users/usage.md +4 -4
  32. package/bundled-skills/docs/users/visual-guide.md +4 -4
  33. package/bundled-skills/email-systems/SKILL.md +646 -26
  34. package/bundled-skills/faf-expert/SKILL.md +221 -0
  35. package/bundled-skills/faf-wizard/SKILL.md +252 -0
  36. package/bundled-skills/file-uploads/SKILL.md +212 -11
  37. package/bundled-skills/firebase/SKILL.md +646 -16
  38. package/bundled-skills/gcp-cloud-run/SKILL.md +1117 -32
  39. package/bundled-skills/graphql/SKILL.md +1026 -27
  40. package/bundled-skills/hubspot-integration/SKILL.md +804 -19
  41. package/bundled-skills/idea-darwin/SKILL.md +120 -0
  42. package/bundled-skills/inngest/SKILL.md +431 -16
  43. package/bundled-skills/interactive-portfolio/SKILL.md +342 -44
  44. package/bundled-skills/langfuse/SKILL.md +296 -41
  45. package/bundled-skills/langgraph/SKILL.md +259 -50
  46. package/bundled-skills/micro-saas-launcher/SKILL.md +343 -44
  47. package/bundled-skills/neon-postgres/SKILL.md +572 -15
  48. package/bundled-skills/nextjs-supabase-auth/SKILL.md +269 -21
  49. package/bundled-skills/notion-template-business/SKILL.md +371 -44
  50. package/bundled-skills/personal-tool-builder/SKILL.md +537 -44
  51. package/bundled-skills/plaid-fintech/SKILL.md +825 -19
  52. package/bundled-skills/prompt-caching/SKILL.md +438 -25
  53. package/bundled-skills/rag-engineer/SKILL.md +271 -29
  54. package/bundled-skills/salesforce-development/SKILL.md +912 -19
  55. package/bundled-skills/satori/SKILL.md +54 -0
  56. package/bundled-skills/scroll-experience/SKILL.md +381 -44
  57. package/bundled-skills/segment-cdp/SKILL.md +817 -19
  58. package/bundled-skills/shopify-apps/SKILL.md +1475 -19
  59. package/bundled-skills/slack-bot-builder/SKILL.md +1162 -28
  60. package/bundled-skills/telegram-bot-builder/SKILL.md +152 -37
  61. package/bundled-skills/telegram-mini-app/SKILL.md +445 -44
  62. package/bundled-skills/trigger-dev/SKILL.md +916 -27
  63. package/bundled-skills/twilio-communications/SKILL.md +1310 -28
  64. package/bundled-skills/upstash-qstash/SKILL.md +898 -27
  65. package/bundled-skills/vercel-deployment/SKILL.md +637 -39
  66. package/bundled-skills/viral-generator-builder/SKILL.md +132 -37
  67. package/bundled-skills/voice-agents/SKILL.md +937 -27
  68. package/bundled-skills/voice-ai-development/SKILL.md +375 -46
  69. package/bundled-skills/workflow-automation/SKILL.md +982 -29
  70. package/bundled-skills/zapier-make-patterns/SKILL.md +772 -27
  71. package/package.json +1 -1
@@ -1,22 +1,37 @@
1
1
  ---
2
2
  name: zapier-make-patterns
3
- description: "You are a no-code automation architect who has built thousands of Zaps and Scenarios for businesses of all sizes. You've seen automations that save companies 40% of their time, and you've debugged disasters where bad data flowed through 12 connected apps."
3
+ description: No-code automation democratizes workflow building. Zapier and Make
4
+ (formerly Integromat) let non-developers automate business processes without
5
+ writing code. But no-code doesn't mean no-complexity - these platforms have
6
+ their own patterns, pitfalls, and breaking points.
4
7
  risk: unknown
5
- source: "vibeship-spawner-skills (Apache 2.0)"
6
- date_added: "2026-02-27"
8
+ source: vibeship-spawner-skills (Apache 2.0)
9
+ date_added: 2026-02-27
7
10
  ---
8
11
 
9
12
  # Zapier & Make Patterns
10
13
 
11
- You are a no-code automation architect who has built thousands of Zaps and
12
- Scenarios for businesses of all sizes. You've seen automations that save
13
- companies 40% of their time, and you've debugged disasters where bad data
14
- flowed through 12 connected apps.
14
+ No-code automation democratizes workflow building. Zapier and Make (formerly
15
+ Integromat) let non-developers automate business processes without writing
16
+ code. But no-code doesn't mean no-complexity - these platforms have their
17
+ own patterns, pitfalls, and breaking points.
15
18
 
16
- Your core insight: No-code is powerful but not unlimited. You know exactly
17
- when a workflow belongs in Zapier (simple, fast, maximum integrations),
18
- when it belongs in Make (complex branching, data transformation, budget),
19
- and when it needs to g
19
+ This skill covers when to use which platform, how to build reliable
20
+ automations, and when to graduate to code-based solutions. Key insight:
21
+ Zapier optimizes for simplicity and integrations (7000+ apps), Make
22
+ optimizes for power and cost-efficiency (visual branching, operations-based
23
+ pricing).
24
+
25
+ Critical distinction: No-code works until it doesn't. Know the limits.
26
+
27
+ ## Principles
28
+
29
+ - Start simple, add complexity only when needed
30
+ - Test with real data before going live
31
+ - Document every automation with clear naming
32
+ - Monitor errors - 95% error rate auto-disables Zaps
33
+ - Know when to graduate to code-based solutions
34
+ - Operations/tasks cost money - design efficiently
20
35
 
21
36
  ## Capabilities
22
37
 
@@ -29,44 +44,774 @@ and when it needs to g
29
44
  - workflow-builders
30
45
  - business-process-automation
31
46
 
47
+ ## Scope
48
+
49
+ - code-based-workflows → workflow-automation
50
+ - browser-automation → browser-automation
51
+ - custom-integrations → backend
52
+ - api-development → api-designer
53
+
54
+ ## Tooling
55
+
56
+ ### Platforms
57
+
58
+ - Zapier - When: Simple automations, maximum app coverage, beginners Note: 7000+ integrations, linear workflows, task-based pricing
59
+ - Make - When: Complex workflows, visual branching, budget-conscious Note: Visual scenarios, operations pricing, powerful data handling
60
+ - n8n - When: Self-hosted, code-friendly, unlimited operations Note: Open-source, can add custom code, technical users
61
+
62
+ ### Ai_features
63
+
64
+ - Zapier Agents - When: AI-powered autonomous automation Note: Natural language instructions, 7000+ app access
65
+ - Zapier Copilot - When: Building Zaps with AI assistance Note: Describes workflow, AI builds it
66
+ - Zapier MCP - When: LLM tools accessing Zapier actions Note: 30,000+ actions available to AI models
67
+
32
68
  ## Patterns
33
69
 
34
70
  ### Basic Trigger-Action Pattern
35
71
 
36
72
  Single trigger leads to one or more actions
37
73
 
74
+ **When to use**: Simple notifications, data sync, basic workflows
75
+
76
+ # BASIC TRIGGER-ACTION:
77
+
78
+ """
79
+ [Trigger] → [Action]
80
+ e.g., New Email → Create Task
81
+ """
82
+
83
+ ## Zapier Example
84
+ """
85
+ Zap Name: "Gmail New Email → Todoist Task"
86
+
87
+ TRIGGER: Gmail - New Email
88
+ - From: specific-sender@example.com
89
+ - Has attachment: yes
90
+
91
+ ACTION: Todoist - Create Task
92
+ - Project: Inbox
93
+ - Content: {{Email Subject}}
94
+ - Description: From: {{Email From}}
95
+ - Due date: Tomorrow
96
+ """
97
+
98
+ ## Make Example
99
+ """
100
+ Scenario: "Gmail to Todoist"
101
+
102
+ [Gmail: Watch Emails] → [Todoist: Create a Task]
103
+
104
+ Gmail Module:
105
+ - Folder: INBOX
106
+ - From: specific-sender@example.com
107
+
108
+ Todoist Module:
109
+ - Project ID: (select from dropdown)
110
+ - Content: {{1.subject}}
111
+ - Due String: tomorrow
112
+ """
113
+
114
+ ## Best Practices:
115
+ - Use descriptive Zap/Scenario names
116
+ - Test with real sample data
117
+ - Use filters to prevent unwanted runs
118
+
38
119
  ### Multi-Step Sequential Pattern
39
120
 
40
121
  Chain of actions executed in order
41
122
 
123
+ **When to use**: Multi-app workflows, data enrichment pipelines
124
+
125
+ # MULTI-STEP SEQUENTIAL:
126
+
127
+ """
128
+ [Trigger] → [Action 1] → [Action 2] → [Action 3]
129
+ Each step's output available to subsequent steps
130
+ """
131
+
132
+ ## Zapier Multi-Step Zap
133
+ """
134
+ Zap: "New Lead → CRM → Slack → Email"
135
+
136
+ 1. TRIGGER: Typeform - New Entry
137
+ - Form: Lead Capture Form
138
+
139
+ 2. ACTION: HubSpot - Create Contact
140
+ - Email: {{Typeform Email}}
141
+ - First Name: {{Typeform First Name}}
142
+ - Lead Source: "Website Form"
143
+
144
+ 3. ACTION: Slack - Send Channel Message
145
+ - Channel: #sales-leads
146
+ - Message: "New lead: {{Typeform Name}} from {{Typeform Company}}"
147
+
148
+ 4. ACTION: Gmail - Send Email
149
+ - To: {{Typeform Email}}
150
+ - Subject: "Thanks for reaching out!"
151
+ - Body: (template with personalization)
152
+ """
153
+
154
+ ## Make Scenario
155
+ """
156
+ [Typeform] → [HubSpot] → [Slack] → [Gmail]
157
+
158
+ - Each module passes data to the next
159
+ - Use {{N.field}} to reference module N's output
160
+ - Add error handlers between critical steps
161
+ """
162
+
42
163
  ### Conditional Branching Pattern
43
164
 
44
165
  Different actions based on conditions
45
166
 
46
- ## Anti-Patterns
167
+ **When to use**: Different handling for different data types
168
+
169
+ # CONDITIONAL BRANCHING:
170
+
171
+ """
172
+ ┌→ [Action A] (condition met)
173
+ [Trigger] ───┤
174
+ └→ [Action B] (condition not met)
175
+ """
176
+
177
+ ## Zapier Paths (Pro+ required)
178
+ """
179
+ Zap: "Route Support Tickets"
180
+
181
+ 1. TRIGGER: Zendesk - New Ticket
182
+
183
+ 2. PATH A: If priority = "urgent"
184
+ - Slack: Post to #urgent-support
185
+ - PagerDuty: Create incident
186
+
187
+ 3. PATH B: If priority = "normal"
188
+ - Slack: Post to #support
189
+ - Asana: Create task
190
+
191
+ 4. PATH C: Otherwise (catch-all)
192
+ - Slack: Post to #support-overflow
193
+ """
194
+
195
+ ## Make Router
196
+ """
197
+ [Zendesk: Watch Tickets]
198
+
199
+ [Router]
200
+ ├── Route 1: priority = urgent
201
+ │ └→ [Slack] → [PagerDuty]
202
+
203
+ ├── Route 2: priority = normal
204
+ │ └→ [Slack] → [Asana]
205
+
206
+ └── Fallback route
207
+ └→ [Slack: overflow]
208
+
209
+ # Make's visual router makes complex branching clear
210
+ """
211
+
212
+ ## Best Practices:
213
+ - Always have a fallback/else path
214
+ - Test each path independently
215
+ - Document which conditions trigger which path
216
+
217
+ ### Data Transformation Pattern
218
+
219
+ Clean, format, and transform data between apps
220
+
221
+ **When to use**: Apps expect different data formats
222
+
223
+ # DATA TRANSFORMATION:
224
+
225
+ ## Zapier Formatter
226
+ """
227
+ Common transformations:
228
+
229
+ 1. Text manipulation:
230
+ - Split text: "John Doe" → First: "John", Last: "Doe"
231
+ - Capitalize: "john" → "John"
232
+ - Replace: Remove special characters
233
+
234
+ 2. Date formatting:
235
+ - Convert: "2024-01-15" → "January 15, 2024"
236
+ - Adjust: Add 7 days to date
237
+
238
+ 3. Numbers:
239
+ - Format currency: 1000 → "$1,000.00"
240
+ - Spreadsheet formula: =SUM(A1:A10)
241
+
242
+ 4. Lookup tables:
243
+ - Map status codes: "1" → "Active", "2" → "Pending"
244
+ """
245
+
246
+ ## Make Data Functions
247
+ """
248
+ Make has powerful built-in functions:
249
+
250
+ Text:
251
+ {{lower(1.email)}} # Lowercase
252
+ {{substring(1.name; 0; 10)}} # First 10 chars
253
+ {{replace(1.text; "-"; "")}} # Remove dashes
254
+
255
+ Arrays:
256
+ {{first(1.items)}} # First item
257
+ {{length(1.items)}} # Count items
258
+ {{map(1.items; "id")}} # Extract field
259
+
260
+ Dates:
261
+ {{formatDate(1.date; "YYYY-MM-DD")}}
262
+ {{addDays(now; 7)}}
263
+
264
+ Math:
265
+ {{round(1.price * 0.8; 2)}} # 20% discount, 2 decimals
266
+ """
267
+
268
+ ## Best Practices:
269
+ - Transform early in the workflow
270
+ - Use filters to skip invalid data
271
+ - Log transformations for debugging
272
+
273
+ ### Error Handling Pattern
274
+
275
+ Graceful handling of failures
276
+
277
+ **When to use**: Any production automation
278
+
279
+ # ERROR HANDLING:
280
+
281
+ ## Zapier Error Handling
282
+ """
283
+ 1. Built-in retry (automatic):
284
+ - Zapier retries failed actions automatically
285
+ - Exponential backoff for temporary failures
286
+
287
+ 2. Error handling step:
288
+ Zap:
289
+ 1. [Trigger]
290
+ 2. [Action that might fail]
291
+ 3. [Error Handler]
292
+ - If error → [Slack: Alert team]
293
+ - If error → [Email: Send report]
294
+
295
+ 3. Path-based handling:
296
+ [Action] → Path A: Success → [Continue]
297
+ → Path B: Error → [Alert + Log]
298
+ """
299
+
300
+ ## Make Error Handlers
301
+ """
302
+ Make has visual error handling:
303
+
304
+ [Module] ──┬── Success → [Next Module]
305
+
306
+ └── Error → [Error Handler]
307
+
308
+ Error handler types:
309
+ 1. Break: Stop scenario, send notification
310
+ 2. Rollback: Undo completed operations
311
+ 3. Commit: Save partial results, continue
312
+ 4. Ignore: Skip error, continue with next item
313
+
314
+ Example:
315
+ [API Call] → Error Handler (Ignore)
316
+ → [Log to Airtable: "Failed: {{error.message}}"]
317
+ → Continue scenario
318
+ """
319
+
320
+ ## Best Practices:
321
+ - Always add error handlers for external APIs
322
+ - Log errors to a spreadsheet/database
323
+ - Set up Slack/email alerts for critical failures
324
+ - Test failure scenarios, not just success
325
+
326
+ ### Batch Processing Pattern
327
+
328
+ Process multiple items efficiently
329
+
330
+ **When to use**: Importing data, bulk operations
331
+
332
+ # BATCH PROCESSING:
333
+
334
+ ## Zapier Looping
335
+ """
336
+ Zap: "Process Order Items"
337
+
338
+ 1. TRIGGER: Shopify - New Order
339
+ - Returns: order with line_items array
340
+
341
+ 2. LOOPING: For each item in line_items
342
+ - Create inventory adjustment
343
+ - Update product count
344
+ - Log to spreadsheet
345
+
346
+ Note: Each loop iteration counts as tasks!
347
+ 10 items = 10 tasks consumed
348
+ """
349
+
350
+ ## Make Iterator
351
+ """
352
+ [Webhook: Receive Order]
353
+
354
+ [Iterator: line_items]
355
+ ↓ (processes each item)
356
+ [Inventory: Adjust Stock]
357
+
358
+ [Aggregator: Collect Results]
359
+
360
+ [Slack: Summary Message]
361
+
362
+ Iterator creates one bundle per item.
363
+ Aggregator combines results back together.
364
+ Use Array Aggregator for collecting processed items.
365
+ """
366
+
367
+ ## Best Practices:
368
+ - Use aggregators to combine results
369
+ - Consider batch limits (some APIs limit to 100)
370
+ - Watch operation/task counts for cost
371
+ - Add delays for rate-limited APIs
372
+
373
+ ### Scheduled Automation Pattern
374
+
375
+ Time-based triggers instead of events
376
+
377
+ **When to use**: Daily reports, periodic syncs, batch jobs
378
+
379
+ # SCHEDULED AUTOMATION:
380
+
381
+ ## Zapier Schedule Trigger
382
+ """
383
+ Zap: "Daily Sales Report"
384
+
385
+ TRIGGER: Schedule by Zapier
386
+ - Every: Day
387
+ - Time: 8:00 AM
388
+ - Timezone: America/New_York
389
+
390
+ ACTIONS:
391
+ 1. Google Sheets: Get rows (yesterday's sales)
392
+ 2. Formatter: Calculate totals
393
+ 3. Gmail: Send report to team
394
+ """
395
+
396
+ ## Make Scheduled Scenarios
397
+ """
398
+ Scenario Schedule Options:
399
+ - Run once (manual)
400
+ - At regular intervals (every X minutes)
401
+ - Advanced: Cron expression (0 8 * * *)
402
+
403
+ [Scheduled Trigger: Every day at 8 AM]
404
+
405
+ [Google Sheets: Search Rows]
406
+
407
+ [Iterator: Process each row]
408
+
409
+ [Aggregator: Sum totals]
410
+
411
+ [Gmail: Send Report]
412
+ """
413
+
414
+ ## Best Practices:
415
+ - Consider timezone differences
416
+ - Add buffer time for long-running jobs
417
+ - Log execution times for monitoring
418
+ - Don't schedule at exactly midnight (busy period)
419
+
420
+ ## Sharp Edges
421
+
422
+ ### Using Text Instead of IDs in Dropdown Fields
423
+
424
+ Severity: CRITICAL
425
+
426
+ Situation: Configuring actions with dropdown selections
427
+
428
+ Symptoms:
429
+ "Bad Request" errors. "Invalid value" messages. Action fails
430
+ despite correct-looking input. Works when you select from dropdown,
431
+ fails with dynamic values.
432
+
433
+ Why this breaks:
434
+ Dropdown menus display human-readable text but send IDs to APIs.
435
+ When you type "Marketing Team" instead of selecting it, Zapier
436
+ tries to send that text as the ID, which the API doesn't recognize.
437
+
438
+ Recommended fix:
439
+
440
+ # ALWAYS use dropdowns to select, don't type
441
+
442
+ # If you need dynamic values:
47
443
 
48
- ### Text in Dropdown Fields
444
+ ## Zapier approach:
445
+ 1. Add a "Find" or "Search" action first
446
+ - HubSpot: Find Contact → returns contact_id
447
+ - Slack: Find User by Email → returns user_id
49
448
 
50
- ### No Error Handling
449
+ 2. Use the returned ID in subsequent actions
450
+ - Dropdown: Use Custom Value
451
+ - Select the ID from the search step
51
452
 
52
- ### Hardcoded Values
453
+ ## Make approach:
454
+ 1. Add a Search module first
455
+ - Search Contacts: filter by email
456
+ - Returns: contact_id
53
457
 
54
- ## ⚠️ Sharp Edges
458
+ 2. Map the ID to subsequent modules
459
+ - Contact ID: {{2.id}} (from search module)
55
460
 
56
- | Issue | Severity | Solution |
57
- |-------|----------|----------|
58
- | Issue | critical | # ALWAYS use dropdowns to select, don't type |
59
- | Issue | critical | # Prevention: |
60
- | Issue | high | # Understand the math: |
61
- | Issue | high | # When a Zap breaks after app update: |
62
- | Issue | high | # Immediate fix: |
63
- | Issue | medium | # Handle duplicates: |
64
- | Issue | medium | # Understand operation counting: |
65
- | Issue | medium | # Best practices: |
461
+ # Common ID fields that trip people up:
462
+ - User/Member IDs in Slack, Teams
463
+ - Contact/Company IDs in CRMs
464
+ - Project/Folder IDs in project tools
465
+ - Category/Tag IDs in content systems
466
+
467
+ ### Zap Auto-Disabled at 95% Error Rate
468
+
469
+ Severity: CRITICAL
470
+
471
+ Situation: Running a Zap with frequent errors
472
+
473
+ Symptoms:
474
+ Zap suddenly stops running. Email notification about auto-disable.
475
+ "This Zap was automatically turned off" message. Data stops syncing.
476
+
477
+ Why this breaks:
478
+ Zapier automatically disables Zaps that have 95% or higher error
479
+ rate over 7 days. This prevents runaway automation failures from
480
+ consuming your task quota and creating data problems.
481
+
482
+ Recommended fix:
483
+
484
+ # Prevention:
485
+
486
+ 1. Add error handling steps:
487
+ - Use Path: If error → [Log + Alert]
488
+ - Add fallback actions for failures
489
+
490
+ 2. Use filters to prevent bad data:
491
+ - Only continue if email exists
492
+ - Only continue if amount > 0
493
+ - Filter out test/invalid entries
494
+
495
+ 3. Monitor task history regularly:
496
+ - Check for recurring errors
497
+ - Fix issues before 95% threshold
498
+
499
+ # Recovery:
500
+
501
+ 1. Check Task History for error patterns
502
+ 2. Fix the root cause (auth, bad data, API changes)
503
+ 3. Test with sample data
504
+ 4. Re-enable the Zap manually
505
+ 5. Monitor closely for next 24 hours
506
+
507
+ # Common causes:
508
+ - Expired authentication tokens
509
+ - API rate limits
510
+ - Changed field names in connected apps
511
+ - Invalid data formats
512
+
513
+ ### Loops Consuming Unexpected Task Counts
514
+
515
+ Severity: HIGH
516
+
517
+ Situation: Processing arrays or multiple items
518
+
519
+ Symptoms:
520
+ Task quota depleted unexpectedly. One Zap run shows as 100+ tasks.
521
+ Monthly limit reached in days. "You've used X of Y tasks" surprise.
522
+
523
+ Why this breaks:
524
+ In Zapier, each iteration of a loop counts as separate tasks.
525
+ If a webhook delivers an order with 50 line items and you loop
526
+ through each, that's 50+ tasks for one order.
527
+
528
+ Recommended fix:
529
+
530
+ # Understand the math:
531
+
532
+ Order with 10 items, 5 actions per item:
533
+ = 1 trigger + (10 items × 5 actions) = 51 tasks
534
+
535
+ # Strategies to reduce task usage:
536
+
537
+ 1. Batch operations when possible:
538
+ - Use "Create Many Rows" instead of loop + create
539
+ - Use bulk API endpoints
540
+
541
+ 2. Aggregate before sending:
542
+ - Collect all items
543
+ - Send one summary message, not one per item
544
+
545
+ 3. Filter before looping:
546
+ - Only process items that need action
547
+ - Skip unchanged/duplicate items
548
+
549
+ 4. Consider Make for high-volume:
550
+ - Make uses operations, not tasks per action
551
+ - More cost-effective for loops
552
+
553
+ # Make approach:
554
+ [Iterator] → [Actions] → [Aggregator]
555
+ - Pay for operations (module executions)
556
+ - Not per-action like Zapier
557
+
558
+ ### App Updates Breaking Existing Zaps
559
+
560
+ Severity: HIGH
561
+
562
+ Situation: App you're connected to releases updates
563
+
564
+ Symptoms:
565
+ Working Zap suddenly fails. "Field not found" errors. Different
566
+ data format in outputs. Actions that worked yesterday fail today.
567
+
568
+ Why this breaks:
569
+ When connected apps update their APIs, field names can change,
570
+ new required fields appear, or data formats shift. Zapier/Make
571
+ integrations may not immediately update to match.
572
+
573
+ Recommended fix:
574
+
575
+ # When a Zap breaks after app update:
576
+
577
+ 1. Check the Task History for specific errors
578
+ 2. Open the Zap editor to see field mapping issues
579
+ 3. Re-select the trigger/action to refresh schema
580
+ 4. Re-map any fields that show as "unknown"
581
+ 5. Test with new sample data
582
+
583
+ # Prevention:
584
+
585
+ 1. Subscribe to changelog for critical apps
586
+ 2. Keep connection authorizations fresh
587
+ 3. Test Zaps after major app updates
588
+ 4. Document your field mappings
589
+ 5. Use test/duplicate Zaps for experiments
590
+
591
+ # If integration is outdated:
592
+ - Check Zapier/Make status pages
593
+ - Report issue to support
594
+ - Consider webhook alternative temporarily
595
+
596
+ # Common offenders:
597
+ - CRM field restructures
598
+ - API version upgrades
599
+ - OAuth scope changes
600
+ - New required permissions
601
+
602
+ ### Authentication Tokens Expiring
603
+
604
+ Severity: HIGH
605
+
606
+ Situation: Using OAuth connections to apps
607
+
608
+ Symptoms:
609
+ "Authentication failed" errors. "Please reconnect" messages.
610
+ Zaps fail after weeks of working. Multiple apps fail simultaneously.
611
+
612
+ Why this breaks:
613
+ OAuth tokens expire. Some apps require re-authentication every
614
+ 60-90 days. If the user who connected the app leaves the company,
615
+ their connection may stop working.
616
+
617
+ Recommended fix:
618
+
619
+ # Immediate fix:
620
+ 1. Go to Settings → Apps
621
+ 2. Find the app with issues
622
+ 3. Reconnect (re-authorize)
623
+ 4. Test affected Zaps
624
+
625
+ # Prevention:
626
+
627
+ 1. Use service accounts for connections
628
+ - Don't connect with personal accounts
629
+ - Use shared team email/account
630
+
631
+ 2. Monitor connection health
632
+ - Check Apps page regularly
633
+ - Set calendar reminders for known expiration
634
+
635
+ 3. Document who connected what
636
+ - Track in spreadsheet
637
+ - Handoff process when people leave
638
+
639
+ 4. Prefer connections that don't expire
640
+ - API keys over OAuth when available
641
+ - Long-lived tokens
642
+
643
+ # Zapier Enterprise:
644
+ - Admin controls for managing connections
645
+ - SSO integration
646
+ - Centralized connection management
647
+
648
+ ### Webhooks Missing or Duplicating Events
649
+
650
+ Severity: MEDIUM
651
+
652
+ Situation: Using webhooks as triggers
653
+
654
+ Symptoms:
655
+ Some events never trigger the Zap. Same event triggers multiple
656
+ times. Inconsistent automation behavior. "Works sometimes."
657
+
658
+ Why this breaks:
659
+ Webhooks are fire-and-forget. If Zapier's receiving endpoint is
660
+ slow or unavailable, the webhook may fail. Some systems retry
661
+ webhooks, causing duplicates. Network issues lose events.
662
+
663
+ Recommended fix:
664
+
665
+ # Handle duplicates:
666
+
667
+ 1. Add deduplication logic:
668
+ - Filter: Only continue if ID not in Airtable
669
+ - First action: Check if already processed
670
+
671
+ 2. Use idempotency:
672
+ - Store processed IDs
673
+ - Skip if ID exists
674
+
675
+ ## Zapier example:
676
+ [Webhook Trigger]
677
+
678
+ [Airtable: Find Records] - search by event_id
679
+
680
+ [Filter: Only continue if not found]
681
+
682
+ [Process Event]
683
+
684
+ [Airtable: Create Record] - store event_id
685
+
686
+ # Handle missed events:
687
+
688
+ 1. Use polling triggers for critical data
689
+ - Less real-time but more reliable
690
+ - Catches events during downtime
691
+
692
+ 2. Implement reconciliation:
693
+ - Scheduled Zap to check for gaps
694
+ - Compare source data to processed data
695
+
696
+ 3. Check source system retry settings:
697
+ - Some systems retry on failure
698
+ - Configure retry count/timing
699
+
700
+ ### Make Operations Consumed by Error Retries
701
+
702
+ Severity: MEDIUM
703
+
704
+ Situation: Scenarios with failing modules
705
+
706
+ Symptoms:
707
+ Operations quota depleted quickly. Scenario runs "succeeded" but
708
+ used many operations. Same scenario running more than expected.
709
+
710
+ Why this breaks:
711
+ Make counts operations per module execution, including failed
712
+ attempts and retries. Error handler modules consume operations.
713
+ Scenarios that fail and retry can use 3-5x expected operations.
714
+
715
+ Recommended fix:
716
+
717
+ # Understand operation counting:
718
+
719
+ Successful run: Each module = 1 operation
720
+ Failed + retry (3x): 3 operations for that module
721
+ Error handler: Additional operation per handler module
722
+
723
+ # Reduce operation waste:
724
+
725
+ 1. Add error handlers that break early:
726
+ [Module] → Error → [Break] (1 additional op)
727
+ vs
728
+ [Module] → Error → [Log] → [Alert] → [Update] (3+ ops)
729
+
730
+ 2. Use ignore instead of retry when appropriate:
731
+ - If failure is expected (record exists)
732
+ - If retrying won't help (bad data)
733
+
734
+ 3. Pre-validate before expensive operations:
735
+ [Check Data] → Filter → [API Call]
736
+ - Fail fast before consuming operations
737
+
738
+ 4. Optimize scenario scheduling:
739
+ - Don't run every minute if hourly is enough
740
+ - Use webhooks for real-time when possible
741
+
742
+ # Monitor usage:
743
+ - Check Operations dashboard
744
+ - Set up usage alerts
745
+ - Review high-consumption scenarios
746
+
747
+ ### Timezone Mismatches in Scheduled Triggers
748
+
749
+ Severity: MEDIUM
750
+
751
+ Situation: Setting up scheduled automations
752
+
753
+ Symptoms:
754
+ Zap runs at wrong time. "9 AM" trigger fires at 2 PM. Different
755
+ behavior on different days. DST causes hour shifts.
756
+
757
+ Why this breaks:
758
+ Zapier shows times in your local timezone but may store in UTC.
759
+ If you change timezones or DST occurs, scheduled times shift.
760
+ Team members in different zones see different times.
761
+
762
+ Recommended fix:
763
+
764
+ # Best practices:
765
+
766
+ 1. Explicitly set timezone in schedule:
767
+ - Don't rely on browser detection
768
+ - Use business timezone, not personal
769
+
770
+ 2. Document in Zap name:
771
+ - "Daily Report 9AM EST"
772
+ - Include timezone in description
773
+
774
+ 3. Test around DST transitions:
775
+ - Schedule changes at DST boundaries
776
+ - Verify times before/after change
777
+
778
+ 4. For global teams:
779
+ - Use UTC as standard
780
+ - Convert to local in descriptions
781
+
782
+ 5. Consider buffer times:
783
+ - Don't schedule at exactly midnight
784
+ - Avoid on-the-hour (busy periods)
785
+
786
+ ## Make timezone handling:
787
+ - Scenarios use account timezone setting
788
+ - formatDate() function respects timezone
789
+ - Use parseDate() with explicit timezone
790
+
791
+ ## Collaboration
792
+
793
+ ### Delegation Triggers
794
+
795
+ - automation requires custom code -> workflow-automation (Code-based solutions like Inngest, Temporal)
796
+ - need browser automation in workflow -> browser-automation (Playwright/Puppeteer integration)
797
+ - building custom API integration -> api-designer (API design and implementation)
798
+ - automation needs AI capabilities -> agent-tool-builder (AI agent tools and Zapier MCP)
799
+ - high-volume data processing -> backend (Custom backend processing)
800
+ - need self-hosted automation -> devops (n8n or custom workflow deployment)
66
801
 
67
802
  ## Related Skills
68
803
 
69
804
  Works well with: `workflow-automation`, `agent-tool-builder`, `backend`, `api-designer`
70
805
 
71
806
  ## When to Use
72
- This skill is applicable to execute the workflow or actions described in the overview.
807
+
808
+ - User mentions or implies: zapier
809
+ - User mentions or implies: make
810
+ - User mentions or implies: integromat
811
+ - User mentions or implies: zap
812
+ - User mentions or implies: scenario
813
+ - User mentions or implies: no-code automation
814
+ - User mentions or implies: trigger action
815
+ - User mentions or implies: workflow automation
816
+ - User mentions or implies: connect apps
817
+ - User mentions or implies: automate