@arcjet/bun
v1.0.0
Published
Arcjet SDK for Bun
Readme
@arcjet/bun
Arcjet helps developers protect their apps in just a few lines of code. Implement rate limiting, bot protection, email verification, and defense against common attacks.
This is the Arcjet SDK for Bun.sh.
Getting started
Visit the quick start guide to get started.
Example app
Try an Arcjet protected app live at https://example.arcjet.com (source code).
What is this?
This is our adapter to integrate Arcjet into Bun. Arcjet helps you secure your Bun server. This package exists so that we can provide the best possible experience to Bun users.
When should I use this?
You can use this if you are using Bun. See our Get started guide for other supported runtimes.
Install
This package is ESM only. Install with Bun:
bun add @arcjet/bunUse
import arcjet, { shield } from "@arcjet/bun";
// Get your Arcjet key at <https://app.arcjet.com>.
// Set it as an environment variable instead of hard coding it.
const arcjetKey = Bun.env.ARCJET_KEY;
if (!arcjetKey) {
throw new Error("Cannot find `ARCJET_KEY` environment variable");
}
const aj = arcjet({
key: arcjetKey,
rules: [
// Shield protects your app from common attacks.
// Use `DRY_RUN` instead of `LIVE` to only log.
shield({ mode: "LIVE" }),
],
});
export default {
port: 8000,
fetch: aj.handler(async function (request: Request) {
const decision = await aj.protect(request);
if (decision.isDenied()) {
return Response.json({ message: "Forbidden" }, { status: 403 });
}
return Response.json({ message: "Hello world" });
}),
};For more on how to configure Arcjet with Bun and how to protect Bun, see the Arcjet Bun SDK reference on our website.
Test
This monorepo is tested with Node.js but this package targets Bun. Run the tests from this package folder with:
bun test