git: 0e4fb336cba5 - main - www/opengist: Build fixes and improvements
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Sun, 09 Mar 2025 00:57:22 UTC
The branch main has been updated by fox:
URL: https://cgit.FreeBSD.org/ports/commit/?id=0e4fb336cba5439a9f7f692df86c87a6dc1519f8
commit 0e4fb336cba5439a9f7f692df86c87a6dc1519f8
Author: Dave Cottlehuber <dch@freebsd.org>
AuthorDate: 2025-03-09 00:45:26 +0000
Commit: Santhosh Raju <fox@FreeBSD.org>
CommitDate: 2025-03-09 00:51:52 +0000
www/opengist: Build fixes and improvements
un-break arm64 by installing both esbuild arches
- stop lang/go from fetching newer toolchains during build
- pet port with portfmt & portclippy, fix pkg-plist
run under non-root user by default
- add UID, GID for opengist user
- amend rc script to support user
PR: 285179
Reviewed by: fox
Sponsored by: SkunkWerks, GmbH
---
GIDs | 2 +-
UIDs | 2 +-
www/opengist/Makefile | 45 ++++++++++++++++++++++++++++--------------
www/opengist/distinfo | 6 +++---
www/opengist/files/opengist.in | 32 +++++++++++++++++++++++-------
www/opengist/pkg-plist | 7 +++----
6 files changed, 63 insertions(+), 31 deletions(-)
diff --git a/GIDs b/GIDs
index db0429c94754..c3797e521400 100644
--- a/GIDs
+++ b/GIDs
@@ -306,7 +306,7 @@ readarr:*:362:
victoria-logs:*:363:
elog:*:364:
gotify:*:365:
-# free: 366
+opengist:*:366:
# free: 367
# free: 368
# free: 369
diff --git a/UIDs b/UIDs
index d29867210962..b2f2f4b4568f 100644
--- a/UIDs
+++ b/UIDs
@@ -312,7 +312,7 @@ readarr:*:362:362::0:0:Readarr Daemon:/nonexistent:/usr/sbin/nologin
victoria-logs:*:363:363::0:0:VictoriaLogs Daemon:/nonexistent:/usr/sbin/nologin
elog:*:364:364::0:0:Elog server:/nonexistent:/usr/sbin/nologin
gotify:*:365:365::0:0:Gotify User:/var/db/gotify:/usr/sbin/nologin
-# free: 366
+opengist:*:366:366::0:0:OpenGist User:/var/db/opengist:/usr/sbin/nologin
# free: 367
# free: 368
# free: 369
diff --git a/www/opengist/Makefile b/www/opengist/Makefile
index 8ed591351227..cf5acb6ddde2 100644
--- a/www/opengist/Makefile
+++ b/www/opengist/Makefile
@@ -1,9 +1,8 @@
PORTNAME= opengist
PORTVERSION= 1.8.4
DISTVERSIONPREFIX= v
-PORTREVISION= 1
CATEGORIES= www textproc
-MASTER_SITES= LOCAL/fox/:js
+MASTER_SITES= LOCAL/dch/:js
DISTFILES= opengist-${DISTVERSION}-node_modules.tgz:js
MAINTAINER= fox@FreeBSD.org
@@ -12,23 +11,26 @@ WWW= https://opengist.io/
LICENSE= AGPLv3
-BROKEN_aarch64= fails to build
BROKEN_i386= fails to build
BUILD_DEPENDS= npm${NODEJS_SUFFIX}>0:www/npm${NODEJS_SUFFIX}
RUN_DEPENDS= git:devel/git
-USES= go:modules nodejs:20,build
-USE_RC_SUBR= opengist
+USES= go:1.23,modules nodejs:20,build
USE_GITHUB= nodefault
GH_ACCOUNT= thomiceli
GH_PROJECT= opengist
+USE_RC_SUBR= opengist
GO_MODULE= github.com/thomiceli/opengist
GO_TARGET= .
GO_BUILDFLAGS= -tags fs_embed \
-ldflags="-X github.com/thomiceli/opengist/internal/config.OpengistVersion=v${DISTVERSION}"
+GO_ENV+= GOTOOLCHAIN=local+path
+
+GROUP= opengist
+USER= opengist
post-extract:
@${RLN} ${WRKDIR}/node_modules ${WRKSRC}/node_modules
@@ -38,18 +40,26 @@ post-patch:
${WRKSRC}/config.yml
pre-build:
- cd ${WRKSRC} && ${SETENV} ${MAKE_ENV} npx --offline vite -c public/vite.config.js build
- cd ${WRKSRC} && ${SETENV} ${MAKE_ENV} \
- EMBED=1 npx --offline postcss 'public/assets/embed-*.css' -c public/postcss.config.js --replace
+ cd ${WRKSRC} && \
+ ${SETENV} ${MAKE_ENV} npx --offline vite -c public/vite.config.js \
+ build
+ cd ${WRKSRC} && \
+ ${SETENV} ${MAKE_ENV} EMBED=1 npx --offline postcss 'public/assets/embed-*.css' \
+ -c public/postcss.config.js --replace
post-install:
${MKDIR} ${STAGEDIR}${PREFIX}/etc/${PORTNAME}
- ${INSTALL_DATA} ${WRKSRC}/config.yml ${STAGEDIR}${PREFIX}/etc/${PORTNAME}/config.yml.sample
+ ${INSTALL_DATA} ${WRKSRC}/config.yml \
+ ${STAGEDIR}${PREFIX}/etc/${PORTNAME}/config.yml.sample
${MKDIR} ${STAGEDIR}/var/db/${PORTNAME}
${MKDIR} ${STAGEDIR}/var/run/${PORTNAME}
${MKDIR} ${STAGEDIR}${WWWDIR}/assets
- cd ${WRKSRC} && ${INSTALL_DATA} public/assets/* ${STAGEDIR}${WWWDIR}/assets
- cd ${WRKSRC} && ${INSTALL_DATA} public/manifest.json ${STAGEDIR}${WWWDIR}
+ cd ${WRKSRC} && \
+ ${INSTALL_DATA} public/assets/* \
+ ${STAGEDIR}${WWWDIR}/assets
+ cd ${WRKSRC} && \
+ ${INSTALL_DATA} public/manifest.json \
+ ${STAGEDIR}${WWWDIR}
#
# To update the opengist-${DISTVERSION}-node_modules.tgz archive:
@@ -62,9 +72,14 @@ post-install:
regenerate-node_modules-distfile: patch
cd ${WRKSRC} && \
- ${RM} -r node_modules && \
- ${MAKE_ENV} npm install --prefix ${WRKSRC} && \
- ${TAR} czf ${DISTDIR}/opengist-${DISTVERSION}-node_modules.tgz node_modules && \
- ${ECHO} "Please upload the file ${DISTDIR}/opengist-${DISTVERSION}-node_modules.tgz"
+ ${RM} -r node_modules && \
+ ${MAKE_ENV} npm install --prefix ${WRKSRC} && \
+ ${MAKE_ENV} npm install --prefix ${WRKSRC} --os freebsd --cpu \
+ amd64 esbuild@0.18.20 && \
+ ${MAKE_ENV} npm install --prefix ${WRKSRC} --os freebsd --cpu \
+ arm64 esbuild@0.18.20 && \
+ ${TAR} czf ${DISTDIR}/opengist-${DISTVERSION}-node_modules.tgz \
+ node_modules && \
+ ${ECHO} "Please upload the file ${DISTDIR}/opengist-${DISTVERSION}-node_modules.tgz"
.include <bsd.port.mk>
diff --git a/www/opengist/distinfo b/www/opengist/distinfo
index 04f3196b3b13..4559945d6e54 100644
--- a/www/opengist/distinfo
+++ b/www/opengist/distinfo
@@ -1,6 +1,6 @@
-TIMESTAMP = 1735040783
-SHA256 (go/www_opengist/opengist-v1.8.4/opengist-1.8.4-node_modules.tgz) = 5fea4ceb76e5654a0ddc704cd212764f8a85663f569670b8750e16c8918a465c
-SIZE (go/www_opengist/opengist-v1.8.4/opengist-1.8.4-node_modules.tgz) = 22568160
+TIMESTAMP = 1741184663
+SHA256 (go/www_opengist/opengist-v1.8.4/opengist-1.8.4-node_modules.tgz) = 8aa17fda03b079a33a547a18bdd18e9792da02257bfb3c0ded442270d9efd044
+SIZE (go/www_opengist/opengist-v1.8.4/opengist-1.8.4-node_modules.tgz) = 26305117
SHA256 (go/www_opengist/opengist-v1.8.4/v1.8.4.mod) = e23e2417d8d5b9b0cfee169732e45679fe2cda94d3153c9edb51cc56ce7343ec
SIZE (go/www_opengist/opengist-v1.8.4/v1.8.4.mod) = 5060
SHA256 (go/www_opengist/opengist-v1.8.4/v1.8.4.zip) = 40454c34f595bba558c294bd65aeaf15efd97bb2aa07f78afcbb6b08582227e2
diff --git a/www/opengist/files/opengist.in b/www/opengist/files/opengist.in
index 9681c7d7fd1a..8249f946c892 100644
--- a/www/opengist/files/opengist.in
+++ b/www/opengist/files/opengist.in
@@ -4,15 +4,33 @@
# REQUIRE: LOGIN NETWORKING
# KEYWORD: shutdown
#
+# Add the following lines to /etc/rc.conf to run opengist:
+#
+# opengist_enable (bool): Set it to "YES" to enable opengist server.
+# Default is "NO".
+# opengist_home (str): Set the home directory for opengist server.
+# Default is "%%WWWDIR%%".
+# opengist_user (str): Set the user for running opengist server.
+# Default is "opengist".
+# opengist_config_file (str): Set config file location for opengist server.
+# Default is "%%PREFIX%%/etc/${name}/config.yml".
+# opengist_syslog_output_enable (bool): Set it to "YES" for enabling output to syslogd(8)
+# Default is "NO"
+# opengist_syslog_output_priority (str): Set logging priority.
+# Default is "info"
+# opengist_syslog_output_facility (str): Set logging facility
+# Default is "daemon"
. /etc/rc.subr
name=opengist
rcvar=opengist_enable
-load_rc_config $name
+load_rc_config ${name}
: ${opengist_enable:="NO"}
+: ${opengist_user:="opengist"}
+: ${opengist_files:="/var/db/opengist/"}
: ${opengist_home:="%%WWWDIR%%"}
: ${opengist_config_file:="%%PREFIX%%/etc/${name}/config.yml"}
: ${opengist_syslog_output_enable:="NO"}
@@ -39,18 +57,18 @@ start_precmd="${name}_precmd"
opengist_precmd()
{
- if [ ! -f ${opengist_config_file} ]
- then
+ if [ ! -f ${opengist_config_file} ]; then
echo ${opengist_config_file} missing.
return 1
fi
}
opengist_start() {
- /usr/sbin/daemon -f ${opengist_syslog_output_flags} -p ${pidfile} \
- /usr/bin/env -i \
- "PATH=%%PREFIX%%/bin:${PATH}" \
- ${procname} -c ${opengist_config_file}
+ echo "Starting opengist."
+ /usr/sbin/daemon -f ${opengist_syslog_output_flags} -p ${pidfile} \
+ /usr/bin/env -i \
+ "PATH=%%PREFIX%%/bin:${PATH}" \
+ ${procname} -c ${opengist_config_file}
}
cd ${opengist_home}
diff --git a/www/opengist/pkg-plist b/www/opengist/pkg-plist
index a5bbab4c2094..7881d75cf384 100644
--- a/www/opengist/pkg-plist
+++ b/www/opengist/pkg-plist
@@ -1,6 +1,5 @@
bin/opengist
-%%ETCDIR%%/config.yml.sample
-etc/rc.d/opengist
+@sample(opengist,opengist,640) %%ETCDIR%%/config.yml.sample
%%WWWDIR%%/assets/admin-f49fd6c0.js
%%WWWDIR%%/assets/default-f34219fc.png
%%WWWDIR%%/assets/editor-dd91ca8c.js
@@ -13,5 +12,5 @@ etc/rc.d/opengist
%%WWWDIR%%/assets/opengist-85b89b9c.svg
%%WWWDIR%%/assets/webauthn-da047c6d.js
%%WWWDIR%%/manifest.json
-@dir /var/db/opengist
-@dir /var/run/opengist
+@dir(opengist,opengist,640) /var/db/opengist
+@dir(opengist,opengist,600) /var/run/opengist