All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.azure.core.models.JsonPatchOperation Maven / Gradle / Ivy

There is a newer version: 1.54.1
Show newest version
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.

package com.azure.core.models;

import com.azure.core.annotation.Immutable;
import com.azure.core.implementation.Option;
import com.azure.json.JsonReader;
import com.azure.json.JsonSerializable;
import com.azure.json.JsonToken;
import com.azure.json.JsonWriter;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;

import java.io.IOException;
import java.util.Objects;
import java.util.Optional;

/**
 * 

Represents a JSON Patch operation.

* *

This class encapsulates a single operation in a JSON Patch document. Each operation is defined by its kind * (add, replace, remove, etc.), a path pointing to the location within the target JSON document, an optional * 'from' path for copy and move operations, and an optional value.

* *

This class also provides a {@link #toJson(JsonWriter)} method to serialize the JSON Patch operation to JSON, * and a {@link #fromJson(JsonReader)} method to deserialize a JSON Patch operation from JSON.

* *

This class is useful when you want to create a JSON Patch operation to be included in a JSON Patch document. * For example, you can use it to represent an operation that adds a new property to a JSON object, replaces the * value of a property, or removes a property.

* * @see JsonPatchOperationKind * @see JsonSerializable * @see JsonWriter * @see JsonReader */ @Immutable @JsonSerialize(using = JsonPatchOperationSerializer.class) final class JsonPatchOperation implements JsonSerializable { private final JsonPatchOperationKind op; private final String from; private final String path; private final Option value; /** * Creates a JSON Patch operation. *

* When {@code optionalValue} is null the value won't be included in the JSON request, use {@link Optional#empty()} * to indicate a JSON null. * * @param op The kind of operation. * @param from Optional from target path. * @param path Operation target path. * @param value Optional value. */ JsonPatchOperation(JsonPatchOperationKind op, String from, String path, Option value) { this.op = op; this.from = from; this.path = path; this.value = value; } /** * Gets the operation kind. * * @return The kind of operation. */ JsonPatchOperationKind getOp() { return op; } /** * Gets the operation from target path. * * @return The operation from target path. */ String getFrom() { return from; } /** * Gets the operation target path. * * @return The operation target path. */ String getPath() { return path; } /** * Gets the operation value. *

* If the operation doesn't take a value {@link Option#uninitialized()} will be returned. * * @return The operation value. */ Option getValue() { return value; } @Override public int hashCode() { return Objects.hash(op.toString(), from, path, (value == null) ? null : value.getValue()); } @Override public boolean equals(Object obj) { if (!(obj instanceof JsonPatchOperation)) { return false; } if (this == obj) { return true; } JsonPatchOperation other = (JsonPatchOperation) obj; return Objects.equals(op, other.op) && Objects.equals(from, other.from) && Objects.equals(path, other.path) && Objects.equals(value, other.value); } @Override public String toString() { return buildString(new StringBuilder()).toString(); } StringBuilder buildString(StringBuilder builder) { builder.append("{\"op\":\"").append(op.toString()).append("\""); if (from != null) { builder.append(",\"from\":\"").append(from).append("\""); } builder.append(",\"path\":\"").append(path).append("\""); if (value.isInitialized()) { builder.append(",\"value\":").append(value.getValue()); } return builder.append("}"); } @Override public JsonWriter toJson(JsonWriter jsonWriter) throws IOException { jsonWriter.writeStartObject() .writeStringField("op", op.toString()) .writeStringField("from", from) .writeStringField("path", path); if (value.isInitialized()) { String valueString = value.getValue(); if (valueString == null) { jsonWriter.writeNullField("value"); } else { jsonWriter.writeRawField("value", value.getValue()); } } return jsonWriter.writeEndObject(); } /** * Reads a JSON stream into a {@link JsonPatchOperation}. * * @param jsonReader The {@link JsonReader} being read. * @return The {@link JsonPatchOperation} that the JSON stream represented, or null if it pointed to JSON null. * @throws IllegalStateException If the deserialized JSON object was missing any required properties. * @throws IOException If a {@link JsonPatchOperation} fails to be read from the {@code jsonReader}. */ public static JsonPatchOperation fromJson(JsonReader jsonReader) throws IOException { return jsonReader.readObject(reader -> { JsonPatchOperationKind op = null; String from = null; String path = null; Option value = Option.uninitialized(); while (reader.nextToken() != JsonToken.END_OBJECT) { String fieldName = reader.getFieldName(); reader.nextToken(); if ("op".equals(fieldName)) { op = JsonPatchOperationKind.fromString(reader.getString()); } else if ("from".equals(fieldName)) { from = reader.getString(); } else if ("path".equals(fieldName)) { path = reader.getString(); } else if ("value".equals(fieldName)) { value = Option.of(reader.getString()); } else { reader.skipChildren(); } } return new JsonPatchOperation(op, from, path, value); }); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy