โ† Back to list
groeimetai

flow-designer

by groeimetai

๐Ÿค– AI-powered ServiceNow development with 400+ MCP tools. Works with Claude, GPT, Gemini, Ollama & 75+ providers. Deploy widgets, manage incidents, automate workflows - all through natural language. Open-source Build Agent alternative.

โญ 42๐Ÿด 9๐Ÿ“… Jan 23, 2026

SKILL.md


name: flow-designer description: This skill should be used when the user asks to "create flow", "Flow Designer", "workflow automation", "subflow", "action", "flow trigger", "scheduled flow", or any ServiceNow Flow Designer development. license: Apache-2.0 compatibility: Designed for Snow-Code and ServiceNow development metadata: author: groeimetai version: "1.0.0" category: servicenow tools:

  • snow_query_table
  • snow_find_artifact
  • snow_execute_script_with_output

Flow Designer Patterns for ServiceNow

Flow Designer is the modern automation engine in ServiceNow, replacing legacy Workflows for new development.

Flow Designer Components

ComponentPurposeReusable
FlowMain automation processNo
SubflowReusable flow logicYes
ActionSingle operation (Script, REST, etc.)Yes
SpokeCollection of related actionsYes

Flow Triggers

Record-Based Triggers

Trigger: Created
Table: incident
Condition: Priority = 1

Trigger: Updated
Table: incident
Condition: State changes to Resolved

Trigger: Created or Updated
Table: change_request
Condition: Risk = High

Schedule Triggers

Trigger: Daily
Time: 02:00 AM
Timezone: America/New_York

Trigger: Weekly
Day: Monday
Time: 08:00 AM

Service Catalog Triggers

Trigger: Service Catalog
Catalog Item: Request New Laptop

Flow Best Practices

1. Use Subflows for Reusability

Main Flow: Incident P1 Handler
โ”œโ”€โ”€ Trigger: Incident Created (Priority = 1)
โ”œโ”€โ”€ Action: Log Event
โ”œโ”€โ”€ Subflow: Notify On-Call Team     โ† Reusable!
โ”œโ”€โ”€ Subflow: Create Major Incident   โ† Reusable!
โ””โ”€โ”€ Action: Update Incident

2. Error Handling

Flow: Process Integration
โ”œโ”€โ”€ Try
โ”‚   โ”œโ”€โ”€ Action: Call REST API
โ”‚   โ”œโ”€โ”€ Action: Parse Response
โ”‚   โ””โ”€โ”€ Action: Update Record
โ”œโ”€โ”€ Catch (all errors)
โ”‚   โ”œโ”€โ”€ Action: Log Error Details
โ”‚   โ”œโ”€โ”€ Action: Create Error Task
โ”‚   โ””โ”€โ”€ Action: Send Alert
โ””โ”€โ”€ Always
    โ””โ”€โ”€ Action: Cleanup Temp Data

3. Flow Variables

// Input Variables (from trigger)
var incidentSysId = fd_data.trigger.current.sys_id;
var priority = fd_data.trigger.current.priority;

// Scratch Variables (within flow)
fd_data.scratch.approval_required = priority == '1';
fd_data.scratch.notification_sent = false;

// Output Variables (to calling flow/subflow)
fd_data.output.success = true;
fd_data.output.message = 'Processed successfully';

4. Conditions and Branches

If: Priority = Critical
  Then:
    - Notify VP
    - Create Major Incident
    - Page On-Call
  Else If: Priority = High
    - Notify Manager
    - Escalate in 4 hours
  Else:
    - Standard Processing

Custom Actions (Scripts)

Basic Script Action

(function execute(inputs, outputs) {
  // Inputs defined in Action Designer
  var incidentId = inputs.incident_sys_id;
  var newState = inputs.target_state;

  // Process
  var gr = new GlideRecord('incident');
  if (gr.get(incidentId)) {
    gr.setValue('state', newState);
    gr.update();

    // Set outputs
    outputs.success = true;
    outputs.incident_number = gr.getValue('number');
  } else {
    outputs.success = false;
    outputs.error_message = 'Incident not found';
  }
})(inputs, outputs);

Script Action with Error Handling

(function execute(inputs, outputs) {
  try {
    var gr = new GlideRecord(inputs.table_name);
    gr.addEncodedQuery(inputs.query);
    gr.query();

    var records = [];
    while (gr.next()) {
      records.push({
        sys_id: gr.getUniqueValue(),
        display_value: gr.getDisplayValue()
      });
    }

    outputs.records = JSON.stringify(records);
    outputs.count = records.length;
    outputs.success = true;

  } catch (e) {
    outputs.success = false;
    outputs.error_message = e.message;
    // Flow Designer will catch this and route to error handler
    throw new Error('Query failed: ' + e.message);
  }
})(inputs, outputs);

REST Action Example

Configuration

Action: Call External API
Connection: My REST Connection Alias
HTTP Method: POST
Endpoint: /api/v1/tickets

Headers:
  Content-Type: application/json
  Authorization: Bearer ${connection.credential.token}

Request Body:
{
  "title": "${inputs.short_description}",
  "priority": "${inputs.priority}",
  "reporter": "${inputs.caller_email}"
}

Parse Response: JSON

Response Handling

// In a Script step after REST call
var response = fd_data.action_outputs.rest_response;

if (response.status_code == 201) {
  outputs.external_id = response.body.id;
  outputs.success = true;
} else {
  outputs.success = false;
  outputs.error = response.body.error || 'Unknown error';
}

Subflow Patterns

Notification Subflow

Subflow: Send Notification
Inputs:
  - recipient_email (String)
  - subject (String)
  - body (String)
  - priority (String, default: "normal")

Actions:
  1. Look Up: User by email
  2. If: User found
     - Send Email notification
     - Output: success = true
  3. Else:
     - Log Warning
     - Output: success = false

Approval Subflow

Subflow: Request Approval
Inputs:
  - record_sys_id (Reference)
  - approver (Reference: sys_user)
  - approval_message (String)

Actions:
  1. Create: Approval record
  2. Wait: For approval state change
  3. If: Approved
     - Output: approved = true
  4. Else:
     - Output: approved = false
     - Output: rejection_reason = comments

Flow Designer vs Workflow

FeatureFlow DesignerWorkflow
InterfaceModern, visualLegacy
ReusabilitySubflows, ActionsLimited
TestingBuilt-in testingManual
Version ControlYesLimited
Integration HubYesNo
PerformanceBetterSlower
RecommendationUse for new developmentMaintain existing only

Debugging Flows

Flow Context Logs

// In Script Action
fd_log.info('Processing incident: ' + inputs.incident_number);
fd_log.debug('Input data: ' + JSON.stringify(inputs));
fd_log.warn('Retry attempt: ' + inputs.retry_count);
fd_log.error('Failed to process: ' + error.message);

Flow Execution History

Navigate: Flow Designer > Executions
Filter by: Flow name, Status, Date range
View: Step-by-step execution details

Common Patterns

Pattern 1: SLA Escalation Flow

Trigger: SLA breached (Task SLA)
Actions:
  1. Get: Task details
  2. Get: Assignment group manager
  3. Send: Escalation email
  4. Update: Task priority
  5. Create: Escalation task

Pattern 2: Approval Routing

Trigger: Request Item created
Actions:
  1. If: Amount < $1000
     - Auto-approve
  2. Else If: Amount < $10000
     - Request: Manager approval
  3. Else:
     - Request: VP approval
     - Wait: 3 business days
     - If timeout: Escalate to CFO

Pattern 3: Integration Sync

Trigger: Scheduled (every 15 minutes)
Actions:
  1. Call: External API (get changes)
  2. For Each: Changed record
     a. Look Up: Matching local record
     b. If exists: Update
     c. Else: Create
  3. Log: Sync summary

Performance Tips

  1. Use conditions early - Filter before expensive operations
  2. Limit loops - Set max iterations on For Each
  3. Async where possible - Don't block on slow operations
  4. Cache lookups - Store repeated queries in scratch variables
  5. Batch operations - Group similar updates together

Score

Total Score

75/100

Based on repository quality metrics

โœ“SKILL.md

SKILL.mdใƒ•ใ‚กใ‚คใƒซใŒๅซใพใ‚Œใฆใ„ใ‚‹

+20
โœ“LICENSE

ใƒฉใ‚คใ‚ปใƒณใ‚นใŒ่จญๅฎšใ•ใ‚Œใฆใ„ใ‚‹

+10
โœ“่ชฌๆ˜Žๆ–‡

100ๆ–‡ๅญ—ไปฅไธŠใฎ่ชฌๆ˜ŽใŒใ‚ใ‚‹

+10
โ—‹ไบบๆฐ—

GitHub Stars 100ไปฅไธŠ

0/15
โœ“ๆœ€่ฟ‘ใฎๆดปๅ‹•

1ใƒถๆœˆไปฅๅ†…ใซๆ›ดๆ–ฐ

+10
โ—‹ใƒ•ใ‚ฉใƒผใ‚ฏ

10ๅ›žไปฅไธŠใƒ•ใ‚ฉใƒผใ‚ฏใ•ใ‚Œใฆใ„ใ‚‹

0/5
โœ“Issue็ฎก็†

ใ‚ชใƒผใƒ—ใƒณIssueใŒ50ๆœชๆบ€

+5
โœ“่จ€่ชž

ใƒ—ใƒญใ‚ฐใƒฉใƒŸใƒณใ‚ฐ่จ€่ชžใŒ่จญๅฎšใ•ใ‚Œใฆใ„ใ‚‹

+5
โœ“ใ‚ฟใ‚ฐ

1ใคไปฅไธŠใฎใ‚ฟใ‚ฐใŒ่จญๅฎšใ•ใ‚Œใฆใ„ใ‚‹

+5

Reviews

๐Ÿ’ฌ

Reviews coming soon