Add files
This commit is contained in:
parent
1b598d853e
commit
57c9f0011e
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
email
|
||||||
|
|
||||||
|
errors/img
|
28
Caddyfile
Normal file
28
Caddyfile
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
# vim: ft=caddyfile
|
||||||
|
|
||||||
|
{
|
||||||
|
grace_period 60s
|
||||||
|
import email
|
||||||
|
#acme_ca "https://acme-staging-v02.api.letsencrypt.org/directory"
|
||||||
|
}
|
||||||
|
|
||||||
|
(basicerrors) {
|
||||||
|
handle_errors {
|
||||||
|
templates
|
||||||
|
rewrite * /index.html
|
||||||
|
root * /etc/caddy/errors
|
||||||
|
file_server
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
(hsts) {
|
||||||
|
header Strict-Transport-Security max-age=31536000
|
||||||
|
}
|
||||||
|
|
||||||
|
(log) {
|
||||||
|
log {
|
||||||
|
output file /var/log/caddy/access.log
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
import conf.d/*
|
18
conf.d/bbaovanc.com
Normal file
18
conf.d/bbaovanc.com
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
# vim: ft=caddyfile
|
||||||
|
|
||||||
|
www.bbaovanc.com {
|
||||||
|
redir https://bbaovanc.com{uri}
|
||||||
|
}
|
||||||
|
|
||||||
|
bbaovanc.com {
|
||||||
|
import hsts
|
||||||
|
import log
|
||||||
|
|
||||||
|
header Cache-Control no-cache
|
||||||
|
root * /var/www/bbaovanc.com/public
|
||||||
|
file_server {
|
||||||
|
precompressed br gzip
|
||||||
|
}
|
||||||
|
|
||||||
|
import basicerrors
|
||||||
|
}
|
13
conf.d/demo.bbaovanc.com
Normal file
13
conf.d/demo.bbaovanc.com
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
# vim: ft=caddyfile
|
||||||
|
|
||||||
|
demo.bbaovanc.com {
|
||||||
|
import hsts
|
||||||
|
|
||||||
|
header Cache-Control no-store
|
||||||
|
root * /var/www/demo.bbaovanc.com
|
||||||
|
file_server {
|
||||||
|
browse
|
||||||
|
}
|
||||||
|
|
||||||
|
import basicerrors
|
||||||
|
}
|
13
conf.d/drone.bbaovanc.com
Normal file
13
conf.d/drone.bbaovanc.com
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
# vim: ft=caddyfile
|
||||||
|
|
||||||
|
drone.bbaovanc.com {
|
||||||
|
encode zstd gzip
|
||||||
|
import hsts
|
||||||
|
import log
|
||||||
|
|
||||||
|
reverse_proxy localhost:8080 {
|
||||||
|
header_up X-Real-IP {remote_host}
|
||||||
|
}
|
||||||
|
|
||||||
|
import basicerrors
|
||||||
|
}
|
10
conf.d/errors.bbaovanc.com
Normal file
10
conf.d/errors.bbaovanc.com
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
# vim: ft=caddyfile
|
||||||
|
|
||||||
|
errors.bbaovanc.com {
|
||||||
|
encode zstd gzip
|
||||||
|
import hsts
|
||||||
|
import log
|
||||||
|
root * /etc/caddy/errors/img
|
||||||
|
file_server
|
||||||
|
import basicerrors
|
||||||
|
}
|
20
conf.d/git.bbaovanc.com
Normal file
20
conf.d/git.bbaovanc.com
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
# vim: ft=caddyfile
|
||||||
|
|
||||||
|
git.bbaovanc.com {
|
||||||
|
encode zstd gzip
|
||||||
|
import hsts
|
||||||
|
import log
|
||||||
|
|
||||||
|
handle_path /_/static/assets/* {
|
||||||
|
root * /var/www/git.bbaovanc.com/public
|
||||||
|
file_server
|
||||||
|
}
|
||||||
|
|
||||||
|
handle {
|
||||||
|
reverse_proxy localhost:81 {
|
||||||
|
header_up X-Real-IP {remote_host}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
import basicerrors
|
||||||
|
}
|
13
conf.d/media.bbaovanc.com
Normal file
13
conf.d/media.bbaovanc.com
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
# vim: ft=caddyfile
|
||||||
|
|
||||||
|
media.bbaovanc.com {
|
||||||
|
encode zstd gzip
|
||||||
|
import hsts
|
||||||
|
import log
|
||||||
|
|
||||||
|
root * /var/www/media.bbaovanc.com
|
||||||
|
file_server {
|
||||||
|
browse
|
||||||
|
}
|
||||||
|
import basicerrors
|
||||||
|
}
|
13
conf.d/remark.bbaovanc.com
Normal file
13
conf.d/remark.bbaovanc.com
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
# vim: ft=caddyfile
|
||||||
|
|
||||||
|
remark.bbaovanc.com {
|
||||||
|
encode zstd gzip
|
||||||
|
import hsts
|
||||||
|
import log
|
||||||
|
|
||||||
|
reverse_proxy localhost:82 {
|
||||||
|
header_up X-Real-IP {remote_host}
|
||||||
|
}
|
||||||
|
|
||||||
|
import basicerrors
|
||||||
|
}
|
9
conf.d/rick.bbaovanc.com
Normal file
9
conf.d/rick.bbaovanc.com
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# vim: ft=caddyfile
|
||||||
|
|
||||||
|
rick.bbaovanc.com {
|
||||||
|
encode zstd gzip
|
||||||
|
import hsts
|
||||||
|
import log
|
||||||
|
|
||||||
|
redir https://www.youtube.com/watch?v=dQw4w9WgXcQ;
|
||||||
|
}
|
77
conf.d/search.bbaovanc.com
Normal file
77
conf.d/search.bbaovanc.com
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
# vim: ft=caddyfile
|
||||||
|
|
||||||
|
search.bbaovanc.com {
|
||||||
|
encode zstd gzip
|
||||||
|
import hsts
|
||||||
|
import log
|
||||||
|
|
||||||
|
@api {
|
||||||
|
path /config
|
||||||
|
path /status
|
||||||
|
}
|
||||||
|
|
||||||
|
@static {
|
||||||
|
path /static/*
|
||||||
|
}
|
||||||
|
|
||||||
|
@morty {
|
||||||
|
path /morty/*
|
||||||
|
}
|
||||||
|
|
||||||
|
@notmorty {
|
||||||
|
not path /morty/*
|
||||||
|
}
|
||||||
|
|
||||||
|
header {
|
||||||
|
# Enable cross-site filter (XSS) and tell browser to block detected attacks
|
||||||
|
X-XSS-Protection "1; mode=block"
|
||||||
|
|
||||||
|
# Prevent some browsers from MIME-sniffing a response away from the declared Content-Type
|
||||||
|
X-Content-Type-Options "nosniff"
|
||||||
|
|
||||||
|
# Disallow the site to be rendered within a frame (clickjacking protection)
|
||||||
|
X-Frame-Options "SAMEORIGIN"
|
||||||
|
|
||||||
|
# Disable some features
|
||||||
|
Permissions-Policy "accelerometer=();ambient-light-sensor=(); autoplay=();camera=();encrypted-media=();focus-without-user-activation=(); geolocation=();gyroscope=();magnetometer=();microphone=();midi=();payment=();picture-in-picture=(); speaker=();sync-xhr=();usb=();vr=()"
|
||||||
|
|
||||||
|
# Disable some features (legacy)
|
||||||
|
Feature-Policy "accelerometer 'none';ambient-light-sensor 'none'; autoplay 'none';camera 'none';encrypted-media 'none';focus-without-user-activation 'none'; geolocation 'none';gyroscope 'none';magnetometer 'none';microphone 'none';midi 'none';payment 'none';picture-in-picture 'none'; speaker 'none';sync-xhr 'none';usb 'none';vr 'none'"
|
||||||
|
|
||||||
|
# Referer
|
||||||
|
Referrer-Policy "no-referrer"
|
||||||
|
|
||||||
|
# X-Robots-Tag
|
||||||
|
X-Robots-Tag "noindex, noarchive, nofollow"
|
||||||
|
}
|
||||||
|
|
||||||
|
header @api {
|
||||||
|
Access-Control-Allow-Methods "GET, OPTIONS"
|
||||||
|
Access-Control-Allow-Origin "*"
|
||||||
|
}
|
||||||
|
|
||||||
|
header @static {
|
||||||
|
#Cache-Control "public, max-age=31536000"
|
||||||
|
Cache-Control no-cache
|
||||||
|
defer
|
||||||
|
}
|
||||||
|
|
||||||
|
header @notmorty {
|
||||||
|
Content-Security-Policy "upgrade-insecure-requests; default-src 'none'; script-src 'self'; style-src 'self' 'unsafe-inline'; form-action 'self'; font-src 'self'; frame-ancestors 'self'; base-uri 'self'; connect-src 'self' https://overpass-api.de; img-src 'self' data: https://*.tile.openstreetmap.org; frame-src https://www.youtube-nocookie.com https://player.vimeo.com https://www.dailymotion.com https://www.deezer.com https://www.mixcloud.com https://w.soundcloud.com https://embed.spotify.com"
|
||||||
|
}
|
||||||
|
|
||||||
|
handle @morty {
|
||||||
|
header Content-Security-Policy "default-src 'none'; style-src 'self' 'unsafe-inline'; form-action 'self'; frame-ancestors 'self'; base-uri 'self'; img-src 'self' data:; font-src 'self'; frame-src 'self'"
|
||||||
|
reverse_proxy localhost:3000
|
||||||
|
}
|
||||||
|
|
||||||
|
handle {
|
||||||
|
reverse_proxy localhost:4040 {
|
||||||
|
header_up X-Forwarded-Port {http.request.port}
|
||||||
|
header_up X-Forwarded-TlsProto {tls_protocol}
|
||||||
|
header_up X-Forwarded-TlsCipher {tls_cipher}
|
||||||
|
header_up X-Forwarded-HttpsProto {proto}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
import basicerrors
|
5
errors/dl.sh
Executable file
5
errors/dl.sh
Executable file
@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/sh -x
|
||||||
|
|
||||||
|
mkdir -p img/
|
||||||
|
cd img/
|
||||||
|
curl https://http.cat | grep -oE '[0-9]{3}\.jpg' | sort | uniq | parallel $@ 'wget -q https://http.cat/{} && echo "DL {}"'
|
28
errors/index.html
Normal file
28
errors/index.html
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
{{ $code := placeholder "http.error.status_code" -}}
|
||||||
|
{{ $text := placeholder "http.error.status_text" -}}
|
||||||
|
{{ $host := placeholder "http.request.host" -}}
|
||||||
|
{{ $img_url := (printf "https://errors.bbaovanc.com/%s.jpg" $code) -}}
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>{{ $code }} {{ $text }}</title>
|
||||||
|
|
||||||
|
<meta name="title" content="{{ $code }} {{ $text }}" />
|
||||||
|
<meta name="description" content="{{ $code }} {{ $text }}" />
|
||||||
|
|
||||||
|
<meta property="og:title" content="{{ $code }} {{ $text }}" />
|
||||||
|
<meta property="og:description" content="{{ $code }} {{ $text }}" />
|
||||||
|
<meta property="og:image" content="{{ $img_url }}"/>
|
||||||
|
<meta property="og:site_name" content="{{ $host }}" />
|
||||||
|
|
||||||
|
<meta name="twitter:card" content="summary"/>
|
||||||
|
<meta name="twitter:image" content="{{ $img_url }}"/>
|
||||||
|
<meta name="twitter:title" content="{{ $code }} {{ $text }}" />
|
||||||
|
<meta name="twitter:description" content="{{ $code }} {{ $text }}" />
|
||||||
|
</head>
|
||||||
|
<body bgcolor="black" text="white">
|
||||||
|
<center>
|
||||||
|
<h1>{{ $code }} {{ $text }}</h1>
|
||||||
|
<img src='{{ $img_url }}' alt="cat" />
|
||||||
|
</center>
|
||||||
|
</body>
|
||||||
|
</html>
|
Loading…
Reference in New Issue
Block a user