diff options
-rwxr-xr-x | php-simplesamlphp-saml2_3-get-source.sh | 69 | ||||
-rw-r--r-- | php-simplesamlphp-saml2_3.spec | 191 |
2 files changed, 260 insertions, 0 deletions
diff --git a/php-simplesamlphp-saml2_3-get-source.sh b/php-simplesamlphp-saml2_3-get-source.sh new file mode 100755 index 0000000..ba71f5d --- /dev/null +++ b/php-simplesamlphp-saml2_3-get-source.sh @@ -0,0 +1,69 @@ +#/bin/sh + +GIT=`which git` +RPM=`which rpm` + +if [ -z "$GIT" ] +then + echo "ERROR: 'git' command not found" 1>&2 + exit 1 +elif [ -z "$RPM" ] +then + echo "ERROR: 'rpm' command not found" 1>&2 + exit 1 +fi + +function print { + echo -e "\e[0;33m>>>>> ${1}\e[0m" +} + +if [ -x "$1" ] +then + SPEC=$1 +else + SPEC=`ls *.spec | head -1` +fi + +NAME=`echo $SPEC | sed 's#\.spec##'` +VERSION=`egrep '%global\s*github_version' $SPEC | awk '{print $3}'` + +print "SPEC = $SPEC" +print "NAME = $NAME" + +GIT_OWNER=`egrep '%global\s*github_owner' $SPEC | awk '{print $3}'` +GIT_NAME=`egrep '%global\s*github_name' $SPEC | awk '{print $3}'` +GIT_COMMIT=`egrep '%global\s*github_commit' $SPEC | awk '{print $3}'` +GIT_REPO=https://github.com/${GIT_OWNER}/${GIT_NAME} +GIT_DIR=`echo $GIT_REPO | sed 's#.*/##'` + +print "GIT_OWNER = $GIT_OWNER" +print "GIT_NAME = $GIT_NAME" +print "GIT_COMMIT = $GIT_COMMIT" +print "GIT_REPO = $GIT_REPO" +print "GIT_DIR = $GIT_DIR" + +TEMP_DIR=$(mktemp --dir) + +pushd $TEMP_DIR + print "Cloning git repo..." + $GIT clone $GIT_REPO + + pushd $GIT_DIR + print "Checking out commit..." + $GIT checkout $GIT_COMMIT + popd + + TAR_DIR=${GIT_NAME}-${GIT_COMMIT} + print "TAR_DIR = $TAR_DIR" + + mv $GIT_DIR $TAR_DIR + + TAR_FILE=`$RPM --eval='%{_sourcedir}'`/${NAME}-${VERSION}-${GIT_COMMIT}.tar.gz + print "TAR_FILE = $TAR_FILE" + + [ -e $TAR_FILE ] && rm -f $TAR_FILE + tar --exclude-vcs -czf $TAR_FILE $TAR_DIR + chmod 0644 $TAR_FILE +popd + +rm -rf $TEMP_DIR diff --git a/php-simplesamlphp-saml2_3.spec b/php-simplesamlphp-saml2_3.spec new file mode 100644 index 0000000..e90f0b8 --- /dev/null +++ b/php-simplesamlphp-saml2_3.spec @@ -0,0 +1,191 @@ +# +# Fedora spec file for php-simplesamlphp-saml2_3 +# +# Copyright (c) 2017 Shawn Iwinski <shawn@iwin.ski> +# +# License: MIT +# http://opensource.org/licenses/MIT +# +# Please preserve the changelog entries +# + +%global github_owner simplesamlphp +%global github_name saml2 +%global github_version 3.0.2 +%global github_commit bacad25473258cfefb7a7fd418cc5f8a22cda0a1 + +%global composer_vendor simplesamlphp +%global composer_project saml2 + +# "php": ">=5.3.3" +%global php_min_ver 5.3.3 +# "mockery/mockery": "~0.9" +%global mockery_min_ver 0.9 +%global mockery_max_ver 1.0 +# "psr/log": "~1.0" +# NOTE: Min version not 1.0 because autoloader required +%global psr_log_min_ver 1.0.1 +%global psr_log_max_ver 2.0 +# "simplesamlphp/xmlseclibs": "^2.0|^3.0" +# +# https://github.com/simplesamlphp/xmlseclibs +# Micro-fork of xmlseclibs, sole difference is restore of PHP 5.4 compatibility +# +# Using robrichards/xmlseclibs instead of simplesamlphp/xmlseclibs because +# they use the same namespace, the only difference is PHP version compatibility, +# and tests pass. +# +# NOTE: Min version not 2.0 to force version 3.0 and remove build dependency php-mcrypt +%global xmlseclibs_min_ver 3.0 +%global xmlseclibs_max_ver 4.0 + +# Build using "--without tests" to disable tests +%global with_tests 0%{!?_without_tests:1} + +%{!?phpdir: %global phpdir %{_datadir}/php} + +Name: php-%{composer_vendor}-%{composer_project}_3 +Version: %{github_version} +Release: 3%{?github_release}%{?dist} +Summary: SAML2 PHP library from SimpleSAMLphp (version 3) + +Group: Development/Libraries +License: LGPLv2 +URL: https://github.com/%{github_owner}/%{github_name} + +# GitHub export does not include tests. +# Run php-simplesamlphp-saml2_3-get-source.sh to create full source. +Source0: %{name}-%{github_version}-%{github_commit}.tar.gz +Source1: %{name}-get-source.sh + +BuildArch: noarch +# Tests +%if %{with_tests} +## composer.json +BuildRequires: php(language) >= %{php_min_ver} +BuildRequires: php-composer(mockery/mockery) < %{mockery_max_ver} +BuildRequires: php-composer(mockery/mockery) >= %{mockery_min_ver} +BuildRequires: php-composer(phpunit/phpunit) +BuildRequires: php-composer(psr/log) < %{psr_log_max_ver} +BuildRequires: php-composer(psr/log) >= %{psr_log_min_ver} +BuildRequires: php-composer(robrichards/xmlseclibs) < %{xmlseclibs_max_ver} +BuildRequires: php-composer(robrichards/xmlseclibs) >= %{xmlseclibs_min_ver} +BuildRequires: php-dom +BuildRequires: php-openssl +BuildRequires: php-zlib +## phpcompatinfo (computed from version 3.0.2) +BuildRequires: php-date +BuildRequires: php-libxml +BuildRequires: php-pcre +BuildRequires: php-soap +BuildRequires: php-spl +%endif +## Autoloader +BuildRequires: php-fedora-autoloader-devel + +# composer.json +Requires: php(language) >= %{php_min_ver} +Requires: php-composer(psr/log) < %{psr_log_max_ver} +Requires: php-composer(psr/log) >= %{psr_log_min_ver} +Requires: php-composer(robrichards/xmlseclibs) < %{xmlseclibs_max_ver} +Requires: php-composer(robrichards/xmlseclibs) >= %{xmlseclibs_min_ver} +Requires: php-dom +Requires: php-openssl +Requires: php-zlib +# phpcompatinfo (computed from version 3.0.2) +Requires: php-date +Requires: php-libxml +Requires: php-pcre +Requires: php-soap +Requires: php-spl +# Autoloader +Requires: php-composer(fedora/autoloader) + +# Composer +Provides: php-composer(%{composer_vendor}/%{composer_project}) = %{version} + + +%description +A PHP library for SAML2 related functionality. Extracted from SimpleSAMLphp [1], +used by OpenConext [2]. This library started as a collaboration between +UNINETT [3] and SURFnet [4] but everyone is invited to contribute. + +Autoloader: %{phpdir}/SAML2_3/autoload.php + +[1] https://www.simplesamlphp.org/ +[2] https://www.openconext.org/ +[3] https://www.uninett.no/ +[4] https://www.surfnet.nl/ + + +%prep +%setup -qn %{github_name}-%{github_commit} + + +%build +: Create autoloader +%{_bindir}/phpab --template fedora --output src/SAML2/autoload.php src/SAML2 +cat <<'AUTOLOAD' >> src/SAML2/autoload.php + +class_alias('\\SAML2\\Constants', 'SAML2_Const'); + +\Fedora\Autoloader\Dependencies::required(array( + '%{phpdir}/Psr/Log/autoload.php', + '%{phpdir}/RobRichards/XMLSecLibs3/autoload.php', +)); +AUTOLOAD + + +%install +mkdir -p %{buildroot}%{phpdir} +cp -rp src/SAML2 %{buildroot}%{phpdir}/SAML2_3 + + +%check +%if %{with_tests} +: Create pseudo Composer autoloader +mkdir vendor +%{_bindir}/phpab --template fedora --output vendor/autoload.php tests +cat <<'AUTOLOAD' | tee -a vendor/autoload.php +require_once '%{buildroot}%{phpdir}/SAML2_3/autoload.php'; +require_once '%{phpdir}/Mockery/autoload.php'; +AUTOLOAD + +: Skip test known to fail +sed 's/function testToString/function SKIP_testToString/' \ + -i tests/SAML2/XML/saml/NameIDTest.php + +: Upstream tests +RETURN_CODE=0 +PHPUNIT=$(which phpunit) +for PHP_EXEC in php %{?rhel:php54 php55} php56 php70 php71 php72; do + if [ "php" = "$PHP_EXEC" ] || which $PHP_EXEC; then + $PHP_EXEC $PHPUNIT --configuration=tools/phpunit --verbose || RETURN_CODE=1 + fi +done +exit $RETURN_CODE +%else +: Tests skipped +%endif + + +%files +%{!?_licensedir:%global license %%doc} +%license LICENSE +%doc *.md +%doc composer.json +%{phpdir}/SAML2_3 + + +%changelog +* Wed Aug 30 2017 Shawn Iwinski <shawn@iwin.ski> - 3.0.2-3 +- Drop support for simplesamlphp/xmlseclibs v2 + +* Tue Aug 22 2017 Shawn Iwinski <shawn@iwin.ski> - 3.0.2-2 +- Build require mcrypt for robrichards/xmlseclibs version 2 + +* Sun Aug 20 2017 Shawn Iwinski <shawn@iwin.ski> - 3.0.2-1 +- Update to 3.0.2 + +* Wed Jul 12 2017 Shawn Iwinski <shawn@iwin.ski> - 3.0.0-1 +- Initial package |