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

Access profile on plugin initialization #1452

Closed
TimoGlastra opened this issue Oct 21, 2021 · 6 comments · Fixed by #1459
Closed

Access profile on plugin initialization #1452

TimoGlastra opened this issue Oct 21, 2021 · 6 comments · Fixed by #1459

Comments

@TimoGlastra
Copy link
Contributor

We're currently writing a plugin for ACA-Py that needs access to the profile and storage on startup and having a hard time finding a clean approach to this. The setup method only takes the InjectionContext, no profile, and the routes registration also doesn't get a profile.

How we currently solved is by adding a new endpoint and then calling that from the setup method. This is not ideal but gives us access to the context.

I was thinking whether we could maybe add an event that will be emitted after the agent has fully started. This would allow us to hook into that from the setup method and have access to the profile. Bonus is that we don't have to guess anymore when ACA-Py is fully initialized because the event will only trigger after the agent is initialized.

Is it already possible to do this? If not do you think something like the event I described above would work? Are there other (better) solutions?

@TimoGlastra
Copy link
Contributor Author

cc @dbluhm. You know a lot about plugins and event busses :)

@dbluhm
Copy link
Contributor

dbluhm commented Oct 21, 2021

We've run into this as well. The few times we've needed a profile, we've ended up restructuring things and getting the profile through another event or similar but I agree that having both "startup" and "shutdown" events would be beneficial.

@ianco
Copy link
Contributor

ianco commented Oct 21, 2021

I agree, startup and shutdown events would be beneficial.

I recently added a facility for protocols to subscribe to events (part of the endorser refactor work), you can check out the schema, cred def and revocation protocols for an example (e.g. https://github.com/hyperledger/aries-cloudagent-python/blob/main/aries_cloudagent/messaging/credential_definitions/routes.py#L422)

... so using this, a protocol could listen for startup and shutdown events, and it would be pretty straightforward to add these event notifications ...

@ianco
Copy link
Contributor

ianco commented Oct 28, 2021

I suggest we add a "provision" event as well. aca-py provision can be used for example to create the initial wallet database, there are probably other setup type operations that should be done on provision vs start

@dbluhm dbluhm reopened this Oct 30, 2021
@dbluhm
Copy link
Contributor

dbluhm commented Oct 30, 2021

I fumbled the reopening of this issue (sorry) but while I've already triggered notifications: do we want to track the provision event addition as a feature request within this issue and keep it open until implemented?

@swcurran
Copy link
Contributor

swcurran commented Jun 3, 2022

Do we think the provision event needs to handled in the same way? If so, please add a new issue.

Closing this one as complete as originally requested.

@swcurran swcurran closed this as completed Jun 3, 2022
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

Successfully merging a pull request may close this issue.

4 participants