mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 18:05:37 +00:00
dtls: Add ability to set custom GstFlowReturn on callback error
Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/-/merge_requests/2229>
This commit is contained in:
parent
3bdf1e691e
commit
8b8428aec2
2 changed files with 25 additions and 3 deletions
|
@ -101,6 +101,7 @@ struct _GstDtlsConnectionPrivate
|
||||||
GstDtlsConnectionSendCallback send_callback;
|
GstDtlsConnectionSendCallback send_callback;
|
||||||
gpointer send_callback_user_data;
|
gpointer send_callback_user_data;
|
||||||
GDestroyNotify send_callback_destroy_notify;
|
GDestroyNotify send_callback_destroy_notify;
|
||||||
|
GstFlowReturn syscall_flow_return;
|
||||||
|
|
||||||
gboolean timeout_pending;
|
gboolean timeout_pending;
|
||||||
GThreadPool *thread_pool;
|
GThreadPool *thread_pool;
|
||||||
|
@ -600,6 +601,14 @@ gst_dtls_connection_set_send_callback (GstDtlsConnection * self,
|
||||||
g_mutex_unlock (&priv->mutex);
|
g_mutex_unlock (&priv->mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
gst_dtls_connection_set_flow_return (GstDtlsConnection * self,
|
||||||
|
GstFlowReturn flow_ret)
|
||||||
|
{
|
||||||
|
g_return_if_fail (GST_IS_DTLS_CONNECTION (self));
|
||||||
|
self->priv->syscall_flow_return = flow_ret;
|
||||||
|
}
|
||||||
|
|
||||||
GstFlowReturn
|
GstFlowReturn
|
||||||
gst_dtls_connection_process (GstDtlsConnection * self, gpointer data, gsize len,
|
gst_dtls_connection_process (GstDtlsConnection * self, gpointer data, gsize len,
|
||||||
gsize * written, GError ** err)
|
gsize * written, GError ** err)
|
||||||
|
@ -1002,13 +1011,19 @@ handle_error (GstDtlsConnection * self, int ret, GstResourceError error_type,
|
||||||
case SSL_ERROR_WANT_WRITE:
|
case SSL_ERROR_WANT_WRITE:
|
||||||
GST_LOG_OBJECT (self, "SSL wants write");
|
GST_LOG_OBJECT (self, "SSL wants write");
|
||||||
return GST_FLOW_OK;
|
return GST_FLOW_OK;
|
||||||
case SSL_ERROR_SYSCALL:
|
case SSL_ERROR_SYSCALL:{
|
||||||
|
GstFlowReturn rc = GST_FLOW_OK;
|
||||||
/* OpenSSL shouldn't be making real system calls, so we can safely
|
/* OpenSSL shouldn't be making real system calls, so we can safely
|
||||||
* ignore syscall errors. System interactions should happen through
|
* ignore syscall errors. System interactions should happen through
|
||||||
* our BIO.
|
* our BIO.
|
||||||
*/
|
*/
|
||||||
GST_DEBUG_OBJECT (self, "OpenSSL reported a syscall error, ignoring.");
|
if (error_type == GST_RESOURCE_ERROR_WRITE) {
|
||||||
return GST_FLOW_OK;
|
rc = self->priv->syscall_flow_return;
|
||||||
|
}
|
||||||
|
GST_DEBUG_OBJECT (self,
|
||||||
|
"OpenSSL reported a syscall error. flow_return=%i", rc);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
if (self->priv->connection_state != GST_DTLS_CONNECTION_STATE_FAILED) {
|
if (self->priv->connection_state != GST_DTLS_CONNECTION_STATE_FAILED) {
|
||||||
self->priv->connection_state = GST_DTLS_CONNECTION_STATE_FAILED;
|
self->priv->connection_state = GST_DTLS_CONNECTION_STATE_FAILED;
|
||||||
|
@ -1182,6 +1197,7 @@ bio_method_write (BIO * bio, const char *data, int size)
|
||||||
gboolean ret = TRUE;
|
gboolean ret = TRUE;
|
||||||
|
|
||||||
GST_LOG_OBJECT (self, "BIO: writing %d", size);
|
GST_LOG_OBJECT (self, "BIO: writing %d", size);
|
||||||
|
self->priv->syscall_flow_return = GST_FLOW_OK;
|
||||||
|
|
||||||
if (self->priv->send_callback)
|
if (self->priv->send_callback)
|
||||||
ret = self->priv->send_callback (self, data, size,
|
ret = self->priv->send_callback (self, data, size,
|
||||||
|
|
|
@ -118,6 +118,11 @@ typedef gboolean (*GstDtlsConnectionSendCallback) (GstDtlsConnection * connectio
|
||||||
*/
|
*/
|
||||||
void gst_dtls_connection_set_send_callback(GstDtlsConnection *, GstDtlsConnectionSendCallback, gpointer, GDestroyNotify);
|
void gst_dtls_connection_set_send_callback(GstDtlsConnection *, GstDtlsConnectionSendCallback, gpointer, GDestroyNotify);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Sets the GstFlowReturn that be returned from gst_dtls_connection_send() if callback returns FALSE
|
||||||
|
*/
|
||||||
|
void gst_dtls_connection_set_flow_return(GstDtlsConnection *, GstFlowReturn);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Processes data that has been received, the transformation is done in-place.
|
* Processes data that has been received, the transformation is done in-place.
|
||||||
*
|
*
|
||||||
|
@ -142,6 +147,7 @@ GstFlowReturn gst_dtls_connection_process(GstDtlsConnection *, gpointer ptr, gsi
|
||||||
* we received an EOS before.
|
* we received an EOS before.
|
||||||
* - GST_FLOW_ERROR + err if an error happened
|
* - GST_FLOW_ERROR + err if an error happened
|
||||||
* - GST_FLOW_OK + written >= 0 if processing was successful
|
* - GST_FLOW_OK + written >= 0 if processing was successful
|
||||||
|
* - Any GstFlowReturn set with gst_dtls_connection_set_flow_return()
|
||||||
*/
|
*/
|
||||||
GstFlowReturn gst_dtls_connection_send(GstDtlsConnection *, gconstpointer ptr, gsize len, gsize *written, GError **err);
|
GstFlowReturn gst_dtls_connection_send(GstDtlsConnection *, gconstpointer ptr, gsize len, gsize *written, GError **err);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue