File fence-agents.spec of Package fence-agents.7446

#
# spec file for package fence-agents
#
# Copyright (c) 2019 SUSE LINUX GmbH, Nuernberg, Germany.
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
# upon. The license for this file, and modifications and additions to the
# file, is the same license as for the pristine package itself (unless the
# license for the pristine package is not an Open Source License, in which
# case the license is the MIT License). An "Open Source License" is a
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.

# Please submit bugfixes or comments via http://bugs.opensuse.org/
#


%global plugin_dir %{_libdir}/stonith/plugins/rhcs

Name:           fence-agents
Summary:        Fence Agents for Pacemaker from RHCS
License:        GPL-2.0-only AND LGPL-2.1-only
Group:          Productivity/Clustering/HA
Version:        4.0.22+git.1455008135.15c5e92
Release:        0
Url:            https://github.com/ClusterLabs/fence-agents
Source0:        %{name}-%{version}.tar.xz
# PATCH-FIX-UPSTREAM: fence_compute: Add --insecure command line argument
Patch1:         0001-fence_compute-Add-insecure-command-line-argument.patch
# PATCH-FIX-UPSTREAM: fence_compute: Add --region-name command line argument
Patch2:         0002-fence_compute-Add-region-name-command-line-argument.patch
# PATCH-FIX-UPSTREAM: fence_compute: Create nova client with API 2.11
Patch3:         0003-fence_compute-Create-nova-client-with-API-2.11.patch
# PATCH-FIX-UPSTREAM: fence_compute: Fix disabling force_down on node when action is on
Patch4:         0004-fence_compute-Fix-disabling-force_down-on-node-when-.patch
# PATCH-FIX-UPSTREAM: fence_compute: Evacuate instances on all tenants
Patch5:         0005-fence_compute-Evacuate-instances-on-all-tenants.patch
# PATCH-FIX-UPSTREAM: fence_compute: On list, don't list hypervisors but nova-compute services
Patch6:         0006-fence_compute-On-list-don-t-list-hypervisors-but-nov.patch
# PATCH-FIX-UPSTREAM: fence_compute: Only list nova-compute services when getting status
Patch7:         0007-fence_compute-Only-list-nova-compute-services-when-g.patch
# PATCH-FIX-UPSTREAM: fence_compute: Deprecate the domain option
Patch8:         0008-fence_compute-Deprecate-the-domain-option.patch
# Add support for Azure fence agent
Patch9:         0009-fence_azure_arm-add-fencing-agent-for-Azure-Resource-Manager.patch
Patch10:        0010-fence_azure_arm-move-option-definitions-to-define_new_opts.patch
Patch11:        0011-fence_azure_arm-remove-reboot-action-remove-sys.exit.patch
Patch12:        0012-fix-compile-error-for-azure_zrm.patch
Patch13:        0013-change-getopt-and-help-in-define_new_opts.patch
# PATCH-FIX-UPSTREAM: fencing: include timestamps when logging to STDERR and debug file (bsc#1049852)
Patch14:        0001-fencing-include-timestamps-when-logging-to-STDERR-an.patch
# Add fence_gce: Google Compute Engine fence support (fate#325539) (bsc#1088358)
Patch15:        0001-fence_gce-new-agent.patch
Patch16:        0001-Zone-Project-parameters-are-mandatory.patch
Patch17:        0001-fence_gce-Write-error-messages-to-log.patch
Patch18:        0001-fence_gce-fix-regression-missing-import-googleapicli.patch
Patch19:        0002-fence_gce-fix-regression-missing-import-oauth2client.patch
Patch20:        0003-fence_gce-use-default-credentials-from-googleapiclie.patch
Patch21:        0001-fence_gce-add-support-for-stackdriver-logging.patch
Patch22:        0002-fence_gce-set-project-and-zone-as-not-required.patch
Patch23:        0003-fence_gce-add-power-cycle-as-default-method.patch
Patch24:        0004-fence_gce-add-missing-imports-to-retrieve-the-projec.patch
Patch25:        0005-fence_gce-s-loging-stackdriver-logging.patch
Patch26:        0006-fence_gce-use-root-logger-for-stackdriver.patch
Patch27:        0007-fence_gce-minor-changes-in-logging.patch
Patch28:        0001-fence_gce-filter-call-to-aggregatedList.patch
Patch29:        fence_gce-Makefile.am.patch
Patch30:        fence_gce-python-shebang.patch
Patch31:        fence_gce-metadata-xml.patch

BuildRoot:      %{_tmppath}/%{name}-%{version}-build
BuildRequires:  autoconf
BuildRequires:  automake
BuildRequires:  fdupes
BuildRequires:  glibc-devel
BuildRequires:  libtool
BuildRequires:  libxml2-tools
BuildRequires:  libxslt
BuildRequires:  mozilla-nspr-devel
BuildRequires:  mozilla-nss-devel
BuildRequires:  perl
BuildRequires:  perl-Net-Telnet
BuildRequires:  pkg-config
BuildRequires:  python
BuildRequires:  python-curl
BuildRequires:  python-google-api-python-client
BuildRequires:  python-pexpect
BuildRequires:  python-requests
BuildRequires:  python-suds
BuildRequires:  python-xml
BuildRequires:  xz

Requires:       net-snmp
Requires:       openssh
Requires:       perl-Net-Telnet
Requires:       python-curl
Requires:       python-openssl
Requires:       python-pexpect
Requires:       python-requests
Requires:       python-suds
Requires:       sg3_utils
Requires:       telnet
# This is required by fence_virsh. Per discussion on fedora-devel
# switching from package to file based require.
Requires:       /usr/bin/virsh

# This is required by fence_ipmilan. it appears that the packages
# have changed Requires around. Make sure to get the right one.
Requires:       /usr/bin/ipmitool

%if 0%{?with_regression_tests}
BuildRequires:  time
%endif

%description
Fence Agents is a collection of scripts to handle remote power
management for several devices.

%package devel
Summary:        Fence Agents for Pacemaker from RHCS
Group:          Development/Tools/Other
Requires:       %{name} = %{version}

%description devel
Fence Agents is a collection of scripts to handle remote power
management for several devices. This package contains
fence agents only suitable for development.

%prep
%setup -q -n %{name}-%{version}
%patch1 -p1
%patch2 -p1
%patch3 -p1
%patch4 -p1
%patch5 -p1
%patch6 -p1
%patch7 -p1
%patch8 -p1
%patch9 -p1
%patch10 -p1
%patch11 -p1
%patch12 -p1
%patch13 -p1
%patch14 -p1
%patch15 -p1
%patch16 -p1
%patch17 -p1
%patch18 -p1
%patch19 -p1
%patch20 -p1
%patch21 -p1
%patch22 -p1
%patch23 -p1
%patch24 -p1
%patch25 -p1
%patch26 -p1
%patch27 -p1
%patch28 -p1
%patch29 -p1
%patch30 -p1
%patch31 -p1

%build
CFLAGS="${CFLAGS} ${RPM_OPT_FLAGS}"
export CFLAGS
./autogen.sh
%{configure}
make

%install
make install DESTDIR=%{buildroot}

## tree fix up
# fix libfence permissions
chmod 0755 %{buildroot}%{_datadir}/fence/fenc*.py
# remove docs
rm -rf %{buildroot}/usr/share/doc/fence-agents
# create links to agents in the plugins dir
mkdir -p %{buildroot}%{plugin_dir}
ln -s %{_sbindir}/fence_cisco_ucs %{buildroot}%{plugin_dir}
%fdupes %buildroot%{_sbindir}
%fdupes %buildroot%{_datadir}/cluster

%if 0%{?with_regression_tests}
%check
make check
PYTHONPATH=fence/agents/lib python fence/agents/lib/tests/test_fencing.py
%endif

%files
%defattr(-,root,root,-)
%doc doc/COPYING.* doc/COPYRIGHT doc/README.licence
%dir %{plugin_dir}
%dir %{_libdir}/stonith/plugins
%dir %{_libdir}/stonith
%{_datadir}/fence
%{_datadir}/cluster
%{plugin_dir}/fence_cisco_ucs
%{_sbindir}/fence_*
%exclude %{_sbindir}/fence_dummy
%exclude %{_mandir}/man8/fence_dummy*
%{_mandir}/man8/fence_*
%{_libexecdir}/fence_*

%files devel
%{_sbindir}/fence_dummy
%{_mandir}/man8/fence_dummy*

%changelog
openSUSE Build Service is sponsored by