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: tokenless auth (part II) #308

Merged
merged 3 commits into from
Dec 20, 2023
Merged

Conversation

giovanni-guidini
Copy link
Contributor

Implement TokenlessAuth details, so it actually
does things.

Hook it tokenless auth to the upload endpoints that are supposed to support it.

@codecov-qa
Copy link

codecov-qa bot commented Dec 14, 2023

Codecov Report

All modified and coverable lines are covered by tests ✅

Comparison is base (c6f790d) 95.97% compared to head (332318c) 96.00%.

Additional details and impacted files
@@            Coverage Diff             @@
##             main     #308      +/-   ##
==========================================
+ Coverage   95.97%   96.00%   +0.02%     
==========================================
  Files         613      613              
  Lines       15861    15877      +16     
==========================================
+ Hits        15222    15242      +20     
+ Misses        639      635       -4     
Flag Coverage Δ
unit 96.00% <100.00%> (+0.02%) ⬆️
unit-latest-uploader 96.00% <100.00%> (+0.02%) ⬆️

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

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

Copy link

codecov-public-qa bot commented Dec 14, 2023

Codecov Report

Merging #308 (332318c) into main (c6f790d) will increase coverage by 0.02%.
The diff coverage is 100.00%.

Impacted file tree graph

@@            Coverage Diff             @@
##             main     #308      +/-   ##
==========================================
+ Coverage   95.97%   96.00%   +0.02%     
==========================================
  Files         613      613              
  Lines       15861    15877      +16     
==========================================
+ Hits        15222    15242      +20     
+ Misses        639      635       -4     
Flag Coverage Δ
unit 96.00% <100.00%> (+0.02%) ⬆️
unit-latest-uploader 96.00% <100.00%> (+0.02%) ⬆️

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

Files Coverage Δ
codecov_auth/authentication/repo_auth.py 97.57% <100.00%> (+2.36%) ⬆️
upload/views/commits.py 100.00% <100.00%> (ø)
upload/views/reports.py 100.00% <ø> (ø)
upload/views/uploads.py 98.95% <100.00%> (+0.02%) ⬆️

Impacted file tree graph

Copy link

codecov bot commented Dec 14, 2023

Codecov Report

Attention: 1 lines in your changes are missing coverage. Please review.

Comparison is base (c6f790d) 95.59% compared to head (5e4f182) 95.57%.

❗ Current head 5e4f182 differs from pull request most recent head 332318c. Consider uploading reports for the commit 332318c to get more accurate results

Files Patch % Lines
codecov_auth/authentication/repo_auth.py 98.27% 1 Missing ⚠️
Additional details and impacted files
@@           Coverage Diff           @@
##            main    #308     +/-   ##
=======================================
- Coverage   95.59   95.57   -0.02     
=======================================
  Files        728     727      -1     
  Lines      16370   16258    -112     
=======================================
- Hits       15648   15538    -110     
+ Misses       722     720      -2     
Flag Coverage Δ
unit 95.66% <98.76%> (-0.31%) ⬇️
unit-latest-uploader 95.66% <98.76%> (-0.31%) ⬇️

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

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@giovanni-guidini giovanni-guidini force-pushed the gio/tokenless/complete-auth branch from c7c8773 to 5e4f182 Compare December 15, 2023 13:38
@giovanni-guidini giovanni-guidini force-pushed the gio/tokenless/token-auth-conditions branch from 57e3903 to 69829a2 Compare December 18, 2023 14:16
raise ValidationError("missing branch")
# The CLI might have pre-prended the branch with something already
if ":" in branch_info:
_, branch_info = branch_info.split(":")
Copy link
Contributor

Choose a reason for hiding this comment

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

Would branch_info always have 2 items if it had a ":"?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I think so. we do fork_slug:branch. And as mentioned by Dana here branches can't have : in them. I don't think repos can either.

fake_provider_service.get_pull_request.assert_called_with("4")


def test_commit_tokenless_missing_branch(db, client, mocker):
Copy link
Contributor

Choose a reason for hiding this comment

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

Is tokenless reliant on there being a branch?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

only in this implementation, but it would be weird to not have a branch

Copy link
Contributor

Choose a reason for hiding this comment

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

yaaa makes sense, more so me learning how this works heh

authentication.authenticate(request)
assert str(exp.value) == "Not valid tokenless upload"

def test_tokenless_not_supported_services(self):
Copy link
Contributor

Choose a reason for hiding this comment

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

Does tokenless support gh and github and all there uppercase/lowercase variants?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

depends if the upload URL supports that or not. I don't think it does.
If you look in the GetterMixin (here) you'll see that the Service has a limited number of options.

Copy link
Contributor

Choose a reason for hiding this comment

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

Good to know in case we ever want to support/change for multiple services

Copy link
Contributor

@adrian-codecov adrian-codecov left a comment

Choose a reason for hiding this comment

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

Generally looks okay, left some questions here and there but looks gtm

Base automatically changed from gio/tokenless/token-auth-conditions to main December 20, 2023 18:26
context: codecov/engineering-team#736

We want to accept tokenless uploads for forks of public repos.
This is a feature that is currently missing from the CLI and upload.

These changes are part I of that.
What it adds:
* `TokenlessAuthentication` - a new auth class that controls
  when a tokenless upload is accepted
* scaffolding `TokenlessAuth`
* `TOKENLESS_AUTH_BY_OWNER_SLUG` feature for internal testing
* The logic that will let us accept a tokenless upload

What is missing:
* Implementation of the methods in `TokenlessAuth`, so that it can
actually be used
* Hooking up the auth to existing endpoints.

Conditions to accept tokenless upload:
1. Request has `X-Tokenless` header, value is the fork repo slug AND
 `X-Tokenless-PR` header, value is the PR number
2. Request is to one of the new upload endpoints
3. The encoded repo (in the request path) exists AND is public repo
4. (temp) the repo is from an owner that can accept tokenless
5. The git service provider reports that the PR in `X-Tokenless-PR`
indeed exists and is from `X-Tokenless` repo to the encoded repo.
Implement `TokenlessAuth` details, so it actually
does things.

Hook it tokenless auth to the upload endpoints that
are supposed to support it.
Or "don't trust the CLI to do it".
Introduces a check that changes request data prior to serializing
commits to make sure we don't overwrite coverage for existing branch
in the upstream repo if the upload comes from a fork (tokenless)
@giovanni-guidini giovanni-guidini force-pushed the gio/tokenless/complete-auth branch from 5e4f182 to 332318c Compare December 20, 2023 19:03
@codecov-staging
Copy link

Codecov Report

All modified and coverable lines are covered by tests ✅

📢 Thoughts on this report? Let us know!

@giovanni-guidini giovanni-guidini merged commit 90bec21 into main Dec 20, 2023
18 of 19 checks passed
@giovanni-guidini giovanni-guidini deleted the gio/tokenless/complete-auth branch December 20, 2023 19:22
scott-codecov added a commit that referenced this pull request Dec 21, 2023
* main:
  feat: tokenless auth (part II) (#308)
  feat: tokenless auth (part I) (#304)
  fix: stop returning 400 code when user installs github app (#314)
  Always send to mkto (#313)
  feat: Bundle analysis upload endpoint (#299)
  Reduce db queries coming from health endpoint (#311)
scott-codecov added a commit that referenced this pull request Dec 21, 2023
* main:
  feat: tokenless auth (part II) (#308)
  feat: tokenless auth (part I) (#304)
  fix: stop returning 400 code when user installs github app (#314)
  Always send to mkto (#313)
  feat: Bundle analysis upload endpoint (#299)
  Reduce db queries coming from health endpoint (#311)
scott-codecov added a commit that referenced this pull request Dec 21, 2023
* main:
  feat: tokenless auth (part II) (#308)
  feat: tokenless auth (part I) (#304)
  fix: stop returning 400 code when user installs github app (#314)
  Always send to mkto (#313)
  feat: Bundle analysis upload endpoint (#299)
  Reduce db queries coming from health endpoint (#311)
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.

2 participants