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

[feature] Implement device deactivation and reactivation #625

Closed
nemesifier opened this issue Apr 7, 2022 · 0 comments · Fixed by #840
Closed

[feature] Implement device deactivation and reactivation #625

nemesifier opened this issue Apr 7, 2022 · 0 comments · Fixed by #840

Comments

@nemesifier
Copy link
Member

nemesifier commented Apr 7, 2022

The details of this shall be discussed further before proceeding.

We shall implement two new admin actions and related model methods which perform the following:

1. Deactivation

  • we shall make all the field of a deactivated device readonly
  • if the device has any related OpenVPN template with certificates, the certificates shall be flagged as revoked
  • removes any config and template from the device, ensuring the revoked certificates do not get deleted (because we need those to be in the CRL)
  • sets the config status to deactivating (this is a new status)
  • once the config is applied by the agent (we must make sure it's deactivated) the config status should be set to "deactivated" instead of "modified"
  • once the config is set to deactivated, the controller HTTP API should return 404 for these devices, so that the agent stops asking for the checksum
  • I think we should hide the delete button of the admin and show "deactivate" instead, we could show the delete button only if the config status is "deactivated" or if the device does not have a config object
  • we should add the deactivate admin list action, if we can add it before the delete action it's better
  • the admin action which deactivates multiple items at once must deal with the case in which one or multiple devices are already deactivated in a graceful way, informing the user and without failing
  • ensure we emit a signal when this happens, I believe a config status change is emitted but let's double check (so we can listen for this event in other modules)
  • we will also need to update the API to prevent changing any details on the deactivated devices

2. Activation

  • add an admin action which sets the config status to applied;
    it must deal with the case in which one or multiple devices are already activated in graceful way, informing the user and without failing

Why this feature?

Right now deleting a device does not remove the configuration from a device, so a device which gets deleted from OpenWISP Controller can still potentially connect to the configured VPNs.

On the OpenVPN side, we must recommend configuring the CRL (needs to be downloaded periodically from OpenWISP and when a change is detected the VPN conf should be reloaded).

Related to openwisp/openwisp-monitoring#445.

@nemesifier nemesifier changed the title [feature] Implement device deactivation [feature] Implement device deactivation and reactivation Feb 6, 2024
nemesifier added a commit that referenced this issue Nov 19, 2024
Closes #625
Closes #849

* [feature] Do not delete related Certs when device is deactivated
* [feature] Set device status to deactivated if current status is deactivating
* [feature] Return 404 checksum for deactivated devices
* [feature] Added activate and deactivate button on the device page
* [feature] Added "config_deactivating" signal
* [change] Show delete action after deactivate action
* [feature] Emit device_deactivated signal when device is deactivated
* [fix] Don't show any extra form on deactivated devices
* [change] Clear management IP after the device is deactivated
* [change] Added API endpoints for activating/deactivating device
* [change] Updated device delete API endpoint
* [change] Disable API operations on deactivated devices
* [feature] Added "device_activated" signal
* [docs] Updated docs
* [fix] Don't allow PUT/PATCH request for deactivated device

---------

Co-authored-by: Federico Capoano <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Development

Successfully merging a pull request may close this issue.

1 participant