diff options
Diffstat (limited to 'PKGBUILD')
-rw-r--r-- | PKGBUILD | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/PKGBUILD b/PKGBUILD new file mode 100644 index 000000000000..756295a2d512 --- /dev/null +++ b/PKGBUILD @@ -0,0 +1,92 @@ +# Maintainer: amo <https://aur.archlinux.org/account/amo> +# Contributor: Lucki <https://aur.archlinux.org/account/Lucki> + +pkgname=papermerge +pkgver=1.5.3 +pkgrel=1 +pkgdesc="An open source document management system (DMS) primarily designed for archiving and retrieving your digital documents." +arch=('any') +url="https://github.com/ciur/papermerge" +license=('Apache') +backup=("etc/$pkgname.conf.py" "usr/lib/python3.8/site-packages/config/settings/production.py") +install=$pkgname.install +depends=('imagemagick' 'pdftk' 'poppler' 'python-celery' 'python-django' 'python-django-allauth' 'python-django-celery-results' 'python-django-dynamic-preferences' 'python-django-modelcluster' 'python-django-mptt' 'python-django-polymorphic-tree' 'python-django-rest-framework' 'python-django-rest-knox' 'python-django-taggit' 'python-imapclient' 'python-lxml' 'python-mgclipboard' 'python-mglib' 'python-psycopg2' 'python-pyaml' 'tesseract' 'gunicorn') +optdepends=('nginx: reverse proxy for papermerge provided by gunicorn' 'redis: file based transport of messaging queue' 'python-redis: file based transport of messaging queue') +source=("$pkgname-$pkgver.src.tar.gz::https://github.com/ciur/$pkgname/archive/v$pkgver.tar.gz" + "$pkgname.install" + "$pkgname.sysusers" + "$pkgname.tmpfiles" + "$pkgname-gunicorn.service" + "$pkgname-worker.service" + "$pkgname.sh") +sha512sums=('f6ac25b363ddf81b9e2631c1b963a1f04ed679a7174caac91bf42ef5b81929ad49b1be3a5ace17e038406a688a773f0e0b80b95549dbeb5414823374a33b98e7' + 'c63ce4c8eb95c477c37f70d4a6abba2e467f72617d2032e5dbe7e6a73a63ce092acacb9ec4d8776e5d5fba7351e1b81c18a69afc5960bff0d269086930c4c11f' + 'eb408d6d6c0072b4883cae9b6aa591935b910585e93aa6fdacbb543dbc4233588678d396c06d0f10b7c74b4d393af19b8be526d094821de23792c29df593d4a5' + '6b14701ab03192756f00d7d9105aceba82c808341099819e4830e601d005e808261c381b0580d65e9d0d489a6906bf85b249edb6b5f6d8bd5173f2b78e8fefce' + '4a8e1d3ce19e0ce13febea0c93d5130c492eb3d319194eb63791ad5a95f40083f2f90d299a74f1059865db1d38b6effb1f9cbfe4576680a70b43b6a594c85b9a' + 'fcdd49e0b6b93ade84ddafd77111f28bdea75a4f12829ec249d414d46a14399198be7bf29d0ce5166de6dba1d6386eda4ab9b39a1f5376b7c7758c8966a53ce3' + 'b838d54dca56e45f99690ddaae1b058e3f72b314adf9d689869f14bb141a5bbf209df974eea20cb2305b127d5119d0b8d11293494d47350f6974edc6fffc374f') + +prepare() { + { + echo 'DBDIR = "/var/lib/papermerge/database"'; + echo 'MEDIA_DIR = "/var/lib/papermerge/media"'; + echo 'STATIC_DIR = "/var/lib/papermerge/static"'; + echo 'IMPORTER_DIR = "/var/lib/papermerge/import"'; + echo 'TASK_QUEUE_DIR = "/var/tmp/papermerge/queue"' + } >> "$pkgname-$pkgver/$pkgname.conf.py.example" + + # https://papermerge.readthedocs.io/en/latest/setup/server_configurations.html#step-1-install-gunicorn + { + echo 'from .base import * # noqa'; + echo 'DEBUG = False'; + echo "ALLOWED_HOSTS = ['*']" + } > "$pkgname-$pkgver/config/settings/production.py" + + # The admin package is missing somehow so let's move it plain stupid directly in place + mkdir -p "$pkgname-$pkgver/build/lib/$pkgname/" + cp -dpr --no-preserve=ownership "$pkgname-$pkgver/$pkgname/contrib" "$pkgname-$pkgver/build/lib/$pkgname/" +} + +build() { + cd "$pkgname-$pkgver" || exit + python setup.py build +} + +check() { + cd "$pkgname-$pkgver" || exit + ./run_tests.sh +} + +package() { + # tmpfiles.d + install -Dm 644 "$pkgname.tmpfiles" \ + "$pkgdir/usr/lib/tmpfiles.d/$pkgname.conf" + + # sysusers.d + install -Dm 644 "$pkgname.sysusers" \ + "$pkgdir/usr/lib/sysusers.d/$pkgname.conf" + + # service files + install -Dm 644 "$pkgname-gunicorn.service" \ + "$pkgdir/usr/lib/systemd/system/$pkgname-gunicorn.service" + install -Dm 644 "$pkgname-worker.service" \ + "$pkgdir/usr/lib/systemd/system/$pkgname-worker.service" + + # wrapper + install -Dm 755 "$pkgname.sh" \ + "$pkgdir/usr/bin/$pkgname-manage" + + cd "$pkgname-$pkgver" || exit + + # config + install -Dm 644 "$pkgname.conf.py.example" \ + "$pkgdir/etc/$pkgname.conf.py" + + # migrations + # mkdir -p "$pkgdir/usr/lib/python3.8/site-packages/papermerge/core" + # ln -s /var/lib/papermerge/migrations "$pkgdir/usr/lib/python3.8/site-packages/papermerge/core/migrations" + + export PYTHONHASHSEED=0 + python setup.py install --root="$pkgdir" --optimize=1 --skip-build +} |