Log In
Log In
Places
All Projects
Status Monitor
Collapse sidebar
zimbra:talk
prosody
prosody.spec
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File prosody.spec of Package prosody
%global sslcert %{_sysconfdir}/pki/%{name}/localhost.crt %global sslkey %{_sysconfdir}/pki/%{name}/localhost.key %global luaver 5.1 %global vernum 0.10 %global buildnum 290 Summary: Flexible communications server for Jabber/XMPP Name: prosody Version: %{vernum}~1.%{buildnum} Release: 1%{?dist} License: MIT Group: System Environment/Daemons URL: https://prosody.im/ Source0: https://prosody.im/nightly/%{vernum}/build%{buildnum}/%{name}-%{vernum}-1nightly%{buildnum}.tar.gz Source1: prosody.init Source2: prosody.logrotate-init Source3: prosody.service Source4: prosody.logrotate-service Source5: prosody.tmpfilesd Source6: prosody-localhost.cfg.lua Source7: prosody-example.com.cfg.lua Patch0: prosody-0.10-config.patch BuildRequires: libidn-devel, openssl-devel Requires: %{_bindir}/openssl Requires(pre): shadow-utils %if 0%{?rhel} > 6 || 0%{?fedora} > 17 Requires(post): systemd, %{_bindir}/openssl Requires(preun): systemd Requires(postun): systemd BuildRequires: systemd %else Requires(post): /sbin/chkconfig, %{_bindir}/openssl Requires(preun): /sbin/service, /sbin/chkconfig Requires(postun): /sbin/service %endif %if 0%{?rhel} > 7 || 0%{?fedora} > 19 # Prosody does not work with lua >= 5.2, so use compat-lua instead of lua # on Fedora >= 20; luajit (compatible with 5.1) would be second choice. Requires: compat-lua, lua-filesystem-compat, lua-expat-compat Requires: lua-socket-compat, lua-sec-compat BuildRequires: compat-lua-devel %else %if 0%{?rhel} > 6 || 0%{?fedora} > 15 Requires: lua(abi) = %{luaver} %else Requires: lua >= %{luaver} %endif Requires: lua-filesystem, lua-expat, lua-socket, lua-sec BuildRequires: lua-devel %endif BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) %description Prosody is a flexible communications server for Jabber/XMPP written in Lua. It aims to be easy to use, and light on resources. For developers it aims to be easy to extend and give a flexible system on which to rapidly develop added functionality, or prototype new protocols. %prep %setup -q -n %{name}-%{vernum}-1nightly%{buildnum} %patch0 -p1 -b .config %build ./configure \ --prefix=%{_prefix} \ --libdir=%{_libdir} \ %if 0%{?rhel} > 7 || 0%{?fedora} > 19 --with-lua-include=%{_includedir}/lua-%{luaver} \ --runwith=lua-%{luaver} \ %else --with-lua-include=%{_includedir} \ %endif --cflags="$RPM_OPT_FLAGS -fPIC -D_GNU_SOURCE" \ --ldflags="$RPM_LD_FLAGS -shared" \ --no-example-certs make %{?_smp_mflags} # Make prosody-migrator make -C tools/migration %{?_smp_mflags} %install rm -rf $RPM_BUILD_ROOT mkdir -p $RPM_BUILD_ROOT{%{_sysconfdir}/pki,%{_localstatedir}/{lib,log}/%{name}}/ make DESTDIR=$RPM_BUILD_ROOT install # Install prosody-migrator make -C tools/migration DESTDIR=$RPM_BUILD_ROOT install # Install ejabberd2prosody install -p -m 755 tools/ejabberd2prosody.lua $RPM_BUILD_ROOT%{_bindir}/ejabberd2prosody sed -e 's@;../?.lua@;%{_libdir}/%{name}/util/?.lua;%{_libdir}/%{name}/?.lua;@' \ %if 0%{?rhel} > 7 || 0%{?fedora} > 19 -e '1s@ lua$@ lua-%{luaver}@' \ %endif -i $RPM_BUILD_ROOT%{_bindir}/ejabberd2prosody touch -c -r tools/ejabberd2prosody.lua $RPM_BUILD_ROOT%{_bindir}/ejabberd2prosody install -p -m 644 tools/erlparse.lua $RPM_BUILD_ROOT%{_libdir}/%{name}/util/ # Move certificates directory and symlink it mv -f $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/certs/ $RPM_BUILD_ROOT%{_sysconfdir}/pki/%{name}/ ln -s ../pki/%{name}/ $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/certs # Install systemd/tmpfiles or initscript files %if 0%{?fedora} >= 15 || 0%{?rhel} >= 7 install -D -p -m 644 %{SOURCE3} $RPM_BUILD_ROOT%{_unitdir}/%{name}.service install -D -p -m 644 %{SOURCE4} $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/%{name} install -D -p -m 644 %{SOURCE5} $RPM_BUILD_ROOT%{_tmpfilesdir}/%{name}.conf mkdir -p $RPM_BUILD_ROOT/run/%{name} %else install -D -p -m 755 %{SOURCE1} $RPM_BUILD_ROOT%{_sysconfdir}/rc.d/init.d/%{name} install -D -p -m 644 %{SOURCE2} $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/%{name} mkdir -p $RPM_BUILD_ROOT%{_localstatedir}/run/%{name} sed -e 's@/run@%{_localstatedir}/run@' -i $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/prosody.cfg.lua %endif # Keep configuration file timestamp touch -c -r prosody.cfg.lua.dist.config $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/prosody.cfg.lua # Install virtual host configuration install -D -p -m 644 %{SOURCE6} $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/conf.d/localhost.cfg.lua install -D -p -m 644 %{SOURCE7} $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/conf.d/example.com.cfg.lua # Fix permissions for rpmlint chmod 755 $RPM_BUILD_ROOT%{_libdir}/%{name}/util/*.so # Fix incorrect end-of-line encoding sed -e 's/\r//g' -i doc/stanza.txt doc/session.txt doc/roster_format.txt %clean rm -rf $RPM_BUILD_ROOT %pre getent group %{name} > /dev/null || %{_sbindir}/groupadd -r %{name} getent passwd %{name} > /dev/null || %{_sbindir}/useradd -r -g %{name} -d %{_localstatedir}/lib/%{name} -s /sbin/nologin -c "Prosody XMPP Server" %{name} exit 0 %post %if 0%{?rhel} > 6 || 0%{?fedora} > 17 %systemd_post %{name}.service %else /sbin/chkconfig --add %{name} %endif if [ ! -f %{sslkey} ]; then umask 077 %{_bindir}/openssl genrsa 2048 > %{sslkey} 2> /dev/null chown root:%{name} %{sslkey} chmod 640 %{sslkey} fi if [ ! -f %{sslcert} ]; then FQDN=`hostname` if [ "x${FQDN}" = "x" ]; then FQDN=localhost.localdomain fi cat << EOF | %{_bindir}/openssl req -new -key %{sslkey} -x509 -sha256 -days 365 -set_serial $RANDOM -out %{sslcert} 2> /dev/null -- SomeState SomeCity SomeOrganization SomeOrganizationalUnit ${FQDN} root@${FQDN} EOF chmod 644 %{sslcert} fi %preun %if 0%{?rhel} > 6 || 0%{?fedora} > 17 %systemd_preun %{name}.service %else if [ $1 -eq 0 ]; then /sbin/service %{name} stop > /dev/null 2>&1 || : /sbin/chkconfig --del %{name} fi %endif %postun %if 0%{?rhel} > 6 || 0%{?fedora} > 17 %systemd_postun_with_restart %{name}.service %else if [ $1 -ne 0 ]; then /sbin/service %{name} condrestart > /dev/null 2>&1 || : fi %endif %files %defattr(-,root,root,-) %{!?_licensedir:%global license %%doc} %license COPYING %doc AUTHORS HACKERS README doc/* %{_bindir}/%{name} %{_bindir}/%{name}ctl %{_bindir}/%{name}-migrator %{_bindir}/ejabberd2prosody %{_libdir}/%{name}/ %dir %attr(750,root,%{name}) %{_sysconfdir}/pki/%{name}/ %config(noreplace) %attr(0640,root,%{name}) %{_sysconfdir}/pki/%{name}/* %dir %attr(750,root,%{name}) %{_sysconfdir}/%{name}/ %config(noreplace) %attr(0640,root,%{name}) %{_sysconfdir}/%{name}/*.cfg.lua %dir %attr(750,root,%{name}) %{_sysconfdir}/%{name}/conf.d/ %config(noreplace) %attr(0640,root,%{name}) %{_sysconfdir}/%{name}/conf.d/*.cfg.lua %attr(750,root,%{name}) %{_sysconfdir}/%{name}/certs %config(noreplace) %{_sysconfdir}/logrotate.d/%{name} %if 0%{?rhel} > 6 || 0%{?fedora} > 17 %{_unitdir}/%{name}.service %{_tmpfilesdir}/%{name}.conf %dir %attr(0755,%{name},%{name}) /run/%{name}/ %else %{_sysconfdir}/rc.d/init.d/%{name} %dir %attr(0755,%{name},%{name}) %{_localstatedir}/run/%{name}/ %endif %dir %attr(750,%{name},%{name}) %{_localstatedir}/lib/%{name}/ %dir %attr(750,%{name},%{name}) %{_localstatedir}/log/%{name}/ %{_mandir}/man1/%{name}*.1*
Locations
Projects
Search
Status Monitor
Help
OpenBuildService.org
Documentation
API Documentation
Contact
Support
@OBShq
The Open Build Service is an
openSUSE project
.
Log In
Places
Places
All Projects
Status Monitor