tor-relay
ci/woodpecker/push/woodpecker Pipeline failed
Details
ci/woodpecker/push/woodpecker Pipeline failed
Details
This commit is contained in:
parent
c7a0c74236
commit
c6f62dfc63
|
@ -1,6 +1,6 @@
|
||||||
services:
|
services:
|
||||||
ferdium-server:
|
tor-relay:
|
||||||
build:
|
build:
|
||||||
context: ./docker/ferdium-server/
|
context: ./docker/tor-relay/
|
||||||
dockerfile: Dockerfile.production
|
dockerfile: Dockerfile.production
|
||||||
image: git.nixc.us/nixius/ferdium-server:production
|
image: git.nixc.us/nixius/tor-relay:production
|
|
@ -1,6 +1,6 @@
|
||||||
services:
|
services:
|
||||||
ferdium-server:
|
tor-relay:
|
||||||
build:
|
build:
|
||||||
context: ./docker/ferdium-server/
|
context: ./docker/tor-relay/
|
||||||
dockerfile: Dockerfile
|
dockerfile: Dockerfile
|
||||||
image: git.nixc.us/nixius/ferdium-server:staging
|
image: git.nixc.us/nixius/tor-relay:staging
|
||||||
|
|
|
@ -1 +0,0 @@
|
||||||
FROM ferdium/ferdium-server:latest
|
|
|
@ -0,0 +1,45 @@
|
||||||
|
# Stage 1: Build Tor from source on Alpine Linux
|
||||||
|
FROM alpine:latest AS builder
|
||||||
|
|
||||||
|
# Install necessary dependencies
|
||||||
|
RUN apk update && \
|
||||||
|
apk add --no-cache \
|
||||||
|
build-base \
|
||||||
|
libevent-dev \
|
||||||
|
openssl-dev \
|
||||||
|
zlib-dev \
|
||||||
|
asciidoc \
|
||||||
|
xmlto \
|
||||||
|
git
|
||||||
|
|
||||||
|
# Download and compile Tor
|
||||||
|
RUN git clone https://git.torproject.org/tor.git && \
|
||||||
|
cd tor && \
|
||||||
|
./autogen.sh && \
|
||||||
|
./configure && \
|
||||||
|
make && \
|
||||||
|
make install
|
||||||
|
|
||||||
|
# Stage 2: Create the final minimal image with Tor
|
||||||
|
FROM scratch
|
||||||
|
|
||||||
|
# Copy necessary files from the builder stage
|
||||||
|
COPY --from=builder /usr/local/bin/tor /usr/local/bin/tor
|
||||||
|
COPY --from=builder /usr/local/etc/tor /usr/local/etc/tor
|
||||||
|
COPY --from=builder /etc/ssl /etc/ssl
|
||||||
|
COPY --from=builder /lib/ld-musl-x86_64.so.1 /lib/ld-musl-x86_64.so.1
|
||||||
|
COPY --from=builder /lib/libevent-2.1.so.6 /lib/libevent-2.1.so.6
|
||||||
|
COPY --from=builder /lib/libssl.so.1.1 /lib/libssl.so.1.1
|
||||||
|
COPY --from=builder /lib/libcrypto.so.1.1 /lib/libcrypto.so.1.1
|
||||||
|
COPY --from=builder /lib/libz.so.1 /lib/libz.so.1
|
||||||
|
COPY --from=builder /lib/libgcc_s.so.1 /lib/libgcc_s.so.1
|
||||||
|
COPY --from=builder /lib/libc.musl-x86_64.so.1 /lib/libc.musl-x86_64.so.1
|
||||||
|
|
||||||
|
# Copy the torrc configuration file
|
||||||
|
COPY torrc /usr/local/etc/tor/torrc
|
||||||
|
|
||||||
|
# Expose Tor relay ports
|
||||||
|
EXPOSE 9001 9030
|
||||||
|
|
||||||
|
# Run Tor
|
||||||
|
CMD ["/usr/local/bin/tor", "-f", "/usr/local/etc/tor/torrc"]
|
|
@ -0,0 +1,14 @@
|
||||||
|
# torrc: Tor configuration file
|
||||||
|
|
||||||
|
# Define this as a relay-only node
|
||||||
|
SocksPort 0
|
||||||
|
ORPort 9001
|
||||||
|
DirPort 9030
|
||||||
|
ExitRelay 0
|
||||||
|
RelayBandwidthRate 100 KB
|
||||||
|
RelayBandwidthBurst 200 KB
|
||||||
|
Nickname YourRelayNickname
|
||||||
|
ContactInfo your-email@example.com
|
||||||
|
|
||||||
|
# Optionally, configure logs
|
||||||
|
Log notice stdout
|
|
@ -1,60 +1,12 @@
|
||||||
networks:
|
|
||||||
traefik:
|
|
||||||
external: true
|
|
||||||
default:
|
|
||||||
driver: overlay
|
|
||||||
services:
|
services:
|
||||||
ferdium:
|
tor-relay:
|
||||||
image: git.nixc.us/nixius/ferdium-server:production
|
image: git.nixc.us/nixius/tor-relay:production
|
||||||
networks:
|
|
||||||
- traefik
|
|
||||||
environment:
|
|
||||||
NODE_ENV: production
|
|
||||||
APP_URL: ferdium.nixc.us
|
|
||||||
DB_CONNECTION: sqlite
|
|
||||||
# Uncomment the lines below to use MySQL instead of SQLite
|
|
||||||
# DB_CONNECTION: mysql
|
|
||||||
# DB_HOST: <your-mysql-host>
|
|
||||||
# DB_PORT: 3306
|
|
||||||
# DB_USER: <your-mysql-user>
|
|
||||||
# DB_PASSWORD: <your-mysql-password>
|
|
||||||
# DB_DATABASE: ferdium
|
|
||||||
DB_SSL: "false"
|
|
||||||
MAIL_CONNECTION: smtp
|
|
||||||
SMTP_HOST: box.p.nixc.us
|
|
||||||
SMTP_PORT: 465
|
|
||||||
MAIL_SSL: "true"
|
|
||||||
MAIL_USERNAME: ferdium@nixc.us
|
|
||||||
MAIL_PASSWORD: dzUAQp3ZmjLN2tMq5XDoS6J29EdFqjntF
|
|
||||||
MAIL_SENDER: ferdium@nixc.us
|
|
||||||
IS_CREATION_ENABLED: "true"
|
|
||||||
IS_DASHBOARD_ENABLED: "true"
|
|
||||||
IS_REGISTRATION_ENABLED: "true"
|
|
||||||
CONNECT_WITH_FRANZ: "true"
|
|
||||||
DATA_DIR: /data
|
|
||||||
JWT_USE_PEM: "true"
|
|
||||||
volumes:
|
|
||||||
- /mnt/tank/persist/nixc.us/ferdium/production/data:/data
|
|
||||||
- /mnt/tank/persist/nixc.us/ferdium/production/recipes:/app/build/recipes
|
|
||||||
deploy:
|
deploy:
|
||||||
placement:
|
placement:
|
||||||
constraints:
|
constraints:
|
||||||
- node.hostname == macmini14
|
- node.hostname == macmini14
|
||||||
labels:
|
labels:
|
||||||
homepage.group: apps
|
traefik.enable: "false"
|
||||||
homepage.name: ferdium
|
|
||||||
homepage.href: https://ferdium.nixc.us/
|
|
||||||
homepage.description: ferdium
|
|
||||||
traefik.enable: "true"
|
|
||||||
traefik.http.routers.production-ferdium_ferdium.rule: "Host(`ferdium.nixc.us`)"
|
|
||||||
traefik.http.routers.production-ferdium_ferdium.entrypoints: "websecure"
|
|
||||||
traefik.http.routers.production-ferdium_ferdium.tls: "true"
|
|
||||||
traefik.http.routers.production-ferdium_ferdium.tls.certresolver: "letsencryptresolver"
|
|
||||||
traefik.http.routers.production-ferdium_ferdium.service: "production-ferdium_ferdium"
|
|
||||||
traefik.http.services.production-ferdium_ferdium.loadbalancer.server.port: "3333"
|
|
||||||
traefik.docker.network: "traefik"
|
|
||||||
# traefik.http.routers.production_ferdium.middlewares: 'authelia_authelia@docker'
|
|
||||||
# traefik.http.routers.production-ferdium_ferdium.middlewares: 'authelia_authelia@docker'
|
|
||||||
update_config:
|
update_config:
|
||||||
order: stop-first
|
order: stop-first
|
||||||
failure_action: rollback
|
failure_action: rollback
|
||||||
|
|
|
@ -1,35 +1,12 @@
|
||||||
networks:
|
|
||||||
traefik:
|
|
||||||
external: true
|
|
||||||
default:
|
|
||||||
driver: overlay
|
|
||||||
services:
|
services:
|
||||||
ferdium:
|
tor-relay:
|
||||||
image: git.nixc.us/nixius/ferdium-server:staging
|
image: git.nixc.us/nixius/tor-relay:staging
|
||||||
networks:
|
|
||||||
- traefik
|
|
||||||
# volumes:
|
|
||||||
# - /mnt/tank/persist/nixc.us/ferdium/staging/data:/data
|
|
||||||
# - /mnt/tank/persist/nixc.us/ferdium/staging/recipes:/app/build/recipes
|
|
||||||
deploy:
|
deploy:
|
||||||
placement:
|
placement:
|
||||||
constraints:
|
constraints:
|
||||||
- node.hostname == macmini14
|
- node.hostname == macmini14
|
||||||
labels:
|
labels:
|
||||||
homepage.group: apps
|
traefik.enable: "false"
|
||||||
homepage.name: ferdium
|
|
||||||
homepage.href: https://ferdium.nixc.us/
|
|
||||||
homepage.description: ferdium
|
|
||||||
traefik.enable: "true"
|
|
||||||
traefik.http.routers.staging-ferdium_ferdium.rule: "Host(`ferdium.nixc.us`)"
|
|
||||||
traefik.http.routers.staging-ferdium_ferdium.entrypoints: "websecure"
|
|
||||||
traefik.http.routers.staging-ferdium_ferdium.tls: "true"
|
|
||||||
traefik.http.routers.staging-ferdium_ferdium.tls.certresolver: "letsencryptresolver"
|
|
||||||
traefik.http.routers.staging-ferdium_ferdium.service: "staging-ferdium_ferdium"
|
|
||||||
traefik.http.services.staging-ferdium_ferdium.loadbalancer.server.port: "3333"
|
|
||||||
traefik.docker.network: "traefik"
|
|
||||||
# traefik.http.routers.staging_ferdium.middlewares: 'authelia_authelia@docker'
|
|
||||||
traefik.http.routers.staging-ferdium_ferdium.middlewares: 'authelia_authelia@docker'
|
|
||||||
update_config:
|
update_config:
|
||||||
order: stop-first
|
order: stop-first
|
||||||
failure_action: rollback
|
failure_action: rollback
|
||||||
|
|
Loading…
Reference in New Issue