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

Google Drive downloader: Create separate classes for authenticated/nonauthenticated downloads #23

Open
jacobdadams opened this issue Sep 7, 2022 · 2 comments
Labels
enhancement New feature or request
Milestone

Comments

@jacobdadams
Copy link
Member

suggestion: I noticed another loader class takes the credentials in the ctor and creates a class client. It's nice to have consistency between classes for the sake of the api.

Originally posted by @steveoh in #21 (comment)

@jacobdadams jacobdadams added the enhancement New feature or request label Sep 7, 2022
@jacobdadams jacobdadams added this to the v3 milestone Sep 7, 2022
@steveoh
Copy link
Member

steveoh commented Sep 7, 2022

Separate classes for auth/anon may not have been my intention from that comment. However, it may be an improvement if you like the idea.

I noticed one class takes the creds as a ctor parameter and creates a client used within the instance and the other class takes credentials as a method parameter and creates the client in the method. That was the inconsistency I wanted to highlight.

@jacobdadams
Copy link
Member Author

Sorry, yeah, I was taking it one step further without being clear 🙂

Because that class has methods for downloading both with authentication and without, I intentionally didn't put the creds in the constructor. However, you're totally right, that is inconsistent with the other class in the module. I'm thinking the best fix is to split the class into two classes, one for auth'ed downloads and another for anon. I think that will give the best ux.

(Or honestly, it may make sense to just remove the anon downloader, since google's abuse-blocking lockout makes using it fragile and finicky. But it may be nice to keep it for small things, or keep and modify it for situations when sharing the files with the service account is not feasible. Just thinking out loud here.)

@jacobdadams jacobdadams modified the milestones: v3, v3.1 Jan 27, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

2 participants