Skip to content

Latest commit

 

History

History
84 lines (61 loc) · 1.26 KB

README.md

File metadata and controls

84 lines (61 loc) · 1.26 KB

Bun Box

Installation

  1. Install bun & create a new project
❯ mkdir bunbox-example && cd bunbox-example
❯ bun init
# work through prompts
❯ bun install
  1. Install bunbox
❯ bun add bunbox

Usage

My goal with this project is to hideaway as much of the boiler plate import crud as I can, following in the footsteps of frameworks like Rails.

By default, this is the directory structure bunbox expects:

|
|- index.ts
|- controllers/
    |- hello.ts
  1. Create a controller:
// controllers/hello.ts
import { Controller } from "bunbox"
import type { Context } from "bunbox"

class HelloController implements Controller {
    route: string
    method: string

    constructor() {
        this.method = "GET"
        this.route = "/hello"
    }

    run = (c: Context) => c.text("Hello!")
}

export default HelloController

or in vanilla JavaScript:

// controllers/hello.js
class HelloController {
    constructor() {
        this.method = "GET"
        this.route = "/hello"
    }

    run = c => c.text("Hello")
}
  1. Update your index.ts:
import BunBox from "bunbox"
const box = new BunBox()

box.serve()
  1. Run with bun run index.ts:
❯ curl localhost:3000/hello
Hello!