Built and signed on GitHub ActionsBuilt and signed on GitHub Actions
Built and signed on GitHub Actions
latest
oakserver/oakA middleware framework for handling HTTP with Deno, Node.js, Bun and Cloudflare Workers 🐿️🦕🥟⚙️
This package works with Cloudflare Workers, Node.js, Deno, Bundata:image/s3,"s3://crabby-images/83ea7/83ea7c6743cfc0c4bcc040485ad339709c5f7430" alt="This package works with Cloudflare Workers This package works with Cloudflare Workers"
data:image/s3,"s3://crabby-images/2f5c1/2f5c1f870fb6368b2484852db7a758cf687e540f" alt="This package works with Node.js This package works with Node.js"
data:image/s3,"s3://crabby-images/15703/157031d99653aba0fd9d2f43d353e8e5b33c2c03" alt="This package works with Deno This package works with Deno"
data:image/s3,"s3://crabby-images/bb3b6/bb3b6daf6330d28acc6a95a270245041ca373167" alt="This package works with Bun This package works with Bun"
JSR Score
94%
Published
2 months ago (17.1.4)
A middleware framework for handling HTTP with Deno CLI, Deno Deploy, Cloudflare Workers, Node.js, and Bun.
oak is inspired by koa.
Example server
A minimal router server which responds with content on /
.
Deno CLI and Deno Deploy
import { Application } from "jsr:@oak/oak/application"; import { Router } from "jsr:@oak/oak/router"; const router = new Router(); router.get("/", (ctx) => { ctx.response.body = `<!DOCTYPE html> <html> <head><title>Hello oak!</title><head> <body> <h1>Hello oak!</h1> </body> </html> `; }); const app = new Application(); app.use(router.routes()); app.use(router.allowedMethods()); app.listen({ port: 8080 });
Node.js and Bun
You will have to install the package and then:
import { Application } from "@oak/oak/application"; import { Router } from "@oak/oak/router"; const router = new Router(); router.get("/", (ctx) => { ctx.response.body = `<!DOCTYPE html> <html> <head><title>Hello oak!</title><head> <body> <h1>Hello oak!</h1> </body> </html> `; }); const app = new Application(); app.use(router.routes()); app.use(router.allowedMethods()); app.listen({ port: 8080 });
Cloudflare Workers
You will have to install the package and then:
import { Application } from "@oak/oak/application"; import { Router } from "@oak/oak/router"; const router = new Router(); router.get("/", (ctx) => { ctx.response.body = `<!DOCTYPE html> <html> <head><title>Hello oak!</title><head> <body> <h1>Hello oak!</h1> </body> </html> `; }); const app = new Application(); app.use(router.routes()); app.use(router.allowedMethods()); export default { fetch: app.fetch };
Built and signed on
View transparency logGitHub Actions
Add Package
deno add jsr:@oak/oak
Import symbol
import * as oak from "@oak/oak";
---- OR ----
Import directly with a jsr specifier
import * as oak from "jsr:@oak/oak";
Add Package
npx jsr add @oak/oak
Import symbol
import * as oak from "@oak/oak";
Add Package
yarn dlx jsr add @oak/oak
Import symbol
import * as oak from "@oak/oak";
Add Package
pnpm dlx jsr add @oak/oak
Import symbol
import * as oak from "@oak/oak";
Add Package
bunx jsr add @oak/oak
Import symbol
import * as oak from "@oak/oak";