<?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: Kat Laszlo</title>
    <description>The latest articles on DEV Community by Kat Laszlo (@kat_laszlo).</description>
    <link>https://dev.to/kat_laszlo</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%2F3832776%2F9683a03f-431d-4e26-abef-c8145cbbf89a.png</url>
      <title>DEV Community: Kat Laszlo</title>
      <link>https://dev.to/kat_laszlo</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/kat_laszlo"/>
    <language>en</language>
    <item>
      <title>What Claude Code stores on your machine (and how to see it)</title>
      <dc:creator>Kat Laszlo</dc:creator>
      <pubDate>Tue, 31 Mar 2026 18:31:18 +0000</pubDate>
      <link>https://dev.to/kat_laszlo/what-claude-code-stores-on-your-machine-and-how-to-see-it-17bb</link>
      <guid>https://dev.to/kat_laszlo/what-claude-code-stores-on-your-machine-and-how-to-see-it-17bb</guid>
      <description>&lt;p&gt;Claude Code keeps a lot of data in &lt;code&gt;~/.claude/&lt;/code&gt; that most people never look at. I wanted to know what was there, so I built a scanner.&lt;/p&gt;

&lt;p&gt;On my machine it found:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;76 persistent memory files across 10 projects&lt;/li&gt;
&lt;li&gt;4,445 session transcripts totaling 1.8GB&lt;/li&gt;
&lt;li&gt;2.2GB total data footprint&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The memory files are markdown with frontmatter, organized by type: what Claude thinks your role is, feedback you've given, project context, reference links. It remembers more than you'd expect.&lt;/p&gt;

&lt;h2&gt;
  
  
  The tool
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npx agentlens scan
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;No API keys, no accounts. Reads local files only.&lt;/p&gt;

&lt;h3&gt;
  
  
  Scan commands
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;code&gt;agentlens memory&lt;/code&gt; — what Claude remembers about you&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;agentlens costs&lt;/code&gt; — token usage by model and project&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;agentlens features&lt;/code&gt; — active feature flags on your account&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;agentlens sessions&lt;/code&gt; — transcript stats and tool usage&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;agentlens privacy&lt;/code&gt; — total data footprint&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  Action commands
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;code&gt;agentlens clean --dry-run&lt;/code&gt; — preview which memories would be deleted&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;agentlens redact&lt;/code&gt; — find secrets that leaked into memory files&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;agentlens diff save&lt;/code&gt; — snapshot current state, then &lt;code&gt;diff show&lt;/code&gt; to compare later&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;agentlens export&lt;/code&gt; — dump everything to portable JSON&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  What surprised me
&lt;/h2&gt;

&lt;p&gt;The sensitivity scanner flagged 13 potential secrets in my memory files. Most were false positives (the word "token" in pricing discussions), but some were file paths and references I wouldn't want in a shared context.&lt;/p&gt;

&lt;p&gt;Session transcripts contain everything: every file you read, every bash command you ran, every edit you made. If you've ever read a &lt;code&gt;.env&lt;/code&gt; file during a Claude Code session, it's in there.&lt;/p&gt;

&lt;h2&gt;
  
  
  Stack
&lt;/h2&gt;

&lt;p&gt;~900 lines of TypeScript. Node 18+. Dependencies: chalk, commander, glob, yaml. MIT licensed.&lt;/p&gt;

&lt;p&gt;GitHub: &lt;a href="https://github.com/katrinalaszlo/agentlens" rel="noopener noreferrer"&gt;https://github.com/katrinalaszlo/agentlens&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Would love to hear what you think!&lt;/p&gt;

</description>
      <category>ai</category>
      <category>typescript</category>
      <category>opensource</category>
      <category>devtools</category>
    </item>
    <item>
      <title>Track Your AI Costs Per Customer in One API Call</title>
      <dc:creator>Kat Laszlo</dc:creator>
      <pubDate>Wed, 25 Mar 2026 18:27:44 +0000</pubDate>
      <link>https://dev.to/tanso/track-your-ai-costs-per-customer-in-one-api-call-32c7</link>
      <guid>https://dev.to/tanso/track-your-ai-costs-per-customer-in-one-api-call-32c7</guid>
      <description>&lt;p&gt;If you're building on top of AI APIs, you're probably calling OpenAI, Anthropic, Cohere, and a few others depending on the task. Each one bills differently. Costs shift when model prices change. And at some point, someone asks: "Are we making money on this customer?"&lt;/p&gt;

&lt;p&gt;Without instrumentation, that question takes a day to answer. With it, it takes a query.&lt;/p&gt;

&lt;h2&gt;
  
  
  The problem
&lt;/h2&gt;

&lt;p&gt;You ship a feature. It works. Customers use it. Then pricing changes, or a customer's usage spikes, or you realize token costs for one feature are eating your margin on that plan tier.&lt;/p&gt;

&lt;p&gt;The issue isn't that you don't have cost data. Your AI provider invoices you every month. The issue is that data isn't broken down by your customers or your features. You see what you spent. You don't see what each customer cost you.&lt;/p&gt;

&lt;p&gt;To know your margin per customer, you need to capture cost at the moment the AI call happens, with context attached.&lt;/p&gt;

&lt;h2&gt;
  
  
  One event call
&lt;/h2&gt;

&lt;p&gt;After each AI API response, send one event to Tanso:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="nf"&gt;fetch&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;http://localhost:8080/api/v1/client/events&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="na"&gt;method&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;POST&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="na"&gt;headers&lt;/span&gt;&lt;span class="p"&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;Content-Type&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;application/json&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;Authorization&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;Bearer sk_test_67d9fb04f0344036ba92ecc973f1445a&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;
  &lt;span class="p"&gt;},&lt;/span&gt;
  &lt;span class="na"&gt;body&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;JSON&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;stringify&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt;
    &lt;span class="na"&gt;eventIdempotencyKey&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;crypto&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;randomUUID&lt;/span&gt;&lt;span class="p"&gt;(),&lt;/span&gt;
    &lt;span class="na"&gt;eventName&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;chat_completion&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;customerReferenceId&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;cus_123&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;featureKey&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;ai_summarization&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;costInput&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="na"&gt;model&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;gpt-4o&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
      &lt;span class="na"&gt;modelProvider&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;openai&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="p"&gt;},&lt;/span&gt;
    &lt;span class="na"&gt;usageUnits&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;response&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;usage&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;total_tokens&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;costAmount&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="mf"&gt;0.05&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="p"&gt;})&lt;/span&gt;
&lt;span class="p"&gt;})&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;


&lt;p&gt;A few things worth noting:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;&lt;code&gt;eventIdempotencyKey&lt;/code&gt;&lt;/strong&gt; required. If the same event is sent twice (network retry, duplicate webhook), Tanso deduplicates silently. Use &lt;code&gt;crypto.randomUUID()&lt;/code&gt; per call, or derive it from your own request ID if you need stable deduplication.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;&lt;code&gt;customerReferenceId&lt;/code&gt;&lt;/strong&gt; your customer's ID, whatever you already use. Tanso maps this to their account.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;&lt;code&gt;featureKey&lt;/code&gt;&lt;/strong&gt; ties the event to a specific feature on the customer's plan. This is how Tanso separates cost for &lt;code&gt;ai_summarization&lt;/code&gt; from &lt;code&gt;document_export&lt;/code&gt; from &lt;code&gt;chat_completion&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;&lt;code&gt;costAmount&lt;/code&gt;&lt;/strong&gt; dollars, not cents. Pass &lt;code&gt;0.05&lt;/code&gt;, not &lt;code&gt;5&lt;/code&gt; for 5 cents.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;&lt;code&gt;costInput&lt;/code&gt;&lt;/strong&gt; model and provider metadata. Used for cost attribution when you want Tanso to calculate costs from usage rather than passing them explicitly.&lt;/p&gt;

&lt;p&gt;That's it. No batch jobs. No ETL. No scraping provider invoices.&lt;/p&gt;
&lt;h2&gt;
  
  
  What you get
&lt;/h2&gt;

&lt;p&gt;Once events are flowing, Tanso aggregates them in real time by customer and feature.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Margin by customer.&lt;/strong&gt; You know what &lt;code&gt;cus_123&lt;/code&gt; costs you this billing period, broken down by feature. Compare that to what they're paying. That's your margin.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Margin by feature.&lt;/strong&gt; If &lt;code&gt;ai_summarization&lt;/code&gt; on your Starter plan is consistently underwater, you see it before it shows up as a bad quarter.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Usage against plan limits.&lt;/strong&gt; Tanso tracks &lt;code&gt;usageUnits&lt;/code&gt; against the feature's limit on the customer's plan. The entitlement check API (&lt;code&gt;POST /api/v1/client/entitlements/check&lt;/code&gt;) returns current usage and limit in real time, so you can gate access before a customer blows past their quota.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Automatic Stripe sync.&lt;/strong&gt; Events flow through to Stripe Billing Meters and land on the customer's next invoice. You don't manage the billing side separately.&lt;/p&gt;
&lt;h2&gt;
  
  
  Works from anywhere
&lt;/h2&gt;

&lt;p&gt;You don't need a dedicated service to send events. Tanso's event API is an HTTP POST. That means it works from:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Your backend&lt;/strong&gt; add the call after any AI API response&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Your terminal&lt;/strong&gt; curl for one-off testing or backfilling&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;An AI agent&lt;/strong&gt; Tanso exposes an MCP server, so Claude Code and other agents can instrument their own AI calls natively, or query cost data while they work
&lt;/li&gt;
&lt;/ul&gt;
&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;curl &lt;span class="nt"&gt;-X&lt;/span&gt; POST http://localhost:8080/api/v1/client/events &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;-H&lt;/span&gt; &lt;span class="s2"&gt;"Content-Type: application/json"&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;-H&lt;/span&gt; &lt;span class="s2"&gt;"Authorization: Bearer sk_test_67d9fb04f0344036ba92ecc973f1445a"&lt;/span&gt; &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;-d&lt;/span&gt; &lt;span class="s1"&gt;'{
    "eventIdempotencyKey": "550e8400-e29b-41d4-a716-446655440000",
    "eventName": "chat_completion",
    "customerReferenceId": "cus_123",
    "featureKey": "ai_summarization",
    "costInput": {
      "model": "gpt-4o",
      "modelProvider": "openai"
    },
    "usageUnits": 1847,
    "costAmount": 0.05
  }'&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;

&lt;h2&gt;
  
  
  Get started
&lt;/h2&gt;

&lt;ol&gt;
&lt;li&gt;Get an API key from the &lt;a href="https://dashboard.tansohq.com" rel="noopener noreferrer"&gt;Tanso dashboard&lt;/a&gt;
&lt;/li&gt;
&lt;li&gt;Configure a feature on your plan (e.g., &lt;code&gt;ai_summarization&lt;/code&gt;) with the expected pricing model&lt;/li&gt;
&lt;li&gt;Add the event call after each AI API response in your code&lt;/li&gt;
&lt;li&gt;Check the dashboard, cost and usage data appears immediately&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;If you want to verify an event landed correctly, the dashboard shows raw event history per customer. You can also check a customer's current entitlement state at any time via the entitlement API.&lt;/p&gt;



&lt;p&gt;Tanso is built for teams shipping on top of multiple AI APIs who need to know their economics at the customer level, not just at the invoice level. The event API is the foundation. Everything else, entitlement checks, metered billing, plan enforcement, runs on the same data.&lt;/p&gt;

&lt;p&gt;Would love to hear if this is helpful or not. &lt;a href="https://cal.com/katrina-laszlo/meeting?duration=15&amp;amp;overlayCalendar=true" rel="noopener noreferrer"&gt;Happy to chat!&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;The Docs:&lt;br&gt;
&lt;/p&gt;
&lt;div class="crayons-card c-embed text-styles text-styles--secondary"&gt;
    &lt;div class="c-embed__content"&gt;
      &lt;div class="c-embed__body flex items-center justify-between"&gt;
        &lt;a href="https://tanso-core.readme.io/reference/createcustomer" rel="noopener noreferrer" class="c-link fw-bold flex items-center"&gt;
          &lt;span class="mr-2"&gt;tanso-core.readme.io&lt;/span&gt;
          

        &lt;/a&gt;
      &lt;/div&gt;
    &lt;/div&gt;
&lt;/div&gt;



</description>
      <category>ai</category>
      <category>saas</category>
      <category>billing</category>
      <category>devops</category>
    </item>
    <item>
      <title>We built an MCP server so AI coding tools can set up your entire billing system</title>
      <dc:creator>Kat Laszlo</dc:creator>
      <pubDate>Wed, 18 Mar 2026 21:55:09 +0000</pubDate>
      <link>https://dev.to/tanso/we-built-an-mcp-server-so-ai-coding-tools-can-set-up-your-entire-billing-system-3npd</link>
      <guid>https://dev.to/tanso/we-built-an-mcp-server-so-ai-coding-tools-can-set-up-your-entire-billing-system-3npd</guid>
      <description>&lt;h1&gt;
  
  
  We built an MCP server so AI coding tools can set up your entire billing system
&lt;/h1&gt;

&lt;p&gt;Every AI and API company we've talked to ends up building the same internal system. Redis counters tracking credits. Cron jobs reconciling usage. If-statements scattered across the codebase gating feature access. It starts as a quick hack when you launch your first pricing tier and becomes a permanent headache every time pricing changes.&lt;/p&gt;

&lt;p&gt;Billing platforms like Stripe handle what happens after usage. They meter events, generate invoices, process payments. But nothing in that stack answers the question that matters at runtime: should this request be allowed to run?&lt;/p&gt;

&lt;p&gt;Does this customer have enough credits? Are they within their plan limits? Is this feature included in their subscription? That logic is still on your engineering team.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;That's what we built Tanso for.&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;One API call before the request runs. Subscription state, usage limits, and credit balance checked simultaneously. Allow or deny. If denied, no compute runs. No cost incurred. No surprise invoice.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="c1"&gt;// Check before running compute&lt;/span&gt;
&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;isAllowed&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="nx"&gt;tanso&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;entitlements&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;evaluate&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt;
  &lt;span class="na"&gt;customerReferenceId&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;cust_482&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="na"&gt;featureKey&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;ai-analysis&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="na"&gt;usage&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="na"&gt;usageUnits&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;

&lt;span class="c1"&gt;// Denied? No compute runs. No cost incurred.&lt;/span&gt;
&lt;span class="k"&gt;if &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="o"&gt;!&lt;/span&gt;&lt;span class="nx"&gt;isAllowed&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="nx"&gt;res&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;status&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;403&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;

&lt;span class="c1"&gt;// Safe to run. This request is billable.&lt;/span&gt;
&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;result&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="nx"&gt;openai&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;chat&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;completions&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;create&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt; &lt;span class="p"&gt;...&lt;/span&gt; &lt;span class="p"&gt;});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  The MCP server
&lt;/h2&gt;

&lt;p&gt;We shipped an MCP server with 34 tools so AI coding tools can configure the whole thing. Claude Code, Cursor, VS Code, Windsurf, and ChatGPT can:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Create plans with graduated pricing tiers&lt;/li&gt;
&lt;li&gt;Link features with usage limits and cost models&lt;/li&gt;
&lt;li&gt;Onboard customers and create subscriptions&lt;/li&gt;
&lt;li&gt;Check entitlements and ingest usage events&lt;/li&gt;
&lt;li&gt;Set up model-aware cost tracking for LLM spend&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;No dashboard clicking required. Point your coding agent at the MCP and describe what you want.&lt;/p&gt;

&lt;p&gt;MCP config:&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;"tanso"&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;"url"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"https://api.tansohq.com/mcp"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
      &lt;/span&gt;&lt;span class="nl"&gt;"headers"&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;"X-API-Key"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"sk_live_your_api_key_here"&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;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;We also have AI-native docs so coding agents can read the full API in context: &lt;a href="https://tansohq.com/llms-mcp.txt" rel="noopener noreferrer"&gt;https://tansohq.com/llms-mcp.txt&lt;/a&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  How it fits with Stripe
&lt;/h2&gt;

&lt;p&gt;Tanso plugs into your existing Stripe setup. You define plans and features in Tanso. Invoices push to Stripe. Payment status flows back automatically. Your payment processor still handles transactions. Tanso controls the pricing logic in your product.&lt;/p&gt;

&lt;h2&gt;
  
  
  What we're seeing
&lt;/h2&gt;

&lt;p&gt;Every team we talk to has some version of this held together with internal tools. The pattern is always the same:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Ship a simple pricing tier&lt;/li&gt;
&lt;li&gt;Hardcode some limits&lt;/li&gt;
&lt;li&gt;Pricing changes, nothing updates&lt;/li&gt;
&lt;li&gt;Customers exceed limits, nobody notices until the invoice&lt;/li&gt;
&lt;li&gt;Spend weeks rebuilding&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;If that sounds familiar, we'd love to hear what you ended up building. What broke first?&lt;/p&gt;

&lt;p&gt;Self-serve is live with a free tier at &lt;a href="https://tansohq.com?utm_source=devto&amp;amp;utm_medium=blog&amp;amp;utm_campaign=mcp-launch" rel="noopener noreferrer"&gt;tansohq.com&lt;/a&gt;.&lt;/p&gt;

</description>
      <category>ai</category>
      <category>mcp</category>
      <category>saas</category>
      <category>showdev</category>
    </item>
  </channel>
</rss>
