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

Pagination on created schemas and cred defs? #2373

Closed
dbluhm opened this issue Jul 31, 2023 · 4 comments
Closed

Pagination on created schemas and cred defs? #2373

dbluhm opened this issue Jul 31, 2023 · 4 comments

Comments

@dbluhm
Copy link
Contributor

dbluhm commented Jul 31, 2023

See: https://github.com/hyperledger/aries-cloudagent-python/blob/anoncreds-rs/aries_cloudagent/anoncreds/issuer.py#L232-L255
And: https://github.com/hyperledger/aries-cloudagent-python/blob/anoncreds-rs/aries_cloudagent/anoncreds/issuer.py#L417-L446

This is similar in behavior to the current interface but as you can see it is using fetch_all to retrieve all of the matching records. In the event your issuer has created lots of schemas/cred defs, this might be a slow operation. Should it use pagination?

@dbluhm dbluhm converted this from a draft issue Jul 31, 2023
@dbluhm dbluhm added the AnonCreds Ledger Agnostic AnonCreds label Jul 31, 2023
@dbluhm
Copy link
Contributor Author

dbluhm commented Jul 31, 2023

Perhaps it is best to just use the other values to narrow the results rather than to paginate?

@genaris
Copy link

genaris commented Aug 1, 2023

Are you using pagination for other kind of records in ACA-Py? We had recently a discussion regarding this in an AFJ call and we figured out that, even if it's certainly possible to add offset and limit, special care must be taken in case new records are added between calls.

An issue we have is about sorting: it seems that Indy's WQL was not meant to store a massive amount of data (and possibly Askar inherited this design constraints as well). For server deployments like ACA-Py it's a bit tricky because we would probably like to sort records by creation date or last activity date or whatever, and this will not be possible if using encrypted tags.

@swcurran
Copy link
Contributor

swcurran commented Aug 8, 2023

Askar does a better job at handling large numbers of records because of improvements in indexing and the like. That said, it does still use encrypted tags. Not using encrypted tags is a big change in the security model. Note that there is a way to specifically use unencrypted tags for specific purposes, and then to use those with ordering and filtering. Is that enough of a compromise, or would you wind up with plaintext tags everywhere?

I’ve heard that in AFJ you are considering going to database engine-managed encryption at rest. Any progress on that? What are the ramifications of enabling that support — impact on the security model, compatibility across DB engines in particular.

@swcurran
Copy link
Contributor

Closing in favor of #3001

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

No branches or pull requests

3 participants