+# TODO
+# - test build on amd64 and check /usr/lib64 patch
+# - cosmetics (sort in %%files and %%install)
+# - contrib split
+#
+# Conditional build:
+%bcond_without lmsd # without lmsd daemon
+#
+%define lmsver 1.8
+%define lmssubver 0
Summary: LAN Managment System
-Summary(pl): System Zarz±dzania Siec± Lokaln±
+Summary(pl): System Zarz±dzania Sieci± Lokaln±
Name: lms
-Version: 1.0pre10
+Version: %{lmsver}.%{lmssubver}
Release: 0.1
-License: GPL
+License: GPL v2
Vendor: LMS Developers
Group: Networking/Utilities
-Source0: http://lms.rulez.pl/download/%{name}-%{version}.tar.gz
+Source0: http://lms.rulez.pl/download/%{lmsver}/%{name}-%{version}.tar.gz
+# Source0-md5: afa0680e112dc14c4fbb41d9ec2eedee
+Source1: %{name}.conf
+Source2: %{name}.init
+Source3: %{name}.sysconfig
Patch0: %{name}-PLD.patch
+Patch1: %{name}-amd64.patch
URL: http://lms.rulez.pl/
+%{?with_lmsd:BuildRequires: libgadu-devel}
+%{?with_lmsd:BuildRequires: mysql-devel}
+%{?with_lmsd:BuildRequires: postgresql-devel}
+%{?with_lmsd:Requires(post,preun): /sbin/chkconfig}
+Requires: Smarty >= 2.6.10-4
Requires: php
-Requires: php-posix
+Requires: php-gd
+Requires: php-iconv
Requires: php-pcre
-Requires: webserver
-Requires: Smarty >= 2.5.0
-Requires: adodb >= 2.90
-BuildArch: noarch
+Requires: php-posix
+%{?with_lmsd:Requires: rc-scripts}
+Requires: webapps
BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
-%define _lmsdir /home/services/httpd/html/%{name}
-%define _sharedstatedir /var/lib
-# when spec'll be finished, this sould go to RA-branch
-# because sharedstatedir is already defined at rpm macros from HEAD
+%define _sysconfdir /etc/%{name}
+%define _lmsdir %{_datadir}/%{name}
+%define _lmsvar /var/lib/%{name}
+%define _webapps /etc/webapps
+%define _webapp %{name}
%description
This is a package of applications in PHP and Perl for managing LANs.
-It's using MySQL (for now) but PostgreSQL will be supported in near
-future. The main goal is to get the best service of users at
-provider's level.
-The main features in LMS are:
-- database of users (name, surname, address, telefon number,
+It's using MySQL or PostgreSQL. The main goal is to get the best
+service of users at provider's level. The main features in LMS are:
+- database of users (name, surname, address, telephone number,
commentary);
- database of computers (IP, MAC);
- easy-ridden financial system and funds of network;
- different subscriptions;
- sending warnings to users;
-- autogenerating dhcpd.conf;
-- autogenerating firewall rules (ipchains/iptables);
-- autogenerating idents for ident daemon;
- many levels of access for LMS administrators;
-- integration with LinuxStat package;
-- autogenerating ARP rules (ether auth);
-- autogenerating DNS files.
+- autogenerating ipchains, iptables, dhcpd, ethers file, oidentd,
+ openbsd packet filter configuration files/scripts;
+- autogenerating almost any kind of config file using templates.
%description -l pl
"LMS" jest skrótem od "LAN Management System". Jest to zestaw
aplikacji w PHP i Perlu, u³atwiaj±cych zarz±dzanie sieciami
osiedlowymi (popularnie zwanymi Amatorskimi Sieciami Komputerowymi),
-opartych o bazê danych MySQL (docelowo, do wyboru, MySQL lub
-PostgreSQL). G³ówne za³o¿enia to uzyskanie jako¶ci us³ug oraz obs³ugi
-u¿ytkowników na poziomie providera z prawdziwego zdarzenia.
-Najbardziej podstawowe cechy LMS to:
+opartych o bazê danych MySQL lub PostgreSQL. G³ówne za³o¿enia to
+uzyskanie jako¶ci us³ug oraz obs³ugi u¿ytkowników na poziomie
+providera z prawdziwego zdarzenia. Najbardziej podstawowe cechy LMS
+to:
- baza danych u¿ytkowników (imiê, nazwisko, adres, numer telefonu,
uwagi);
- baza danych komputerów (adres IP, adres MAC);
- ró¿ne taryfy abonamentowe;
- wysy³anie poczt± elektroniczn± upomnieñ do u¿ytkowników;
- automatyczne naliczanie op³at miesiêcznych;
-- generowanie dhcpd.conf;
-- generowanie regu³ firewalla (ipchains/iptables);
-- generowanie identów dla demona oidentd;
- ró¿ne poziomy dostêpu do funkcji LMS dla administratorów;
-- integracja z pakietem LinuxStat;
-- generowanie wpisów ARP (blokada adresów IP po ARP);
-- generowanie wpisów do DNS.
+- generowanie regu³ i plików konfiguracyjnych dla ipchains, iptables,
+ dhcpd, oidentd, packet filtra openbsd, wpisów /etc/ethers
+- generowanie praktycznie ka¿dego pliku konfiguracyjnego na podstawie
+ danych w bazie przy u¿yciu prostych szablonów.
%package scripts
Summary: LAN Managment System - scripts
Summary(pl): LAN Managment System - skrypty
-Requires: perl-Net-SMTP-Server
+Group: Networking/Utilities
Requires: perl-Config-IniFiles
Requires: perl-DBI
-BuildArch: noarch
-Group: Networking/Utilities
+Requires: perl-Net-SMTP-Server
%description scripts
This package contains scripts to integrate LMS with your system,
monthly billing, notify users about their debts and cutting off
-customers. Also you can build propably any kind of config file using
+customers. Also you can build probably any kind of config file using
lms-mgc.
%description scripts -l pl
ich automagicznego od³±czania. Mo¿esz tak¿e zbudowaæ prawdopodobnie
ka¿dy typ pliku konfiguracyjnego przy u¿yciu lms-mgc.
+%package sqlpanel
+Summary: LAN Managment System - sqlpanel module
+Summary(pl): LAN Managment System - modu³ sqlpanel
+Group: Networking/Utilities
+Requires: %{name} = %{version}-%{release}
+
+%description sqlpanel
+SQL-panel module allows you to execute SQL queries and directly modify
+data.
+
+%description sqlpanel -l pl
+Modu³ 'SQL - panel' daje mo¿liwo¶æ bezpo¶redniego dostêpu do bazy
+danych poprzez zadawanie zapytañ SQL. Wyniki wy¶wietlane s± w formie
+tabeli. Ponadto podawany jest czas wykonania zapytania.
+
+%package user
+Summary: LAN Managment System - simple user interface
+Summary(pl): LAN Managment System - prosty interfejs u¿ytkownika
+Group: Networking/Utilities
+Requires: %{name} = %{version}-%{release}
+
+%description user
+Simple user interface.
+
+%description user -l pl
+Prosty interfejs u¿ytkownika.
+
+%package lmsd
+Summary: LAN Managment System - LMS system backend
+Summary(pl): LAN Managment System - backend systemu LMS
+Group: Networking/Utilities
+Requires: %{name} = %{version}-%{release}
+Obsoletes: lms-almsd
+
+%description lmsd
+A program to manage the server by creating configuration files based
+upon LMS database and restarting selected services.
+
+%description lmsd -l pl
+Program zarz±dzaj±cy serwerem poprzez tworzenie plików
+konfiguracyjnych na podstawie bazy danych LMS'a i restartowanie
+wybranych us³ug.
+
%prep
%setup -q -n %{name}
%patch0 -p1
+%if "%{_lib}" == "lib64"
+%patch1 -p1
+%endif
+
+%build
+%if %{with lmsd}
+
+cd daemon
+
+./configure --with-mysql
+%{__make} \
+ CC='%{__cc}' CFLAGS='%{rpmcflags} -fPIC -DUSE_MYSQL -DLMS_LIB_DIR=\"%{_libdir}/lms/\" -I../..'
+mv lmsd lmsd-mysql
+
+./configure --with-pgsql
+%{__make} lmsd \
+ CC='%{__cc}' \
+ CFLAGS='%{rpmcflags} -fPIC -DUSE_PGSQL -DLMS_LIB_DIR=\"%{_libdir}/lms/\" -I../..'
+mv lmsd lmsd-pgsql
+
+cd ..
+%endif
%install
rm -rf $RPM_BUILD_ROOT
-install -d $RPM_BUILD_ROOT%{_lmsdir}/img
-install -d $RPM_BUILD_ROOT%{_datadir}/%{name}
-install -d $RPM_BUILD_ROOT%{_bindir}
-install -d $RPM_BUILD_ROOT%{_sysconfdir}/%{name}
-install -d $RPM_BUILD_ROOT%{_sharedstatedir}/%{name}/{backups,templates_c}
-install -d $RPM_BUILD_ROOT%{_libexecdir}/%{name}/{lib,modules,templates}
-
-install *.php $RPM_BUILD_ROOT%{_lmsdir}
-install bin/* $RPM_BUILD_ROOT%{_bindir}
-install lib/* $RPM_BUILD_ROOT%{_libexecdir}/%{name}/lib
-install img/* $RPM_BUILD_ROOT%{_lmsdir}/img
-install modules/* $RPM_BUILD_ROOT%{_libexecdir}/%{name}/modules
-install templates/* $RPM_BUILD_ROOT%{_libexecdir}/%{name}/templates
-install sample/%{name}.ini $RPM_BUILD_ROOT%{_sysconfdir}/%{name}
+install -d $RPM_BUILD_ROOT%{_sbindir} \
+ $RPM_BUILD_ROOT/etc/{rc.d/init.d,sysconfig} \
+ $RPM_BUILD_ROOT/etc/lms/modules/{dns,ggnofity,nofity} \
+ $RPM_BUILD_ROOT{%{_lmsvar}/{backups,templates_c},%{_libdir}/lms} \
+ $RPM_BUILD_ROOT%{_lmsdir}/www/{img,doc,user}
+
+install *.php $RPM_BUILD_ROOT%{_lmsdir}/www
+install img/* $RPM_BUILD_ROOT%{_lmsdir}/www/img
+cp -r doc/html $RPM_BUILD_ROOT%{_lmsdir}/www/doc
+cp -r lib contrib modules templates sample $RPM_BUILD_ROOT%{_lmsdir}
+install bin/* $RPM_BUILD_ROOT%{_sbindir}
+
+install sample/%{name}.ini $RPM_BUILD_ROOT%{_sysconfdir}
+
+install -d $RPM_BUILD_ROOT%{_webapps}/%{_webapp}
+install %{SOURCE1} $RPM_BUILD_ROOT%{_webapps}/%{_webapp}/apache.conf
+install %{SOURCE1} $RPM_BUILD_ROOT%{_webapps}/%{_webapp}/httpd.conf
+
+# sqlpanel
+install contrib/sqlpanel/sql.php $RPM_BUILD_ROOT%{_lmsdir}/modules
+install contrib/sqlpanel/*.html $RPM_BUILD_ROOT%{_lmsdir}/templates
+
+# user
+cp -r contrib/customer/* $RPM_BUILD_ROOT%{_lmsdir}/www/user
+
+# daemon
+%if %{with lmsd}
+install daemon/lmsd-* $RPM_BUILD_ROOT%{_sbindir}
+install daemon/modules/*/*.so $RPM_BUILD_ROOT%{_libdir}/lms
+cp -r daemon/modules/dns/sample $RPM_BUILD_ROOT%{_sysconfdir}/modules/dns
+cp -r daemon/modules/ggnotify/sample $RPM_BUILD_ROOT%{_sysconfdir}/modules/ggnotify
+cp -r daemon/modules/dns/sample $RPM_BUILD_ROOT%{_sysconfdir}/modules/nofity
+install %{SOURCE2} $RPM_BUILD_ROOT/etc/rc.d/init.d/lmsd
+install %{SOURCE3} $RPM_BUILD_ROOT/etc/sysconfig/%{name}
+%endif
%clean
rm -rf $RPM_BUILD_ROOT
+%post lmsd
+/sbin/chkconfig --add lmsd
+if [ -f /var/lock/subsys/lmsd ]; then
+ /etc/rc.d/init.d/lmsd restart >&2
+else
+ echo "Run \"/etc/rc.d/init.d/lmsd start\" to start lmsd daemon."
+fi
+
+%preun lmsd
+if [ "$1" = "0" ]; then
+ if [ -f /var/lock/subsys/lmsd ]; then
+ /etc/rc.d/init.d/lmsd stop >&2
+ fi
+ /sbin/chkconfig --del lmsd
+fi
+
+%triggerin -- apache1
+%webapp_register apache %{_webapp}
+
+%triggerun -- apache1
+%webapp_unregister apache %{_webapp}
+
+%triggerin -- apache < 2.2.0, apache-base
+%webapp_register httpd %{_webapp}
+
+%triggerun -- apache < 2.2.0, apache-base
+%webapp_unregister httpd %{_webapp}
+
+%triggerpostun -- %{name} <= 1.0.4
+echo "WARNING!!!"
+echo "_READ_ and upgrade LMS database:"
+echo "MySQL: /usr/share/doc/%{name}-%{version}/UPGRADE-1.0-1.5.mysql.gz"
+echo "PostgreSQL: /usr/share/doc/%{name}-%{version}/UPGRADE-1.0-1.5.pgsql.gz"
+
+%triggerpostun -- %{name} <= 1.2.0
+echo "BEWARE:"
+echo "Automatic upgrade from LMS<= 1.2.0 is NO LONGER SUPPORTED by lms team"
+echo "You are advised to upgrade it manually"
+echo
+
+%triggerpostun -- %{name} < 1.6.6-1.4
+# nuke very-old config location (this mostly for Ra)
+if [ -f /etc/httpd/httpd.conf ]; then
+ sed -i -e "/^Include.*%{name}.conf/d" /etc/httpd/httpd.conf
+fi
+
+# migrate from httpd (apache2) config dir
+if [ -f /etc/httpd/%{name}.conf.rpmsave ]; then
+ cp -f %{_webapps}/%{_webapp}/httpd.conf{,.rpmnew}
+ mv -f /etc/httpd/%{name}.conf.rpmsave %{_webapps}/%{_webapp}/httpd.conf
+fi
+
+rm -f /etc/httpd/httpd.conf/99_%{name}.conf
+/usr/sbin/webapp register httpd %{_webapp}
+%service -q httpd reload
+
%files
%defattr(644,root,root,755)
-%doc doc sample/*.ini sample/*txt sample/rc.reminder_1st sample/crontab-entry
+%doc doc/{AUTHORS,ChangeLog,INSTALL,README*,lms*}
+%dir %{_sysconfdir}
+%attr(640,root,http) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/*.ini
+%dir %attr(750,root,http) %{_webapps}/%{_webapp}
+%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_webapps}/%{_webapp}/apache.conf
+%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_webapps}/%{_webapp}/httpd.conf
+#
+%dir %{_lmsvar}
+%attr(770,root,http) %{_lmsvar}/backups
+%attr(770,root,http) %{_lmsvar}/templates_c
+#
%dir %{_lmsdir}
-%dir %{_libexecdir}/%{name}
-%dir %{_sharedstatedir}/%{name}
-%attr(770,root,http) %{_sharedstatedir}/%{name}/templates_c
-%attr(770,root,http) %{_sharedstatedir}/%{name}/backups
-%{_lmsdir}/*.php
-%{_lmsdir}/img
-%{_libexecdir}/%{name}/lib
-%{_libexecdir}/%{name}/modules
-%{_libexecdir}/%{name}/templates
-%dir %{_sysconfdir}/%{name}
-%config(noreplace) %verify(not size mtime md5) %{_sysconfdir}/%{name}/*.ini
+%{_lmsdir}/www
+%exclude %{_lmsdir}/www/user
+%{_lmsdir}/lib
+%{_lmsdir}/modules
+%exclude %{_lmsdir}/modules/sql.php
+%{_lmsdir}/contrib
+%{_lmsdir}/sample
+%attr(755,root,root) %{_lmsdir}/sample/traffic_ipt.pl
+%{_lmsdir}/templates
+%exclude %{_lmsdir}/templates/sql.html
+%exclude %{_lmsdir}/templates/sqlprint.html
%files scripts
%defattr(644,root,root,755)
-%attr(755,root,root) %{_bindir}/lms-*
-%doc sample/*.ini
+%dir %{_sbindir}
+%attr(755,root,root) %{_sbindir}/*
+
+%files sqlpanel
+%defattr(644,root,root,755)
+%{_lmsdir}/modules/sql.php
+%{_lmsdir}/templates/sql.html
+%{_lmsdir}/templates/sqlprint.html
+
+%files user
+%defattr(644,root,root,755)
+%{_lmsdir}/www/user
+
+%if %{with lmsd}
+%files lmsd
+%defattr(644,root,root,755)
+%attr(755,root,root) %{_sbindir}/lmsd-*
+%attr(755,root,root) %{_libdir}/lms/*.so
+%attr(754,root,root) /etc/rc.d/init.d/lmsd
+/etc/lms/modules/*
+%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/sysconfig/%{name}
+%endif