> [!info] read more > [wasp-lang/wasp: The fastest way to develop full-stack web apps with React & Node.js. (github.com)](https://github.com/wasp-lang/wasp/tree/main) Wasp (**W**eb **A**pplication **Sp**ecification) is a Rails-like framework for React, Node.js and Prisma. Build your app in a day and deploy it with a single CLI command! ## [Why is Wasp awesome](https://github.com/wasp-lang/wasp#why-is-wasp-awesome) - 🚀 **Quick start**: Due to its expressiveness, you can create and deploy a production-ready web app from scratch with very few lines of concise, consistent, declarative code. - 😌 **No boilerplate**: By abstracting away complex full-stack features, there is less boilerplate code. That means less code to maintain and understand! It also means easier upgrades. - 🔓 **No lock-in**: You can deploy Wasp app anywhere you like. There is no lock-in into specific providers, you have full control over the code (and can actually check it out in .wasp/ dir if you are interested ). ```ts // file: main.wasp app todoApp { title: "ToDo App", // visible in the browser tab wasp: { version: "^0.11.0" }, auth: { // full-stack auth out-of-the-box userEntity: User, methods: { email: {...} } } } route RootRoute { path: "/", to: MainPage } page MainPage { authRequired: true, // Limit access to logged in users. component: import Main from "@client/Main.tsx" // Your React code. } query getTasks { fn: import { getTasks } from "@server/tasks.js", // Your Node.js code. entities: [Task] // Automatic cache invalidation. } entity Task {=psl // Your Prisma data model. id Int @id @default(autoincrement()) description String isDone Boolean @default(false) psl=} ```