#
# Conditional build:
%bcond_with hadoop # Hadoop client (requires JNI)
+%bcond_without java # Java binding
#
Summary: User space components of the Ceph file system
Summary(pl.UTF-8): Działające w przestrzeni użytkownika elementy systemu plików Ceph
Name: ceph
-Version: 0.52
+Version: 0.56.3
Release: 1
-License: LGPL v2
+License: LGPL v2.1 (libraries), GPL v2 (some programs)
Group: Base
Source0: http://ceph.newdream.net/download/%{name}-%{version}.tar.bz2
-# Source0-md5: b3b9c8e7160d69cdf735628342a8dee0
+# Source0-md5: 949c348b95c72e0870fabb033e4d1f8e
Patch0: %{name}-init-fix.patch
Patch1: %{name}.logrotate.patch
Patch2: %{name}-link.patch
BuildRequires: expat-devel >= 1.95
BuildRequires: fcgi-devel
BuildRequires: gdbm-devel
-%{?with_hadoop:BuildRequires: jdk}
+%if %{with java} || %{with hadoop}
+BuildRequires: jdk
+%endif
BuildRequires: keyutils-devel
+BuildRequires: leveldb-devel
BuildRequires: libaio-devel
BuildRequires: libatomic_ops
BuildRequires: libedit-devel >= 2.11
BuildRequires: libfuse-devel
BuildRequires: libltdl-devel
+BuildRequires: libs3-devel
BuildRequires: libstdc++-devel
BuildRequires: libtcmalloc-devel
BuildRequires: libtool >= 2:1.5
BuildRequires: pkgconfig
BuildRequires: python >= 1:2.4
BuildRequires: rpmbuild(macros) >= 1.228
-BuildRequires: sed >= 4.0
+BuildRequires: snappy-devel
Requires(post,preun): /sbin/chkconfig
Requires(preun): rc-scripts
Requires: %{name}-libs = %{version}-%{release}
%package devel
Summary: Ceph header files
Summary(pl.UTF-8): Pliki nagłówkowe bibliotek Cepha
+License: LGPL v2.1
Group: Development/Libraries
Requires: %{name}-libs = %{version}-%{release}
+Requires: boost-devel >= 1.34
+Requires: cryptopp-devel
+Requires: leveldb-devel
+Requires: libatomic_ops
+Requires: libuuid-devel
%description devel
This package contains the headers needed to develop programs that use
%package static
Summary: Ceph static libraries
Summary(pl.UTF-8): Biblioteki statyczne Cepha
-License: LGPLv2
+License: LGPL v2.1
Group: Development/Libraries
Requires: %{name}-devel = %{version}-%{release}
%description -n python-ceph -l pl.UTF-8
Wiązania Pythona do bibliotek Cepha.
+%package -n java-cephfs
+Summary: CephFS Java bindings
+Summary(pl.UTF-8): Wiązania Javy do biblioteki CephFS
+Group: Libraries/Java
+Requires: %{name}-libs = %{version}-%{release}
+
+%description -n java-cephfs
+CephFS Java bindings.
+
+%description -n java-cephfs -l pl.UTF-8
+Wiązania Javy do biblioteki CephFS.
+
%package fuse
Summary: Ceph FUSE-based client
Summary(pl.UTF-8): Klient Cepha oparty na FUSE
Jest zaimplementowana jako moduł FastCGI wykorzystujący libfcgi i może
być używana w połączeniu z dowolnym serwerem WWW obsługującym FastCGI.
-%package obsync
-Summary: Synchronize data between cloud object storage providers or a local directory
-Summary(pl.UTF-8): Synchronizacja danych między obiektami przechowywanymi w chmurze i katalogami lokalnymi
-Group: Applications/Networking
-Requires: python
-Requires: python-boto
+%package resource-agents
+Summary: OCF Resource Agents for Ceph processes
+Summary(pl.UTF-8): Agenci OCF do monitorowania procesów Cepha
+Group: Applications/System
+Requires: %{name} = %{version}-%{release}
+Requires: resource-agents
+
+%description resource-agents
+OCF Resource Agents for Ceph processes.
-%description obsync
-obsync is a tool to synchronize objects between cloud object storage
-providers, such as Amazon S3 (or compatible services), a Ceph RADOS
-cluster, or a local directory.
+%description resource-agents -l pl.UTF-8
+Agenci OCF do monitorowania procesów Cepha.
-%description obsync -l pl.UTF-8
-obsync to narzędzie do synchronizacji obiektów między systemami
-przechowującymi obiekty w chmurze, takimi jak Amazon S3 (lub serwisy
-kompatybilne) a klastrem Ceph RADOS lub katalogiem lokalnym.
+%package -n hadoop-cephfs
+Summary: Hadoop client for Ceph filesystem
+Summary(pl.UTF-8): Klient Hadoopa dla systemu plików Ceph
+Group: Libraries
+Requires: %{name} = %{version}-%{release}
+Requires: hadoop
+
+%description -n hadoop-cephfs
+Hadoop client for Ceph filesystem.
+
+%description -n hadoop-cephfs -l pl.UTF-8
+Klient Hadoopa dla systemu plików Ceph.
%prep
%setup -q
%patch0 -p1
-%patch1 -p0
+%patch1 -p1
%patch2 -p1
-%{__sed} -i -e '1s,/usr/bin/env python,/usr/bin/python,' src/obsync/obsync
-
%build
%{__libtoolize}
%{__aclocal}
%{__autoconf}
%{__autoheader}
%{__automake}
+%{?with_hadoop:CPPFLAGS="%{rpmcppflags} -I%{_jvmdir}/java/include -I%{_jvmdir}/java/include/linux"}
%configure \
--sbindir=/sbin \
--with-cryptopp \
--with-hadoop%{!?with_hadoop:=no} \
+ --with-ocf \
--with-radosgw \
+ --with-system-leveldb \
+ --with-system-libs3 \
+ %{?with_java:--enable-cephfs-java --with-jdk-dir=%{_jvmdir}/java} \
--disable-silent-rules
-# --with-ocf ?
-# --with-system-leveldb (BR: libleveldb, snappy-devel)
-# --with-system-libs3 (BR: libs3)
%{__make}
rm -rf $RPM_BUILD_ROOT
install -d $RPM_BUILD_ROOT%{_localstatedir}/{lib/ceph/tmp,log/ceph/stat} \
$RPM_BUILD_ROOT%{_sysconfdir}/{ceph,bash_completion.d,logrotate.d,rc.d/init.d}
+
%{__make} install \
- DESTDIR=$RPM_BUILD_ROOT
+ DESTDIR=$RPM_BUILD_ROOT \
+ javadir=%{_javadir}
install -p src/init-ceph $RPM_BUILD_ROOT/etc/rc.d/init.d/ceph
install -p src/logrotate.conf $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/ceph
+# loadable modules
%{__rm} $RPM_BUILD_ROOT%{_libdir}/rados-classes/*.{a,la}
+%if %{with hadoop}
+%{__rm} $RPM_BUILD_ROOT%{_libdir}/libhadoopcephfs.{la,a}
+%endif
+%if %{with java}
+%{__rm} $RPM_BUILD_ROOT%{_libdir}/libcephfs_jni.{la,a}
+%endif
+
+# packaged as %doc
+%{__rm} $RPM_BUILD_ROOT%{_docdir}/ceph/sample.{ceph.conf,fetch_config}
+
%py_postclean
%clean
%post libs -p /sbin/ldconfig
%postun libs -p /sbin/ldconfig
+%post -n java-cephfs -p /sbin/ldconfig
+%postun -n java-cephfs -p /sbin/ldconfig
+
+%post -n hadoop-cephfs -p /sbin/ldconfig
+%postun -n hadoop-cephfs -p /sbin/ldconfig
+
%files
%defattr(644,root,root,755)
-%doc README src/sample.ceph.conf src/sample.fetch_config
+# COPYING specifies licenses of individual parts
+%doc AUTHORS COPYING README src/sample.ceph.conf src/sample.fetch_config
%attr(754,root,root) /etc/rc.d/init.d/ceph
%dir %{_sysconfdir}/ceph
%attr(755,root,root) %{_bindir}/ceph
%attr(755,root,root) %{_bindir}/rbd
%attr(755,root,root) %{_bindir}/ceph-debugpack
%attr(755,root,root) %{_bindir}/ceph-coverage
-%dir %{_libdir}/rados-classes
-%attr(755,root,root) %{_libdir}/rados-classes/libcls_lock.so*
-%attr(755,root,root) %{_libdir}/rados-classes/libcls_rbd.so*
-%attr(755,root,root) %{_libdir}/rados-classes/libcls_rgw.so*
+%attr(755,root,root) /sbin/ceph-create-keys
%attr(755,root,root) /sbin/ceph-disk-activate
%attr(755,root,root) /sbin/ceph-disk-prepare
%attr(755,root,root) /sbin/mkcephfs
%attr(755,root,root) /sbin/mount.ceph
+%attr(755,root,root) /sbin/mount.fuse.ceph
+%dir %{_libdir}/rados-classes
+%attr(755,root,root) %{_libdir}/rados-classes/libcls_kvs.so*
+%attr(755,root,root) %{_libdir}/rados-classes/libcls_lock.so*
+%attr(755,root,root) %{_libdir}/rados-classes/libcls_rbd.so*
+%attr(755,root,root) %{_libdir}/rados-classes/libcls_refcount.so*
+%attr(755,root,root) %{_libdir}/rados-classes/libcls_rgw.so*
%dir %{_libdir}/ceph
%attr(755,root,root) %{_libdir}/ceph/ceph_common.sh
%config(noreplace) /etc/logrotate.d/ceph
%{py_sitescriptdir}/rados.py[co]
%{py_sitescriptdir}/rbd.py[co]
+%if %{with java}
+%files -n java-cephfs
+%defattr(644,root,root,755)
+%attr(755,root,root) %{_libdir}/libcephfs_jni.so.*.*.*
+%attr(755,root,root) %ghost %{_libdir}/libcephfs_jni.so.1
+%attr(755,root,root) %{_libdir}/libcephfs_jni.so
+%{_javadir}/libcephfs.jar
+%endif
+
%files fuse
%defattr(644,root,root,755)
-%doc COPYING
%attr(755,root,root) %{_bindir}/ceph-fuse
%{_mandir}/man8/ceph-fuse.8*
%attr(755,root,root) %{_bindir}/radosgw-admin
%{_sysconfdir}/bash_completion.d/radosgw-admin
-%files obsync
+%files resource-agents
+%defattr(644,root,root,755)
+%dir %{_prefix}/lib/ocf/resource.d/ceph
+%attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/ceph
+%attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/mds
+%attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/mon
+%attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/osd
+%attr(755,root,root) %{_prefix}/lib/ocf/resource.d/ceph/rbd
+
+%if %{with hadoop}
+%files -n hadoop-cephfs
%defattr(644,root,root,755)
-%attr(755,root,root) %{_bindir}/obsync
-%attr(755,root,root) %{_bindir}/boto_tool
-%{_mandir}/man1/obsync.1*
+%attr(755,root,root) %{_libdir}/libhadoopcephfs.so.*.*.*
+%attr(755,root,root) %ghost %{_libdir}/libhadoopcephfs.so.1
+%attr(755,root,root) %{_libdir}/libhadoopcephfs.so
+%endif