import javax.ws.rs.WebApplicationException;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.MultivaluedMap;
-import javax.ws.rs.core.Response;
import javax.ws.rs.ext.MessageBodyWriter;
import javax.ws.rs.ext.Provider;
import org.opendaylight.controller.sal.rest.api.Draft02;
import org.opendaylight.controller.sal.rest.api.RestconfService;
import org.opendaylight.controller.sal.restconf.impl.InstanceIdentifierContext;
import org.opendaylight.controller.sal.restconf.impl.NormalizedNodeContext;
-import org.opendaylight.controller.sal.restconf.impl.RestconfDocumentedException;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.PathArgument;
import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode;
import org.opendaylight.yangtools.yang.data.api.schema.DataContainerChild;
throws IOException, WebApplicationException {
NormalizedNode<?, ?> data = t.getData();
if (data == null) {
- throw new RestconfDocumentedException(Response.Status.NOT_FOUND);
+ return;
}
- final InstanceIdentifierContext context = t.getInstanceIdentifierContext();
+ final InstanceIdentifierContext<DataSchemaNode> context = (InstanceIdentifierContext<DataSchemaNode>) t.getInstanceIdentifierContext();
SchemaPath path = context.getSchemaNode().getPath();
boolean isDataRoot = false;
// FIXME: Add proper handling of reading root.
}
- JsonWriter jsonWriter = createJsonWriter(entityStream);
- NormalizedNodeWriter nnWriter = createNormalizedNodeWriter(context,path,jsonWriter);
+ final JsonWriter jsonWriter = createJsonWriter(entityStream);
+ final NormalizedNodeWriter nnWriter = createNormalizedNodeWriter(context,path,jsonWriter);
jsonWriter.beginObject();
if(isDataRoot) {
jsonWriter.flush();
}
- private NormalizedNodeWriter createNormalizedNodeWriter(InstanceIdentifierContext context, SchemaPath path, JsonWriter jsonWriter) {
+ private NormalizedNodeWriter createNormalizedNodeWriter(final InstanceIdentifierContext<DataSchemaNode> context,
+ final SchemaPath path, final JsonWriter jsonWriter) {
final DataSchemaNode schema = context.getSchemaNode();
final JSONCodecFactory codecs = getCodecFactory(context);
return NormalizedNodeWriter.forStreamWriter(streamWriter);
}
- private JsonWriter createJsonWriter(OutputStream entityStream) {
+ private JsonWriter createJsonWriter(final OutputStream entityStream) {
// FIXME BUG-2153: Add pretty print support
return JsonWriterFactory.createJsonWriter(new OutputStreamWriter(entityStream, Charsets.UTF_8));
}
- private JSONCodecFactory getCodecFactory(InstanceIdentifierContext context) {
+ private JSONCodecFactory getCodecFactory(final InstanceIdentifierContext context) {
// TODO: Performance: Cache JSON Codec factory and schema context
return JSONCodecFactory.create(context.getSchemaContext());
}
private void writeDataRoot(final NormalizedNodeWriter nnWriter, final ContainerNode data) throws IOException {
- for(DataContainerChild<? extends PathArgument, ?> child : data.getValue()) {
+ for(final DataContainerChild<? extends PathArgument, ?> child : data.getValue()) {
nnWriter.write(child);
}
}