com.azure.core.annotation.Patch Maven / Gradle / Ivy
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.core.annotation;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
/**
* HTTP PATCH method annotation describing the parameterized relative path to a REST endpoint for resource update.
*
* The required value can be either a relative path or an absolute path. When it's an absolute path, it must start
* with a protocol or a parameterized segment (Otherwise the parse cannot tell if it's absolute or relative).
*
* Example 1: Relative path segments
*
*
* {@literal @}Patch("subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/
* Microsoft.Compute/virtualMachines/{vmName}")
* VirtualMachine patch(@PathParam("resourceGroupName") String rgName, @PathParam("vmName") String
* vmName, @PathParam("subscriptionId") String subscriptionId, @BodyParam VirtualMachineUpdateParameters
* updateParameters);
*
* Example 2: Absolute path segment
*
*
* {@literal @}Patch({vaultBaseUrl}/secrets/{secretName})
* Secret patch(@PathParam("vaultBaseUrl" encoded = true) String vaultBaseUrl, @PathParam("secretName") String
* secretName, @BodyParam SecretUpdateParameters updateParameters);
*/
@Retention(RUNTIME)
@Target(METHOD)
public @interface Patch {
/**
* Get the relative path of the annotated method's PATCH URL.
*
* @return The relative path of the annotated method's PATCH URL.
*/
String value();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy