summaryrefslogtreecommitdiff
path: root/src/couchdb/couch_doc.erl
diff options
context:
space:
mode:
Diffstat (limited to 'src/couchdb/couch_doc.erl')
-rw-r--r--src/couchdb/couch_doc.erl133
1 files changed, 75 insertions, 58 deletions
diff --git a/src/couchdb/couch_doc.erl b/src/couchdb/couch_doc.erl
index 56d559ea..3e0a8614 100644
--- a/src/couchdb/couch_doc.erl
+++ b/src/couchdb/couch_doc.erl
@@ -18,65 +18,82 @@
-include("couch_db.hrl").
-to_json_obj(#doc{id=Id,deleted=Del,body=Body,revs=Revs,meta=Meta}=Doc,Options)->
- {[{<<"_id">>, Id}] ++
- case Revs of
+% helpers used by to_json_obj
+to_json_rev([]) ->
+ [];
+to_json_rev(Revs) ->
+ [{<<"_rev">>, lists:nth(1, Revs)}].
+
+to_json_body(true, _Body) ->
+ [{<<"_deleted">>, true}];
+to_json_body(false, {Body}) ->
+ Body.
+
+to_json_revs(Options, Revs) ->
+ case lists:member(revs, Options) of
+ false -> [];
+ true ->
+ [{<<"_revs">>, Revs}]
+ end.
+
+to_json_revs_info(Meta) ->
+ lists:map(
+ fun({revs_info, RevsInfo}) ->
+ JsonRevsInfo =
+ [{[{rev, Rev}, {status, list_to_binary(atom_to_list(Status))}]} ||
+ {Rev, Status} <- RevsInfo],
+ {<<"_revs_info">>, JsonRevsInfo};
+ ({conflicts, Conflicts}) ->
+ {<<"_conflicts">>, Conflicts};
+ ({deleted_conflicts, Conflicts}) ->
+ {<<"_deleted_conflicts">>, Conflicts}
+ end, Meta).
+
+to_json_attachment_stubs(Attachments) ->
+ BinProps = lists:map(
+ fun({Name, {Type, BinValue}}) ->
+ {Name, {[
+ {<<"stub">>, true},
+ {<<"content_type">>, Type},
+ {<<"length">>, bin_size(BinValue)}
+ ]}}
+ end,
+ Attachments),
+ case BinProps of
[] -> [];
- _ -> [{<<"_rev">>, lists:nth(1, Revs)}]
- end ++
- case Del of
- false ->
- {BodyProps} = Body,
- BodyProps;
- true ->
- [{<<"_deleted">>, true}]
- end ++
- case lists:member(revs, Options) of
- false -> [];
- true ->
- [{<<"_revs">>, Revs}]
- end ++
- lists:map(
- fun({revs_info, RevsInfo}) ->
- JsonRevsInfo =
- [{[{rev, Rev}, {status, list_to_binary(atom_to_list(Status))}]} ||
- {Rev, Status} <- RevsInfo],
- {<<"_revs_info">>, JsonRevsInfo};
- ({conflicts, Conflicts}) ->
- {<<"_conflicts">>, Conflicts};
- ({deleted_conflicts, Conflicts}) ->
- {<<"_deleted_conflicts">>, Conflicts}
- end, Meta) ++
- case lists:member(attachments, Options) of
- true -> % return the full rev list and the binaries as strings.
- BinProps = lists:map(
- fun({Name, {Type, BinValue}}) ->
- {Name, {[
- {<<"content_type">>, Type},
- {<<"data">>, couch_util:encodeBase64(bin_to_binary(BinValue))}
- ]}}
- end,
- Doc#doc.attachments),
- case BinProps of
- [] -> [];
- _ -> [{<<"_attachments">>, {BinProps}}]
- end;
- false ->
- BinProps = lists:map(
- fun({Name, {Type, BinValue}}) ->
- {Name, {[
- {<<"stub">>, true},
- {<<"content_type">>, Type},
- {<<"length">>, bin_size(BinValue)}
- ]}}
- end,
- Doc#doc.attachments),
- case BinProps of
- [] -> [];
- _ -> [{<<"_attachments">>, {BinProps}}]
- end
- end
- }.
+ _ -> [{<<"_attachments">>, {BinProps}}]
+ end.
+
+to_json_attachments(Attachments) ->
+ BinProps = lists:map(
+ fun({Name, {Type, BinValue}}) ->
+ {Name, {[
+ {<<"content_type">>, Type},
+ {<<"data">>, couch_util:encodeBase64(bin_to_binary(BinValue))}
+ ]}}
+ end,
+ Attachments),
+ case BinProps of
+ [] -> [];
+ _ -> [{<<"_attachments">>, {BinProps}}]
+ end.
+
+to_json_attachments(Attachments, Options) ->
+ case lists:member(attachments, Options) of
+ true -> % return the full rev list and the binaries as strings.
+ to_json_attachments(Attachments);
+ false ->
+ to_json_attachment_stubs(Attachments)
+ end.
+
+to_json_obj(#doc{id=Id,deleted=Del,body=Body,revs=Revs,meta=Meta}=Doc,Options)->
+ {[{<<"_id">>, Id}]
+ ++ to_json_rev(Revs)
+ ++ to_json_body(Del, Body)
+ ++ to_json_revs(Options, Revs)
+ ++ to_json_revs_info(Meta)
+ ++ to_json_attachments(Doc#doc.attachments, Options)
+ }.
from_json_obj({Props}) ->
{JsonBins} = proplists:get_value(<<"_attachments">>, Props, {[]}),