That did it, thanks for the help!!
Hi @petedykinga
I created a script for this and I run it inside the 'Terminal' connection of Royal TSX.
The address is taken from the 'Computer Name':
The password is taken from the 'Credentials' section.
And the script is placed in the 'Custom Commands' section:
The number of the Group Name (in case you have to select a group upon connecting) is taken from 'Custom Field 1' under 'Custom Fields'.
The script also asks you for a 2FA password in case you need to enter one.
The script also checks if there is already a Cisco AnyConnection VPN connection active. If true, it asks you whether you want to keep it or to disconnect.
#!/bin/zsh # title : ciscoVpnConnectAF 4 RoyalTSX.sh # description : This script will connect/disconnect VPN via Cisco AnyConnect with 2 Factor Authentication # author : Pascal Reutener [email protected] (a&f systems ag) # date : 2021-07-29 # version : 1.3 # usage : as custom command in Royal TSX # notes : The Number of the Group Name is taken from 'Custom Field 1' in Royal TSX # change history # 2020-03-19 | PRE : initial release # usage: ./ciscoVpnConnectAF.sh # 2020-03-20 | PRE : remove storage of credentials in clear text file # and instead use a variable # cosmetic changes # 2020-11-23 | PRE : added groupName variable # 2021-07-29 | PRE : Make group name/number dynamic (taken from 'CustomField1') #============================================================================== # configure var_uid=$EffectiveUsername$ var_pwd="$EffectivePassword$" var_ciscopath="/opt/cisco/anyconnect/bin" var_url=$URI$ # Group Name Number is taken from Royal TSX's Custom Field 1 var_groupNameNumber=$CustomField1$ connect_vpn() { # ask for second password echo " Please enter your OTP (One-Time Password) [ENTER]: " read -s var_passcode echo "\n Your One-Time Password is: $var_passcode \n\n" sleep 1 read -r -d '' var_logininfo <<- EOM $var_groupNameNumber $var_uid $var_pwd $var_passcode y EOM # connect $var_ciscopath/vpn -s <<< "$var_logininfo" connect $var_url } disconnect_vpn() { # disconnect $var_ciscopath/vpn disconnect } if /opt/cisco/anyconnect/bin/vpn status | grep Connected > /dev/null then echo "\n\n --> You have currently an active Cisco AnyConnect VPN connection.\n Do you want to disconnect?\n" select yn in "Yes" "No"; do case $yn in Yes ) disconnect_vpn; break;; No ) exit;; esac done else echo "\n\n --> You are currently NOT connected to $var_url" connect_vpn fi
Use at your own risk.
I hope this helps :)
—Best regards, Pascal
thanks for the reply, I can launch anyconnect with
/opt/cisco/anyconnect/bin/vpn -s connect vpn.soundtransit.org
in the command task but I cannot seem to be able to pass credentials for some reason
thanks for the reply, it appears that I can get it launched with:
in the command task but no matter how I try to pass in the creds, it just won't work. very odd
I think the command task statement has to be a single line. Try escaping the line endings?
Side note, I'd put the un/pw into Custom Properties so they can be easily changed and stored as Protected Fields. Then reference the $CustomProperties.name$ in the command task.
peted826
Can someone help me out, this works in terminal but I cannot set it up as a command task, I must be missing something??