<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: ura-tools</title>
    <description>The latest articles on DEV Community by ura-tools (@uratools).</description>
    <link>https://dev.to/uratools</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3848206%2F7e41a066-95c6-44ed-a7e3-c8811173402b.png</url>
      <title>DEV Community: ura-tools</title>
      <link>https://dev.to/uratools</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/uratools"/>
    <language>en</language>
    <item>
      <title>Your AI Agent Forgets Everything Between Sessions. I Fixed That.</title>
      <dc:creator>ura-tools</dc:creator>
      <pubDate>Sun, 29 Mar 2026 23:29:57 +0000</pubDate>
      <link>https://dev.to/uratools/your-ai-agent-forgets-everything-between-sessions-i-fixed-that-3i0e</link>
      <guid>https://dev.to/uratools/your-ai-agent-forgets-everything-between-sessions-i-fixed-that-3i0e</guid>
      <description>&lt;p&gt;Every time you start a new session with Claude Code, Cursor, or any AI coding agent, it starts from scratch. It does not remember:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Who you are or what you prefer&lt;/li&gt;
&lt;li&gt;What decisions were made yesterday&lt;/li&gt;
&lt;li&gt;What corrections you already gave it&lt;/li&gt;
&lt;li&gt;Where external resources live&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;I built &lt;strong&gt;memorybank&lt;/strong&gt; to fix this.&lt;/p&gt;

&lt;h2&gt;
  
  
  What is memorybank?
&lt;/h2&gt;

&lt;p&gt;An MCP server that gives any AI agent persistent, cross-session memory. Zero dependencies, file-based, works with Claude Code, Cursor, Windsurf, and any MCP-compatible tool.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npx @ura-dev/memorybank &lt;span class="nt"&gt;--help&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  8 MCP Tools
&lt;/h2&gt;

&lt;div class="table-wrapper-paragraph"&gt;&lt;table&gt;
&lt;thead&gt;
&lt;tr&gt;
&lt;th&gt;Tool&lt;/th&gt;
&lt;th&gt;What it does&lt;/th&gt;
&lt;/tr&gt;
&lt;/thead&gt;
&lt;tbody&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;memory_store&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;Save a memory (user, project, feedback, reference, custom)&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;memory_recall&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;Retrieve most relevant memories for a query&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;memory_list&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;List all memories, filter by type or tag&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;memory_get&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;Get a specific memory by ID&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;memory_update&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;Update an existing memory&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;memory_delete&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;Delete a memory&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;memory_search&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;Full-text search across all memories&lt;/td&gt;
&lt;/tr&gt;
&lt;tr&gt;
&lt;td&gt;&lt;code&gt;memory_stats&lt;/code&gt;&lt;/td&gt;
&lt;td&gt;Counts, types, storage size&lt;/td&gt;
&lt;/tr&gt;
&lt;/tbody&gt;
&lt;/table&gt;&lt;/div&gt;

&lt;h2&gt;
  
  
  How it works
&lt;/h2&gt;

&lt;ol&gt;
&lt;li&gt;Your agent encounters something worth remembering&lt;/li&gt;
&lt;li&gt;It calls &lt;code&gt;memory_store&lt;/code&gt; with a type, name, and content&lt;/li&gt;
&lt;li&gt;memorybank saves it as a markdown file with YAML frontmatter&lt;/li&gt;
&lt;li&gt;Next session, the agent calls &lt;code&gt;memory_recall&lt;/code&gt; to load relevant context&lt;/li&gt;
&lt;li&gt;The agent now knows what happened before&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Memories are stored locally in &lt;code&gt;~/.memorybank/&lt;/code&gt;, organized by namespace (one per project). No cloud, no database, no API keys.&lt;/p&gt;

&lt;h2&gt;
  
  
  Setup in 30 seconds
&lt;/h2&gt;

&lt;p&gt;Add to your Claude Code config (&lt;code&gt;~/.claude/settings.json&lt;/code&gt;):&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight json"&gt;&lt;code&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"mcpServers"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="nl"&gt;"memorybank"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
      &lt;/span&gt;&lt;span class="nl"&gt;"command"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"npx"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
      &lt;/span&gt;&lt;span class="nl"&gt;"args"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="s2"&gt;"-y"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"@ura-dev/memorybank"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"memorybank-mcp"&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Or Cursor (&lt;code&gt;.cursor/mcp.json&lt;/code&gt;):&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight json"&gt;&lt;code&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"mcpServers"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="nl"&gt;"memorybank"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
      &lt;/span&gt;&lt;span class="nl"&gt;"command"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"npx"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
      &lt;/span&gt;&lt;span class="nl"&gt;"args"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="s2"&gt;"-y"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"@ura-dev/memorybank"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"memorybank-mcp"&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;That is it. Your agent now has persistent memory.&lt;/p&gt;

&lt;h2&gt;
  
  
  Five memory types
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;user&lt;/strong&gt; — About you: role, preferences, expertise level&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;project&lt;/strong&gt; — About the work: goals, architecture decisions, deadlines&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;feedback&lt;/strong&gt; — Corrections you gave: what to avoid, what worked&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;reference&lt;/strong&gt; — External pointers: URLs, docs locations, API endpoints&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;custom&lt;/strong&gt; — Anything else&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Why not just use CLAUDE.md?
&lt;/h2&gt;

&lt;p&gt;CLAUDE.md is great for static project instructions. memorybank is for dynamic knowledge that evolves during work:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;User corrections that should persist&lt;/li&gt;
&lt;li&gt;Architecture decisions made mid-project&lt;/li&gt;
&lt;li&gt;References discovered during research&lt;/li&gt;
&lt;li&gt;Project status that changes daily&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;memorybank complements CLAUDE.md. One for rules, the other for learned knowledge.&lt;/p&gt;

&lt;h2&gt;
  
  
  CLI too
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;memorybank store user team-lead &lt;span class="s2"&gt;"User is the team lead for backend services"&lt;/span&gt;
memorybank search &lt;span class="s2"&gt;"TypeScript preferences"&lt;/span&gt;
memorybank list &lt;span class="nt"&gt;--type&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;feedback
memorybank store project api-rewrite &lt;span class="s2"&gt;"Migrating REST to GraphQL"&lt;/span&gt; &lt;span class="nt"&gt;--namespace&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;myproject
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Also: agentrace
&lt;/h2&gt;

&lt;p&gt;If you want to see what your AI agent is doing (not just what it remembers), check out &lt;a href="https://www.npmjs.com/package/@ura-dev/agentrace" rel="noopener noreferrer"&gt;agentrace&lt;/a&gt;. Structured observability for AI agents. Same philosophy: MCP server, zero deps, file-based.&lt;/p&gt;




&lt;p&gt;&lt;strong&gt;Links:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;npm: &lt;a href="https://www.npmjs.com/package/@ura-dev/memorybank" rel="noopener noreferrer"&gt;@ura-dev/memorybank&lt;/a&gt;
&lt;/li&gt;
&lt;li&gt;GitHub: &lt;a href="https://github.com/ura-tools/memorybank" rel="noopener noreferrer"&gt;ura-tools/memorybank&lt;/a&gt;
&lt;/li&gt;
&lt;li&gt;Landing page: &lt;a href="https://ura-tools.github.io/memorybank/" rel="noopener noreferrer"&gt;ura-tools.github.io/memorybank&lt;/a&gt;
&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Built with zero dependencies. MIT licensed. Works today.&lt;/p&gt;

</description>
      <category>ai</category>
      <category>mcp</category>
      <category>productivity</category>
      <category>opensource</category>
    </item>
    <item>
      <title>I built an observability tool for AI agents — trace what they do and why</title>
      <dc:creator>ura-tools</dc:creator>
      <pubDate>Sat, 28 Mar 2026 22:14:34 +0000</pubDate>
      <link>https://dev.to/uratools/i-built-an-observability-tool-for-ai-agents-trace-what-they-do-and-why-25l0</link>
      <guid>https://dev.to/uratools/i-built-an-observability-tool-for-ai-agents-trace-what-they-do-and-why-25l0</guid>
      <description>

&lt;p&gt;&lt;em&gt;Also from ura: &lt;a href="https://dev.to/uratools/i-built-a-changelog-generator-that-works-on-any-repo-no-conventional-commits-needed-1ekc"&gt;changelogai — AI-powered changelog generation from any git repo&lt;/a&gt;&lt;/em&gt;&lt;/p&gt;

</description>
      <category>ai</category>
      <category>devtools</category>
      <category>mcp</category>
      <category>opensource</category>
    </item>
    <item>
      <title>I built a changelog generator that works on any repo — no conventional commits needed</title>
      <dc:creator>ura-tools</dc:creator>
      <pubDate>Sat, 28 Mar 2026 19:43:58 +0000</pubDate>
      <link>https://dev.to/uratools/i-built-a-changelog-generator-that-works-on-any-repo-no-conventional-commits-needed-1ekc</link>
      <guid>https://dev.to/uratools/i-built-a-changelog-generator-that-works-on-any-repo-no-conventional-commits-needed-1ekc</guid>
      <description>&lt;p&gt;Every changelog tool I tried had the same problem: they only work if your team writes perfect conventional commits. Most teams don't.&lt;/p&gt;

&lt;p&gt;So I built &lt;strong&gt;changelogai&lt;/strong&gt; — a CLI that generates professional changelogs from &lt;em&gt;any&lt;/em&gt; git history.&lt;/p&gt;

&lt;h2&gt;
  
  
  What makes it different
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;It works on messy repos.&lt;/strong&gt; The parser detects commit types from 24 keyword patterns, not just &lt;code&gt;type(scope):&lt;/code&gt; prefixes. Commits like "fixed the auth bug" or "Updated dashboard layout" get classified correctly.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Clickable commit links.&lt;/strong&gt; Auto-detects your GitHub/GitLab remote and generates linked hashes. No config needed.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;AI mode&lt;/strong&gt; (optional). Pass &lt;code&gt;--ai&lt;/code&gt; and it rewrites technical commit messages into user-facing release notes using Claude. Costs ~$0.001 per changelog.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;MCP server included.&lt;/strong&gt; Other AI agents can call &lt;code&gt;changelogai_generate&lt;/code&gt; and &lt;code&gt;changelogai_version_bump&lt;/code&gt; as tools. Add it to your Claude Code or Cursor config in one line.&lt;/p&gt;

&lt;h2&gt;
  
  
  Quick start
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npm &lt;span class="nb"&gt;install&lt;/span&gt; &lt;span class="nt"&gt;-g&lt;/span&gt; @ura-dev/changelogai

&lt;span class="c"&gt;# Grouped changelog since last tag&lt;/span&gt;
changelogai &lt;span class="nt"&gt;--group&lt;/span&gt;

&lt;span class="c"&gt;# AI-enhanced&lt;/span&gt;
changelogai &lt;span class="nt"&gt;--ai&lt;/span&gt; &lt;span class="nt"&gt;--group&lt;/span&gt; &lt;span class="nt"&gt;--output&lt;/span&gt; CHANGELOG.md

&lt;span class="c"&gt;# JSON for CI/CD&lt;/span&gt;
changelogai &lt;span class="nt"&gt;--format&lt;/span&gt; json

&lt;span class="c"&gt;# Suggest next version&lt;/span&gt;
changelogai &lt;span class="nt"&gt;--version-bump&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Use as a library
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;generateChangelog&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;getGitLog&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;getLatestTag&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;require&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;changelogai&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;

&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;commits&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;getGitLog&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;.&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;v1.0.0&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;HEAD&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="mi"&gt;500&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;md&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="nf"&gt;generateChangelog&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;commits&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="na"&gt;format&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;markdown&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="na"&gt;group&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="kc"&gt;true&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  MCP server (for AI agents)
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight json"&gt;&lt;code&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"mcpServers"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="nl"&gt;"changelogai"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="nl"&gt;"command"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"changelogai-mcp"&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Any MCP client (Claude Code, Cursor, Dapr Agents) can now generate changelogs autonomously.&lt;/p&gt;

&lt;h2&gt;
  
  
  Sample output
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight markdown"&gt;&lt;code&gt;&lt;span class="gu"&gt;## [v1.1.0](https://github.com/you/repo/compare/v1.0.0...v1.1.0) — 2026-03-28&lt;/span&gt;

&lt;span class="gu"&gt;### Features&lt;/span&gt;
&lt;span class="p"&gt;-&lt;/span&gt; Add dark mode toggle (abc123)
&lt;span class="p"&gt;-&lt;/span&gt; Support custom themes (def456)

&lt;span class="gu"&gt;### Bug Fixes&lt;/span&gt;
&lt;span class="p"&gt;-&lt;/span&gt; Fix login redirect on mobile (789abc)
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  The boring details
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Zero dependencies — pure Node.js&lt;/li&gt;
&lt;li&gt;Works with Node 18+&lt;/li&gt;
&lt;li&gt;Markdown, JSON, or plain text output&lt;/li&gt;
&lt;li&gt;Prepend mode for existing CHANGELOG.md files&lt;/li&gt;
&lt;li&gt;MIT license&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Built by &lt;a href="https://github.com/ura-tools/changelogai" rel="noopener noreferrer"&gt;ura&lt;/a&gt; — developer tools that go deeper.&lt;/p&gt;




&lt;p&gt;&lt;em&gt;Also from ura: &lt;a href="https://dev.to/uratools/i-built-an-observability-tool-for-ai-agents-trace-what-they-do-and-why-25l0"&gt;agentrace — structured observability for AI agents&lt;/a&gt;&lt;/em&gt;&lt;/p&gt;

</description>
      <category>cli</category>
      <category>devtools</category>
      <category>ai</category>
      <category>opensource</category>
    </item>
  </channel>
</rss>
