From d03c18b715bc06dc9f185904d224fae047e55975 Mon Sep 17 00:00:00 2001 From: Remi Collet Date: Fri, 19 Sep 2014 09:57:27 +0200 Subject: php-pecl-graphdat: 1.0.3 (+ patches) - New package --- Makefile | 4 + graphdat-pr5.patch | 209 ++++++++++++++++++++++++++++++++++++++++++++ php-pecl-graphdat.spec | 232 +++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 445 insertions(+) create mode 100644 Makefile create mode 100644 graphdat-pr5.patch create mode 100644 php-pecl-graphdat.spec diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..13af741 --- /dev/null +++ b/Makefile @@ -0,0 +1,4 @@ +SRCDIR := $(shell pwd) +NAME := $(shell basename $(SRCDIR)) +include ../../../common/Makefile + diff --git a/graphdat-pr5.patch b/graphdat-pr5.patch new file mode 100644 index 0000000..1640635 --- /dev/null +++ b/graphdat-pr5.patch @@ -0,0 +1,209 @@ +From 138bb73a32d8b19feeb9032225caed686f66674b Mon Sep 17 00:00:00 2001 +From: Remi Collet +Date: Fri, 19 Sep 2014 08:14:40 +0200 +Subject: [PATCH 1/6] add --with-libmsgpack to use system library + +--- + config.m4 | 47 +++++++++++++++++++++++++++++++++++++---------- + graphdat.c | 2 +- + src/timers.h | 2 +- + 3 files changed, 39 insertions(+), 12 deletions(-) + +diff --git a/config.m4 b/config.m4 +index d6b6ac0..435475c 100644 +--- a/config.m4 ++++ b/config.m4 +@@ -4,6 +4,9 @@ dnl config.m4 for extension graphdat + PHP_ARG_ENABLE(graphdat, whether to enable Graphdat support, + [ --enable-graphdat Enable Graphdat support]) + ++PHP_ARG_WITH(libmsgpack, whether to use system msgpack, ++ [ --with-libmsgpack Use system msgpack], no, no) ++ + if test "$PHP_GRAPHDAT" != "no"; then + dnl # --with-graphdat -> add include path + +@@ -14,21 +17,45 @@ if test "$PHP_GRAPHDAT" != "no"; then + src/drupal7.c \ + src/joomla.c \ + src/magento.c \ +- src/msgpack/objectc.c \ +- src/msgpack/unpack.c \ +- src/msgpack/version.c \ +- src/msgpack/vrefbuffer.c \ +- src/msgpack/zone.c \ + src/sockets.c \ + src/timers.c \ + src/wordpress.c \ + src/zendplugin.c" + +- PHP_NEW_EXTENSION(graphdat, $graphdat_sources, $ext_shared) +- ++ if test "$PHP_LIBMSGPACK" != "no"; then ++ AC_PATH_PROG(PKG_CONFIG, pkg-config, no) ++ AC_MSG_CHECKING(msgpack version) ++ if test -x "$PKG_CONFIG" && $PKG_CONFIG --exists msgpack; then ++ LIBMSGPACK_INCLUDE=`$PKG_CONFIG msgpack --cflags` ++ LIBMSGPACK_LIBRARY=`$PKG_CONFIG msgpack --libs` ++ LIBMSGPACK_VERSION=`$PKG_CONFIG msgpack --modversion` ++ fi ++ ++ if test -z "$LIBMSGPACK_VERSION"; then ++ AC_MSG_RESULT(msgpack.pc not found) ++ AC_CHECK_HEADERS([msgpack.h]) ++ PHP_CHECK_LIBRARY(msgpack, msgpack_version, ++ [PHP_ADD_LIBRARY(msgpack, 1, GRAPHDAT_SHARED_LIBADD)], ++ [AC_MSG_ERROR(msgpack library not found)]) ++ else ++ AC_MSG_RESULT($LIBMSGPACK_VERSION) ++ PHP_EVAL_INCLINE($LIBMSGPACK_INCLUDE) ++ PHP_EVAL_LIBLINE($LIBMSGPACK_LIBRARY, GRAPHDAT_SHARED_LIBADD) ++ fi ++ PHP_NEW_EXTENSION(graphdat, $graphdat_sources, $ext_shared) ++ PHP_SUBST(GRAPHDAT_SHARED_LIBADD) ++ else ++ graphdat_sources="$graphdat_sources \ ++ src/msgpack/objectc.c \ ++ src/msgpack/unpack.c \ ++ src/msgpack/version.c \ ++ src/msgpack/vrefbuffer.c \ ++ src/msgpack/zone.c" ++ PHP_NEW_EXTENSION(graphdat, $graphdat_sources, $ext_shared) ++ PHP_ADD_INCLUDE($ext_srcdir/src/msgpack) ++ PHP_ADD_BUILD_DIR($ext_builddir/src/msgpack) ++ fi ++ + PHP_ADD_INCLUDE($ext_srcdir/src) +- PHP_ADD_INCLUDE($ext_srcdir/src/msgpack) + PHP_ADD_BUILD_DIR($ext_builddir/src) +- PHP_ADD_BUILD_DIR($ext_builddir/src/msgpack) +- + fi +diff --git a/graphdat.c b/graphdat.c +index 735d1cb..a2fd714 100644 +--- a/graphdat.c ++++ b/graphdat.c +@@ -32,7 +32,7 @@ + #include "ext/standard/info.h" + #include "php_graphdat.h" + #include "sockets.h" +-#include "msgpack.h" ++#include + #include "ext/standard/base64.h" + #include "timers.h" + #include +diff --git a/src/timers.h b/src/timers.h +index 384cb5a..0db6020 100644 +--- a/src/timers.h ++++ b/src/timers.h +@@ -8,7 +8,7 @@ + + #include + #include +-#include "msgpack.h" ++#include + + #ifndef graphdat_sdk_php_timers_h + #define graphdat_sdk_php_timers_h + +From 149a1182a7e503e6a81262b40fad9aeec628e652 Mon Sep 17 00:00:00 2001 +From: Remi Collet +Date: Fri, 19 Sep 2014 08:20:00 +0200 +Subject: [PATCH 2/6] report msgpack version + +--- + graphdat.c | 2 ++ + 1 file changed, 2 insertions(+) + +diff --git a/graphdat.c b/graphdat.c +index a2fd714..131d238 100644 +--- a/graphdat.c ++++ b/graphdat.c +@@ -228,6 +228,8 @@ PHP_MINFO_FUNCTION(graphdat) + { + php_info_print_table_start(); + php_info_print_table_header(2, "graphdat", "enabled"); ++ php_info_print_table_header(2, "msgpack headers version", MSGPACK_VERSION); ++ php_info_print_table_header(2, "msgpack library version", msgpack_version()); + php_info_print_table_end(); + + DISPLAY_INI_ENTRIES(); + +From a93473a771a5c4556da1aa52e471200e2f7e9e9f Mon Sep 17 00:00:00 2001 +From: Remi Collet +Date: Fri, 19 Sep 2014 08:22:24 +0200 +Subject: [PATCH 3/6] fix version in reflection + report version in phpinfo + +--- + graphdat.c | 3 ++- + package2.xml | 1 + + php_graphdat.h | 2 ++ + 3 files changed, 5 insertions(+), 1 deletion(-) + +diff --git a/graphdat.c b/graphdat.c +index 131d238..ef721cd 100644 +--- a/graphdat.c ++++ b/graphdat.c +@@ -86,7 +86,7 @@ zend_module_entry graphdat_module_entry = { + PHP_RSHUTDOWN(graphdat), /* Replace with NULL if there's nothing to do at request end */ + PHP_MINFO(graphdat), + #if ZEND_MODULE_API_NO >= 20010901 +- "0.1", /* Replace with version number for your extension */ ++ PHP_GRAPHDAT_VERSION, + #endif + STANDARD_MODULE_PROPERTIES + }; +@@ -228,6 +228,7 @@ PHP_MINFO_FUNCTION(graphdat) + { + php_info_print_table_start(); + php_info_print_table_header(2, "graphdat", "enabled"); ++ php_info_print_table_header(2, "graphdat extension version", PHP_GRAPHDAT_VERSION); + php_info_print_table_header(2, "msgpack headers version", MSGPACK_VERSION); + php_info_print_table_header(2, "msgpack library version", msgpack_version()); + php_info_print_table_end(); +diff --git a/php_graphdat.h b/php_graphdat.h +index ae735f4..8a4e3df 100644 +--- a/php_graphdat.h ++++ b/php_graphdat.h +@@ -21,6 +21,8 @@ + #ifndef PHP_GRAPHDAT_H + #define PHP_GRAPHDAT_H + ++#define PHP_GRAPHDAT_VERSION "1.0.3" ++ + #include + #include "timers.h" + + +From 9947c97b544d32607226cab5e812c92c1bf9d7fe Mon Sep 17 00:00:00 2001 +From: Remi Collet +Date: Fri, 19 Sep 2014 08:36:23 +0200 +Subject: [PATCH 6/6] add arginfo for reflection + +--- + graphdat.c | 8 ++++++-- + 1 file changed, 6 insertions(+), 2 deletions(-) + +diff --git a/graphdat.c b/graphdat.c +index ef721cd..812cb85 100644 +--- a/graphdat.c ++++ b/graphdat.c +@@ -61,12 +61,16 @@ ZEND_DECLARE_MODULE_GLOBALS(graphdat) + /* True global resources - no need for thread safety here */ + static int le_graphdat; + ++ZEND_BEGIN_ARG_INFO_EX(arginfo_graphdat_name, 0, 0, 1) ++ ZEND_ARG_INFO(0, name) ++ZEND_END_ARG_INFO() ++ + /* + * Every user visible function must have an entry in graphdat_functions[]. + */ + const zend_function_entry graphdat_functions[] = { +- PHP_FE(graphdat_begin, NULL) +- PHP_FE(graphdat_end, NULL) ++ PHP_FE(graphdat_begin, arginfo_graphdat_name) ++ PHP_FE(graphdat_end, arginfo_graphdat_name) + PHP_FE_END /* Must be the last line in graphdat_functions[] */ + }; + diff --git a/php-pecl-graphdat.spec b/php-pecl-graphdat.spec new file mode 100644 index 0000000..55317e6 --- /dev/null +++ b/php-pecl-graphdat.spec @@ -0,0 +1,232 @@ +# spec file for php-pecl-graphdat +# +# Copyright (c) 2014 Remi Collet +# License: CC-BY-SA +# http://creativecommons.org/licenses/by-sa/3.0/ +# +# Please, preserve the changelog entries +# +%{?scl: %scl_package php-pecl-graphdat} +%{!?php_inidir: %global php_inidir %{_sysconfdir}/php.d} +%{!?__pecl: %global __pecl %{_bindir}/pecl} +%{!?__php: %global __php %{_bindir}/php} + +%global pecl_name graphdat +%global with_zts 0%{?__ztsphp:1} +%if "%{php_version}" < "5.6" +%global ini_name %{pecl_name}.ini +%else +%global ini_name 40-%{pecl_name}.ini +%endif +%if 0%{?fedora} > 15 || 0%{?rhel} > 6 +%global with_msgpack 1 +%else +%global with_msgpack 0 +%endif + +Summary: Troubleshoot application and server performance +Name: %{?scl_prefix}php-pecl-graphdat +Version: 1.0.3 +Release: 1%{?dist}%{!?nophptag:%(%{__php} -r 'echo ".".PHP_MAJOR_VERSION.".".PHP_MINOR_VERSION;')} +# https://github.com/alphashack/graphdat-sdk-php/issues/6 +License: ASL 2.0 +Group: Development/Languages +URL: http://pecl.php.net/package/%{pecl_name} +Source: http://pecl.php.net/get/%{pecl_name}-%{version}.tgz + +# https://github.com/alphashack/graphdat-sdk-php/pull/5 +Patch0: %{pecl_name}-pr5.patch + +BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root +BuildRequires: %{?scl_prefix}php-devel +BuildRequires: %{?scl_prefix}php-pear +%if %{with_msgpack} +BuildRequires: msgpack-devel +%endif + +Requires(post): %{__pecl} +Requires(postun): %{__pecl} +Requires: %{?scl_prefix}php(zend-abi) = %{php_zend_api} +Requires: %{?scl_prefix}php(api) = %{php_core_api} +%{?_sclreq:Requires: %{?scl_prefix}runtime%{?_sclreq}%{?_isa}} + +Provides: %{?scl_prefix}php-%{pecl_name} = %{version} +Provides: %{?scl_prefix}php-%{pecl_name}%{?_isa} = %{version} +Provides: %{?scl_prefix}php-pecl(%{pecl_name}) = %{version} +Provides: %{?scl_prefix}php-pecl(%{pecl_name})%{?_isa} = %{version} + +%if "%{?vendor}" == "Remi Collet" && 0%{!?scl:1} +# Other third party repo stuff +Obsoletes: php53-pecl-%{pecl_name} <= %{version} +Obsoletes: php53u-pecl-%{pecl_name} <= %{version} +Obsoletes: php54-pecl-%{pecl_name} <= %{version} +Obsoletes: php54w-pecl-%{pecl_name} <= %{version} +%if "%{php_version}" > "5.5" +Obsoletes: php55u-pecl-%{pecl_name} <= %{version} +Obsoletes: php55w-pecl-%{pecl_name} <= %{version} +%endif +%if "%{php_version}" > "5.6" +Obsoletes: php56u-pecl-%{pecl_name} <= %{version} +Obsoletes: php56w-pecl-%{pecl_name} <= %{version} +%endif +%endif + +%if 0%{?fedora} < 20 && 0%{?rhel} < 7 +# Filter shared private +%{?filter_provides_in: %filter_provides_in %{_libdir}/.*\.so$} +%{?filter_setup} +%endif + + +%description +Graphdat is a real time performance monitoring tool for websites. +Graphdat graphs system metrics along side request counts and response +time data. The purpose of the extension is report request counts and +response time information to our agent (installed on the box) which +forwards that along to our servers. The data is then presented in a +graph so that you can see performance spikes as they happen, and +trends over time. + +Package built for PHP %(%{__php} -r 'echo PHP_MAJOR_VERSION.".".PHP_MINOR_VERSION;')%{?scl: as Software Collection}. + + +%prep +%setup -q -c + +# Don't install/register tests +sed -e 's/role="test"/role="src"/' \ +%if %{with_msgpack} + -e '\:name="src/msgpack:d' \ +%endif + -i package.xml + +mv %{pecl_name}-%{version} NTS +cd NTS +%patch0 -p1 -b .pr5 + +%if %{with_msgpack} +# use system library +rm -rf src/msgpack +%endif + +# Sanity check, really often broken +extver=$(sed -n '/#define PHP_GRAPHDAT_VERSION/{s/.* "//;s/".*$//;p}' php_graphdat.h) +if test "x${extver}" != "x%{version}"; then + : Error: Upstream extension version is ${extver}, expecting %{version}. + exit 1 +fi +cd .. + +%if %{with_zts} +# duplicate for ZTS build +cp -pr NTS ZTS +%endif + +# Drop in the bit of configuration +cat << 'EOF' | tee %{ini_name} +; Enable '%{pecl_name}' extension module +extension = %{pecl_name}.so + +; Configuration options +;graphdat.socketFile = /tmp/gd.agent.sock +;graphdat.socketPort = 26873 +;graphdat.debug = false +;graphdat.enable_joomla = false +;graphdat.enable_drupal = false +;graphdat.enable_magento = false +;graphdat.enable_cakephp = false +EOF + + +%build +cd NTS +%{_bindir}/phpize +%configure \ +%if %{with_msgpack} + --with-libmsgpack \ +%endif + --with-php-config=%{_bindir}/php-config +make %{?_smp_mflags} + +%if %{with_zts} +cd ../ZTS +%{_bindir}/zts-phpize +%configure \ +%if %{with_msgpack} + --with-libmsgpack \ +%endif + --with-php-config=%{_bindir}/zts-php-config +make %{?_smp_mflags} +%endif + + +%install +rm -rf %{buildroot} +# Install the NTS stuff +make -C NTS install INSTALL_ROOT=%{buildroot} +install -D -m 644 %{ini_name} %{buildroot}%{php_inidir}/%{ini_name} + +%if %{with_zts} +# Install the ZTS stuff +make -C ZTS install INSTALL_ROOT=%{buildroot} +install -D -m 644 %{ini_name} %{buildroot}%{php_ztsinidir}/%{ini_name} +%endif + +# Install the package XML file +install -D -m 644 package.xml %{buildroot}%{pecl_xmldir}/%{name}.xml + +# Documentation +cd NTS +for i in $(grep 'role="doc"' ../package.xml | sed -e 's/^.*name="//;s/".*$//') +do install -Dpm 644 $i %{buildroot}%{pecl_docdir}/%{pecl_name}/$i +done + + +%check +: Minimal load test for NTS extension +%{__php} --no-php-ini \ + --define extension=%{buildroot}%{php_extdir}/%{pecl_name}.so \ + --modules | grep %{pecl_name} + +%if %{with_zts} +: Minimal load test for ZTS extension +%{__ztsphp} --no-php-ini \ + --define extension=%{buildroot}%{php_ztsextdir}/%{pecl_name}.so \ + --modules | grep %{pecl_name} +%endif + + +%post +%{pecl_install} %{pecl_xmldir}/%{name}.xml >/dev/null || : + + +%postun +if [ $1 -eq 0 ] ; then + %{pecl_uninstall} %{pecl_name} >/dev/null || : +fi + + +%clean +rm -rf %{buildroot} + + +%files +%defattr(-,root,root,-) +%{?_licensedir:%license NTS/LICENSE} +%doc %{pecl_docdir}/%{pecl_name} +%{pecl_xmldir}/%{name}.xml + +%config(noreplace) %{php_inidir}/%{ini_name} +%{php_extdir}/%{pecl_name}.so + +%if %{with_zts} +%config(noreplace) %{php_ztsinidir}/%{ini_name} +%{php_ztsextdir}/%{pecl_name}.so +%endif + + +%changelog +* Fri Sep 19 2014 Remi Collet - 1.0.3-1 +- initial package, version 1.0.3 (stable) +- open https://github.com/alphashack/graphdat-sdk-php/pull/5 +- open https://github.com/alphashack/graphdat-sdk-php/issues/6 \ No newline at end of file -- cgit