mirror of
https://github.com/openwrt/packages.git
synced 2025-12-23 16:44:31 +04:00
* Package scripts that are shipped by upstream in their binary download
* Includes setup scripts (setup-seafile.sh to use SQLite,
setup-seafile-mysql.{sh,py} to use MySQL) and control scripts
(seafile.sh, seahub.sh)
* Does not include seafile-admin, which is not shipped in upstream's
binary download. Combined with the fact that it hasn't been updated
to Python 3 suggests the script has been abandoned.
* Replace previous init scripts with a simplified script
* Previous init scripts (seafile.init, seahub.init) were modified from
older versions of seafile.sh and seahub.sh, but they haven't kept up
with changes to upstream's scripts
* New init script (seafile-server.init) start/stops both Seafile and
Seahub (there is no need to control them separately) by calling
upstream's control scripts
* Replace previous package config file with new config file
* Options in previous config file (seafile.conf) were mainly for using
Seahub in FastCGI mode. FastCGI was deprecated in Django 1.7 and
removed in 1.9; upstream's control script will only start Seahub
using Gunicorn. (Options for Gunicorn including port number can be
changed by editing /etc/seafile/conf/gunicorn.conf.py.)
* New config file (seafile-server.config) has one option that controls
where the Seafile/Seahub data directories are stored
* Patch scripts/binaries to use standard, system-wide directory
locations
* Script files (wrappers for binaries) in /usr/bin
* Binaries (not meant to be run directly by the user) in /usr/libexec
* Config files in /etc/seafile
* Pid/socket files in /var/run/seafile
* Logs in /var/log/seafile
* Include a new script to create the first admin account
* With upstream's original scripts, the user is required to
interactively create the first admin account when Seahub is started
for the first time
* The user will now use the new script (create-seafile-admin.sh) to
create the first admin account after setup (using setup-seafile.sh
or setup-seafile-mysql.sh) and before starting Seafile/Seahub
* seahub.sh is patched to only check if there is at least one admin
account and exit with an error if there is no admin account
* Remove build config options and add seafile-server-fuse package
* The console option controls whether the console window is shown when
Seafile server is run on Windows. It has no use on Linux.
* The fuse option controls whether seaf-fuse is built. (seaf-fuse is a
FUSE implementation that allows the Seafile database/file system to
be mounted to a local directory.) seaf-fuse is now always built and
is available in a separate package (seafile-server-fuse).
* Add myself as a maintainer
Signed-off-by: Jeffery To <jeffery.to@gmail.com>
105 lines
3.9 KiB
Diff
105 lines
3.9 KiB
Diff
--- a/scripts/seaf-fsck.sh
|
|
+++ b/scripts/seaf-fsck.sh
|
|
@@ -8,9 +8,9 @@ TOPDIR=$(dirname "${INSTALLPATH}")
|
|
default_ccnet_conf_dir=${TOPDIR}/ccnet
|
|
default_seafile_data_dir=${TOPDIR}/seafile-data
|
|
default_conf_dir=${TOPDIR}/conf
|
|
-seaf_fsck=${INSTALLPATH}/seafile/bin/seaf-fsck
|
|
+seaf_fsck=/usr/libexec/seaf-fsck
|
|
|
|
-export PATH=${INSTALLPATH}/seafile/bin:$PATH
|
|
+export PATH=/usr/libexec:$PATH
|
|
export SEAFILE_LD_LIBRARY_PATH=${INSTALLPATH}/seafile/lib/:${INSTALLPATH}/seafile/lib64:${LD_LIBRARY_PATH}
|
|
|
|
script_name=$0
|
|
--- a/scripts/seaf-fuse.sh
|
|
+++ b/scripts/seaf-fuse.sh
|
|
@@ -8,9 +8,9 @@ TOPDIR=$(dirname "${INSTALLPATH}")
|
|
default_ccnet_conf_dir=${TOPDIR}/ccnet
|
|
default_seafile_data_dir=${TOPDIR}/seafile-data
|
|
default_conf_dir=${TOPDIR}/conf
|
|
-seaf_fuse=${INSTALLPATH}/seafile/bin/seaf-fuse
|
|
+seaf_fuse=/usr/libexec/seaf-fuse
|
|
|
|
-export PATH=${INSTALLPATH}/seafile/bin:$PATH
|
|
+export PATH=/usr/libexec:$PATH
|
|
export SEAFILE_LD_LIBRARY_PATH=${INSTALLPATH}/seafile/lib/:${INSTALLPATH}/seafile/lib64:${LD_LIBRARY_PATH}
|
|
|
|
script_name=$0
|
|
--- a/scripts/seaf-gc.sh
|
|
+++ b/scripts/seaf-gc.sh
|
|
@@ -8,10 +8,10 @@ TOPDIR=$(dirname "${INSTALLPATH}")
|
|
default_ccnet_conf_dir=${TOPDIR}/ccnet
|
|
default_seafile_data_dir=${TOPDIR}/seafile-data
|
|
default_conf_dir=${TOPDIR}/conf
|
|
-seaf_gc=${INSTALLPATH}/seafile/bin/seafserv-gc
|
|
+seaf_gc=/usr/libexec/seafserv-gc
|
|
seaf_gc_opts=""
|
|
|
|
-export PATH=${INSTALLPATH}/seafile/bin:$PATH
|
|
+export PATH=/usr/libexec:$PATH
|
|
export SEAFILE_LD_LIBRARY_PATH=${INSTALLPATH}/seafile/lib/:${INSTALLPATH}/seafile/lib64:${LD_LIBRARY_PATH}
|
|
|
|
script_name=$0
|
|
--- a/scripts/seafile.sh
|
|
+++ b/scripts/seafile.sh
|
|
@@ -18,9 +18,9 @@ TOPDIR=$(dirname "${INSTALLPATH}")
|
|
default_ccnet_conf_dir=${TOPDIR}/ccnet
|
|
default_seafile_data_dir=${TOPDIR}/seafile-data
|
|
central_config_dir=${TOPDIR}/conf
|
|
-seaf_controller="${INSTALLPATH}/seafile/bin/seafile-controller"
|
|
+seaf_controller="/usr/libexec/seafile-controller"
|
|
|
|
-export PATH=${INSTALLPATH}/seafile/bin:$PATH
|
|
+export PATH=/usr/libexec:$PATH
|
|
export ORIG_LD_LIBRARY_PATH=${LD_LIBRARY_PATH}
|
|
export SEAFILE_LD_LIBRARY_PATH=${INSTALLPATH}/seafile/lib/:${INSTALLPATH}/seafile/lib64:${LD_LIBRARY_PATH}
|
|
|
|
--- a/scripts/seahub.sh
|
|
+++ b/scripts/seahub.sh
|
|
@@ -25,7 +25,7 @@ gunicorn_conf=${TOPDIR}/conf/gunicorn.co
|
|
pidfile=${TOPDIR}/pids/seahub.pid
|
|
errorlog=${TOPDIR}/logs/gunicorn_error.log
|
|
accesslog=${TOPDIR}/logs/gunicorn_access.log
|
|
-gunicorn_exe=${INSTALLPATH}/seahub/thirdpart/bin/gunicorn
|
|
+gunicorn_exe=/usr/bin/gunicorn3
|
|
|
|
script_name=$0
|
|
function usage () {
|
|
@@ -233,9 +233,9 @@ function clear_sessions () {
|
|
function stop_seahub () {
|
|
if [[ -f ${pidfile} ]]; then
|
|
echo "Stopping seahub ..."
|
|
- pkill -9 -f "thirdpart/bin/gunicorn"
|
|
+ pkill -9 -f "/usr/bin/gunicorn3"
|
|
sleep 1
|
|
- if pgrep -f "thirdpart/bin/gunicorn" 2>/dev/null 1>&2 ; then
|
|
+ if pgrep -f "/usr/bin/gunicorn3" 2>/dev/null 1>&2 ; then
|
|
echo 'Failed to stop seahub.'
|
|
exit 1
|
|
fi
|
|
--- a/scripts/setup-seafile-mysql.py
|
|
+++ b/scripts/setup-seafile-mysql.py
|
|
@@ -299,7 +299,7 @@ class EnvManager(object):
|
|
def __init__(self):
|
|
self.install_path = os.path.dirname(os.path.abspath(__file__))
|
|
self.top_dir = os.path.dirname(self.install_path)
|
|
- self.bin_dir = os.path.join(self.install_path, 'seafile', 'bin')
|
|
+ self.bin_dir = '/usr/libexec'
|
|
self.central_config_dir = os.path.join(self.top_dir, 'conf')
|
|
self.central_pids_dir = os.path.join(self.top_dir, 'pids')
|
|
self.central_logs_dir = os.path.join(self.top_dir, 'logs')
|
|
--- a/scripts/setup-seafile.sh
|
|
+++ b/scripts/setup-seafile.sh
|
|
@@ -455,8 +455,8 @@ if [[ "${need_pause}" == "1" ]]; then
|
|
read dummy
|
|
fi
|
|
|
|
-ccnet_init=${INSTALLPATH}/seafile/bin/ccnet-init
|
|
-seaf_server_init=${INSTALLPATH}/seafile/bin/seaf-server-init
|
|
+ccnet_init=/usr/libexec/ccnet-init
|
|
+seaf_server_init=/usr/libexec/seaf-server-init
|
|
|
|
# -------------------------------------------
|
|
# Create ccnet conf
|