diff options
author | Andre Heinecke <[email protected]> | 2018-06-07 15:48:55 +0000 |
---|---|---|
committer | Andre Heinecke <[email protected]> | 2018-06-08 08:29:59 +0000 |
commit | af8510fb7f4d5c90cc53f10dcc740f377af73d68 (patch) | |
tree | 39e4e65729cd84c0b4537a428434590a3f6b5e15 /tests | |
parent | json: Rework verify_result_to_json (diff) | |
download | gpgme-af8510fb7f4d5c90cc53f10dcc740f377af73d68.tar.gz gpgme-af8510fb7f4d5c90cc53f10dcc740f377af73d68.zip |
json: Generalize chunking and getmore
* src/gpgme-json.c (MIN_REPLY_CHUNK_SIZE): Lower value to
new real minimum.
(DEF_REPLY_CHUNK_SIZE): Don't chunk by default.
(pending_data): Remove type and base64.
(make_data_object): Remove chunksize handling as this is now
generic.
(encode_and_chunk): Setup the pending_data buffer for chunking
if required.
(op_getmore): Changed to generically work on a response.
(hlp_getmore): Update accordingly.
(hlp_help): Document chunksize as generic parameter for all commands.
(process_request): Use encode_and_chunk on the response.
(hlp_encrypt, op_encrypt, hlp_decrypt, op_decrypt),
(hlp_verify, op_verify, hlp_sign, op_sign),
(op_keylist, hlp_keylist, hlp_export, op_export): Update accordingly.
--
To include handling for json properties e.g. in a keylist in
the chunk mechanism the mechanism is now more general.
If the chunksize property is provided the response will
always look exactly like a "getmore" response. E.g.
e.g.:
{
"op": "keylist",
"chunksize": 64
}
Results in:
{
"more": true,
"base64": true,
"response": "ewoJImtleXMiOglbewoJCQkicmV2b2tlZCI6"
}
For simplicity this is even true if the chunksize is larger
then the response.
The client has to combine all "response" chunks and base64
decode them to get valid json.
The complete response (including json) is never larger then
the chunksize but might be smaller. Except for interactive
use due to additional format characters.
Diffstat (limited to 'tests')
0 files changed, 0 insertions, 0 deletions