mirror of
				https://github.com/Telecominfraproject/wlan-lanforge-scripts.git
				synced 2025-10-30 18:27:53 +00:00 
			
		
		
		
	Version of lf_wifi_fire that creates EAP-TLS 802.1x authenticated station
This commit is contained in:
		
							
								
								
									
										234
									
								
								lf_wifi_dot1x.bash
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										234
									
								
								lf_wifi_dot1x.bash
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,234 @@ | ||||
| #!/bin/bash | ||||
|  | ||||
| #  This script is an attempt to simplify the creation of stations and connections for said stations. | ||||
| #  One UDP connection will be created for each station. | ||||
| #  The number of stations, station SSID, encryption type and passphrase, number of packets to send, and transmit rates | ||||
| #  can all be configured with the below options. | ||||
| #  Required values are SSID, radio, and upstream port. | ||||
| #  Note: The upstream port will be designated to Endpoint A and station to Endpoint B. | ||||
| #  -m   Manager IP or hostname. | ||||
| #  -r   Resource number. | ||||
| #  -w   Which radio to use i.e. wiphy0 wiphy1 etc. | ||||
| #  -n   Number of stations to create. | ||||
| #  -s   SSID for stations. | ||||
| #  -e   Encryption type: open|wep|wpa|wpa2. | ||||
| #  -k   Passphrase for when AP is encrypted. | ||||
| #  -a   The upstream port to which station(s) will connect. | ||||
| #  -A   Transmit rate from upstream port. | ||||
| #  -B   Transmit rate from station. | ||||
| #  -p   Number of default UDP sized packets to send. | ||||
| #  -h   Help information. | ||||
|  | ||||
| #  Example usage: | ||||
| #  ./lf_wifi_fire.bash -m lf0350-1234 -r 1 -w wiphy0 -n 40 -s test-SSID -e wpa2 -k hello123 -a eth1 -A 56000 -B 2000000 -p 10000 | ||||
|  | ||||
| set -e | ||||
| #set -u | ||||
| set -o pipefail | ||||
|  | ||||
| clilog="--log_cli /tmp/clilog.txt" | ||||
|  | ||||
| #default values | ||||
| mgr=localhost | ||||
| resource=1 | ||||
| num_stas=40 | ||||
| num_packets=Infinite | ||||
| encryption=open | ||||
| passphrase='[BLANK]' | ||||
| rate_A=1000000 | ||||
| rate_B=1000000 | ||||
|  | ||||
| #other variables | ||||
| first_sta=100 | ||||
| flag_radio=false | ||||
| flag_ssid=false | ||||
| flag_port=false | ||||
|  | ||||
| show_help="This script is an attempt to simplify the creation of stations and connections for said stations. | ||||
| One UDP connection will be created for each station. | ||||
| The number of stations, station SSID, encryption type and passphrase, number of packets to send, and transmit rates | ||||
| can all be configured with the below options. | ||||
| Required values are SSID, radio, and upstream port. | ||||
| Note: The upstream port will be designated to Endpoint A and station to Endpoint B. | ||||
| -m   Manager IP or hostname. | ||||
| -r   Resource number. | ||||
| -w   Which radio to use i.e. wiphy0 wiphy1 etc. | ||||
| -n   Number of stations to create. | ||||
| -s   SSID for stations. | ||||
| -e   Encryption type: open|wep|wpa|wpa2. | ||||
| -k   Passphrase for when AP is encrypted. | ||||
| -a   The upstream port to which station(s) will connect. | ||||
| -A   Transmit rate from upstream port. | ||||
| -B   Transmit rate from station. | ||||
| -p   Number of default UDP sized packets to send. | ||||
| -h   Help information. | ||||
|  | ||||
| Example usage: | ||||
| ./lf_wifi_fire.bash -m lf0350-1234 -r 1 -w wiphy0 -n 40 -s test-SSID -e wpa2 -k hello123 -a eth1 -A 56000 -B 2000000 -p 10000" | ||||
|  | ||||
| while getopts 'm:r:n:p:a:e:k:w:s:A:B:h' OPTION; do | ||||
|    case "$OPTION" in | ||||
|       m) | ||||
|         #manager | ||||
|         mgr="$OPTARG" | ||||
|         ;; | ||||
|       r) | ||||
|         #resource | ||||
|         resource="$OPTARG" | ||||
|         ;; | ||||
|       n) | ||||
|         #num stations | ||||
|         num_stas="$OPTARG" | ||||
|         ;; | ||||
|       p) | ||||
|         #packets | ||||
|         num_packets="$OPTARG" | ||||
|         ;; | ||||
|       a) | ||||
|         #upstream port | ||||
|         flag_port=true | ||||
|         port_A="$OPTARG" | ||||
|         ;; | ||||
|       e) | ||||
|         #encryption | ||||
|         encryption="$OPTARG" | ||||
|         ;; | ||||
|       k) | ||||
|         #encryption passphrase | ||||
|         passphrase="$OPTARG" | ||||
|         ;; | ||||
|       w) | ||||
|         #radio | ||||
|         flag_radio=true | ||||
|         radio="$OPTARG" | ||||
|         ;; | ||||
|       s) | ||||
|         #ssid | ||||
|         flag_ssid=true | ||||
|         ssid="$OPTARG" | ||||
|         ;; | ||||
|       A) | ||||
|         #transmit rate for endpoint A | ||||
|         rate_A="$OPTARG" | ||||
|         ;; | ||||
|       B) | ||||
|         #transmit rate for endpoint B | ||||
|         rate_B="$OPTARG" | ||||
|         ;; | ||||
|       h) | ||||
|         #send help message | ||||
|         echo "$show_help" | ||||
|         exit 1 | ||||
|         ;; | ||||
| esac | ||||
| done | ||||
| shift "$(($OPTIND -1))" | ||||
|  | ||||
| #check for required getopts | ||||
| if [ "$flag_ssid" = false ] || [ "$flag_radio" = false ] || [ "$flag_port" = false ] ; | ||||
| then | ||||
|    echo "Please provide at minimum the upstream port (-a), ssid (-s), and radio (-w). Run the script with -h for more information." | ||||
|    exit 1 | ||||
| fi | ||||
|  | ||||
| echo "Deleting old stations." | ||||
| ./lf_associate_ap.pl --mgr $mgr --resource $resource $clilog --action del_all_phy --port_del $radio | ||||
|  | ||||
| ./lf_firemod.pl --mgr $mgr --resource $resource --quiet yes --action do_cmd $clilog \ | ||||
|  --cmd "nc_show_ports 1 $resource all 1" &>/dev/null | ||||
|  | ||||
| sleep 2 | ||||
|  | ||||
| echo "Creating new stations." | ||||
| ./lf_associate_ap.pl --mgr $mgr --resource $resource $clilog \ | ||||
|  --ssid $ssid --security $encryption --passphrase $passphrase \ | ||||
|  --num_stations $num_stas --first_sta "sta$first_sta" \ | ||||
|  --first_ip DHCP --radio $radio --action add --xsec use-dot1x | ||||
|  | ||||
|  | ||||
|  | ||||
| sleep 2 | ||||
|  | ||||
| key_mgt="WPA-EAP" | ||||
| pairwise="CCMP" | ||||
| group="CCMP" | ||||
| psk=NA | ||||
| key=NA | ||||
| ca_cert="/home/lanforge/apu2-a-ca.pem" | ||||
| eap="TLS" | ||||
| identity="lanforge@lanforge.com" | ||||
| anon_id=NA | ||||
| phase1=NA | ||||
| phase2=NA | ||||
| eap_passwd=eap_passwd | ||||
| pin=NA | ||||
| pac_file=NA | ||||
| private_key="/home/lanforge/apu2-a-client.p12" | ||||
| pk_passwd="lanforge" | ||||
| hessid=NA | ||||
| realm=NA | ||||
| client_cert=NA | ||||
| imsi=NA | ||||
| milenage=NA | ||||
| domain=NA | ||||
| roaming_consortium=NA | ||||
| venue_group=NA | ||||
| venue_type=NA | ||||
| network_type=NA | ||||
| ipaddr_type_avail=NA | ||||
| network_auth_type=NA | ||||
| anqp_3gpp_cell_net=NA | ||||
|  | ||||
| for n in `seq $first_sta $(($first_sta -1 + $num_stas))` ; do | ||||
|   ./lf_firemod.pl --mgr $mgr --resource $resource $clilog --action do_cmd --cmd \ | ||||
|    "set_wifi_extra 1 $resource sta$n $key_mgt $pairwise $group $psk $key $ca_cert $eap $identity $anon_id $phase1 $phase2 $eap_passwd $pin $pac_file $private_key $pk_passwd $hessid $realm $client_cert" | ||||
| done | ||||
|  | ||||
| function new_cx(){ | ||||
|    local cx=$1 | ||||
|    local portA=$2 | ||||
|    local portB=$3 | ||||
|  | ||||
|    ./lf_firemod.pl --mgr $mgr --resource $resource $clilog \ | ||||
|     --action create_endp --endp_name "$cx-A" --port_name $portA \ | ||||
|     --speed $rate_A --endp_type lf_udp --report_timer 1000 | ||||
|  | ||||
|    ./lf_firemod.pl --mgr $mgr --resource $resource $clilog \ | ||||
|     --action create_endp --endp_name "$cx-B" --port_name $portB \ | ||||
|     --speed $rate_B --endp_type lf_udp --report_timer 1000 | ||||
|  | ||||
|    ./lf_firemod.pl --mgr $mgr $clilog  --action create_cx --cx_name $cx --cx_endps "$cx-A,$cx-B" --report_timer 1000 | ||||
|  | ||||
|    ./lf_firemod.pl --mgr $mgr --resource $resource $clilog --quiet yes --action do_cmd \ | ||||
|     --cmd "set_endp_details $cx-A NA NA NA $num_packets" &>/dev/null | ||||
|  | ||||
|    ./lf_firemod.pl --mgr $mgr --resource $resource $clilog --quiet yes --action do_cmd \ | ||||
|     --cmd "set_endp_details $cx-B NA NA NA $num_packets" &>/dev/null | ||||
| } | ||||
|  | ||||
| # Delete all connections and endpoints that have 'bg' in the name | ||||
| echo "Deleting old connections." | ||||
| cx_array=( `./lf_firemod.pl --mgr $mgr --resource $resource $clilog --action list_cx | awk '/bg/ { print $ 2 }' | sed 's/,$//'`  ) | ||||
| for i in "${cx_array[@]}" | ||||
|    do | ||||
|       : | ||||
|        ./lf_firemod.pl --mgr $mgr --resource $resource $clilog --action delete_cx --cx_name $i | ||||
|        ./lf_firemod.pl --mgr $mgr --resource $resource $clilog --action delete_endp --endp_name "$i-A" | ||||
|        ./lf_firemod.pl --mgr $mgr --resource $resource $clilog --action delete_endp --endp_name "$i-B" | ||||
|    done | ||||
|  | ||||
| ./lf_firemod.pl --mgr $mgr --resource $resource $clilog --quiet yes --action do_cmd --cmd 'nc_show_endpoints all' &>/dev/null | ||||
|  | ||||
| sleep 5 | ||||
|  | ||||
| echo "Creating new connections." | ||||
| last_sta=$((first_sta + num_stas - 1)) | ||||
| for i in `seq $first_sta $last_sta`; do | ||||
|    new_cx bg$i $port_A sta$i | ||||
| done | ||||
|  | ||||
| echo "All stations and connections have been created." | ||||
|  | ||||
| /lf_firemod.pl --mgr $mgr --resource $resource $clilog --quiet yes --action do_cmd --cmd 'nc_show_endpoints all' &>/dev/null | ||||
|  | ||||
| # | ||||
		Reference in New Issue
	
	Block a user
	 Jed Reynolds
					Jed Reynolds