METHOD(tls_t, is_complete, bool,
private_tls_t *this)
{
- return this->crypto->get_eap_msk(this->crypto).len != 0;
+ if (this->handshake->finished(this->handshake))
+ {
+ if (!this->application)
+ {
+ return TRUE;
+ }
+ return this->fragmentation->application_finished(this->fragmentation);
+ }
+ return FALSE;
}
METHOD(tls_t, get_eap_msk, chunk_t,
*/
alert_state_t state;
+ /**
+ * Did the application layer complete successfully?
+ */
+ bool application_finished;
+
/**
* Handshake input buffer
*/
return NEED_MORE;
}
status = this->application->process(this->application, reader);
- if (status != NEED_MORE)
+ switch (status)
{
- this->alert->add(this->alert, TLS_FATAL, TLS_CLOSE_NOTIFY);
- return NEED_MORE;
+ case NEED_MORE:
+ continue;
+ case SUCCESS:
+ this->application_finished = TRUE;
+ /* FALL */
+ case FAILED:
+ default:
+ this->alert->add(this->alert, TLS_FATAL, TLS_CLOSE_NOTIFY);
+ return NEED_MORE;
}
}
return NEED_MORE;
{
if (this->application)
{
- status = this->application->build(this->application, msg);
- if (status == INVALID_STATE)
+ while (TRUE)
{
- *type = TLS_APPLICATION_DATA;
- this->output = chunk_clone(msg->get_buf(msg));
- }
- else if (status != NEED_MORE)
- {
- this->alert->add(this->alert, TLS_FATAL, TLS_CLOSE_NOTIFY);
- if (check_alerts(this, data))
+ status = this->application->build(this->application, msg);
+ switch (status)
{
- this->state = ALERT_SENDING;
- *type = TLS_ALERT;
- return NEED_MORE;
+ case NEED_MORE:
+ continue;
+ case INVALID_STATE:
+ *type = TLS_APPLICATION_DATA;
+ this->output = chunk_clone(msg->get_buf(msg));
+ break;
+ case SUCCESS:
+ this->application_finished = TRUE;
+ /* FALL */
+ case FAILED:
+ default:
+ this->alert->add(this->alert, TLS_FATAL,
+ TLS_CLOSE_NOTIFY);
+ if (check_alerts(this, data))
+ {
+ this->state = ALERT_SENDING;
+ *type = TLS_ALERT;
+ msg->destroy(msg);
+ return NEED_MORE;
+ }
}
+ break;
}
}
}
return status;
}
+METHOD(tls_fragmentation_t, application_finished, bool,
+ private_tls_fragmentation_t *this)
+{
+ return this->application_finished;
+}
+
METHOD(tls_fragmentation_t, destroy, void,
private_tls_fragmentation_t *this)
{
.public = {
.process = _process,
.build = _build,
+ .application_finished = _application_finished,
.destroy = _destroy,
},
.handshake = handshake,
status_t (*build)(tls_fragmentation_t *this,
tls_content_type_t *type, chunk_t *data);
+ /**
+ * Has the application layer finished (returned SUCCESS)?.
+ *
+ * @return TRUE if application layer finished
+ */
+ bool (*application_finished)(tls_fragmentation_t *this);
+
/**
* Destroy a tls_fragmentation_t.
*/