A lightweight web backend framework based on bun , implemented using pure ts + bun native.
Thanks to the fast bun native, issac has good performance.
Currently supports.
tip: bun provides first support for ts, which allows issac to get good type hints in js without a .d.ts file.
- routing
- middleware
- built-in logging
- error handling
- basic websocket support (to be improved in the future)
- Complete basic websocket support (✔)
- Path Parameters and Wildcard Routing (✔)
- Complete websocket routing support (in progress)
- Lifecycle support (in progress)
- Type Safe (in progress)
- Route Cache (in progress)
Since issac is based on bun Native implementation, issac can only be used in bun environment.
Use bun's package management tool (Recommended).
bun add issac
Using npm
npm install issac
Create a simple http/ws server with issac:
import { Issac } from 'issac'
const app = new Issac({
ws: {
// Configure the ws scheduler to escalate requests to ws.
// Any request that contains test: issac in the request header will be escalated to ws
scheduler: (req) => req.headers.get('test') === 'issac'
}
})
// Register the ws handler
app.ws({
open(ws) {
console.log('a new websocket!')
},
message(ws, message) {
ws.send(message + 'plus!')
}
})
// Register the http route
app.get('/test', (req, res) => {
// Return a piece of text
res.text('issac!')
})
// listen
app.listen(1145, () => {
console.log('listen on 1145!')
})
issac's API style is very express-like, so developers familiar with express can get started quickly.