Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cham11ng/bun-api-starter
Bun (🍔) ElysiaJS / MongoDB API Starter
https://github.com/cham11ng/bun-api-starter
bun docker elysia elysiajs good-first-issue hacktoberfest mongodb
Last synced: 3 months ago
JSON representation
Bun (🍔) ElysiaJS / MongoDB API Starter
- Host: GitHub
- URL: https://github.com/cham11ng/bun-api-starter
- Owner: cham11ng
- Created: 2024-03-04T06:25:34.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-08-28T18:30:31.000Z (5 months ago)
- Last Synced: 2024-08-29T20:22:25.207Z (5 months ago)
- Topics: bun, docker, elysia, elysiajs, good-first-issue, hacktoberfest, mongodb
- Language: TypeScript
- Homepage:
- Size: 316 KB
- Stars: 19
- Watchers: 1
- Forks: 3
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Security: SECURITY.md
Awesome Lists containing this project
README
# bun-api-starter
[![Bun (🍔) API Starter CI](https://github.com/cham11ng/bun-api-starter/actions/workflows/ci.yml/badge.svg)](https://github.com/cham11ng/bun-api-starter/actions/workflows/ci.yml)
A robust Bun-based API starter built using ElysiaJS framework, and MongoDB as database. ElysiaJS, a type-safe and fast framework. MongoDB, a powerful NoSQL database. This starter offers a solid foundation for your API development, allowing you to focus on your unique business logic.
## Getting Started
To install bun and starter packages.
```bash
curl -fsSL https://bun.sh/install | bashbun install
```## Development
To start the development server run:
```bash
$ bun run dev
Environment: development
Bun (🍔) API Starter is running at localhost:8000
Info: MongoDB connection successful: starter
```Open with your browser to see the result.
### cURL
```bash
curl --request POST \
--url http://localhost:8000/login \
--header 'Content-Type: application/json' \
--data '{
"email": "[email protected]",
"password": "secret@123"
}'
```### Docker
```bash
# development
$ docker compose up -d dev
[+] Running 2/3
⠋ Network bun-api-starter_default Created 1.0s
✔ Container starter-mongodb Started 0.5s
✔ Container starter-dev Started 0.9s# check logs
$ docker compose logs -f
``````bash
# production
docker build --target production -t bun-api-starter-prod .
docker run -d --rm --env-file .env.docker \
-p 8080:8000 \
-t bun-api-starter-prod:latest
```### MongoDB Compass
```bash
# connect URI for root user.
mongodb://rootuser:root%40123@localhost:27017/starter?authSource=admin
```## Troubleshooting
```bash
# on default export error
const app = new Elysia();
export default app;# double bun server initiated.
$ Bun (🍔) API Starter is running at localhost:8000
Started server http://localhost:3000# do this
export const app = new Elysia();
``````js
// exception not captured onError.
function controller(context: Context) {}// do this
const controller = (context: Context) => {}
```## Happy Coding
> @cham11ng