From 5c9665a0706cd9de96a2e49f8ad3102a37acd36f Mon Sep 17 00:00:00 2001 From: Jean-Michel Lacroix Date: Sun, 1 Jan 2017 12:44:56 -0500 Subject: [PATCH] bandwidthd: update to 2.0.1-34, sqlite support and SMTP tracking Addition of sqlite storage Tracking of SMTP traffic instead of P2P traffic Based on NethServer bandwidthd implementation Signed-off-by: Jean-Michel lacroix --- utils/bandwidthd-php/Makefile | 51 -- utils/bandwidthd-php/files/legend.gif | Bin 1649 -> 0 bytes utils/bandwidthd/Makefile | 155 +++++- .../bandwidthd/files/bandwidthd-pgsql.config | 6 +- .../files/bandwidthd-php.config | 0 .../files/bandwidthd-php.init | 2 +- .../bandwidthd/files/bandwidthd-sqlite.config | 13 + ...dthd-pgsql.init => bandwidthd-sqlite.init} | 67 ++- utils/bandwidthd/files/bandwidthd.config | 2 +- utils/bandwidthd/files/bandwidthd.init | 38 +- .../files/logo-openwrt.gif} | Bin utils/bandwidthd/files/logo.gif | Bin 9431 -> 0 bytes .../files/phphtdocs-sqlite/details.php | 104 ++++ .../files/phphtdocs-sqlite}/footer.php | 0 .../files/phphtdocs-sqlite/graph.php | 455 ++++++++++++++++++ .../files/phphtdocs-sqlite/include.php | 69 +++ .../files/phphtdocs-sqlite/index.php | 190 ++++++++ .../files/phphtdocs}/details.php | 2 +- utils/bandwidthd/files/phphtdocs/footer.php | 3 + .../files/phphtdocs}/graph.php | 69 ++- .../files/phphtdocs}/include.php | 0 .../files/phphtdocs}/index.php | 2 +- ...010-dont-add-host-paths-in-config.in.patch | 24 + .../patches/010-dont-add-host-paths.patch | 36 -- .../patches/020-change-p2p-to-smtp.patch | 20 + .../patches/100-fix_config_file_location | 31 -- 26 files changed, 1130 insertions(+), 209 deletions(-) delete mode 100644 utils/bandwidthd-php/Makefile delete mode 100644 utils/bandwidthd-php/files/legend.gif rename utils/{bandwidthd-php => bandwidthd}/files/bandwidthd-php.config (100%) rename utils/{bandwidthd-php => bandwidthd}/files/bandwidthd-php.init (97%) create mode 100644 utils/bandwidthd/files/bandwidthd-sqlite.config rename utils/bandwidthd/files/{bandwidthd-pgsql.init => bandwidthd-sqlite.init} (50%) mode change 100644 => 100755 mode change 100644 => 100755 utils/bandwidthd/files/bandwidthd.init rename utils/{bandwidthd-php/files/logo.gif => bandwidthd/files/logo-openwrt.gif} (100%) delete mode 100644 utils/bandwidthd/files/logo.gif create mode 100644 utils/bandwidthd/files/phphtdocs-sqlite/details.php rename utils/{bandwidthd-php/files => bandwidthd/files/phphtdocs-sqlite}/footer.php (100%) create mode 100644 utils/bandwidthd/files/phphtdocs-sqlite/graph.php create mode 100644 utils/bandwidthd/files/phphtdocs-sqlite/include.php create mode 100644 utils/bandwidthd/files/phphtdocs-sqlite/index.php rename utils/{bandwidthd-php/files => bandwidthd/files/phphtdocs}/details.php (99%) create mode 100644 utils/bandwidthd/files/phphtdocs/footer.php rename utils/{bandwidthd-php/files => bandwidthd/files/phphtdocs}/graph.php (80%) rename utils/{bandwidthd-php/files => bandwidthd/files/phphtdocs}/include.php (100%) rename utils/{bandwidthd-php/files => bandwidthd/files/phphtdocs}/index.php (99%) create mode 100644 utils/bandwidthd/patches/010-dont-add-host-paths-in-config.in.patch delete mode 100644 utils/bandwidthd/patches/010-dont-add-host-paths.patch create mode 100644 utils/bandwidthd/patches/020-change-p2p-to-smtp.patch delete mode 100644 utils/bandwidthd/patches/100-fix_config_file_location diff --git a/utils/bandwidthd-php/Makefile b/utils/bandwidthd-php/Makefile deleted file mode 100644 index c71d798dc..000000000 --- a/utils/bandwidthd-php/Makefile +++ /dev/null @@ -1,51 +0,0 @@ -# -# Copyright (C) 2006-2016 OpenWrt.org -# -# This is free software, licensed under the GNU General Public License v2. -# See /LICENSE for more information. -# - -include $(TOPDIR)/rules.mk - -PKG_NAME:=bandwidthd-php -PKG_VERSION:=2.0.1 -PKG_RELEASE:=2 - -PKG_MAINTAINER:=Jean-Michel Lacroix - -PKG_LICENSE:=GPL-2.0 - -include $(INCLUDE_DIR)/package.mk - -define Package/bandwidthd-php - SECTION:=utils - CATEGORY:=Utilities - DEPENDS:=+libpcre +libxml2 +php7 +php7-cgi +php7-mod-pgsql +php7-mod-gd - TITLE:=PHP files to graph bandwidthd data in a postgresql database - URL:=http://bandwidthd.sourceforge.net/ -endef - -define Package/bandwidthd-php/description - PHP files to graph bandwidthd data in a postgresql database -endef - -define Build/Compile -endef - -define Package/bandwidthd-php/install - $(INSTALL_DIR) $(1)/www/phphtdocs - $(INSTALL_DATA) ./files/legend.gif $(1)/www/phphtdocs/ - $(INSTALL_DATA) ./files/logo.gif $(1)/www/phphtdocs/ - $(INSTALL_DATA) ./files/details.php $(1)/www/phphtdocs/ - $(INSTALL_DATA) ./files/footer.php $(1)/www/phphtdocs/ - $(INSTALL_DATA) ./files/graph.php $(1)/www/phphtdocs/ - $(INSTALL_DATA) ./files/include.php $(1)/www/phphtdocs/ - $(INSTALL_DATA) ./files/index.php $(1)/www/phphtdocs/ - ln -s /var/etc/bandwidthd-php.conf $(1)/www/phphtdocs/config.conf - $(INSTALL_DIR) $(1)//etc/config - $(INSTALL_CONF) ./files/bandwidthd-php.config $(1)/etc/config/bandwidthd-php - $(INSTALL_DIR) $(1)/etc/init.d - $(INSTALL_BIN) ./files/bandwidthd-php.init $(1)/etc/init.d/bandwidthd-php -endef - -$(eval $(call BuildPackage,bandwidthd-php)) diff --git a/utils/bandwidthd-php/files/legend.gif b/utils/bandwidthd-php/files/legend.gif deleted file mode 100644 index 3df909037fadf8df608efdb3cdc389aea779053c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1649 zcmb_bi&NB96uyEXiesiyK0tC1k>w$JO&1*(4`lzIb3Nn=lgTcVzcaFI9fG7L~0l)o!fe|7IQG}S-1R2H%6ND+k3}G&c z1S3Kap@=XPjVSOXZ4hDo3WJYX?k12h*W65UXS9D>8e zz(~*sYawIOOD24k?k$Sa35CtlRYb33v~XSWPK-)+h$Bb}1(HNs+(hCbfF)>n9pFk} z9%zD9UgB*Q{|m^TBNuz8^;N|`r`S)IDUDU9ucuFSRjAijpZPU=CXVeiR%@Gb-u2IN z3alwH9b5RRUTLa1+j7D;s#zUad#<%W{>@;gsaAJWvnFMdv!br_mUjIyS!i=zS(|Q) zR#B*^*WW4syf(J0xxV~f<-&0p&KvT-YN?57D%zC2-+Ozl*TeiHp26OKUQT#E*yW%~ zdU#Fs+D3l4xXOGzbwbl_Lqm1cZ&|@MTh?5v+1Z@C)kfuChNI=htD>hA6xR*3on7}d zw6(GR%aTOfmY~FGsJp`0To@?2TGc~XGbWiBJty!euH(Fb~bxuyt z-ukg9VZ`r+a-YtzK@-_OvfO$9jG&l#;T>;Wn44%DU^J({nHwAyX%{f_eviauyxDNc@sxUDDYip)4zG`h;6{LqCo&*6r}<`o4={Y0;?40*f3vwA4RQcyb(7wb~1 zv5BpuC09M%-R`!Bd|c$;XdOIKnpghpm&qw#RHTjgY@4bbTCFEHvYQo}pZ3Yh_GU8K z(aPg4AF)TKukD-$3>_;L?y9ja^LoyfE}z{K-k7YYPQGTdp)%dlZCZR~+5#`vtMAM) zhMVjZ @@ -21,6 +21,8 @@ PKG_LICENSE:=GPL-2.0 PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(BUILD_VARIANT)/$(PKG_NAME)-$(PKG_VERSION) +PKG_FIXUP:=autoreconf + include $(INCLUDE_DIR)/package.mk define Package/bandwidthd/Default @@ -32,8 +34,8 @@ endef define Package/bandwidthd $(call Package/bandwidthd/Default) - TITLE += (without postgresql) - VARIANT:=no-pgsql + TITLE += (without database) + VARIANT:=no-db DEPENDS:=+libgd +libpcap endef @@ -44,6 +46,20 @@ $(call Package/bandwidthd/Default) DEPENDS:=+libgd +libpcap +libpq endef +define Package/bandwidthd-sqlite +$(call Package/bandwidthd/Default) + TITLE += (with sqlite enabled) + VARIANT:=sqlite + DEPENDS:=+libgd +libpcap +libsqlite3 +php7 +php7-cgi +php7-mod-gd +php7-mod-pdo +php7-mod-pdo-sqlite +endef + +define Package/bandwidthd-php +$(call Package/bandwidthd/Default) + TITLE = PHP files to graph bandwidthd data from postgresql + VARIANT:=php + DEPENDS:=+libpcre +libxml2 +php7 +php7-cgi +php7-mod-pgsql +php7-mod-gd +endef + define Package/bandwidthd/description A bandwidthd tracking utility. endef @@ -53,15 +69,32 @@ $(call Package/bandwidthd/description) With the ability to store in a postgresql database. endef +define Package/bandwidthd-sqlite/description +$(call Package/bandwidthd/description) +With the ability to store in a sqlite database. +endef + +define Package/bandwidthd-php/description + PHP files to graph bandwidthd data from pgsql. +endef + define Package/bandwidthd/daemon - This package contains bandwidthd a bandwidth tracking utility. + This package contains bandwidthd, a bandwidth tracking utility. endef define Package/bandwidthd-pgsql/daemon - This package contains bandwidthd a bandwidth tracking utility. + This package contains bandwidthd, a bandwidth tracking utility. +endef + +define Package/bandwidthd-sqlite/daemon + This package contains bandwidthd, a bandwidth tracking utility. +endef + +define Package/bandwidthd-php/daemon + This package contains the PHP files to graph the data from a pgsql database. endef -ifeq ($(BUILD_VARIANT),no-pgsql) +ifeq ($(BUILD_VARIANT),no-db) CONFIGURE_ARGS += \ ac_cv_file__sw_lib=no \ ac_cv_file__sw_include=no \ @@ -69,20 +102,45 @@ CONFIGURE_ARGS += \ ac_cv_file__usr_pkg_include=no \ ac_cv_file__usr_local_pgsql_lib=no \ ac_cv_file__usr_local_pgsql_include=no \ - ac_cv_lib_pq_PQconnectdb=no + ac_cv_lib_pq_PQconnectdb=no \ + ac_cv_lib_sqlite3_sqlite3_open=no endif ifeq ($(BUILD_VARIANT),pgsql) CONFIGURE_ARGS += \ - ac_cv_file__sw_lib=no \ - ac_cv_file__sw_include=no \ - ac_cv_file__usr_pkg_lib=no \ - ac_cv_file__usr_pkg_include=no \ - ac_cv_file__usr_local_pgsql_lib=no \ - ac_cv_file__usr_local_pgsql_include=no + ac_cv_file__sw_lib=no \ + ac_cv_file__sw_include=no \ + ac_cv_file__usr_pkg_lib=no \ + ac_cv_file__usr_pkg_include=no \ + ac_cv_file__usr_local_pgsql_lib=no \ + ac_cv_file__usr_local_pgsql_include=no \ + ac_cv_lib_sqlite3_sqlite3_open=no endif -EXTRA_CFLAGS+= $(TARGET_CPPFLAGS) -std=gnu89 +ifeq ($(BUILD_VARIANT),sqlite) +CONFIGURE_ARGS += \ + ac_cv_file__sw_lib=no \ + ac_cv_file__sw_include=no \ + ac_cv_file__usr_pkg_lib=no \ + ac_cv_file__usr_pkg_include=no \ + ac_cv_file__usr_local_pgsql_lib=no \ + ac_cv_file__usr_local_pgsql_include=no \ + ac_cv_lib_pq_PQconnectdb=no +endif + +ifeq ($(BUILD_VARIANT),php) +CONFIGURE_ARGS += \ + ac_cv_file__sw_lib=no \ + ac_cv_file__sw_include=no \ + ac_cv_file__usr_pkg_lib=no \ + ac_cv_file__usr_pkg_include=no \ + ac_cv_file__usr_local_pgsql_lib=no \ + ac_cv_file__usr_local_pgsql_include=no \ + ac_cv_lib_pq_PQconnectdb=no \ + ac_cv_lib_sqlite3_sqlite3_open=no +endif + +EXTRA_CFLAGS+= $(TARGET_CPPFLAGS) EXTRA_LDFLAGS+= $(TARGET_LDFLAGS) -Wl,-rpath-link,$(STAGING_DIR)/usr/lib define Package/bandwidthd/install @@ -93,8 +151,8 @@ define Package/bandwidthd/install $(INSTALL_DIR) $(1)/etc/init.d $(INSTALL_BIN) ./files/bandwidthd.init $(1)/etc/init.d/bandwidthd $(INSTALL_DIR) $(1)/www - $(INSTALL_DATA) $(PKG_BUILD_DIR)/htdocs/legend.gif $(1)/www/ - $(INSTALL_DATA) $(PKG_BUILD_DIR)/htdocs/logo.gif $(1)/www/ + $(INSTALL_DATA) $(PKG_BUILD_DIR)/phphtdocs/legend.gif $(1)/www/ + $(INSTALL_DATA) ./files/logo-openwrt.gif $(1)/www/logo.gif endef define Package/bandwidthd-pgsql/install @@ -103,15 +161,50 @@ define Package/bandwidthd-pgsql/install $(INSTALL_DIR) $(1)/etc/config $(INSTALL_DATA) ./files/bandwidthd-pgsql.config $(1)/etc/config/bandwidthd $(INSTALL_DIR) $(1)/etc/init.d - $(INSTALL_BIN) ./files/bandwidthd-pgsql.init $(1)/etc/init.d/bandwidthd - $(INSTALL_DIR) $(1)/www/phphtdocs - $(INSTALL_DATA) $(PKG_BUILD_DIR)/htdocs/legend.gif $(1)/www/ - $(INSTALL_DATA) ./files/logo.gif $(1)/www/ + $(INSTALL_BIN) ./files/bandwidthd.init $(1)/etc/init.d/bandwidthd + $(INSTALL_DIR) $(1)/www + $(INSTALL_DATA) $(PKG_BUILD_DIR)/phphtdocs/legend.gif $(1)/www/ + $(INSTALL_DATA) ./files/logo-openwrt.gif $(1)/www/logo.gif $(INSTALL_DIR) $(1)/usr/share/postgresql - $(INSTALL_DATA) $(PKG_BUILD_DIR)/schema.postgresql $(1)/usr/share/postgresql $(INSTALL_BIN) $(PKG_BUILD_DIR)/phphtdocs/bd_pgsql_purge.sh $(1)/usr/share/postgresql endef +define Package/bandwidthd-sqlite/install + $(INSTALL_DIR) $(1)/usr/sbin + $(INSTALL_BIN) $(PKG_BUILD_DIR)/bandwidthd $(1)/usr/sbin/ + $(INSTALL_DIR) $(1)/etc/config + $(INSTALL_DATA) ./files/bandwidthd-sqlite.config $(1)/etc/config/bandwidthd + $(INSTALL_DIR) $(1)/etc/init.d + $(INSTALL_BIN) ./files/bandwidthd-sqlite.init $(1)/etc/init.d/bandwidthd + $(INSTALL_DIR) $(1)/www/phphtdocs + $(INSTALL_DATA) $(PKG_BUILD_DIR)/phphtdocs/legend.gif $(1)/www/phphtdocs/ + $(INSTALL_DATA) ./files/phphtdocs-sqlite/details.php $(1)/www/phphtdocs/ + $(INSTALL_DATA) ./files/phphtdocs-sqlite/footer.php $(1)/www/phphtdocs/ + $(INSTALL_DATA) ./files/phphtdocs-sqlite/graph.php $(1)/www/phphtdocs/ + $(INSTALL_DATA) ./files/phphtdocs-sqlite/include.php $(1)/www/phphtdocs/ + $(INSTALL_DATA) ./files/phphtdocs-sqlite/index.php $(1)/www/phphtdocs/ + $(INSTALL_DATA) ./files/logo-openwrt.gif $(1)/www/phphtdocs/logo.gif + ln -s /var/etc/bandwidthd-php.conf $(1)/www/phphtdocs/config.conf.php + $(INSTALL_DATA) $(PKG_BUILD_DIR)/phphtdocs/legend.gif $(1)/www/ + $(INSTALL_DATA) ./files/logo-openwrt.gif $(1)/www/logo.gif +endef + +define Package/bandwidthd-php/install + $(INSTALL_DIR) $(1)/www/phphtdocs + $(INSTALL_DATA) $(PKG_BUILD_DIR)/phphtdocs/legend.gif $(1)/www/phphtdocs/ + $(INSTALL_DATA) ./files/phphtdocs/details.php $(1)/www/phphtdocs/ + $(INSTALL_DATA) ./files/phphtdocs/footer.php $(1)/www/phphtdocs/ + $(INSTALL_DATA) ./files/phphtdocs/graph.php $(1)/www/phphtdocs/ + $(INSTALL_DATA) ./files/phphtdocs/include.php $(1)/www/phphtdocs/ + $(INSTALL_DATA) ./files/phphtdocs/index.php $(1)/www/phphtdocs/ + $(INSTALL_DATA) ./files/logo-openwrt.gif $(1)/www/phphtdocs/logo.gif + ln -s /var/etc/bandwidthd-php.conf $(1)/www/phphtdocs/config.conf + $(INSTALL_DIR) $(1)//etc/config + $(INSTALL_CONF) ./files/bandwidthd-php.config $(1)/etc/config/bandwidthd-php + $(INSTALL_DIR) $(1)/etc/init.d + $(INSTALL_BIN) ./files/bandwidthd-php.init $(1)/etc/init.d/bandwidthd-php +endef + define Package/bandwidthd/conffiles /etc/config/bandwidthd endef @@ -120,5 +213,15 @@ define Package/bandwidthd-pgsql/conffiles /etc/config/bandwidthd endef +define Package/bandwidthd-sqlite/conffiles +/etc/config/bandwidthd +endef + +define Package/bandwidthd-php/conffiles +/etc/config/bandwidthd-php +endef + $(eval $(call BuildPackage,bandwidthd)) $(eval $(call BuildPackage,bandwidthd-pgsql)) +$(eval $(call BuildPackage,bandwidthd-sqlite)) +$(eval $(call BuildPackage,bandwidthd-php)) diff --git a/utils/bandwidthd/files/bandwidthd-pgsql.config b/utils/bandwidthd/files/bandwidthd-pgsql.config index 0f8768792..f94c737a5 100644 --- a/utils/bandwidthd/files/bandwidthd-pgsql.config +++ b/utils/bandwidthd/files/bandwidthd-pgsql.config @@ -1,5 +1,5 @@ config bandwidthd - option dev br-lan + option dev br-lan option subnets "192.168.1.0/24" option skip_intervals 0 option graph_cutoff 1024 @@ -9,5 +9,5 @@ config bandwidthd option filter ip option graph true option meta_refresh 150 - option disabled_pgsql_connect_string "user = postgres dbname = bandwidthd host = 192.168.1.1" - option disabled_sensor_id "openwrt.mydomain.domain" + option pgsql_connect_string "user = postgres dbname = bandwidthd host = 192.168.1.1" + option sensor_id "openwrt" diff --git a/utils/bandwidthd-php/files/bandwidthd-php.config b/utils/bandwidthd/files/bandwidthd-php.config similarity index 100% rename from utils/bandwidthd-php/files/bandwidthd-php.config rename to utils/bandwidthd/files/bandwidthd-php.config diff --git a/utils/bandwidthd-php/files/bandwidthd-php.init b/utils/bandwidthd/files/bandwidthd-php.init similarity index 97% rename from utils/bandwidthd-php/files/bandwidthd-php.init rename to utils/bandwidthd/files/bandwidthd-php.init index f3a7c6702..b7b6434f0 100755 --- a/utils/bandwidthd-php/files/bandwidthd-php.init +++ b/utils/bandwidthd/files/bandwidthd-php.init @@ -1,5 +1,5 @@ #!/bin/sh /etc/rc.common -# Copyright (C) 2006-2016 OpenWrt.org +# Copyright (C) 2006-2017 OpenWrt.org START=99 diff --git a/utils/bandwidthd/files/bandwidthd-sqlite.config b/utils/bandwidthd/files/bandwidthd-sqlite.config new file mode 100644 index 000000000..bc4154af2 --- /dev/null +++ b/utils/bandwidthd/files/bandwidthd-sqlite.config @@ -0,0 +1,13 @@ +config bandwidthd + option dev br-lan + option subnets "192.168.1.0/24" + option skip_intervals 0 + option graph_cutoff 1024 + option promiscuous true + option output_cdf false + option recover_cdf false + option filter ip + option graph true + option meta_refresh 150 + option sqlite_filename "/www/bandwidthd/stats.db" + option sensor_id "default" diff --git a/utils/bandwidthd/files/bandwidthd-pgsql.init b/utils/bandwidthd/files/bandwidthd-sqlite.init old mode 100644 new mode 100755 similarity index 50% rename from utils/bandwidthd/files/bandwidthd-pgsql.init rename to utils/bandwidthd/files/bandwidthd-sqlite.init index 232fa0cb8..c456974ab --- a/utils/bandwidthd/files/bandwidthd-pgsql.init +++ b/utils/bandwidthd/files/bandwidthd-sqlite.init @@ -1,8 +1,15 @@ #!/bin/sh /etc/rc.common -# Copyright (C) 2008-2015 OpenWrt.org +# Copyright (C) 2008-2017 OpenWrt.org START=99 +USE_PROCD=1 + +CONFIGNAME="bandwidthd" +CONFIGPHPNAME="bandwidthd-php" +CONFIGFILE="/tmp/etc/bandwidthd.conf" +CONFIGPHPFILE="/tmp/etc/bandwidthd-php.conf" + config_cb() { local cfg_type="$1" local cfg_name="$2" @@ -50,18 +57,17 @@ export_string() { fi } -start() { - local subnet conffile +set_conf_file() { + local subnet conffile="# auto-generated config file from /etc/config/${CONFIGNAME}\n" [ -d /tmp/bandwidthd ] || mkdir -p /tmp/bandwidthd && cp /www/legend.gif /www/logo.gif /tmp/bandwidthd/ [ -e /htdocs ] || ln -s /tmp/bandwidthd /htdocs [ -e /www/bandwidthd ] || ln -s /tmp/bandwidthd /www/bandwidthd - rm -f /tmp/bandwidthd.conf - touch /tmp/bandwidthd.conf - [ -e /etc/bandwidthd.conf ] || ln -s /tmp/bandwidthd.conf /etc/bandwidthd.conf - - - config_load bandwidthd + rm -f $CONFIGFILE + touch $CONFIGFILE + [ -e /etc/bandwidthd.conf ] || ln -s $CONFIGFILE /etc/bandwidthd.conf + + config_load $CONFIGNAME for cfg in $cfgs; do config_get subnets $cfg subnets for subnet in $subnets; do @@ -77,14 +83,51 @@ start() { export_bool graph $cfg export_number meta_refresh $cfg export_string pgsql_connect_string $cfg + export_string sqlite_filename $cfg export_string sensor_id $cfg - [ -n "$conffile" ] && echo -e "$conffile" >>/tmp/bandwidthd.conf + [ -n "$conffile" ] && echo -e "$conffile" >>$CONFIGFILE unset conffile done cd / - service_start /usr/sbin/bandwidthd } -stop() { +set_php_conf_file() { + local subnet conffile="" + [ -n "$conffile" ] && echo -e "$conffile" >>$CONFIGPHPFILE + done + cd / +} + +service_triggers() { + procd_add_reload_trigger $CONFIGNAME + procd_add_reload_trigger $CONFIGPHPNAME +} + +start_service() { + set_conf_file + set_php_conf_file + procd_open_instance + procd_set_param command /usr/sbin/bandwidthd + procd_close_instance +} + +stop_service() { service_stop /usr/sbin/bandwidthd } diff --git a/utils/bandwidthd/files/bandwidthd.config b/utils/bandwidthd/files/bandwidthd.config index 0769b1c8e..ac1669ef4 100644 --- a/utils/bandwidthd/files/bandwidthd.config +++ b/utils/bandwidthd/files/bandwidthd.config @@ -1,5 +1,5 @@ config bandwidthd - option dev br-lan + option dev br-lan option subnets "192.168.1.0/24" option skip_intervals 0 option graph_cutoff 1024 diff --git a/utils/bandwidthd/files/bandwidthd.init b/utils/bandwidthd/files/bandwidthd.init old mode 100644 new mode 100755 index 38d9cb165..ac9d01dc4 --- a/utils/bandwidthd/files/bandwidthd.init +++ b/utils/bandwidthd/files/bandwidthd.init @@ -1,8 +1,13 @@ #!/bin/sh /etc/rc.common -# Copyright (C) 2008-2015 OpenWrt.org +# Copyright (C) 2008-2017 OpenWrt.org START=99 +USE_PROCD=1 + +CONFIGNAME="bandwidthd" +CONFIGFILE="/tmp/etc/bandwidthd.conf" + config_cb() { local cfg_type="$1" local cfg_name="$2" @@ -50,18 +55,17 @@ export_string() { fi } -start() { +set_conf_file() { local subnet conffile [ -d /tmp/bandwidthd ] || mkdir -p /tmp/bandwidthd && cp /www/legend.gif /www/logo.gif /tmp/bandwidthd/ [ -e /htdocs ] || ln -s /tmp/bandwidthd /htdocs [ -e /www/bandwidthd ] || ln -s /tmp/bandwidthd /www/bandwidthd - rm -f /tmp/bandwidthd.conf - touch /tmp/bandwidthd.conf - [ -e /etc/bandwidthd.conf ] || ln -s /tmp/bandwidthd.conf /etc/bandwidthd.conf + rm -f $CONFIGFILE + touch $CONFIGFILE + [ -e /etc/bandwidthd.conf ] || ln -s $CONFIGFILE /etc/bandwidthd.conf - - config_load bandwidthd + config_load $CONFIGNAME for cfg in $cfgs; do config_get subnets $cfg subnets for subnet in $subnets; do @@ -76,13 +80,27 @@ start() { export_string filter $cfg export_bool graph $cfg export_number meta_refresh $cfg - [ -n "$conffile" ] && echo -e "$conffile" >>/tmp/bandwidthd.conf + export_string pgsql_connect_string $cfg + export_string sqlite_filename $cfg + export_string sensor_id $cfg + [ -n "$conffile" ] && echo -e "$conffile" >>$CONFIGFILE unset conffile done cd / - service_start /usr/sbin/bandwidthd } -stop() { +service_triggers() +{ + procd_add_reload_trigger $CONFIGNAME +} + +start_service() { + set_conf_file + procd_open_instance + procd_set_param command /usr/sbin/bandwidthd + procd_close_instance +} + +stop_service() { service_stop /usr/sbin/bandwidthd } diff --git a/utils/bandwidthd-php/files/logo.gif b/utils/bandwidthd/files/logo-openwrt.gif similarity index 100% rename from utils/bandwidthd-php/files/logo.gif rename to utils/bandwidthd/files/logo-openwrt.gif diff --git a/utils/bandwidthd/files/logo.gif b/utils/bandwidthd/files/logo.gif deleted file mode 100644 index 2ffec5605b72c48f49d8ee3dc069e80baccd6aa7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9431 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 + +
+ +Please provide a sensor_name"; + exit(1); + } + +if (isset($_GET['ip'])) + $ip = $_GET['ip']; +else + { + echo "
Please provide an ip address"; + exit(1); + } + +echo "

"; +if (strpos($ip, "/") === FALSE) + echo "$ip - ".gethostbyaddr($ip)."

"; +else + echo "Total - $ip"; + +$db = ConnectDb(); + +if ($ip == "0.0.0.0/0") + { + $rxtable = "bd_rx_total_log"; + $txtable = "bd_tx_total_log"; + } +else + { + $rxtable = "bd_rx_log"; + $txtable = "bd_tx_log"; + } + +$sql = "select rx.scale as rxscale, tx.scale as txscale, tx.total+rx.total as total, tx.total as sent, +rx.total as received, tx.tcp+rx.tcp as tcp, tx.udp+rx.udp as udp, +tx.icmp+rx.icmp as icmp, tx.http+rx.http as http, +tx.p2p+rx.p2p as p2p, tx.ftp+rx.ftp as ftp +from + +(SELECT ip, max(total/sample_duration)*8 as scale, sum(total) as total, sum(tcp) as tcp, sum(udp) as udp, sum(icmp) as icmp, +sum(http) as http, sum(p2p) as p2p, sum(ftp) as ftp +from sensors, $txtable +where sensor_name = '$sensor_name' +and sensors.sensor_id = ".$txtable.".sensor_id +$sql_subnet +group by ip) as tx, + +(SELECT ip, max(total/sample_duration)*8 as scale, sum(total) as total, sum(tcp) as tcp, sum(udp) as udp, sum(icmp) as icmp, +sum(http) as http, sum(p2p) as p2p, sum(ftp) as ftp +from sensors, $rxtable +where sensor_name = '$sensor_name' +and sensors.sensor_id = ".$rxtable.".sensor_id +$sql_subnet +group by ip) as rx + +where tx.ip = rx.ip;"; +//error_log($sql); printf('
%s
', $sql); +$db = ConnectDb(); +$result = $db->query($sql); +echo "
IpNameTotalSentReceivedtcpudpicmphttpsmtpftp"; +$r = $result->fetch(); +$db = NULL; +echo "
"; +if (strpos($ip, "/") === FALSE) + echo "$ip".gethostbyaddr($ip); +else + echo "Total$ip"; +echo fmtb($r['total']).fmtb($r['sent']).fmtb($r['received']). + fmtb($r['tcp']).fmtb($r['udp']).fmtb($r['icmp']).fmtb($r['http']). + fmtb($r['p2p']).fmtb($r['ftp']); +echo "
"; + +echo "

Daily

"; +echo "Send:

"; +echo "
"; +echo "Receive:

"; +echo "
"; + +echo "

Weekly

"; +echo "Send:

"; +echo "
"; +echo "Receive:

"; +echo "
"; + +echo "

Monthly

"; +echo "Send:

"; +echo "
"; +echo "Receive:

"; +echo "
"; + +echo "

Yearly

"; +echo "Send:

"; +echo "
"; +echo "Receive:

"; +echo "
"; diff --git a/utils/bandwidthd-php/files/footer.php b/utils/bandwidthd/files/phphtdocs-sqlite/footer.php similarity index 100% rename from utils/bandwidthd-php/files/footer.php rename to utils/bandwidthd/files/phphtdocs-sqlite/footer.php diff --git a/utils/bandwidthd/files/phphtdocs-sqlite/graph.php b/utils/bandwidthd/files/phphtdocs-sqlite/graph.php new file mode 100644 index 000000000..82df317fb --- /dev/null +++ b/utils/bandwidthd/files/phphtdocs-sqlite/graph.php @@ -0,0 +1,455 @@ + $number) + { + $total[$key] /= $number; + $icmp[$key] /= $number; + $udp[$key] /= $number; + $tcp[$key] /= $number; + $ftp[$key] /= $number; + $http[$key] /= $number; + $p2p[$key] /= $number; + } + + foreach ($Count as $key => $number) + { + $a_total[$key] += $total[$key]; + $a_icmp[$key] += $icmp[$key]; + $a_udp[$key] += $udp[$key]; + $a_tcp[$key] += $tcp[$key]; + $a_ftp[$key] += $ftp[$key]; + $a_http[$key] += $http[$key]; + $a_p2p[$key] += $p2p[$key]; + + if ($a_total[$key] > $YMax) + $YMax = $a_total[$key]; + } + + unset($GLOBALS['total'], $GLOBALS['icmp'], $GLOBALS['udp'], $GLOBALS['tcp'], $GLOBALS['ftp'], $GLOBALS['http'], $GLOBALS['p2p'], $GLOBALS['Count']); + + $total = array(); + $icmp = array(); + $udp = array(); + $tcp = array(); + $ftp = array(); + $http = array(); + $p2p = array(); + $Count = array(); + } + +$db = ConnectDb(); + +// Get parameters + +if (isset($_GET['width'])) + $width = $_GET['width']; +else + $width = DFLT_WIDTH; + +if (isset($_GET['height'])) + $height = $_GET['height']; +else + $height = DFLT_HEIGHT; + +if (isset($_GET['interval'])) + $interval = $_GET['interval']; +else + $interval = DFLT_INTERVAL; + +if (isset($_GET['ip'])) + $ip = $_GET['ip']; +else + exit(1); + +if (isset($_GET['sensor_name'])) + $sensor_name = $_GET['sensor_name']; +else + exit(1); + +if (isset($_GET['timestamp'])) + $timestamp = $_GET['timestamp']; +else + $timestamp = time() - $interval + (0.05*$interval); + +if (isset($_GET['table'])) + $table = $_GET['table']; +else + $table = "bd_rx_log"; + +if (isset($_GET['yscale'])) + $yscale = $_GET['yscale']; + +$total = array(); +$icmp = array(); +$udp = array(); +$tcp = array(); +$ftp = array(); +$http = array(); +$p2p = array(); +$Count = array(); + +// Accumulator +$a_total = array(); +$a_icmp = array(); +$a_udp = array(); +$a_tcp = array(); +$a_ftp = array(); +$a_http = array(); +$a_p2p = array(); + +$sql_subnet = prepare_sql_subnet($ip); +$sql = "select *, timestamp as ts from sensors, $table where sensors.sensor_id = ".$table.".sensor_id $sql_subnet and sensor_name = '$sensor_name' and timestamp > $timestamp and timestamp < ".($timestamp+$interval)." order by ip;"; +//error_log($sql); +$result = $db->query($sql); + +// The SQL statement pulls the data out of the database ordered by IP address, that way we can average each +// datapoint for each IP address to provide smoothing and then toss the smoothed value into the accumulator +// to provide accurate total traffic rate. + +while ($row = $result->fetch()) + { + if ($row['ip'] != $last_ip) + { + AverageAndAccumulate(); + $last_ip = $row['ip']; + } + + $x = ($row['ts']-$timestamp)*(($width-XOFFSET)/$interval)+XOFFSET; + $xint = (int) $x; + + //echo "xint: ".$xint."
"; + $Count[$xint]++; + + if ($row['total']/$row['sample_duration'] > $SentPeak) + $SentPeak = $row['total']/$row['sample_duration']; + $TotalSent += $row['total']; + $total[$xint] += $row['total']/$row['sample_duration']; + $icmp[$xint] += $row['icmp']/$row['sample_duration']; + $udp[$xint] += $row['udp']/$row['sample_duration']; + $tcp[$xint] += $row['tcp']/$row['sample_duration']; + $ftp[$xint] += $row['ftp']/$row['sample_duration']; + $http[$xint] += $row['http']/$row['sample_duration']; + $p2p[$xint] += $row['p2p']/$row['sample_duration']; + } + +// One more time for the last IP +AverageAndAccumulate(); + +// Pull the data out of Accumulator +$total = $a_total; +$icmp = $a_icmp; +$udp = $a_udp; +$tcp = $a_tcp; +$ftp = $a_ftp; +$http = $a_http; +$p2p = $a_p2p; + +$YMax += $YMax*0.05; // Add an extra 5% + +// if a y scale was specified override YMax +if (isset($yscale)&& $yscale > 0) + $YMax = $yscale/8; + +// Plot the data + +header("Content-type: image/png"); + +$im = imagecreate($width, $height); +$white = imagecolorallocate($im, 255, 255, 255); +$purple = ImageColorAllocate($im, 255, 0, 255); +$green = ImageColorAllocate($im, 0, 255, 0); +$blue = ImageColorAllocate($im, 0, 0, 255); +$lblue = ImageColorAllocate($im, 128, 128, 255); +$brown = ImageColorAllocate($im, 128, 0, 0); +$red = ImageColorAllocate($im, 255, 0, 0); +$black = ImageColorAllocate($im, 0, 0, 0); + +for($Counter=XOFFSET+1; $Counter < $width; $Counter++) + { + if (isset($total[$Counter])) + { + // Convert the bytes/sec to y coords + $total[$Counter] = ($total[$Counter]*($height-YOFFSET))/$YMax; + $tcp[$Counter] = ($tcp[$Counter]*($height-YOFFSET))/$YMax; + $ftp[$Counter] = ($ftp[$Counter]*($height-YOFFSET))/$YMax; + $http[$Counter] = ($http[$Counter]*($height-YOFFSET))/$YMax; + $p2p[$Counter] = ($p2p[$Counter]*($height-YOFFSET))/$YMax; + $udp[$Counter] = ($udp[$Counter]*($height-YOFFSET))/$YMax; + $icmp[$Counter] = ($icmp[$Counter]*($height-YOFFSET))/$YMax; + + // Stack 'em up! + // Total is stacked from the bottom + // Icmp is on the bottom too + // Udp is stacked on top of icmp + $udp[$Counter] += $icmp[$Counter]; + // TCP and p2p are stacked on top of Udp + $tcp[$Counter] += $udp[$Counter]; + $p2p[$Counter] += $udp[$Counter]; + // Http is stacked on top of p2p + $http[$Counter] += $p2p[$Counter]; + // Ftp is stacked on top of http + $ftp[$Counter] += $http[$Counter]; + + // Plot them! + //echo "$Counter:".$Counter." (h-y)-t:".($height-YOFFSET) - $total[$Counter]." h-YO-1:".$height-YOFFSET-1; + ImageLine($im, $Counter, ($height-YOFFSET) - $icmp[$Counter], $Counter, $height-YOFFSET-1, $red); + ImageLine($im, $Counter, ($height-YOFFSET) - $udp[$Counter], $Counter, ($height-YOFFSET) - $icmp[$Counter] - 1, $brown); + ImageLine($im, $Counter, ($height-YOFFSET) - $tcp[$Counter], $Counter, ($height-YOFFSET) - $udp[$Counter] - 1, $green); + ImageLine($im, $Counter, ($height-YOFFSET) - $p2p[$Counter], $Counter, ($height-YOFFSET) - $udp[$Counter] - 1, $purple); + ImageLine($im, $Counter, ($height-YOFFSET) - $http[$Counter], $Counter, ($height-YOFFSET) - $p2p[$Counter] - 1, $blue); + ImageLine($im, $Counter, ($height-YOFFSET) - $ftp[$Counter], $Counter, ($height-YOFFSET) - $http[$Counter] - 1, $lblue); + } +// else +// echo $Counter." not set
"; + } + +// Margin Text +if ($SentPeak < 1024/8) + $txtPeakSendRate = sprintf("Peak Send Rate: %.1f KBits/sec", $SentPeak*8); +else if ($SentPeak < (1024*1024)/8) + $txtPeakSendRate = sprintf("Peak Send Rate: %.1f MBits/sec", ($SentPeak*8.0)/1024.0); +else + $txtPeakSendRate = sprintf("Peak Send Rate: %.1f GBits/sec", ($SentPeak*8.0)/(1024.0*1024.0)); + +if ($TotalSent < 1024) + $txtTotalSent = sprintf("Sent %.1f KBytes", $TotalSent); +else if ($TotalSent < 1024*1024) + $txtTotalSent = sprintf("Sent %.1f MBytes", $TotalSent/1024.0); +else + $txtTotalSent = sprintf("Sent %.1f GBytes", $TotalSent/(1024.0*1024.0)); + +ImageString($im, 2, XOFFSET+5, $height-20, $txtTotalSent, $black); +ImageString($im, 2, $width/2+XOFFSET/2, $height-20, $txtPeakSendRate, $black); + +// Draw X Axis + +ImageLine($im, 0, $height-YOFFSET, $width, $height-YOFFSET, $black); + +// Day/Month Seperator bars + +if ((24*60*60*($width-XOFFSET))/$interval > ($width-XOFFSET)/10) + { + $ts = getdate($timestamp); + $MarkTime = mktime(0, 0, 0, $ts['mon'], $ts['mday'], $ts['year']); + + $x = ts2x($MarkTime); + while ($x < XOFFSET) + { + $MarkTime += (24*60*60); + $x = ts2x($MarkTime); + } + + while ($x < ($width-10)) + { + // Day Lines + ImageLine($im, $x, 0, $x, $height-YOFFSET, $black); + ImageLine($im, $x+1, 0, $x+1, $height-YOFFSET, $black); + + $txtDate = strftime("%a, %b %d", $MarkTime); + ImageString($im, 2, $x-30, $height-YOFFSET+10, $txtDate, $black); + + // Calculate Next x + $MarkTime += (24*60*60); + $x = ts2x($MarkTime); + } + } +else if ((24*60*60*30*($width-XOFFSET))/$interval > ($width-XOFFSET)/10) + { + // Monthly Bars + $ts = getdate($timestamp); + $month = $ts['mon']; + $MarkTime = mktime(0, 0, 0, $month, 1, $ts['year']); + + $x = ts2x($MarkTime); + while ($x < XOFFSET) + { + $month++; + $MarkTime = mktime(0, 0, 0, $month, 1, $ts['year']); + $x = ts2x($MarkTime); + } + + while ($x < ($width-10)) + { + // Day Lines + ImageLine($im, $x, 0, $x, $height-YOFFSET, $black); + ImageLine($im, $x+1, 0, $x+1, $height-YOFFSET, $black); + + $txtDate = strftime("%b, %Y", $MarkTime); + ImageString($im, 2, $x-25, $height-YOFFSET+10, $txtDate, $black); + + // Calculate Next x + $month++; + $MarkTime = mktime(0, 0, 0, $month, 1, $ts['year']); + $x = ts2x($MarkTime); + } + } +else + { + // Year Bars + $ts = getdate($timestamp); + $year = $ts['year']; + $MarkTime = mktime(0, 0, 0, 1, 1, $year); + + $x = ts2x($MarkTime); + while ($x < XOFFSET) + { + $year++; + $MarkTime = mktime(0, 0, 0, 1, 1, $year); + $x = ts2x($MarkTime); + } + + while ($x < ($width-10)) + { + // Day Lines + ImageLine($im, $x, 0, $x, $height-YOFFSET, $black); + ImageLine($im, $x+1, 0, $x+1, $height-YOFFSET, $black); + + $txtDate = strftime("%b, %Y", $MarkTime); + ImageString($im, 2, $x-25, $height-YOFFSET+10, $txtDate, $black); + + // Calculate Next x + $year++; + $MarkTime = mktime(0, 0, 0, 1, 1, $year); + $x = ts2x($MarkTime); + } + } + +// Draw Major Tick Marks +if ((6*60*60*($width-XOFFSET))/$interval > 10) // pixels per 6 hours is more than 2 + $MarkTimeStep = 6*60*60; // Major ticks are 6 hours +else if ((24*60*60*($width-XOFFSET))/$interval > 10) + $MarkTimeStep = 24*60*60; // Major ticks are 24 hours; +else if ((24*60*60*30*($width-XOFFSET))/$interval > 10) + { + // Major tick marks are months + $MarkTimeStep = 0; // Skip the standard way of drawing major tick marks below + + $ts = getdate($timestamp); + $month = $ts['mon']; + $MarkTime = mktime(0, 0, 0, $month, 1, $ts['year']); + + $x = ts2x($MarkTime); + while ($x < XOFFSET) + { + $month++; + $MarkTime = mktime(0, 0, 0, $month, 1, $ts['year']); + $x = ts2x($MarkTime); + } + + while ($x < ($width-10)) + { + // Day Lines + $date = getdate($MarkTime); + if ($date['mon'] != 1) + { + ImageLine($im, $x, $height-YOFFSET-5, $x, $height-YOFFSET+5, $black); + $txtDate = strftime("%b", $MarkTime); + ImageString($im, 2, $x-5, $height-YOFFSET+10, $txtDate, $black); + } + + // Calculate Next x + $month++; + $MarkTime = mktime(0, 0, 0, $month, 1, $ts['year']); + $x = ts2x($MarkTime); + } + } +else + $MarkTimeStep = 0; // Skip Major Tick Marks + +if ($MarkTimeStep) + { + $ts = getdate($timestamp); + $MarkTime = mktime(0, 0, 0, $ts['mon'], $ts['mday'], $ts['year']); + $x = ts2x($MarkTime); + + while ($x < ($width-10)) + { + if ($x > XOFFSET) + { + ImageLine($im, $x, $height-YOFFSET-5, $x, $height-YOFFSET+5, $black); + } + $MarkTime += $MarkTimeStep; + $x = ts2x($MarkTime); + } + } + +// Draw Minor Tick marks +if ((60*60*($width-XOFFSET))/$interval > 4) // pixels per hour is more than 2 + $MarkTimeStep = 60*60; // Minor ticks are 1 hour +else if ((6*60*60*($width-XOFFSET))/$interval > 4) + $MarkTimeStep = 6*60*60; // Minor ticks are 6 hours +else if ((24*60*60*($width-XOFFSET))/$interval > 4) + $MarkTimeStep = 24*60*60; +else + $MarkTimeStep = 0; // Skip minor tick marks + +if ($MarkTimeStep) + { + $ts = getdate($timestamp); + $MarkTime = mktime(0, 0, 0, $ts['mon'], $ts['mday'], $ts['year']); + $x = ts2x($MarkTime); + + while ($x < ($width-10)) + { + if ($x > XOFFSET) + { + ImageLine($im, $x, $height-YOFFSET, $x, $height-YOFFSET+5, $black); + } + $MarkTime += $MarkTimeStep; + $x = ts2x($MarkTime); + } + } + +// Draw Y Axis +ImageLine($im, XOFFSET, 0, XOFFSET, $height, $black); + +$YLegend = 'k'; +$Divisor = 1; +if ($YMax*8 > 1024*2) + { + $Divisor = 1024; // Display in m + $YLegend = 'm'; + } + +if ($YMax*8 > 1024*1024*2) + { + $Divisor = 1024*1024; // Display in g + $YLegend = 'g'; + } + +if ($YMax*8 > 1024*1024*1024*2) + { + $Divisor = 1024*1024*1024; // Display in t + $YLegend = 't'; + } + +$YStep = $YMax/10; +if ($YStep < 1) + $YStep=1; +$YTic=$YStep; + +while ($YTic <= ($YMax - $YMax/10)) + { + $y = ($height-YOFFSET)-(($YTic*($height-YOFFSET))/$YMax); + ImageLine($im, XOFFSET, $y, $width, $y, $black); + $txtYLegend = sprintf("%4.1f %sbits/s", (8.0*$YTic)/$Divisor, $YLegend); + ImageString($im, 2, 3, $y-7, $txtYLegend, $black); + $YTic += $YStep; + } + +imagepng($im); +imagedestroy($im); diff --git a/utils/bandwidthd/files/phphtdocs-sqlite/include.php b/utils/bandwidthd/files/phphtdocs-sqlite/include.php new file mode 100644 index 000000000..51950980d --- /dev/null +++ b/utils/bandwidthd/files/phphtdocs-sqlite/include.php @@ -0,0 +1,69 @@ +getMessage()); + } + return $db; +} + +function fmtb($kbytes) + { + $Max = 1024; + $Output = $kbytes; + $Suffix = 'K'; + + if ($Output > $Max) + { + $Output /= 1024; + $Suffix = 'M'; + } + + if ($Output > $Max) + { + $Output /= 1024; + $Suffix = 'G'; + } + + if ($Output > $Max) + { + $Output /= 1024; + $Suffix = 'T'; + } + + return(sprintf("%.1f%s", $Output, $Suffix)); + } + +function ip2s32($ip) { + $i = ip2long($ip); + return ($i & 0x80000000 ? '-' . ((~$i & 0x7fffffff)+1) : ''. ($i & 0x7fffffff)); +} + +function prepare_sql_subnet($subnet) { + list($snet, $smask) = explode('/', $subnet); + $inet = ip2s32($snet); + if($smask > 0 && $smask < 32) { + $mask = -1 << (32 - (int)$smask); + return "and (ip & $mask = $inet)"; + } elseif ($inet) { + return "and ip = " . $inet; + } + return ""; +} + +$starttime = time(); +set_time_limit(300); +?> diff --git a/utils/bandwidthd/files/phphtdocs-sqlite/index.php b/utils/bandwidthd/files/phphtdocs-sqlite/index.php new file mode 100644 index 000000000..c8b8598d1 --- /dev/null +++ b/utils/bandwidthd/files/phphtdocs-sqlite/index.php @@ -0,0 +1,190 @@ + + +
+ + +
+ + +
+ + + +Subnet Filter:"> + +
+
+Top $limit - $sensor_name"; +else + echo "

All Records - $sensor_name

"; + +// Sqlize the incomming variables +if (isset($subnet)) { + $sql_subnet = prepare_sql_subnet($subnet); +} + +// Sql Statement +$sql = "select tx.ip, rx.scale as rxscale, tx.scale as txscale, tx.total+rx.total as total, tx.total as sent, +rx.total as received, tx.tcp+rx.tcp as tcp, tx.udp+rx.udp as udp, +tx.icmp+rx.icmp as icmp, tx.http+rx.http as http, +tx.p2p+rx.p2p as p2p, tx.ftp+rx.ftp as ftp +from + +(SELECT ip, max(total/sample_duration)*8 as scale, sum(total) as total, sum(tcp) as tcp, sum(udp) as udp, sum(icmp) as icmp, +sum(http) as http, sum(p2p) as p2p, sum(ftp) as ftp +from sensors, bd_tx_log +where sensor_name = '$sensor_name' +and sensors.sensor_id = bd_tx_log.sensor_id +$sql_subnet +and timestamp > $timestamp and timestamp < ".($timestamp+$interval)." +group by ip) as tx, + +(SELECT ip, max(total/sample_duration)*8 as scale, sum(total) as total, sum(tcp) as tcp, sum(udp) as udp, sum(icmp) as icmp, +sum(http) as http, sum(p2p) as p2p, sum(ftp) as ftp +from sensors, bd_rx_log +where sensor_name = '$sensor_name' +and sensors.sensor_id = bd_rx_log.sensor_id +$sql_subnet +and timestamp > $timestamp and timestamp < ".($timestamp+$interval)." +group by ip) as rx + +where tx.ip = rx.ip +order by total desc;"; + +//echo "
$sql
"; error_log($sql); +$pdoResult = $db->query($sql); +$result = $pdoResult->fetchAll(); +$db = NULL; +$num_rows = count($result); +if ($limit == "all") + $limit = $num_rows; + +echo "
IpNameTotalSentReceivedtcpudpicmphttpsmtpftp"; + +if (!isset($subnet)) // Set this now for total graphs + $subnet = "0.0.0.0/0"; + +// Output Total Line +echo "
Total$subnet"; +foreach (array("total", "sent", "received", "tcp", "udp", "icmp", "http", "p2p", "ftp") as $key) + { + for($Counter=0, $Total = 0; $Counter < $num_rows; $Counter++) + { + $r = $result[$Counter]; + $Total += $r[$key]; + } + echo fmtb($Total); + } +echo "\n"; + +// Output Other Lines +for($Counter=0; $Counter < $num_rows && $Counter < $limit; $Counter++) + { + $r = $result[$Counter]; + $r['ip'] = long2ip($r['ip']); + echo "
"; + echo $r['ip']."".gethostbyaddr($r['ip']); + echo ""; + echo fmtb($r['total']).fmtb($r['sent']).fmtb($r['received']). + fmtb($r['tcp']).fmtb($r['udp']).fmtb($r['icmp']).fmtb($r['http']). + fmtb($r['p2p']).fmtb($r['ftp'])."\n"; + } +echo "
"; + +// Output Total Graph +for($Counter=0, $Total = 0; $Counter < $num_rows; $Counter++) + { + $r = $result[$Counter]; + $scale = max($r['txscale'], $scale); + $scale = max($r['rxscale'], $scale); + } + +if ($subnet == "0.0.0.0/0") + $total_table = "bd_tx_total_log"; +else + $total_table = "bd_tx_log"; +echo "

"; +echo "Total - Total of $subnet

"; +echo ""; +echo "Send:

"; +echo "
\n"; +if ($subnet == "0.0.0.0/0") + $total_table = "bd_rx_total_log"; +else + $total_table = "bd_rx_log"; +echo "Receive:

"; +echo "
\n"; + + +// Output Other Graphs +for($Counter=0; $Counter < $num_rows && $Counter < $limit; $Counter++) + { + $r = $result[$Counter]; + $r['ip'] = long2ip($r['ip']); + echo "

"; + if ($r['ip'] == "0.0.0.0") + echo "Total - Total of all subnets

"; + else + echo $r['ip']." - ".gethostbyaddr($r['ip']).""; + echo ""; + echo "Send:

"; + echo "
\n"; + echo "Receive:

"; + echo "
\n"; + } + +include('footer.php'); diff --git a/utils/bandwidthd-php/files/details.php b/utils/bandwidthd/files/phphtdocs/details.php similarity index 99% rename from utils/bandwidthd-php/files/details.php rename to utils/bandwidthd/files/phphtdocs/details.php index d2f0786f9..cb52f4327 100644 --- a/utils/bandwidthd-php/files/details.php +++ b/utils/bandwidthd/files/phphtdocs/details.php @@ -65,7 +65,7 @@ group by ip) as rx where tx.ip = rx.ip;"; //echo "
$sql
";exit(0); $result = pg_query($sql); -echo "
IpNameTotalSentReceivedtcpudpicmphttpp2pftp"; +echo "
IpNameTotalSentReceivedtcpudpicmphttpsmtpftp"; $r = pg_fetch_array($result); echo "
"; if (strpos($ip, "/") === FALSE) diff --git a/utils/bandwidthd/files/phphtdocs/footer.php b/utils/bandwidthd/files/phphtdocs/footer.php new file mode 100644 index 000000000..b3428250d --- /dev/null +++ b/utils/bandwidthd/files/phphtdocs/footer.php @@ -0,0 +1,3 @@ + diff --git a/utils/bandwidthd-php/files/graph.php b/utils/bandwidthd/files/phphtdocs/graph.php similarity index 80% rename from utils/bandwidthd-php/files/graph.php rename to utils/bandwidthd/files/phphtdocs/graph.php index b97817738..323d659ed 100644 --- a/utils/bandwidthd-php/files/graph.php +++ b/utils/bandwidthd/files/phphtdocs/graph.php @@ -13,7 +13,7 @@ function AverageAndAccumulate() { global $Count, $total, $icmp, $udp, $tcp, $ftp, $http, $p2p, $YMax; global $a_total, $a_icmp, $a_udp, $a_tcp, $a_ftp, $a_http, $a_p2p; - + foreach ($Count as $key => $number) { $total[$key] /= $number; @@ -25,7 +25,7 @@ function AverageAndAccumulate() $p2p[$key] /= $number; } - foreach ($Count as $key => $number) + foreach ($Count as $key => $number) { $a_total[$key] += $total[$key]; $a_icmp[$key] += $icmp[$key]; @@ -38,7 +38,7 @@ function AverageAndAccumulate() if ($a_total[$key] > $YMax) $YMax = $a_total[$key]; } - + unset($GLOBALS['total'], $GLOBALS['icmp'], $GLOBALS['udp'], $GLOBALS['tcp'], $GLOBALS['ftp'], $GLOBALS['http'], $GLOBALS['p2p'], $GLOBALS['Count']); $total = array(); @@ -50,7 +50,6 @@ function AverageAndAccumulate() $p2p = array(); $Count = array(); } - $db = ConnectDb(); @@ -133,7 +132,7 @@ while ($row = pg_fetch_array($result)) //echo "xint: ".$xint."
"; $Count[$xint]++; - + if ($row['total']/$row['sample_duration'] > $SentPeak) $SentPeak = $row['total']/$row['sample_duration']; $TotalSent += $row['total']; @@ -143,7 +142,7 @@ while ($row = pg_fetch_array($result)) $tcp[$xint] += $row['tcp']/$row['sample_duration']; $ftp[$xint] += $row['ftp']/$row['sample_duration']; $http[$xint] += $row['http']/$row['sample_duration']; - $p2p[$xint] += $row['p2p']/$row['sample_duration']; + $p2p[$xint] += $row['p2p']/$row['sample_duration']; } // One more time for the last IP @@ -170,7 +169,6 @@ header("Content-type: image/png"); $im = imagecreate($width, $height); $white = imagecolorallocate($im, 255, 255, 255); -$yellow = ImageColorAllocate($im, 255, 255, 0); $purple = ImageColorAllocate($im, 255, 0, 255); $green = ImageColorAllocate($im, 0, 255, 0); $blue = ImageColorAllocate($im, 0, 0, 255); @@ -207,7 +205,6 @@ for($Counter=XOFFSET+1; $Counter < $width; $Counter++) // Plot them! //echo "$Counter:".$Counter." (h-y)-t:".($height-YOFFSET) - $total[$Counter]." h-YO-1:".$height-YOFFSET-1; - ImageLine($im, $Counter, ($height-YOFFSET) - $total[$Counter], $Counter, $height-YOFFSET-1, $yellow); ImageLine($im, $Counter, ($height-YOFFSET) - $icmp[$Counter], $Counter, $height-YOFFSET-1, $red); ImageLine($im, $Counter, ($height-YOFFSET) - $udp[$Counter], $Counter, ($height-YOFFSET) - $icmp[$Counter] - 1, $brown); ImageLine($im, $Counter, ($height-YOFFSET) - $tcp[$Counter], $Counter, ($height-YOFFSET) - $udp[$Counter] - 1, $green); @@ -217,23 +214,23 @@ for($Counter=XOFFSET+1; $Counter < $width; $Counter++) } // else // echo $Counter." not set
"; - } + } // Margin Text if ($SentPeak < 1024/8) $txtPeakSendRate = sprintf("Peak Send Rate: %.1f KBits/sec", $SentPeak*8); else if ($SentPeak < (1024*1024)/8) $txtPeakSendRate = sprintf("Peak Send Rate: %.1f MBits/sec", ($SentPeak*8.0)/1024.0); -else +else $txtPeakSendRate = sprintf("Peak Send Rate: %.1f GBits/sec", ($SentPeak*8.0)/(1024.0*1024.0)); - + if ($TotalSent < 1024) $txtTotalSent = sprintf("Sent %.1f KBytes", $TotalSent); else if ($TotalSent < 1024*1024) $txtTotalSent = sprintf("Sent %.1f MBytes", $TotalSent/1024.0); -else +else $txtTotalSent = sprintf("Sent %.1f GBytes", $TotalSent/(1024.0*1024.0)); - + ImageString($im, 2, XOFFSET+5, $height-20, $txtTotalSent, $black); ImageString($im, 2, $width/2+XOFFSET/2, $height-20, $txtPeakSendRate, $black); @@ -247,23 +244,23 @@ if ((24*60*60*($width-XOFFSET))/$interval > ($width-XOFFSET)/10) { $ts = getdate($timestamp); $MarkTime = mktime(0, 0, 0, $ts['mon'], $ts['mday'], $ts['year']); - + $x = ts2x($MarkTime); while ($x < XOFFSET) { $MarkTime += (24*60*60); $x = ts2x($MarkTime); } - + while ($x < ($width-10)) { // Day Lines ImageLine($im, $x, 0, $x, $height-YOFFSET, $black); ImageLine($im, $x+1, 0, $x+1, $height-YOFFSET, $black); - + $txtDate = strftime("%a, %b %d", $MarkTime); ImageString($im, 2, $x-30, $height-YOFFSET+10, $txtDate, $black); - + // Calculate Next x $MarkTime += (24*60*60); $x = ts2x($MarkTime); @@ -275,7 +272,7 @@ else if ((24*60*60*30*($width-XOFFSET))/$interval > ($width-XOFFSET)/10) $ts = getdate($timestamp); $month = $ts['mon']; $MarkTime = mktime(0, 0, 0, $month, 1, $ts['year']); - + $x = ts2x($MarkTime); while ($x < XOFFSET) { @@ -283,16 +280,16 @@ else if ((24*60*60*30*($width-XOFFSET))/$interval > ($width-XOFFSET)/10) $MarkTime = mktime(0, 0, 0, $month, 1, $ts['year']); $x = ts2x($MarkTime); } - + while ($x < ($width-10)) { // Day Lines ImageLine($im, $x, 0, $x, $height-YOFFSET, $black); ImageLine($im, $x+1, 0, $x+1, $height-YOFFSET, $black); - + $txtDate = strftime("%b, %Y", $MarkTime); ImageString($im, 2, $x-25, $height-YOFFSET+10, $txtDate, $black); - + // Calculate Next x $month++; $MarkTime = mktime(0, 0, 0, $month, 1, $ts['year']); @@ -305,7 +302,7 @@ else $ts = getdate($timestamp); $year = $ts['year']; $MarkTime = mktime(0, 0, 0, 1, 1, $year); - + $x = ts2x($MarkTime); while ($x < XOFFSET) { @@ -313,21 +310,21 @@ else $MarkTime = mktime(0, 0, 0, 1, 1, $year); $x = ts2x($MarkTime); } - + while ($x < ($width-10)) { // Day Lines ImageLine($im, $x, 0, $x, $height-YOFFSET, $black); ImageLine($im, $x+1, 0, $x+1, $height-YOFFSET, $black); - + $txtDate = strftime("%b, %Y", $MarkTime); ImageString($im, 2, $x-25, $height-YOFFSET+10, $txtDate, $black); - + // Calculate Next x $year++; $MarkTime = mktime(0, 0, 0, 1, 1, $year); $x = ts2x($MarkTime); - } + } } // Draw Major Tick Marks @@ -343,7 +340,7 @@ else if ((24*60*60*30*($width-XOFFSET))/$interval > 10) $ts = getdate($timestamp); $month = $ts['mon']; $MarkTime = mktime(0, 0, 0, $month, 1, $ts['year']); - + $x = ts2x($MarkTime); while ($x < XOFFSET) { @@ -351,18 +348,18 @@ else if ((24*60*60*30*($width-XOFFSET))/$interval > 10) $MarkTime = mktime(0, 0, 0, $month, 1, $ts['year']); $x = ts2x($MarkTime); } - + while ($x < ($width-10)) { // Day Lines $date = getdate($MarkTime); if ($date['mon'] != 1) { - ImageLine($im, $x, $height-YOFFSET-5, $x, $height-YOFFSET+5, $black); + ImageLine($im, $x, $height-YOFFSET-5, $x, $height-YOFFSET+5, $black); $txtDate = strftime("%b", $MarkTime); ImageString($im, 2, $x-5, $height-YOFFSET+10, $txtDate, $black); } - + // Calculate Next x $month++; $MarkTime = mktime(0, 0, 0, $month, 1, $ts['year']); @@ -380,13 +377,13 @@ if ($MarkTimeStep) while ($x < ($width-10)) { - if ($x > XOFFSET) + if ($x > XOFFSET) { ImageLine($im, $x, $height-YOFFSET-5, $x, $height-YOFFSET+5, $black); } $MarkTime += $MarkTimeStep; $x = ts2x($MarkTime); - } + } } // Draw Minor Tick marks @@ -407,7 +404,7 @@ if ($MarkTimeStep) while ($x < ($width-10)) { - if ($x > XOFFSET) + if ($x > XOFFSET) { ImageLine($im, $x, $height-YOFFSET, $x, $height-YOFFSET+5, $black); } @@ -438,12 +435,12 @@ if ($YMax*8 > 1024*1024*1024*2) $Divisor = 1024*1024*1024; // Display in t $YLegend = 't'; } - + $YStep = $YMax/10; if ($YStep < 1) $YStep=1; $YTic=$YStep; - + while ($YTic <= ($YMax - $YMax/10)) { $y = ($height-YOFFSET)-(($YTic*($height-YOFFSET))/$YMax); @@ -453,5 +450,5 @@ while ($YTic <= ($YMax - $YMax/10)) $YTic += $YStep; } -imagepng($im); +imagepng($im); imagedestroy($im); diff --git a/utils/bandwidthd-php/files/include.php b/utils/bandwidthd/files/phphtdocs/include.php similarity index 100% rename from utils/bandwidthd-php/files/include.php rename to utils/bandwidthd/files/phphtdocs/include.php diff --git a/utils/bandwidthd-php/files/index.php b/utils/bandwidthd/files/phphtdocs/index.php similarity index 99% rename from utils/bandwidthd-php/files/index.php rename to utils/bandwidthd/files/phphtdocs/index.php index 5159f85d9..b3602afde 100644 --- a/utils/bandwidthd-php/files/index.php +++ b/utils/bandwidthd/files/phphtdocs/index.php @@ -122,7 +122,7 @@ pg_query("set sort_mem to default;"); if ($limit == "all") $limit = pg_num_rows($result); -echo "
IpNameTotalSentReceivedtcpudpicmphttpp2pftp"; +echo "
IpNameTotalSentReceivedtcpudpicmphttpsmtpftp"; if (!isset($subnet)) // Set this now for total graphs $subnet = "0.0.0.0/0"; diff --git a/utils/bandwidthd/patches/010-dont-add-host-paths-in-config.in.patch b/utils/bandwidthd/patches/010-dont-add-host-paths-in-config.in.patch new file mode 100644 index 000000000..cfaba70bd --- /dev/null +++ b/utils/bandwidthd/patches/010-dont-add-host-paths-in-config.in.patch @@ -0,0 +1,24 @@ +--- a/configure.in ++++ b/configure.in +@@ -24,11 +24,6 @@ if test -n "$x_libraries" && test "x$x_l + LDFLAGS="$LDFLAGS -L$x_libraries" + fi + +-# May be equired for BSD +-LDFLAGS="$LDFLAGS -L/usr/local/lib" +- +-CPPFLAGS="$CPPFLAGS -I/usr/local/include" +- + #Check for Darwin sw directory + AC_CHECK_FILE(/sw/lib, LDFLAGS="$LDFLAGS -L/sw/lib") + AC_CHECK_FILE(/sw/include, CPPFLAGS="$CPPFLAGS -I/sw/include") +@@ -55,8 +50,7 @@ AC_CHECK_LIB(pcap, pcap_open_live, , + [AC_CHECK_LIB(wpcap, pcap_open_live, ,[AC_MSG_ERROR([Bandwidthd requires but cannot find libpcap])])]) + + # Optional Library +-AC_CHECK_FILE(/usr/lib, LDFLAGS="$LDFLAGS -L/usr/lib") +-AC_CHECK_FILE(/usr/include/pgsql, CPPFLAGS="$CPPFLAGS -I/usr/include/pgsql") ++AC_CHECK_FILE(/usr/local/pgsql/include, CPPFLAGS="$CPPFLAGS -I/usr/local/pgsql/include") + AC_CHECK_LIB(pq, PQconnectdb, + [AC_CHECK_LIB(pq,PQexecParams, ,AC_MSG_WARN([libpq exists but is too old... bandwidthd requires support for PQexecParams]))]) + AC_CHECK_LIB(sqlite3, sqlite3_open, ,AC_MSG_WARN([sqlite3 is recommended for storage of data but cannot be found])) diff --git a/utils/bandwidthd/patches/010-dont-add-host-paths.patch b/utils/bandwidthd/patches/010-dont-add-host-paths.patch deleted file mode 100644 index 59a57373d..000000000 --- a/utils/bandwidthd/patches/010-dont-add-host-paths.patch +++ /dev/null @@ -1,36 +0,0 @@ -diff --git a/configure b/configure -index 4c2546e..e516137 100755 ---- a/configure -+++ b/configure -@@ -2439,11 +2439,6 @@ if test -n "$x_libraries" && test "x$x_libraries" != xNONE ; then - LDFLAGS="$LDFLAGS -L$x_libraries" - fi - --# May be equired for BSD --LDFLAGS="$LDFLAGS -L/usr/local/lib" -- --CPPFLAGS="$CPPFLAGS -I/usr/local/include" -- - #Check for Darwin sw directory - echo "$as_me:2448: checking for /sw/lib" >&5 - echo $ECHO_N "checking for /sw/lib... $ECHO_C" >&6 -@@ -2505,9 +2500,6 @@ fi - fi - echo "$as_me:2506: result: $ac_cv_file__usr_pkg_lib" >&5 - echo "${ECHO_T}$ac_cv_file__usr_pkg_lib" >&6 --if test $ac_cv_file__usr_pkg_lib = yes; then -- LDFLAGS="$LDFLAGS -L/usr/pkg/lib" --fi - - echo "$as_me:2512: checking for /usr/pkg/include" >&5 - echo $ECHO_N "checking for /usr/pkg/include... $ECHO_C" >&6 -@@ -3092,9 +3084,6 @@ fi - fi - echo "$as_me:3093: result: $ac_cv_file__usr_local_pgsql_lib" >&5 - echo "${ECHO_T}$ac_cv_file__usr_local_pgsql_lib" >&6 --if test $ac_cv_file__usr_local_pgsql_lib = yes; then -- LDFLAGS="$LDFLAGS -L/usr/local/pgsql/lib" --fi - - echo "$as_me:3099: checking for /usr/local/pgsql/include" >&5 - echo $ECHO_N "checking for /usr/local/pgsql/include... $ECHO_C" >&6 diff --git a/utils/bandwidthd/patches/020-change-p2p-to-smtp.patch b/utils/bandwidthd/patches/020-change-p2p-to-smtp.patch new file mode 100644 index 000000000..d0e614476 --- /dev/null +++ b/utils/bandwidthd/patches/020-change-p2p-to-smtp.patch @@ -0,0 +1,20 @@ +--- a/graph.c ++++ b/graph.c +@@ -274,7 +274,7 @@ void MakeIndexPages(int NumIps, struct S + + // PASS 1: Write out the table + +- fprintf(file, "
Ip and NameTotalTotal SentTotal ReceivedFTPHTTPP2PTCPUDPICMP\n"); ++ fprintf(file, "
Ip and NameTotalTotal SentTotal ReceivedFTPHTTPSMTPTCPUDPICMP\n"); + for (Counter=0; Counter < 21 && Counter < NumIps; Counter++) + PrintTableLine(file, SummaryData[Counter], Counter); + +@@ -341,7 +341,7 @@ void MakeIndexPages(int NumIps, struct S + + // PASS 1: Write out the table + +- fprintf(file, "
Ip and NameTotalTotal SentTotal ReceivedFTPHTTPP2PTCPUDPICMP\n"); ++ fprintf(file, "
Ip and NameTotalTotal SentTotal ReceivedFTPHTTPSMTPTCPUDPICMP\n"); + for (tCounter=0, Counter=0; Counter < NumIps; Counter++) + { + if (SubnetTable[SubnetCounter].ip == (SummaryData[Counter]->IP & SubnetTable[SubnetCounter].mask)) diff --git a/utils/bandwidthd/patches/100-fix_config_file_location b/utils/bandwidthd/patches/100-fix_config_file_location deleted file mode 100644 index ae44cd2e4..000000000 --- a/utils/bandwidthd/patches/100-fix_config_file_location +++ /dev/null @@ -1,31 +0,0 @@ ---- bandwidthd-2.0.1/bandwidthd.c.orig 2008-05-09 10:06:37.000000000 -0500 -+++ bandwidthd-2.0.1/bandwidthd.c 2008-05-09 10:32:54.000000000 -0500 -@@ -255,22 +255,22 @@ - - openlog("bandwidthd", LOG_CONS, LOG_DAEMON); - -- if (stat("./etc/bandwidthd.conf", &StatBuf)) -+ if (stat("/etc/bandwidthd.conf", &StatBuf)) - { - chdir(INSTALL_DIR); -- if (stat("./etc/bandwidthd.conf", &StatBuf)) -+ if (stat("/etc/bandwidthd.conf", &StatBuf)) - { -- printf("Cannot find ./etc/bandwidthd.conf or %s/etc/bandwidthd.conf\n", INSTALL_DIR); -- syslog(LOG_ERR, "Cannot find ./etc/bandwidthd.conf or %s/etc/bandwidthd.conf", INSTALL_DIR); -+ printf("Cannot find /etc/bandwidthd.conf or %s/etc/bandwidthd.conf\n", INSTALL_DIR); -+ syslog(LOG_ERR, "Cannot find /etc/bandwidthd.conf or %s/etc/bandwidthd.conf", INSTALL_DIR); - exit(1); - } - } - -- bdconfig_in = fopen("./etc/bandwidthd.conf", "rt"); -+ bdconfig_in = fopen("/etc/bandwidthd.conf", "rt"); - if (!bdconfig_in) - { - syslog(LOG_ERR, "Cannot open bandwidthd.conf"); -- printf("Cannot open ./etc/bandwidthd.conf\n"); -+ printf("Cannot open /etc/bandwidthd.conf\n"); - exit(1); - } - bdconfig_parse();