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

Migrate connections protocol to a plugin #925

Open
wants to merge 9 commits into
base: main
Choose a base branch
from

Conversation

dbluhm
Copy link
Contributor

@dbluhm dbluhm commented Aug 19, 2024

This PR lifts the connections protocol out of ACA-Py proper and turns it into a plugin. The connections protocol has been deprecated for several releases. This completes the deprecation period while also encouraging the community to move on to bigger and better things (DID Exchange). But, for those who absolutely cannot move on, this plugin will fill the gap.

This is the first instance of a deprecated protocol entering retirement as a plugin. There may be processes to figure out still but I think it's time to make the jump.

Opening as draft while testing for input and thoughts.

cc @swcurran @jamshale

@dbluhm
Copy link
Contributor Author

dbluhm commented Aug 19, 2024

A corresponding PR will be opened to ACA-Py to remove the connections protocol.

@dbluhm
Copy link
Contributor Author

dbluhm commented Aug 19, 2024

Functionality lost by moving connections protocol to a plugin (e.g. things we may wish to reinstate as a feature of this plugin, if there's enough desire for it):

  • Automatic mediator setup on startup using a connections invitation
  • Automatic endorser setup on startup using a connections invitation

Issues now resolved:

  • _fetch_connection_targets_for_invitation needs to be reworked or extended by plugin to support conn invite; consider mapping connections invitation into InvitationMessage for uniform handling.
  • invitation attachment and retrieval; consider storing and retrieving using interface other than conn record
  • request attachment and retrieval; consider storing and retrieving using interface other than conn record

Things currently broken as a result of moving to a plugin (e.g. things we must fix to merge and have "good enough" feature parity):

  • OOB Manager _perform_handshake

@dbluhm
Copy link
Contributor Author

dbluhm commented Aug 19, 2024

Corresponding PR in ACA-Py: openwallet-foundation/acapy#3184

@dbluhm
Copy link
Contributor Author

dbluhm commented Sep 19, 2024

This plugin is dependent on changes in an unreleased version of ACA-Py but is otherwise ready for review.

@dbluhm dbluhm marked this pull request as ready for review September 19, 2024 19:21
Copy link
Contributor

@jamshale jamshale left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me.

I'd like to manually test it still and see if there should be anymore integration tests.

connections/README.md Outdated Show resolved Hide resolved
connections/.devcontainer/post-install.sh Outdated Show resolved Hide resolved
connections/.devcontainer/Dockerfile Show resolved Hide resolved
connections/.devcontainer/devcontainer.json Show resolved Hide resolved
Signed-off-by: Daniel Bluhm <dbluhm@pm.me>
Signed-off-by: Daniel Bluhm <dbluhm@pm.me>
Signed-off-by: Daniel Bluhm <dbluhm@pm.me>
Signed-off-by: Daniel Bluhm <dbluhm@pm.me>
Signed-off-by: Daniel Bluhm <dbluhm@pm.me>
Signed-off-by: Daniel Bluhm <dbluhm@pm.me>
Signed-off-by: Daniel Bluhm <dbluhm@pm.me>
@dbluhm dbluhm force-pushed the feature/connection-protocol branch from 636de3d to 7fd565e Compare September 27, 2024 19:05
Signed-off-by: Daniel Bluhm <dbluhm@pm.me>
Signed-off-by: Daniel Bluhm <dbluhm@pm.me>
@swcurran
Copy link
Contributor

Can we merge this?

@jamshale
Copy link
Contributor

@dbluhm Looks like this has become a priority again. Hoping it's not too much work to update. I think the testing is probably the worst because of the new testing profile. Probably easiest to copy them from acapy again. I had updated them all before they got removed recently.

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 this pull request may close these issues.

3 participants