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

Private repository releases support #65

Open
akramhussein opened this issue Dec 21, 2023 · 5 comments
Open

Private repository releases support #65

akramhussein opened this issue Dec 21, 2023 · 5 comments

Comments

@akramhussein
Copy link

This issue was covered #26 but I was not able to get it to work so wanted to double check if the solution is still correct and if you have any advice:

When hosting a Rust dependency in a private repository and using rustler_precompiled, if there is no plans to publish to hex package how can the downstream Mix project fetch the release as the base_url is private and not authenticaiton details are passed through?

Our rustler_precompiled setup has a correct release + checksum-* file etc and works when the project is made public but not if private. The same downstream project is able to pull from the private repo using a GitHub token and compile it but just not rustler_precompiled.

My understanding from a quick glance at the GitHub docs is that rustler_precompiled would need to pass the GitHub Personal Access Token (PAT) through and use the API. This StackOverflow answer also covers it.

@sliiser
Copy link
Contributor

sliiser commented Jun 19, 2024

I am interested in picking this up. @philss, do you have any thoughts on the best approach to take? Any specific config fields you have in mind or should I just come up with something myself?

@philss
Copy link
Owner

philss commented Jun 21, 2024

I think we could accept a tuple of {base_url, request_headers}. Maybe we could also accept {Module, :function} to dynamically call a function that can return this tuple. WDYT?

@sliiser
Copy link
Contributor

sliiser commented Jun 22, 2024

{base_url, request_headers} would make it a lot more flexible, but not sufficient for private repos due to the asset download URLs in the API not being in the format #{base_url}/#{file_name}. There is an API endpoint that will return a list of assets that will have to be iterated through to find the correct file name from the body and then take the actual URL from that response which will be in the format of https://api.github.com/repos/NAME/REPO/releases/assets/1275759, which will then redirect to S3.

I propose accepting a function (for example in the format {Module, :function}) that would take the name of the binary (with or without the tar.gz suffix) as an argument and return {full_url, request_headers}, not {base_url, headers}. Another option would be to have the function make the request and return the binary content.

However, an issue with accepting {Module, :function} is that during mix rustler_precompiled.download YourRustlerModule, the application code has not been loaded (and the NIF module cannot be loaded), so this function might be unavailable. Thoughts?

I also found an issue with following redirects to S3. :httpc unlike other HTTP clients like curl passes the Authorization header to the new URL after a redirect. This then fails in S3 due to S3 complaining that multiple authorization methods were used (example). However, if {full_url, request_headers} is returned, that can already be the S3 URL and this issue can be bypassed.

@philss
Copy link
Owner

philss commented Jun 25, 2024

@sliiser I like your proposal. I think believe my PR fixes the problem of the app being loaded: a5cd67e
WDYT?

@sliiser
Copy link
Contributor

sliiser commented Jun 25, 2024

Alright, I'll get on it.

sliiser added a commit to salemove/rustler_precompiled that referenced this issue Jun 25, 2024
The :base_url attribute now accepts static headers or a custom function
that returns a URL and headers. This allows us to fetch NIFs from more
complicated sources, rather than just public GitHub releases.
sliiser added a commit to salemove/rustler_precompiled that referenced this issue Jul 8, 2024
The :base_url attribute now accepts static headers or a custom function
that returns a URL and headers. This allows us to fetch NIFs from more
complicated sources, rather than just public GitHub releases.

Co-authored-by: Philip Sampaio <[email protected]>
philss pushed a commit that referenced this issue Aug 28, 2024
* Add support for headers and dynamic base URL (#65)

The :base_url attribute now accepts static headers or a custom function
that returns a URL and headers. This allows us to fetch NIFs from more
complicated sources, rather than just public GitHub releases.

* Apply suggestions from code review

* Enable config validation in tests

Previously the `RustlerPrecompiled.Config` struct was initialized
directly in the tests, which bypassed the validation in `new/1`.
This change updates the tests to use `new/1` wherever possible.
Some tests still use direct struct access to test invalid values.
philss added a commit that referenced this issue Aug 28, 2024
This reverts commit ae78223.

This change is temporary, since we need to release a patch first.
philss added a commit that referenced this issue Aug 28, 2024
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

No branches or pull requests

3 participants