First Commit
/ build_macos (push) Has been cancelled
/ build_windows (push) Has been cancelled
/ build_ubuntu (push) Has been cancelled

This commit is contained in:
2025-11-19 16:23:45 +07:00
commit dbdc5bcc4a
1791 changed files with 489451 additions and 0 deletions
@@ -0,0 +1,28 @@
## NOTE: to retain configuration; mount a Docker volume, or use a bind-mount, on /var/lib/zerotier-one
FROM debian:buster-slim as builder
## Supports x86_64, x86, arm, and arm64
RUN apt-get update && apt-get install -y curl gnupg
RUN apt-key adv --keyserver pgp.mit.edu --recv-keys 0x1657198823e52a61 && \
echo "deb http://download.zerotier.com/debian/buster buster main" > /etc/apt/sources.list.d/zerotier.list
RUN apt-get update && apt-get install -y zerotier-one=1.8.6
COPY ext/installfiles/linux/zerotier-containerized/main.sh /var/lib/zerotier-one/main.sh
FROM debian:buster-slim
LABEL version="1.8.6"
LABEL description="Containerized ZeroTier One for use on CoreOS or other Docker-only Linux hosts."
# ZeroTier relies on UDP port 9993
EXPOSE 9993/udp
RUN mkdir -p /var/lib/zerotier-one
COPY --from=builder /usr/sbin/zerotier-cli /usr/sbin/zerotier-cli
COPY --from=builder /usr/sbin/zerotier-idtool /usr/sbin/zerotier-idtool
COPY --from=builder /usr/sbin/zerotier-one /usr/sbin/zerotier-one
COPY --from=builder /var/lib/zerotier-one/main.sh /main.sh
RUN chmod 0755 /main.sh
ENTRYPOINT ["/main.sh"]
CMD ["zerotier-one"]
+10
View File
@@ -0,0 +1,10 @@
#!/bin/sh
export PATH=/bin:/usr/bin:/usr/local/bin:/sbin:/usr/sbin
if [ ! -e /dev/net/tun ]; then
echo 'FATAL: cannot start ZeroTier One in container: /dev/net/tun not present.'
exit 1
fi
exec "$@"
+138
View File
@@ -0,0 +1,138 @@
#!/bin/bash
#
# zerotier-one Start the ZeroTier One network virtualization service
#
# chkconfig: 2345 55 25
# description: ZeroTier One allows systems to join and participate in \
# ZeroTier virtual networks. See https://www.zerotier.com/
#
# processname: zerotier-one
# config: /var/lib/zerotier-one/identity.public
# config: /var/lib/zerotier-one/identity.secret
# config: /var/lib/zerotier-one/local.conf
# config: /var/lib/zerotier-one/authtoken.secret
# pidfile: /var/lib/zerotier-one/zerotier-one.pid
### BEGIN INIT INFO
# Provides: zerotier-one
# Required-Start: $local_fs $network $syslog
# Required-Stop: $local_fs $syslog
# Should-Start: $syslog
# Should-Stop: $network $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Start the ZeroTier One network virtualization service
# Description: ZeroTier One allows systems to join and participate in
# ZeroTier virtual networks. See https://www.zerotier.com/
### END INIT INFO
# source function library
. /etc/rc.d/init.d/functions
# pull in sysconfig settings
[ -f /etc/sysconfig/zerotier-one ] && . /etc/sysconfig/zerotier-one
RETVAL=0
prog="zerotier-one"
lockfile=/var/lock/subsys/$prog
ZT="/usr/sbin/zerotier-one"
PID_FILE=/var/lib/zerotier-one/zerotier-one.pid
runlevel=$(set -- $(runlevel); eval "echo \$$#" )
start()
{
[ -x $ZT ] || exit 5
echo -n $"Starting $prog: "
$ZT $ZT_OPTIONS -d && success || failure
RETVAL=$?
[ $RETVAL -eq 0 ] && touch $lockfile
echo
return $RETVAL
}
stop()
{
echo -n $"Stopping $prog: "
killproc -p $PID_FILE $ZT
RETVAL=$?
if [ "x$runlevel" = x0 -o "x$runlevel" = x6 ] ; then
trap '' TERM
killall $prog 2>/dev/null
trap TERM
fi
[ $RETVAL -eq 0 ] && rm -f $lockfile
echo
}
reload()
{
stop
start
}
restart() {
stop
start
}
force_reload() {
restart
}
rh_status() {
status -p $PID_FILE zerotier-one
}
rh_status_q() {
rh_status >/dev/null 2>&1
}
case "$1" in
start)
rh_status_q && exit 0
start
;;
stop)
if ! rh_status_q; then
rm -f $lockfile
exit 0
fi
stop
;;
restart)
restart
;;
reload)
rh_status_q || exit 7
reload
;;
force-reload)
force_reload
;;
condrestart|try-restart)
rh_status_q || exit 0
if [ -f $lockfile ] ; then
do_restart_sanity_check
if [ $RETVAL -eq 0 ] ; then
stop
# avoid race
sleep 3
start
else
RETVAL=6
fi
fi
;;
status)
rh_status
RETVAL=$?
if [ $RETVAL -eq 3 -a -f $lockfile ] ; then
RETVAL=2
fi
;;
*)
echo $"Usage: $0 {start|stop|restart|reload|force-reload|condrestart|try-restart|status}"
RETVAL=2
esac
exit $RETVAL
+14
View File
@@ -0,0 +1,14 @@
module zerotier-one 1.0;
require {
type unconfined_t;
type initrc_t;
class memprotect mmap_zero;
}
#============= initrc_t ==============
allow initrc_t self:memprotect mmap_zero;
#============= unconfined_t ==============
allow unconfined_t self:memprotect mmap_zero;