Show HN: Plain – The full-stack Python framework designed for humans and agents
TL;DR Highlight
A Python web framework forked from Django, redesigned with type hints, a single convention, and an agent-friendly structure, making it easier for LLMs to read and modify code.
Who Should Read
Python web developers attempting vibe-coding or AI agent-based development using LLMs (Claude, Codex, etc.). Especially developers frustrated with Django's complex legacy.
Core Mechanics
- Plain is a fork of Django refined over years of actual operation, maintaining Django's core structure while organizing unnecessary complexity and rough edges discovered in the field.
- The biggest feature is its Postgres-exclusive model design, explicitly declared using type annotations like `email: str = types.EmailField()`, allowing you to grasp the structure with a single read of the code.
- Based on the philosophy that 'code that is good for humans is also good for AI,' it adopts an explicit, typed, and predictable code style to reduce the probability of errors when LLMs infer code.
- Getting started is agent-friendly. You can entrust project setup to a Claude agent with the command `claude "$(curl -sSf https://plainframework.com/start.md)"` or run it directly with `uvx plain-start my-app`.
- Full-stack packages such as plain-admin, plain-auth, plain-jobs, plain-oauth, and plain-tailwind are provided together in a monorepo structure, allowing agents to attach functionality in a predetermined manner without choices.
- Detailed READMEs and examples are included within each module, designed to allow agents to obtain context from within the codebase without searching external documents.
- It adopts a simpler View structure instead of Django's Class-based View, eliminating the need for agents to trace inheritance hierarchies and delve into the source code.
- A CLAUDE.md file is included in the repo root to support Claude agents in immediately understanding the project context.
Evidence
- There was criticism that 'creating something new for agents is counterproductive.' The logic was that a new framework not in the LLM's training data would inevitably be worse than Django at using it, but the counterargument was that 'agents read markdown documents and accurately call even unfamiliar CLIs, the important thing is whether the interface is predictable.'
- The opinion that Django's flexibility is actually poison to agents gained traction. 'Django can do the same thing in six ways, but Plain forces only one, reducing the surface area for agents to infer,' was one analysis.
- There was harsh criticism that 'it stole the Django codebase, just changed the name, and added AI marketing,' but users who have been watching Plain for a long time defended it, saying 'it was developed long before vibe-coding became popular, and the design decisions are solid.'
- There was criticism of the Class-based View approach. If it's an agent-friendly framework, using CBV with an indirection layer is counterproductive, as agents have to repeatedly read the base classes.
- There was a comment that the model declaration method (type annotation + field assignment) is similar to strawberry GraphQL, and there was a response that this style is much better in terms of developer UX. 'Minimizing the amount of code to review with rule-based conventions is key to creating sustainable projects in the age of agents.'
How to Apply
- If you plan to start a new project with an AI agent like Claude or Codex, you can entrust the initial setup to the agent with the command `mkdir my-app && cd my-app && claude "$(curl -sSf https://plainframework.com/start.md)"`. The agent will automatically set up the project structure following the instructions in the plain-start script.
- If you want to quickly create a Django-based side project with AI-assisted coding, you can benefit from Plain's single convention structure, allowing the agent to generate code without worrying about 'how to do it' and reducing the amount of code humans need to review.
- If you are considering introducing agents to an existing Django project, you can first apply the same agent context document structure as Plain's modules and the CLAUDE.md pattern to your existing project.
- If your team is creating a new Python web app using Postgres as the DB, you can start with `uvx plain-start my-app` and quickly build a full-stack app by combining built-in packages like plain-admin, plain-auth, and plain-jobs. Having only one choice reduces team code review costs.
Code Example
# Start project with agent
mkdir my-app && cd my-app && claude "$(curl -sSf https://plainframework.com/start.md)"
# Or start directly with uv
uvx plain-start my-app
# Plain's model declaration method (type annotation + field)
# app/users/models.py
from plain import postgres
from plain.postgres import types
from plain.postgres.functions import Now
from plain.passwords.models import PasswordField
@postgres.register_model
class User(postgres.Model):
email: str = types.EmailField()
password: str = PasswordField()
display_name: str = types.CharField(max_length=100)
is_admin: bool = types.BooleanField(default=False)
created_at: datetime = types.DateTimeField(default=Now)Terminology
Related Papers
Show HN: adamsreview – better multi-agent PR reviews for Claude Code
Claude Code에서 최대 7개의 병렬 서브 에이전트가 각각 다른 관점으로 PR을 리뷰하고, 자동 수정까지 해주는 오픈소스 플러그인이다. 기존 /review나 CodeRabbit보다 실제 버그를 더 많이 잡는다고 주장하지만 커뮤니티에서는 복잡도와 실효성에 대한 회의론도 나왔다.
How Fast Does Claude, Acting as a User Space IP Stack, Respond to Pings?
Claude Code에게 IP 패킷을 직접 파싱하고 ICMP echo reply를 구성하도록 시켜서 실제로 ping에 응답하게 만든 실험으로, 'Markdown이 곧 코드이고 LLM이 프로세서'라는 아이디어를 네트워크 스택 수준까지 밀어붙인 재미있는 사례다.
Show HN: Git for AI Agents
AI 코딩 에이전트(Claude Code 등)가 수행한 모든 툴 호출을 자동으로 추적하고, 어떤 프롬프트가 어느 코드 줄을 작성했는지 blame까지 가능한 버전 관리 도구다.
Principles for agent-native CLIs
AI 에이전트가 CLI 도구를 더 잘 사용할 수 있도록 설계하는 원칙들을 정리한 글로, 에이전트가 CLI를 도구로 활용하는 빈도가 높아지면서 이 설계 방식이 실용적으로 중요해지고 있다.
Agent-harness-kit scaffolding for multi-agent workflows (MCP, provider-agnostic)
여러 AI 에이전트가 서로 역할을 나눠 협업할 수 있도록 조율하는 scaffolding 도구로, Vite처럼 설정 없이 빠르게 멀티 에이전트 파이프라인을 구성할 수 있다.
Show HN: Tilde.run – Agent sandbox with a transactional, versioned filesystem
AI 에이전트가 실제 프로덕션 데이터를 건드려도 롤백할 수 있는 격리된 샌드박스 환경을 제공하는 도구로, GitHub/S3/Google Drive를 하나의 버전 관리 파일시스템으로 묶어준다.