@depup/bun-types 1.3.11-depup.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CLAUDE.md +105 -0
- package/README.md +25 -0
- package/bun.d.ts +8712 -0
- package/bun.ns.d.ts +5 -0
- package/bundle.d.ts +74 -0
- package/changes.json +5 -0
- package/deprecated.d.ts +184 -0
- package/devserver.d.ts +187 -0
- package/docs/README.md +28 -0
- package/docs/bundler/bytecode.mdx +447 -0
- package/docs/bundler/css.mdx +1024 -0
- package/docs/bundler/esbuild.mdx +304 -0
- package/docs/bundler/executables.mdx +1318 -0
- package/docs/bundler/fullstack.mdx +1086 -0
- package/docs/bundler/hot-reloading.mdx +229 -0
- package/docs/bundler/html-static.mdx +498 -0
- package/docs/bundler/index.mdx +1840 -0
- package/docs/bundler/loaders.mdx +451 -0
- package/docs/bundler/macros.mdx +328 -0
- package/docs/bundler/minifier.mdx +1286 -0
- package/docs/bundler/plugins.mdx +477 -0
- package/docs/bundler/standalone-html.mdx +314 -0
- package/docs/feedback.mdx +75 -0
- package/docs/guides/binary/arraybuffer-to-array.mdx +29 -0
- package/docs/guides/binary/arraybuffer-to-blob.mdx +26 -0
- package/docs/guides/binary/arraybuffer-to-buffer.mdx +27 -0
- package/docs/guides/binary/arraybuffer-to-string.mdx +17 -0
- package/docs/guides/binary/arraybuffer-to-typedarray.mdx +41 -0
- package/docs/guides/binary/blob-to-arraybuffer.mdx +16 -0
- package/docs/guides/binary/blob-to-dataview.mdx +16 -0
- package/docs/guides/binary/blob-to-stream.mdx +16 -0
- package/docs/guides/binary/blob-to-string.mdx +17 -0
- package/docs/guides/binary/blob-to-typedarray.mdx +16 -0
- package/docs/guides/binary/buffer-to-arraybuffer.mdx +16 -0
- package/docs/guides/binary/buffer-to-blob.mdx +16 -0
- package/docs/guides/binary/buffer-to-readablestream.mdx +43 -0
- package/docs/guides/binary/buffer-to-string.mdx +27 -0
- package/docs/guides/binary/buffer-to-typedarray.mdx +16 -0
- package/docs/guides/binary/dataview-to-string.mdx +17 -0
- package/docs/guides/binary/typedarray-to-arraybuffer.mdx +27 -0
- package/docs/guides/binary/typedarray-to-blob.mdx +18 -0
- package/docs/guides/binary/typedarray-to-buffer.mdx +16 -0
- package/docs/guides/binary/typedarray-to-dataview.mdx +16 -0
- package/docs/guides/binary/typedarray-to-readablestream.mdx +43 -0
- package/docs/guides/binary/typedarray-to-string.mdx +18 -0
- package/docs/guides/deployment/aws-lambda.mdx +204 -0
- package/docs/guides/deployment/digital-ocean.mdx +161 -0
- package/docs/guides/deployment/google-cloud-run.mdx +194 -0
- package/docs/guides/deployment/railway.mdx +145 -0
- package/docs/guides/deployment/render.mdx +82 -0
- package/docs/guides/deployment/vercel.mdx +97 -0
- package/docs/guides/ecosystem/astro.mdx +82 -0
- package/docs/guides/ecosystem/discordjs.mdx +80 -0
- package/docs/guides/ecosystem/docker.mdx +151 -0
- package/docs/guides/ecosystem/drizzle.mdx +195 -0
- package/docs/guides/ecosystem/elysia.mdx +31 -0
- package/docs/guides/ecosystem/express.mdx +43 -0
- package/docs/guides/ecosystem/gel.mdx +261 -0
- package/docs/guides/ecosystem/hono.mdx +47 -0
- package/docs/guides/ecosystem/mongoose.mdx +92 -0
- package/docs/guides/ecosystem/neon-drizzle.mdx +234 -0
- package/docs/guides/ecosystem/neon-serverless-postgres.mdx +60 -0
- package/docs/guides/ecosystem/nextjs.mdx +103 -0
- package/docs/guides/ecosystem/nuxt.mdx +96 -0
- package/docs/guides/ecosystem/pm2.mdx +55 -0
- package/docs/guides/ecosystem/prisma-postgres.mdx +169 -0
- package/docs/guides/ecosystem/prisma.mdx +164 -0
- package/docs/guides/ecosystem/qwik.mdx +114 -0
- package/docs/guides/ecosystem/react.mdx +52 -0
- package/docs/guides/ecosystem/remix.mdx +97 -0
- package/docs/guides/ecosystem/sentry.mdx +54 -0
- package/docs/guides/ecosystem/solidstart.mdx +62 -0
- package/docs/guides/ecosystem/ssr-react.mdx +49 -0
- package/docs/guides/ecosystem/stric.mdx +54 -0
- package/docs/guides/ecosystem/sveltekit.mdx +138 -0
- package/docs/guides/ecosystem/systemd.mdx +114 -0
- package/docs/guides/ecosystem/tanstack-start.mdx +791 -0
- package/docs/guides/ecosystem/upstash.mdx +87 -0
- package/docs/guides/ecosystem/vite.mdx +77 -0
- package/docs/guides/html-rewriter/extract-links.mdx +71 -0
- package/docs/guides/html-rewriter/extract-social-meta.mdx +97 -0
- package/docs/guides/http/cluster.mdx +69 -0
- package/docs/guides/http/fetch-unix.mdx +35 -0
- package/docs/guides/http/fetch.mdx +26 -0
- package/docs/guides/http/file-uploads.mdx +97 -0
- package/docs/guides/http/hot.mdx +28 -0
- package/docs/guides/http/proxy.mdx +50 -0
- package/docs/guides/http/server.mdx +48 -0
- package/docs/guides/http/simple.mdx +20 -0
- package/docs/guides/http/sse.mdx +91 -0
- package/docs/guides/http/stream-file.mdx +50 -0
- package/docs/guides/http/stream-iterator.mdx +49 -0
- package/docs/guides/http/stream-node-streams-in-bun.mdx +22 -0
- package/docs/guides/http/tls.mdx +32 -0
- package/docs/guides/index.mdx +10 -0
- package/docs/guides/install/add-dev.mdx +28 -0
- package/docs/guides/install/add-git.mdx +40 -0
- package/docs/guides/install/add-optional.mdx +27 -0
- package/docs/guides/install/add-peer.mdx +45 -0
- package/docs/guides/install/add-tarball.mdx +35 -0
- package/docs/guides/install/add.mdx +44 -0
- package/docs/guides/install/azure-artifacts.mdx +76 -0
- package/docs/guides/install/cicd.mdx +43 -0
- package/docs/guides/install/custom-registry.mdx +32 -0
- package/docs/guides/install/from-npm-install-to-bun-install.mdx +230 -0
- package/docs/guides/install/git-diff-bun-lockfile.mdx +48 -0
- package/docs/guides/install/jfrog-artifactory.mdx +28 -0
- package/docs/guides/install/npm-alias.mdx +25 -0
- package/docs/guides/install/registry-scope.mdx +40 -0
- package/docs/guides/install/trusted.mdx +52 -0
- package/docs/guides/install/workspaces.mdx +70 -0
- package/docs/guides/install/yarnlock.mdx +51 -0
- package/docs/guides/process/argv.mdx +66 -0
- package/docs/guides/process/ctrl-c.mdx +18 -0
- package/docs/guides/process/ipc.mdx +69 -0
- package/docs/guides/process/nanoseconds.mdx +15 -0
- package/docs/guides/process/os-signals.mdx +31 -0
- package/docs/guides/process/spawn-stderr.mdx +34 -0
- package/docs/guides/process/spawn-stdout.mdx +28 -0
- package/docs/guides/process/spawn.mdx +43 -0
- package/docs/guides/process/stdin.mdx +62 -0
- package/docs/guides/read-file/arraybuffer.mdx +30 -0
- package/docs/guides/read-file/buffer.mdx +21 -0
- package/docs/guides/read-file/exists.mdx +18 -0
- package/docs/guides/read-file/json.mdx +19 -0
- package/docs/guides/read-file/mime.mdx +22 -0
- package/docs/guides/read-file/stream.mdx +28 -0
- package/docs/guides/read-file/string.mdx +24 -0
- package/docs/guides/read-file/uint8array.mdx +23 -0
- package/docs/guides/read-file/watch.mdx +66 -0
- package/docs/guides/runtime/build-time-constants.mdx +295 -0
- package/docs/guides/runtime/cicd.mdx +45 -0
- package/docs/guides/runtime/codesign-macos-executable.mdx +61 -0
- package/docs/guides/runtime/define-constant.mdx +149 -0
- package/docs/guides/runtime/delete-directory.mdx +39 -0
- package/docs/guides/runtime/delete-file.mdx +21 -0
- package/docs/guides/runtime/heap-snapshot.mdx +28 -0
- package/docs/guides/runtime/import-html.mdx +15 -0
- package/docs/guides/runtime/import-json.mdx +46 -0
- package/docs/guides/runtime/import-json5.mdx +74 -0
- package/docs/guides/runtime/import-toml.mdx +32 -0
- package/docs/guides/runtime/import-yaml.mdx +104 -0
- package/docs/guides/runtime/read-env.mdx +37 -0
- package/docs/guides/runtime/set-env.mdx +51 -0
- package/docs/guides/runtime/shell.mdx +42 -0
- package/docs/guides/runtime/timezone.mdx +38 -0
- package/docs/guides/runtime/tsconfig-paths.mdx +31 -0
- package/docs/guides/runtime/typescript.mdx +51 -0
- package/docs/guides/runtime/vscode-debugger.mdx +47 -0
- package/docs/guides/runtime/web-debugger.mdx +103 -0
- package/docs/guides/streams/node-readable-to-arraybuffer.mdx +13 -0
- package/docs/guides/streams/node-readable-to-blob.mdx +13 -0
- package/docs/guides/streams/node-readable-to-json.mdx +14 -0
- package/docs/guides/streams/node-readable-to-string.mdx +14 -0
- package/docs/guides/streams/node-readable-to-uint8array.mdx +13 -0
- package/docs/guides/streams/to-array.mdx +16 -0
- package/docs/guides/streams/to-arraybuffer.mdx +16 -0
- package/docs/guides/streams/to-blob.mdx +16 -0
- package/docs/guides/streams/to-buffer.mdx +17 -0
- package/docs/guides/streams/to-json.mdx +16 -0
- package/docs/guides/streams/to-string.mdx +16 -0
- package/docs/guides/streams/to-typedarray.mdx +24 -0
- package/docs/guides/test/bail.mdx +24 -0
- package/docs/guides/test/concurrent-test-glob.mdx +146 -0
- package/docs/guides/test/coverage-threshold.mdx +67 -0
- package/docs/guides/test/coverage.mdx +49 -0
- package/docs/guides/test/happy-dom.mdx +73 -0
- package/docs/guides/test/migrate-from-jest.mdx +125 -0
- package/docs/guides/test/mock-clock.mdx +50 -0
- package/docs/guides/test/mock-functions.mdx +70 -0
- package/docs/guides/test/rerun-each.mdx +16 -0
- package/docs/guides/test/run-tests.mdx +116 -0
- package/docs/guides/test/skip-tests.mdx +43 -0
- package/docs/guides/test/snapshot.mdx +102 -0
- package/docs/guides/test/spy-on.mdx +49 -0
- package/docs/guides/test/svelte-test.mdx +113 -0
- package/docs/guides/test/testing-library.mdx +93 -0
- package/docs/guides/test/timeout.mdx +17 -0
- package/docs/guides/test/todo-tests.mdx +74 -0
- package/docs/guides/test/update-snapshots.mdx +49 -0
- package/docs/guides/test/watch-mode.mdx +24 -0
- package/docs/guides/util/base64.mdx +17 -0
- package/docs/guides/util/deep-equals.mdx +41 -0
- package/docs/guides/util/deflate.mdx +20 -0
- package/docs/guides/util/detect-bun.mdx +28 -0
- package/docs/guides/util/entrypoint.mdx +19 -0
- package/docs/guides/util/escape-html.mdx +24 -0
- package/docs/guides/util/file-url-to-path.mdx +16 -0
- package/docs/guides/util/gzip.mdx +20 -0
- package/docs/guides/util/hash-a-password.mdx +56 -0
- package/docs/guides/util/import-meta-dir.mdx +15 -0
- package/docs/guides/util/import-meta-file.mdx +15 -0
- package/docs/guides/util/import-meta-path.mdx +15 -0
- package/docs/guides/util/javascript-uuid.mdx +25 -0
- package/docs/guides/util/main.mdx +43 -0
- package/docs/guides/util/path-to-file-url.mdx +16 -0
- package/docs/guides/util/sleep.mdx +24 -0
- package/docs/guides/util/upgrade.mdx +93 -0
- package/docs/guides/util/version.mdx +23 -0
- package/docs/guides/util/which-path-to-executable-bin.mdx +17 -0
- package/docs/guides/websocket/compression.mdx +33 -0
- package/docs/guides/websocket/context.mdx +79 -0
- package/docs/guides/websocket/pubsub.mdx +43 -0
- package/docs/guides/websocket/simple.mdx +38 -0
- package/docs/guides/write-file/append.mdx +54 -0
- package/docs/guides/write-file/basic.mdx +46 -0
- package/docs/guides/write-file/blob.mdx +30 -0
- package/docs/guides/write-file/cat.mdx +19 -0
- package/docs/guides/write-file/file-cp.mdx +18 -0
- package/docs/guides/write-file/filesink.mdx +54 -0
- package/docs/guides/write-file/response.mdx +19 -0
- package/docs/guides/write-file/stdout.mdx +23 -0
- package/docs/guides/write-file/stream.mdx +19 -0
- package/docs/guides/write-file/unlink.mdx +18 -0
- package/docs/index.mdx +133 -0
- package/docs/installation.mdx +372 -0
- package/docs/pm/bunx.mdx +91 -0
- package/docs/pm/catalogs.mdx +292 -0
- package/docs/pm/cli/add.mdx +179 -0
- package/docs/pm/cli/audit.mdx +60 -0
- package/docs/pm/cli/info.mdx +70 -0
- package/docs/pm/cli/install.mdx +591 -0
- package/docs/pm/cli/link.mdx +61 -0
- package/docs/pm/cli/outdated.mdx +197 -0
- package/docs/pm/cli/patch.mdx +69 -0
- package/docs/pm/cli/pm.mdx +323 -0
- package/docs/pm/cli/publish.mdx +131 -0
- package/docs/pm/cli/remove.mdx +16 -0
- package/docs/pm/cli/update.mdx +140 -0
- package/docs/pm/cli/why.mdx +84 -0
- package/docs/pm/filter.mdx +127 -0
- package/docs/pm/global-cache.mdx +72 -0
- package/docs/pm/isolated-installs.mdx +220 -0
- package/docs/pm/lifecycle.mdx +64 -0
- package/docs/pm/lockfile.mdx +64 -0
- package/docs/pm/npmrc.mdx +245 -0
- package/docs/pm/overrides.mdx +83 -0
- package/docs/pm/scopes-registries.mdx +35 -0
- package/docs/pm/security-scanner-api.mdx +95 -0
- package/docs/pm/workspaces.mdx +115 -0
- package/docs/project/benchmarking.mdx +296 -0
- package/docs/project/bindgen.mdx +223 -0
- package/docs/project/building-windows.mdx +143 -0
- package/docs/project/contributing.mdx +366 -0
- package/docs/project/feedback.mdx +20 -0
- package/docs/project/license.mdx +78 -0
- package/docs/project/roadmap.mdx +8 -0
- package/docs/quickstart.mdx +251 -0
- package/docs/runtime/archive.mdx +452 -0
- package/docs/runtime/auto-install.mdx +97 -0
- package/docs/runtime/binary-data.mdx +846 -0
- package/docs/runtime/bun-apis.mdx +60 -0
- package/docs/runtime/bunfig.mdx +765 -0
- package/docs/runtime/c-compiler.mdx +204 -0
- package/docs/runtime/child-process.mdx +659 -0
- package/docs/runtime/color.mdx +267 -0
- package/docs/runtime/console.mdx +67 -0
- package/docs/runtime/cookies.mdx +454 -0
- package/docs/runtime/cron.mdx +358 -0
- package/docs/runtime/csrf.mdx +171 -0
- package/docs/runtime/debugger.mdx +335 -0
- package/docs/runtime/environment-variables.mdx +231 -0
- package/docs/runtime/ffi.mdx +567 -0
- package/docs/runtime/file-io.mdx +306 -0
- package/docs/runtime/file-system-router.mdx +118 -0
- package/docs/runtime/file-types.mdx +482 -0
- package/docs/runtime/glob.mdx +181 -0
- package/docs/runtime/globals.mdx +72 -0
- package/docs/runtime/hashing.mdx +315 -0
- package/docs/runtime/html-rewriter.mdx +333 -0
- package/docs/runtime/http/cookies.mdx +79 -0
- package/docs/runtime/http/error-handling.mdx +40 -0
- package/docs/runtime/http/metrics.mdx +36 -0
- package/docs/runtime/http/routing.mdx +289 -0
- package/docs/runtime/http/server.mdx +672 -0
- package/docs/runtime/http/tls.mdx +101 -0
- package/docs/runtime/http/websockets.mdx +414 -0
- package/docs/runtime/index.mdx +223 -0
- package/docs/runtime/json5.mdx +271 -0
- package/docs/runtime/jsonl.mdx +188 -0
- package/docs/runtime/jsx.mdx +115 -0
- package/docs/runtime/markdown.mdx +381 -0
- package/docs/runtime/module-resolution.mdx +374 -0
- package/docs/runtime/networking/dns.mdx +111 -0
- package/docs/runtime/networking/fetch.mdx +484 -0
- package/docs/runtime/networking/tcp.mdx +239 -0
- package/docs/runtime/networking/udp.mdx +180 -0
- package/docs/runtime/node-api.mdx +19 -0
- package/docs/runtime/nodejs-compat.mdx +468 -0
- package/docs/runtime/plugins.mdx +419 -0
- package/docs/runtime/redis.mdx +583 -0
- package/docs/runtime/repl.mdx +176 -0
- package/docs/runtime/s3.mdx +881 -0
- package/docs/runtime/secrets.mdx +340 -0
- package/docs/runtime/semver.mdx +57 -0
- package/docs/runtime/shell.mdx +637 -0
- package/docs/runtime/sql.mdx +1404 -0
- package/docs/runtime/sqlite.mdx +721 -0
- package/docs/runtime/streams.mdx +232 -0
- package/docs/runtime/templating/create.mdx +269 -0
- package/docs/runtime/templating/init.mdx +58 -0
- package/docs/runtime/toml.mdx +238 -0
- package/docs/runtime/transpiler.mdx +288 -0
- package/docs/runtime/typescript.mdx +58 -0
- package/docs/runtime/utils.mdx +1010 -0
- package/docs/runtime/watch-mode.mdx +161 -0
- package/docs/runtime/web-apis.mdx +29 -0
- package/docs/runtime/workers.mdx +314 -0
- package/docs/runtime/yaml.mdx +470 -0
- package/docs/snippets/cli/add.mdx +166 -0
- package/docs/snippets/cli/build.mdx +197 -0
- package/docs/snippets/cli/bunx.mdx +49 -0
- package/docs/snippets/cli/feedback.mdx +17 -0
- package/docs/snippets/cli/init.mdx +84 -0
- package/docs/snippets/cli/install.mdx +173 -0
- package/docs/snippets/cli/link.mdx +163 -0
- package/docs/snippets/cli/outdated.mdx +140 -0
- package/docs/snippets/cli/patch.mdx +171 -0
- package/docs/snippets/cli/publish.mdx +198 -0
- package/docs/snippets/cli/remove.mdx +146 -0
- package/docs/snippets/cli/run.mdx +305 -0
- package/docs/snippets/cli/test.mdx +105 -0
- package/docs/snippets/cli/update.mdx +144 -0
- package/docs/test/code-coverage.mdx +409 -0
- package/docs/test/configuration.mdx +574 -0
- package/docs/test/dates-times.mdx +129 -0
- package/docs/test/discovery.mdx +90 -0
- package/docs/test/dom.mdx +226 -0
- package/docs/test/index.mdx +409 -0
- package/docs/test/lifecycle.mdx +366 -0
- package/docs/test/mocks.mdx +637 -0
- package/docs/test/reporters.mdx +126 -0
- package/docs/test/runtime-behavior.mdx +342 -0
- package/docs/test/snapshots.mdx +434 -0
- package/docs/test/writing-tests.mdx +672 -0
- package/docs/typescript.mdx +54 -0
- package/extensions.d.ts +40 -0
- package/fetch.d.ts +79 -0
- package/ffi.d.ts +1154 -0
- package/globals.d.ts +2067 -0
- package/html-rewriter.d.ts +186 -0
- package/index.d.ts +32 -0
- package/jsc.d.ts +233 -0
- package/jsx.d.ts +11 -0
- package/overrides.d.ts +376 -0
- package/package.json +53 -0
- package/redis.d.ts +3352 -0
- package/s3.d.ts +1354 -0
- package/security.d.ts +101 -0
- package/serve.d.ts +1296 -0
- package/shell.d.ts +380 -0
- package/sql.d.ts +887 -0
- package/sqlite.d.ts +1322 -0
- package/test-globals.d.ts +22 -0
- package/test.d.ts +2392 -0
- package/vendor/expect-type/branding.d.ts +283 -0
- package/vendor/expect-type/index.d.ts +1207 -0
- package/vendor/expect-type/messages.d.ts +395 -0
- package/vendor/expect-type/overloads.d.ts +669 -0
- package/vendor/expect-type/utils.d.ts +431 -0
- package/wasm.d.ts +193 -0
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Write a simple HTTP server
|
|
3
|
+
sidebarTitle: Simple HTTP Server with Bun
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
This starts an HTTP server listening on port `3000`. It responds to all requests with a `Response` with status `200` and body `"Welcome to Bun!"`.
|
|
8
|
+
|
|
9
|
+
See [`Bun.serve`](/docs/runtime/http/server) for details.
|
|
10
|
+
|
|
11
|
+
```ts server.ts icon="/icons/typescript.svg"
|
|
12
|
+
const server = Bun.serve({
|
|
13
|
+
port: 3000,
|
|
14
|
+
fetch(request) {
|
|
15
|
+
return new Response("Welcome to Bun!");
|
|
16
|
+
},
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
console.log(`Listening on ${server.url}`);
|
|
20
|
+
```
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Server-Sent Events (SSE) with Bun
|
|
3
|
+
sidebarTitle: Server-Sent Events
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
[Server-Sent Events](https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events) let you push a stream of text events to the browser over a single HTTP response. The client consumes them via [`EventSource`](https://developer.mozilla.org/en-US/docs/Web/API/EventSource).
|
|
8
|
+
|
|
9
|
+
In Bun, you can implement an SSE endpoint by returning a `Response` whose body is a streaming source and setting the `Content-Type` header to `text/event-stream`.
|
|
10
|
+
|
|
11
|
+
<Note>
|
|
12
|
+
`Bun.serve` closes idle connections after **10 seconds** by default. A quiet SSE stream counts as idle, so the
|
|
13
|
+
examples below call `server.timeout(req, 0)` to disable the timeout for the stream. See
|
|
14
|
+
[`idleTimeout`](/docs/runtime/http/server#idletimeout) for details.
|
|
15
|
+
</Note>
|
|
16
|
+
|
|
17
|
+
## Using an async generator
|
|
18
|
+
|
|
19
|
+
In Bun, `new Response` accepts an async generator function directly. This is usually the simplest way to write an SSE endpoint — each `yield` flushes a chunk to the client, and if the client disconnects, the generator's `finally` block runs so you can clean up.
|
|
20
|
+
|
|
21
|
+
```ts server.ts icon="/icons/typescript.svg"
|
|
22
|
+
Bun.serve({
|
|
23
|
+
port: 3000,
|
|
24
|
+
routes: {
|
|
25
|
+
"/events": (req, server) => {
|
|
26
|
+
// SSE streams are often quiet between events. By default,
|
|
27
|
+
// Bun.serve closes connections after 10 seconds of inactivity.
|
|
28
|
+
// Disable the idle timeout for this request so the stream
|
|
29
|
+
// stays open indefinitely.
|
|
30
|
+
server.timeout(req, 0);
|
|
31
|
+
|
|
32
|
+
return new Response(
|
|
33
|
+
async function* () {
|
|
34
|
+
yield `data: connected at ${Date.now()}\n\n`;
|
|
35
|
+
|
|
36
|
+
// Emit a tick every 5 seconds until the client disconnects.
|
|
37
|
+
// When the client goes away, the generator is returned
|
|
38
|
+
// (cancelled) and this loop stops automatically.
|
|
39
|
+
while (true) {
|
|
40
|
+
await Bun.sleep(5000);
|
|
41
|
+
yield `data: tick ${Date.now()}\n\n`;
|
|
42
|
+
}
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
headers: {
|
|
46
|
+
"Content-Type": "text/event-stream",
|
|
47
|
+
"Cache-Control": "no-cache",
|
|
48
|
+
},
|
|
49
|
+
},
|
|
50
|
+
);
|
|
51
|
+
},
|
|
52
|
+
},
|
|
53
|
+
});
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
## Using a `ReadableStream`
|
|
57
|
+
|
|
58
|
+
If your events originate from callbacks — message brokers, timers, external pushes — rather than a linear `await` flow, a `ReadableStream` often fits better. When the client disconnects, Bun calls the stream's `cancel()` method automatically, so you can release any resources you set up in `start()`.
|
|
59
|
+
|
|
60
|
+
```ts server.ts icon="/icons/typescript.svg"
|
|
61
|
+
Bun.serve({
|
|
62
|
+
port: 3000,
|
|
63
|
+
routes: {
|
|
64
|
+
"/events": (req, server) => {
|
|
65
|
+
server.timeout(req, 0);
|
|
66
|
+
|
|
67
|
+
let timer: Timer;
|
|
68
|
+
const stream = new ReadableStream({
|
|
69
|
+
start(controller) {
|
|
70
|
+
controller.enqueue(`data: connected at ${Date.now()}\n\n`);
|
|
71
|
+
|
|
72
|
+
timer = setInterval(() => {
|
|
73
|
+
controller.enqueue(`data: tick ${Date.now()}\n\n`);
|
|
74
|
+
}, 5000);
|
|
75
|
+
},
|
|
76
|
+
cancel() {
|
|
77
|
+
// Called automatically when the client disconnects.
|
|
78
|
+
clearInterval(timer);
|
|
79
|
+
},
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
return new Response(stream, {
|
|
83
|
+
headers: {
|
|
84
|
+
"Content-Type": "text/event-stream",
|
|
85
|
+
"Cache-Control": "no-cache",
|
|
86
|
+
},
|
|
87
|
+
});
|
|
88
|
+
},
|
|
89
|
+
},
|
|
90
|
+
});
|
|
91
|
+
```
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Stream a file as an HTTP Response
|
|
3
|
+
sidebarTitle: Stream file response
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
This snippet reads a file from disk using [`Bun.file()`](/docs/runtime/file-io#reading-files-bun-file). This returns a `BunFile` instance, which can be passed directly into the `new Response` constructor.
|
|
8
|
+
|
|
9
|
+
```ts server.ts icon="/icons/typescript.svg"
|
|
10
|
+
const path = "/path/to/file.txt";
|
|
11
|
+
const file = Bun.file(path);
|
|
12
|
+
const resp = new Response(file);
|
|
13
|
+
```
|
|
14
|
+
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
The `Content-Type` is read from the file and automatically set on the `Response`.
|
|
18
|
+
|
|
19
|
+
```ts server.ts icon="/icons/typescript.svg"
|
|
20
|
+
new Response(Bun.file("./package.json")).headers.get("Content-Type");
|
|
21
|
+
// => application/json;charset=utf-8
|
|
22
|
+
|
|
23
|
+
new Response(Bun.file("./test.txt")).headers.get("Content-Type");
|
|
24
|
+
// => text/plain;charset=utf-8
|
|
25
|
+
|
|
26
|
+
new Response(Bun.file("./index.tsx")).headers.get("Content-Type");
|
|
27
|
+
// => text/javascript;charset=utf-8
|
|
28
|
+
|
|
29
|
+
new Response(Bun.file("./img.png")).headers.get("Content-Type");
|
|
30
|
+
// => image/png
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
---
|
|
34
|
+
|
|
35
|
+
Putting it all together with [`Bun.serve()`](/docs/runtime/http/server).
|
|
36
|
+
|
|
37
|
+
```ts server.ts icon="/icons/typescript.svg"
|
|
38
|
+
// static file server
|
|
39
|
+
Bun.serve({
|
|
40
|
+
async fetch(req) {
|
|
41
|
+
const path = new URL(req.url).pathname;
|
|
42
|
+
const file = Bun.file(path);
|
|
43
|
+
return new Response(file);
|
|
44
|
+
},
|
|
45
|
+
});
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
---
|
|
49
|
+
|
|
50
|
+
See [Docs > API > File I/O](/docs/runtime/file-io#writing-files-bun-write) for complete documentation of `Bun.write()`.
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Streaming HTTP Server with Async Iterators
|
|
3
|
+
sidebarTitle: Stream with iterators
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
In Bun, [`Response`](https://developer.mozilla.org/en-US/docs/Web/API/Response) objects can accept an async generator function as their body. This allows you to stream data to the client as it becomes available, rather than waiting for the entire response to be ready.
|
|
8
|
+
|
|
9
|
+
```ts stream-iterator.ts icon="/icons/typescript.svg"
|
|
10
|
+
Bun.serve({
|
|
11
|
+
port: 3000,
|
|
12
|
+
fetch(req) {
|
|
13
|
+
return new Response(
|
|
14
|
+
// An async generator function
|
|
15
|
+
async function* () {
|
|
16
|
+
yield "Hello, ";
|
|
17
|
+
await Bun.sleep(100);
|
|
18
|
+
yield "world!";
|
|
19
|
+
|
|
20
|
+
// you can also yield a TypedArray or Buffer
|
|
21
|
+
yield new Uint8Array(["\n".charCodeAt(0)]);
|
|
22
|
+
},
|
|
23
|
+
{ headers: { "Content-Type": "text/plain" } },
|
|
24
|
+
);
|
|
25
|
+
},
|
|
26
|
+
});
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
---
|
|
30
|
+
|
|
31
|
+
You can pass any async iterable directly to `Response`:
|
|
32
|
+
|
|
33
|
+
```ts stream-iterator.ts icon="/icons/typescript.svg"
|
|
34
|
+
Bun.serve({
|
|
35
|
+
port: 3000,
|
|
36
|
+
fetch(req) {
|
|
37
|
+
return new Response(
|
|
38
|
+
{
|
|
39
|
+
[Symbol.asyncIterator]: async function* () {
|
|
40
|
+
yield "Hello, ";
|
|
41
|
+
await Bun.sleep(100);
|
|
42
|
+
yield "world!";
|
|
43
|
+
},
|
|
44
|
+
},
|
|
45
|
+
{ headers: { "Content-Type": "text/plain" } },
|
|
46
|
+
);
|
|
47
|
+
},
|
|
48
|
+
});
|
|
49
|
+
```
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Streaming HTTP Server with Node.js Streams
|
|
3
|
+
sidebarTitle: Stream with Node.js
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
In Bun, [`Response`](https://developer.mozilla.org/en-US/docs/Web/API/Response) objects can accept a Node.js [`Readable`](https://nodejs.org/api/stream.html#stream_readable_streams).
|
|
8
|
+
|
|
9
|
+
This works because Bun's `Response` object allows any async iterable as its body. Node.js streams are async iterables, so you can pass them directly to `Response`.
|
|
10
|
+
|
|
11
|
+
```ts server.ts icon="/icons/typescript.svg"
|
|
12
|
+
import { Readable } from "stream";
|
|
13
|
+
import { serve } from "bun";
|
|
14
|
+
serve({
|
|
15
|
+
port: 3000,
|
|
16
|
+
fetch(req) {
|
|
17
|
+
return new Response(Readable.from(["Hello, ", "world!"]), {
|
|
18
|
+
headers: { "Content-Type": "text/plain" },
|
|
19
|
+
});
|
|
20
|
+
},
|
|
21
|
+
});
|
|
22
|
+
```
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Configure TLS on an HTTP server
|
|
3
|
+
sidebarTitle: Configure TLS
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
Set the `tls` key to configure TLS. Both `key` and `cert` are required. The `key` should be the contents of your private key; `cert` should be the contents of your issued certificate. Use [`Bun.file()`](/docs/runtime/file-io#reading-files-bun-file) to read the contents.
|
|
8
|
+
|
|
9
|
+
```ts server.ts icon="/icons/typescript.svg"
|
|
10
|
+
const server = Bun.serve({
|
|
11
|
+
fetch: request => new Response("Welcome to Bun!"),
|
|
12
|
+
tls: {
|
|
13
|
+
cert: Bun.file("cert.pem"),
|
|
14
|
+
key: Bun.file("key.pem"),
|
|
15
|
+
},
|
|
16
|
+
});
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
---
|
|
20
|
+
|
|
21
|
+
By default Bun trusts the default Mozilla-curated list of well-known root CAs. To override this list, pass an array of certificates as `ca`.
|
|
22
|
+
|
|
23
|
+
```ts server.ts icon="/icons/typescript.svg"
|
|
24
|
+
const server = Bun.serve({
|
|
25
|
+
fetch: request => new Response("Welcome to Bun!"),
|
|
26
|
+
tls: {
|
|
27
|
+
cert: Bun.file("cert.pem"),
|
|
28
|
+
key: Bun.file("key.pem"),
|
|
29
|
+
ca: [Bun.file("ca1.pem"), Bun.file("ca2.pem")],
|
|
30
|
+
},
|
|
31
|
+
});
|
|
32
|
+
```
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Add a development dependency
|
|
3
|
+
sidebarTitle: Add a dev dependency
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
To add an npm package as a development dependency, use `bun add --development`.
|
|
8
|
+
|
|
9
|
+
```sh terminal icon="terminal"
|
|
10
|
+
bun add zod --dev
|
|
11
|
+
bun add zod -d # shorthand
|
|
12
|
+
```
|
|
13
|
+
|
|
14
|
+
---
|
|
15
|
+
|
|
16
|
+
This will add the package to `devDependencies` in `package.json`.
|
|
17
|
+
|
|
18
|
+
```json
|
|
19
|
+
{
|
|
20
|
+
"devDependencies": {
|
|
21
|
+
"zod": "^3.0.0" // [!code ++]
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
---
|
|
27
|
+
|
|
28
|
+
See [Docs > Package manager](/docs/pm/cli/install) for complete documentation of Bun's package manager.
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Add a Git dependency
|
|
3
|
+
sidebarTitle: Add a Git dependency
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
Bun supports directly adding GitHub repositories as dependencies of your project.
|
|
8
|
+
|
|
9
|
+
```sh terminal icon="terminal"
|
|
10
|
+
bun add github:lodash/lodash
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
This will add the following line to your `package.json`:
|
|
16
|
+
|
|
17
|
+
```json package.json icon="file-json"
|
|
18
|
+
{
|
|
19
|
+
"dependencies": {
|
|
20
|
+
"lodash": "github:lodash/lodash"
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
---
|
|
26
|
+
|
|
27
|
+
Bun supports a number of protocols for specifying Git dependencies.
|
|
28
|
+
|
|
29
|
+
```sh terminal icon="terminal"
|
|
30
|
+
bun add git+https://github.com/lodash/lodash.git
|
|
31
|
+
bun add git+ssh://github.com/lodash/lodash.git#4.17.21
|
|
32
|
+
bun add git@github.com:lodash/lodash.git
|
|
33
|
+
bun add github:colinhacks/zod
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
**Note:** GitHub dependencies download via HTTP tarball when possible for faster installation.
|
|
37
|
+
|
|
38
|
+
---
|
|
39
|
+
|
|
40
|
+
See [Docs > Package manager](/docs/pm/cli/install) for complete documentation of Bun's package manager.
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Add an optional dependency
|
|
3
|
+
sidebarTitle: Add an optional dependency
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
To add an npm package as an optional dependency, use the `--optional` flag.
|
|
8
|
+
|
|
9
|
+
```sh terminal icon="terminal"
|
|
10
|
+
bun add zod --optional
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
This will add the package to `optionalDependencies` in `package.json`.
|
|
16
|
+
|
|
17
|
+
```json package.json icon="file-json"
|
|
18
|
+
{
|
|
19
|
+
"optionalDependencies": {
|
|
20
|
+
"zod": "^3.0.0" // [!code ++]
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
---
|
|
26
|
+
|
|
27
|
+
See [Docs > Package manager](/docs/pm/cli/install) for complete documentation of Bun's package manager.
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Add a peer dependency
|
|
3
|
+
sidebarTitle: Add a peer dependency
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
To add an npm package as a peer dependency, use the `--peer` flag.
|
|
8
|
+
|
|
9
|
+
```sh terminal icon="terminal"
|
|
10
|
+
bun add @types/bun --peer
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
This will add the package to `peerDependencies` in `package.json`.
|
|
16
|
+
|
|
17
|
+
```json package.json icon="file-json"
|
|
18
|
+
{
|
|
19
|
+
"peerDependencies": {
|
|
20
|
+
"@types/bun": "^1.3.3" // [!code ++]
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
---
|
|
26
|
+
|
|
27
|
+
Running `bun install` will install peer dependencies by default, unless marked optional in `peerDependenciesMeta`.
|
|
28
|
+
|
|
29
|
+
{/* prettier-ignore */}
|
|
30
|
+
```json package.json icon="file-json"
|
|
31
|
+
{
|
|
32
|
+
"peerDependencies": {
|
|
33
|
+
"@types/bun": "^1.3.3"
|
|
34
|
+
},
|
|
35
|
+
"peerDependenciesMeta": {
|
|
36
|
+
"@types/bun": { // [!code ++]
|
|
37
|
+
"optional": true // [!code ++]
|
|
38
|
+
} // [!code ++]
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
---
|
|
44
|
+
|
|
45
|
+
See [Docs > Package manager](/docs/pm/cli/install) for complete documentation of Bun's package manager.
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Add a tarball dependency
|
|
3
|
+
sidebarTitle: Add a tarball dependency
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
Bun's package manager can install any publicly available tarball URL as a dependency of your project.
|
|
8
|
+
|
|
9
|
+
```sh terminal icon="terminal"
|
|
10
|
+
bun add zod@https://registry.npmjs.org/zod/-/zod-3.21.4.tgz
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
Running this command will download, extract, and install the tarball to your project's `node_modules` directory. It will also add the following line to your `package.json`:
|
|
16
|
+
|
|
17
|
+
```json package.json icon="file-json"
|
|
18
|
+
{
|
|
19
|
+
"dependencies": {
|
|
20
|
+
"zod": "https://registry.npmjs.org/zod/-/zod-3.21.4.tgz" // [!code ++]
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
---
|
|
26
|
+
|
|
27
|
+
The package `"zod"` can now be imported as usual.
|
|
28
|
+
|
|
29
|
+
```ts
|
|
30
|
+
import { z } from "zod";
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
---
|
|
34
|
+
|
|
35
|
+
See [Docs > Package manager](/docs/pm/cli/install) for complete documentation of Bun's package manager.
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Add a dependency
|
|
3
|
+
sidebarTitle: Add a dependency
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
To add an npm package as a dependency, use `bun add`.
|
|
8
|
+
|
|
9
|
+
```sh terminal icon="terminal"
|
|
10
|
+
bun add zod
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
This will add the package to `dependencies` in `package.json`. By default, the `^` range specifier will be used, to indicate that any future minor or patch versions are acceptable.
|
|
16
|
+
|
|
17
|
+
```json package.json icon="file-json"
|
|
18
|
+
{
|
|
19
|
+
"dependencies": {
|
|
20
|
+
"zod": "^3.0.0" // [!code ++]
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
---
|
|
26
|
+
|
|
27
|
+
To "pin" to an exact version of the package, use `--exact`. This will add the package to `dependencies` without the `^`, pinning your project to the exact version you installed.
|
|
28
|
+
|
|
29
|
+
```sh terminal icon="terminal"
|
|
30
|
+
bun add zod --exact
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
---
|
|
34
|
+
|
|
35
|
+
To specify an exact version or a tag:
|
|
36
|
+
|
|
37
|
+
```sh terminal icon="terminal"
|
|
38
|
+
bun add zod@3.0.0
|
|
39
|
+
bun add zod@next
|
|
40
|
+
```
|
|
41
|
+
|
|
42
|
+
---
|
|
43
|
+
|
|
44
|
+
See [Docs > Package manager](/docs/pm/cli/install) for complete documentation of Bun's package manager.
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Using bun install with an Azure Artifacts npm registry
|
|
3
|
+
sidebarTitle: Azure Artifacts with Bun
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
<Note>
|
|
8
|
+
In [Azure
|
|
9
|
+
Artifact's](https://learn.microsoft.com/en-us/azure/devops/artifacts/npm/npmrc?view=azure-devops&tabs=windows%2Cclassic)
|
|
10
|
+
instructions for `.npmrc`, they say to base64 encode the password. Do not do this for `bun install`. Bun will
|
|
11
|
+
automatically base64 encode the password for you if needed.
|
|
12
|
+
</Note>
|
|
13
|
+
|
|
14
|
+
[Azure Artifacts](https://azure.microsoft.com/en-us/products/devops/artifacts) is a package management system for Azure DevOps. It allows you to host your own private npm registry, npm packages, and other types of packages as well.
|
|
15
|
+
|
|
16
|
+
---
|
|
17
|
+
|
|
18
|
+
### Configure with bunfig.toml
|
|
19
|
+
|
|
20
|
+
---
|
|
21
|
+
|
|
22
|
+
To use it with `bun install`, add a `bunfig.toml` file to your project with the following contents. Make sure to replace `my-azure-artifacts-user` with your Azure Artifacts username, such as `jarred1234`.
|
|
23
|
+
|
|
24
|
+
```toml bunfig.toml icon="settings"
|
|
25
|
+
[install.registry]
|
|
26
|
+
url = "https://pkgs.dev.azure.com/my-azure-artifacts-user/_packaging/my-azure-artifacts-user/npm/registry"
|
|
27
|
+
username = "my-azure-artifacts-user"
|
|
28
|
+
# You can use an environment variable here
|
|
29
|
+
password = "$NPM_PASSWORD"
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
---
|
|
33
|
+
|
|
34
|
+
Then assign your Azure Personal Access Token to the `NPM_PASSWORD` environment variable. Bun [automatically reads](/docs/runtime/environment-variables) `.env` files, so create a file called `.env` in your project root. There is no need to base-64 encode this token! Bun will do this for you.
|
|
35
|
+
|
|
36
|
+
```ini .env icon="settings"
|
|
37
|
+
NPM_PASSWORD=<paste token here>
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
---
|
|
41
|
+
|
|
42
|
+
### Configure with environment variables
|
|
43
|
+
|
|
44
|
+
---
|
|
45
|
+
|
|
46
|
+
To configure Azure Artifacts without `bunfig.toml`, you can set the `NPM_CONFIG_REGISTRY` environment variable. The URL should include `:username` and `:_password` as query parameters. Replace `<USERNAME>` and `<PASSWORD>` with the appropriate values.
|
|
47
|
+
|
|
48
|
+
```bash terminal icon="terminal"
|
|
49
|
+
NPM_CONFIG_REGISTRY=https://pkgs.dev.azure.com/my-azure-artifacts-user/_packaging/my-azure-artifacts-user/npm/registry/:username=<USERNAME>:_password=<PASSWORD>
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
---
|
|
53
|
+
|
|
54
|
+
### Don't base64 encode the password
|
|
55
|
+
|
|
56
|
+
---
|
|
57
|
+
|
|
58
|
+
In [Azure Artifact's](https://learn.microsoft.com/en-us/azure/devops/artifacts/npm/npmrc?view=azure-devops&tabs=windows%2Cclassic) instructions for `.npmrc`, they say to base64 encode the password. Do not do this for `bun install`. Bun will automatically base64 encode the password for you if needed.
|
|
59
|
+
|
|
60
|
+
<Note>**Tip** — If it ends with `==`, it probably is base64 encoded.</Note>
|
|
61
|
+
|
|
62
|
+
---
|
|
63
|
+
|
|
64
|
+
To decode a base64-encoded password, open your browser console and run:
|
|
65
|
+
|
|
66
|
+
```js browser icon="computer"
|
|
67
|
+
atob("<base64-encoded password>");
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
---
|
|
71
|
+
|
|
72
|
+
Alternatively, use the `base64` command line tool, but doing so means it may be saved in your terminal history which is not recommended:
|
|
73
|
+
|
|
74
|
+
```bash terminal icon="terminal"
|
|
75
|
+
echo "base64-encoded-password" | base64 --decode
|
|
76
|
+
```
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Install dependencies with Bun in GitHub Actions
|
|
3
|
+
sidebarTitle: Install Bun in GitHub Actions
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
Use the official [`setup-bun`](https://github.com/oven-sh/setup-bun) GitHub Action to install `bun` in your GitHub Actions runner.
|
|
8
|
+
|
|
9
|
+
```yaml workflow.yml icon="file-code"
|
|
10
|
+
title: my-workflow
|
|
11
|
+
jobs:
|
|
12
|
+
my-job:
|
|
13
|
+
title: my-job
|
|
14
|
+
runs-on: ubuntu-latest
|
|
15
|
+
steps:
|
|
16
|
+
# ...
|
|
17
|
+
- uses: actions/checkout@v4
|
|
18
|
+
- uses: oven-sh/setup-bun@v2 // [!code ++]
|
|
19
|
+
|
|
20
|
+
# run any `bun` or `bunx` command
|
|
21
|
+
- run: bun install // [!code ++]
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
---
|
|
25
|
+
|
|
26
|
+
To specify a version of Bun to install:
|
|
27
|
+
|
|
28
|
+
```yaml workflow.yml icon="file-code"
|
|
29
|
+
title: my-workflow
|
|
30
|
+
jobs:
|
|
31
|
+
my-job:
|
|
32
|
+
title: my-job
|
|
33
|
+
runs-on: ubuntu-latest
|
|
34
|
+
steps:
|
|
35
|
+
# ...
|
|
36
|
+
- uses: oven-sh/setup-bun@v2
|
|
37
|
+
with: # [!code ++]
|
|
38
|
+
version: "latest" # or "canary" # [!code ++]
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
---
|
|
42
|
+
|
|
43
|
+
Refer to the [README.md](https://github.com/oven-sh/setup-bun) for complete documentation of the `setup-bun` GitHub Action.
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Override the default npm registry for bun install
|
|
3
|
+
sidebarTitle: Override the default npm registry
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
The default registry is `registry.npmjs.org`. This can be globally configured in `bunfig.toml`.
|
|
8
|
+
|
|
9
|
+
```toml bunfig.toml icon="settings"
|
|
10
|
+
[install]
|
|
11
|
+
# set default registry as a string
|
|
12
|
+
registry = "https://registry.npmjs.org"
|
|
13
|
+
|
|
14
|
+
# if needed, set a token
|
|
15
|
+
registry = { url = "https://registry.npmjs.org", token = "123456" }
|
|
16
|
+
|
|
17
|
+
# if needed, set a username/password
|
|
18
|
+
registry = "https://usertitle:password@registry.npmjs.org"
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
---
|
|
22
|
+
|
|
23
|
+
Your `bunfig.toml` can reference environment variables. Bun automatically loads environment variables from `.env.local`, `.env.[NODE_ENV]`, and `.env`. See [Docs > Environment variables](/docs/runtime/environment-variables) for more information.
|
|
24
|
+
|
|
25
|
+
```toml bunfig.toml icon="settings"
|
|
26
|
+
[install]
|
|
27
|
+
registry = { url = "https://registry.npmjs.org", token = "$npm_token" }
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
---
|
|
31
|
+
|
|
32
|
+
See [Docs > Package manager](/docs/pm/cli/install) for complete documentation of Bun's package manager.
|