Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aexol-studio/axolotl
Type-safe GraphQL Schema-first Framework around popular GraphQL servers
https://github.com/aexol-studio/axolotl
graphql server
Last synced: about 1 month ago
JSON representation
Type-safe GraphQL Schema-first Framework around popular GraphQL servers
- Host: GitHub
- URL: https://github.com/aexol-studio/axolotl
- Owner: aexol-studio
- License: mit
- Created: 2023-10-10T15:24:48.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-09-11T14:46:04.000Z (4 months ago)
- Last Synced: 2024-09-11T22:47:48.670Z (4 months ago)
- Topics: graphql, server
- Language: TypeScript
- Homepage: https://axolotl-docs.vercel.app
- Size: 2.6 MB
- Stars: 27
- Watchers: 2
- Forks: 0
- Open Issues: 9
-
Metadata Files:
- Readme: Readme.md
- License: LICENSE
Awesome Lists containing this project
README
### ![Vector 902 (Stroke) (1)](/docs/public/axolotl-stroke.png)
From the [GraphQL Editor](https://graphqleditor.com/) and [Aexol Studio](http://aexol.com/) teams, comes a Framework ensuring **GraphQL** Resolvers and arguments **type-safety**. Written in TypeScript.
> [!TIP]
> Check our *full documentation* and the *Discord channel*:\
> [Full documentation](https://axolotl-docs.vercel.app)\
> [Discord channel](https://discord.gg/f8SfgGBHRz)
## 😮 Features
Axolotl is a framework overlord/wrapper thats lets you forget about type-casting and looking into schemas. When there is no drama, only efficiency remains.
- ⚙️ Generates models at runtime during development - which ensures type safety
- 🏃 Enables seamless migration between different GraphQL Servers like GraphQL Yoga and Apollo Server
- 🤓 Lets you write your own adapters for various purposes
- 🐙 Supports micro-federation! It allows to merge different schemas and resolvers inside one repository.
- 🦕 Supports Deno from version 0.2.7. It works with Deno in production.
- 😂 Is very easy to setup, start and integrate. You just need to `npx @aexol/axololtl create-yoga`
- 🦎 includes modularium, a package with installable GraphQL schemas with backend
## 🤔 The Origin Story
Writing GraphQL for backend developers remains a complicated process when you want to take the schema-first approach instead of going code-first. I was in the type-safety rabbit hole while building [GraphQL Zeus](https://github.com/graphql-editor/graphql-zeus) (a GraphQL client with almost 1 million downloads). Maintaining Zeus and developing with the constantly-changing TypeScript proved to be really hard. \
Over the years, I have come to understand that there was even more to it: we needed an **evolutionary** framework. I decided to write something simpler. Something that the community needed that integrated everything using the same knowledge. Something, ultimately, much more powerful.This is how Axolotl was born.
## 😇 How It Works
Axolotl provides type-safety and lets you choose the adapter (or write your own). It allows you to develop your GraphQL project quickly and efficiently. How it runs it also depends on the underlying framework you choose.
## Repository
|Element|Description|
|:---|:---|
| Adapters | To develop adapters for popular nodejs frameworks |
| Examples | To experiment with axolotl and its packages |
| Modularium | Installable code chunks for your project |
|
Micro-federation | To use the micro-federation feature in axolotl
- Micro-federation means that all the modules are located within one project or one monorepo **or** are distributed as npm packages
- The axolotl projects are merged to the supergraph later|
## Development
>[!IMPORTANT]
>To start developing you need to know a few things.
This is an npm workspaces monorepo.
There is a sequential build order for commands as seen below:
```sh
npm run build --ws --if-present
```
To run an example execute you need to type in:
```sh
npm run start -w beerpub
```