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

推荐订阅源

雷峰网
雷峰网
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%
A backend where you never need migrations or auth code
WolfOliver · 2026-06-17 · via Hacker News: Show HN

How building a writing app led to building a Firebase alternative with a different idea about authorization

The goal: a backend you never have to change

No code changes when you add a feature. No database migrations when your data model evolves. No authorization rules deployed to the server. If you can build a backend like that, you have something genuinely new.

The tool I built to get there is called LinkedRecords — an open-source (MIT), generic backend-as-a-service for single-page applications, in the same space as Firebase or Convex, but self-hostable. The core difference is the authorization model: instead of writing permission rules in backend code, you assert them as facts — the same triple-store mechanism you use to query data. Your schema, your relationships, your access control: all stored as data the backend already knows how to enforce.

Here's how I got there.

2017: An itch that wouldn't go away

I was writing large architecture documents at work, using Google Docs for it. It worked — until the documents got big. Then it slowed to a crawl. And for technical writing, it was constantly in your way: no citation management, no table captions, no cross-references, formatting that fought you every time you inserted an image.

But what actually kept me awake at night wasn't the missing features. It was the real-time collaboration. Multiple cursors. Instant sync. No conflicts. You could see exactly who was writing where. How did they build that?

I'd actually tried to tackle something similar back in 2007 — a CMS usingcontenteditable— and failed. But now I had a clearer question: if I skip the page layout entirely (the part that makes Google Docs complex), and just let the browser handle rendering, how hard would it actually be to build the collaboration part?

Operational Transformation and a dangerous question

The algorithm behind Google Docs is called Operational Transformation (OT). In 2017 it was hard to find good documentation about it — one guy who'd worked on Google Wave had written it up, and that was basically it.

OT has two halves: a frontend part and a backend part. The backend part is opinionated — it needs to store data, manage change history, and broadcast updates. And that got me thinking: what if I built the most generic version of this backend I possibly could? Something reusable across any app I'd ever want to build?

I care a lot about zero-cost abstractions — the idea that you can generalize something without adding layers or overhead, sometimes just by renaming it to something more universal. That principle became the guiding constraint.

2018: LinkedRecords v1 — almost useful

The first version was a key-value store with streaming changes. You create an "attribute" — a piece of data, which could be long text, JSON, or a file — get back an ID, and subscribe to changes from any browser. The API looked like this:

const doc = await lr.Attribute.createLongText('initial content');

doc.id // → store this, retrieve the document later

doc.set('new content');
doc.change(/* a delta — e.g. "insert D at position 5374" */);

doc.subscribe((delta) => {
  // remote update arrived — apply to editor
})

It worked for collaboration. But it was missing two things that made it useless for building real apps: no authentication/authorization, and no query language. You could only access data if you already knew its ID. Not practical.

So I made a pragmatic call: go build the editor first. Come back and fix LinkedRecords later.

2018–2023: Five years building the editor

MonsterWriter is the app I wished had existed — Microsoft Word rebuilt for students and researchers: citations, LaTeX export, cross-references, distraction-free writing, no page layout getting in your way.

Turns out contenteditable is a nightmare. Different browsers produce different HTML from the same input. Syncing remote changes means you have to save and restore the cursor position before applying each delta, or the user's cursor just vanishes. One content editable field per section (rather than one giant one) helps with performance. None of this is obvious until you're deep in it.

The GitHub history shows a long quiet stretch from 2017 through 2022. MonsterWriter is a real product now — people pay for it, students write their theses with it. But all along it was running on a backend I kept having to touch, which violated the whole original point.

The real differentiator isn't collaboration

When I came back to LinkedRecords, I had to be honest about something: the collaboration feature wasn't the main value anymore. CRDTs (conflict-free replicated data types) have become the go-to for this now — nobody would pick OT as their first choice today. The technology moved on.

What makes LinkedRecords different from Firebase, Supabase, or Pocketbase isn't real-time sync. It's the authorization system — and the fact that it's expressed as data, not code.

RDF: the forgotten web standard that still has good ideas

For the query language and authorization model, I remembered something from a university course on Semantic Interoperability: the Resource Description Framework (RDF). A triple store — every fact in the database is three things: subject, predicate, object. It was briefly called "Web 3.0" in academia before the crypto crowd adopted that term.

Nobody uses RDF in web development. But the model is clean. I didn't want to use the full SPARQL stack — that felt like overkill. What I needed was a Postgres table with three columns and some pattern matching. I called my implementation "Facts" instead of triples.

You describe what an attribute is — and who can access it — by attaching facts to it:

// Create a document and classify it
await lr.Attribute.createLongText('task content', [
  ['$it', 'isA', 'Todo']
]);

// Query all todos
const todos = lr.Attribute.find([
  ['$it', 'isA', 'Todo']
]);

// Transitive query: finds Biographies, Autobiographies, etc.
const allBooks = lr.Attribute.find([
  ['$it', 'isA*', 'Book']
]);

// Compound query in one request
const { books, bios } = await lr.Attribute.findAll({
  books: [['$it', 'isA*', 'Book'], ['$it', 'is', '$not(deleted)']],
  bios:  [['$it', 'isA*', 'Biography'], ['$it', 'is', '$not(deleted)']],
});

Authorization works through the same facts. Instead of writing permission rules in backend code, you assert them as data. LinkedRecords defines a small set of built-in permission predicates —$isAccountableFor,$isHostOf,$isMemberOf,$canRead, and a few others — and enforces them at the database level. You can model organizations, teams, roles, and sharing patterns purely through facts, with no custom backend code.

Think of it like giving users a very constrained SQL client. Within the rules the system enforces, they can query and modify data. If someone misuses their permissions, they can only harm their own data.

Bring Your Own Backend

The longer-term vision is something I call Bring Your Own Backend.

Most SaaS sits somewhere between two extremes: PaaS (you manage your app and data, they manage the infrastructure) and SaaS (they manage everything, including your data). The gap in between — "I love the app, but I don't trust them with your data" — has no good answer today.

MonsterWriter is a single-page application. The frontend is served frommonsterwriter.com — always the latest version. The plan is to let users point it at their own LinkedRecords instance. You pick who runs your backend. Your data never has to leave your own infrastructure. You still get app updates automatically. The backend only needs security patches — otherwise it stays stable.

This isn't live in MonsterWriter yet, but it's where this is heading.

If this sounds familiar, it's because it rhymes with something the local-first community has been working toward. Local-first software — popularized by the Ink & Switch essay and the rise of CRDTs — puts your data on your own device, making the cloud optional rather than mandatory. The philosophy is the same: you should own your data, and the app you use to access it should be a separate concern from where that data lives.

LinkedRecords doesn't go quite as far as local-first — your data lives on a server, not your device. But it occupies the same ideological territory: the app layer and the data layer are decoupled, and you control the latter. Think of it as local-first's pragmatic cousin — cloud-hosted, but on a cloud you choose and trust.

This feels increasingly important. Cloud sovereignty has moved from a niche compliance concern to a mainstream political one. European companies are rethinking their dependency on US-based SaaS providers. Governments are scrutinizing where citizen data lives. The US CLOUD Act means data held by American companies is reachable by American courts, regardless of which country's servers it sits on. Against that backdrop, "you love the app but you don't trust them with your data" isn't a theoretical user story anymore — it's an enterprise requirement, and increasingly a personal one too.

The architecture LinkedRecords enables — a stable, self-hostable backend that any SPA can point at — is a small but concrete step toward a web where switching who holds your data is as easy as changing a URL.

Where things stand

MonsterWriter is a real product with paying users. LinkedRecords is the backend running behind it — and until recently, nobody knew it existed. The GitHub repository was published just recently. The documentation went up the day before the first public talk about it.

It's been 8 years of evenings and weekends. The commit history starts January 2017, goes quiet for 5 years while the editor got built, and has been steadily active again since 2022. The core idea — a generic, zero-migration, schema-free backend where authorization is data — has stayed the same throughout.

If you're building a single-page application and you keep running into the same backend boilerplate — schema migrations, hardcoded auth rules, user management — LinkedRecords might be worth a look.

The vision: a collaboration platform where you own the cloud

MonsterWriter started as a tool for students writing theses. But the underlying architecture points somewhere much bigger.

Think about what Notion did: it took the idea of a document editor and stretched it into a general-purpose collaboration workspace — pages, databases, wikis, project tracking, all in one place, all multiplayer. It's genuinely useful. Millions of teams run on it. But there's a catch that almost nobody thinks about until it matters: every document, every database row, every comment your team has ever written lives on Notion's servers, under Notion's terms, governed by Notion's jurisdiction.

The vision for MonsterWriter and LinkedRecords is to build toward that same kind of collaborative workspace — documents, structured data, real-time multiplayer, rich content — but with a fundamentally different answer to the question of who holds the data.

The answer LinkedRecords gives is: whoever you decide. Your company runs its own LinkedRecords instance. Your team's data stays in your data center, your cloud region, your jurisdiction. The application — the UI, the features, the product improvements — is delivered as a SPA from a server you don't have to trust. The two concerns are cleanly separated. You get the product without the lock-in.

Collaborating with someone from a different organization doesn't mean merging your data into a shared vendor's silo. It means two LinkedRecords instances exchanging facts with each other, while each organization retains full control of its own data. Like email — nobody thinks it's strange that Gmail and Outlook can send messages to each other, even though they're run by competitors. Collaboration apps could work the same way.

We're not there yet. The federation layer doesn't exist. MonsterWriter today is a writing tool, not a Notion replacement. But the data model, the authorization primitives, and the bring-your-own-backend architecture are being built with this in mind from the start — because retrofitting data sovereignty onto a platform that was never designed for it is much harder than building it in from day one.

It's an ambitious target for a solo side project. But sometimes the right architecture is obvious before the product is ready for it.