feat: first commit
This commit is contained in:
94
netoik-cloud.spec
Normal file
94
netoik-cloud.spec
Normal file
@@ -0,0 +1,94 @@
|
||||
%define debug_package %{nil}
|
||||
|
||||
Name: %(make name)
|
||||
Version: %(make version)
|
||||
Release: %(make release)
|
||||
Summary: %(make summary)
|
||||
License: %(make license)
|
||||
URL: %(make url)
|
||||
|
||||
Source0: %(make source0)
|
||||
Buildarch: %(make arch)
|
||||
BuildRequires: make
|
||||
Requires: netoik-rp netoik-db netoik-cache php php-cli php-gd php-mbstring php-intl php-pecl-apcu php-mysqlnd php-opcache php-json php-zip php-redis php-imagick php-fpm
|
||||
|
||||
%description
|
||||
Install the cloud server called Nextcloud.
|
||||
|
||||
%prep
|
||||
%autosetup -v
|
||||
|
||||
%install
|
||||
%make_install
|
||||
|
||||
%post
|
||||
# Display commands and exit on error
|
||||
set -xe
|
||||
|
||||
# Create nextcloud user
|
||||
if ! id nextcloud >/dev/null 2>&1; then
|
||||
useradd --no-create-home --shell $SHELL --system nextcloud
|
||||
fi
|
||||
|
||||
# Add nextcloud to postgres and valkey groups
|
||||
usermod --groups postgres,valkey --user nextcloud
|
||||
|
||||
# Download nextcloud latest release
|
||||
wget --output-document %{_tmppath}/nextcloud-latest.tar.bz2 https://download.nextcloud.com/server/releases/latest.tar.bz2
|
||||
wget --output-document %{_tmppath}/nextcloud-latest.tar.bz2.asc https://download.nextcloud.com/server/releases/latest.tar.bz2.asc
|
||||
wget --output-document %{_tmppath}/nextcloud.asc https://nextcloud.com/nextcloud.asc
|
||||
gpg --import %{_tmppath}/nextcloud.asc
|
||||
gpg --verify %{_tmppath}/nextcloud-latest.tar.bz2.asc %{_tmppath}/nextcloud-latest.tar.bz2
|
||||
tar --extract --file=%{_tmppath}/nextcloud-latest.tar.bz2 --directory=%{_sharedstatedir}
|
||||
|
||||
# Change rights an owner
|
||||
chown nextcloud:nextcloud %{_sharedstatedir}/nextcloud
|
||||
chmod 700 %{_sharedstatedir}/nextcloud
|
||||
|
||||
# Create data dir
|
||||
runuser --user=nextcloud -- mkdir %{_sharedstatedir}/nextcloud/data
|
||||
|
||||
# Add link to config
|
||||
runuser --user=nextcloud -- ln --symbolic --force %{_sysconfdir}/nextcloud/config.php %{_sharedstatedir}/nextcloud/config/config.php
|
||||
|
||||
# Create postgres user and db
|
||||
if ! runuser --user=postgres -- psql --quiet --tuples-only --command='\du' | grep --quiet nextcloud; then
|
||||
runuser --user=postgres -- createuser nextcloud
|
||||
fi
|
||||
if ! runuser --user=postgres -- psql --quiet --tuples-only --command='\l' | grep --quiet nextcloud; then
|
||||
runuser --user=postgres -- createdb --owner=nextcloud nextcloud
|
||||
fi
|
||||
|
||||
# Restart services
|
||||
systemctl daemon-reload
|
||||
systemctl reenable nginx.service php-fpm.service
|
||||
systemctl restart nginx.service php-fpm.service
|
||||
|
||||
%postun
|
||||
# Display commands and exit on error
|
||||
set -xe
|
||||
|
||||
# Stop service
|
||||
systemctl stop php-fpm
|
||||
|
||||
# If uninstalling, then delete user and db
|
||||
if [ $1 == 0 ]; then
|
||||
if id nextcloud; then
|
||||
userdel --force --remove nextcloud
|
||||
fi
|
||||
if runuser --user=postgres -- psql --quiet --tuples-only --command='\l' | grep --quiet nextcloud; then
|
||||
runuser --user=postgres -- dropdb nextcloud
|
||||
fi
|
||||
if runuser --user=postgres -- psql --quiet --tuples-only --command='\du' | grep --quiet nextcloud; then
|
||||
runuser --user=postgres -- dropuser nextcloud
|
||||
fi
|
||||
fi
|
||||
|
||||
%files
|
||||
%dir %attr(755, root, root) %{_sysconfdir}/nextcloud
|
||||
%attr(640, root, -) %{_sysconfdir}/nextcloud/config.php
|
||||
|
||||
%attr(644, root, root) %{_sysconfdir}/nginx/conf.d/cloud.netoik.io.conf
|
||||
|
||||
%changelog
|
||||
%autochangelog
|
||||
Reference in New Issue
Block a user