Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allow DEB and RPM packages to supply an uninstall token when upgrading with Elastic Defend installed #6394

Open
cmacknz opened this issue Dec 18, 2024 · 3 comments
Assignees
Labels
Team:Elastic-Agent-Control-Plane Label for the Agent Control Plane team

Comments

@cmacknz
Copy link
Member

cmacknz commented Dec 18, 2024

Describe the enhancement:

For Fleet managed agents that are running Elastic Defend, upgrading the RPM or DEB packages does not send a signed upgrade action to Defend which is what allows Defend to upgrade without believing it is being tampered with. The tamper protection feature of Defend is based on all operations requiring a digital signature signed by a private key in Kibana. There is no way to provide a signed token for DEB or RPM upgrades, so Defend legitimately believes it was being tampered with and orphaned from agent here.

Specifically using the CLI skips this block

if h.tamperProtectionFn() {
// Find inputs that want to receive UPGRADE action
// Endpoint needs to receive a signed UPGRADE action in order to be able to uncontain itself
state := h.coord.State()
ucs := findMatchingUnitsByActionType(state, a.Type())
if len(ucs) > 0 {
h.log.Debugf("handlerUpgrade: proxy/dispatch action '%+v'", a)
err := notifyUnitsOfProxiedAction(ctx, h.log, action, ucs, h.coord.PerformAction)
h.log.Debugf("handlerUpgrade: after action dispatched '%+v', err: %v", a, err)
if err != nil {
return err
}
} else {
// Log and continue
h.log.Debugf("No components running for %v action type", a.Type())
}
}

To make the upgrade command work with tamper protection properly we'd have to allow it to accept an uninstall token to allow endpoint to unprotect itself for a CLI upgrade.

Describe a specific use case for the enhancement or feature:

Upgrading an Elastic Agent installed with either the RPM or DEB packages when Elastic Defend is used. Without this change, the only way to upgrade in this situation is to temporarily disable tamper protection.

What is the definition of done?

  • Tests exists proving that the RPM and DEB packages can be upgraded when Elastic Defend is installed without disabling tamper protection.
  • These packages types can ideally indicate to users that they should supply an uninstall token when defend is installed.
  • The documentation for the RPM and DEB packages is updated to indicate that an uninstall token is required in this situation.
@cmacknz cmacknz added the Team:Elastic-Agent-Control-Plane Label for the Agent Control Plane team label Dec 18, 2024
@elasticmachine
Copy link
Contributor

Pinging @elastic/elastic-agent-control-plane (Team:Elastic-Agent-Control-Plane)

@intxgo
Copy link
Contributor

intxgo commented Dec 23, 2024

@cmacknz what about msi and Tamper Protection?

I forgot, msi accepts INSATLLARGS, example here https://discuss.elastic.co/t/installing-elastic-agent-with-gpo/364659/

Furthermore, the variables table of msi can be edited, so we can embed any argument. @gabriellandau already made a nice PS script https://gist.github.com/gabriellandau/b838192eefd81fc53816f4e973a026d0

@cmacknz
Copy link
Member Author

cmacknz commented Dec 30, 2024

We don't support upgrading via the msi package today, only installing, so I wouldn't expect to have to support an uninstall token for that purpose there unless that changes.

There is INSTALLARGS for uninstalling while installing.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Team:Elastic-Agent-Control-Plane Label for the Agent Control Plane team
Projects
None yet
Development

No branches or pull requests

4 participants