-
Notifications
You must be signed in to change notification settings - Fork 57
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
Support HTTP/HEAD data requests #2331
Comments
It would be nice to be able to access the response headers in HTTP GET/POST requests as well. Perhaps using some flag at the source level to indicate whether we want the response body, the headers, or both. That could also be extended to support binary sources as requested in #2274, by being able to specify the body encoding. |
This is the header format we can get from the http library surf:
The value is
And the header order is important. Is it possible to do handle each header as an array using radon? For example we would need ArrayContains to check if a header value exists, and also some operator to enforce the size of the array to 1 and get the value. Or shall we always return only one header? (the first or last instance). Because our HTTP POST headers implementation ignores repeated headers, so should we fix that as well? Although in that case the surf library does not allow us to maintain the order, so if order is important then we may need to change the http library. In the sample HTTP HEAD response:
With the current proposal we will be unable to do anything with the first line (HTTP/1.0 200 OK), so we cannot check the HTTP version or the status code. We also do not get any way to see the order of the headers, but I guess that won't be an important use case. However we could get access to all that information if we use an array instead of a map, and then iterate over the values, or if we keep the headers as a string, and add a new StringParseHttpHeaders operator. Then if we had a StringSplit(\n) operator, we would be able to read the headers one at a time, as well as the http version and status code. We would need to change the http library to implement that, but it should be doable. So, summary, the input of the radon script can be a:
|
Also it looks like the surf client in its current configuration doesn't support HEAD requests because of a bug, see this issue: http-rs/surf#218 (comment) So most probably we will need to use another http client. We are already using isahc which is a low level wrapper around libcurl, and it's also used by surf, so I will create an issue to stop using surf and use isahc directly. |
I don't think we'd need to include first line (transport level) within the data request response (app level). Ofc, it has to be interpreted by the node as to know whether the HTTP/HEAD request was successfull or not. |
The radon script needs to access headers as a map some way or another, as it cannot assume the headers will be returned in any specific pre-known order. |
@guidiaz please ping me before you go about this to discuss some challenges. |
By directly using |
So only the metadata from a web resource is actually fetched in the form of HTTP response headers.
For instance, these HTTP response headers would be quite handfull for implementing content-based use cases with Witnet:
The implementation of HTTP/HEAD requests should:
Also, it would be nice to support a new String operator in Radon:
decodeHash(<encoding_type>)
, as to transform etag literals into properly decoded array of bytes, at least supportingSHA-256
as possible encoding type.Possible new use-cases for Witnet:
Javascript DSL usage example:
The text was updated successfully, but these errors were encountered: