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

feat: add a new admin API to remove a specific 2nd factor credential #2962

Merged
merged 14 commits into from
Jan 28, 2023

Conversation

supercairos
Copy link
Contributor

@supercairos supercairos commented Dec 16, 2022

This PR provide a way for an admin to remove a specific credential method.
For now, only 2nd factor methods are allowed (TOTP, Lookup Secrets, WebAuthn)
This endpoint can be used by support services to unlock a custom account in case they've lost they MFA device.

Following the discussion with issue #2505 i've decided to implement in the following way:
DELETE /admin/identities/{id}/credential/{type}
id: being the targeted user id
type: being one of the 2FA kratos supports (totp, lookup, webauthn)

Related issue(s)

#2505

Checklist

  • I have read the contributing guidelines.
  • I have referenced an issue containing the design document if my change
    introduces a new feature.
  • I am following the
    contributing code guidelines.
  • I have read the security policy.
  • I confirm that this pull request does not address a security
    vulnerability. If this pull request addresses a security vulnerability, I
    confirm that I got the approval (please contact
    security@ory.sh) from the maintainers to push
    the changes.
  • I have added tests that prove my fix is effective or that my feature
    works.
  • I have added or changed the documentation.

Further Comments

I've moved the credentials config models found previously in the selfservice/strategy pkg to the identity package to be able to use them from the admin endpoints and to avoid some cyclic pkg inclusion

@supercairos supercairos marked this pull request as ready for review December 16, 2022 14:46
Copy link
Member

@aeneasr aeneasr left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Very nice! Only a few nit picks :)

identity/handler.go Outdated Show resolved Hide resolved
identity/handler.go Outdated Show resolved Hide resolved
identity/handler.go Outdated Show resolved Hide resolved
identity/handler.go Outdated Show resolved Hide resolved
identity/handler.go Outdated Show resolved Hide resolved
@codecov
Copy link

codecov bot commented Dec 19, 2022

Codecov Report

Merging #2962 (b0b246f) into master (acf9261) will decrease coverage by 0.01%.
The diff coverage is 85.14%.

@@            Coverage Diff             @@
##           master    #2962      +/-   ##
==========================================
- Coverage   77.31%   77.30%   -0.01%     
==========================================
  Files         313      313              
  Lines       19454    19462       +8     
==========================================
+ Hits        15041    15046       +5     
- Misses       3254     3255       +1     
- Partials     1159     1161       +2     
Impacted Files Coverage Δ
identity/handler.go 84.58% <75.40%> (-0.81%) ⬇️
identity/credentials_lookup.go 100.00% <100.00%> (ø)
identity/credentials_webauthn.go 100.00% <100.00%> (ø)
selfservice/strategy/lookup/login.go 76.47% <100.00%> (ø)
selfservice/strategy/lookup/settings.go 62.50% <100.00%> (ø)
selfservice/strategy/lookup/strategy.go 91.30% <100.00%> (ø)
selfservice/strategy/totp/login.go 80.39% <100.00%> (ø)
selfservice/strategy/totp/settings.go 61.48% <100.00%> (ø)
selfservice/strategy/totp/strategy.go 91.66% <100.00%> (ø)
selfservice/strategy/webauthn/login.go 62.50% <100.00%> (ø)
... and 9 more

Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here.

@supercairos
Copy link
Contributor Author

Hi @aeneasr or @zepatrik any chance you had time to check this PR ? :)

Copy link
Member

@aeneasr aeneasr left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Awesome, this is very neat! Also great tests! There's two things that need to be improved in the tests, but I think those changes should be doable in little time :) Once these are addressed, this is good to go to master!

identity/handler_test.go Outdated Show resolved Hide resolved
identity/handler.go Outdated Show resolved Hide resolved
@supercairos
Copy link
Contributor Author

@aeneasr thanks for the review, I should have fixed all your raised concerns.

Let me know if it looks good :) 🙏

@supercairos supercairos force-pushed the feat-multifactor-admin-api branch from e1dbe10 to 703eb16 Compare January 26, 2023 00:46
Fix SDK generation
Add some more tests cases
@supercairos supercairos force-pushed the feat-multifactor-admin-api branch from 703eb16 to b0b246f Compare January 26, 2023 00:52
@aeneasr
Copy link
Member

aeneasr commented Jan 28, 2023

Great work!

@aeneasr aeneasr merged commit 44556a4 into ory:master Jan 28, 2023
@Linyhazel
Copy link

Hellooo the type is actually lookup_secret instead of lookup, maybe you can update the documentation :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants