/*
* ============================================================================
* GNU General Public License
* ============================================================================
*
* Copyright (C) 2006-2011 Serotonin Software Technologies Inc. http://serotoninsoftware.com
* @author Matthew Lohbihler
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* When signing a commercial license with Serotonin Software Technologies Inc.,
* the following extension to GPL is made. A special exception to the GPL is
* included to allow you to distribute a combined work that includes BAcnet4J
* without being obliged to provide the source code for any proprietary components.
*/
package com.serotonin.bacnet4j.service.confirmed;
import com.serotonin.bacnet4j.LocalDevice;
import com.serotonin.bacnet4j.exception.BACnetException;
import com.serotonin.bacnet4j.exception.NotImplementedException;
import com.serotonin.bacnet4j.service.acknowledgement.AcknowledgementService;
import com.serotonin.bacnet4j.type.constructed.Address;
import com.serotonin.bacnet4j.type.primitive.Boolean;
import com.serotonin.bacnet4j.type.primitive.CharacterString;
import com.serotonin.bacnet4j.type.primitive.OctetString;
import com.serotonin.bacnet4j.type.primitive.UnsignedInteger;
import org.free.bacnet4j.util.ByteQueue;
public class AuthenticateRequest extends ConfirmedRequestService {
private static final long serialVersionUID = 4272319357309373386L;
public static final byte TYPE_ID = 24;
private final UnsignedInteger pseudoRandomNumber;
private final UnsignedInteger expectedInvokeID;
private final CharacterString operatorName;
private final CharacterString operatorPassword;
private final Boolean startEncipheredSession;
public AuthenticateRequest(UnsignedInteger pseudoRandomNumber, UnsignedInteger expectedInvokeID,
CharacterString operatorName, CharacterString operatorPassword, Boolean startEncipheredSession) {
this.pseudoRandomNumber = pseudoRandomNumber;
this.expectedInvokeID = expectedInvokeID;
this.operatorName = operatorName;
this.operatorPassword = operatorPassword;
this.startEncipheredSession = startEncipheredSession;
}
@Override
public byte getChoiceId() {
return TYPE_ID;
}
@Override
public AcknowledgementService handle(LocalDevice localDevice, Address from, OctetString linkService)
throws BACnetException {
throw new NotImplementedException();
}
@Override
public void write(ByteQueue queue) {
write(queue, pseudoRandomNumber, 0);
writeOptional(queue, expectedInvokeID, 1);
writeOptional(queue, operatorName, 2);
writeOptional(queue, operatorPassword, 3);
writeOptional(queue, startEncipheredSession, 4);
}
AuthenticateRequest(ByteQueue queue) throws BACnetException {
pseudoRandomNumber = read(queue, UnsignedInteger.class, 0);
expectedInvokeID = readOptional(queue, UnsignedInteger.class, 1);
operatorName = readOptional(queue, CharacterString.class, 2);
operatorPassword = readOptional(queue, CharacterString.class, 3);
startEncipheredSession = readOptional(queue, Boolean.class, 4);
}
@Override
public int hashCode() {
final int PRIME = 31;
int result = 1;
result = PRIME * result + ((expectedInvokeID == null) ? 0 : expectedInvokeID.hashCode());
result = PRIME * result + ((operatorName == null) ? 0 : operatorName.hashCode());
result = PRIME * result + ((operatorPassword == null) ? 0 : operatorPassword.hashCode());
result = PRIME * result + ((pseudoRandomNumber == null) ? 0 : pseudoRandomNumber.hashCode());
result = PRIME * result + ((startEncipheredSession == null) ? 0 : startEncipheredSession.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
final AuthenticateRequest other = (AuthenticateRequest) obj;
if (expectedInvokeID == null) {
if (other.expectedInvokeID != null)
return false;
}
else if (!expectedInvokeID.equals(other.expectedInvokeID))
return false;
if (operatorName == null) {
if (other.operatorName != null)
return false;
}
else if (!operatorName.equals(other.operatorName))
return false;
if (operatorPassword == null) {
if (other.operatorPassword != null)
return false;
}
else if (!operatorPassword.equals(other.operatorPassword))
return false;
if (pseudoRandomNumber == null) {
if (other.pseudoRandomNumber != null)
return false;
}
else if (!pseudoRandomNumber.equals(other.pseudoRandomNumber))
return false;
if (startEncipheredSession == null) {
if (other.startEncipheredSession != null)
return false;
}
else if (!startEncipheredSession.equals(other.startEncipheredSession))
return false;
return true;
}
}