#bastion (2019-04)
Discuss cloudposse/bastion
2019-04-02
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
@Paul Calabro has joined the channel
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
so erik, what are your thoughts on that?
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
(from the other channel)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So I thought of somewhat interesting way that a bad actor could bypass 2FA and I’m curious if this of interest to anyone else.
Scenario:
A bad actor compromises a machine in an untrusted network and quietly imposes these SSH settings on a user (or maybe they’re already in place b/c the user put them there for a reason– e.g. Ansible):
Host *
ControlMaster auto
ControlPath ~/.ssh/control-sockets/%C
ControlPersist yes
ServerAliveCountMax 5
ServerAliveInterval 60
…and then they wait for a user to connect to a host behind a bastion using 2FA. Once they do, the bad actor can then reuse that socket over and over again unbeknownst to the user to create sessions using that established connection. And then, course, pivot from there.
AFAIK, unless the bastion server modifies the MaxSessions
value, the default number of sessions is 10.
What are your thoughts on this?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So this would be a problem if the person’s workstation were compromised, no?
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
correct
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
with those kinds of settings in place, 2FA is only prompted on the first attempt
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
i was trying to think of an fun analogy and the best i could come up with is someone using a door wedge, haha
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
True it is like a door wedge
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
But the same thing exists with ssh agents
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
And sockets
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I am not averse to adding support to optionally disabling these settings
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Not sure what the default should be
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Often times, if the bad actor has control of the workstation all bets are off
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
yeah, those are all good points. i think the bastion is a little unique though in that you’re not just using your keys you’ve already added to the ssh agent. you’re also using push notification/sms/etc as that second factor…however, those gets bypass completely in this scenario.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yea true
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
What if we had some SSH server config profiles? E.g. configs with an extension
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
When starting the container we install one of those config profiles
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
yeah, i was thinking of that as well. i use configs in my docker compose file to mount files.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
One profile could be the one you suggest and maybe we make that default
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
that works
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
If you want to open a PR for that we will promptly review
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
i came across this accidentally and just thought i’d share b/c it seems like an interesting way to misuse an ssh feature
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
sweet! thanks!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yea makes sense
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
It’s a very popular repo and #1 search result
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So we should make it as locked down as possible
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
yeah, i’m a fan of this project
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Very cool!
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
it’s good stuff!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
If you have a chance to audit our scripts in that project, that would be appreciated as well
data:image/s3,"s3://crabby-images/58701/58701e2f62d4c3e353324bf4461442a2883bb17f" alt="Paul Calabro avatar"
data:image/s3,"s3://crabby-images/0f65e/0f65ea2592af59f1b2b9d017c2954c8559e16a0f" alt="Bruce avatar"
@Bruce has joined the channel
data:image/s3,"s3://crabby-images/aa7db/aa7db9888f7d39cd714fb5ad99038aed2c76a04a" alt="mahmoudamindolah avatar"
@mahmoudamindolah has joined the channel
data:image/s3,"s3://crabby-images/dc599/dc599f630ad796b13061bde9cc98c680735421b3" alt="Vidhi Virmani avatar"
@Vidhi Virmani has joined the channel
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
@kskewes has joined the channel
2019-04-03
data:image/s3,"s3://crabby-images/74dbd/74dbd66aeaa6424caa919eb1c16c6447340b3301" alt="rontron avatar"
@rontron has joined the channel
2019-04-05
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
@oscarsullivan_old has joined the channel
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Do you install Bastion on to every machine or just your one jump host that connects to your internal machines on private subnets?
data:image/s3,"s3://crabby-images/35a1d/35a1d9c272dc5018de448c065da1aeb0eaf29669" alt="xluffy avatar"
bastion is a jump host
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
Thanks that’s what I thoght
data:image/s3,"s3://crabby-images/6ecd9/6ecd98c1138dd1d43b568f2ce7f1a57b189a5d16" alt="oscarsullivan_old avatar"
here’s an updated readme PR @Erik Osterman (Cloud Posse) https://github.com/cloudposse/bastion/pull/43
What Improves readme with the following: Fixes missing backslash in example Makes assumptions easier to read Restructures into a much more readable format Makes shell examples easier to copy and p…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
( I am out of town, will check on Monday! Thanks @oscarsullivan_old )
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
@joshmyers has joined the channel
2019-04-10
data:image/s3,"s3://crabby-images/a46f4/a46f48168eba4ae607d400efa7634f3baf97531a" alt="mohamed.naseer avatar"
@mohamed.naseer has joined the channel