diff options
Diffstat (limited to 'www-apps/pleroma/pleroma-2.10.2.ebuild')
| -rw-r--r-- | www-apps/pleroma/pleroma-2.10.2.ebuild | 137 |
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 +} |
