Last updated
Last updated
Pass the ticket is a technique that allows you to add Kerberos tickets to an existing logon session (LUID) that you have access to, or a new one you create. Accessing a remote resource will then allow that authentication to happen via Kerberos.
For this, we can leverage the TGT we extracted from jking's logon session on Workstation 2.
The first step is to create a blank, "sacrificial" logon session that we can pass the TGT into. We do this because a logon session can only hold a single TGT at a time. If we passed jking's TGT into the LUID for bfarmer, it would erase bfarmer's TGT and cause all sorts of authentication issues for the user.
Creating a new logon session and passing tickets into sessions other than your own requires elevated privileges.
Rubeus' createnetonly
command will start a new hidden process of our choosing, using the API.
This also creates a new LUID. It will have no tickets inside, so won't be visible with triage
just yet. The next step is to pass the TGT into this new LUID using the Rubeus ptt
command. Where the /luid
is the new LUID we just created and /ticket
is the base64 encoded ticket we previously extracted.
Rubeus triage will now show jking's TGT inside this LUID.
The final step is to impersonate the process that we created with createnetonly using Cobalt Strike's steal_token
command. At a minimum, this requires the PID of the target process, which in this example, is 4748. We'll then be able to access the remote machine.
As before, use rev2self
to drop the impersonation. To destroy the logon session we created, simply kill the process with the kill
command.
Rubeus triage will no longer show the logon session.
OPSEC By default, Rubeus will use a random username, domain and password with CreateProcessWithLogonW, which will appear in the associated 4624 logon event. The "Suspicious Logon Events" saved search will show 4624's where the TargetOutboundDomainName is not an expected value.