Cisco ASA and non-std SSH – the reprise
Any readers of this blog will possibly remember that I compared a few different vendors’ firewalls to see how easy it was to configure them to block ssh access when it was running on the non-standard port of tcp 80 which is typically used by http. (This is a little contrived because anyone trying to get out like this would probably use tcp 443 giving us the complication of encryption but it gives a feel for how easy it is to configure application inspection)
During this process I had problems with the Cisco ASA and disqualified it from my trial. However, would you believe I have had countless emails asking me when I would give it a second chance? No, neither would I. Nonetheless I decided to revist the ASA.
This is the topology:
data:image/s3,"s3://crabby-images/50fb8/50fb87451897e4c6e01cb31d429b79cc223f52d7" alt=""
The stages of the test will follow the trials conducted earlier. We will set up the firewall with a rule allowing port 80 or http traffic out from the DMZ and stand up a server running ssh on port 80 (ssh.labtinker.net). We will then see if we can ssh out through the firewall on port 80 from the linux server running on the DMZ.
I can report that with a rule allowing http (amongst other things but not ssh!)…
data:image/s3,"s3://crabby-images/d33d9/d33d986e32de058d94748b997e86a6312b0dc947" alt=""
I was able to connect straight away to my ssh server.
data:image/s3,"s3://crabby-images/d4923/d49233b2f4a0b83129c0a1dc4f8c0f6383c6141b" alt=""
I knew the ASA already did some from of application inspection out of the box using its default global service policy but checking this out I saw that it didn’t cover http
data:image/s3,"s3://crabby-images/d7a71/d7a71a43ad935bb2f64a8df0dd1ff3db25dced44" alt=""
I added ‘http’ to this policy
data:image/s3,"s3://crabby-images/13b82/13b826a43621a73adbeda4e274891f7c81dc7f02" alt=""
I then tried my ssh connection out on port 80 and it was still allowed…. I won’t bother with the visual evidence this time but obvioulsy the default http application inspection didn’t stop ssh.
I realised I was going to have to delve into modular policy framework which is what Cisco uses to do application inspection (amongst other things). I never found it hugely intuitive so I determined that I would satisfy myself that I could get it working before trying to use it to block ssh. I chose as a way of doing this allowing access to www.labtinker.net but blocking access to www.labtinker.co.uk; mainly because someone had already given an example of how to do something similar.
To avoid confusion, I deleted the default service policy (the joy of a lab – I would advise against this generally!!) then created a policy which would check the http host header for the presence of the text labtinker.net and only allow a connection if this was present…
data:image/s3,"s3://crabby-images/66eff/66eff3da4bc055f1a67ad531ba7dc5492df41c26" alt=""
I achieved this as follows…
data:image/s3,"s3://crabby-images/d0cc1/d0cc1cfa2bbabeb2d59101600cfd685746986cb8" alt=""
….a global rule service policy rule matching all http traffic…
data:image/s3,"s3://crabby-images/7d9f7/7d9f78bf78d3ad27aa10b972f5f8995301e9f41a" alt=""
data:image/s3,"s3://crabby-images/634b5/634b5c147d8e605abe40e778730b06af1d02963c" alt=""
data:image/s3,"s3://crabby-images/65acb/65acb8516d8f8a4662644c16bf95b42fd93cd481" alt=""
data:image/s3,"s3://crabby-images/dd95e/dd95e60c3564afa23fdd3404ed7da88943872f2b" alt=""
data:image/s3,"s3://crabby-images/710e8/710e83ccf72c40d108268691c547beb5b771cf96" alt=""
Which in class maps is defined as follows..
data:image/s3,"s3://crabby-images/c1b3a/c1b3a587eae0f5e71b96d36992d3472548876b31" alt=""
data:image/s3,"s3://crabby-images/67775/677759f55a53009435334264889ac4e7a09c1aee" alt=""
data:image/s3,"s3://crabby-images/99745/99745d349be927ebb9ae39871c43d30ea0f70ba9" alt=""
The CLI config for this being…
class-map type inspect http match-all class-http1
match not request header host regex urlallow1
class-map dmz-class
match port tcp eq www
class-map match-all
!
policy-map type inspect http policy-http1
parameters
class class-http1
drop-connection log
regex urlallow1 “labtinker\.net”
Which in action, is demonstrated by trying two curl commands from DMZ linux…
This is a curl connection to www.labtinker.net which shows the start of the successful HTTP GET
data:image/s3,"s3://crabby-images/1394d/1394d172943a275e4cab0b7574932270d71a3405" alt=""
…as logged going through the ASA…
data:image/s3,"s3://crabby-images/037fe/037fe8253540b12f807f961cf6ca996d17634750" alt=""
And now trying www.labtinker.co.uk
data:image/s3,"s3://crabby-images/42c53/42c533f9039f59f2c10abfa2a0391b0ebcb21737" alt=""
The connection is dropped by the inspection engine.
data:image/s3,"s3://crabby-images/37167/371675c827a5d33ec6cafcbb04a368408b371faf" alt=""
So I know that the ASA is inspecting my http connnection. However, it still allows my ssh connection through on port 80.
data:image/s3,"s3://crabby-images/e52ef/e52ef0b069325ba0f9b63c475bdc905716864d47" alt=""
Then, in here…
data:image/s3,"s3://crabby-images/5b282/5b282dedd8a221b81216fe3a2d2f4cc7e0c4d193" alt=""
I found this…
data:image/s3,"s3://crabby-images/67c39/67c399e42e0ccb23bace6301acd8ce9fc6e234fc" alt=""
…which had this….
data:image/s3,"s3://crabby-images/f3be3/f3be3515312cd442aca61173e13e0b59ed8939d4" alt=""
So I ticked it… and ASDM generated these CLI commands…
data:image/s3,"s3://crabby-images/9f83b/9f83bd68eb7c37a36f5c03b9f7fa84cb46452067" alt=""
That had to be it, didn’t it? Ladies and Gentlemen, it was!!
data:image/s3,"s3://crabby-images/511d0/511d035f88cb95c89f09471f90097f011e2a5d2f" alt=""
And in the logs…
data:image/s3,"s3://crabby-images/f719e/f719e89912ad48620a81c8c1b44b0af8a832b95d" alt=""
So the ASA can be configured to drop non-http traffic on port 80. I then decided to remove the http inspection checking the header text so I could allow all http traffic out but block ssh.. (and presumably anything else not http)
data:image/s3,"s3://crabby-images/30ca0/30ca09dbccac3615a3937748046fe9ed73b0a0f1" alt=""
…and I could make curl connections to www.labtinker.net and www.labtinker.co.uk and any website but I still could not ssh out on this port 80… result!
data:image/s3,"s3://crabby-images/456ba/456ba6561fa8300efa3328c3feaac75519d0d635" alt=""
I apologise for taking such a circuitous route to find out how to do what I set out to but I genuinely couldn’t find much in the way of guidance so I offer this up… as an untidy but successful example.#
I guess the ASA is creaking as it’s not an NG firewall and that this kind of thing would be done in Cisco’s FMC / FTD offfering. I’ve been out of the Cisco space for a while and it doesn’t seem that easy to get hold of an eval VM outside of a contract to play around with this… but I’ll hopefully be getting up to speed on this area fairly shortly as my new role calls for it!