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: allow build-time overrides of attestation server url and static fingerprint override #234

Open
wants to merge 6 commits into
base: main
Choose a base branch
from

Conversation

cassandracomar
Copy link

pulls the attestation server url and overriden fingerprint from res/values/strings, allowing them to be overriden at AOSP/GrapheneOS build time. because the device info/fingerprint can't be known statically, this PR introduces a dynamic look up for the device info and fingerprint via a singleton that gets its context set by the main activity, avoiding null pointer issues by ensuring static accesses for Resources in AttestationProtocol.java occur as late as possible.

this allows the attestation server url to be overriden at
AOSP/GrapheneOS build time.
when the fingerprint override resource is set at build time, dynamically
look up the device info for the current device, checking that the AVB
fingerprint matches the one the Auditor app was built with.

uses a singleton to allow lazily-initialized lookups of the device name
and override fingerprint in a static context.
@@ -507,6 +506,10 @@ public boolean onPrepareOptionsMenu(final Menu menu) {
return true;
}

final String tutorial_url() {
Copy link
Member

Choose a reason for hiding this comment

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

Should make this private since Java defaults to package public. Don't need to make it final since if we want to do that it probably makes more sense to just make the classes final but it isn't really needed. It doesn't have the usual meaning of an immutable variable binding here but rather preventing an override by a class inheriting this one.

@@ -127,6 +124,18 @@ static void cancel(final Context context) {
scheduler.cancel(FIRST_RUN_JOB_ID);
}

final String domain() {
Copy link
Member

Choose a reason for hiding this comment

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

Same as tutorial_url.

@@ -1,5 +1,6 @@
<resources>
<string name="app_name">Auditor</string>
<string name="url">attestation.app</string>
Copy link
Member

Choose a reason for hiding this comment

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

Probably better to call this base_url and it can include the https:// prefix.

@@ -1,6 +1,7 @@
<resources>
<string name="app_name">Auditor</string>
<string name="url">attestation.app</string>
<string name="avb_fingerprint_override">NOT OVERRIDEN</string>
Copy link
Member

Choose a reason for hiding this comment

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

This approach won't really work because Auditor requires 2 devices. The standard GrapheneOS and stock OS entries should also be left working for a custom build. Instead, new entries should be added to the non-stock OS table and the person doing it will need to use their build on both ends since our Auditor builds won't trust their Auditor builds (signing key fingerprint of the app is verified remotely via key attestation) and won't have the entries for their OS builds.

Copy link
Author

Choose a reason for hiding this comment

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

this is here so there's still a local check of the fingerprint before the verification is submitted. I'm unsure how new entries can be added to the table without source code modification at build time. do you have thoughts?

Copy link
Author

Choose a reason for hiding this comment

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

I took a pass at resolving this by setting up maps in the XML resources to connect device identifiers with fingerprints. this should allow someone building a custom os for several devices to inject their own map of keys / DeviceInfo without source code modification. as I needed to validate the parser anyway, I've moved the existing static maps into their own resource maps, but I'm open to thoughts on that -- it is useful for ensuring the parser doesn't break sometime in the future.

return getString(R.string.url);
}

final String challenge_url() {
Copy link
Contributor

Choose a reason for hiding this comment

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

Method names should also match the code/naming style of the rest of the codebase even if they're private methods

Suggested change
final String challenge_url() {
final String challengeUrl() {

@muhomorr
Copy link
Member

muhomorr commented Apr 23, 2023

we're actually already passing the Context around so there's no need for
a singleton.
this allows multiple devices to be configured the same even when they
have different AVB fingerprints, and therefore should be able to
validate each other.
they got increased when I was moving the tests around to figure out what
would make them actually function.
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.

4 participants