
com.azure.resourcemanager.network.models.NextHop Maven / Gradle / Ivy
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.resourcemanager.network.models;
import com.azure.core.annotation.Fluent;
import com.azure.resourcemanager.resources.fluentcore.arm.models.HasParent;
import com.azure.resourcemanager.resources.fluentcore.model.Executable;
/** A client-side representation allowing user to get next hop for a packet from specific vm. */
@Fluent
public interface NextHop extends Executable, HasParent {
/**
* Get the resource identifier of the target resource against which the action is to be performed.
*
* @return the targetResourceId value
*/
String targetResourceId();
/** @return the source IP address */
String sourceIpAddress();
/** @return the destination IP address */
String destinationIpAddress();
/** @return the network interface id */
String targetNetworkInterfaceId();
/** @return the next hop type */
NextHopType nextHopType();
/** @return the next hop IP Address */
String nextHopIpAddress();
/**
* Get the resource identifier for the route table associated with the route being returned. If the route being
* returned does not correspond to any user created routes then this field will be the string 'System Route'.
*
* @return the routeTableId value
*/
String routeTableId();
/** The entirety of next hop parameters definition. */
interface Definition
extends DefinitionStages.WithTargetResource,
DefinitionStages.WithSourceIP,
DefinitionStages.WithDestinationIP,
DefinitionStages.WithExecute {
}
/** Grouping of next hop definition stages. */
interface DefinitionStages {
/** The first stage of next hop parameters definition. */
interface WithTargetResource {
/**
* Set the targetResourceId value.
*
* @param vmId the targetResourceId value to set
* @return the VerificationIPFlow object itself.
*/
WithSourceIP withTargetResourceId(String vmId);
}
/** Sets the source IP address. */
interface WithSourceIP {
/**
* Set the sourceIPAddress value.
*
* @param sourceIPAddress the sourceIPAddress value to set
* @return the VerificationIPFlow object itself.
*/
WithDestinationIP withSourceIpAddress(String sourceIPAddress);
}
/** Sets the destination IP address. */
interface WithDestinationIP {
/**
* Set the destinationIPAddress value.
*
* @param destinationIPAddress the destinationIPAddress value to set
* @return the VerificationIPFlow object itself.
*/
WithExecute withDestinationIpAddress(String destinationIPAddress);
}
/**
* Sets the NIC ID. (If VM has multiple NICs and IP forwarding is enabled on any of the nics, then this
* parameter must be specified. Otherwise optional).
*/
interface WithNetworkInterface {
/**
* Set the targetNetworkInterfaceId value.
*
* @param targetNetworkInterfaceId the targetNetworkInterfaceId value to set
* @return the VerificationIPFlow object itself.
*/
WithExecute withTargetNetworkInterfaceId(String targetNetworkInterfaceId);
}
/**
* The stage of the definition which contains all the minimum required inputs for execution, but also allows for
* any other optional settings to be specified.
*/
interface WithExecute extends Executable, WithNetworkInterface {
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy