-
Notifications
You must be signed in to change notification settings - Fork 7
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
Request body serialization #81
Comments
In the current spec, it would look like this (see the bottom of this comment for a version that includes the embedded serialization): let $data := file:read-binary(...) (: xs:base64Binary :)
return (
(: Send Binary :)
http:post('url', $data)
(: Send Base64 :)
http:post('url', fn:serialize($data), map { 'headers': { map: 'Content-Type': 'application/octet-stream' } }
)
When generating a Content-Type header string for textual data (strings, XML, JSON), we should definitely append UTF-8 as encoding (
This would lead to an I would have preferred to keep serialization out of the spec (because it’s something that already exists outside the spec), but the major restriction may be that fn:serialize cannot be used to generate results in other encodings (because the encoding parameter is ignored), and we have no alternative for serializing data to a binary representation.
I think it’s simple like that! The cast should suffice in most scenarios; and in the remaining cases, users can still define their own Content-Type and use custom serialization. The Here are some suggestions on how function calls with optional serialization could look like: (: Binary data; generated Content-Type string: "application/octet-stream" :)
http:post('url', $base64)
(: Base64 string; generated Content-Type string: "text/plain;charset=UTF-8" :)
http:post('url', string($base64))
(: String with custom encoding; generated Content-Type string: "text/plain;charset=Shift-JIS" :)
http:post('url', '日本', map { 'serialize': map { 'encoding': 'Shift-JIS' } })
(: html5; generated Content-Type string: "text/html;charset=UTF-8" :)
http:post(
'url',
<html/>,
map { 'serialize': map { 'method': 'html', 'version': '5.0' } }
) |
@adamretter: Would you like me to create a little PR for this solution? |
Hmm... So you are proposing to add the XSLT and XQuery Serialization 3.1 to the If so that seems reasonable to me :-)
This would match what users are used to with the One moment though... I wonder if perhaps we are going to far in offering convenience? Are there any use-cases where we could not just have the user use So I think I am arguing with myself here, but it is good to think about this. I think overall, it is okay to add the same/similar functionality of fn:serialize into the http client functions, as it allows for much easier implementation of efficient sending of the data over the network, without having to write complex XQuery optimizations. Also for the user, it is convenient. |
What about adding all XSER 3.1 parameters as possible properties in the
The spec is already there, and addresses this very topic (and it is part of the common ground between all implementations.) And it supports JSON and HTML5. |
It was mostly the unresolved encoding issue (see e.g. the Shift-JIS example above) why I thought about readding the serialization parameters to the spec – in the beginning, I hoped that we could get rid of it. We would need to clarify which Content-Type header value will be generated for the available serialization methods (the rules might be equal to the ones in version 1.0 of the spec). My initial hope was to keep the new specification as compact as possible. I’m not sure if this might be confusing for some users? An alternative could be to let users serialize their data and introduce an |
By simply listing the parameters and their possible values in an appendix, and liking to the XSER spec, that is compact, clear, and comprehensive at the same time. Because of the specificities of defining a HTTP Client, there might be a few details to deal with besides the XSER, like the impact on |
Talking about the impact on |
I think we could just have a We should not reproduce XSER 3.1 in our spec or list all the options. Instead we should just link to it. Most of our target audience are already familiar with it |
@adamretter I might be mislead as I am not familiar with the current format of
instead of simply:
|
@ChristianGruen Yes, something like that. But a bit more sophisticated, e.g. if using |
@fgeorges please examine Also using a property like $serialization allows serialization options to be reused, it also fits with the design of other XP 3.1 fn: functions |
As Adam pointed out in the past, ISO-8859-1 is the default HTTP encoding, so we should probably always add the charset (by default
This syntax may be more compact, but I am not sure if we should simply merge keys from different specs (even now when it is unlikely that we’ll have a future serialization spec with conflicting keys). Instead, I would opt for a dedicated option, in analogy with e.g. file:write) in the EXPath File Module. |
I think we need better controls over Request body serialization. Some concerns I have:
What happens when you actually want to send base64 encoded or hex encoded data?
What happens when you need an encoding which is not UTF-8? For example the HTTP 1.1 default of ISO-8559-1
What happens when you want to send HTML5?
What happens when you try and serialize a map which has something in it which cannot be serialized to JSON like a
function()
or sequence of more than one item?Of course we already have a lovely spec that clearly defines such things - XSLT and XQuery Serialization 3.1.
I think the above serialization rules are actually fine as the defaults, but that we need to be able to offer greater control over serialization to the user. I would propose that we add an additional arity set of function signatures which take a
$serialization-parameters
argument which follows the example offn:serialize
and uses the rules of the XSLT and XQuery Serialization 3.1.I am not quite sure what to do with regards sending base64 binary data, perhaps it is as simple as
$binary cast as xs:string
? Perhaps we might want to introduce abinary
serialization method and any additional parameters that we need for that, so that we can control base64 and hex binary serialization.The text was updated successfully, but these errors were encountered: