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

推荐订阅源

N
News and Events Feed by Topic
Malwarebytes
Malwarebytes
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
C
Cybersecurity and Infrastructure Security Agency CISA
F
Future of Privacy Forum
C
Cisco Blogs
T
The Exploit Database - CXSecurity.com
A
Arctic Wolf
S
Securelist
K
Kaspersky official blog
S
Schneier on Security
T
ThreatConnect
T
Tenable Blog
Spread Privacy
Spread Privacy
T
True Tiger Recordings
AWS News Blog
AWS News Blog
F
Fox-IT International blog
量子位
T
Threatpost
V
Vulnerabilities – Threatpost
C
CERT Recently Published Vulnerability Notes
Cisco Talos Blog
Cisco Talos Blog
GbyAI
GbyAI
宝玉的分享
宝玉的分享
腾讯CDC
G
Google Developers Blog
aimingoo的专栏
aimingoo的专栏
Cyberwarzone
Cyberwarzone
有赞技术团队
有赞技术团队
S
SegmentFault 最新的问题
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
V
Visual Studio Blog
U
Unit 42
雷峰网
雷峰网
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Simon Willison's Weblog
Simon Willison's Weblog
O
OpenAI News
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
The GitHub Blog
The GitHub Blog
The Register - Security
The Register - Security
MyScale Blog
MyScale Blog
小众软件
小众软件
A
About on SuperTechFans
Last Week in AI
Last Week in AI
Y
Y Combinator Blog
博客园 - 三生石上(FineUI控件)
美团技术团队
Google Online Security Blog
Google Online Security Blog
P
Proofpoint News Feed
MongoDB | Blog
MongoDB | Blog

DEV Community

Gemma 4: The 128K Multimodal Powerhouse in Your Terminal How to Consolidate Your QA Toolstack: A Practical Buyer's Guide The Thank-You Email Almost Nobody Sends (And Why That's Your Edge) Schema Types 2026 Idempotency Keys: The API Safety Net You're Probably Not Using Kiro Did It: Build a Simple Portfolio Website with Kiro IDE | From Prompt to HTML Prototype Islands of Commerce: What Marketplace Founders Can Learn from 60 Years of Island Biogeography React Pointer Hooks: Hover, Long-Press, Double-Click, Scratch, and Click-Outside Without the Bugs Engineering decisions for my video call tool VBScript Still Lives: How a Custom Go VM Brought Classic ASP to Linux and Mac What Happens When You Teach Old Scripting Languages New Runtime Tricks? I Tested 6 AI Coding Assistants for a Month. Here's What Actually Works. Extendscript Still Has Life Afriex Webhook Integration Guide: Signature Verification, Event Handling, and Production Best Practices The Blind Alleys of Veltrix Configuration How an ESP32 Turned a LEGO WALL-E Into a Real Working Robot The Flawed Promise of Real-Time Event Handling SSH Login Taking Forever? Check Your DNS Settings Found 897 Fake Followers on DEV.to. Here's How I Proved It. Retry logic, Kafka consumer lag, and the hidden failure pattern that Kubernetes won’t catch WebMCP Might Be the Most Important Announcement at Google I/O 2026 Build a Secure API with Rails 8 - Part-3: Auth Controllers I A/B tested 4 LLMs on the same 500 queries. The results surprised me. Google I/O 2026’s Smartest Developer Release Wasn’t a Model, It Was the Runtime - Managed Agents in Gemini API OSS Monthly Recap: What My Daily Commit Challenge Taught Me About Open Source “Culture” GemmaNotes Cognitive Debt: AI Is Building Your Systems. Do You Actually Understand Them? GeekNews Frontend Weekly Deep Dive - 2026-05-25 I Built a Universal Silicon Loader That Runs on Any SOC (No Bootrom Exploit) Docker容器化部署Node.js应用最佳实践 I Put a Neural Network in a Thermometer — Then It Got Out of Hand Building MGZon: Developer Portfolio + AI Bot + Social Network (9 min demo) Bearing Life (L10): What the Catalog Number Really Tells You Longhorn Volume Health: The Gap Between 'Healthy' and Actually Working Stop Prompting. Start Specifying: How Spec-Driven Development Fixes AI Coding TIL a PowerPoint file is just a zip — so I converted .pptx to Word entirely in the browser 로컬 LLM 셋업 가이드 (v18) Cx Dev Log — 2026-04-24 github's agent audit api is the boring feature that matters # From Teaching Code to Building Real-World Applications Vivado 2026.1 and Linux: why this decision matters beyond the headline Vivado 2026.1 y Linux: por qué la decisión importa más allá del titular ORA-00206 오류 원인과 해결 방법 완벽 가이드 Entidades finas e composição: o design que escolhi para a nova plataforma 10 Open Source Tools Every Developer Should Know 🔥 SSH Config File Mastery: Turning `~/.ssh/config` Into a Productivity Tool I tried to create a programming language... in python I Replaced 70MB Node.js Log Viewer with a 172KB Zig Binary I Turned npm outdated into a CI Gate — Here's How Don't fall for the Claude Mythos hype Vestige: A Gemma 4 Brain Tracker That Won't Blow Smoke Up Your Ass Gemminate: Transforming Static Textbooks into Interactive Learning Journeys with Gemma 4 Where Did All the Code Playgrounds Go? I built PROOFER - Privacy first Chrome extension that proofreads your texts using Gemma 4 I Automated My Entire Digital Product Business on a $13/Month GCP VM. Here's the Architecture. Beginner's Mind in Engineering and AI How I use AI agents to turn ideas into public demos I Built a Quotation Generator for Kenyan Street Welders Using Gemma 4's Vision The Math Behind Neural Networks — Explained Like Nobody Did for Me 🧨 Understanding TPC with IEEE802.11h What I’m Starting to Look for in Engineers An npm Downloads Comparison Chart in 300 Lines of Vanilla JS — Nice-Tick Math and API-Direct Fetch Vitreus: Local-First Spreadsheet Intelligence with Gemma 4 Transfer Fees, Metadata, and Soulbound Tokens: A Tour of Solana Token Extensions I got tired of re-explaining my codebase to ChatGPT — so I built a VS Code extension Revisiting My Phone AI After Gemma 4: The Upgrade I Didn't Know I Needed I built a privacy-first PDF merger in 7 hours — here's the stack and the lessons Google I/O 2026 made me ask an uncomfortable question: are we still coding, or are we managing builders? SSR with JavaScript: Escaping Node.js Clunkiness with AxonASP My CKA Exam-Day Experience: What Went Right, What Went Wrong, and Lessons Learned Gemma 4 Soft Tokens: The Rise and Fall of 16x16 Words ⚡👀 Two weeks ago, I built a private AI brain on my phone using Gemma 4. Yesterday, Google dropped a new variant that made everything I built feel like a beta test. 256M parameters. MoE architecture. Apache 2.0 license. I broke down what changed and why it mat I got tired of clicking through the Stripe dashboard, so I built a CLI Getting Data from Multiple Sources in Power BI: A Practical Guide to Modern Data Integration Google Is No Longer Just a Search Engine I built GemmaPod - A truly composable and portable AI agent solution powered by your local LLM Gemma 4 E4B caught three planted fabrications in 50 seconds — on a laptop, no cloud How to build an AI-powered content moderation pipeline for user comments Running Gemma 4 on a Modest Machine: Unsloth vs LM Studio vs llama.cpp vs Ollama AI Makes Building Cheap. Our Product Architectures Still Assume It’s Expensive. I built an in-browser Roku TV remote with ~80 lines of TypeScript. Here's how Roku's ECP API actually works The Direction of Blame babbled notes: a sound-to-music agent for people who could not make music before How I Built a Live SQL Workshop Where Students Can't Break Anything Rescuing a Stranded Protocol: Re-Skinning Legacy Code for the Trestle DeFi Flywheel SOLID Heuristics Reveal Incomplete Domain Knowledge — Nothing More AllasCode Intitute / FullAgenticStack: The Intent-Based Router Introducing LogicGrid — Multi-Agent AI Orchestration for .NET AI Prompt Injection, Drupal SQLi Exploitation, and Nmap for Hardening AI Agents & Python Workflows: Anthropic Skills, Jupyter Challenges, and Edge Deployment SQLite Optimization, PostgreSQL Async Queries, & DuckLake Dataframe Spec RTX 5080 Undervolt Benchmarks, CGO-Free CUDA API Binding, & AMD GPU Compatibility Fix Microsoft Burned Its 2026 AI Budget on Claude Code in Six Months. That's the Real Story. Why I Started Learning FastAPI in 2026 I Abandoned Ghost for Months — Then Came Back and Finally Finished It Building an Open MIT-Licensed Ephemeris Engine in C — JPL Moshier Ephemeris 4 Smart Ways to Manage Retries in Side Projects Securing Web APIs: A Practical Guide to Authentication & Authorization Methods Google I/O 2026: AI Built an OS in 12 Hours. I Spent Mine Sorting Screenshots. 🤦 Half a Day, Not a Week: One Nix Flake for Three Machines
How to let Claude see my Plaid bank data
FinContext · 2026-05-25 · via DEV Community

Claude remembers your projects, your writing style, the context you've shared across conversations. It does not know what you spent last quarter. So when you ask it for budgeting advice, the answer comes back as a generic checklist: "track your spending, make a budget, automate your savings." Useful for a 22-year-old. Less useful when the question you actually have is "did I overspend on travel last quarter?"

The fix is not better prompting. It is to give Claude real access to your real bank data, so the answer comes back with numbers from your accounts. This post walks through the setup end-to-end: the protocol that makes it possible (MCP), the bank connection (Plaid), and the FinContext server that bridges the two. Setup is about ten minutes. (Prefer ChatGPT, Cursor, Cline, or Zed? The same server works there too — more on that below.)

What MCP changes

The Model Context Protocol (MCP) is a standard for letting AI clients — Claude Desktop, ChatGPT with custom connectors, Cursor, Cline, Zed — read data from external tools through a uniform interface. Before MCP, every "AI plus your data" integration was bespoke: a ChatGPT plugin here, a Claude tool there, a different config for every editor. MCP collapses that surface area: one server speaks the protocol, and every MCP-compatible client can use it.

For personal finance, the practical effect is that one MCP server can serve your bank context to whatever AI you actually use. You are not locked into a vendor. You are not maintaining six integrations.

What FinContext does

FinContext is an MCP server for personal finance. It exposes ten tools that let an AI client read and lightly organize your bank context:

  • status — account and onboarding state
  • link_bank — Plaid Link URL to connect a new account
  • balances — accounts and current balances
  • transactions — search and list transactions
  • categories — taxonomy and usage stats
  • sync — pull the latest from Plaid's cache
  • update — relabel a merchant or category
  • stat — read-only SQL surface for arbitrary analytics
  • feedback — send a note to the FinContext team
  • help — describe any tool in detail

Six of those are read-only (status, balances, transactions, categories, stat, help). Four are writes that don't touch your bank (link_bank, sync, update, feedback — local relabeling and sync triggers). None move money. None have a code path that could move money. We come back to that.

What about ChatGPT's built-in finance?

Some assistants have started shipping built-in finance features — ChatGPT among them. Claude hasn't. So if Claude is your main assistant, FinContext is how you give it your real numbers today.

And because FinContext speaks MCP, it isn't tied to one assistant. You link your accounts once and the same connection works in Claude, ChatGPT, Cursor, Cline, and Zed — your bank context follows you to whatever AI you're using that day, instead of being rebuilt (or locked) inside each app. A built-in feature reads from whatever the platform has wired up; FinContext reads your bank — any of 10,000+ US institutions through Plaid.

It's also standalone at $4.99/month: it doesn't depend on which AI subscription you happen to be paying for, and it's read-only by architecture with delete-anytime control. The bet is simple — your bank data should be something you bring to any AI, not a feature you rent inside one.

Setup, three steps

The flow below uses Claude (Desktop or claude.ai). ChatGPT, Cursor, Cline, and Zed use the same custom-connector pattern; on Claude Code (the CLI) it's a one-line claude mcp add command. See the developers page for per-client instructions.

Step 1 — Sign up at fincontext.ai

Create an account. The free trial is full access with no credit card; pricing is on the homepage.

Step 2 — Connect a bank through Plaid

In your FinContext dashboard, click "Link a bank." Plaid's hosted flow opens — same flow you have probably used before for Venmo, Robinhood, or Chime. Choose your bank, log in, pick which accounts to share. FinContext never sees your bank credentials; Plaid handles authentication and returns a scoped, read-only access token, which we encrypt and store.

Step 3 — Add FinContext to Claude as a custom connector

In Claude (Desktop or claude.ai), open Settings → Connectors → Add custom connector. Enter:

https://fincontext.ai/mcp

Enter fullscreen mode Exit fullscreen mode

Claude redirects to FinContext to log in and grant access. There is no API token to paste — the OAuth flow handles authentication. After approval, Claude shows the connector as active. (Using Claude Code, the CLI? It's a one-line claude mcp add with your API token — see the developers page.)

That is the whole setup.

Try these prompts

The tools are documented; the prompts are how you actually use them. These five are the canonical prompts from our own testing — the questions we built the product to answer.

1. Monthly spending review. "How am I doing this month?" Claude calls stat for current-month spending by category, then stat for the 3-month historical average, then balances for the current snapshot. The answer comes back something like: month-to-date $1,019 across six categories, with rent not yet posted, and 3-month averages for comparison.

2. Subscription audit. "Am I wasting money on subscriptions?" Claude queries stat for recurring merchants — defined as ≥3 charges in 12 months with low amount variance — then sorts the result into SaaS subscriptions vs. fixed life costs (rent is recurring; rent is not Netflix). On our test account, this surfaces three or four real SaaS subscriptions and confirms nothing has been quietly auto-renewing into the void.

3. Affordability check. "Can I afford a $2,000 vacation next month?" balances for liquid totals, stat for 6-month average income and spending, then arithmetic: surplus per month, runway covered, whether the trip eats into savings. The answer is a number with a one-paragraph rationale, not a hedge.

4. Spending diagnosis. "Why does it feel like I'm spending more?" This one is interesting because the answer is often "you're not." stat compares current month by category against the 3-month baseline; if a category is over baseline, Claude pulls top merchants in that category. Sometimes the diagnosis is one $114 Shell charge. Sometimes it's that rent has not posted yet.

5. Net worth progress. "Am I making progress?" balances for current, stat for the historical balance series. The answer reports the trajectory — and explicitly flags reconstructed history (computed by walking transactions backward) as estimate, not audited snapshot. Real daily snapshots accrue from when you connect.

The bigger point: an AI assistant with FinContext is not a dashboard. You phrase the question in your own terms — your definition of "this month," your sense of "subscriptions" — and the AI translates that into the right tool calls.

What FinContext can read, what it cannot

The trust question deserves a direct answer.

Can read: account names and types, current balances, transaction history (merchant, amount, date, Plaid category), and any merchant or category overrides you have set in FinContext.

Cannot read: your bank password (Plaid handles authentication; we never see it), your conversations with Claude or ChatGPT, anything outside transactions and balances, or anything from a bank you have not explicitly connected.

Cannot do, by architecture, not policy: move money, place trades, initiate transfers, or take any action against your bank. There is no code path in the FinContext server that does any of those things. The Plaid scope we request is read-only; even if the server were compromised, the attacker has no privileged action available to them.

Storage: Plaid access tokens are encrypted at rest with Fernet (authenticated AES-128-CBC plus HMAC-SHA256); the key is stored in Google Cloud Secret Manager and injected at runtime — never in the database or the codebase. Everything travels TLS 1.3. Each user's data is isolated by Postgres row-level security — not by application-level filters that can have bugs. You can disconnect a bank, delete the account, or set a 30-day retention window at any time.

US-only today.

Limitations worth flagging

Honest about the rough edges:

  • Sync latency. FinContext pulls from Plaid's cache. Transactions posted in the last hour or two may not show up until the next sync cycle. Run the sync tool to force-pull from cache; it does not force the bank to re-poll.
  • Reconstructed history. Daily balance history before your account-link date is reconstructed from transaction flow, not pulled from the bank. Treat older points as estimates.
  • AI hallucination. The data is real, but the AI can still misread or oversimplify it. For decisions that matter, confirm by asking Claude to show its work — it can repeat the underlying numbers from the tool calls.

Where to go next

If this worked for you, the same MCP endpoint works in ChatGPT, Cursor, Cline, and Zed too — same setup pattern, different add-connector flow. Link once, use your bank context anywhere. The developers page has per-client instructions.

If you want to dig into the architecture before connecting a bank, the security page documents the threat model and the data inventory.

Try it: fincontext.ai.