diff --git a/Scripts/Bash/Functions/cli_checkActionArguments.sh b/Scripts/Bash/Functions/cli_checkActionArguments.sh new file mode 100755 index 0000000..50845c3 --- /dev/null +++ b/Scripts/Bash/Functions/cli_checkActionArguments.sh @@ -0,0 +1,102 @@ +#!/bin/bash +# +# cli_checkActionArgument.sh -- This function provides input validation +# for the action value (ACTIONVAL) variable. +# +# Copyright (C) 2009, 2010 Alain Reguera Delgado +# +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License 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. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 +# USA. +# +# ---------------------------------------------------------------------- +# $Id$ +# ---------------------------------------------------------------------- + +function cli_checkActionArgument { + + # Check action value before making an absolute path from it. + if [[ $ACTIONVAL =~ '(\.\.(/)?)' ]];then + cli_printMessage "`gettext "The path provided can't be processed."`" 'AsErrorLine' + cli_printMessage "$(caller)" "AsToKnowMoreLine" + fi + if [[ ! $ACTIONVAL =~ '^[A-Za-z0-9\.:/-]+$' ]];then + cli_printMessage "`gettext "The path provided can't be processed."`" 'AsErrorLine' + cli_printMessage "$(caller)" "AsToKnowMoreLine" + fi + + # Re-define action value to build repository absolute path from + # repository top level on. As we are removing + # /home/centos/artwork/ from all centos-art.sh output (in order to + # save horizontal output space), we need to be sure that all + # strings begining with trunk/..., branches/..., and tags/... use + # the correct absolute path. That is, you can refer trunk's + # entries using both /home/centos/artwork/trunk/... or just + # trunk/..., the /home/centos/artwork/ part is automatically added + # here. + if [[ $ACTIONVAL =~ '^(trunk|branches|tags)' ]];then + ACTIONVAL=/home/centos/artwork/$ACTIONVAL + fi + + # Re-define action value to build repository absolute path from + # repository relative paths. This let us to pass repository + # relative paths as action value. Passing relative paths as + # action value may save us some typing; specially if we are stood + # a few levels up from the location we want to refer to as action + # value. There is no need to pass the absolute path to it, just + # refere it relatively. + if [[ -d ${ACTIONVAL} ]];then + + # Add directory to the top of the directory stack. + pushd "$ACTIONVAL" > /dev/null + + # Check directory existence inside the repository. + if [[ $(pwd) =~ '^/home/centos/artwork/.+$' ]];then + # Re-define action value using absolute path. + ACTIONVAL=$(pwd) + else + cli_printMessage "`gettext "The location provided is not valid."`" 'AsErrorLine' + cli_printMessage "$(caller)" 'AsToKnowMoreLine' + fi + + # Remove directory from the directory stack. + popd > /dev/null + + elif [[ -f ${ACTIONVAL} ]];then + + # Add directory to the top of the directory stack. + pushd "$(dirname $ACTIONVAL)" > /dev/null + + # Check directory existence inside the repository. + if [[ $(pwd) =~ '^/home/centos/artwork/.+$' ]];then + # Re-define action value using absolute path. + ACTIONVAL=$(pwd)/$(basename $ACTIONVAL) + else + cli_printMessage "`gettext "The location provided is not valid."`" 'AsErrorLine' + cli_printMessage "$(caller)" 'AsToKnowMoreLine' + fi + + # Remove directory from the directory stack. + popd > /dev/null + + else + + # Check repository url. + if [[ ! $ACTIONVAL =~ '^(https|http)://projects.centos.org/svn/artwork/.+$' ]];then + cli_printMessage "`gettext "The location provided is not valid."`" 'AsErrorLine' + cli_printMessage "$(caller)" 'AsToKnowMoreLine' + fi + fi + +} diff --git a/Scripts/Bash/Functions/cli_checkOptionValue.sh b/Scripts/Bash/Functions/cli_checkOptionValue.sh deleted file mode 100755 index 50845c3..0000000 --- a/Scripts/Bash/Functions/cli_checkOptionValue.sh +++ /dev/null @@ -1,102 +0,0 @@ -#!/bin/bash -# -# cli_checkActionArgument.sh -- This function provides input validation -# for the action value (ACTIONVAL) variable. -# -# Copyright (C) 2009, 2010 Alain Reguera Delgado -# -# This program is free software; you can redistribute it and/or -# modify it under the terms of the GNU General Public License 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. -# -# You should have received a copy of the GNU General Public License -# along with this program; if not, write to the Free Software -# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 -# USA. -# -# ---------------------------------------------------------------------- -# $Id$ -# ---------------------------------------------------------------------- - -function cli_checkActionArgument { - - # Check action value before making an absolute path from it. - if [[ $ACTIONVAL =~ '(\.\.(/)?)' ]];then - cli_printMessage "`gettext "The path provided can't be processed."`" 'AsErrorLine' - cli_printMessage "$(caller)" "AsToKnowMoreLine" - fi - if [[ ! $ACTIONVAL =~ '^[A-Za-z0-9\.:/-]+$' ]];then - cli_printMessage "`gettext "The path provided can't be processed."`" 'AsErrorLine' - cli_printMessage "$(caller)" "AsToKnowMoreLine" - fi - - # Re-define action value to build repository absolute path from - # repository top level on. As we are removing - # /home/centos/artwork/ from all centos-art.sh output (in order to - # save horizontal output space), we need to be sure that all - # strings begining with trunk/..., branches/..., and tags/... use - # the correct absolute path. That is, you can refer trunk's - # entries using both /home/centos/artwork/trunk/... or just - # trunk/..., the /home/centos/artwork/ part is automatically added - # here. - if [[ $ACTIONVAL =~ '^(trunk|branches|tags)' ]];then - ACTIONVAL=/home/centos/artwork/$ACTIONVAL - fi - - # Re-define action value to build repository absolute path from - # repository relative paths. This let us to pass repository - # relative paths as action value. Passing relative paths as - # action value may save us some typing; specially if we are stood - # a few levels up from the location we want to refer to as action - # value. There is no need to pass the absolute path to it, just - # refere it relatively. - if [[ -d ${ACTIONVAL} ]];then - - # Add directory to the top of the directory stack. - pushd "$ACTIONVAL" > /dev/null - - # Check directory existence inside the repository. - if [[ $(pwd) =~ '^/home/centos/artwork/.+$' ]];then - # Re-define action value using absolute path. - ACTIONVAL=$(pwd) - else - cli_printMessage "`gettext "The location provided is not valid."`" 'AsErrorLine' - cli_printMessage "$(caller)" 'AsToKnowMoreLine' - fi - - # Remove directory from the directory stack. - popd > /dev/null - - elif [[ -f ${ACTIONVAL} ]];then - - # Add directory to the top of the directory stack. - pushd "$(dirname $ACTIONVAL)" > /dev/null - - # Check directory existence inside the repository. - if [[ $(pwd) =~ '^/home/centos/artwork/.+$' ]];then - # Re-define action value using absolute path. - ACTIONVAL=$(pwd)/$(basename $ACTIONVAL) - else - cli_printMessage "`gettext "The location provided is not valid."`" 'AsErrorLine' - cli_printMessage "$(caller)" 'AsToKnowMoreLine' - fi - - # Remove directory from the directory stack. - popd > /dev/null - - else - - # Check repository url. - if [[ ! $ACTIONVAL =~ '^(https|http)://projects.centos.org/svn/artwork/.+$' ]];then - cli_printMessage "`gettext "The location provided is not valid."`" 'AsErrorLine' - cli_printMessage "$(caller)" 'AsToKnowMoreLine' - fi - fi - -}