惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

雷峰网
雷峰网
Google DeepMind News
Google DeepMind News
D
DataBreaches.Net
博客园 - 三生石上(FineUI控件)
B
Blog
L
LangChain Blog
C
Check Point Blog
Recorded Future
Recorded Future
云风的 BLOG
云风的 BLOG
L
LINUX DO - 最新话题
NISL@THU
NISL@THU
酷 壳 – CoolShell
酷 壳 – CoolShell
S
SegmentFault 最新的问题
C
CXSECURITY Database RSS Feed - CXSecurity.com
博客园 - Franky
Scott Helme
Scott Helme
Security Latest
Security Latest
A
Arctic Wolf
K
Kaspersky official blog
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
C
Cybersecurity and Infrastructure Security Agency CISA
T
Threat Research - Cisco Blogs
D
Darknet – Hacking Tools, Hacker News & Cyber Security
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
C
Cisco Blogs
月光博客
月光博客
The Hacker News
The Hacker News
Apple Machine Learning Research
Apple Machine Learning Research
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
G
GRAHAM CLULEY
L
Lohrmann on Cybersecurity
WordPress大学
WordPress大学
Engineering at Meta
Engineering at Meta
Martin Fowler
Martin Fowler
F
Fortinet All Blogs
Cyberwarzone
Cyberwarzone
有赞技术团队
有赞技术团队
小众软件
小众软件
Microsoft Security Blog
Microsoft Security Blog
aimingoo的专栏
aimingoo的专栏
博客园 - 聂微东
P
Proofpoint News Feed
T
The Exploit Database - CXSecurity.com
量子位
Project Zero
Project Zero
Recent Commits to openclaw:main
Recent Commits to openclaw:main
C
Cyber Attacks, Cyber Crime and Cyber Security
The Last Watchdog
The Last Watchdog
H
Hackread – Cybersecurity News, Data Breaches, AI and More
S
Security Archives - TechRepublic

Hacker News: Show HN

PurrrrrFocus: Pomodoro Timer App - App Store Workflow Engine — Multi-Step Orchestration for Bun RapidPhoto: Pro Photo Editor App - App Store GitHub - DheerG/swarms: Achieve extraordinary results with claude code across a variety of tasks SPICE simulation → oscilloscope → verification with Claude Code — Lucas Gerads Show HN: VCoding – A 5 MB native Windows IDE with no dynamic dependencies Show HN: LLMs don't hallucinate because they're bad at math, it's the format GitHub - Agent-FM/agentfm-core: AgentFM is a peer-to-peer network that turns everyday computers into a decentralized AI supercomputer. AgentFM lets you run massive AI workloads directly across a global mesh of idle CPUs and GPUs. Show HN: Tracking Top US Science Olympiad Alumni over Last 25 Years GitHub - Potarix/agent-hub: One place to talk to all your agents Show HN: Runtime security for AI agents(injection,tool abuse, data exfiltration) GitHub - dubeyKartikay/lazyspotify: Terminal Spotify client for macOS and Linux GitHub - the-banana-tool/king-louie: Easy to use GUI Personal AI Assistant. Win/Linux/Mac. Show HN I made my vacation rental bookable by AI agents–no Airbnb, 0% commission GitHub - basteez/jsf-autoreload: maven plugin to enable hot reload on jsf projects uvm32/hosts/host-gdbstub at main · ringtailsoftware/uvm32 GitHub - labsai/EDDI: Config-driven engine that turns JSON into production-grade AI agents. Multi-agent orchestration, 12+ LLM providers, MCP/A2A protocols, RAG, persistent memory, and enterprise compliance (EU AI Act, GDPR, HIPAA). Built on Quarkus. GitHub - glitchnsec/fortyone-oss: AI Executive Assistant Platform Quickstart | Alien GitHub - muxshed/shed: One stream in, or many. Every destination, simultaneously. No cloud middleman, no per-channel fees, no limits. GitHub - ocrbase-hq/ocrbase: 📄 PDF/IMG ->.MD/JSON Document OCR API for PaddleOCR and GLMOCR. Self-hostable. GitHub - impactjo/home-memory: MCP server that lets your AI assistant remember everything about your home. GitHub - Sets88/dbcls: DbCls is a powerful terminal database client that supports various databases GitHub - neptun2000/heor-agent-mcp GitHub - SeanFDZ/macmind: Single-layer transformer in HyperTalk for the classic Macintosh RollQuation: Math Puzzles - Apps on Google Play GitHub - dropbox/witchcraft Show HN: Agent-cache – Multi-tier LLM/tool/session caching for Valkey and Redis GitHub - opentalon/opentalon: OpenTalon is an open-source platform built from the ground up in Go as a robust alternative to OpenClaw LinkedIn™ 职位抓取工具 - Chrome 应用商店 GitHub - EdoardoBambini/Agent-Armor-Iaga: AI agents are getting tool access — shell, file system, databases, APIs, secrets. But **nobody is governing what they actually do with it**. Frameworks like LangChain, CrewAI, AutoGen, and Claude Code give agents the power to execute. Agent Armor gives you the power to control, audit, and approve every single action before it happens. HN Vibes — Week 15, Apr 7–13 2026 GitHub - chojs23/ec: Easy terminal-native 3-way git mergetool vim-like workflow GitHub - SethPyle376/hiraeth: Local AWS emulator focused on fast integration testing, with SQS support, SQLite-backed state, and a debug-friendly web UI. GitHub - JakOb-dotcom/cloud-sandbox-security-analysis: Technical analysis and Proof of Concept (PoC) regarding environment variable exfiltration in containerized cloud sandboxes via side-channel data leaks. Springboards - Flint Alpha Show HN: A simpler coding agent harness GitHub - audiodude/sudomake-friends GitHub - 256thFission/mini-mythos: OSS clone of Anthropic’s Mythos harness to locate C/C++ memory vulnerabilities Show HN: OpenParallax: OS-level privilege separation for AI agent execution Hacker News Sorted - Chrome 应用商店 Show HN: How to Install Docker on Ubuntu 24.04 LTS: Complete 2026 Guide GitHub - himanshudongre/smriti GitHub - sverrirsig/claude-control: macOS desktop dashboard for monitoring and managing multiple Claude Code sessions GitHub - ory/dockertest: Write better integration tests! Dockertest helps you boot up ephermal docker images for your Go tests with minimal work. Chiral - Chrome 应用商店 Show HN: Two Claudes collaborating through shared memory on a $100 mini-PC GitHub - pmichaillat/latex-cv: Minimalist LaTeX template for academic CVs GitHub - oguzbilgic/posse: A web UI for Anthropic Managed Agents. GitHub - sshiraz/depsly: Dependency risk analysis tool for npm packages ABI Add safari/agent-harness — Safari browser automation via safari-mcp by achiya-automation · Pull Request #212 · HKUDS/CLI-Anything GitHub - Halfblood-Prince/trustcheck: Verify PyPI package attestations and improve Python supply-chain security GitHub - oguzbilgic/kern-ai: Agents that do the work and show it. GitHub - bruits/satteri: High-performance Markdown and MDX processing for the JavaScript ecosystem GitHub - tylergibbs1/feedstock: High-performance web crawler and scraper for TypeScript, powered by Bun and Playwright GitHub - Grimm67123/grimmbot: The self-improving sandboxed and open-source AI agent. With persistent memory and scheduling. GitHub - whitevanillaskies/whitebloom: Local whiteboard that blooms. GitHub - hwdsl2/docker-whisper: Docker image for a self-hosted Whisper speech-to-text server with speaker diarization and OpenAI-compatible transcription and translation APIs. Powered by faster-whisper. Supports all Whisper models, NVIDIA GPU (CUDA) acceleration, JSON/SRT/VTT output, SSE streaming, offline mode, and multi-arch (amd64, arm64). GitHub - yisding/reviewwiggum GitHub - MarwanAlsoltany/serrors: Structured errors for Go: sentinel hierarchies, typed data, custom formatting, and slog integration. GitHub - soatok/age-php GitHub - Luthiraa/markitme GitHub - stagas/rtdiff: realtime git diff gui and AI-assisted commits GitHub - tombedor/excalicharts GitHub - wh1le/excalidraw-edit: Open and edit .excalidraw files from the terminal. Offline, auto-saves to disk. MalExt Sentry - Malicious Extension Scanner - Chrome 应用商店 GitHub - syi0808/asciianimesvg: Generate animated ASCII art SVGs from text. CLI, Rust library, WASM, and web editor. GitHub - zaina-ml/ml_forge: A visual-based graph node editor for training computer vision models. GitHub - anakin87/llm-rl-environments-lil-course: 🌱 A little course on Reinforcement Learning Environments for evaluating and training Language Models GitHub - takaakit/superpowers-uml: Superpowers-UML modifies Superpowers to ensure a software development workflow in which AI agents design through UML modeling. AdriByte Studio - Sviluppo Web e Soluzioni Digitali GitHub - chouligi/angel-copilot: Your personalized Angel Investment Advisor Show HN: MoodSense AI (ML and FastAPI and Gradio, Deployed on Hugging Face) Moodsense Ai - a Hugging Face Space by aman179102 GitHub - agenteractai/lodmem: Level Of Detail Context Management for Agents GitHub - ostefani/subnetlens: A fast, concurrent network scanner with a TUI and plain-text CLI, built in Go. It discovers live hosts on your network, scans their open ports, resolves hostnames, and fingerprints operating systems—delivered. Cyber Pulse: Agentic Intel - Apps on Google Play Whisper API: Self-Hostable Speech to Text Transcription The Agent-Web Protocol Stack: A Research Thesis GitHub - msmarkgu/RelayFreeLLM: A restful API designed to route user prompts to various AI model providers. Show HN: Provepy – A Python decorator that proves your code using Lean and LLMs Show HN: Pardonned.com – A searchable database of US Pardons GitHub - patrickdappollonio/dux: Dux is a terminal UI that lets you run multiple AI coding agents side by side, each in its own git worktree, with full companion terminals, macros, commit generation, and a command palette that knows more tricks than you do. kMC Crystal Simulator Show HN: HyperFlow – A self-improving agent framework built on LangGraph GitHub - stef41/vibescore: 🎵 Grade your vibe-coded project. One command, instant letter grade across security, quality, dependencies, and testing. GitHub - stef41/lmscan: 🔍 Detect AI-generated text and fingerprint which LLM wrote it. Open-source GPTZero alternative. Zero dependencies, works offline. imgur.com GitHub - visionscaper/collabmem: Enabling long-term collaboration with Agentic AI - building up episodic and world model memory over time with in-context awareness 在 Steam 上购买 FriedrichAI: Offline AI 立省 10% GitHub - atripati/ark: AI Runtime Kernel — a context operating system for AI agents. Eliminates tool bloat, loads only what’s needed, and gives LLMs their reasoning space back. GitHub - nowork-studio/toprank: Open-source Claude Code skills for SEO, SEM, Google Ads GitHub - tacomanator/sash: Lightweight macOS menu bar app for reliably cycling through windows of the current application. Appents | Social Media Management for Product-First Teams GitHub - pnhoang/youtube-spam-blocker: Automatically detects and hides spam messages in YouTube Live chat. Set rate limits, keyword filters, and block repeat offenders. GitHub - decisionnode/DecisionNode: CLI + Local MCP - A shared structured memory store across Claude Code, Cursor, Windsurf, Antigravity, and every MCP client. Semantically queryable. GitHub - AvaCodeSolutions/django-email-learning: An open source Django app for creating email-based learning platforms with IMAP integration and React frontend components. The $100K Gap in Kubernetes Security Tooling Function Calling Harness: From 6.75% to 100%
GitHub - Elpulgo/azdo: A TUI for working with Azure DevOps in ze terminal.
elpulgo · 2026-06-17 · via Hacker News: Show HN

A Terminal User Interface (TUI) for Azure DevOps - manage pull requests, work items, and pipelines directly from your terminal.

Tests Go License GitHub Release

Table of Contents

  • Installation
  • Features
  • Demo Mode
  • CLI Usage
  • Configuration
  • Keyboard Shortcuts
  • Technology Stack
  • Development
  • FAQ
  • Contributing
  • License

Installation

Quick Install (Recommended)

Linux / macOS:

curl -fsSL https://raw.githubusercontent.com/Elpulgo/azdo/main/install.sh | sh

Windows (PowerShell):

irm https://raw.githubusercontent.com/Elpulgo/azdo/main/install.ps1 | iex

The install scripts will automatically:

  • Detect your OS and architecture
  • Download the latest release from GitHub
  • Install the binary to the appropriate location
  • Create a config file with placeholder values
  • Verify the download checksum

Install options:

# Install a specific version
curl -fsSL https://raw.githubusercontent.com/Elpulgo/azdo/main/install.sh | sh -s -- --version v0.1.0

# Install to a custom directory
./install.sh --install-dir ~/bin

Manual Download

Download the latest release for your platform from the Releases page.

Platform Architecture File
Linux x86_64 azdo_*_Linux_x86_64.tar.gz
Linux ARM64 azdo_*_Linux_arm64.tar.gz
macOS x86_64 azdo_*_Darwin_x86_64.tar.gz
macOS ARM64 (M1+) azdo_*_Darwin_arm64.tar.gz
Windows x86_64 azdo_*_Windows_x86_64.zip
Windows ARM64 azdo_*_Windows_arm64.zip

Extract the archive and move the binary to a directory in your PATH.

From Source

git clone https://github.com/Elpulgo/azdo.git
cd azdo
go build -o azdo-tui ./cmd/azdo-tui

Using Go Install

go install github.com/Elpulgo/azdo/cmd/azdo-tui@latest

Features

Multi-Tab Interface

  • Pull Requests (Tab 1): View and track pull requests
  • Work Items (Tab 2): Browse and manage work items
  • Pipelines (Tab 3): Monitor and drill into pipeline runs
  • Switch between tabs using 1, 2, 3 keys or / arrow keys

Pull Requests

  • List view of pull requests with status indicators
  • Filter to show only your created PRs (m key) or PRs where you're a reviewer (A key)
  • Detailed view showing PR information and metadata
  • Vote on PRs directly from the detail view (approve, reject, suggestions, wait, reset)
  • Code review: Diff viewer with file-by-file navigation
  • Inline commenting, thread replies, and thread resolution
  • General (non-file-specific) comments

Work Items

  • List view of work items with status and type information
  • Detailed view showing work item details
  • View the Discussion (comments) below the description, newest first
  • Add comments from the detail view (c key, multi-line form)
  • Change work item state directly from the detail view (dynamically fetches available states)
  • Filter to show only your assigned items
  • Filter by tag (T key)
  • Filter by state (s key)

Pipeline Dashboard

  • View recent pipeline runs in a sortable table
  • Color-coded status indicators (✓ Success, ✗ Failed, ● Running, ○ Queued)
  • Filter by status (S key)
  • Live auto-refresh with configurable polling interval
  • Connection status indicator in footer
  • Hierarchical detail view with stages, jobs, and tasks
  • Duration tracking for each step
  • Full log viewer with scrollable viewport

Metrics Dashboard (opt-in)

A management view for team leads, disabled by default. Enable it via metrics.enabled: true in config.yaml and a fourth tab appears.

Two sub-views, toggled with v:

  • Live — current-state dwell per work item, per-user roll-up (WIP, in-flight, oldest Active / Ready for Test, points closed in the configured interval), and a worst-first "stuck items" pane. Sourced from the live work-item fetch — no local state, on-demand refresh only.
  • Trends — sprint-on-sprint comparison from a local 90-day snapshot file. Pick any combination of sprint tags with T (multi-select; space toggles, enter confirms) and see per-user points closed, average WIP, stuck count, and cycle time side-by-side. Values are colored: green for closed points, yellow when overloaded, red for stuck items.

The snapshot file lives at ~/.config/azdo-tui/metrics.jsonl. One row per work item per day is appended on first metrics-tab launch each day, then pruned to a 90-day window. No database — append-only JSONL.

One-shot backfill (optional). A fresh install starts with an empty snapshot file, so the Trends view shows "Insufficient snapshot history" for the first ~2 sprints. To seed the file from your team's actual recent history, set:

metrics:
  run_one_shot_backfill: true

On the next launch the tab walks every in-flight or recently-closed work item across all configured projects, reads each item's revision history via /updates, and synthesizes daily snapshot rows back 90 days. The footer reports progress and the result. A marker file (~/.config/azdo-tui/.metrics-backfill-done) prevents re-running — delete it if you want to re-seed. Flip the flag back to false once it's done so the footer hint stops appearing.

User Experience

  • Setup wizard on first run guides you through configuration
  • Help modal with all keyboard shortcuts (press ?)
  • Secure PAT storage using system keyring
  • Context-aware keybinding hints
  • Graceful error handling with automatic retry
  • Eight built-in themes with true color support
  • Theme switcher modal (press t) to change themes on the fly
  • Multi-project support with display name customization
  • State persistence — remembers the last active tab and the last opened PR / work item detail across sessions, so you can pick up where you left off

Demo Mode

Want to try azdo without an Azure DevOps account? Run the demo — no configuration, no PAT, no setup required:

This launches the full TUI with realistic mock data (two fictional projects, pull requests with diffs, work items, pipeline runs with logs). All features work — you can navigate, view details, switch themes, and explore the UI. Perfect for evaluating the tool or taking screenshots.

Pull Requests list view

See more screenshots in the screenshots folder.

CLI Usage

# Start the TUI
azdo

# Try it out with mock data (no setup needed)
azdo demo

# Set or update your Personal Access Token
azdo auth

# Show version
azdo --version

# Show help
azdo --help

Configuration

1. Create Configuration File

When running azdo for the first time, a wizard setup will help you setup this. Otherwise follow these instructions.

Create a configuration file at the following location:

  • Linux/macOS: ~/.config/azdo-tui/config.yaml
  • Windows: C:\Users\<username>\.config\azdo-tui\config.yaml
# Azure DevOps organization name (required)
organization: your-org-name

# Azure DevOps project name(s) (required)
# Simple format:
projects:
  - your-project-name

# With display names (friendly name shown in UI):
#   projects:
#     - name: ugly-api-project-name
#       display_name: My Project
#     - name: ugly-api-project-name-2
#       display_name: My Project 2

# Polling interval in seconds (optional, default: 60)
polling_interval: 60

# Theme (optional, default: dark)
# Available themes: dark, gruvbox, nord, dracula, catppuccin, github, retro, monokai
theme: dark

# Disable specific panes (optional, comma-separated)
# Valid values: pipelines, workitems
# disabled_panes: pipelines,workitems

# Metrics dashboard (opt-in, management feature). Hidden unless enabled.
# See "Metrics Configuration" below for the full reference.
# metrics:
#   enabled: false
#   interval_days: 14            # window for the Live "closed pts" column
#   active_stale_days: 3         # dwell in Active above this flags the item
#   rft_stale_days: 2            # dwell in Ready for Test above this flags the item
#   wip_limit: 4                 # in-flight strictly above this marks a user overloaded
#   run_one_shot_backfill: false # one-time /updates seed (see Features → Metrics)
#   states:                      # your board's actual state names (case-insensitive)
#     active: Active
#     ready_for_test: Ready for Test
#     closed: Closed
#   state_labels:                # optional column-header overrides (auto-derived if omitted)
#     active: active
#     ready_for_test: rft
#     closed: closed

Configuration Options:

  • organization: Your Azure DevOps organization name (required)
  • projects: List of Azure DevOps project names (required). Each entry can be a plain string or an object with name and display_name fields. The display_name is shown in the TUI while the name is used for API calls.
  • polling_interval: How often to refresh data in seconds (optional, default: 60)
  • theme: Color theme for the UI (optional, default: dark)
  • disabled_panes: Comma-separated list of panes to hide (optional). Valid values: pipelines, workitems. When a pane is disabled, its tab, keyboard shortcuts, and all related UI are removed. Pull Requests cannot be disabled.
  • metrics: Opt-in management dashboard. See Metrics Configuration below for the full reference, and Features → Metrics Dashboard for what it does.

Available Themes:

  • dark - Dark theme with blue and cyan accents
  • gruvbox - Retro groove color scheme
  • nord - Arctic, north-bluish color palette
  • dracula - Default dark theme with purple and pink accents
  • catppuccin - Soothing pastel theme (Mocha variant)
  • github - GitHub Dark theme
  • retro - Matrix-inspired green phosphor on black
  • monokai - Classic Monokai color scheme

Metrics Configuration

The metrics dashboard is opt-in and hidden entirely unless metrics.enabled: true. All keys live under the top-level metrics: block and are optional — the defaults below apply when a key is omitted. The validation rules only apply when enabled is true.

Key Type Default Description
metrics.enabled bool false Master switch. The whole tab is hidden when false.
metrics.interval_days int 14 Look-back window (days) for points-closed / velocity. Must be > 0.
metrics.active_stale_days int 3 Dwell in Active longer than this flags the item as stuck. Must be >= 0.
metrics.rft_stale_days int 2 Dwell in Ready-for-Test longer than this flags the item as stuck. Must be >= 0.
metrics.wip_limit int 4 In-flight items strictly above this marks a user overloaded (⚠). Must be > 0.
metrics.run_one_shot_backfill bool false One-time 90-day /updates seed of history on next launch. A marker file prevents it re-running.

State names — metrics.states

These map your board's actual workflow-state strings onto the three buckets the metrics engine tracks. Matching is case-insensitive and whitespace-trimmed, but each takes a single name (no comma-separated aliases). If your board doesn't literally use "Active" / "Ready for Test" / "Closed", set these or the metrics tab will bucket nothing.

Key Default
metrics.states.active Active
metrics.states.ready_for_test Ready for Test
metrics.states.closed Closed

Each name must be non-empty, distinct from the other two, and contain no single quote (') — single quotes are rejected for WIQL-injection safety.

Column labels — metrics.state_labels (optional)

Display-only overrides for the metrics table column headers. When omitted, labels are auto-derived from the configured state name: multi-word names become lowercased initials (Ready for Testrft, In Progressip), single-word names are lowercased as-is (Donedone).

Key Falls back to
metrics.state_labels.active derived from states.active
metrics.state_labels.ready_for_test derived from states.ready_for_test
metrics.state_labels.closed derived from states.closed

Example — a board using "Doing" / "QA" / "Done":

metrics:
  enabled: true
  interval_days: 14
  wip_limit: 4
  states:
    active: Doing
    ready_for_test: QA
    closed: Done
  state_labels:
    ready_for_test: QA   # override the auto-derived lowercase "qa" to keep the caps

Custom Themes

You can create your own custom themes by placing JSON theme files in the themes directory:

  • Linux/macOS: ~/.config/azdo-tui/themes/
  • Windows: C:\Users\<username>\.config\azdo-tui\themes\

Creating a Custom Theme:

  1. Create the themes directory if it doesn't exist:

    mkdir -p ~/.config/azdo-tui/themes
  2. Create a JSON theme file (e.g., mytheme.json):

    {
      "name": "mytheme",
      "primary": "#0088ff",
      "secondary": "#00aaff",
      "accent": "#ff8800",
      "success": "#00ff88",
      "warning": "#ffaa00",
      "error": "#ff4444",
      "info": "#00ccff",
      "background": "#1a1b26",
      "background_alt": "#24283b",
      "background_select": "#343b58",
      "foreground": "#c0caf5",
      "foreground_muted": "#787c99",
      "foreground_bold": "#ffffff",
      "select_foreground": "#ffffff",
      "select_background": "#0088ff",
      "border": "#3b4261",
      "link": "#7aa2f7",
      "spinner": "#bb9af7",
      "tab_active_foreground": "#ffffff",
      "tab_active_background": "#0088ff",
      "tab_inactive_foreground": "#787c99"
    }
  3. Set the theme in your config.yaml:

  4. Restart the application to use your custom theme.

See example-theme.json in the repository for a complete template with all available color properties. Colors can be specified as:

  • Hex values: #ff0000 or #f00
  • ANSI 256 colors: "1", "33", "196"

State File

The application persists a small amount of navigation state between runs (last active tab, last opened PR / work item detail) so you land back where you left off. The file is written to:

  • Linux/macOS: $XDG_STATE_HOME/azdo-tui/state.yaml if set, otherwise ~/.local/state/azdo-tui/state.yaml
  • Windows: %USERPROFILE%\.local\state\azdo-tui\state.yaml

The file is created lazily — no state file is required to run the app. Writes are debounced and flushed on clean exit (including SIGINT / SIGTERM / SIGHUP). Delete the file to reset the saved view.

2. Azure DevOps Personal Access Token (PAT)

On first run, the application will prompt you to enter your Azure DevOps PAT. The token is securely stored in your system's credential manager:

  • Windows: Windows Credential Manager
  • macOS: Keychain
  • Linux: Secret Service (gnome-keyring, KWallet, etc.)

You can also set the AZDO_PAT environment variable as a fallback if your system doesn't support a keyring. To update your PAT at any time, run azdo auth.

Required PAT Scopes:

Scope Access Used For
Build Read Pipeline runs, build timelines, and logs
Code Read & Write List PRs, view threads/iterations/diffs, vote on PRs, add comments, and update thread status
Work Items Read & Write Query and view work items, read/add comments, fetch available states, and change work item state

To create a PAT:

  1. Go to Azure DevOps → User Settings → Personal Access Tokens
  2. Click "New Token"
  3. Select the required scopes
  4. Copy the generated token

Keyboard Shortcuts

Global

Key Action
1, 2, 3 Switch to PR/Work Items/Pipelines tab
←/→ Previous / next tab
r Refresh data
↑/↓ or j/k Navigate up/down
pgup/pgdn Page up/down
enter View details / expand
f Search / filter
m Toggle my items (PRs / work items)
A Toggle as reviewer (PRs)
T Filter by tag (work items)
s Filter by state (work items)
S Filter by status (pipelines)
esc Go back / dismiss search
? Toggle help modal
t Select theme
q or Ctrl+C Quit

PR Detail View

Key Action
v Vote on pull request
o Open pull request in browser
enter View diff for selected file

PR Diff / Code Review View

Key Action
c Create comment (on selected line or general)
p Reply to nearest thread
x Resolve nearest thread
n Jump to next comment
N Jump to previous comment
r Refresh changed files

Work Item Detail View

Key Action
w Change work item state
c Add a comment (opens form; Ctrl+S to send, Esc to cancel)
o Open work item in browser

Log Viewer

Key Action
g Jump to top
G Jump to bottom

Technology Stack

Development

Running Tests

Running with Coverage

Building

go build -o azdo ./cmd/azdo-tui

Releases

See RELEASES.md for release process and GoReleaser usage.

FAQ

See FAQ.md for common questions and troubleshooting.

Contributing

Contributions are welcome! See CONTRIBUTING.md for guidelines.

License

MIT License - see LICENSE for details.