Releases: tumbl3w33d/nexus-oauth2-proxy-plugin
Release 3.4.0
Yet another great contribution by @herglotzmarco brings us the option to set stricter API token invalidation settings. You now have an additional attribute in the token invalidation task which sets an upper limit for how long a token can be active before an interactive refresh via UI is required.
In addition, the README has been enhanced with information about an alternative OAuth2 Proxy configuration which allows access using Bearer tokens.
If you have an SMTP server configured with Nexus you can now also let users get notified when their API tokens expired.
Release 3.3.0
Thanks to @herglotzmarco the logout button can now become functional. You need to enable a capability for it which allows configuring a custom logout URl, but that field is optional (OAuth2 Proxy users can leave it empty, Authentik users need to fill in the right URL).
Important note: If you encounter unexpected behavior concerning this logout functionality after updating, delete your browser cache. Nexus caches scripts for 30d.
Release 3.2.0
- Further cleanup and maintenance by @ChriFo 🙇
- Token reset on user profile page is now explicit (before it was happening by just visiting the page which was a little awkward), contributed by @herglotzmarco
Thank you for your contributions everybody, keep 'em coming! 🤩
Release 3.1.1
This is a bugfix release for a path issue explained here.
Release 3.1.0
Mostly a maintenance release with a lot of cleanup and improvement of maintainability.
In addition, the invalidate task descriptor requires a certain version annotation that has now been added.
Thank you so much @ChriFo for your contributions.
3.0.0
This release adds support for H2 (instead of OrientDB) which is required for running with Nexus OSS starting from version 3.71.0. See their release notes and the related db migration guide.
Note: the db migration will not migrate the databases of this plugin and there is no migration logic available. That means you will lose your persisted API tokens and you need to inform your users that they need to fetch new ones from the UI.
2.1.0
Added an icon for the admin's manage users dropdown.
2.0.2
Yet another log noise reduction.
2.0.1
Just reduced some log noise for the common case of local db users logging in programmatically.
2.0.0
This release changes the approach of how data of users that signed in via OAuth2 Proxy are stored in Nexus.
Before, the plugin tried to be smart by recycling the nexus local db and that worked to some extent but had two major drawbacks:
- you were not able to distinguish between "real" local users and those who came via proxy (source attribute was
default
for both) - you needed to prefix your role names with
idp-
(again in order to distinguish because the source could not be properly persisted)
It was simply not possible to make use of the source
attribute of users and roles because it gets overwritten in several places of internal nexus code.
Now there is a dedicated orient db for all purposes of this plugin which also allows for an own api token store for the user which means the original password field does not need to be abused anymore. The hashing is done the same as it is done for the original password file, though, so no clear text tokens are stored.
Programmatic access is now handled by the plugin itself. Before, the original mechanism of Nexus was used by simply not touching those requests. The behavior remains the same, but internally the matching is done against the new api token column.
Role mapping now works with the original "external role mapping" feature as it is done for sources like LDAP as well. The dropdown which offers role names gets populated with group names picked up by people signing in, so if one you expect is missing, make someone sign in who has the group. In the future it could make sense to provide an endpoint for extending that list without a user login.