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

prototype(probeservices): annotate request and response with their type #997

Closed
wants to merge 10 commits into from

Conversation

bassosimone
Copy link
Contributor

@bassosimone bassosimone commented Dec 5, 2022

Checklist

Description

This pull request contains an early prototype of annotating the (JSON) request and response of probeservices with their type such that we can generate a swagger to compare to the API's swagger and implement ooni/probe#2372.

This diff changes httpapi Endpoint and Descriptor such that the
logger field is part of the Endpoint rather than Descriptor.

This changes makes sense because the logger to use should be the
same for every API call. What matters, instead, is whether to log
bodies, which remains a property of the API Descriptor.
The current httpapi code has the concept of Descriptor, which
describes how an API call should be made in terms of its request,
but which lacks a precise response definition.

Because our goal is to automatically generate swaggers from
the API spec, we need a more abstract way of describing an API.

This way will be the Spec. We will have two kind of Spec:

1. `SimpleSpec` is the specification for an API that returns
a raw response only consisting of bytes;

2. `TypedSpec[T]` is the specification for an API that
returns `*T` responses on success.

From a Spec, you can generate the `Descriptor`, so the previous
code does not change much.

Also, while there, recognize that, with a little tweak, we
don't need the SequenceCaller but we can do all the work
inside of the new APIs for calling specs.

Additionally, deprecate previous code that is now superseded
by this new approach--without removing this code for now.
The SequenceCaller concept is useful because potentially it can
incapsulate some state. Thus, in the future we may be able to
try the list of endpoints in the correct order.

So, it's actually worth keeping this concept and so we need
two distinct callers one for each possible calling style.

(I am starting to wonder whether this is a place where we could
use monads to decorate return values?)
It _seems_ I should be able to take advantage of the new style to
automatically generate a swagger to validate against ooni/api's one.
bassosimone added a commit that referenced this pull request Dec 9, 2022
This diff changes httpapi Endpoint and Descriptor such that the
logger field is part of the Endpoint rather than Descriptor.

This changes makes sense because the logger to use should be the
same for every API call. What matters, instead, is whether to log
bodies, which remains a property of the API Descriptor.

While I authored this diff originally as part of the work done
in #997, it seems it's
required in #1002 as well.

Hence, the reference issue is ooni/probe#2379.
bassosimone added a commit that referenced this pull request Dec 9, 2022
This diff changes httpapi Endpoint and Descriptor such that the
logger field is part of the Endpoint rather than Descriptor.

This changes makes sense because the logger to use should be the
same for every API call. What matters, instead, is whether to log
bodies, which remains a property of the API Descriptor.

While I authored this diff originally as part of the work done
in #997, it seems it's
required in #1002 as well.

Hence, the reference issue is ooni/probe#2379.

While there, fix the go1.19 build workflow, which was broken
by using actions/setup-go rather than downloading go manually.
bassosimone added a commit that referenced this pull request Dec 14, 2022
Conflicts:
	internal/engine/probeservices/checkreportid.go
	internal/httpapi/descriptor.go
@bassosimone
Copy link
Contributor Author

Superseded by #1010 and #1011

@bassosimone bassosimone deleted the issues/2372 branch December 16, 2022 10:11
@bassosimone
Copy link
Contributor Author

Reference issue was ooni/probe#2372.

@bassosimone bassosimone changed the title Issues/2372 prototype(probeservices): annotate request and response with their type Dec 16, 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 this pull request may close these issues.

1 participant