diff options
author | Shawn Iwinski <siwinski@redhat.com> | 2017-03-28 12:23:51 -0400 |
---|---|---|
committer | Shawn Iwinski <siwinski@redhat.com> | 2017-03-28 12:23:51 -0400 |
commit | 40ccd8e6fb52636b0f64ba5380349f633ddba724 (patch) | |
tree | 3470c336a718d7ae524a05168c030bde47f26f9c | |
parent | 790a8e267253d68e61fdc007dd2369430b63b57f (diff) |
Initial import (RHBZ #1431377)
-rw-r--r-- | .gitignore | 1 | ||||
-rwxr-xr-x | php-firebase-php-jwt-get-source.sh | 69 | ||||
-rw-r--r-- | php-firebase-php-jwt.spec | 138 | ||||
-rw-r--r-- | sources | 1 |
4 files changed, 209 insertions, 0 deletions
@@ -0,0 +1 @@ +/php-firebase-php-jwt-4.0.0-dccf163dc8ed7ed6a00afc06c51ee5186a428d35.tar.gz diff --git a/php-firebase-php-jwt-get-source.sh b/php-firebase-php-jwt-get-source.sh new file mode 100755 index 0000000..ba71f5d --- /dev/null +++ b/php-firebase-php-jwt-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-firebase-php-jwt.spec b/php-firebase-php-jwt.spec new file mode 100644 index 0000000..1178a5e --- /dev/null +++ b/php-firebase-php-jwt.spec @@ -0,0 +1,138 @@ +# +# Fedora spec file for php-firebase-php-jwt +# +# Copyright (c) 2017 Shawn Iwinski <shawn@iwin.ski> +# +# License: MIT +# http://opensource.org/licenses/MIT +# +# Please preserve changelog entries +# + +%global github_owner firebase +%global github_name php-jwt +%global github_version 4.0.0 +%global github_commit dccf163dc8ed7ed6a00afc06c51ee5186a428d35 + +%global composer_vendor firebase +%global composer_project php-jwt + +# "php": ">= 5.3.0" +%global php_min_ver 5.3.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} +Version: %{github_version} +Release: 1%{?github_release}%{?dist} +Summary: A simple library to encode and decode JSON Web Tokens (JWT) + +Group: Development/Libraries +License: BSD +URL: https://github.com/%{github_owner}/%{github_name} + +# GitHub export does not include tests. +# Run php-firebase-php-jwt-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(phpunit/phpunit) +## phpcompatinfo (computed from version 4.0.0) +BuildRequires: php-date +BuildRequires: php-hash +BuildRequires: php-json +BuildRequires: php-mbstring +BuildRequires: php-openssl +BuildRequires: php-pcre +BuildRequires: php-spl +## Autoloader +BuildRequires: php-composer(fedora/autoloader) +%endif + +# composer.json +Requires: php(language) >= %{php_min_ver} +# phpcompatinfo (computed from version 4.0.0) +Requires: php-date +Requires: php-hash +Requires: php-json +Requires: php-mbstring +Requires: php-openssl +Requires: php-pcre +Requires: php-spl +# Autoloader +Requires: php-composer(fedora/autoloader) + +# Composer +Provides: php-composer(%{composer_vendor}/%{composer_project}) = %{version} + +%description +A simple library to encode and decode JSON Web Tokens (JWT) in PHP, conforming +to RFC 7519 [1]. + +Autoloader: %{phpdir}/Firebase/JWT/autoload.php + +[1] https://tools.ietf.org/html/rfc7519 + + +%prep +%setup -qn %{github_name}-%{github_commit} + + +%build +: Create autoloader +cat <<'AUTOLOAD' | tee src/autoload.php +<?php +/** + * Autoloader for %{name} and its' dependencies + * (created by %{name}-%{version}-%{release}). + */ +require_once '%{phpdir}/Fedora/Autoloader/autoload.php'; + +\Fedora\Autoloader\Autoload::addPsr4('Firebase\\JWT\\', __DIR__); +AUTOLOAD + + +%install +mkdir -p %{buildroot}%{phpdir}/Firebase +cp -rp src %{buildroot}%{phpdir}/Firebase/JWT + + +%check +%if %{with_tests} +BOOTSTRAP=%{buildroot}%{phpdir}/Firebase/JWT/autoload.php + +: Upstream tests +RETURN_CODE=0 +for PHP_EXEC in php %{?rhel:php54 php55} php56 php70 php71; do + if which $PHP_EXEC; then + $PHP_EXEC %{_bindir}/phpunit \ + --bootstrap %{buildroot}%{phpdir}/Firebase/JWT/autoload.php \ + || RETURN_CODE=1 + fi +done +exit $RETURN_CODE +%else +: Tests skipped +%endif + + +%files +%{!?_licensedir:%global license %%doc} +%license LICENSE +%doc *.md +%doc composer.json +%dir %{phpdir}/Firebase + %{phpdir}/Firebase/JWT + + +%changelog +* Sat Mar 11 2017 Shawn Iwinski <shawn@iwin.ski> - 4.0.0-1 +- Initial package @@ -0,0 +1 @@ +SHA512 (php-firebase-php-jwt-4.0.0-dccf163dc8ed7ed6a00afc06c51ee5186a428d35.tar.gz) = c578f4f918b5e009d7ab2b27b3cc6f835010b3b1dd3f5ffff1b5885c0a5ef46ac67c1d810ea87df65ab2370afc6cca780e812537113102ef056f5b93a0b3a5e7 |