-
Notifications
You must be signed in to change notification settings - Fork 219
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
change all dapp deploy scripts to install by hash bundle, not source bundle #4564
Comments
Previously, `E(zoe).install()` accepted a source bundle. Now it accepts either a source bundle, or a "bundle ID". The ID is a hash-based identifier string that refers to a bundle installed into the kernel via `controller.validateAndInstallBundle()`, and is retrievable from vatAdminService. Zoe exchanges the ID for a bundlecap, and retains the bundlecap for future use (including passing to the new ZCF vat, which converts it into a source bundle for evaluation at the last possible moment). The kernel install step can happen either before or after `E(zoe).install`, because the id-to-bundlecap conversion waits until the kernel install is complete. This begins the process of making Zoe work exclusively with (small) bundlecaps, and not (large) source bundles. The next step is to modify all unit tests and external callers (including deploy scripts, #4564) to kernel-install their bundle and use a bundleID for the Zoe install() invocation. After that is complete, #4565 will remove support for full bundles, and `E(zoe).install(bundleID)` will be the only choice. closes #4563
@kriskowal Is this something you could take on? |
I can. I would bump the estimate to 5. I’ll need to get up-to-speed on @warner’s bundle caps API and some kernel layers I haven’t touched yet. The extra time is probably a good investment. |
Estimate bumped. |
This needs to happen for the RUN Protocol Review release, but not for all DApps, just for the scripts that deploy the proposal(s) to start RUN protocol. We need someone to pick up this work. FYI @dckc |
The current plan that @kriskowal is working on does not require any code changes to deploy scripts. We may still change deploy scripts for other reasons (captured in other issues), but this is not one of them. |
The plan has changed. Dapps will need to performa a migration like: Agoric/dapp-fungible-faucet#46 This is because These aren’t absolute constraints, but I think strong enough to make the separation between the two functions clear in dapp deploy scripts. |
What is the Problem Being Solved?
After #4563 gives Zoe the ability to
E(zoe).install(bundleID)
(instead of a bundle), and after #4396 gives cosmic-swingset the ability to accept "install bundle" transactions, the next step of the process is to change the deploy scripts in all dapps to use them. Currently, these deploy scripts usebundleSource()
on the local contract code, thenE(zoe).install(bundle)
, which creates a large (swingset/mailbox) message to deliver the bundle to the chain and install it. That should change to:bundleSource()
to get both a bundle and it's bundleID (hash)E(zoe).install(bundleID)
Description of the Design
We need the client-side facility to create the new transaction types.
Security Considerations
On the real chain, for the Mainnet-1 timeframe, there will be a governance process to limit the installation of new contracts. The bundleID must be in an approved list before the install-bundle transaction will be accepted. Test chains won't have such a limitation. I think the real chain process will look like:
E(zoe).install(ID)
is called by the proposal code, waits for bundle to be installedcontroller.validateAndInstallBundle()
Test Plan
cc @michaelfig
The text was updated successfully, but these errors were encountered: