*/
package org.opendaylight.netconf.sal.rest.impl;
+import static com.google.common.base.Verify.verify;
+
+import com.google.common.base.Throwables;
import com.google.common.collect.ImmutableList;
import com.google.gson.stream.JsonReader;
import com.google.gson.stream.JsonToken;
import org.opendaylight.netconf.sal.restconf.impl.ControllerContext;
import org.opendaylight.restconf.common.context.InstanceIdentifierContext;
import org.opendaylight.restconf.common.errors.RestconfDocumentedException;
-import org.opendaylight.restconf.common.errors.RestconfError.ErrorTag;
-import org.opendaylight.restconf.common.errors.RestconfError.ErrorType;
import org.opendaylight.restconf.common.patch.PatchContext;
import org.opendaylight.restconf.common.patch.PatchEditOperation;
import org.opendaylight.restconf.common.patch.PatchEntity;
import org.opendaylight.restconf.common.util.RestUtil;
+import org.opendaylight.yangtools.yang.common.ErrorTag;
+import org.opendaylight.yangtools.yang.common.ErrorType;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier.NodeIdentifierWithPredicates;
import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode;
import org.opendaylight.yangtools.yang.data.impl.schema.ImmutableNormalizedNodeStreamWriter;
import org.opendaylight.yangtools.yang.data.impl.schema.NormalizedNodeResult;
import org.opendaylight.yangtools.yang.data.impl.schema.ResultAlreadySetException;
+import org.opendaylight.yangtools.yang.model.api.EffectiveModelContext;
import org.opendaylight.yangtools.yang.model.api.SchemaNode;
-import org.opendaylight.yangtools.yang.model.util.SchemaContextUtil;
+import org.opendaylight.yangtools.yang.model.api.meta.EffectiveStatement;
+import org.opendaylight.yangtools.yang.model.util.SchemaInferenceStack;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
private static final Logger LOG = LoggerFactory.getLogger(JsonToPatchBodyReader.class);
- public JsonToPatchBodyReader(ControllerContext controllerContext) {
+ public JsonToPatchBodyReader(final ControllerContext controllerContext) {
super(controllerContext);
}
private PatchContext readFrom(final InstanceIdentifierContext<?> path, final InputStream entityStream)
throws IOException {
final Optional<InputStream> nonEmptyInputStreamOptional = RestUtil.isInputStreamEmpty(entityStream);
- if (!nonEmptyInputStreamOptional.isPresent()) {
+ if (nonEmptyInputStreamOptional.isEmpty()) {
return new PatchContext(path, null, null);
}
}
private static RuntimeException propagateExceptionAs(final Exception exception) throws RestconfDocumentedException {
- if (exception instanceof RestconfDocumentedException) {
- throw (RestconfDocumentedException)exception;
- }
+ Throwables.throwIfInstanceOf(exception, RestconfDocumentedException.class);
+ LOG.debug("Error parsing json input", exception);
if (exception instanceof ResultAlreadySetException) {
- LOG.debug("Error parsing json input:", exception);
throw new RestconfDocumentedException("Error parsing json input: Failed to create new parse result data. ");
}
+ RestconfDocumentedException.throwIfYangError(exception);
throw new RestconfDocumentedException("Error parsing json input: " + exception.getMessage(), ErrorType.PROTOCOL,
ErrorTag.MALFORMED_MESSAGE, exception);
}
private void readEditDefinition(final @NonNull PatchEdit edit, final @NonNull JsonReader in,
final @NonNull InstanceIdentifierContext<?> path,
final @NonNull StringModuleInstanceIdentifierCodec codec) throws IOException {
- final StringBuffer value = new StringBuffer();
+ final StringBuilder value = new StringBuilder();
in.beginObject();
while (in.hasNext()) {
edit.setTargetSchemaNode(path.getSchemaContext());
} else {
edit.setTarget(codec.deserialize(codec.serialize(path.getInstanceIdentifier()).concat(target)));
- edit.setTargetSchemaNode(SchemaContextUtil.findDataSchemaNode(path.getSchemaContext(),
- codec.getDataContextTree().getChild(edit.getTarget()).getDataSchemaNode().getPath()
- .getParent()));
+
+ final EffectiveStatement<?, ?> parentStmt = SchemaInferenceStack.ofInstantiatedPath(
+ path.getSchemaContext(),
+ codec.getDataContextTree().findChild(edit.getTarget()).orElseThrow().getDataSchemaNode()
+ .getPath().getParent())
+ .currentStatement();
+ verify(parentStmt instanceof SchemaNode, "Unexpected parent %s", parentStmt);
+ edit.setTargetSchemaNode((SchemaNode) parentStmt);
}
break;
* @param in JsonReader reader
* @throws IOException if operation fails
*/
- private void readValueNode(final @NonNull StringBuffer value, final @NonNull JsonReader in) throws IOException {
+ private void readValueNode(final @NonNull StringBuilder value, final @NonNull JsonReader in) throws IOException {
in.beginObject();
- value.append("{");
+ value.append('{');
- value.append("\"" + in.nextName() + "\"" + ":");
+ value.append('"').append(in.nextName()).append("\":");
if (in.peek() == JsonToken.BEGIN_ARRAY) {
in.beginArray();
- value.append("[");
+ value.append('[');
while (in.hasNext()) {
if (in.peek() == JsonToken.STRING) {
- value.append("\"" + in.nextString() + "\"");
+ value.append('"').append(in.nextString()).append('"');
} else {
readValueObject(value, in);
}
if (in.peek() != JsonToken.END_ARRAY) {
- value.append(",");
+ value.append(',');
}
}
in.endArray();
- value.append("]");
+ value.append(']');
} else {
readValueObject(value, in);
}
in.endObject();
- value.append("}");
+ value.append('}');
}
/**
* @param in JsonReader reader
* @throws IOException if operation fails
*/
- private void readValueObject(final @NonNull StringBuffer value, final @NonNull JsonReader in) throws IOException {
+ private void readValueObject(final @NonNull StringBuilder value, final @NonNull JsonReader in) throws IOException {
// read simple leaf value
if (in.peek() == JsonToken.STRING) {
- value.append("\"" + in.nextString() + "\"");
+ value.append('"').append(in.nextString()).append('"');
return;
}
in.beginObject();
- value.append("{");
+ value.append('{');
while (in.hasNext()) {
- value.append("\"" + in.nextName() + "\"");
- value.append(":");
+ value.append('"').append(in.nextName()).append("\":");
if (in.peek() == JsonToken.STRING) {
- value.append("\"" + in.nextString() + "\"");
+ value.append('"').append(in.nextString()).append('"');
} else {
if (in.peek() == JsonToken.BEGIN_ARRAY) {
in.beginArray();
- value.append("[");
+ value.append('[');
while (in.hasNext()) {
if (in.peek() == JsonToken.STRING) {
- value.append("\"" + in.nextString() + "\"");
+ value.append('"').append(in.nextString()).append('"');
} else {
readValueObject(value, in);
}
if (in.peek() != JsonToken.END_ARRAY) {
- value.append(",");
+ value.append(',');
}
}
in.endArray();
- value.append("]");
+ value.append(']');
} else {
readValueObject(value, in);
}
}
if (in.peek() != JsonToken.END_OBJECT) {
- value.append(",");
+ value.append(',');
}
}
in.endObject();
- value.append("}");
+ value.append('}');
}
/**
* @param in reader JsonReader reader
* @return NormalizedNode representing data
*/
- private static NormalizedNode<?, ?> readEditData(final @NonNull JsonReader in,
+ private static NormalizedNode readEditData(final @NonNull JsonReader in,
final @NonNull SchemaNode targetSchemaNode, final @NonNull InstanceIdentifierContext<?> path) {
final NormalizedNodeResult resultHolder = new NormalizedNodeResult();
final NormalizedNodeStreamWriter writer = ImmutableNormalizedNodeStreamWriter.from(resultHolder);
- JsonParserStream.create(writer,
- JSONCodecFactorySupplier.DRAFT_LHOTKA_NETMOD_YANG_JSON_02.getShared(path.getSchemaContext()),
- targetSchemaNode).parse(in);
+ final EffectiveModelContext context = path.getSchemaContext();
+ JsonParserStream.create(writer, JSONCodecFactorySupplier.DRAFT_LHOTKA_NETMOD_YANG_JSON_02.getShared(context),
+ SchemaInferenceStack.ofInstantiatedPath(context, targetSchemaNode.getPath()).toInference())
+ .parse(in);
return resultHolder.getResult();
}
private PatchEditOperation operation;
private YangInstanceIdentifier target;
private SchemaNode targetSchemaNode;
- private NormalizedNode<?, ?> data;
+ private NormalizedNode data;
public String getId() {
return this.id;
this.targetSchemaNode = targetSchemaNode;
}
- public NormalizedNode<?, ?> getData() {
+ public NormalizedNode getData() {
return this.data;
}
- public void setData(final NormalizedNode<?, ?> data) {
+ public void setData(final NormalizedNode data) {
this.data = data;
}