Compare commits

..

5 commits
blog ... main

Author SHA1 Message Date
7038e47c75 fix: filter
filter also reacting to external posts
2025-07-17 13:48:11 +02:00
5681454b61 fix: og-image => thumbnail
renamed og-image to thumbnail for external blog posts
2025-07-17 13:39:38 +02:00
23a01e782a add: health check
health check
2025-07-15 13:28:17 +02:00
7ad780be6c Merge branch 'blog' 2025-07-15 13:17:50 +02:00
2c42f24d0f add: blog
blog post
2025-07-15 08:19:19 +02:00
4 changed files with 62 additions and 13 deletions

View file

@ -48,24 +48,13 @@ const firstTen = computed<BlogCard[]>(() => {
return (articles.value?.slice(0, 10) ?? []).map(makeBlogCard)
})
const allCategoriesAndCount = computed<Record<Category, number>>(() => {
const categories = {} as Record<Category, number>
articles.value?.forEach(article => {
const category = article.category as Category
if (category) {
categories[category] = (categories[category] ?? 0) + 1
}
})
return categories
})
const { data: externalPostsRaw } = useFetch('/api/external-posts', { method: 'POST' })
const externalPosts = computed<BlogCard[]>(() => externalPostsRaw.value?.flatMap(externalBlog => {
return externalBlog.posts.map(post => ({
title: post.title,
description: post.excerpt,
image: post['og-image'],
image: post.thumbnail,
date: post.date,
link: post.url,
category: 'extern',
@ -75,6 +64,18 @@ const externalPosts = computed<BlogCard[]>(() => externalPostsRaw.value?.flatMap
const allPosts = computed<BlogCard[]>(() => [...(firstTen.value ?? []), ...(externalPosts.value ?? [])].sort((a, b) => new Date(b.date).getTime() - new Date(a.date).getTime()))
const allCategoriesAndCount = computed<Record<Category, number>>(() => {
const categories = {} as Record<Category, number>
articles.value?.forEach(article => {
const category = article.category as Category
if (category) {
categories[category] = (categories[category] ?? 0) + 1
}
})
categories['extern'] = externalPosts.value?.length ?? 0
return categories
})
const makeBlogCard = (article: BlogCollectionItem): BlogCard => ({
title: article.title,
description: article.description,

47
docker-compose.yaml Normal file
View file

@ -0,0 +1,47 @@
version: '3'
services:
wf4:
image: oven/bun:latest
container_name: wf4
working_dir: /app
ports:
- "1337:3000"
volumes:
- wf4_data:/app
environment:
- NODE_ENV=production
command: >
sh -c "
# Install git and curl if not already installed
if ! command -v git &> /dev/null || ! command -v curl &> /dev/null; then
echo 'Installing required packages...'
apt-get update && apt-get install -y git curl
fi &&
# Clone repository if not already cloned
if [ ! -d /app/.git ]; then
echo 'Cloning repository...'
git clone https://git.webfussel.de/webfussel/wf4 /tmp/wf4 &&
cp -r /tmp/wf4/. /app/ &&
rm -rf /tmp/wf4
fi &&
# Install dependencies and start application
echo 'Installing dependencies...' &&
bun install &&
echo 'Building application...' &&
bun run build &&
echo 'Starting application...' &&
bun .output/server/index.mjs
"
restart: unless-stopped
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:1337"]
interval: 30s
timeout: 10s
retries: 3
start_period: 40s
volumes:
wf4_data:

1
server/api/health.get.ts Normal file
View file

@ -0,0 +1 @@
export default defineEventHandler((): string => 'ok' )

View file

@ -3,7 +3,7 @@ export type Post = {
title: string
excerpt: string
date: string
'og-image': string
thumbnail: string
}
type Author = {