Introduction
Building GraphQL APIs shouldn't be complicated. Baeta helps developers focus on what matters most - creating powerful, scalable APIs without the boilerplate.
What is Baeta?
Baeta is a modern, modular, open-source GraphQL framework designed with flexibility in mind. It follows a granular approach where you only add what you need. Starting with a powerful core for building GraphQL APIs, you can progressively add features through official extensions based on your requirements
Key Features
- Modular Architecture: Organize your API into manageable modules
- Schema-First Development: Define your API contract upfront
- Type Safety: Automatic code generation for type-safe development
- Middleware & Directives: Easy integration of custom behaviors
- High Performance: Built for scalability and efficiency
And optional extensions and plugins
- @baeta/extension-auth: Add powerful scope-based authorization
- @baeta/extension-cache: Implement automatic caching with simple update patterns
- ... and more!
Why use Baeta?
Baeta makes it easy to build better GraphQL APIs while staying flexible. Here's how:
Granular and Progressive: Start small and add features as you need them. Whether you're building a simple API or a complex system, Baeta scales with your needs.
Modular architecture: Baeta's modular design allows you to organize your GraphQL API into smaller, more manageable modules that can be added or removed as needed. This makes it easier to maintain and scale your API over time.
Schema-first approach: With Baeta, you define your schema first, and then logic and resolvers. This approach ensures a consistent and well-defined API for your clients and reduces boilerplate code.
How it Works
1. Define your schema
type User {
id: ID!
name: String!
email: String!
age: Int
}
input UserWhereUnique {
id: ID
email: String
}
type Query {
user(where: UserWhereUnique!): User!
users: [User!]!
}
2. Implement your resolvers
import { getUserModule } from "./typedef";
const { Query } = getUserModule();
Query.user(({ args }) => {
return dataSource.user.find(args.where);
});
Query.users(() => {
return dataSource.user.findMany();
});
3. Add authorization
const { Query, Mutation } = getUserModule();
Query.users.$auth({
$or: {
isPublic: true,
isLoggedIn: true,
},
});
4. Add caching
import { getUserModule } from "./typedef";
const { User, Query } = getUserModule();
export const userCache = User.$createCache();
Query.user.$useCache(userCache);
Query.users.$useCache(userCache);
Compatibility
Baeta is compatible with all GraphQL servers, which makes it easy to integrate with your existing stack. It works seamlessly with popular GraphQL server libraries such as Graphql Yoga and Apollo Server, as well as other popular tools like Prisma, Drizzle and Kysely.
Baeta's development tools are built for Node.js, but the runtime code is environment-agnostic. This means your Baeta applications can run anywhere JavaScript runs, including:
- Deno
- Cloudflare Workers
- AWS Lambda
- Vercel Edge Functions
- Bun
- Node.js
- Any other JavaScript runtime
Ready to get started?
Head over to the the next page to learn more and to get started!