Server IP : 213.176.29.180  /  Your IP : 3.144.48.228
Web Server : Apache
System : Linux 213.176.29.180.hostiran.name 4.18.0-553.22.1.el8_10.x86_64 #1 SMP Tue Sep 24 05:16:59 EDT 2024 x86_64
User : webtaragh ( 1001)
PHP Version : 7.4.33
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON
Directory (0755) :  /etc/binfmt.d/../bash_completion.d/

[  Home  ][  C0mmand  ][  Upload File  ]

Current File : //etc/binfmt.d/../bash_completion.d/authselect-completion.sh
#
#    Authors:
#        Tomas Halman <thalman@redhat.com>
#
#    Copyright (C) 2019 Red Hat
#
#    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 3 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, see <http://www.gnu.org/licenses/>.
#
#
# provides autocompletion for authselect command
#

_authselect_completions()
{
    local COMMANDS
    local command
    local possibleopts

    function is_valid_command() {
        local cmd

        for cmd in "${COMMANDS[@]}"; do
            if [[ "$cmd" = "$1" ]]; then
                return 0
            fi
        done
        return 1
    }

    function get_command() {
        local opt

        if [[ $COMP_CWORD -lt 2 ]] ; then
            return
        fi
        for opt in "${COMP_WORDS[@]:0:$COMP_CWORD}"; do
            if is_valid_command "$opt"; then
                echo "$opt"
                return
            fi
        done
    }

    function get_command_param() {
        local havecmd=0
        local len=${#COMP_WORDS[@]}-1

        if [[ "$command" = "" ]]; then
            return
        fi
        havecmd=0
        for (( i=0; i<$len; i++ )); do
            if [[ "$havecmd" = "1" ]] ; then
                if [[ "${COMP_WORDS[$i]}" =~ ^[-=] || "${COMP_WORDS[$i-1]}" = "=" ]] ; then
                    continue
                fi
                echo "${COMP_WORDS[$i]}"
                return
            fi
            if [[ "${COMP_WORDS[$i]}" = "$command" ]] ; then
                havecmd=1
            fi
        done
    }

    function get_profile() {
        case "$command" in
        select|show|requirements|test|list-features)
            get_command_param
            ;;
        enable-feature|disable-feature)
            authselect current 2>/dev/null | head -n1 | cut -d" " -f3
            ;;
        esac
    }

    function get_command_keywords() {
        local profile

        case "$command" in
            select|requirements|test)
                profile="$(get_profile)"
                if [[ "$profile" != "" ]] ; then
                    authselect list-features "$profile" 2>/dev/null
                fi
                ;;
        esac
    }

    function get_command_options() {
        if [[ "${COMP_WORDS[$COMP_CWORD]}" =~ ^- ]] ; then
            case "$command" in
                select)
                    echo "--force --quiet --nobackup --backup="
                    ;;
                apply-changes|disable-feature)
                    echo "--backup="
                    ;;
                enable-feature)
                    echo "--backup= --quiet"
                    ;;
                current|backup-list)
                    echo "--raw"
                    ;;
                create-profile)
                    echo "--vendor --base-on= --base-on-default" \
                         "--symlink-meta --symlink-nsswitch --symlink-pam" \
                         "--symlink-dconf --symlink="
                    ;;
                test)
                    echo "--all --nsswitch --system-auth --password-auth" \
                         "--smartcard-auth --fingerprint-auth --postlogin" \
                         "--dconf-db --dconf-lock"
                    ;;
            esac
        fi
    }

    function get_global_options() {
        if [[ "${COMP_WORDS[$COMP_CWORD]}" =~ ^- ]] ; then
            echo "--debug --trace --warn --help"
        fi
    }

    function get_option_params() {
        local opt

        if [[ $COMP_CWORD -gt 2 && "${COMP_WORDS[$COMP_CWORD-1]}" = "=" ]] ; then
            opt="${COMP_WORDS[$COMP_CWORD-2]}"
        else
            if [[ $COMP_CWORD -gt 1 ]] ; then
                opt="${COMP_WORDS[$COMP_CWORD-1]}"
            fi
        fi
        case "$opt" in
        --base-on)
            authselect list 2>/dev/null | cut -d" " -f2
            ;;
        --symlink)
            echo "dconf-db dconf-locks fingerprint-auth nsswitch.conf" \
                 "password-auth postlogin smartcard-auth system-auth" \
                 "README REQUIREMENTS"
            ;;
        esac

    }

    function get_command_params() {
        local i
        local profile

        if [[ "$command" = "" ]]; then
            return
        fi
        for (( i=$COMP_CWORD-1; i>1; i-- )); do
            opt="${COMP_WORDS[$i]}"
            if [[ "$opt" = "$command" ]] ; then
                break
            fi
            if [[ "$opt" =~ ^[-=] || "${COMP_WORDS[$i-1]}" = "=" ]] ; then
                continue
            fi
            return
        done
        case "$command" in
        select|show|requirements|test|list-features)
            authselect list 2>/dev/null | cut -d" " -f2
            ;;
        backup-remove|backup-restore)
            authselect backup-list 2>/dev/null | cut -d" " -f1
            ;;
        enable-feature|disable-feature)
            profile="$(get_profile)"
            if [[ "$profile" != "" ]] ; then
                authselect list-features "$profile" 2>/dev/null
            fi
            ;;
        esac
    }

    COMMANDS=(select apply-changes list list-features show requirements current
              check test enable-feature disable-feature create-profile
              backup-list backup-remove backup-restore)

    possibleopts="$(get_option_params)"
    if [[ "$possibleopts" != "" ]]; then
        if [[ "${COMP_WORDS[$COMP_CWORD]}" = "=" ]]; then
            COMPREPLY=($(compgen -W "$possibleopts"))
        else
            COMPREPLY=($(compgen -W "$possibleopts" -- "${COMP_WORDS[$COMP_CWORD]}"))
        fi
    else
        command="$(get_command)"
        if [[ "$command" = "" ]]; then
            possibleopts="$(get_global_options) ${COMMANDS[@]}"
        else
            possibleopts="$(get_global_options) $(get_command_params) $(get_command_keywords) $(get_command_options)"
        fi
        COMPREPLY=($(compgen -W "$possibleopts" -- "${COMP_WORDS[$COMP_CWORD]}"))
    fi
}

complete -F _authselect_completions authselect