Compare commits
18 Commits
3df25da009
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| 387ef209ab | |||
| 3b27cbd194 | |||
| 61842ebc70 | |||
| 4e2418116f | |||
| c1fd535549 | |||
| 78f5da9cff | |||
| b283816713 | |||
| c77bf3e757 | |||
| 36b2053642 | |||
| c3898170fd | |||
| 4cc1b21c05 | |||
| e41334a7cc | |||
| 47743e9239 | |||
| d271378912 | |||
| 4cc6c4f210 | |||
| fde4adfad5 | |||
| 3e530e0ac5 | |||
| d8153ed619 |
167
.woodpecker.yml
167
.woodpecker.yml
@ -1,4 +1,85 @@
|
|||||||
steps:
|
steps:
|
||||||
|
audit_dependencies:
|
||||||
|
image: node:20
|
||||||
|
commands:
|
||||||
|
- npm install --package-lock-only
|
||||||
|
- npm audit --audit-level=moderate --json > audit-result.json 2>&1 || echo "Audit completed"
|
||||||
|
- npm audit --audit-level=moderate > audit-output.txt 2>&1 || echo "Audit completed"
|
||||||
|
when:
|
||||||
|
- branch: main
|
||||||
|
event: push
|
||||||
|
|
||||||
|
discord_notify_audit:
|
||||||
|
image: alpine:latest
|
||||||
|
environment:
|
||||||
|
DISCORD_WEBHOOK:
|
||||||
|
from_secret: discord_webhook
|
||||||
|
commands:
|
||||||
|
- apk add --no-cache curl jq
|
||||||
|
- |
|
||||||
|
if [ -f audit-result.json ]; then
|
||||||
|
TOTAL=$(jq -r '.metadata.vulnerabilities.total // 0' audit-result.json 2>/dev/null || echo "0")
|
||||||
|
CRITICAL=$(jq -r '.metadata.vulnerabilities.critical // 0' audit-result.json 2>/dev/null || echo "0")
|
||||||
|
HIGH=$(jq -r '.metadata.vulnerabilities.high // 0' audit-result.json 2>/dev/null || echo "0")
|
||||||
|
MODERATE=$(jq -r '.metadata.vulnerabilities.moderate // 0' audit-result.json 2>/dev/null || echo "0")
|
||||||
|
LOW=$(jq -r '.metadata.vulnerabilities.low // 0' audit-result.json 2>/dev/null || echo "0")
|
||||||
|
|
||||||
|
if [ "$CRITICAL" -gt 0 ] || [ "$HIGH" -gt 0 ] || [ "$MODERATE" -gt 0 ]; then
|
||||||
|
COLOR=16744448
|
||||||
|
STATUS="⚠️ Vulnerabilities Found"
|
||||||
|
else
|
||||||
|
COLOR=3066993
|
||||||
|
STATUS="✅ No Vulnerabilities"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f audit-output.txt ]; then
|
||||||
|
VULNS=$(head -50 audit-output.txt | tail -40 || echo "No details")
|
||||||
|
else
|
||||||
|
VULNS="No audit output available"
|
||||||
|
fi
|
||||||
|
|
||||||
|
printf '%s' "$VULNS" > /tmp/vulns.txt
|
||||||
|
|
||||||
|
PAYLOAD=$(jq -n \
|
||||||
|
--arg title "🔒 Security Audit - Build #${CI_BUILD_NUMBER}" \
|
||||||
|
--arg status "$STATUS" \
|
||||||
|
--arg total "$TOTAL" \
|
||||||
|
--arg critical "$CRITICAL" \
|
||||||
|
--arg high "$HIGH" \
|
||||||
|
--arg moderate "$MODERATE" \
|
||||||
|
--arg low "$LOW" \
|
||||||
|
--arg commit "${CI_COMMIT_SHA:0:7}" \
|
||||||
|
--rawfile details /tmp/vulns.txt \
|
||||||
|
--arg timestamp "$(date -u +%Y-%m-%dT%H:%M:%S.000Z)" \
|
||||||
|
--argjson color "$COLOR" \
|
||||||
|
'{
|
||||||
|
embeds: [{
|
||||||
|
title: $title,
|
||||||
|
description: $status,
|
||||||
|
color: $color,
|
||||||
|
fields: [
|
||||||
|
{ name: "Total", value: $total, inline: true },
|
||||||
|
{ name: "Critical", value: $critical, inline: true },
|
||||||
|
{ name: "High", value: $high, inline: true },
|
||||||
|
{ name: "Moderate", value: $moderate, inline: true },
|
||||||
|
{ name: "Low", value: $low, inline: true },
|
||||||
|
{ name: "Commit", value: ("`" + $commit + "`"), inline: true },
|
||||||
|
{ name: "Details", value: ("```\n" + ($details[:800]) + (if ($details | length) > 800 then "\n... (truncated)" else "" end) + "\n```"), inline: false }
|
||||||
|
],
|
||||||
|
timestamp: $timestamp
|
||||||
|
}]
|
||||||
|
}')
|
||||||
|
|
||||||
|
curl -H "Content-Type: application/json" -X POST \
|
||||||
|
-d "$PAYLOAD" "$DISCORD_WEBHOOK"
|
||||||
|
else
|
||||||
|
echo "No audit results found - listing workspace files:"
|
||||||
|
ls -la
|
||||||
|
fi
|
||||||
|
when:
|
||||||
|
- branch: main
|
||||||
|
event: push
|
||||||
|
|
||||||
deploy_frontend:
|
deploy_frontend:
|
||||||
image: node:20
|
image: node:20
|
||||||
environment:
|
environment:
|
||||||
@ -9,5 +90,87 @@ steps:
|
|||||||
- export PATH="$HOME/.fly/bin:$PATH"
|
- export PATH="$HOME/.fly/bin:$PATH"
|
||||||
- flyctl deploy --config fly.toml --app gallus-pub --remote-only
|
- flyctl deploy --config fly.toml --app gallus-pub --remote-only
|
||||||
when:
|
when:
|
||||||
branch: main
|
- branch: main
|
||||||
event: push
|
event: push
|
||||||
|
|
||||||
|
notify_success:
|
||||||
|
image: alpine:latest
|
||||||
|
environment:
|
||||||
|
DISCORD_WEBHOOK:
|
||||||
|
from_secret: discord_webhook
|
||||||
|
commands:
|
||||||
|
- apk add --no-cache curl jq
|
||||||
|
- |
|
||||||
|
# Schreibe Commit-Message in Datei (sicher gegen Shell-Sonderzeichen)
|
||||||
|
printf '%s\n' "$CI_COMMIT_MESSAGE" > /tmp/commit_msg.txt
|
||||||
|
|
||||||
|
PAYLOAD=$(cat /tmp/commit_msg.txt | jq -Rs \
|
||||||
|
--arg title "✅ Build #${CI_BUILD_NUMBER} - Success" \
|
||||||
|
--arg repo "${CI_REPO}" \
|
||||||
|
--arg branch "${CI_COMMIT_BRANCH}" \
|
||||||
|
--arg commit "${CI_COMMIT_SHA:0:7}" \
|
||||||
|
--arg author "${CI_COMMIT_AUTHOR}" \
|
||||||
|
--arg timestamp "$(date -u +%Y-%m-%dT%H:%M:%S.000Z)" \
|
||||||
|
'. as $message | {
|
||||||
|
embeds: [{
|
||||||
|
title: $title,
|
||||||
|
description: "Build und Deployment erfolgreich abgeschlossen!",
|
||||||
|
color: 3066993,
|
||||||
|
fields: [
|
||||||
|
{ name: "Repository", value: $repo, inline: true },
|
||||||
|
{ name: "Branch", value: $branch, inline: true },
|
||||||
|
{ name: "Commit", value: ("`" + $commit + "`"), inline: true },
|
||||||
|
{ name: "Author", value: $author, inline: true },
|
||||||
|
{ name: "Commit Message", value: $message, inline: false }
|
||||||
|
],
|
||||||
|
timestamp: $timestamp
|
||||||
|
}]
|
||||||
|
}')
|
||||||
|
|
||||||
|
curl -H "Content-Type: application/json" -X POST \
|
||||||
|
-d "$PAYLOAD" "$DISCORD_WEBHOOK"
|
||||||
|
when:
|
||||||
|
- branch: main
|
||||||
|
event: push
|
||||||
|
status: success
|
||||||
|
|
||||||
|
notify_failure:
|
||||||
|
image: alpine:latest
|
||||||
|
environment:
|
||||||
|
DISCORD_WEBHOOK:
|
||||||
|
from_secret: discord_webhook
|
||||||
|
commands:
|
||||||
|
- apk add --no-cache curl jq
|
||||||
|
- |
|
||||||
|
# Schreibe Commit-Message in Datei (sicher gegen Shell-Sonderzeichen)
|
||||||
|
printf '%s\n' "$CI_COMMIT_MESSAGE" > /tmp/commit_msg.txt
|
||||||
|
|
||||||
|
PAYLOAD=$(cat /tmp/commit_msg.txt | jq -Rs \
|
||||||
|
--arg title "❌ Build #${CI_BUILD_NUMBER} - Failure" \
|
||||||
|
--arg repo "${CI_REPO}" \
|
||||||
|
--arg branch "${CI_COMMIT_BRANCH}" \
|
||||||
|
--arg commit "${CI_COMMIT_SHA:0:7}" \
|
||||||
|
--arg author "${CI_COMMIT_AUTHOR}" \
|
||||||
|
--arg timestamp "$(date -u +%Y-%m-%dT%H:%M:%S.000Z)" \
|
||||||
|
'. as $message | {
|
||||||
|
embeds: [{
|
||||||
|
title: $title,
|
||||||
|
description: "Build oder Deployment ist fehlgeschlagen!",
|
||||||
|
color: 15158332,
|
||||||
|
fields: [
|
||||||
|
{ name: "Repository", value: $repo, inline: true },
|
||||||
|
{ name: "Branch", value: $branch, inline: true },
|
||||||
|
{ name: "Commit", value: ("`" + $commit + "`"), inline: true },
|
||||||
|
{ name: "Author", value: $author, inline: true },
|
||||||
|
{ name: "Commit Message", value: $message, inline: false }
|
||||||
|
],
|
||||||
|
timestamp: $timestamp
|
||||||
|
}]
|
||||||
|
}')
|
||||||
|
|
||||||
|
curl -H "Content-Type: application/json" -X POST \
|
||||||
|
-d "$PAYLOAD" "$DISCORD_WEBHOOK"
|
||||||
|
when:
|
||||||
|
- branch: main
|
||||||
|
event: push
|
||||||
|
status: failure
|
||||||
@ -1,7 +1,6 @@
|
|||||||
import { sqliteTable, text, integer } from 'drizzle-orm/sqlite-core';
|
import { sqliteTable, text, integer } from 'drizzle-orm/sqlite-core';
|
||||||
import { sql } from 'drizzle-orm';
|
import { sql } from 'drizzle-orm';
|
||||||
|
|
||||||
// Users table - stores Gitea user info for audit and access control
|
|
||||||
export const users = sqliteTable('users', {
|
export const users = sqliteTable('users', {
|
||||||
id: text('id').primaryKey().$defaultFn(() => crypto.randomUUID()),
|
id: text('id').primaryKey().$defaultFn(() => crypto.randomUUID()),
|
||||||
giteaId: text('gitea_id').notNull().unique(),
|
giteaId: text('gitea_id').notNull().unique(),
|
||||||
|
|||||||
@ -43,6 +43,7 @@ export class FileGeneratorService {
|
|||||||
|
|
||||||
return `---
|
return `---
|
||||||
import Layout from "../components/Layout.astro";
|
import Layout from "../components/Layout.astro";
|
||||||
|
import Banner from "../components/Banner.astro";
|
||||||
import Hero from "../components/Hero.astro";
|
import Hero from "../components/Hero.astro";
|
||||||
import Welcome from "../components/Welcome.astro";
|
import Welcome from "../components/Welcome.astro";
|
||||||
import EventsGrid from "../components/EventsGrid.astro";
|
import EventsGrid from "../components/EventsGrid.astro";
|
||||||
@ -62,6 +63,7 @@ ${imagesCode}
|
|||||||
|
|
||||||
<Layout>
|
<Layout>
|
||||||
\t<Hero id="hero" />
|
\t<Hero id="hero" />
|
||||||
|
\t<Banner />
|
||||||
\t<Welcome id="welcome" />
|
\t<Welcome id="welcome" />
|
||||||
\t<EventsGrid id="events" events={events} />
|
\t<EventsGrid id="events" events={events} />
|
||||||
\t<ImageCarousel id="gallery" images={images} />
|
\t<ImageCarousel id="gallery" images={images} />
|
||||||
|
|||||||
1092
package-lock.json
generated
1092
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
BIN
public/images/events/mk6wdnz2-rpxzvl.jpeg
Normal file
BIN
public/images/events/mk6wdnz2-rpxzvl.jpeg
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 156 KiB |
@ -31,6 +31,10 @@ import "../styles/components/Banner.css"
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Load banner when page loads
|
// Load banner when DOM is ready
|
||||||
loadBanner();
|
if (document.readyState === 'loading') {
|
||||||
|
document.addEventListener('DOMContentLoaded', loadBanner);
|
||||||
|
} else {
|
||||||
|
loadBanner();
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
@ -1,8 +1,10 @@
|
|||||||
---
|
---
|
||||||
import Layout from "../components/Layout.astro";
|
import Layout from "../components/Layout.astro";
|
||||||
|
import Banner from "../components/Banner.astro";
|
||||||
---
|
---
|
||||||
|
|
||||||
<Layout>
|
<Layout>
|
||||||
|
<Banner />
|
||||||
|
|
||||||
<h1>Gallery</h1>
|
<h1>Gallery</h1>
|
||||||
|
|
||||||
|
|||||||
@ -1,8 +1,10 @@
|
|||||||
---
|
---
|
||||||
import Layout from "../components/Layout.astro";
|
import Layout from "../components/Layout.astro";
|
||||||
|
import Banner from "../components/Banner.astro";
|
||||||
---
|
---
|
||||||
|
|
||||||
<Layout>
|
<Layout>
|
||||||
|
<Banner />
|
||||||
|
|
||||||
<h1>Openings</h1>
|
<h1>Openings</h1>
|
||||||
|
|
||||||
|
|||||||
@ -1,5 +1,6 @@
|
|||||||
---
|
---
|
||||||
import Layout from "../components/Layout.astro";
|
import Layout from "../components/Layout.astro";
|
||||||
|
import Banner from "../components/Banner.astro";
|
||||||
import Hero from "../components/Hero.astro";
|
import Hero from "../components/Hero.astro";
|
||||||
import Welcome from "../components/Welcome.astro";
|
import Welcome from "../components/Welcome.astro";
|
||||||
import EventsGrid from "../components/EventsGrid.astro";
|
import EventsGrid from "../components/EventsGrid.astro";
|
||||||
@ -26,32 +27,6 @@ const events = [
|
|||||||
Plätze sind begrenzt! Jetzt reservieren unter 🍀WA 077 232 27 70
|
Plätze sind begrenzt! Jetzt reservieren unter 🍀WA 077 232 27 70
|
||||||
`,
|
`,
|
||||||
},
|
},
|
||||||
{
|
|
||||||
image: "/images/events/mj67ssjo-sp3i0e.jpeg",
|
|
||||||
title: "Adventskalender",
|
|
||||||
date: "2025-12-03",
|
|
||||||
description: `
|
|
||||||
Jeden Tag neue Überraschungen!
|
|
||||||
Check unsere Social Media Stories oder komm am besten gleich vorbei!
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
image: "/images/events/miyxej2c-7l8end.jpeg",
|
|
||||||
title: "Ferien Flyer",
|
|
||||||
date: "2026-01-02",
|
|
||||||
description: `
|
|
||||||
Wir sind ab 02.01.2026 wieder wie gewohnt für euch da! 🍀Für Anfragen WA 077 232 27 70 Antwort innerhalb 48h
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
image: "/images/events/mjbgwbzv-n60vrw.jpeg",
|
|
||||||
title: "New Year Apero",
|
|
||||||
date: "2026-01-02",
|
|
||||||
description: `
|
|
||||||
Wir stossen mit euch an!
|
|
||||||
Freitag 02.01. bereits ab 18:00 OFFEN!
|
|
||||||
`,
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
image: "/images/events/mjbgxwyk-ygcymt.jpeg",
|
image: "/images/events/mjbgxwyk-ygcymt.jpeg",
|
||||||
title: "Schlager Flyer",
|
title: "Schlager Flyer",
|
||||||
@ -69,6 +44,16 @@ Plätze reservieren unter WA 077 232 27 70
|
|||||||
description: `
|
description: `
|
||||||
Celtic Folk Night im Gallus Pub!✨🌿20:30Uhr Eintritt ist Frei/Hutkollekte. Reservation via WA 077 232 27 70
|
Celtic Folk Night im Gallus Pub!✨🌿20:30Uhr Eintritt ist Frei/Hutkollekte. Reservation via WA 077 232 27 70
|
||||||
`,
|
`,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
image: "/images/events/mk6wdnz2-rpxzvl.jpeg",
|
||||||
|
title: "Pg Petricca - LIVE",
|
||||||
|
date: "2026-03-20",
|
||||||
|
description: `
|
||||||
|
LIVE Musik mit Pg Petricca! - Folk & Blues.
|
||||||
|
Eintritt ist Frei / Hutkollekte
|
||||||
|
Reservation unter 🍀WA 077 232 27 70
|
||||||
|
`,
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
@ -87,6 +72,7 @@ const images = [
|
|||||||
|
|
||||||
<Layout>
|
<Layout>
|
||||||
<Hero id="hero" />
|
<Hero id="hero" />
|
||||||
|
<Banner />
|
||||||
<Welcome id="welcome" />
|
<Welcome id="welcome" />
|
||||||
<EventsGrid id="events" events={events} />
|
<EventsGrid id="events" events={events} />
|
||||||
<ImageCarousel id="gallery" images={images} />
|
<ImageCarousel id="gallery" images={images} />
|
||||||
|
|||||||
Reference in New Issue
Block a user