summaryrefslogtreecommitdiff
path: root/src/couchdb/couch_rep.erl
diff options
context:
space:
mode:
Diffstat (limited to 'src/couchdb/couch_rep.erl')
-rw-r--r--src/couchdb/couch_rep.erl27
1 files changed, 24 insertions, 3 deletions
diff --git a/src/couchdb/couch_rep.erl b/src/couchdb/couch_rep.erl
index 4fc1cdd6..99cca65d 100644
--- a/src/couchdb/couch_rep.erl
+++ b/src/couchdb/couch_rep.erl
@@ -379,9 +379,30 @@ open_doc_revs(#http_db{uri=DbUrl, headers=Headers}, DocId, Revs, Options) ->
% latest is only option right now
"latest=true"
end, Options),
- RevsQueryStrs = lists:flatten(?JSON_ENCODE(Revs)),
- Url = DbUrl ++ url_encode(DocId) ++ "?" ++ couch_util:implode(["revs=true", "attachments=true", "open_revs=" ++ RevsQueryStrs ] ++ QueryOptionStrs, "&"),
- JsonResults = do_http_request(Url, get, Headers),
+
+ BaseUrl = DbUrl ++ url_encode(DocId) ++ "?" ++ couch_util:implode(
+ ["revs=true", "attachments=true"] ++ QueryOptionStrs, "&"),
+
+ %% MochiWeb expects URLs < 8KB long, so maybe split into multiple requests
+ MaxN = trunc((8192 - length(BaseUrl))/14),
+
+ JsonResults = case length(Revs) > MaxN of
+ false ->
+ Url = BaseUrl ++ "&open_revs=" ++ lists:flatten(?JSON_ENCODE(Revs)),
+ do_http_request(Url, get, Headers);
+ true ->
+ {_, Rest, Acc} = lists:foldl(
+ fun(Rev, {Count, RevsAcc, AccResults}) when Count =:= MaxN ->
+ QSRevs = lists:flatten(?JSON_ENCODE(lists:reverse(RevsAcc))),
+ Url = BaseUrl ++ "&open_revs=" ++ QSRevs,
+ {1, [Rev], AccResults++do_http_request(Url, get, Headers)};
+ (Rev, {Count, RevsAcc, AccResults}) ->
+ {Count+1, [Rev|RevsAcc], AccResults}
+ end, {0, [], []}, Revs),
+ Acc ++ do_http_request(BaseUrl ++ "&open_revs=" ++
+ lists:flatten(?JSON_ENCODE(lists:reverse(Rest))), get, Headers)
+ end,
+
Results =
lists:map(
fun({[{<<"missing">>, Rev}]}) ->