summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Makefile4
-rw-r--r--graphdat-pr5.patch209
-rw-r--r--php-pecl-graphdat.spec232
3 files changed, 445 insertions, 0 deletions
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 <fedora@famillecollet.com>
+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 <msgpack.h>
+ #include "ext/standard/base64.h"
+ #include "timers.h"
+ #include <string.h>
+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 <stddef.h>
+ #include <sys/time.h>
+-#include "msgpack.h"
++#include <msgpack.h>
+
+ #ifndef graphdat_sdk_php_timers_h
+ #define graphdat_sdk_php_timers_h
+
+From 149a1182a7e503e6a81262b40fad9aeec628e652 Mon Sep 17 00:00:00 2001
+From: Remi Collet <fedora@famillecollet.com>
+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 <fedora@famillecollet.com>
+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 <sys/time.h>
+ #include "timers.h"
+
+
+From 9947c97b544d32607226cab5e812c92c1bf9d7fe Mon Sep 17 00:00:00 2001
+From: Remi Collet <fedora@famillecollet.com>
+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 <remi@fedoraproject.org> - 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