3 * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
5 * This program and the accompanying materials are made available under the
6 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
7 * and is available at http://www.eclipse.org/legal/epl-v10.html
10 package org.opendaylight.controller.sal.action;
12 import javax.xml.bind.annotation.XmlAccessType;
13 import javax.xml.bind.annotation.XmlAccessorType;
14 import javax.xml.bind.annotation.XmlElement;
15 import javax.xml.bind.annotation.XmlRootElement;
17 import org.apache.commons.lang3.builder.EqualsBuilder;
18 import org.apache.commons.lang3.builder.HashCodeBuilder;
19 import org.opendaylight.controller.sal.utils.HexEncode;
22 * Set source datalayer address action
26 @XmlAccessorType(XmlAccessType.NONE)
28 public class SetDlSrc extends Action {
29 private byte[] address;
31 /* Dummy constructor for JAXB */
35 public SetDlSrc(byte[] dlAddress) {
36 type = ActionType.SET_DL_SRC;
37 if (dlAddress != null) {
38 this.address = dlAddress.clone();
45 * Returns the datalayer address that this action will set
49 public byte[] getDlAddress() {
50 return address.clone();
53 @XmlElement(name = "address")
54 public String getDlAddressString() {
55 return HexEncode.bytesToHexString(address);
59 public boolean equals(Object other) {
60 return EqualsBuilder.reflectionEquals(this, other);
64 public int hashCode() {
65 return HashCodeBuilder.reflectionHashCode(this);
69 public String toString() {
70 return type + "[address = " + HexEncode.bytesToHexString(address) + "]";