|
22 | 22 | import org.slf4j.Logger;
|
23 | 23 | import org.slf4j.LoggerFactory;
|
24 | 24 |
|
| 25 | +import com.fasterxml.jackson.databind.node.JsonNodeFactory; |
| 26 | + |
25 | 27 | import com.redhat.lightblue.OperationStatus;
|
26 | 28 |
|
27 | 29 | import com.redhat.lightblue.crud.CRUDController;
|
|
33 | 35 | import com.redhat.lightblue.metadata.EntityMetadata;
|
34 | 36 |
|
35 | 37 | import com.redhat.lightblue.util.JsonDoc;
|
| 38 | +import com.redhat.lightblue.util.Path; |
36 | 39 |
|
37 | 40 | public class SimpleFindImpl implements Finder {
|
38 | 41 |
|
@@ -65,13 +68,24 @@ public void explain(OperationContext ctx,
|
65 | 68 | CRUDFindRequest req) {
|
66 | 69 | if(controller instanceof ExplainQuerySupport) {
|
67 | 70 | JsonDoc doc=new JsonDoc(ctx.getFactory().getNodeFactory().objectNode());
|
| 71 | + if(req.getQuery()!=null) |
| 72 | + doc.modify(new Path("request.query"),req.getQuery().toJson(),true); |
| 73 | + if(req.getProjection()!=null) |
| 74 | + doc.modify(new Path("request.projection"),req.getProjection().toJson(),true); |
| 75 | + if(req.getSort()!=null) |
| 76 | + doc.modify(new Path("request.sort"),req.getSort().toJson(),true); |
| 77 | + if(req.getFrom()!=null) |
| 78 | + doc.modify(new Path("request.from"),JsonNodeFactory.instance.numberNode(req.getFrom()),true); |
| 79 | + if(req.getTo()!=null) |
| 80 | + doc.modify(new Path("request.to"),JsonNodeFactory.instance.numberNode(req.getTo()),true); |
68 | 81 | ((ExplainQuerySupport)controller).explain(ctx,
|
69 | 82 | req.getQuery(),
|
70 | 83 | req.getProjection(),
|
71 | 84 | req.getSort(),
|
72 | 85 | req.getFrom(),
|
73 | 86 | req.getTo(),
|
74 | 87 | doc);
|
| 88 | + LOGGER.debug("Adding explain doc:{}",doc); |
75 | 89 | ctx.addDocument(doc);
|
76 | 90 | }
|
77 | 91 | }
|
|
0 commit comments