summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEric Avdey <eiri@eiri.ca>2019-02-01 12:41:54 -0400
committerEric Avdey <eiri@eiri.ca>2019-02-04 21:55:25 -0400
commit9517b260951c6e62c6190a9ccc15a8e28d8cfa63 (patch)
tree5688a2ccde4980067a42f00c58517166ca894634
parentd3618bf0d5a275d669c2a846279c458ceb4b6a97 (diff)
downloadcouchdb-9517b260951c6e62c6190a9ccc15a8e28d8cfa63.tar.gz
Fix from_json_obj_validate crash when provided rev isn't a valid hex
-rw-r--r--src/couch/src/couch_doc.erl13
-rw-r--r--src/couch/test/couch_doc_json_tests.erl6
2 files changed, 16 insertions, 3 deletions
diff --git a/src/couch/src/couch_doc.erl b/src/couch/src/couch_doc.erl
index e5ad9e9f1..2a2b4db68 100644
--- a/src/couch/src/couch_doc.erl
+++ b/src/couch/src/couch_doc.erl
@@ -275,9 +275,16 @@ transfer_fields([{<<"_revisions">>, {Props}} | Rest], Doc, DbName) ->
true ->
ok
end,
- [throw({doc_validation, "RevId isn't a string"}) ||
- RevId <- RevIds, not is_binary(RevId)],
- RevIds2 = [parse_revid(RevId) || RevId <- RevIds],
+ RevIds2 = lists:map(fun(RevId) ->
+ try
+ parse_revid(RevId)
+ catch
+ error:function_clause ->
+ throw({doc_validation, "RevId isn't a string"});
+ error:badarg ->
+ throw({doc_validation, "RevId isn't a valid hexadecimal"})
+ end
+ end, RevIds),
transfer_fields(Rest, Doc#doc{revs={Start, RevIds2}}, DbName);
transfer_fields([{<<"_deleted">>, B} | Rest], Doc, DbName) when is_boolean(B) ->
diff --git a/src/couch/test/couch_doc_json_tests.erl b/src/couch/test/couch_doc_json_tests.erl
index 848bae888..51f228900 100644
--- a/src/couch/test/couch_doc_json_tests.erl
+++ b/src/couch/test/couch_doc_json_tests.erl
@@ -270,6 +270,12 @@ from_json_error_cases() ->
"Revision ids must be strings."
},
{
+ {[{<<"_revisions">>, {[{<<"start">>, 0},
+ {<<"ids">>, [<<"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx">>]}]}}]},
+ {doc_validation, "RevId isn't a valid hexadecimal"},
+ "Revision ids must be a valid hex."
+ },
+ {
{[{<<"_something">>, 5}]},
{doc_validation, <<"Bad special document member: _something">>},
"Underscore prefix fields are reserved."