Unpack jbvBinary objects passed to pushJsonbValue
authorAndrew Dunstan <andrew@dunslane.net>
Fri, 22 May 2015 14:21:41 +0000 (10:21 -0400)
committerAndrew Dunstan <andrew@dunslane.net>
Fri, 22 May 2015 14:21:41 +0000 (10:21 -0400)
commit5302760a50332a684e35b9865ff47ff5fd4970c2
tree35e0a5c42e1cd1530ef599589105a434125e03a8
parent6d1733fa90a3f8037c7c815ed6ab4d97c295e525
Unpack jbvBinary objects passed to pushJsonbValue

pushJsonbValue was accepting jbvBinary objects passed as WJB_ELEM or
WJB_VALUE data. While this succeeded, when those objects were later
encountered in attempting to convert the result to Jsonb, errors
occurred. With this change we ghuarantee that a JSonbValue constructed
from calls to pushJsonbValue does not contain any jbvBinary objects.
This cures a problem observed with jsonb_delete.

This means callers of pushJsonbValue no longer need to perform this
unpacking themselves. A subsequent patch will perform some cleanup in
that area.

The error was not triggered by any 9.4 code, but this is a publicly
visible routine, and so the error could be exercised by third party
code, therefore backpatch to 9.4.

Bug report from Peter Geoghegan, fix by me.
src/backend/utils/adt/jsonb_util.c
src/include/utils/jsonb.h