/**
* TLS-Attacker - A Modular Penetration Testing Framework for TLS
*
* Copyright 2014-2016 Ruhr University Bochum / Hackmanit GmbH
*
* Licensed under Apache License 2.0
* http://www.apache.org/licenses/LICENSE-2.0
*/
package de.rub.nds.tlsattacker.eap;
/**
* Set EAP-TLS Statemachine in Start-State for TLS and send EAP-TLS Start out.
* Change the State if a EAP-TLS Frame was received.
*
* @author Felix Lange <flx.lange@gmail.com>
*/
public class EapTlsStartState implements EapState {
EapolMachine eapolMachine;
int id;
EapFactory eaptlsfactory = new EapTlsFactory();
NetworkHandler nic = NetworkHandler.getInstance();
byte[] data = {};
public EapTlsStartState(EapolMachine eapolMachine, int id) {
this.eapolMachine = eapolMachine;
this.id = id;
}
@Override
public void send() {
EAPFrame eapstart = eaptlsfactory.createFrame("EAPNAK", id);
nic.sendFrame(eapstart.getFrame());
}
@Override
public void sendTLS(byte[] tlspacket) {
}
@Override
public byte[] receive() {
data = nic.receiveFrame();
int id = (int) data[19]; // Get ID
if (data[22] == 0x0d) {
eapolMachine.setState(new HelloState(eapolMachine, id));
} else {
eapolMachine.setState(new EapTlsStartState(eapolMachine, id));
}
return data;
}
@Override
public String getState() {
return "EapTlsStartState";
}
@Override
public int getID() {
return (int) data[19];
}
}