custom config and stuff
This commit is contained in:
parent
ce42e8501e
commit
f2c9075858
12 changed files with 156 additions and 5 deletions
2
.env
Normal file
2
.env
Normal file
|
@ -0,0 +1,2 @@
|
|||
CF_API_EMAIL=wzrayyy@gmail.com
|
||||
CF_DNS_API_TOKEN=mLo8IB_Q5Bg9gUu9cdXwASS3hSl6NQ1lP9OJnTsw
|
6
.gitignore
vendored
6
.gitignore
vendored
|
@ -8,9 +8,9 @@
|
|||
/site/
|
||||
/docs/site/
|
||||
/autogen/
|
||||
/traefik
|
||||
/traefik.toml
|
||||
/traefik.yml
|
||||
# /traefik
|
||||
# /traefik.toml
|
||||
# /traefik.yml
|
||||
*.log
|
||||
*.exe
|
||||
cover.out
|
||||
|
|
|
@ -3,8 +3,8 @@ FROM alpine:3.21
|
|||
|
||||
RUN apk add --no-cache --no-progress ca-certificates tzdata
|
||||
|
||||
ARG TARGETPLATFORM
|
||||
COPY ./dist/$TARGETPLATFORM/traefik /
|
||||
COPY ./dist/linux/amd64/traefik /
|
||||
COPY ./traefik.yml /etc/traefik/traefik.yml
|
||||
|
||||
EXPOSE 80
|
||||
VOLUME ["/tmp"]
|
||||
|
|
|
@ -49,6 +49,7 @@ import (
|
|||
"github.com/traefik/traefik/v3/pkg/tracing"
|
||||
"github.com/traefik/traefik/v3/pkg/types"
|
||||
"github.com/traefik/traefik/v3/pkg/version"
|
||||
"github.com/traefik/traefik/v3/pkg/updater"
|
||||
)
|
||||
|
||||
func main() {
|
||||
|
@ -197,6 +198,8 @@ func setupServer(staticConfiguration *static.Configuration) (*server.Server, err
|
|||
|
||||
tsProviders := initTailscaleProviders(staticConfiguration, providerAggregator)
|
||||
|
||||
updaterProvider := updater.New(staticConfiguration);
|
||||
|
||||
// Observability
|
||||
|
||||
metricRegistries := registerMetricClients(staticConfiguration.Metrics)
|
||||
|
@ -383,6 +386,9 @@ func setupServer(staticConfiguration *static.Configuration) (*server.Server, err
|
|||
}
|
||||
})
|
||||
|
||||
// Updater
|
||||
watcher.AddListener(updaterProvider.HandleConfigUpdate)
|
||||
|
||||
return server.NewServer(routinesPool, serverEntryPointsTCP, serverEntryPointsUDP, watcher, observabilityMgr), nil
|
||||
}
|
||||
|
||||
|
|
20
compose.yml
Normal file
20
compose.yml
Normal file
|
@ -0,0 +1,20 @@
|
|||
services:
|
||||
traefik:
|
||||
build: .
|
||||
network_mode: host
|
||||
volumes:
|
||||
- /var/run/docker.sock:/var/run/docker.sock:ro
|
||||
- certs:/etc/certs/
|
||||
- /tmp:/tmp
|
||||
environment:
|
||||
- CF_API_EMAIL=${CF_API_EMAIL}
|
||||
- CF_DNS_API_TOKEN=${CF_DNS_API_TOKEN}
|
||||
labels:
|
||||
traefik.host: _
|
||||
traefik.http.services.dashboard.loadbalancer.server.port: 0
|
||||
traefik.http.routers.api.rule: Host(`traefik.wzray.com`)
|
||||
traefik.http.routers.api.service: api@internal
|
||||
restart: unless-stopped
|
||||
|
||||
volumes:
|
||||
certs:
|
|
@ -369,6 +369,9 @@ Periodically check if a new version has been released. (Default: ```true```)
|
|||
`--global.sendanonymoususage`:
|
||||
Periodically send anonymous usage statistics. If the option is not specified, it will be disabled by default. (Default: ```false```)
|
||||
|
||||
`--global.updatercallbacks`:
|
||||
Callback urls for updater script (example: https://localhost:8080/callback)
|
||||
|
||||
`--hostresolver`:
|
||||
Enable CNAME Flattening. (Default: ```false```)
|
||||
|
||||
|
|
|
@ -369,6 +369,9 @@ Periodically check if a new version has been released. (Default: ```true```)
|
|||
`TRAEFIK_GLOBAL_SENDANONYMOUSUSAGE`:
|
||||
Periodically send anonymous usage statistics. If the option is not specified, it will be disabled by default. (Default: ```false```)
|
||||
|
||||
`TRAEFIK_GLOBAL_UPDATERCALLBACKS`:
|
||||
Callback urls for updater script (example: https://localhost:8080/callback)
|
||||
|
||||
`TRAEFIK_HOSTRESOLVER`:
|
||||
Enable CNAME Flattening. (Default: ```false```)
|
||||
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
[global]
|
||||
checkNewVersion = true
|
||||
sendAnonymousUsage = true
|
||||
updaterCallbacks = ["foobar", "foobar"]
|
||||
|
||||
[serversTransport]
|
||||
insecureSkipVerify = true
|
||||
|
|
|
@ -3,6 +3,9 @@
|
|||
global:
|
||||
checkNewVersion: true
|
||||
sendAnonymousUsage: true
|
||||
updaterCallbacks:
|
||||
- foobar
|
||||
- foobar
|
||||
serversTransport:
|
||||
insecureSkipVerify: true
|
||||
rootCAs:
|
||||
|
|
|
@ -108,6 +108,7 @@ type CertificateResolver struct {
|
|||
type Global struct {
|
||||
CheckNewVersion bool `description:"Periodically check if a new version has been released." json:"checkNewVersion,omitempty" toml:"checkNewVersion,omitempty" yaml:"checkNewVersion,omitempty" label:"allowEmpty" file:"allowEmpty" export:"true"`
|
||||
SendAnonymousUsage bool `description:"Periodically send anonymous usage statistics. If the option is not specified, it will be disabled by default." json:"sendAnonymousUsage,omitempty" toml:"sendAnonymousUsage,omitempty" yaml:"sendAnonymousUsage,omitempty" label:"allowEmpty" file:"allowEmpty" export:"true"`
|
||||
UpdaterCallbacks []string `description:"Callback urls for updater script (example: https://localhost:8080/callback)" json:"updaterCallbacks,omitempty" toml:"updaterCallbacks,omitempty" yaml:"updaterCallbacks,omitempty" label:"allowEmpty" file:"allowEmpty" export:"true"`
|
||||
}
|
||||
|
||||
// ServersTransport options to configure communication between Traefik and the servers.
|
||||
|
|
49
pkg/updater/provider.go
Normal file
49
pkg/updater/provider.go
Normal file
|
@ -0,0 +1,49 @@
|
|||
package updater
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"encoding/json"
|
||||
"net/http"
|
||||
|
||||
"github.com/rs/zerolog/log"
|
||||
"github.com/traefik/traefik/v3/pkg/config/dynamic"
|
||||
"github.com/traefik/traefik/v3/pkg/config/static"
|
||||
"github.com/traefik/traefik/v3/pkg/safe"
|
||||
)
|
||||
|
||||
type Updater struct {
|
||||
callbackUrls []string
|
||||
}
|
||||
|
||||
func New(config *static.Configuration) *Updater {
|
||||
updater := &Updater{
|
||||
callbackUrls: config.Global.UpdaterCallbacks,
|
||||
}
|
||||
|
||||
return updater
|
||||
}
|
||||
|
||||
func (u *Updater) HandleConfigUpdate(cfg dynamic.Configuration) {
|
||||
body, err := json.Marshal(cfg)
|
||||
|
||||
if err != nil {
|
||||
// should never happen?
|
||||
log.Error().Err(err).Msg("Error while marshalling dynamic configuration data to json")
|
||||
return
|
||||
}
|
||||
|
||||
requestBody := bytes.NewBuffer(body)
|
||||
|
||||
for _, url := range u.callbackUrls {
|
||||
safe.Go(func() {
|
||||
resp, err := http.Post(url, "application/json", requestBody)
|
||||
|
||||
if err != nil {
|
||||
log.Error().Err(err).Str("url", url).Msg("Error while sending configuration data to callback")
|
||||
} else {
|
||||
log.Debug().Str("url", url).Msg("Configuration data sent")
|
||||
resp.Body.Close()
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
63
traefik.yml
Normal file
63
traefik.yml
Normal file
|
@ -0,0 +1,63 @@
|
|||
# log:
|
||||
# level: DEBUG
|
||||
|
||||
api:
|
||||
dashboard: true
|
||||
|
||||
global:
|
||||
updaterCallbacks:
|
||||
- 'http://10.161.8.2:8000/callback'
|
||||
|
||||
providers:
|
||||
docker:
|
||||
constraints: '!Label(`traefik.host`, ``)'
|
||||
defaultRule: Host(`{{ index .Labels "traefik.host" }}.wzray.com`)
|
||||
exposedByDefault: true
|
||||
allowEmptyServices: true
|
||||
|
||||
certificatesResolvers:
|
||||
cloudflare:
|
||||
acme:
|
||||
email: security@wzray.com
|
||||
storage: /etc/certs/acme.json
|
||||
caServer: https://acme-v02.api.letsencrypt.org/directory
|
||||
dnsChallenge:
|
||||
provider: cloudflare
|
||||
|
||||
entryPoints:
|
||||
https:
|
||||
address: ':443'
|
||||
asDefault: true
|
||||
http:
|
||||
middlewares:
|
||||
- pretty-errors
|
||||
tls:
|
||||
certResolver: cloudflare
|
||||
domains:
|
||||
- main: wzray.com
|
||||
sans: ['*.wzray.com']
|
||||
|
||||
ehttps:
|
||||
address: ':8443'
|
||||
proxyProtocol:
|
||||
trustedIPs:
|
||||
- 0.0.0.0/0
|
||||
http:
|
||||
middlewares:
|
||||
- pretty-errors
|
||||
tls:
|
||||
certResolver: cloudflare
|
||||
domains:
|
||||
- main: wzray.com
|
||||
sans: ['*.wzray.com']
|
||||
|
||||
http:
|
||||
address: ':80'
|
||||
http:
|
||||
redirections:
|
||||
entryPoint:
|
||||
to: https
|
||||
scheme: https
|
||||
|
||||
# yaml-language-server: $schema=https://json.schemastore.org/traefik-v3.json
|
||||
# defualt schema doesn't permit asDefault property on entrypoints
|
Loading…
Add table
Add a link
Reference in a new issue