File opie.spec of Package opie

# spec file for package opie
# Copyright (c) 2017 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

Name:           opie
#!BuildIgnore: opie
BuildRequires:  automake
BuildRequires:  bison
BuildRequires:  pam-devel
Version:        2.4
Release:        0
Provides:       pam_opie
%define name_pam         pam_opie
%define version_pam	 0.21
Source0:        %{name}-%{version}.tar.bz2
Source1:        %{name_pam}-%{version_pam}.tar.bz2
Source2:        baselibs.conf
Patch0:         %{name}-%{version}.diff
Patch1:         %{name_pam}-%{version_pam}.diff
Patch2:         %{name}-%{version}.newseed.diff 
Patch3:         uint4_def.patch
Patch4:         %name-2.4-bison.patch
Patch5:         %name-2.4-nonvoid.patch
Patch6:         %name-2.4-decl.diff
Patch7:         %name-2.4-nul-overflow.patch
Patch8:         %name-2.4-cxx.patch
Patch9:         %name-2.4-undef.patch
Patch10:        %name-2.4-noroot.patch
Patch11:        %{name}-%{version}_array-subscript.patch
Patch12:        %{name_pam}-%{version_pam}_array-subscript.patch
Patch13:        %name-2.4-getline.patch
Patch14:        %name-2.4-fclose.patch
Patch15:        %name-2.4-implicit.patch
Patch16:        opielogin-setuid-CVE-2011-2490.patch
Patch17:        opiesu-overflow-CVE-2011-2489.patch
Patch18:        opie-fix-autoconf.patch
Patch19:        opie-2.4-DESTDIR.patch
Patch20:        opie-2.4-pie.patch
Patch21:        opie-fix-indendation.patch
Summary:        Support for One-Time Passwords
License:        SUSE-Innernet-2.0
Group:          Productivity/Security
BuildRoot:      %{_tmppath}/%{name}-%{version}-build
PreReq:         permissions

OPIE stands for One-time Passwords In Everything. One-time passwords
can be used to foil password sniffers because they cannot be reused by
the attacker.

This package provides a PAM module and several utility programs that
let you use one-time passwords for authentication.

%setup -q -n %{name}-%{version} -a 1
%patch0 -p1
%patch2 -p1
%patch6 -p1
%patch7 -p1
%patch8 -p1
%patch19 -p1
%patch10 -p1
pushd %{name_pam}
%patch1 -p0
%patch15 -p1
%patch20 -p1
%patch21 -p1

# build opie
export CFLAGS="$RPM_OPT_FLAGS -fno-strict-aliasing"
autoreconf -i -f
%configure --enable-insecure-override
make %{?_smp_mflags}

# build pam_opie
cd %{name_pam}
make %{?_smp_mflags}

# install opie
mkdir -p $RPM_BUILD_ROOT/etc
mkdir -p $RPM_BUILD_ROOT/%{_mandir}/man1/
make CHOWN=/bin/echo DESTDIR=$RPM_BUILD_ROOT install
install -m 644 -D opie.h $RPM_BUILD_ROOT%{_includedir}/opie.h
install -m 644 -D libopie/libopie.a $RPM_BUILD_ROOT%{_libdir}/libopie.a
mv %{name_pam}/README ./README.PAM
# install pam_opie
cd %{name_pam}
     SECUREDIR=/%{_lib}/security install

[ "$RPM_BUILD_ROOT" != "/" ] && [ -d $RPM_BUILD_ROOT ] && rm -rf $RPM_BUILD_ROOT

%verify_permissions -e /usr/bin/opiepasswd -e /usr/bin/opiesu

%set_permissions /usr/bin/opiepasswd /usr/bin/opiesu

%dir /etc/opielocks
%config(noreplace) /etc/opiekeys
%verify(not mode) /usr/bin/opiepasswd
%verify(not mode) /usr/bin/opiesu
%doc %{_mandir}/man*/*

openSUSE Build Service is sponsored by