How should one approach building "robot legs", i.e., multiple instances of the same interface, with the component model? Is it like the aliases in the composed component like in the complex-import example? Or should component developers essentially be building a record factory like open_connection in wasi-sql... and then the controller of the runtime/linker then have a proxy component that manages connections and forwards requests to various host implementations?
If the interface cannot be statically enumerated then putting the interface behind a resource
might be a way to go. That way you'd have a dynamic "load the interface" function.
If you can statically enumerate the interfaces then that's not super well supported right now in the sense that you can't import a WIT interface under multiple names (you'd have to duplicate the interface). That may make sense to use a reosurce
and then have static functions returning the resource perhaps
Cool, thanks! I'm catching up again with components, I guess I didn't see resource
before. I also somehow just misread that the open_connection
returned a connection
which is a resource
type, and not record
.
Are there standard interfaces or patterns for dynamic instantiation of components implementing a specific interface?
For example (sorry, this is maybe silly) consider a secret store that manages CRUD over secrets, but users upload each "secret" as a WASM component that exposes functions like "getName" and "sign(payload)". This store wants to instantiate each component that's currently stored. Are there standard interfaces for performing this kind of dynamic instantiation from within a wasm component?
Currently components themselves cannot model dynamic instantiation, so in some sense this is a feature not specified in the component model. That being said it's always possible for embedders to have extra support on the host itself to do things like this, so there's nothing precluding it in that respect. It'd be a host convention though as opposed to something codified in a component itself.
It'd be a host convention though as opposed to something codified in a component itself.
OK, thanks! I'd imagine there might (someday) be interest in standardizing what this interface looks like (similar to filesystem access -- so a host has to participate, but the interface is consistent across components) But in the near term can explore supporting this ad-hoc.
Last updated: Jan 24 2025 at 00:11 UTC