github agentic workflows tools ecosystem

πŸ› οΈ GitHub Agentic Workflows Tools Ecosystem

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 "github agentic workflows tools ecosystem" with this command: npx skills add hack23/riksdagsmonitor/hack23-riksdagsmonitor-github-agentic-workflows-tools-ecosystem

πŸ› οΈ GitHub Agentic Workflows Tools Ecosystem

πŸ“‹ Overview

This skill provides a comprehensive guide to all tools available in GitHub Agentic Workflows. Understanding the tools ecosystem is critical for building effective AI agents that can interact with code, GitHub APIs, browsers, and external services.

What is the Tools Ecosystem?

The Tools Ecosystem is the collection of capabilities that AI agents can invoke to perform actions:

  • GitHub Tools: Interact with repositories, issues, PRs, workflows

  • File Operations: Read, write, edit files in repositories

  • Web Tools: Fetch web pages, make HTTP requests, search the web

  • Bash Tools: Execute shell commands, run scripts

  • Playwright Tools: Automate browsers, take screenshots, interact with web UIs

  • Memory Tools: Store and retrieve knowledge across sessions

  • Custom Tools: Develop domain-specific tools via MCP servers

Why Master the Tools Ecosystem?

Effective agents require deep knowledge of available tools:

  • βœ… Capability Awareness: Know what's possible

  • βœ… Tool Selection: Choose the right tool for each task

  • βœ… Efficient Workflows: Combine tools effectively

  • βœ… Security: Understand tool limitations and risks

  • βœ… Error Handling: Handle tool failures gracefully

  • βœ… Extensibility: Build custom tools when needed

πŸ™ GitHub Tools

Repository Operations

View Files and Directories

// github-get_file_contents await github.getFileContents({ owner: 'Hack23', repo: 'riksdagsmonitor', path: 'src/index.js', ref: 'main', });

// List directory await github.getFileContents({ owner: 'Hack23', repo: 'riksdagsmonitor', path: 'src/', });

Get Repository Tree

// github-get_repository_tree await github.getRepositoryTree({ owner: 'Hack23', repo: 'riksdagsmonitor', tree_sha: 'main', recursive: true, path_filter: 'src/', });

Issue Operations

// Create issue await github.issueWrite({ method: 'create', owner: 'Hack23', repo: 'riksdagsmonitor', title: 'Bug: Application crashes', body: 'Description here...', labels: ['bug', 'P1-high'], assignees: ['developer1'], });

// Search issues await github.searchIssues({ query: 'repo:Hack23/riksdagsmonitor is:open label:bug', sort: 'created', order: 'desc', });

Pull Request Operations

// Create PR await github.createPullRequest({ owner: 'Hack23', repo: 'riksdagsmonitor', title: 'feat: Add dark mode', body: 'Implementation details...', head: 'feature/dark-mode', base: 'main', });

// Get PR diff await github.pullRequestRead({ method: 'get_diff', owner: 'Hack23', repo: 'riksdagsmonitor', pullNumber: 456, });

// Code review await github.pullRequestReviewWrite({ method: 'create', owner: 'Hack23', repo: 'riksdagsmonitor', pullNumber: 456, body: 'LGTM!', event: 'APPROVE', });

GitHub Actions

// List workflows await github.actionsList({ method: 'list_workflows', owner: 'Hack23', repo: 'riksdagsmonitor', });

// Trigger workflow await github.actionsRunTrigger({ method: 'run_workflow', owner: 'Hack23', repo: 'riksdagsmonitor', workflow_id: 'deploy.yml', ref: 'main', inputs: { environment: 'production' }, });

// Get job logs await github.getJobLogs({ owner: 'Hack23', repo: 'riksdagsmonitor', job_id: 98765432, return_content: true, tail_lines: 500, });

πŸ“ File Operations

Read Files

// Read entire file const content = await filesystem.readTextFile({ path: '/workspace/src/index.js', });

// Read first 50 lines const header = await filesystem.readTextFile({ path: '/workspace/README.md', head: 50, });

// Read last 100 lines const logs = await filesystem.readTextFile({ path: '/workspace/app.log', tail: 100, });

// Read multiple files const files = await filesystem.readMultipleFiles({ paths: ['file1.js', 'file2.js', 'file3.js'], });

Write and Edit Files

// Create or overwrite file await filesystem.writeFile({ path: '/workspace/output.txt', content: 'File content...', });

// Edit file (line-based) await filesystem.editFile({ path: '/workspace/src/index.js', edits: [ { oldText: 'const oldVar = 123;', newText: 'const newVar = 456;', }, ], });

Directory Operations

// List directory const entries = await filesystem.listDirectory({ path: '/workspace/src', });

// List with sizes const entriesWithSizes = await filesystem.listDirectoryWithSizes({ path: '/workspace/dist', sortBy: 'size', });

// Get directory tree const tree = await filesystem.directoryTree({ path: '/workspace', excludePatterns: ['node_modules/', '.git/'], });

// Create directory await filesystem.createDirectory({ path: '/workspace/new-dir', });

// Search files const jsFiles = await filesystem.searchFiles({ path: '/workspace', pattern: '**/*.js', });

🌐 Web Tools

AI-Powered Web Search

// Web search with AI-generated answer const result = await web.search({ query: 'What are the latest features in React 19?', });

// Returns: // { // answer: 'AI-generated answer with citations...', // sources: [...] // }

HTTP Requests (via bash)

GET request

curl -s https://api.github.com/repos/Hack23/riksdagsmonitor | jq .

POST request

curl -s -X POST https://api.example.com/endpoint
-H "Content-Type: application/json"
-d '{"key":"value"}'

With authentication

curl -s -H "Authorization: Bearer $TOKEN"
https://api.example.com/data

πŸ’» Bash Tools

Execute Commands

// Synchronous const result = await bash({ command: 'npm test', mode: 'sync', initial_wait: 60, });

// Async await bash({ command: 'npm run build', mode: 'async', shellId: 'build-session', });

// Read output await read_bash({ shellId: 'build-session', delay: 30, });

// Detached (persistent) await bash({ command: 'npm run dev', mode: 'async', detach: true, });

Common Patterns

Code analysis

eslint src/ --format json > report.json npm audit --json > audit.json

Git operations

git --no-pager status git --no-pager diff git add . && git commit -m "feat: New feature"

Build and test

npm ci npm run lint npm test npm run build

🌐 Playwright Tools

Browser Navigation

// Navigate await playwright.browserNavigate({ url: 'https://riksdagsmonitor.pages.dev', });

// Capture accessibility snapshot const snapshot = await playwright.browserSnapshot();

Page Interaction

// Click element await playwright.browserClick({ ref: '[2]', element: 'Button', });

// Type text await playwright.browserType({ ref: '[5]', element: 'Search input', text: 'query', submit: true, });

// Fill form await playwright.browserFillForm({ fields: [ { ref: '[10]', name: 'username', type: 'textbox', value: 'user' }, { ref: '[11]', name: 'password', type: 'textbox', value: 'pass' }, ], });

Screenshots

// Full page screenshot await playwright.browserTakeScreenshot({ filename: 'page.png', fullPage: true, });

// Element screenshot await playwright.browserTakeScreenshot({ ref: '[4]', element: 'Article', filename: 'article.png', });

🧠 Memory Tools

Knowledge Graph

// Create entities await memory.createEntities({ entities: [ { name: 'Riksdagsmonitor', entityType: 'project', observations: ['Static website', 'GitHub Pages'], }, ], });

// Create relationships await memory.createRelations({ relations: [ { from: 'Riksdagsmonitor', to: 'GitHub Pages', relationType: 'uses', }, ], });

// Search knowledge const results = await memory.searchNodes({ query: 'Swedish Parliament', });

// Read graph const graph = await memory.readGraph();

πŸ”§ Custom Tool Development

Create MCP Server

// custom-mcp-server.js import { Server } from '@modelcontextprotocol/sdk/server/index.js';

class CustomMCPServer { constructor() { this.server = new Server({ name: 'custom-tools', version: '1.0.0', }, { capabilities: { tools: {} }, });

this.setupTools();

}

setupTools() { this.server.setRequestHandler('tools/list', async () => ({ tools: [ { name: 'analyze_code', description: 'Analyze code quality', inputSchema: { type: 'object', properties: { path: { type: 'string' }, }, required: ['path'], }, }, ], }));

this.server.setRequestHandler('tools/call', async (request) => {
  const { name, arguments: args } = request.params;
  
  if (name === 'analyze_code') {
    return this.analyzeCode(args);
  }
  
  throw new Error(`Unknown tool: ${name}`);
});

}

async analyzeCode(args) { // Implementation return { content: [ { type: 'text', text: 'Analysis results...' }, ], }; }

async start() { const transport = new StdioServerTransport(); await this.server.connect(transport); } }

const server = new CustomMCPServer(); server.start();

Register in Configuration

{ "mcpServers": { "custom-tools": { "type": "local", "command": "node", "args": ["custom-mcp-server.js"], "tools": ["*"] } } }

πŸ”’ Security Considerations

Input Validation

// Validate tool inputs function validateInput(tool, args) { const Ajv = require('ajv'); const ajv = new Ajv();

const schema = getToolSchema(tool); const validate = ajv.compile(schema);

if (!validate(args)) { throw new Error('Invalid input'); } }

// Sanitize paths function sanitizePath(path) { if (path.includes('..')) { throw new Error('Path traversal not allowed'); } return path; }

Rate Limiting

class RateLimiter { constructor(maxRequests, windowMs) { this.maxRequests = maxRequests; this.windowMs = windowMs; this.requests = new Map(); }

checkLimit(toolName) { const now = Date.now(); const requests = this.requests.get(toolName) || [];

const validRequests = requests.filter(
  time => now - time < this.windowMs
);

if (validRequests.length >= this.maxRequests) {
  throw new Error('Rate limit exceeded');
}

validRequests.push(now);
this.requests.set(toolName, validRequests);

} }

Audit Logging

class ToolAuditLogger { log(tool, args, result, error = null) { const entry = { timestamp: new Date().toISOString(), tool, args: this.sanitizeArgs(args), result: error ? null : result, error: error ? error.message : null, };

console.log(JSON.stringify(entry));

}

sanitizeArgs(args) { const sanitized = { ...args };

for (const key in sanitized) {
  if (key.toLowerCase().includes('token')) {
    sanitized[key] = '[REDACTED]';
  }
}

return sanitized;

} }

πŸ”— Integration Patterns

Sequential Chain

async function sequentialChain(steps) { const results = [];

for (const step of steps) { const result = await invokeTool(step.tool, step.args); results.push(result); }

return results; }

Parallel Execution

async function parallelExecution(tasks) { const promises = tasks.map(task => invokeTool(task.tool, task.args) );

return await Promise.all(promises); }

Conditional Execution

async function conditionalExecution(condition, ifTrue, ifFalse) { const result = await invokeTool(condition.tool, condition.args);

if (evaluateCondition(result, condition.predicate)) { return await invokeTool(ifTrue.tool, ifTrue.args); } else if (ifFalse) { return await invokeTool(ifFalse.tool, ifFalse.args); }

return null; }

Error Handling

async function retryTool(tool, args, maxRetries = 3) { for (let attempt = 0; attempt <= maxRetries; attempt++) { try { return await invokeTool(tool, args); } catch (error) { if (attempt === maxRetries) throw error;

  const delay = Math.pow(2, attempt) * 1000;
  await new Promise(resolve => setTimeout(resolve, delay));
}

} }

πŸ“Š Tool Capabilities Matrix

Tool Read Write Search Execute Browser

GitHub Issues βœ… βœ… βœ… ❌ ❌

GitHub PRs βœ… βœ… βœ… βœ… ❌

File System βœ… βœ… βœ… ❌ ❌

Bash βœ… βœ… ❌ βœ… ❌

Web βœ… ❌ βœ… ❌ ❌

Playwright βœ… βœ… ❌ βœ… βœ…

Memory βœ… βœ… βœ… ❌ ❌

πŸŽ“ Related Skills

  • gh-aw-security-architecture: Tool security

  • gh-aw-mcp-configuration: Custom tools

  • gh-aw-continuous-ai-patterns: Tool orchestration

πŸ“š References

  • GitHub REST API

  • Playwright Docs

  • MCP Specification

βœ… Remember

  • Understand all available tools

  • Choose the right tool for each task

  • Validate tool inputs

  • Sanitize paths and commands

  • Rate limit tool invocations

  • Audit log all usage

  • Handle errors gracefully

  • Use parallel execution when possible

  • Secure sensitive parameters

  • Test custom tools thoroughly

  • Monitor tool performance

  • Keep tools up to date

Last Updated: 2026-02-17

Version: 1.0.0

License: Apache-2.0

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

github-agentic-workflows

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

code-review-practices

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

code-quality-checks

No summary provided by upstream source.

Repository SourceNeeds Review