Skip to content
This repository was archived by the owner on Jul 11, 2023. It is now read-only.

Certificate issuance state management #4743

Merged
merged 7 commits into from
May 23, 2022

Conversation

steeling
Copy link
Contributor

@steeling steeling commented May 13, 2022

State management for certificate rotation

This PR implements certificate state management for rotation, by maintaining 2 certificate.Issuer's (previously certificate.Provider). It adds an ID to each issuer, to be extracted from the MRC, to delineate between a prior issued cert, and the current intended issuer.

We then add a combine method on a certificate, which will add in a pem.RootCertificate, such that GetIssuingCA will now return the combined set of certificates for validation.

@jaellio
Copy link
Contributor

jaellio commented May 13, 2022

@steeling could you please update the PR description to elaborate on the changes made in this PR?

@jaellio jaellio marked this pull request as draft May 13, 2022 23:04
@codecov-commenter
Copy link

codecov-commenter commented May 16, 2022

Codecov Report

Merging #4743 (cbbd756) into main (21bc67d) will increase coverage by 0.11%.
The diff coverage is 80.89%.

@@            Coverage Diff             @@
##             main    #4743      +/-   ##
==========================================
+ Coverage   68.85%   68.97%   +0.11%     
==========================================
  Files         227      227              
  Lines       16170    16192      +22     
==========================================
+ Hits        11134    11168      +34     
+ Misses       4984     4972      -12     
  Partials       52       52              
Flag Coverage Δ
unittests 68.97% <80.89%> (+0.11%) ⬆️

Flags with carried forward coverage won't be shown. Click here to find out more.

Impacted Files Coverage Δ
pkg/certificate/providers/compat.go 100.00% <ø> (+20.00%) ⬆️
pkg/certificate/types.go 100.00% <ø> (ø)
pkg/certificate/providers/config.go 78.86% <48.48%> (-4.16%) ⬇️
pkg/certificate/certificate.go 95.55% <100.00%> (+6.36%) ⬆️
pkg/certificate/fake_manager.go 61.53% <100.00%> (+13.91%) ⬆️
pkg/certificate/manager.go 90.90% <100.00%> (+10.56%) ⬆️
pkg/ticker/ticker.go 87.17% <0.00%> (+3.84%) ⬆️

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update 21bc67d...cbbd756. Read the comment docs.

@steeling steeling force-pushed the featurt/next-up branch 2 times, most recently from 6f22f45 to 70c8651 Compare May 16, 2022 17:50
Enable the certificate handler to correctly issue certificates
from the correct issuer based on the set state. We don't actually
populate any additional states yet.

Signed-off-by: Sean Teeling <[email protected]>
@steeling steeling marked this pull request as ready for review May 18, 2022 03:23
steeling added 2 commits May 18, 2022 10:19
Signed-off-by: Sean Teeling <[email protected]>
Signed-off-by: Sean Teeling <[email protected]>
@steeling
Copy link
Contributor Author

@nojnhuh @shashankram @trstringer friendly ping on this

@jaellio jaellio merged commit ecc4e67 into openservicemesh:main May 23, 2022
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants