git: 3fc479f35f65 - main - www/pydio-cells: Fix build and overhaul

Serhii Kozlov (Sergey) skozlov at FreeBSD.org
Sun May 30 11:31:47 UTC 2021


The branch main has been updated by skozlov:

URL: https://cgit.FreeBSD.org/ports/commit/?id=3fc479f35f65392937dabe00b94b2ef4d8bec74d

commit 3fc479f35f65392937dabe00b94b2ef4d8bec74d
Author:     Serhii (Sergey) Kozlov <skozlov at FreeBSD.org>
AuthorDate: 2021-05-17 21:27:39 +0000
Commit:     Serhii (Sergey) Kozlov <skozlov at FreeBSD.org>
CommitDate: 2021-05-30 11:27:16 +0000

    www/pydio-cells: Fix build and overhaul
    
    Summary:
    Pydio cells uses a custom version of packr to embed the static
    resources into the `cells` binary. Previously, the embedding process
    was not peformed, resulting in a non-functional binary. When trying
    to use the app, user will just get "404 Not Found" error instead of
    a web page.
    
    To fix this - before the build `gmake generate` has to be performed
    in the WRKSRC, and a special custom version of packr v1
    (devel/pydio-packr) has to be used.
    
    Other changes:
    - DOCS option was removed, as the README.md file didn't really provide
      any useful information for the port's users
    - Generation of bash and zsh completion files was added
    - App version is now provided during the build process (previously 0.1.0
      would be indicated instead of the real version)
    - Indicate failure to build on i386
    - Create separate user/group for running the daemon, as recommended by
      the administrator's manual
    - Add rc script
    - Add pkg-message with configuration instructions
    - Add more patches fixing bugs and adapting the code for FreeBSD
    
    No UPDATING is required, as the port was not functional previously
    
    Reviewed by:    koobs
    MFH:            No (port isn't in any of the quarterly branches yet)
    Differential Revision:          https://reviews.freebsd.org/D30323
---
 GIDs                                              |  2 +-
 UIDs                                              |  2 +-
 www/pydio-cells/Makefile                          | 56 ++++++++++++---
 www/pydio-cells/files/cells.in                    | 85 +++++++++++++++++++++++
 www/pydio-cells/files/patch-cmd_start.go          | 15 ++++
 www/pydio-cells/files/patch-common_config_dirs.go | 19 +++++
 www/pydio-cells/pkg-message                       | 24 +++++++
 7 files changed, 192 insertions(+), 11 deletions(-)

diff --git a/GIDs b/GIDs
index 58146b04c480..c88db791479c 100644
--- a/GIDs
+++ b/GIDs
@@ -230,7 +230,7 @@ webdis:*:287:
 ntopng:*:288:
 victoria-metrics:*:289:
 _gmid:*:290:
-# free: 291
+pydio:*:291:
 # free: 292
 # free: 293
 # free: 294
diff --git a/UIDs b/UIDs
index 47fca7e85caf..8a16d44b933c 100644
--- a/UIDs
+++ b/UIDs
@@ -235,7 +235,7 @@ webdis:*:287:287::0:0:webdis daemon user:/nonexistent:/usr/sbin/nologin
 ntopng:*:288:288::0:0:ntopng daemon user:/nonexistent:/usr/sbin/nologin
 victoria-metrics:*:289:289::0:0:VictoriaMetrics user:/nonexistent:/usr/sbin/nologin
 _gmid:*:290:290::0:0:gmid daemon user:/var/empty:/usr/sbin/nologin
-# free: 291
+pydio:*:291:291::0:0:pydio cells user:/var/pydio:/bin/sh
 # free: 292
 # free: 293
 # free: 294
diff --git a/www/pydio-cells/Makefile b/www/pydio-cells/Makefile
index 4c75e55d52b2..caa8ef3bae4b 100644
--- a/www/pydio-cells/Makefile
+++ b/www/pydio-cells/Makefile
@@ -1,6 +1,7 @@
 PORTNAME=	cells
-PORTVERSION=	2.2.7
 DISTVERSIONPREFIX=	v
+DISTVERSION=	2.2.7
+PORTREVISION=	1
 CATEGORIES=	www
 PKGNAMEPREFIX=	pydio-
 
@@ -10,20 +11,57 @@ COMMENT=	Nextgen file sharing platform for organizations
 LICENSE=	AGPLv3
 LICENSE_FILE=	${WRKSRC}/LICENSE
 
-USES=		go
+NOT_FOR_ARCHS=	i386
+NOT_FOR_ARCHS_REASON=	Not supported on i386
 
-GO_PKGNAME=	github.com/pydio/cells
+BUILD_DEPENDS=	pydio-packr:devel/pydio-packr
+
+USES=		go gmake
+USE_RC_SUBR=	${PORTNAME}
 USE_GITHUB=	yes
 GH_ACCOUNT=	pydio
 
+GO_PKGNAME=	github.com/pydio/cells
+GO_BUILDFLAGS=	-ldflags "-X github.com/pydio/cells/common.version=${DISTVERSION}"
+
+USERS=		pydio
+GROUPS=		pydio
 PLIST_FILES=	bin/cells
-PORTDOCS=	README.md
 
-OPTIONS_DEFINE=	DOCS
-DOCS_DESC=	Install pydio-cells README file
+OPTIONS_DEFINE=		BASH ZSH
+OPTIONS_DEFAULT=	BASH ZSH
+
+BASH_PLIST_FILES=	etc/bash_completion.d/${PORTNAME}
+ZSH_PLIST_FILES=	share/zsh/site-functions/_${PORTNAME}
+
+post-patch:
+	${REINPLACE_CMD} -e "s|\$${GOPATH}/bin/packr|${LOCALBASE}/bin/pydio-packr|g" \
+		${WRKSRC}/Makefile
+
+pre-build:
+	@cd ${WRKSRC} && \
+		${MAKE_CMD} generate
+
+post-build-BASH-on:
+	${SETENV} CELLS_WORKING_DIR=${WRKDIR}/wrkdir \
+		${GO_WRKDIR_BIN}/${PORTNAME} tools completion bash \
+		> ${WRKDIR}/bash_completions
+	@${REINPLACE_CMD} -e 's|${GO_WRKDIR_BIN}/||g' ${WRKDIR}/bash_completions
+
+post-build-ZSH-on:
+	${SETENV} CELLS_WORKING_DIR=${WRKDIR}/wrkdir \
+		${GO_WRKDIR_BIN}/${PORTNAME} tools completion zsh \
+		> ${WRKDIR}/zsh_completions
+	@${REINPLACE_CMD} -e 's|${GO_WRKDIR_BIN}/||g' ${WRKDIR}/zsh_completions
+
+post-install-BASH-on:
+	@${MKDIR} ${STAGEDIR}${PREFIX}/etc/bash_completion.d
+	${INSTALL_DATA} ${WRKDIR}/bash_completions \
+		${STAGEDIR}${PREFIX}/etc/bash_completion.d/${PORTNAME}
 
-do-install-DOCS-on:
-	${MKDIR} ${STAGEDIR}${DOCSDIR}
-	${INSTALL_DATA} ${WRKSRC}/${PORTDOCS} ${STAGEDIR}${DOCSDIR}
+post-install-ZSH-on:
+	@${MKDIR} ${STAGEDIR}${PREFIX}/share/zsh/site-functions
+	${INSTALL_DATA} ${WRKDIR}/zsh_completions \
+		${STAGEDIR}${PREFIX}/share/zsh/site-functions/_${PORTNAME}
 
 .include <bsd.port.mk>
diff --git a/www/pydio-cells/files/cells.in b/www/pydio-cells/files/cells.in
new file mode 100644
index 000000000000..b90b2995024e
--- /dev/null
+++ b/www/pydio-cells/files/cells.in
@@ -0,0 +1,85 @@
+#!/bin/sh
+
+# PROVIDE: cells
+# REQUIRE: LOGIN
+# KEYWORD: shutdown
+#
+# Add the following line to /etc/rc.conf to enable Pydio Cells:
+#
+# cells_enable (bool):     Set to "NO" by default.
+#                          Set to "YES" to enable Pydio Cells.
+# cells_user (str):        Default to "pydio".
+# cells_group (str):       Default to "pydio".
+#                          User and group to run Pydio Cells with.
+# cells_flags (str):       Additional flags to append to "cells start" command.
+#                          Read `cells help start` for more information.
+# cells_workingdir (str):  Default to "/var/pydio/.config/pydio/cells".
+#                          Application directory.
+# cells_logdir (str):      Default to "${cells_workingdir}/logs".
+#                          Directory for application logs.
+
+. /etc/rc.subr
+
+name=cells
+rcvar=cells_enable
+desc="Pydio Cells"
+
+load_rc_config cells
+
+: ${cells_enable:=NO}
+: ${cells_user:=pydio}
+: ${cells_group:=pydio}
+: ${cells_workingdir=/var/pydio/.config/pydio/cells}
+: ${cells_logdir="${cells_workingdir}/logs"}
+
+_envvars="CELLS_WORKING_DIR=${cells_workingdir} CELLS_LOG_DIR=${cells_logdir}"
+_sucmd=/usr/bin/su
+
+extra_commands=cli
+pidfile=/var/run/${name}/${name}.pid
+cli_precmd=cells_precmd
+cli_cmd="cells_cli $@"
+start_precmd=cells_precmd
+stop_cmd=cells_stop
+procname="%%PREFIX%%/bin/cells"
+command=/usr/sbin/daemon
+command_args="-p ${pidfile} -o ${cells_logdir}/cells.log env ${_envvars} ${procname} start ${cells_flags}"
+
+cells_precmd()
+{
+    # Create PID file directory
+    install -d -o ${cells_user} -g ${cells_group} -m 0755 "$(dirname ${pidfile})"
+
+    # Remove default flags, they're added in `command_args` manually
+    rc_flags=""
+}
+
+cells_cli()
+{
+    shift 1
+    ${_sucmd} -l ${cells_user} -c "exec env ${_envvars} ${procname} $*"
+}
+
+cells_stop()
+{
+    # Copy-paste from rc.subr
+    if [ -z "${rc_pid}" ]; then
+        [ -n "${rc_fast}" ] && return 0
+        _run_rc_notrunning
+        return 1
+    fi
+    _children_pids=$(pgrep -P ${rc_pid})
+
+    echo "Stopping ${name}."
+    _run_rc_doit "kill -TERM ${rc_pid}" || return 1
+
+    # Stopping children is unreliable, so re-send TERM to them
+    # and wait for both the parent and the children
+    for _pid in ${_children_pids}; do
+        kill -TERM ${_pid}
+    done
+
+    wait_for_pids ${rc_pid} ${children_pids}
+}
+
+run_rc_command "$1"
diff --git a/www/pydio-cells/files/patch-cmd_start.go b/www/pydio-cells/files/patch-cmd_start.go
new file mode 100644
index 000000000000..70beb4144f5e
--- /dev/null
+++ b/www/pydio-cells/files/patch-cmd_start.go
@@ -0,0 +1,15 @@
+--- cmd/start.go.orig	2021-05-06 12:02:02 UTC
++++ cmd/start.go
+@@ -289,7 +289,11 @@ ENVIRONMENT
+ 				if (process == nil || len(process.Services) == 0) && len(childrenProcesses) == 0 {
+ 					return nil
+ 				}
+-				log.Info("Services are still running ", zap.Any("services", process.Services))
++				// Already fixed upstream, should be in the next version after 2.2.7:
++				// https://github.com/pydio/cells/issues/325
++				if (process != nil) {
++					log.Info("Services are still running ", zap.Any("services", process.Services))
++				}
+ 				continue
+ 			case <-timeout:
+ 				return nil
diff --git a/www/pydio-cells/files/patch-common_config_dirs.go b/www/pydio-cells/files/patch-common_config_dirs.go
new file mode 100644
index 000000000000..3f72940370be
--- /dev/null
+++ b/www/pydio-cells/files/patch-common_config_dirs.go
@@ -0,0 +1,19 @@
+--- common/config/dirs.go.orig	2021-05-06 12:02:02 UTC
++++ common/config/dirs.go
+@@ -54,9 +54,14 @@ func ApplicationWorkingDir(dirType ...ApplicationDirTy
+ 	} else if d == ApplicationDirServices && os.Getenv("CELLS_SERVICES_DIR") != "" {
+ 		f = os.Getenv("CELLS_SERVICES_DIR")
+ 	} else {
+-		vendor := "Pydio"
+-		if runtime.GOOS == "linux" {
++		// Pull request upstream:
++		// https://github.com/pydio/cells/pull/326
++		var vendor string
++		switch runtime.GOOS {
++		case "linux", "freebsd":
+ 			vendor = "pydio"
++		default:
++			vendor = "Pydio"
+ 		}
+ 		appName := "cells"
+ 		configDirs := configdir.New(vendor, appName)
diff --git a/www/pydio-cells/pkg-message b/www/pydio-cells/pkg-message
new file mode 100644
index 000000000000..bc70d7cedc82
--- /dev/null
+++ b/www/pydio-cells/pkg-message
@@ -0,0 +1,24 @@
+[
+{ type: install
+  message: <<EOM
+To configure and start Pydio Cells:
+
+1. Enable cells in rc.conf:
+   # sysrc cells_enable=YES
+
+2. (optional) Set the custom working and log directories:
+   # sysrc cells_workingdir=<working_dir>
+   # sysrc cells_logdir=<log_dir>
+
+3. Run the configuration
+   # service cells cli configure --exit_after_install
+
+4. When the configuration master finishes - start the cells
+   # service cells start
+
+To control your installation you can use cells CLI
+with workingdir and logdir set by running:
+# service cells cli ...
+EOM
+}
+]


More information about the dev-commits-ports-all mailing list