summaryrefslogtreecommitdiff
path: root/www-apps/pleroma/pleroma-2.10.2.ebuild
diff options
context:
space:
mode:
Diffstat (limited to 'www-apps/pleroma/pleroma-2.10.2.ebuild')
-rw-r--r--www-apps/pleroma/pleroma-2.10.2.ebuild137
1 files changed, 137 insertions, 0 deletions
diff --git a/www-apps/pleroma/pleroma-2.10.2.ebuild b/www-apps/pleroma/pleroma-2.10.2.ebuild
new file mode 100644
index 000000000000..ea7f5292580e
--- /dev/null
+++ b/www-apps/pleroma/pleroma-2.10.2.ebuild
@@ -0,0 +1,137 @@
+# Copyright 2022-2026 Haelwenn (lanodan) Monnier <contact@hacktivis.me>
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+inherit mix optfeature flag-o-matic toolchain-funcs
+
+DESCRIPTION="ActivityPub social networking software compatible with other Fediverse software"
+HOMEPAGE="https://pleroma.social/"
+if [[ "${PV}" == *9999 ]]; then
+ inherit git-r3
+ EGIT_REPO_URI="https://git.pleroma.social/pleroma/pleroma"
+else
+ SRC_URI="https://git.pleroma.social/pleroma/pleroma/archive/v${PV}.tar.gz -> pleroma-${PV}.tar.gz"
+ S="${WORKDIR}/${PN}"
+ KEYWORDS="~amd64"
+fi
+LICENSE="AGPL-3 CC-BY-SA-4.0 CC-BY-4.0"
+SLOT="otp"
+
+IUSE="+system-lexbor +system-vips"
+
+# Requires network access (https) as long as elixir dependencies aren't packaged
+# said dependencies have their checksum verified via `mix.lock`
+RESTRICT="network-sandbox"
+
+BDEPEND="
+ <dev-lang/erlang-27:=
+ >=dev-lang/elixir-1.14:=
+ <dev-lang/elixir-1.18
+ dev-build/cmake
+ >=dev-util/rebar-3.20.0-r1
+ dev-elixir/hex
+ dev-vcs/git
+"
+DEPEND="
+ dev-libs/glib
+ sys-apps/file
+ sys-libs/ncurses:=
+ system-lexbor? ( dev-libs/lexbor )
+ system-vips? ( media-libs/vips:= )
+"
+RDEPEND="
+ ${DEPEND}
+ acct-user/pleroma
+ acct-group/pleroma
+ dev-db/postgresql[uuid]
+"
+
+src_unpack() {
+ default
+
+ [[ "${PV}" == *9999 ]] && git-r3_src_unpack
+
+ cd "${S}" || die
+ emix deps.get --only prod
+}
+
+src_prepare() {
+ default
+
+ # Point to the correct source repo, needed for AGPL compliance
+ if [[ "${PV}" == *9999 ]] && [[ -n "${EGIT_OVERRIDE_REPO}" ]]; then
+ sed -i "s!source_url: .*!source_url: \"${EGIT_OVERRIDE_REPO}\",!" mix.exs || die
+ fi
+
+ # strip_beams: Keep debug information in Erlang BEAM bytecode
+ # include_erts: Depend on system erlang for the runtime
+ sed -i '/include_executables_for:/a\ strip_beams: false,\n\ include_erts: false,' mix.exs || die
+
+ sed -i \
+ -e '/update \[OPTIONS\]/,/--tmp-dir/d' \
+ -e 's;update "$@";echo "Unsupported, check the '"${CATEGORY}/${PN}"' package instead.";' \
+ rel/files/bin/pleroma_ctl || die
+
+ # Default ends up being inside /opt/pleroma which should be kept read-only to pleroma
+ echo 'config :tzdata, :data_dir, "/var/lib/pleroma/tzdata"' >> config/prod.exs || die
+
+ echo "import Config" > config/prod.secret.exs || die
+}
+
+src_compile() {
+ mkdir -p pleroma || die
+
+ tc-export CC
+
+ # Needs -fPIC under glibc for exile library
+ # https://bugs.gentoo.org/937130
+ append-flags -fPIC
+
+ use system-vips && export VIX_COMPILATION_MODE="PLATFORM_PROVIDED_LIBVIPS"
+
+ use system-lexbor && export WITH_SYSTEM_LEXBOR=1
+
+ emix release --overwrite --path pleroma
+}
+
+src_install() {
+ # doins doesn't seems to preserve permissions
+ mkdir -p "${ED}/opt" || die
+ cp -pr ./pleroma "${ED}/opt/pleroma" || die
+ fperms 0750 /opt/pleroma
+ fperms -R g-w,o= /opt/pleroma
+ fowners -R 0:pleroma /opt/pleroma
+
+ doinitd ./pleroma/installation/init.d/pleroma
+
+ # Generated by Elixir, see lib/mix/lib/mix/tasks/release.init.ex
+ # Real executable needs to be in /opt/pleroma/bin due to usage of readlink to guess install path
+ dosym /opt/pleroma/bin/pleroma /usr/bin/pleroma
+
+ # Technically could be with regular binaries via dobin,
+ # but useless without the pleroma command, which has restricted access
+ dosym /opt/pleroma/bin/pleroma_ctl /usr/bin/pleroma_ctl
+
+ # This file controls console access
+ fperms 0750 /opt/pleroma/releases/COOKIE
+ fowners 0:pleroma /opt/pleroma/releases/COOKIE
+
+ keepdir /etc/pleroma
+ fperms 0750 /etc/pleroma
+ fowners 0:pleroma /etc/pleroma
+
+ keepdir /var/lib/pleroma
+ fperms 0750 /var/lib/pleroma
+ fowners pleroma:pleroma /var/lib/pleroma
+
+ # So that www-apps/pleroma-fe (optional) doesn't ends up creating namespace conflicts
+ dosym /opt/pleroma-fe/dist /var/lib/pleroma/static/frontends/pleroma-fe/gentoo
+}
+
+pkg_postinst() {
+ optfeature "For Pleroma.Upload.Filters.{Mogrify,Mogrifun} & images in previews" media-gfx/imagemagick
+ optfeature "For video support in Media Preview Proxy" media-video/ffmpeg
+ optfeature "For Pleroma.Upload.Filters.Exiftool.* filters" media-libs/exiftool
+ optfeature "Allows to pick system-managed frontend instead of bundled" www-apps/pleroma-fe
+}