/* * Copyright 2014 Tariq Bugrara * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package io.progix.dropwizard.patch.operations; import io.progix.dropwizard.patch.BasicJsonPatch; import io.progix.dropwizard.patch.JsonPath; import io.progix.dropwizard.patch.exception.InvalidPatchPathException; /** * A handler to contain logic for the patch operation MOVE used in the explicit mode of patching. * <p/> * This handler can be registered to a {@link BasicJsonPatch} in a resource. * <p/> * For more information on what the MOVE patch operation should do, reference RFC6902. */ public interface MoveOperation { /** * Method to contain logic on how a MOVE operation should be preformed for a resource. An {@link * InvalidPatchPathException} should be thrown if the path given is not matched. * * @param from the {@link JsonPath} for the location of the value to be moved. * @param path the {@link JsonPath} for the location the value should be moved to. */ public void move(JsonPath from, JsonPath path); }