Get the FREE Ultimate OpenClaw Setup Guide →

nathan-standards

npx machina-cli add skill aiskillstore/marketplace/nathan-standards --openclaw
Files (1)
SKILL.md
4.8 KB

Nathan Development Standards

Standards and patterns for developing within the Nathan project - an n8n-Jira agent automation system.

When to Use

Invoke this skill when:

  • Creating or modifying n8n workflow JSON files
  • Writing Python code for the Nathan helpers or templating modules
  • Designing webhook command contracts
  • Building workflow registry configurations
  • Implementing spec-driven features via agent-os

Project Architecture

Nathan follows a layered architecture:

External Service (Jira) <-- n8n Workflows <-- Python Agent Service
                             (credentials)      (webhook calls)

Core Principle: n8n owns all external credentials. Python services call n8n webhooks with shared secret authentication.

n8n Workflow Standards

For detailed workflow patterns, load references/n8n-workflow-patterns.md.

Standard Workflow Structure

Every webhook workflow must follow this pattern:

Webhook --> Validate Secret --> Operation --> Respond to Webhook
               |                   |              |
               v                   v              v
           Unauthorized       Error Response   Success Response
           Response (401)     (500)            (200)

Required Node Pattern

{
  "id": "validate-secret",
  "name": "Validate Secret",
  "type": "n8n-nodes-base.if",
  "typeVersion": 2,
  "parameters": {
    "conditions": {
      "conditions": [{
        "leftValue": "={{ $json.headers['x-n8n-secret'] }}",
        "rightValue": "={{ $env.N8N_WEBHOOK_SECRET }}",
        "operator": { "type": "string", "operation": "equals" }
      }]
    }
  }
}

Response Format

All responses must follow this shape:

{ "success": true, "data": {...}, "status_code": 200, "error": null }
{ "success": false, "data": {}, "status_code": 500, "error": "message" }

JQL Expression Escaping

In n8n expressions within JSON, escape properly:

WrongCorrect
.map(x => "${x}").map(x => '"' + x + '"')
.join('\n').join('\\n')
.replaceAll('\n', ' ').replaceAll('\\n', ' ')

Python Standards

For detailed patterns, load references/python-patterns.md.

Module Structure

nathan/
  helpers/           # Shared utilities (workflow registry, etc.)
  workflows/         # n8n workflow JSON + registry.yaml per category
  templating/        # YAML-to-JSON template engine
  scripts/           # Standalone runnable scripts

Code Style

# Required imports pattern
from __future__ import annotations
from typing import Any
from pathlib import Path
import logging

logger = logging.getLogger(__name__)

# Type hints required, use T | None not Optional[T]
async def trigger_workflow(url: str, params: dict[str, Any]) -> dict[str, Any]:
    ...

Registry Pattern

# registry.yaml
version: "1.0.0"
description: "Registry description"

commands:
  command_name:
    endpoint: /webhook/endpoint-path
    method: POST
    required_params:
      - param1
    optional_params:
      - param2
    description: What this command does
    example:
      param1: "value"

Spec-Driven Development

Use agent-os commands for feature development:

  1. /shape-spec - Initialize and shape specification
  2. /write-spec - Write detailed spec document
  3. /create-tasks - Generate task list from spec
  4. /orchestrate-tasks - Delegate to subagents

Specs live in agent-os/specs/[spec-name]/ with:

  • spec.md - Feature specification
  • tasks.md - Implementation tasks with checkboxes
  • orchestration.yml - Subagent delegation config

Quick Reference

Common Commands

uv sync                              # Install dependencies
uv run pytest                        # Run tests
uv run pytest path/to/test.py -v     # Single test file
uvx ruff check .                     # Lint
uvx ruff format .                    # Format
docker compose -f docker-compose.n8n.yml up -d  # Start n8n

Environment Variables

VariablePurpose
N8N_WEBHOOK_SECRETShared secret for webhook auth
N8N_API_KEYn8n Public API key
JIRA_DOMAINJira Cloud domain
JIRA_EMAILJira account email
JIRA_API_TOKENJira API token

File Naming Conventions

TypeConventionExample
Workflow JSONkebab-case.jsonjira-get-ticket.json
Python modulessnake_case.pyn8n_workflow_registry.py
Test filestest_*.pytest_parser.py
Registryregistry.yamlper workflow category

Source

git clone https://github.com/aiskillstore/marketplace/blob/main/skills/89jobrien/nathan-standards/SKILL.mdView on GitHub

Overview

Nathan development standards define how to build within the Nathan n8n-Jira automation project. They cover n8n workflows, Python helpers, and project conventions to keep code consistent and secure. Following these standards supports reliability, maintainability, and scalable Jira integration.

How This Skill Works

The Nathan system uses a layered architecture where Jira interacts with n8n workflows and the Python agent service via webhooks. Core principle: n8n owns all external credentials and Python services call n8n webhooks using a shared secret. Patterns include a standard webhook workflow structure, a required node pattern for secret validation, a consistent response format, and spec driven development managed through agent-os.

When to Use It

  • Creating or modifying n8n workflow JSON files
  • Writing Python code for the Nathan helpers or templating modules
  • Designing webhook command contracts
  • Building workflow registry configurations
  • Implementing spec-driven features via agent-os

Quick Start

  1. Step 1: Review the Nathan standards and the architecture where Jira, n8n workflows, and the Python agent service interact
  2. Step 2: Create or update an n8n webhook workflow using the Standard Workflow Structure and Required Node Pattern
  3. Step 3: Use agent-os to shape the spec, write tasks, and orchestrate subagents

Best Practices

  • Follow the Standard Workflow Structure for all webhook workflows
  • Implement the Required Node Pattern to validate secrets
  • Always return responses using the defined Response Format
  • Escape n8n expressions properly in JSON (JQL escaping)
  • Adhere to the Module Structure and Registry Pattern in Python code and registry files

Example Use Cases

  • Webhook workflow that validates a secret and returns a 200 on success
  • Python helper module used to render templated registry.yaml entries
  • registry.yaml entry for a sample Jira operation command
  • Spec-driven feature described via agent-os with spec.md and tasks.md
  • Jira webhook contract for a simple issue update operation

Frequently Asked Questions

Add this skill to your agents
Sponsor this space

Reach thousands of developers