wok-current view nconf/receipt @ rev 20194

Up autofs (5.1.4), btrfs-progs (4.15), cifs-utils (6.7), davfs2 (1.5.4), dosfstools (4.1), e2fsprogs (1.43.9), f2fs-tools (1.10.0), moosefs (3.0.100), milfs-utils (2.2.7), owfs (3.2p1)
author Pascal Bellard <pascal.bellard@slitaz.org>
date Mon Feb 12 13:54:33 2018 +0100 (2018-02-12)
parents 1067bb7f1e24
children 970c5ec9a60a
line source
1 # SliTaz package receipt.
3 PACKAGE="nconf"
4 VERSION="1.3.0-0"
5 CATEGORY="system-tools"
6 SHORT_DESC="Enterprise Nagios configurator"
7 MAINTAINER="erjo@slitaz.org"
8 LICENSE="GPL2"
9 TARBALL="$PACKAGE-$VERSION.tgz"
10 WEB_SITE="http://www.nconf.org/dokuwiki/doku.php"
11 WGET_URL="$SF_MIRROR/$PACKAGE/$TARBALL"
13 DEPENDS="mysql php-apache nagios perl perl-dbi perl-dbd-mysql"
15 # Rules to gen a SliTaz package suitable for Tazpkg.
16 genpkg_rules()
17 {
18 mkdir -p $fs/usr/share/nconf \
19 $fs/var/lib/nconf \
20 $fs/etc/nconf \
21 $fs/etc/apache/conf.d \
22 $fs/etc/nagios/import
24 cp $stuff/apache2-nconf.conf $fs/etc/apache/conf.d
26 # Copy files
27 cp -a $src/* $fs/usr/share/nconf
29 # Move config, output, static_cfg, temp tor $fs/var/lib/nconf (FHS)
30 # and link them to $fs/usr/sahre/nconf
31 cp -a $fs/usr/share/nconf/config.orig/* $fs/etc/nconf
32 mv $fs/usr/share/nconf/output $fs/var/lib/nconf
33 mv $fs/usr/share/nconf/static_cfg $fs/var/lib/nconf
34 mv $fs/usr/share/nconf/temp $fs/var/lib/nconf
36 chown -R www.www $fs/usr/share/nconf \
37 $fs/var/lib/nconf
39 ln -s /etc/nconf/authentication.php $fs/usr/share/nconf/config
40 ln -s /etc/nconf/main.php $fs/usr/share/nconf/config
41 ln -s /etc/nconf/mysql.php $fs/usr/share/nconf/config
42 ln -s /etc/nconf/nconf.php $fs/usr/share/nconf/config
43 ln -s /var/lib/nconf/output $fs/usr/share/nconf/
44 ln -s /var/lib/nconf/static_cfg $fs/usr/share/nconf/
45 ln -s /var/lib/nconf/temp $fs/usr/share/nconf/
47 mv $fs/usr/share/nconf/INSTALL $fs/var/lib/nconf
48 # Cleanup
49 rm -rf $fs/usr/share/nconf/UPDATE*
50 rm -f $fs/usr/share/nconf/INSTALL.php
52 # Set default settings
53 sed -i -e 's/Nconf/nconf/' -e 's/link2db/nconf/' $fs/etc/nconf/mysql.php
54 sed -i -e '/NCONFDIR/ s|/var/www|/usr/share|' \
55 -e '/NAGIOS_BIN/ s|/var/www/nconf/bin|/usr/bin|' $fs/etc/nconf/mysql.php
57 # Fix add-ons scripts
58 sed -i -e 's|bash|sh|' -e '/OUTPUT_DIR/ s|/var/www/html|/usr/share|' \
59 -e '/NAGIOS_DIR/ s|NAGIOS_DIR=.*|NAGIOS_DIR=\"/etc/nagios\"|' $fs/usr/share/nconf/ADD-ONS/deploy_local.sh
60 sed -i -e 's|bash|sh|' -e '/DBNAME/ s|NConf|nconf|' $fs/usr/share/nconf/ADD-ONS/history_cleanup.sh
61 }
63 post_install()
64 {
65 local db=nconf
66 local db_user=nconf
67 local db_password=nconf
68 local sql_script='/var/lib/nconf/INSTALL/create_database.sql'
70 # Minimal config for NConf.
71 if [ -z "$1" ]; then
72 if ( ! mysqladmin -s ping > /dev/null ); then
73 echo "Starting MySQL server"
74 ( /etc/init.d/mysql start ; status ) || exit
75 sleep 4 #let the mysql daemon start
76 fi
77 if ( ! mysql -u root -Be 'show databases' | grep -q $db ); then
78 echo -n "Create $db database"
79 mysql -Be "create database $db" ; status
80 # We suppose that $DB_USER user does not exist.
81 # It may be false.
82 echo -n "Create user $db_user with password $db_password"
83 mysql -Be "grant all privileges on $db.* to '"$db_user"'@'localhost'
84 identified by '"$db_password"'" ; status
85 # At last create the database for $PACKAGE.
86 echo -n "Create $db database schema."
87 mysql -u $db_user -p${db_password} -D $db < $sql_script ; status
88 fi
89 fi
90 true
91 }
93 post_remove()
94 {
95 if [ -z "$1" ]; then
96 local db=nconf
97 local db_user=nconf
98 local db_password=nconf
100 echo -n "Would you like to remove data and database files.(y/n) "
101 read answer
103 case $answer in
104 y|Y)
105 echo -n "Removing data directories..."
106 rm -rf /var/lib/nconf ; status
107 if ( mysql -u root -Be 'show databases' | grep -q $db ); then
108 echo -n "Deleting $db database"
109 mysql -Be "drop database $db" ; status
110 # We suppose that $db_user user does not exist.
111 # It may be false.
112 echo -n "Delete user $db_user"
113 mysql -Be "delete from mysql.db where user='"$db_user"'" ; status
114 fi
115 unset answer
116 ;;
117 *)
118 ;;
119 esac
120 fi
121 }