blob: 7fe1a902367b717da0e7ee640712972cd94135b2 [file] [log] [blame]
/*
* Copyright 2018-present Open Networking Foundation
*
* 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 org.onosproject.mcast.api;
import com.google.common.annotations.Beta;
import com.google.common.base.Objects;
import org.onlab.packet.IpAddress;
import java.util.Optional;
import static com.google.common.base.MoreObjects.toStringHelper;
import static com.google.common.base.Preconditions.checkNotNull;
/**
* An entity representing a multicast route consisting of a source ip
* and a multicast group address.
*/
@Beta
public class McastRoute {
/**
* Possible route types.
*/
public enum Type {
/**
* Route originates from PIM.
*/
PIM,
/**
* Route originates from IGMP.
*/
IGMP,
/**
* Route originates from other config (ie. REST, CLI).
*/
STATIC
}
private final IpAddress source;
private final IpAddress group;
private final Type type;
/**
* Creates the McastRoute object. The source Ip can be null if this route is intent for ASM.
*
* @param source source Ip. Null if ASM route. Will translate in Optional.empty.
* @param group the multicast group
* @param type the route type.
*/
public McastRoute(IpAddress source, IpAddress group, Type type) {
checkNotNull(group, "Multicast route must specify a group address");
this.source = source;
this.group = group;
this.type = type;
}
/**
* Fetches the source address of this route.
*
* @return an optional ip address.
*/
public Optional<IpAddress> source() {
return Optional.ofNullable(source);
}
/**
* Fetches the group address of this route.
*
* @return an ip address
*/
public IpAddress group() {
return group;
}
/**
* Type of this route.
*
* @return type
*/
public Type type() {
return type;
}
@Override
public String toString() {
return toStringHelper(this)
.add("source", source)
.add("group", group)
.add("type", type())
.toString();
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
McastRoute that = (McastRoute) o;
return Objects.equal(source, that.source) &&
Objects.equal(group, that.group) &&
Objects.equal(type, that.type());
}
@Override
public int hashCode() {
return Objects.hashCode(source, group, type);
}
}