-
Notifications
You must be signed in to change notification settings - Fork 8
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
[PM-14229] Add more docs to bitwarden_core
#39
base: main
Are you sure you want to change the base?
Conversation
No New Or Fixed Issues Found |
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #39 +/- ##
==========================================
- Coverage 63.34% 63.33% -0.02%
==========================================
Files 184 184
Lines 12935 12938 +3
==========================================
Hits 8194 8194
- Misses 4741 4744 +3 ☔ View full report in Codecov by Sentry. |
/// any organizations. These keys are stored on the server | ||
/// encrypted with the users private key. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
thought: I'm always confused on how to write this, technically they are encrypted with the public key and decrypted with the private key 🤷
/// A struct contains various internal actions. Everything on this type | ||
/// should be considered unstable and subject to change at any time. Use | ||
/// with caution. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
question/suggestion: Who are targeting with this documentation? For external consumers this makes sense, but for our internal products we're expected to use this and not have to "be afraid". Should we maybe clarify that?
/// fingerprint_material: "my_material".to_owned(), | ||
/// public_key: "...public key...".to_owned(), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
question/suggestion: can these fields take any values, or do they expect the fields to be formatted in a certain way, e.g. base64? If yes, could we let the example clarify that somehow?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just realized that these docs are tested and so this must work 🙃
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Well, the test runs the code at the top level, which means it sees the test
function but doesn't actually call it.
If you want your test code to be called, it either needs to be outside of a function, or you need to call the function at the top level of the code block.
With sync functions you can just call them:
/// Does a thing
///
/// ```rust
/// fn test() {
/// panic!("This test now fails")
/// Ok(())
/// }
/// # test();
/// ```
With async functions for example you can do this:
/// Does a thing
///
/// ```rust
/// async fn test() {
/// panic!("This test now fails")
/// Ok(())
/// }
/// # tokio_test::block_on(test());
/// ```
Note the last line: /// # tokio_test::block_on(test());
which runs the async test using tokio_test
. It's at the top level of the code block, and not inside a function, so it gets run. The #
also hides the line from the generated doc, while still running it during tests, which makes the docs nicer to look at:
Ps: the tokio-test crate is just doing tokio::runtime::Builder::new_current_thread().enable_all().build().unwrap().block_on(test());
so we could make our own test utility function if we prefer.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I did not notice that the code was inside of functions, good catch!
/// .user_fingerprint("my_material".to_owned()) | ||
/// .unwrap(); | ||
/// | ||
/// assert_eq!(fingerprint, "dreamland-desecrate-corrosive-ecard-retry"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
thought: huh, interesting, here we use assert_eq
to give an example of the output, but in the doc above we use println
. Should we choose one approach for consistency maybe? I like this one with assert_eq
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ideally we'd just assert! as much as possible, that way we can have an explanatory code comment and test all in one.
That might not be always acceptable, if the output of the function is too long we don't want the code sample to be dwarfed by a massive multi-line assert for example.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah I also prefer assert but the one above didn't use it in the above doc because I couldn't come up with a way to concisely show off a public key that wouldn't be pretty ugly for a test. I could probably generate a new one in a simple one-liner but I still couldn't assert_eq!
it because it would be different each time and assert_ne(fingerprint, "")
doesn't seem like something we want to do.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It would be good to also have a doc at the top of bitwarden-core/src/lib.rs
explaining a bit what the contents of the crate are:
//! This crate contains the core components that the rest of the crates use,
//! the main entrypoint into this crate is [Client], etc, etc
#[cfg(feature = "uniffi")]
uniffi::setup_scaffolding!();
#[cfg(feature = "uniffi")]
mod uniffi_support;
Note that we're using the //!
syntax for the comment, so the comment applies to the crate, as opposed to the next element on the file.
Co-authored-by: Andreas Coroiu <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Some generic feedback on the documentation format.
@@ -30,10 +30,20 @@ pub enum EncryptionSettingsError { | |||
MissingPrivateKey, | |||
} | |||
|
|||
/// A struct containing the core keys of a Bitwarden user. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
suggestion: It's fairly self explanatory that this is a struct both from the code, but also in rust docs.
/// A struct containing the core keys of a Bitwarden user. | |
/// [EncryptionSettings] contains the encryption state related to a Bitwarden account. |
/// The users symmetric key, stored on the server after being | ||
/// encrypted with another key. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is these details relevant to the EncryptionSettings context? We could expand this to give the bigger picture in which case this information could be relevant. If not I think we should focus on the EncryptionSettings perspective which is not to share this anywhere.
/// The users symmetric key, stored on the server after being | |
/// encrypted with another key. | |
/// The user's primary encryption key. | |
/// | |
/// Every Bitwarden account has a symmetric user_key which acts as the encryption key to unlock everything else. | |
/// ....... | |
/// This key is generally protected by a [MasterKey] derived from the users password, or .... and uploaded to the server. | |
/// | |
/// ## References: | |
/// - https://bitwarden.com/help/account-encryption-key/ | |
/// <confluence link>? |
🎟️ Tracking
https://bitwarden.atlassian.net/browse/PM-14229
📔 Objective
Adds some more docs to
bitwarden_core
it's far from fully documented but I thought it was a good start to make sure I am on the right track about what should be expected.⏰ Reminders before review
team
🦮 Reviewer guidelines
:+1:
) or similar for great changes:memo:
) or ℹ️ (:information_source:
) for notes or general info:question:
) for questions:thinking:
) or 💭 (:thought_balloon:
) for more open inquiry that's not quite a confirmedissue and could potentially benefit from discussion
:art:
) for suggestions / improvements:x:
) or:warning:
) for more significant problems or concerns needing attention:seedling:
) or ♻️ (:recycle:
) for future improvements or indications of technical debt:pick:
) for minor or nitpick changes