Initialize Git Repository: 'Rustdesk-Server'
All checks were successful
Rustdesk Server (Bookworm) / Rustdesk Server [arm64] (push) Successful in 19s
Rustdesk Server (Bookworm) / Rustdesk Server [amd64] (push) Successful in 20s
Rustdesk Server (Noble) / Rustdesk Server [arm64] (push) Successful in 19s
Rustdesk Server (Noble) / Rustdesk Server [amd64] (push) Successful in 20s
Rustdesk Server (Trixie) / Rustdesk Server [arm64] (push) Successful in 17s
Rustdesk Server (Trixie) / Rustdesk Server [amd64] (push) Successful in 28s

This commit is contained in:
Cantibra
2026-01-26 06:10:40 +01:00
commit 3f2a39845d
20 changed files with 1262 additions and 0 deletions

View File

@@ -0,0 +1,86 @@
#!/usr/bin/sh
### BEGIN INIT INFO
# Provides: rustdesk-hbbr
# Required-Start: $local_fs $network $remote_fs
# Required-Stop: $local_fs $network $remote_fs
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: RustDesk Relay Server
# Description: RustDesk is a full-featured open source remote control
# alternative for self-hosting and security with minimal
# configuration.
### END INIT INFO
NAME='rustdesk-hbbr'
DESC='RustDesk Relay Server'
USER='rustdesk'
GROUP='rustdesk'
PIDFOLDER="/run/${NAME}"
PIDFILE="${PIDFOLDER}/${NAME}.pid"
DAEMON='/usr/sbin/hbbr'
DAEMON_CONFIG='/etc/rustdesk/relay.conf'
export DB_URL='/var/lib/rustdesk/server.sqlite'
set -e
[ -f "${DAEMON_CONFIG}" ]
. "${DAEMON_CONFIG}"
. '/lib/lsb/init-functions'
[ -x "${DAEMON}" ]
DAEMON_OPTS="--key ${KEY} --port ${PORT}"
case "${1}" in
start)
/usr/bin/install --directory --group="${GROUP}" ---mode='0755' --owner="${USER}" "${PIDFOLDER}"
log_daemon_msg "Starting ${DESC}" "${NAME}"
if /usr/sbin/start-stop-daemon --quiet \
--start \
--oknodo \
--make-pidfile \
--pidfile "${PIDFILE}" \
--user "${USER}" \
--group "${GROUP}" \
--exec "${DAEMON}" -- "${DAEMON_OPTS}"; then
log_end_msg 0
else
log_end_msg 1
/usr/bin/test -f "${PIDFILE}" && \
/usr/bin/rm --force "${PIDFILE}"
fi
;;
stop)
log_daemon_msg "Stopping ${DESC}" "${NAME}"
if /usr/sbin/start-stop-daemon --quiet \
--stop \
--oknodo \
--retry 30 \
--remove-pidfile \
--pidfile "${PIDFILE}" \
--user "${USER}" \
--group "${GROUP}" \
--exec "${DAEMON}"; then
/usr/bin/test -f "${PIDFILE}" && \
/usr/bin/rm --force "${PIDFILE}"
log_end_msg 0
else
log_end_msg 1
fi
;;
restart)
"${0}" stop
"${0}" start
;;
status)
status_of_proc -p "${PIDFILE}" "${DAEMON}" "${NAME}" && \
exit 0 || \
exit "${?}"
;;
*)
echo "Usage: /etc/init.d/${NAME} {start|stop|restart|status}" >&2
exit 1
;;
esac

View File

@@ -0,0 +1,86 @@
#!/usr/bin/sh
### BEGIN INIT INFO
# Provides: rustdesk-hbbs
# Required-Start: $local_fs $network $remote_fs
# Required-Stop: $local_fs $network $remote_fs
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: RustDesk ID/Rendezvous Server
# Description: RustDesk is a full-featured open source remote control
# alternative for self-hosting and security with minimal
# configuration.
### END INIT INFO
NAME='rustdesk-hbbs'
DESC='RustDesk ID/Rendezvous Server'
USER='rustdesk'
GROUP='rustdesk'
PIDFOLDER="/run/${NAME}"
PIDFILE="${PIDFOLDER}/${NAME}.pid"
DAEMON='/usr/sbin/hbbs'
DAEMON_CONFIG='/etc/rustdesk/signal.conf'
export DB_URL='/var/lib/rustdesk/server.sqlite'
set -e
[ -f "${DAEMON_CONFIG}" ]
. "${DAEMON_CONFIG}"
. '/lib/lsb/init-functions'
[ -x "${DAEMON}" ]
DAEMON_OPTS="--key ${KEY} --port ${PORT} --relay-servers ${RELAY_SERVER} --rmem ${RMEM}"
case "${1}" in
start)
/usr/bin/install --directory --group="${GROUP}" ---mode='0755' --owner="${USER}" "${PIDFOLDER}"
log_daemon_msg "Starting ${DESC}" "${NAME}"
if /usr/sbin/start-stop-daemon --quiet \
--start \
--oknodo \
--make-pidfile \
--pidfile "${PIDFILE}" \
--user "${USER}" \
--group "${GROUP}" \
--exec "${DAEMON}" -- "${DAEMON_OPTS}"; then
log_end_msg 0
else
log_end_msg 1
/usr/bin/test -f "${PIDFILE}" && \
/usr/bin/rm --force "${PIDFILE}"
fi
;;
stop)
log_daemon_msg "Stopping ${DESC}" "${NAME}"
if /usr/sbin/start-stop-daemon --quiet \
--stop \
--oknodo \
--retry 30 \
--remove-pidfile \
--pidfile "${PIDFILE}" \
--user "${USER}" \
--group "${GROUP}" \
--exec "${DAEMON}"; then
/usr/bin/test -f "${PIDFILE}" && \
/usr/bin/rm --force "${PIDFILE}"
log_end_msg 0
else
log_end_msg 1
fi
;;
restart)
"${0}" stop
"${0}" start
;;
status)
status_of_proc -p "${PIDFILE}" "${DAEMON}" "${NAME}" && \
exit 0 || \
exit "${?}"
;;
*)
echo "Usage: /etc/init.d/${NAME} {start|stop|restart|status}" >&2
exit 1
;;
esac

View File

@@ -0,0 +1,71 @@
/var/log/rustdesk/*.log {
# Truncate the original log file in place after creating a copy,
# instead of moving the old log file and optionally creating a
# new one. It can be used when some program cannot be told to
# close its logfile and thus might continue writing (appending)
# to the previous log file forever. Note that there is a very
# small time slice between copying the file and truncating it, so
# some logging data might be lost. When this option is used, the
# create option will have no effect, as the old log file stays in
# place.
copytruncate
# Log files are rotated every day.
daily
# Archive old versions of log files adding a daily extension like
# YYYYMMDD instead of simply adding a number. The extension may
# be configured using the dateformat option.
dateext
# Specify the extension for dateext using the notation similar to
# strftime(3) function. Only %Y %m %d and %s specifiers are allowed.
# The default value is -%Y%m%d. Note that also the character
# separating log name from the extension is part of the dateformat
# string. The system clock must be set past Sep 9th 2001 for %s to
# work correctly. Note that the datestamps generated by this format
# must be lexically sortable (i.e., first the year, then the month
# then the day. e.g., 2001/12/01 is ok, but 01/12/2001 is not, since
# 01/11/2002 would sort lower while it is later). This is because when
# using the rotate option, logrotate sorts all rotated filenames to
# find out which logfiles are older and should be removed.
dateformat .%Y-%m-%d
# Use yesterday's instead of today's date to create the dateext
# extension, so that the rotated log file has a date in its name that
# is the same as the timestamps within it.
dateyesterday
# Postpone compression of the previous log file to the next rotation
# cycle. This only has effect when used in combination with compress.
# It can be used when some program cannot be told to close its logfile
# and thus might continue writing to the previous log file for some time.
delaycompress
# Do not copy the original log file and leave it in place.
nocopy
# New log files are not created.
nocreate
# Don't mail old log files to any address.
nomail
# Do not use shred when deleting old log files.
noshred
# Do not rotate the log if it is empty.
notifempty
# Logs are moved into directory for rotation. The directory must be on the
# same physical device as the log file being rotated, and is assumed to be
# relative to the directory holding the log file unless an absolute path
# name is specified. When this option is used all old versions of the log
# end up in directory.
olddir /var/logrotate/rustdesk
# Log files are rotated count times before being removed or mailed to the
# address specified in a mail directive. If count is 0, old versions are
# removed rather than rotated.
rotate 7
}

View File

@@ -0,0 +1,7 @@
# RustDesk Relay Server (hbbr) configuration
# Only allow the client with the same key.
KEY=''
# Sets the listening port.
PORT='21117'

View File

@@ -0,0 +1,15 @@
# RustDesk ID/Rendezvous Server (hbbs) configuration
# Only allow the client with the same key.
KEY=''
# Sets the listening port.
PORT='21116'
# Sets the default relay servers.
RELAY_SERVER='localhost'
# Sets UDP recv buffer size.
# Set system rmem_max first!
# e.g. 'sysctl -w net.core.rmem_max=52428800'
RMEM='0'