Code Update
This commit is contained in:
		
							
								
								
									
										5
									
								
								src/commands/auto.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								src/commands/auto.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,5 @@
 | 
			
		||||
wx-auto(){
 | 
			
		||||
    wx-ssh-config-sync
 | 
			
		||||
    wx-ssh-keys-sync
 | 
			
		||||
    wx-ssh-sign
 | 
			
		||||
}
 | 
			
		||||
@@ -8,11 +8,22 @@ Usage: $0 COMMAND [OPTIONS]
 | 
			
		||||
 | 
			
		||||
Common Commands:
 | 
			
		||||
  init       Init
 | 
			
		||||
  help       Help
 | 
			
		||||
  ssh        SSH
 | 
			
		||||
    config      Config
 | 
			
		||||
      edit        Edit
 | 
			
		||||
      save        Save
 | 
			
		||||
      sync        Sync
 | 
			
		||||
    keys        Keys
 | 
			
		||||
      generate    Generate
 | 
			
		||||
      delete      Delete
 | 
			
		||||
      save        Save
 | 
			
		||||
      sync        Sync
 | 
			
		||||
    sign        Certificates
 | 
			
		||||
 | 
			
		||||
Management Commands:
 | 
			
		||||
  auto       Auto
 | 
			
		||||
  login      Login
 | 
			
		||||
  settings   Settings
 | 
			
		||||
";
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -5,6 +5,8 @@ wx-infra(){
 | 
			
		||||
    echo "          >> Infra <<         "
 | 
			
		||||
    echo "------------------------------"
 | 
			
		||||
 | 
			
		||||
    INFRA_PATH="/home/cwchristerw/Desktop/Work in Progress/Programming/warengroup/infra"
 | 
			
		||||
 | 
			
		||||
    case $USER in
 | 
			
		||||
        cwchristerw)
 | 
			
		||||
            if [[ -z $1 ]]
 | 
			
		||||
@@ -17,12 +19,12 @@ wx-infra(){
 | 
			
		||||
                    then
 | 
			
		||||
                        echo "Tag Required"
 | 
			
		||||
                    else
 | 
			
		||||
                        cd "/home/cwchristerw/Desktop/Work in Progress/Programming/warengroup/infra"
 | 
			
		||||
                        cd "$INFRA_PATH"
 | 
			
		||||
                        ansible-playbook --vault-id warengroup@vault/warengroup playbooks/init.yml -t $2 $3 $4 $5 $6 $7 $8 $9
 | 
			
		||||
                        cd "$OLDPWD"
 | 
			
		||||
                    fi
 | 
			
		||||
                else
 | 
			
		||||
                    cd "/home/cwchristerw/Desktop/Work in Progress/Programming/warengroup/infra"
 | 
			
		||||
                    cd "$INFRA_PATH"
 | 
			
		||||
                    ansible-playbook --vault-id warengroup@vault/warengroup playbooks.yml -t $1 $2 $3 $4 $5 $6 $7 $8 $9
 | 
			
		||||
                    cd "$OLDPWD"
 | 
			
		||||
                fi
 | 
			
		||||
 
 | 
			
		||||
@@ -5,6 +5,9 @@ wx-ssh(){
 | 
			
		||||
        sign)
 | 
			
		||||
            wx-ssh-sign
 | 
			
		||||
            ;;
 | 
			
		||||
        keys)
 | 
			
		||||
            wx-ssh-keys $2 $3
 | 
			
		||||
            ;;
 | 
			
		||||
        config)
 | 
			
		||||
            wx-ssh-config $2
 | 
			
		||||
            ;;
 | 
			
		||||
 
 | 
			
		||||
@@ -19,8 +19,6 @@ wx-ssh-config(){
 | 
			
		||||
            wx-stop
 | 
			
		||||
            ;;
 | 
			
		||||
    esac
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
wx-ssh-config-edit(){
 | 
			
		||||
@@ -28,9 +26,15 @@ wx-ssh-config-edit(){
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
wx-ssh-config-save(){
 | 
			
		||||
    curl https://$VAULT_DOMAIN/v1/cli/data/$USER -X POST --header "X-Vault-Token: ${config["login",$ORG]}" -d "{ \"data\": { \"settings/ssh/config\": \"$(cat ~/.ssh/config | base64 -w 0)\" } }" -s &> /dev/null
 | 
			
		||||
    curl https://$VAULT_DOMAIN/v1/cli/data/$USER/settings/ssh/config -X POST --header "X-Vault-Token: ${config["login",$ORG]}" -d "{ \"data\": { \"data\": \"$(cat ~/.ssh/config | base64 -w 0)\" } }" -s &> /dev/null
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
wx-ssh-config-sync(){
 | 
			
		||||
    echo $(curl https://$VAULT_DOMAIN/v1/cli/data/$USER -X GET --header "X-Vault-Token: ${config["login",$ORG]}" -s | jq -r '.data.data["settings/ssh/config"]') | base64 -d > ~/.ssh/config 2>&1
 | 
			
		||||
    VAULT_STATUS=$(curl -s -o /dev/null -w "%{http_code}" https://$VAULT_DOMAIN/v1/cli/data/$USER/settings/ssh/config -X GET --header "X-Vault-Token: ${config["login",$ORG]}")
 | 
			
		||||
    if [[ $VAULT_STATUS -eq 200 ]]
 | 
			
		||||
    then
 | 
			
		||||
        echo $(curl https://$VAULT_DOMAIN/v1/cli/data/$USER/settings/ssh/config -X GET --header "X-Vault-Token: ${config["login",$ORG]}" -s | jq -r '.data.data.data') | base64 -d > ~/.ssh/config 2>&1
 | 
			
		||||
    else
 | 
			
		||||
        echo "Status: Config Required"
 | 
			
		||||
    fi
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										62
									
								
								src/commands/ssh/keys.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								src/commands/ssh/keys.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,62 @@
 | 
			
		||||
wx-ssh-keys(){
 | 
			
		||||
    echo "       >> SSH / Keys <<       "
 | 
			
		||||
    echo "------------------------------"
 | 
			
		||||
 | 
			
		||||
    case $1 in
 | 
			
		||||
        generate)
 | 
			
		||||
            wx-ssh-keys-sync $2
 | 
			
		||||
            wx-ssh-keys-generate $2
 | 
			
		||||
            wx-ssh-config-save $2
 | 
			
		||||
            ;;
 | 
			
		||||
        retrieve)
 | 
			
		||||
            wx-ssh-keys-retrieve $2
 | 
			
		||||
            ;;
 | 
			
		||||
        save)
 | 
			
		||||
            wx-ssh-keys-save $2
 | 
			
		||||
            ;;
 | 
			
		||||
        sync)
 | 
			
		||||
            wx-ssh-keys-sync $2
 | 
			
		||||
            ;;
 | 
			
		||||
        delete)
 | 
			
		||||
            wx-ssh-keys-remove $2
 | 
			
		||||
            ;;
 | 
			
		||||
        *)
 | 
			
		||||
            wx-ssh-keys-sync
 | 
			
		||||
            wx-stop
 | 
			
		||||
            ;;
 | 
			
		||||
    esac
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
wx-ssh-keys-generate(){
 | 
			
		||||
    if [[ ! -z $1 ]]
 | 
			
		||||
    then
 | 
			
		||||
        if [[ ! -f "$HOME/.ssh/keys/$1" ]]
 | 
			
		||||
        then
 | 
			
		||||
            ssh-keygen -t ed25519 -f $HOME/.ssh/keys/$1 -q -N "" -C "$USER" &> /dev/null
 | 
			
		||||
        fi
 | 
			
		||||
    fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
wx-ssh-keys-retrieve(){
 | 
			
		||||
    if [[ ! -z $1 ]]
 | 
			
		||||
    then
 | 
			
		||||
        VAULT_STATUS=$(curl -s -o /dev/null -w "%{http_code}" https://$VAULT_DOMAIN/v1/cli/data/$USER/settings/ssh/keys/$1 -X GET --header "X-Vault-Token: ${config["login",$ORG]}")
 | 
			
		||||
        if [[ $VAULT_STATUS -eq 200 ]]
 | 
			
		||||
        then
 | 
			
		||||
            echo $(curl https://$VAULT_DOMAIN/v1/cli/data/$USER/settings/ssh/keys/$1 -X GET --header "X-Vault-Token: ${config["login",$ORG]}" -s | jq -r '.data.data.private') | base64 -d > ~/.ssh/keys/$1 2>&1
 | 
			
		||||
            echo $(curl https://$VAULT_DOMAIN/v1/cli/data/$USER/settings/ssh/keys/$1 -X GET --header "X-Vault-Token: ${config["login",$ORG]}" -s | jq -r '.data.data.public') | base64 -d > ~/.ssh/keys/$1.pub 2>&1
 | 
			
		||||
        else
 | 
			
		||||
            echo "Status: Key Required"
 | 
			
		||||
        fi
 | 
			
		||||
    fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
wx-ssh-keys-save(){
 | 
			
		||||
    if [[ ! -z $1 ]]
 | 
			
		||||
    then
 | 
			
		||||
        if [[ -f "$HOME/.ssh/keys/$1" ]]
 | 
			
		||||
        then
 | 
			
		||||
            curl https://$VAULT_DOMAIN/v1/cli/data/$USER/settings/ssh/keys/$1 -X POST --header "X-Vault-Token: ${config["login",$ORG]}" -d "{ \"data\": { \"private\": \"$(cat ~/.ssh/keys/$1 | base64 -w 0)\", \"public\": \"$(cat ~/.ssh/keys/$1.pub | base64 -w 0)\" } }" -s &> /dev/null
 | 
			
		||||
        fi
 | 
			
		||||
    fi
 | 
			
		||||
}
 | 
			
		||||
@@ -26,14 +26,14 @@ wx-ssh-sign-create(){
 | 
			
		||||
    PRINCIPALS=$2
 | 
			
		||||
    TTL=$3
 | 
			
		||||
 | 
			
		||||
    if [[ ! -f "$HOME/.ssh/keys/$NAME-ed25519" ]]
 | 
			
		||||
    if [[ ! -f "$HOME/.ssh/keys/$NAME" ]]
 | 
			
		||||
    then
 | 
			
		||||
        ssh-keygen -t ed25519 -f $HOME/.ssh/keys/$NAME-ed25519 -q -N "" &> /dev/null
 | 
			
		||||
        ssh-keygen -t ed25519 -f $HOME/.ssh/keys/$NAME -q -N "" -C "$USER" &> /dev/null
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    if [[ -f "$HOME/.ssh/keys/$NAME-ed25519" ]]
 | 
			
		||||
    if [[ -f "$HOME/.ssh/keys/$NAME" ]]
 | 
			
		||||
    then
 | 
			
		||||
        echo "$NAME/$ROLE"
 | 
			
		||||
        echo $(curl https://$VAULT_DOMAIN/v1/ssh/sign/$ROLE -X POST --header "X-Vault-Token: ${config["login",$ORG]}" -d "{ \"public_key\": \"$(cat $HOME/.ssh/keys/$NAME-ed25519.pub)\", \"valid_principals\": \"$PRINCIPALS,$USER\", \"ttl\": \"$TTL\" }" -s | jq -r '.data.signed_key') > ~/.ssh/keys/$NAME-ed25519.sig 2>&1
 | 
			
		||||
        echo $(curl https://$VAULT_DOMAIN/v1/ssh/sign/$ROLE -X POST --header "X-Vault-Token: ${config["login",$ORG]}" -d "{ \"public_key\": \"$(cat $HOME/.ssh/keys/$NAME.pub)\", \"valid_principals\": \"$PRINCIPALS,$USER\", \"ttl\": \"$TTL\" }" -s | jq -r '.data.signed_key') > ~/.ssh/keys/$NAME.sig 2>&1
 | 
			
		||||
    fi
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user