-
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
maybe merge devices.bundle and devices.vatAdmin #4566
Labels
Milestone
Comments
warner
added a commit
that referenced
this issue
Feb 17, 2022
Simplify the user experience by removing `devices.bundle` and merging its functionality into vat-admin. closes #4566
warner
added a commit
that referenced
this issue
Feb 18, 2022
Simplify the user experience by removing `devices.bundle` and merging its functionality into vat-admin. * bootstrap() can go back to doing `vatAdminService = E(vats.vatAdmin).createVatAdminService(devices.vatAdmin)` , instead of `createVatAdminService(devices.vatAdmin, devices.bundle)` * you can get bundlecaps from `E(vatAdminService).getBundlecap` or `.getNamedBundlecap`, you no longer need `D(devices.bundle)` for those * `E(vatAdminService).waitForBundlecap(bundleID)` gives you a Promise that fires when (and if) the bundle has been installed, so you can e.g. begin a `zoe.install()` before the bundle is installed (closes #4521) closes #4566
warner
added a commit
that referenced
this issue
Feb 18, 2022
Simplify the user experience by removing `devices.bundle` and merging its functionality into vat-admin. * bootstrap() can go back to doing `vatAdminService = E(vats.vatAdmin).createVatAdminService(devices.vatAdmin)` , instead of `createVatAdminService(devices.vatAdmin, devices.bundle)` * you can get bundlecaps from `E(vatAdminService).getBundlecap` or `.getNamedBundlecap`, you no longer need `D(devices.bundle)` for those * `E(vatAdminService).waitForBundlecap(bundleID)` gives you a Promise that fires when (and if) the bundle has been installed, so you can e.g. begin a `zoe.install()` before the bundle is installed (closes #4521) closes #4566
turadg
pushed a commit
that referenced
this issue
Feb 21, 2022
Simplify the user experience by removing `devices.bundle` and merging its functionality into vat-admin. * bootstrap() can go back to doing `vatAdminService = E(vats.vatAdmin).createVatAdminService(devices.vatAdmin)` , instead of `createVatAdminService(devices.vatAdmin, devices.bundle)` * you can get bundlecaps from `E(vatAdminService).getBundlecap` or `.getNamedBundlecap`, you no longer need `D(devices.bundle)` for those * `E(vatAdminService).waitForBundlecap(bundleID)` gives you a Promise that fires when (and if) the bundle has been installed, so you can e.g. begin a `zoe.install()` before the bundle is installed (closes #4521) closes #4566
warner
added a commit
that referenced
this issue
Feb 25, 2022
Simplify the user experience by removing `devices.bundle` and merging its functionality into vat-admin. Use mid-capitalized "bundleCap" in the API (e.g. `getNamedBundleCap` instead of `getNamedBundlecap`). * bootstrap() can go back to doing `vatAdminService = E(vats.vatAdmin).createVatAdminService(devices.vatAdmin)` , instead of `createVatAdminService(devices.vatAdmin, devices.bundle)` * you can get bundlecaps from `E(vatAdminService).getBundleCap` or `.getNamedBundleCap`, you no longer need `D(devices.bundle)` for those * `E(vatAdminService).waitForBundleCap(bundleID)` gives you a Promise that fires when (and if) the bundle has been installed, so you can e.g. begin a `zoe.install()` before the bundle is installed (closes #4521) This also introduces a better way to export types from swingset, defines a VatAdminRootDeviceNode type for use by clients who think they need that, and exports a few ancillary types to support it. closes #4566
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
What is the Problem Being Solved?
devices.bundle
was added to provide bundlecaps, which are consumed byvats.vatAdmin
. While changing a lot of external code to accomodate the new device, I'm coming to the conclusion that exposingdevices.bundle
as a separate device is kind of a hassle, and that the functionality is sufficiently intertwined withdevices.vatAdmin
that maybe they should be merged.On the plus side:
bootstrap()
would not need to change to accomodate vatAdmin's need fordevices.bundle
(i.e. we getvatAdminService = E(vats.vatAdmin).createVatAdminService(devices.vatAdmin)
, as before, instead of the newcreateVatAdminService(devices.vatAdmin, devices.bundle)
)4521-use-vat-admin
with these changes)On the negative side:
devices.bundle
is a raw device, butdevices.vatAdmin
is not (yet). We would have to rewritedevices.vatAdmin
to be a raw device to make this work. OTOH,vatAdmin-src.js
is really simple: 8 methods that just pass straight through to the endowments, with no internal state.Description of the Design
Security Considerations
Test Plan
The text was updated successfully, but these errors were encountered: