Compare commits
2 Commits
9b20887cc2
...
c83e4755e9
| Author | SHA1 | Date | |
|---|---|---|---|
| c83e4755e9 | |||
| 6eb6ff6425 |
15
packaging/ubuntu/README.txt
Normal file
15
packaging/ubuntu/README.txt
Normal file
@@ -0,0 +1,15 @@
|
||||
Build the deb:
|
||||
cd bitoj_python/packaging/ubuntu
|
||||
bash build-deb.sh
|
||||
|
||||
Install:
|
||||
sudo dpkg -i dist/bitoj_0.1.0_all.deb
|
||||
|
||||
Service:
|
||||
sudo service bitoj start|stop|restart
|
||||
sudo journalctl -u bitoj -f
|
||||
|
||||
Logs:
|
||||
/var/log/bitoj/daemon.log
|
||||
/var/log/bitoj/judge-*.log
|
||||
/var/log/bitoj/tester-*.log
|
||||
68
packaging/ubuntu/bitoj-guards
Normal file
68
packaging/ubuntu/bitoj-guards
Normal file
@@ -0,0 +1,68 @@
|
||||
#include <tunables/global>
|
||||
|
||||
# BitOJ guard profiles
|
||||
/usr/lib/bitoj/scripts/binary-guard {
|
||||
#include <abstractions/bitoj>
|
||||
|
||||
/var/lib/bitoj/data/**/main mrix,
|
||||
/usr/lib/bitoj/data/**/main mrix,
|
||||
}
|
||||
|
||||
/usr/lib/bitoj/scripts/java-guard {
|
||||
#include <abstractions/bitoj>
|
||||
capability sys_ptrace,
|
||||
|
||||
/var/lib/bitoj/data/**/*.class mr,
|
||||
/usr/lib/bitoj/data/**/*.class mr,
|
||||
/usr/bin/java mrix,
|
||||
|
||||
/etc/passwd mr,
|
||||
/etc/nsswitch.conf mr,
|
||||
/etc/java*/* mr,
|
||||
/proc/** mr,
|
||||
/sys/** mr,
|
||||
/usr/lib/jvm/**/** mr,
|
||||
/usr/lib/jvm/java-6-sun*/jre/bin/* mrix,
|
||||
|
||||
/tmp/hsperfdata_ojrun*/ mrw,
|
||||
/tmp/hsperfdata_ojrun*/* mrw,
|
||||
}
|
||||
|
||||
/usr/lib/bitoj/scripts/mono-guard {
|
||||
#include <abstractions/bitoj>
|
||||
|
||||
/var/lib/bitoj/data/**/main.exe mr,
|
||||
/usr/lib/bitoj/data/**/main.exe mr,
|
||||
/var/lib/bitoj/data/**/.wapi/ mrw,
|
||||
/var/lib/bitoj/data/**/.wapi/* mrw,
|
||||
/usr/lib/bitoj/data/**/.wapi/ mrw,
|
||||
/usr/lib/bitoj/data/**/.wapi/* mrw,
|
||||
|
||||
/usr/bin/mono mrix,
|
||||
/usr/lib/mono/2.0/* mr,
|
||||
/usr/lib/mono/2.0/**/* mr,
|
||||
/etc/mono/config mr,
|
||||
/etc/nsswitch.conf mr,
|
||||
/etc/passwd mr,
|
||||
/proc/**/* mr,
|
||||
}
|
||||
|
||||
/usr/lib/bitoj/scripts/python-guard {
|
||||
#include <abstractions/bitoj>
|
||||
#include <abstractions/python>
|
||||
|
||||
/var/lib/bitoj/data/**/main.py mr,
|
||||
/usr/lib/bitoj/data/**/main.py mr,
|
||||
/usr/bin/python2.5 mrix,
|
||||
/usr/lib/python2.5/lib-dynload/** mr,
|
||||
}
|
||||
|
||||
/usr/lib/bitoj/scripts/bash-guard {
|
||||
#include <abstractions/bitoj>
|
||||
#include <abstractions/bash>
|
||||
|
||||
/var/lib/bitoj/data/**/main.sh mr,
|
||||
/usr/lib/bitoj/data/**/main.sh mr,
|
||||
/bin/* mrix,
|
||||
/usr/bin/* mrix,
|
||||
}
|
||||
17
packaging/ubuntu/bitoj.service
Normal file
17
packaging/ubuntu/bitoj.service
Normal file
@@ -0,0 +1,17 @@
|
||||
[Unit]
|
||||
Description=BitOJ Judge Daemon
|
||||
After=network.target
|
||||
|
||||
[Service]
|
||||
Type=simple
|
||||
WorkingDirectory=/usr/lib/bitoj
|
||||
ExecStart=/usr/lib/bitoj/judge-daemon
|
||||
Restart=on-failure
|
||||
RestartSec=2
|
||||
User=root
|
||||
Group=root
|
||||
Environment=PYTHONUNBUFFERED=1
|
||||
LimitNOFILE=65536
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
||||
50
packaging/ubuntu/build-deb.sh
Normal file
50
packaging/ubuntu/build-deb.sh
Normal file
@@ -0,0 +1,50 @@
|
||||
#!/usr/bin/env bash
|
||||
set -euo pipefail
|
||||
|
||||
SCRIPT_DIR=$(cd "$(dirname "$0")" && pwd)
|
||||
PROJECT_ROOT=$(cd "$SCRIPT_DIR/../.." && pwd)
|
||||
OUT_DIR="$SCRIPT_DIR/dist"
|
||||
BUILD_DIR="$SCRIPT_DIR/build"
|
||||
PKG_ROOT="$BUILD_DIR/bitoj"
|
||||
VERSION="${VERSION:-0.1.0}"
|
||||
ARCH="${ARCH:-all}"
|
||||
|
||||
rm -rf "$BUILD_DIR" "$OUT_DIR"
|
||||
mkdir -p "$PKG_ROOT/DEBIAN" \
|
||||
"$PKG_ROOT/usr/lib/bitoj" \
|
||||
"$PKG_ROOT/etc/bitoj" \
|
||||
"$PKG_ROOT/etc/apparmor.d" \
|
||||
"$PKG_ROOT/lib/systemd/system" \
|
||||
"$PKG_ROOT/var/lib/bitoj" \
|
||||
"$PKG_ROOT/var/log/bitoj"
|
||||
|
||||
cp "$SCRIPT_DIR/control" "$PKG_ROOT/DEBIAN/control"
|
||||
cp "$SCRIPT_DIR/postinst" "$PKG_ROOT/DEBIAN/postinst"
|
||||
cp "$SCRIPT_DIR/prerm" "$PKG_ROOT/DEBIAN/prerm"
|
||||
cp "$SCRIPT_DIR/postrm" "$PKG_ROOT/DEBIAN/postrm"
|
||||
chmod 0755 "$PKG_ROOT/DEBIAN/postinst" "$PKG_ROOT/DEBIAN/prerm" "$PKG_ROOT/DEBIAN/postrm"
|
||||
|
||||
cp "$SCRIPT_DIR/bitoj.service" "$PKG_ROOT/lib/systemd/system/bitoj.service"
|
||||
cp "$SCRIPT_DIR/bitoj-guards" "$PKG_ROOT/etc/apparmor.d/bitoj-guards"
|
||||
mkdir -p "$PKG_ROOT/usr/lib/tmpfiles.d"
|
||||
cp "$SCRIPT_DIR/tmpfiles.conf" "$PKG_ROOT/usr/lib/tmpfiles.d/bitoj.conf"
|
||||
|
||||
if command -v rsync >/dev/null 2>&1; then
|
||||
rsync -a --delete --exclude 'packaging/ubuntu' "$PROJECT_ROOT/" "$PKG_ROOT/usr/lib/bitoj/"
|
||||
else
|
||||
echo "rsync not found; fallback to cp -a" >&2
|
||||
cp -a "$PROJECT_ROOT/." "$PKG_ROOT/usr/lib/bitoj/"
|
||||
rm -rf "$PKG_ROOT/usr/lib/bitoj/packaging/ubuntu"
|
||||
fi
|
||||
|
||||
chmod +x "$PKG_ROOT/usr/lib/bitoj/judge" \
|
||||
"$PKG_ROOT/usr/lib/bitoj/judge-daemon" \
|
||||
"$PKG_ROOT/usr/lib/bitoj/judgeold" \
|
||||
"$PKG_ROOT/usr/lib/bitoj/judge-daemonold" \
|
||||
"$PKG_ROOT/usr/lib/bitoj/utils/bitoj_adduser"
|
||||
|
||||
mkdir -p "$OUT_DIR"
|
||||
|
||||
dpkg-deb --build "$PKG_ROOT" "$OUT_DIR/bitoj_${VERSION}_${ARCH}.deb"
|
||||
|
||||
echo "Built: $OUT_DIR/bitoj_${VERSION}_${ARCH}.deb"
|
||||
8
packaging/ubuntu/control
Normal file
8
packaging/ubuntu/control
Normal file
@@ -0,0 +1,8 @@
|
||||
Package: bitoj
|
||||
Version: 0.1.0
|
||||
Section: utils
|
||||
Priority: optional
|
||||
Architecture: all
|
||||
Depends: python3, gcc, g++, sudo, adduser, bzip2, quota
|
||||
Maintainer: BitOJ Maintainers <admin@localhost>
|
||||
Description: BitOJ judge daemon and runtime for Ubuntu
|
||||
53
packaging/ubuntu/postinst
Normal file
53
packaging/ubuntu/postinst
Normal file
@@ -0,0 +1,53 @@
|
||||
#!/bin/sh
|
||||
set -e
|
||||
|
||||
mkdir -p /etc/bitoj /var/log/bitoj /var/lib/bitoj /usr/lib/bitoj/data
|
||||
|
||||
ln -sfn /etc/bitoj /usr/lib/bitoj/conf
|
||||
ln -sfn /var/log/bitoj /usr/lib/bitoj/log
|
||||
|
||||
if [ ! -f /etc/bitoj/conf-default.py ]; then
|
||||
if [ -f /usr/lib/bitoj/conf-demo.py ]; then
|
||||
cp /usr/lib/bitoj/conf-demo.py /etc/bitoj/conf-default.py
|
||||
else
|
||||
touch /etc/bitoj/conf-default.py
|
||||
fi
|
||||
fi
|
||||
|
||||
if ! getent group oj >/dev/null 2>&1; then
|
||||
groupadd --system oj
|
||||
fi
|
||||
|
||||
if ! id -u oj >/dev/null 2>&1; then
|
||||
useradd --system --no-create-home --gid oj --shell /usr/sbin/nologin oj
|
||||
fi
|
||||
|
||||
if ! id -u ojrun01 >/dev/null 2>&1; then
|
||||
/usr/lib/bitoj/utils/bitoj_adduser 1 10 || true
|
||||
fi
|
||||
|
||||
chown -R oj:oj /var/lib/bitoj || true
|
||||
chmod 755 /var/lib/bitoj /var/log/bitoj
|
||||
|
||||
if [ -f /etc/apparmor.d/bitoj-guards ]; then
|
||||
if command -v apparmor_parser >/dev/null 2>&1; then
|
||||
apparmor_parser -r /etc/apparmor.d/bitoj-guards || true
|
||||
fi
|
||||
if command -v service >/dev/null 2>&1; then
|
||||
service apparmor reload >/dev/null 2>&1 || true
|
||||
elif [ -x /etc/init.d/apparmor ]; then
|
||||
/etc/init.d/apparmor reload >/dev/null 2>&1 || true
|
||||
fi
|
||||
fi
|
||||
|
||||
if command -v systemctl >/dev/null 2>&1; then
|
||||
systemctl daemon-reload
|
||||
if command -v systemd-tmpfiles >/dev/null 2>&1; then
|
||||
systemd-tmpfiles --create /usr/lib/tmpfiles.d/bitoj.conf || true
|
||||
fi
|
||||
systemctl enable bitoj.service >/dev/null 2>&1 || true
|
||||
systemctl restart bitoj.service >/dev/null 2>&1 || true
|
||||
fi
|
||||
|
||||
exit 0
|
||||
|
||||
18
packaging/ubuntu/postrm
Normal file
18
packaging/ubuntu/postrm
Normal file
@@ -0,0 +1,18 @@
|
||||
#!/bin/sh
|
||||
set -e
|
||||
|
||||
if command -v systemctl >/dev/null 2>&1; then
|
||||
systemctl daemon-reload
|
||||
fi
|
||||
|
||||
if [ "$1" = "purge" ]; then
|
||||
rm -rf /etc/bitoj
|
||||
rm -f /etc/apparmor.d/bitoj-guards
|
||||
if command -v service >/dev/null 2>&1; then
|
||||
service apparmor reload >/dev/null 2>&1 || true
|
||||
elif [ -x /etc/init.d/apparmor ]; then
|
||||
/etc/init.d/apparmor reload >/dev/null 2>&1 || true
|
||||
fi
|
||||
fi
|
||||
|
||||
exit 0
|
||||
8
packaging/ubuntu/prerm
Normal file
8
packaging/ubuntu/prerm
Normal file
@@ -0,0 +1,8 @@
|
||||
#!/bin/sh
|
||||
set -e
|
||||
|
||||
if command -v systemctl >/dev/null 2>&1; then
|
||||
systemctl stop bitoj.service >/dev/null 2>&1 || true
|
||||
fi
|
||||
|
||||
exit 0
|
||||
2
packaging/ubuntu/tmpfiles.conf
Normal file
2
packaging/ubuntu/tmpfiles.conf
Normal file
@@ -0,0 +1,2 @@
|
||||
d /var/log/bitoj 0755 root root -
|
||||
d /var/lib/bitoj 0755 oj oj -
|
||||
@@ -58,8 +58,7 @@ class RunGuard:
|
||||
self.usepickle = True
|
||||
|
||||
v = os.getenv('GUARD_RLIMIT_OFILE')
|
||||
if v:
|
||||
self.ofile = int(v)
|
||||
if v: self.ofile = int(v)
|
||||
self.ldpreload = os.getenv('GUARD_LD_PRELOAD')
|
||||
|
||||
def execute(self):
|
||||
|
||||
Reference in New Issue
Block a user