86 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
| #!/bin/bash
 | |
| #
 | |
| # $Id: get_account_by_domain 22 2005-04-11 17:21:15Z jerome $
 | |
| # ----------------------------------------------------------------------
 | |
| # AlternC - Web Hosting System
 | |
| # Copyright (C) 2002 by the AlternC Development Team.
 | |
| # http://alternc.org
 | |
| # ----------------------------------------------------------------------
 | |
| # Based on:
 | |
| # Valentin Lacambre's web hosting softwares: http://altern.org/
 | |
| # ----------------------------------------------------------------------
 | |
| # LICENSE
 | |
| #
 | |
| # This program is free software; you can redistribute it and/or
 | |
| # modify it under the terms of the GNU General Public License (GPL)
 | |
| # as published by the Free Software Foundation; either version 2
 | |
| # of the License, or (at your option) any later version.
 | |
| #
 | |
| # This program is distributed in the hope that it will be useful,
 | |
| # but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| # GNU General Public License for more details.
 | |
| #
 | |
| # To read the license please visit http://www.gnu.org/copyleft/gpl.html
 | |
| # ----------------------------------------------------------------------
 | |
| # Original Author of file: Jerome Moinet
 | |
| # Purpose of file: gives account by domains or sub-domains
 | |
| # ----------------------------------------------------------------------
 | |
| #
 | |
| PATH=""
 | |
| PROG_NAME=get_account_by_domain
 | |
| PROG_VERSION=0.1.0
 | |
| ALTERNC_ETC=/etc/alternc
 | |
| ALTERNC_CONF_FILE=$ALTERNC_ETC/local.sh
 | |
| export TEXTDOMAIN=alternc-admintools
 | |
| 
 | |
| # Be sure to use the right programs on Debian
 | |
| # and be sure they are there
 | |
| id=/usr/bin/id
 | |
| mysql=/usr/bin/mysql
 | |
| sed=/bin/sed
 | |
| gettext=/usr/bin/gettext
 | |
| printf=/usr/bin/printf
 | |
| 
 | |
| 
 | |
| # Must have gettext first to display error messages
 | |
| [ -x "$gettext" ] || { echo "Cannot execute $gettext"; exit 1 ; }
 | |
| 
 | |
| for i in $id $mysql $sed $printf
 | |
| do
 | |
|   ! [ -x "$i" ] && { echo "$($gettext "Unable to execute") ${i}."; exit 1 ; }
 | |
| done
 | |
| 
 | |
| 
 | |
| # Language-dependent messages
 | |
| # Uses gettext and mo files.
 | |
| # Don't change these messages, change the .po file instead.
 | |
| HELP=$($gettext "Gives account hosting domain or sub-domain.")
 | |
| USAGE=`$printf "$($gettext "Usage: %s [domain|sub-domain].")" $PROG_NAME`
 | |
| NOT_FOUND_MSG=$($gettext "does not exist.")
 | |
| NON_ROOT_MSG=$($gettext "You have to be root (uid 0) to execute this program.")
 | |
| MISSING_PROG=$($gettext "Unable to execute")
 | |
| MISSING_CONF_FILE=`$printf "$($gettext "Can't find %s. Are you sure AlterncC is properly installed?")" $ALTERNC_CONF_FILE`
 | |
| MYSQL_UNREACHABLE_DATABASE=`$printf "$($gettext "Cannot access accounts database. Please check either %s or Mysql state.")" $ALTERNC_CONF_FILE`
 | |
| 
 | |
| 
 | |
| #-------------------------
 | |
| # Main
 | |
| #-------------------------
 | |
| # Must be root
 | |
| [ "`$id -u`" != "0" ] && { echo $NON_ROOT_MSG ; exit 1 ; }
 | |
| # Must have minimum 1 parameter
 | |
| [ -z "$1" ] && { echo $USAGE ; exit 1 ; }
 | |
| # Handle -h and --help flags
 | |
| [ "$1" = "-h" ] || [ "$1" = "--help" ] && { echo $HELP ; echo $USAGE ; exit 0 ; }
 | |
| # Have to get AlternC conf file :
 | |
| ! [ -f "$ALTERNC_CONF_FILE" ] && { echo $MISSING_CONF_FILE ; exit 1 ; } || . $ALTERNC_CONF_FILE
 | |
| mysql="$mysql --defaults-file=/etc/alternc/my.cnf"
 | |
| $mysql -e "select count(*) from domaines_standby;" > /dev/null 2>&1
 | |
| [ "$?" != 0 ] && { echo "$MYSQL_UNREACHABLE_DATABASE" ; exit 1 ; }
 | |
| 
 | |
| # Does the stuff
 | |
| $mysql -B -N -e "select concat(a.login, \" (\", a.mail, \")\") from membres a, sub_domaines b where a.uid = b.compte and concat(if(sub=\"\", \"\", concat(sub, \".\")), domaine)  = \"${1}\";"
 | |
| 
 | |
| 
 |