diff options
author | Thijs Vermeir <thijsvermeir@gmail.com> | 2007-09-18 16:32:19 +0000 |
---|---|---|
committer | Thijs Vermeir <thijsvermeir@gmail.com> | 2007-09-18 16:32:19 +0000 |
commit | f9d615c2500a8cedb474a7ee4abe4b7edf4773f6 (patch) | |
tree | bb4771b8b92f189dbec509def66faed6144b9835 /gst/librfb | |
parent | c364c7d630e8a2bb8c11c84a19897431bbfce902 (diff) | |
download | gst-plugins-bad-f9d615c2500a8cedb474a7ee4abe4b7edf4773f6.tar.gz gst-plugins-bad-f9d615c2500a8cedb474a7ee4abe4b7edf4773f6.tar.bz2 gst-plugins-bad-f9d615c2500a8cedb474a7ee4abe4b7edf4773f6.zip |
gst/librfb/rfbdecoder.*: Added some documentation about security handling start implementing security handling for rf...
Original commit message from CVS:
* gst/librfb/rfbdecoder.c:
* gst/librfb/rfbdecoder.h:
Added some documentation about security handling
start implementing security handling for rfb 3.3
Diffstat (limited to 'gst/librfb')
-rw-r--r-- | gst/librfb/rfbdecoder.c | 50 | ||||
-rw-r--r-- | gst/librfb/rfbdecoder.h | 6 |
2 files changed, 48 insertions, 8 deletions
diff --git a/gst/librfb/rfbdecoder.c b/gst/librfb/rfbdecoder.c index 19d051b1..eedfefce 100644 --- a/gst/librfb/rfbdecoder.c +++ b/gst/librfb/rfbdecoder.c @@ -253,21 +253,55 @@ rfb_decoder_state_wait_for_protocol_version (RfbDecoder * decoder) return TRUE; } +/** + * a string describing the reason (where a string is specified as a length followed + * by that many ASCII characters) + **/ +static gboolean +rfb_decoder_state_reason (RfbDecoder * decoder) +{ + /* \TODO Read the reason from the server why he quits */ + return TRUE; +} + static gboolean rfb_decoder_state_wait_for_security (RfbDecoder * decoder) { RfbBuffer *buffer; gint ret; - ret = rfb_bytestream_read (decoder->bytestream, &buffer, 4); - if (ret < 4) - return FALSE; - - decoder->security_type = RFB_GET_UINT32 (buffer->data); - // g_print ("security = %d\n", decoder->security_type); - - rfb_buffer_free (buffer); + /** + * Version 3.3 The server decides the security type and sends a single word + * + * The security-type may only take the value 0, 1 or 2. A value of 0 means that the + * connection has failed and is followed by a string giving the reason, as described + * above. + */ + if (decoder->protocol_major == 3 && decoder->protocol_minor == 3) { + ret = rfb_bytestream_read (decoder->bytestream, &buffer, 4); + if (ret < 4) + return FALSE; + + decoder->security_type = RFB_GET_UINT32 (buffer->data); + GST_DEBUG ("security = %d", decoder->security_type); + + g_return_val_if_fail (decoder->security_type < 3, FALSE); + g_return_val_if_fail (decoder->security_type != SECURITY_FAIL, + rfb_decoder_state_reason (decoder)); + rfb_buffer_free (buffer); + } + switch (decoder->security_type) { + case SECURITY_NONE: + GST_DEBUG ("Security type is None"); + break; + case SECURITY_VNC: + GST_DEBUG ("Security type is VNC Authentication"); + /* \TODO Check if for the correct password */ + break; + default: + break; + } decoder->state = rfb_decoder_state_send_client_initialisation; return TRUE; } diff --git a/gst/librfb/rfbdecoder.h b/gst/librfb/rfbdecoder.h index 193e7995..1a0c2831 100644 --- a/gst/librfb/rfbdecoder.h +++ b/gst/librfb/rfbdecoder.h @@ -6,6 +6,12 @@ G_BEGIN_DECLS +enum { + SECURITY_FAIL = 0, + SECURITY_NONE, + SECURITY_VNC, +}; + typedef struct _RfbDecoder RfbDecoder; struct _RfbDecoder |