423 lines
14 KiB
YAML
423 lines
14 KiB
YAML
kernel:
|
|
#image: nemunaire/kernel:5.10.62-0b705d955f5e283f62583c4e227d64a7924c138f-amd64
|
|
image: linuxkit/kernel:5.10.104
|
|
cmdline: "console=ttyS0 console=tty0"
|
|
|
|
init:
|
|
- linuxkit/init:8f1e6a0747acbbb4d7e24dc98f97faa8d1c6cec7
|
|
- linuxkit/runc:f01b88c7033180d50ae43562d72707c6881904e4
|
|
- linuxkit/containerd:de1b18eed76a266baa3092e5c154c84f595e56da
|
|
- linuxkit/ca-certificates:c1c73ef590dffb6a0138cf758fe4a4305c9864f4
|
|
- linuxkit/getty:76951a596aa5e0867a38e28f0b94d620e948e3e8
|
|
- nemunaire/mdadm:3886edd37c79d5f8000e4f3c4bacaff1f6302aa3
|
|
- nemunaire/kexec:db743618d3674729088d64b5d303e4b7d7ff148b
|
|
|
|
onboot:
|
|
- name: mod
|
|
image: linuxkit/modprobe:1b59b4f2ebb877085ea0d8d3a41cf06f64c09a15
|
|
command: ["/bin/sh", "-c", "modprobe xhci_pci ahci intel_lpss_pci i2c_i801 megaraid_sas tg3 bnxt_en"]
|
|
|
|
- name: sysctl
|
|
image: linuxkit/sysctl:bdc99eeedc224439ff237990ee06e5b992c8c1ae
|
|
binds:
|
|
- /etc/sysctl.d/01-fic.conf:/etc/sysctl.d/01-fic.conf:ro
|
|
|
|
# Filesystem
|
|
- name: swap
|
|
image: linuxkit/swap:77305236719ed7ab4be0f3bccc179c583fe7f5ff
|
|
command: ["/sbin/swapon", "/dev/sda2"]
|
|
- name: dm-crypt
|
|
image: linuxkit/dm-crypt:908d3a270650aff7388092a307673c44d86e1ed0
|
|
command: ["/usr/bin/crypto", "-l", "crypt_fic", "/dev/sda3"]
|
|
- name: mount
|
|
image: linuxkit/mount:422b219bb1c7051096126ac83e6dcc8b2f3f1176
|
|
command: ["/usr/bin/mountie", "-device", "/dev/mapper/crypt_fic", "/var/lib/fic" ]
|
|
|
|
# Network
|
|
# - name: dhcpcd
|
|
# image: linuxkit/dhcpcd:52d2c4df0311b182e99241cdc382ff726755c450
|
|
# command: ["/sbin/dhcpcd", "--nobackground", "-f", "/dhcpcd.conf", "-1"]
|
|
# - name: ntp
|
|
# image: linuxkit/openntpd:d6c36ac367ed26a6eeffd8db78334d9f8041b038
|
|
- name: synchro-ip-setup
|
|
image: linuxkit/ip:6cc44dd4e18ddb02de01bc4b34b5799971b6a7bf
|
|
command: ["/bin/sh", "-c", "ip a add 10.10.10.1/29 dev eth2; ip link set eth2 up;" ]
|
|
net: new
|
|
runtime:
|
|
interfaces:
|
|
- name: eth2
|
|
bindNS:
|
|
net: /run/netns/synchro
|
|
- name: admin-ip-setup
|
|
image: linuxkit/ip:6cc44dd4e18ddb02de01bc4b34b5799971b6a7bf
|
|
#command: ["/bin/sh", "-c", "ip link add link eth3 name adminiface type vlan id 99; ip a add 172.16.99.219/24 dev adminiface; ip link set eth3 up; ip link set adminiface up; ip r add default via 172.16.99.1; ip a add 172.17.0.2/24 dev vethin-admin; ip link set vethin-admin up; ping -W 10 -c 1 172.16.99.1;" ]
|
|
command: ["/bin/sh", "-c", "ip a add 192.168.49.10/24 dev eth3; ip link set eth3 up; ip r add default via 192.168.49.1; ip a add 172.17.0.2/24 dev vethin-admin; ip link set vethin-admin up; ping -W 10 -c 1 192.168.49.1;" ]
|
|
net: new
|
|
runtime:
|
|
interfaces:
|
|
- name: eth3
|
|
- name: vethin-admin
|
|
add: veth
|
|
peer: veth-admin
|
|
bindNS:
|
|
net: /run/netns/fic-admin
|
|
- name: backend-ip-setup
|
|
image: linuxkit/ip:6cc44dd4e18ddb02de01bc4b34b5799971b6a7bf
|
|
command: ["/bin/sh", "-c", "ip a add 172.17.0.3/24 dev vethin-backend; ip link set vethin-backend up;" ]
|
|
net: new
|
|
runtime:
|
|
interfaces:
|
|
- name: vethin-backend
|
|
add: veth
|
|
peer: veth-backend
|
|
bindNS:
|
|
net: /run/netns/fic-backend
|
|
- name: mysql-ip-setup
|
|
image: linuxkit/ip:6cc44dd4e18ddb02de01bc4b34b5799971b6a7bf
|
|
command: ["/bin/sh", "-c", "ip a add 172.17.0.4/24 dev vethin-db; ip link set vethin-db up;" ]
|
|
net: new
|
|
runtime:
|
|
interfaces:
|
|
- name: vethin-db
|
|
add: veth
|
|
peer: veth-db
|
|
bindNS:
|
|
net: /run/netns/db
|
|
- name: bridge-setup
|
|
image: linuxkit/ip:6cc44dd4e18ddb02de01bc4b34b5799971b6a7bf
|
|
command: ["/bin/sh", "-c", "ip a add 172.17.0.1/24 dev br0; ip link set veth-admin master br0; ip link set veth-backend master br0; ip link set veth-db master br0; ip link set br0 up; ip link set veth-admin up; ip link set veth-backend up; ip link set veth-db up;" ]
|
|
runtime:
|
|
interfaces:
|
|
- name: br0
|
|
add: bridge
|
|
|
|
- name: firewall-synchro
|
|
image: linuxkit/ip:6cc44dd4e18ddb02de01bc4b34b5799971b6a7bf
|
|
command: ["/bin/bash", "-c", "/sbin/iptables-restore < /etc/iptables/rules-synchro.v4; /sbin/ip6tables-restore < /etc/iptables/rules.v6" ]
|
|
binds:
|
|
- /etc/iptables/rules-synchro.v4:/etc/iptables/rules-synchro.v4:ro
|
|
- /etc/iptables/rules.v6:/etc/iptables/rules.v6:ro
|
|
net: /run/netns/synchro
|
|
runtime:
|
|
mkdir:
|
|
- /var/lib/fic/teams
|
|
- name: firewall-admin
|
|
image: linuxkit/ip:6cc44dd4e18ddb02de01bc4b34b5799971b6a7bf
|
|
command: ["/bin/bash", "-c", "/sbin/iptables-restore < /etc/iptables/rules-admin.v4; /sbin/ip6tables-restore < /etc/iptables/rules.v6" ]
|
|
binds:
|
|
- /etc/iptables/rules-admin.v4:/etc/iptables/rules-admin.v4:ro
|
|
- /etc/iptables/rules.v6:/etc/iptables/rules.v6:ro
|
|
net: /run/netns/fic-admin
|
|
|
|
services:
|
|
# - name: getty
|
|
# image: linuxkit/getty:76951a596aa5e0867a38e28f0b94d620e948e3e8
|
|
# env:
|
|
# - INSECURE=true
|
|
|
|
# Enable acpi to shutdown on power events
|
|
- name: acpid
|
|
image: linuxkit/acpid:c05a368754f6436b326945dc16135ba547568d8d
|
|
- name: rngd
|
|
image: linuxkit/rngd:4f85d8de3f6f45973a8c88dc8fba9ec596e5495a
|
|
- name: db
|
|
image: mariadb:latest
|
|
command: ["/bin/bash", "/usr/local/bin/docker-entrypoint.sh", "mysqld"]
|
|
capabilities:
|
|
- CAP_CHOWN
|
|
- CAP_SETUID
|
|
- CAP_SETGID
|
|
- CAP_DAC_OVERRIDE
|
|
env:
|
|
- MYSQL_DATABASE=fic
|
|
- MYSQL_USER=fic
|
|
- MYSQL_PASSWORD=fic
|
|
- MYSQL_RANDOM_ROOT_PASSWORD=yes
|
|
binds:
|
|
- /etc/hosts:/etc/hosts:ro
|
|
- /etc/mysql/conf.d:/etc/mysql/conf.d:ro
|
|
- /var/lib/fic/mysql:/var/lib/mysql
|
|
net: /run/netns/db
|
|
pid: new
|
|
ipc: new
|
|
uts: new
|
|
runtime:
|
|
mkdir:
|
|
- /var/lib/fic/mysql
|
|
- name: db-backup
|
|
image: nemunaire/mariadb-client:46433fee4bd61e5486f32260cce1d9bd37372d9b
|
|
command: ["/bin/sh", "/root/mysql_backup.sh"]
|
|
env:
|
|
- MYSQL_HOST=db
|
|
- MYSQL_DATABASE=fic
|
|
- MYSQL_USER=fic
|
|
- MYSQL_PASSWORD=fic
|
|
binds:
|
|
- /etc/hosts:/etc/hosts:ro
|
|
- /root/mysql_backup.sh:/root/mysql_backup.sh:ro
|
|
- /var/lib/fic/backups/:/var/lib/fic/backups/
|
|
net: /run/netns/db
|
|
runtime:
|
|
mkdir:
|
|
- /var/lib/fic/backups
|
|
- name: fic-admin
|
|
image: nemunaire/fic-admin:latest@sha256:41c6dc331a6fee88611d94ecdbdd7f85d1c0a8f8439cd701ed5cde6e68833899
|
|
command: ["/srv/admin", "-4real", "-bind=127.0.0.1:8081", "-baseurl=/admin/", "-localimport=/mnt/fic", "-timestampCheck=/srv/submissions", "-git-import-remote=git@gitlab.cri.epita.fr:ing/majeures/srs/fic/2022/challenges.git"]
|
|
env:
|
|
- PATH=/usr/sbin:/usr/bin:/sbin:/bin
|
|
- MYSQL_HOST=db
|
|
- FICCA_PASS=jee8AhloAith1aesCeQu5ahgIegaeM4K
|
|
binds:
|
|
- /etc/hosts:/etc/hosts:ro
|
|
- /var/lib/fic/raw_files:/mnt/fic
|
|
- /var/lib/fic/dashboard:/srv/DASHBOARD
|
|
- /var/lib/fic/files:/srv/FILES
|
|
- /var/lib/fic/pki:/srv/PKI
|
|
- /var/lib/fic/teams:/srv/TEAMS
|
|
- /var/lib/fic/settings:/srv/SETTINGS
|
|
- /var/lib/fic/sync:/srv/SYNC
|
|
- /var/lib/fic/submissions:/srv/submissions:ro
|
|
net: /run/netns/fic-admin
|
|
pid: new
|
|
ipc: new
|
|
uts: new
|
|
runtime:
|
|
mkdir:
|
|
- /var/lib/fic/dashboard
|
|
- /var/lib/fic/files
|
|
- /var/lib/fic/raw_files
|
|
- /var/lib/fic/pki
|
|
- /var/lib/fic/settings
|
|
- /var/lib/fic/sync
|
|
- /var/lib/fic/submissions
|
|
- /var/lib/fic/teams
|
|
- name: fic-evdist
|
|
image: nemunaire/fic-evdist:latest@sha256:9db168ebc33c0724e7c04facc6d88977d3b5921418f1830cfc101b49b759bf23
|
|
binds:
|
|
- /etc/hosts:/etc/hosts:ro
|
|
- /var/lib/fic/settings:/srv/SETTINGS
|
|
- /var/lib/fic/settingsdist:/srv/SETTINGSDIST
|
|
net: new
|
|
pid: new
|
|
ipc: new
|
|
uts: new
|
|
runtime:
|
|
mkdir:
|
|
- /var/lib/fic/settings
|
|
- /var/lib/fic/settingsdist
|
|
- name: fic-backend
|
|
image: nemunaire/fic-backend:latest@sha256:5d3b0a11f1b871fbc7bd3c51b21b26f1d9a72c78c748c1f17e78ffa0effa36d2
|
|
env:
|
|
- MYSQL_HOST=db
|
|
binds:
|
|
- /etc/hosts:/etc/hosts:ro
|
|
- /var/lib/fic/teams:/srv/TEAMS
|
|
- /var/lib/fic/settingsdist:/srv/SETTINGSDIST:ro
|
|
- /var/lib/fic/submissions:/srv/submissions
|
|
net: /run/netns/fic-backend
|
|
pid: new
|
|
ipc: new
|
|
uts: new
|
|
runtime:
|
|
mkdir:
|
|
- /var/lib/fic/settingsdist
|
|
- /var/lib/fic/submissions
|
|
- /var/lib/fic/teams
|
|
- name: fic-dashboard
|
|
image: nemunaire/fic-dashboard:latest@sha256:d678ecb65d0e2e587d7dc8528c4a5cdb187eb9b556737db29672dd43ae3eb39e
|
|
command: ["/srv/dashboard", "-bind=:8082", "-restrict-to-ips=/srv/DASHBOARD/restricted-ips.json"]
|
|
binds:
|
|
- /etc/hosts:/etc/hosts:ro
|
|
- /var/lib/fic/dashboard:/srv/DASHBOARD:ro
|
|
- /var/lib/fic/files:/srv/FILES:ro
|
|
- /var/lib/fic/teams:/srv/TEAMS:ro
|
|
- /var/lib/fic/settingsdist:/srv/SETTINGSDIST:ro
|
|
net: /run/netns/fic-admin
|
|
pid: new
|
|
ipc: new
|
|
uts: new
|
|
runtime:
|
|
mkdir:
|
|
- /var/lib/fic/dashboard
|
|
- /var/lib/fic/teams
|
|
- /var/lib/fic/settingsdist
|
|
- name: fic-synchro
|
|
image: nemunaire/rsync:5d1f678641de2197041f4bc4c745e7748bedab02
|
|
command: ["/bin/ash", "/root/synchro.sh"]
|
|
binds:
|
|
- /etc/hosts:/etc/hosts:ro
|
|
- /var/lib/fic/ssh:/etc/ssh:ro
|
|
- /root/.ssh/id_ed25519:/root/.ssh/id_ed25519:ro
|
|
- /root/synchro.sh:/root/synchro.sh:ro
|
|
- /var/lib/fic/files:/srv/FILES:ro
|
|
#- /var/lib/fic/pki/ca.key:/srv/PKI/ca.key:ro
|
|
- /var/lib/fic/pki/shared:/srv/PKI/shared:ro
|
|
- /var/lib/fic/settingsdist:/srv/SETTINGSDIST:ro
|
|
- /var/lib/fic/submissions:/srv/submissions
|
|
- /var/lib/fic/teams:/srv/TEAMS:ro
|
|
- /var/log/frontend:/var/log/frontend
|
|
net: /run/netns/synchro
|
|
runtime:
|
|
mkdir:
|
|
- /var/lib/fic/files
|
|
- /var/lib/fic/pki/shared
|
|
- /var/lib/fic/settingsdist
|
|
- /var/lib/fic/ssh
|
|
- /var/lib/fic/submissions
|
|
- /var/lib/fic/teams
|
|
- /var/log/frontend
|
|
- name: sshd
|
|
image: nemunaire/rsync:5d1f678641de2197041f4bc4c745e7748bedab02
|
|
binds:
|
|
- /etc/hosts:/etc/hosts:ro
|
|
- /root/.ssh/:/root/.ssh/:ro
|
|
- /usr/bin/iptables:/usr/bin/iptables:ro
|
|
- /usr/bin/mysql:/usr/bin/mysql:ro
|
|
- /usr/bin/pnsenter:/usr/bin/pnsenter:ro
|
|
- /var/lib/fic/outofsync:/var/lib/fic/outofsync
|
|
- /var/lib/fic/raw_files:/mnt/fic
|
|
- /var/log:/var/log:ro
|
|
capabilities:
|
|
- all
|
|
net: /run/netns/fic-admin
|
|
pid: host
|
|
runtime:
|
|
mkdir:
|
|
- /var/lib/fic/outofsync
|
|
# - name: dhcp-server
|
|
# image: joebiellik/dhcpd
|
|
# binds:
|
|
# - /etc/dhcp/dhcpd.conf:/etc/dhcp/dhcpd.conf:ro
|
|
# capabilities:
|
|
# - CAP_NET_BIND_SERVICE
|
|
# - CAP_NET_RAW
|
|
# - CAP_DAC_OVERRIDE
|
|
# net: /run/netns/fic-admin
|
|
# pid: new
|
|
# ipc: new
|
|
# uts: new
|
|
|
|
files:
|
|
- path: etc/init.d/001-hostname
|
|
contents: |
|
|
#!/bin/sh
|
|
/bin/hostname deimos
|
|
mode: "0555"
|
|
|
|
- path: etc/profile.d/color_prompt.sh
|
|
contents: |
|
|
PS1='\[\e[1;33m\]'$PS1'\[\e[0m\]'
|
|
mode: "0444"
|
|
|
|
- path: etc/init.d/015-setup-sshd
|
|
source: configs/sshd-setup.sh
|
|
mode: "0555"
|
|
|
|
- path: etc/sysctl.d/01-fic.conf
|
|
source: configs/sysctl-backend.conf
|
|
mode: "0444"
|
|
|
|
- path: root/synchro.sh
|
|
source: configs/synchro.sh
|
|
mode: "0755"
|
|
- path: root/mysql_backup.sh
|
|
source: configs/mysql_backup.sh
|
|
mode: "0755"
|
|
- path: etc/hosts
|
|
source: configs/hosts
|
|
mode: "0644"
|
|
- path: root/.ssh/authorized_keys
|
|
source: configs/authorized_keys
|
|
mode: "0400"
|
|
- path: root/.ssh/id_ed25519
|
|
source: configs/id_ed25519
|
|
mode: "0400"
|
|
|
|
- path: usr/bin/iptables
|
|
source: configs/nsenter_iptables.sh
|
|
mode: "0755"
|
|
- path: usr/bin/mysql
|
|
source: configs/nsenter_mysql.sh
|
|
mode: "0755"
|
|
- path: usr/bin/pnsenter
|
|
source: configs/nsenter_process.sh
|
|
mode: "0755"
|
|
|
|
- path: etc/mysql/conf.d/max-conn.cnf
|
|
contents: |
|
|
[mysqld]
|
|
max_connections = 99999
|
|
mode: "0444"
|
|
- path: etc/dhcp/dhcpd.conf
|
|
contents: |
|
|
default-lease-time 600;
|
|
max-lease-time 7200;
|
|
option subnet-mask 255.255.255.0;
|
|
option broadcast-address 192.168.49.255;
|
|
subnet 192.168.49.0 netmask 255.255.255.0 {
|
|
range 192.168.49.11 192.168.49.250;
|
|
}
|
|
mode: "0440"
|
|
- path: etc/iptables/rules.v6
|
|
contents: |
|
|
*filter
|
|
:INPUT DROP [0:0]
|
|
:FORWARD DROP [0:0]
|
|
:OUTPUT DROP [0:0]
|
|
COMMIT
|
|
mode: "0440"
|
|
- path: etc/iptables/rules-admin.v4
|
|
contents: |
|
|
*filter
|
|
:INPUT DROP [0:0]
|
|
:FORWARD DROP [0:0]
|
|
:OUTPUT DROP [0:0]
|
|
[0:0] -A INPUT -i lo -j ACCEPT
|
|
[0:0] -A INPUT -m conntrack --ctstate INVALID -j DROP
|
|
[0:0] -A INPUT -p icmp -j ACCEPT
|
|
[0:0] -A INPUT -m conntrack --ctstate RELATED,ESTABLISHED -j ACCEPT
|
|
[0:0] -A INPUT -p tcp -m conntrack --ctstate NEW -m tcp --dport ssh -j ACCEPT
|
|
[0:0] -A INPUT -p tcp -m conntrack --ctstate NEW -m tcp --dport 8082 -j ACCEPT
|
|
[0:0] -A INPUT -i vethin-admin -s 172.17.0.0/24 -p tcp -m conntrack --ctstate NEW -j ACCEPT
|
|
[0:0] -A INPUT -j LOG
|
|
[0:0] -A FORWARD -j LOG
|
|
[0:0] -A OUTPUT -o lo -j ACCEPT
|
|
[0:0] -A OUTPUT -m conntrack --ctstate RELATED,ESTABLISHED -j ACCEPT
|
|
[0:0] -A OUTPUT -p icmp -j ACCEPT
|
|
[0:0] -A OUTPUT -o vethin-admin -d 172.17.0.0/24 -p tcp -m conntrack --ctstate NEW -j ACCEPT
|
|
[0:0] -A OUTPUT -j LOG
|
|
[0:0] -A OUTPUT -j REJECT
|
|
COMMIT
|
|
mode: "0440"
|
|
- path: etc/iptables/rules-synchro.v4
|
|
contents: |
|
|
*filter
|
|
:INPUT DROP [0:0]
|
|
:FORWARD DROP [0:0]
|
|
:OUTPUT DROP [0:0]
|
|
[0:0] -A INPUT -i lo -j ACCEPT
|
|
[0:0] -A INPUT -m conntrack --ctstate INVALID -j DROP
|
|
[0:0] -A INPUT -p icmp --icmp-type 8 -j ACCEPT
|
|
[0:0] -A INPUT -p icmp --icmp-type 0 -j ACCEPT
|
|
[0:0] -A INPUT -m conntrack --ctstate RELATED,ESTABLISHED -j ACCEPT
|
|
[0:0] -A INPUT -j LOG
|
|
[0:0] -A FORWARD -j LOG
|
|
[0:0] -A OUTPUT -o lo -j ACCEPT
|
|
[0:0] -A OUTPUT -p icmp --icmp-type 0 -j ACCEPT
|
|
[0:0] -A OUTPUT -p icmp --icmp-type 8 -j ACCEPT
|
|
[0:0] -A OUTPUT -m conntrack --ctstate RELATED,ESTABLISHED -j ACCEPT
|
|
[0:0] -A OUTPUT -o eth2 -d 10.10.10.2 -p tcp -m conntrack --ctstate NEW -m tcp --dport ssh -j ACCEPT
|
|
[0:0] -A OUTPUT -j LOG
|
|
[0:0] -A OUTPUT -j REJECT
|
|
COMMIT
|
|
mode: "0440"
|
|
|
|
- path: etc/dm-crypt/key
|
|
source: configs/dm-crypt.key
|
|
mode: "0440"
|
|
|
|
trust:
|
|
org:
|
|
- linuxkit
|
|
- library
|