nathan-standards

Nathan Development Standards

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "nathan-standards" with this command: npx skills add 89jobrien/steve/89jobrien-steve-nathan-standards

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:

Wrong Correct

.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:

  • /shape-spec

  • Initialize and shape specification

  • /write-spec

  • Write detailed spec document

  • /create-tasks

  • Generate task list from spec

  • /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

Variable Purpose

N8N_WEBHOOK_SECRET

Shared secret for webhook auth

N8N_API_KEY

n8n Public API key

JIRA_DOMAIN

Jira Cloud domain

JIRA_EMAIL

Jira account email

JIRA_API_TOKEN

Jira API token

File Naming Conventions

Type Convention Example

Workflow JSON kebab-case.json

jira-get-ticket.json

Python modules snake_case.py

n8n_workflow_registry.py

Test files test_*.py

test_parser.py

Registry registry.yaml

per workflow category

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Coding

dead-code-removal

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

ai-code-cleanup

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

python-scripting

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

developer-experience

No summary provided by upstream source.

Repository SourceNeeds Review