-
Notifications
You must be signed in to change notification settings - Fork 136
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
[DX Streamline] Offer prebuilt filecoin-ffi Go modules natively #209
Comments
One alternative discussed with @Kubuxu on Slack: make the "forwarding FFI module" be separate, such as a new filecoin-ffi-prebuilt, so all the noise related to code generation or continuous bumping of |
Pasting from Slack...
The sprawl reaches any repository that somehow ends up depending on filecoin-ffi. It affects 24 repositories in the filecoin org itself: https://github.com/search?q=org%3Afilecoin-project+filecoin+ffi+replace+filename%3Ago.mod
Yes. We could teach Unified CI to special case filecoin-ffi, such as detecting the presence of the go.mod replace directive and acting accordingly, but that kinda defeats the purpose of Unified CI being generic and encouraging good practices :)
Blast radius (i.e. inability to use Unified CI) is restricted to the modules which have the replace .../filecoin-ffi line, like the search results above.
You might be right - my understanding of the Filecoin org is rather limited. This is the list of filecoin org packages impacted: filecoin-project/boost |
Additional notes from Slack... Unified CI isn't held up by this across PL. We're just unable to use Unified CI on a significant chunk of lotus-related repositories until we solve the problem. As for my proposed solution with Go modules: it's certainly non-trivial, but we think it's in Filecoin's best interest to solve it sooner rather than later as well - not just for Unified CI, because it would also simplify building and development without manual steps. |
Of note, the redirect/forwarding can be achieved with Cloudflare workers, so no server/persistent infra is required. |
Recent discussion about the pain in FIL Slack #fil-lotus-dev: https://filecoinproject.slack.com/archives/CP50PPW2X/p1717676403286179 |
POC is up at https://github.com/aarshkshah1992/ffi-app 🎉 Putting together a plan/executing on taking this to prod now. |
Good stuff @aarshkshah1992 ! I assume you'll post the plan/steps here for review? You don't need to block on review, but I want to make sure we're all aligned. Also, I think a sequence diagram / visual will be worth a lot here. I know there is some description in https://hackmd.io/@mvdan/Hy7iK0TEY and https://app.excalidraw.com/l/AtvYo7ZDrTn/57rJelzHyLp , but a fully accurate picture of the end state including request parameters, redirects, etc. I think could be useful. |
@BigLep Yes, will post a detailed (plan + sequence diagram) here tomorrow to get buy-in as this workstream touches a LOT of touch points. |
@BigLep Have detailed the work that needs to be done at https://github.com/aarshkshah1992/ffi-app/pull/1/files. |
From @rvagg in https://filecoinproject.slack.com/archives/CP50PPW2X/p1721617496659179
|
Another instance where not having this caused trip-ups: filecoin-project/lotus#12306 (comment) |
On 2024-11-11, @rjan90 , @masih , @rvagg , and I met to discuss this project. We reviewed https://github.com/aarshkshah1992/ffi-app/pull/1/files again and identified the following task list: Code
CI related
Infra
Documentation
Cleanup
|
Another case where we wish this had been completed: during 202411 Lotus maintainers found Vulcanize’s archival node got stuck on upgrade because extern/filecoin-ffi wasn’t properly updated on build. |
Hit another case where Protofire was upgrading from v1.32.0-rc1 to v1.32.0-rc2 got stuck because extern/filecoin-ffi wasn’t properly updated on build. |
Detailed design: https://hackmd.io/@mvdan/Hy7iK0TEY
Note that the design just outlines the problem and the high level design of how it would be fixed. I've deliberately left the implementation details vague, e.g. what kind of HTTP server to use for the proxy redirects.
The text was updated successfully, but these errors were encountered: