Skip to content

Commit

Permalink
Move to Bun
Browse files Browse the repository at this point in the history
  • Loading branch information
LitoMore committed Aug 12, 2024
1 parent 09a0c91 commit 759c116
Show file tree
Hide file tree
Showing 16 changed files with 309 additions and 441 deletions.
1 change: 1 addition & 0 deletions .gitattribute
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
*.lockb binary diff=lockb
13 changes: 13 additions & 0 deletions .github/workflows/bun.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
name: Bun
on: [push]
jobs:
build:
runs-on: ubuntu-latest
name: Bun
steps:
- uses: actions/checkout@v4
- uses: oven-sh/setup-bun@v2
with:
bun-version: latest
- run: bun install --frozen-lockfile
- run: bun run lint
15 changes: 0 additions & 15 deletions .github/workflows/deno.yml

This file was deleted.

4 changes: 3 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1 +1,3 @@

.DS_Store
.vscode
node_modules
1 change: 1 addition & 0 deletions .xo-config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{ "prettier": true, "ignores": ["app/index.js"] }
49 changes: 31 additions & 18 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,26 +1,39 @@
# Based on https://github.com/denoland/deno_docker/blob/main/alpine.dockerfile
# syntax = docker/dockerfile:1

ARG BIN_IMAGE=denoland/deno:bin
FROM ${BIN_IMAGE} AS bin
# Adjust BUN_VERSION as desired
ARG BUN_VERSION=1.1.22
FROM oven/bun:${BUN_VERSION}-slim as base

FROM frolvlad/alpine-glibc:alpine-3.13
LABEL fly_launch_runtime="Bun"

RUN apk --no-cache add ca-certificates
# Bun app lives here
WORKDIR /app

RUN addgroup --gid 1000 deno \
&& adduser --uid 1000 --disabled-password deno --ingroup deno \
&& mkdir /deno-dir/ \
&& chown deno:deno /deno-dir/
# Set production environment
ENV NODE_ENV="production"

ENV DENO_DIR /deno-dir/
ENV DENO_INSTALL_ROOT /usr/local

ARG DENO_VERSION
ENV DENO_VERSION=${DENO_VERSION}
COPY --from=bin /deno /bin/deno
# Throw-away build stage to reduce size of final image
FROM base as build

WORKDIR /deno-dir
COPY . .
# Install packages needed to build node modules
RUN apt-get update -qq && \
apt-get install --no-install-recommends -y build-essential pkg-config python-is-python3

ENTRYPOINT ["/bin/deno"]
CMD ["run", "--allow-net", "https://deno.land/std/examples/echo_server.ts"]
# Install node modules
COPY --link bun.lockb package.json ./
RUN bun install --production

# Copy application code
COPY --link . .


# Final stage for app image
FROM base

# Copy built application
COPY --from=build /app /app

# Start the server by default, this can be overwritten at runtime
EXPOSE 8080
CMD [ "bun", "source/app.js" ]
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

<p align="center">
<a href="https://github.com/LitoMore/simple-icons-cdn/actions">
<img src="https://img.shields.io/github/actions/workflow/status/LitoMore/simple-icons-cdn/deno.yml?branch=main&logo=deno&logoColor=000&label=Deno&labelColor=fff"/>
<img src="https://img.shields.io/github/actions/workflow/status/LitoMore/simple-icons-cdn/bun.yml?branch=main&logo=bun&logoColor=fff&label=Bun&labelColor=333"/>
</a>
<a href="https://fly.io">
<img src="https://img.shields.io/badge/Powered_by_Fly.io-fff?logo=" />
Expand Down
Binary file added bun.lockb
Binary file not shown.
12 changes: 0 additions & 12 deletions deno.json

This file was deleted.

148 changes: 0 additions & 148 deletions deno.lock

This file was deleted.

4 changes: 2 additions & 2 deletions fly.toml
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,12 @@ primary_region = 'sjc'
PORT = '8080'

[processes]
app = 'run --allow-net ./source/app.js'
app = 'bun source/app.js'

[http_service]
internal_port = 8080
force_https = true
auto_stop_machines = false
auto_stop_machines = 'off'
auto_start_machines = true
min_machines_running = 3
processes = ['app']
Expand Down
14 changes: 14 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
{
"dependencies": {
"@oakserver/oak": "^14.1.0",
"simple-icons": "^13.5.0",
"svg-path-commander": "^2.0.9"
},
"devDependencies": {
"xo": "^0.59.3"
},
"scripts": {
"start": "bun source/app.js",
"lint": "xo"
}
}
68 changes: 33 additions & 35 deletions source/app.js
Original file line number Diff line number Diff line change
@@ -1,49 +1,47 @@
import { getIconSvg, getSimpleIcon } from "./icon.js";
import { Application } from "jsr:@oak/oak/application";
import { Router } from "jsr:@oak/oak/router";
import {Application, Router} from '@oakserver/oak';
import {getIconSvg, getSimpleIcon} from './icon.js';

const router = new Router();

router.get("/", (ctx) => {
ctx.response.headers.set(
"Cache-Control",
"public, max-age=86400, s-maxage=31536000, stale-while-revalidate=604800",
);
ctx.response.status = 307;
ctx.response.redirect("https://github.com/LitoMore/simple-icons-cdn");
router.get('/', (context) => {
context.response.headers.set(
'Cache-Control',
'public, max-age=86400, s-maxage=31536000, stale-while-revalidate=604800',
);
context.response.status = 307;
context.response.redirect('https://github.com/LitoMore/simple-icons-cdn');
});
router.get("/favicon.ico", (ctx) => {
ctx.response.headers.set(
"Cache-Control",
"public, max-age=31536000, s-maxage=31536000, immutable",
);
ctx.response.status = 204;
router.get('/favicon.ico', (context) => {
context.response.headers.set(
'Cache-Control',
'public, max-age=31536000, s-maxage=31536000, immutable',
);
context.response.status = 204;
});
router.get("/:iconSlug/:color?/:darkModeColor?", (ctx) => {
ctx.response.headers.set("Access-Control-Allow-Origin", "*");
ctx.response.headers.set(
"Cache-Control",
"public, max-age=86400, s-maxage=31536000, stale-while-revalidate=604800",
);
router.get('/:iconSlug/:color?/:darkModeColor?', (context) => {
context.response.headers.set('Access-Control-Allow-Origin', '*');
context.response.headers.set(
'Cache-Control',
'public, max-age=86400, s-maxage=31536000, stale-while-revalidate=604800',
);

const { iconSlug, color, darkModeColor } = ctx.params;
const viewbox = ctx.request.url.searchParams.get("viewbox");
const icon = getSimpleIcon(iconSlug);
const {iconSlug, color, darkModeColor} = context.params;
const viewbox = context.request.url.searchParams.get('viewbox');
const icon = getSimpleIcon(iconSlug);

if (icon) {
const iconSvg = getIconSvg(icon, color, darkModeColor, viewbox);
ctx.response.headers.set("Content-Type", "image/svg+xml");
ctx.response.body = iconSvg;
return;
}
if (icon) {
const iconSvg = getIconSvg(icon, color, darkModeColor, viewbox);
context.response.headers.set('Content-Type', 'image/svg+xml');
context.response.body = iconSvg;
return;
}

ctx.response.status = 404;
return;
context.response.status = 404;
});

const app = new Application();
app.use(router.routes());
app.use(router.allowedMethods());
app.listen({ port: 8080 });
app.listen({port: 8080});

console.log("Server running at http://localhost:8080/simpleicons");
console.log('Server running at http://localhost:8080/simpleicons');
Loading

0 comments on commit 759c116

Please sign in to comment.