-
Notifications
You must be signed in to change notification settings - Fork 204
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
feat(dids): add did registrar #953
feat(dids): add did registrar #953
Conversation
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id>
…trar-module-030-full Signed-off-by: Timo Glastra <timo@animo.id>
…trar-module-030-full
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id>
…trar-module-030-full
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nice @TimoGlastra!
2 things:
- I am really not a big fan of the error handling that is done here with the
didState
and theresult
message. It is not an uncommon pattern but its not consistent with the rest of the framework. Is there any specific reason why you chose for this? - Is there any specific reason why the registrar and resolver are separated? Like, do we see a case where you would like to only have a resolver or registrar without the other? I am not opposed to splitting it up, but more just curious for the reasoning behind it.
This is based on https://identity.foundation/did-registration/. It's a standard interface for did registration. We also support the counterpart for resolution: https://w3c-ccg.github.io/did-resolution/. When adding the resolver functionality I discussed with Jakub and he was also in favour of this approach, even though not in line with the rest of AFJ's interface. I kinda like it because it allows for a bit more detailed responses. E.g. the didState has more than just success and failed. But the main reason I went with this appraoch is because there was an interface defined that we'll probably never do better ourselves. There's a lot of difference between did methods and getting it right is hard. We could choose to only adopt the spec for the input parameters, but then we still need some way of didState, etc... How would you approach it differently?
Registrars are often more complicated than resolvers. I see e.g. mobile devices supporting a lot of resolves, while only supporting a few registrars. This is also what is done with e.g. the universal resolver and universal registrar. There's just a lot less complexity in a resolver. We could of course combine them and add not implemented errors, but a bit worried about possible extra needed dependencies for registrars over resolvers. What do you think? |
Okay yeah I see your point. I think its okay to keep it like this. Since these can also be dynamically added by any user, keeping 100% consistent with the interfaces provided by the specs is the way to go.
The mobile case is indeed a good point. I was not specifically in favor of combining them, but was looking more for a use case to justify the seperation. |
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id>
…lastra/aries-framework-javascript into feat/did-registrar-module-030-full
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id>
Signed-off-by: Timo Glastra <timo@animo.id> Signed-off-by: Ariel Gentile <gentilester@gmail.com>
This has been on my local clone for months, and finally got to finishing it.
Adds a generic did registrar based on the DID Registration spec from DIF. It adds support for registering
did:key
,did:sov
anddid:peer
dids. For it to be useful with did:sov dids there's probably a bit more work needed as you need to provide an submitterDid which needs to have the endorser role. For now this can still be done using thepublicDidSeed
property, but the idea is to remove the publicDidSeed in the near future. We should add a way to store a did, without registering it on the ledger, but as the PR is already quite large I'll do that in a separate PR.It also makes it possible to register did registrars and resolvers on the dids module. No way to configure them yet, but once that's possible it'll work out of the box: