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

Generate and serve OpenAPI specs #106

Merged
merged 8 commits into from
Dec 24, 2022
Merged

Generate and serve OpenAPI specs #106

merged 8 commits into from
Dec 24, 2022

Conversation

enobayram
Copy link
Contributor

@enobayram enobayram commented Dec 9, 2022

This PR adds a hidden --serve-swagger-ui CLI option to the serve subcommand. When --serve-swagger-ui is enabled, chainweb-data serves an OpenAPI v3 spec for the chainweb-data API.

The spec that's currently served is automatically generated from the Servant API definition using servant-openapi3 and this PR makes no effort to refine the documentation generated by servant-openapi3 which lacks any explanations for the endpoints and the data schemas and it produces unhelpful details like integral values having meaningless upper and lower bounds.

So, despite being helpful as it is, the currently generated spec is only rudimentary, that's why this PR hides the new --serve-swagger-ui argument from the CLI --help output keeping it unofficial for now.

@enobayram
Copy link
Contributor Author

Here's how I tested this PR:

I've started my CW-D instance with the --serve-swagger-ui option:

/nix/store/i9y1wln587zi8jac13mifms5i8qcgahi-chainweb-data-2.0.1/bin/chainweb-data --dbstring ... --level debug --service-host localhost --p2p-host localhost --p2p-port ... server --port ... --serve-swagger-ui

And went to $CWDURL/cwd-spec in my browser, which displayed the following page:
image
I've tried making a few request using the interactive documentation and I got back sensible results.

Then I tried starting the instance without --serve-swagger-ui, this time $CWDURL/cwd-spec responded with a 404:

$ curl $CWDURL/cwd-spec
Swagger UI server is not enabled on this instance

@enobayram enobayram marked this pull request as ready for review December 23, 2022 13:51
@enobayram enobayram merged commit 932f933 into master Dec 24, 2022
@enobayram enobayram deleted the enis/openapi-spec branch December 24, 2022 15:32
@enobayram enobayram self-assigned this Dec 24, 2022
enobayram added a commit that referenced this pull request Jan 4, 2023
This PR adds a hidden `--serve-swagger-ui` CLI option to the `serve` subcommand. When `--serve-swagger-ui` is enabled, `chainweb-data` serves an OpenAPI v3 spec for the `chainweb-data` API.

The spec that's currently served is automatically generated from the Servant API definition using [`servant-openapi3`](https://hackage.haskell.org/package/servant-openapi3) and this PR makes no effort to refine the documentation generated by `servant-openapi3` which lacks any explanations for the endpoints and the data schemas and it produces unhelpful details like integral values having meaningless upper and lower bounds.

So, despite being helpful as it is, the currently generated spec is only rudimentary, that's why this PR hides the new `--serve-swagger-ui` argument from the CLI `--help` output keeping it unofficial for now.

* Generate and serve OpenAPI specs

* Make swagger UI optional with a hidden CLI flag

* Remove unused declaration

* Add special 404 message when cwd-spec not enabled
emmanueldenloye pushed a commit that referenced this pull request Jan 4, 2023
This PR adds instrumentation around the connection pool used by the endpoint handlers to keep track of the number of requests currently pending or being served. It then uses this information in order to scale down the amount of work that's performed per request by the search endpoints in order to make it easier to maintain a fair resource allocation under load across multiple clients.

This PR still doesn't stop a single client from making a large number of search requests in parallel, but `chainweb-data` expects that this would be handled via rate limiting at the API gateway layer. In theory, it could be argued that it would be better for the gateway to handle such throttling as well, but it seems harder to implement there in practice.

This PR also increases the maximum `scanLimit` of the search endpoints from 20000 to 50000 (but subject to load throttling) in order to reduce network roundtrips. It used to take us around 50-100ms to scan 20000 rows, so now each request should take between 100-250ms, which is still low enough and now each request should scan around 10 hours worth of blockchain history.


* Increase the scanLimit

* Remove the fromheight parameter of /txs/accounts (#114)

This PR removes the yet unreleased `fromheight` parameter of the `/txs/accounts` endpoint.

The original purpose of that parameter was to facilitate efficient pagination of the `/txs/accounts` results, but it has since been obsoleted for that purpose by the `Chainweb-Next`-token-based pagination workflow. The `Chainweb-Next`-based pagination is superior, because it doesn't require the client to figure out how to stitch together the result chunks produced by each request and it is easier to reuse across endpoints independent of whether specifying `height` limits is a reasonable or efficient way to paginate for a given endpoint.

Admittedly, `fromheight` could still be useful independent of pagination, but I'm not convinced that adding query parameters to `chainweb-data` endpoints for hypothetical use cases is a good idea at this stage, especially considering the backward compatibility burden that entails.

* Remove the fromheight parameter of /txs/accounts

* Update the chainweb-api pin

* Generate and serve OpenAPI specs (#106)

This PR adds a hidden `--serve-swagger-ui` CLI option to the `serve` subcommand. When `--serve-swagger-ui` is enabled, `chainweb-data` serves an OpenAPI v3 spec for the `chainweb-data` API.

The spec that's currently served is automatically generated from the Servant API definition using [`servant-openapi3`](https://hackage.haskell.org/package/servant-openapi3) and this PR makes no effort to refine the documentation generated by `servant-openapi3` which lacks any explanations for the endpoints and the data schemas and it produces unhelpful details like integral values having meaningless upper and lower bounds.

So, despite being helpful as it is, the currently generated spec is only rudimentary, that's why this PR hides the new `--serve-swagger-ui` argument from the CLI `--help` output keeping it unofficial for now.

* Generate and serve OpenAPI specs

* Make swagger UI optional with a hidden CLI flag

* Remove unused declaration

* Add special 404 message when cwd-spec not enabled

* Apply search throttling when there is load
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.

2 participants