From 6f0b5c1bea4aa09467d3113677b65c73bc182bc0 Mon Sep 17 00:00:00 2001 From: Eric House Date: Thu, 17 Apr 2014 08:13:01 -0700 Subject: [PATCH] empty the model string if the client version's lower than what I'm about to release and there's non-ascii stuff in it. --- xwords4/relay/xwrelay.cpp | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/xwords4/relay/xwrelay.cpp b/xwords4/relay/xwrelay.cpp index e11b0cad3..c8f29e6d4 100644 --- a/xwords4/relay/xwrelay.cpp +++ b/xwords4/relay/xwrelay.cpp @@ -327,6 +327,22 @@ vli2un( const uint8_t** bufpp, const uint8_t* end, uint32_t* out ) return success; } +static void +checkAllAscii( string& str ) +{ + const char* strp = str.c_str(); + bool bad = false; + while ( '\0' != *strp && !bad ) { + bad = 0 != (0x80 & *strp); + } + if ( bad ) { + logf( XW_LOGERROR, "emptying string %s", str.c_str() ); + str.clear(); + } else { + logf( XW_LOGINFO, "string %s is ok", str.c_str() ); + } +} + static bool getVLIString( const uint8_t** bufpp, const uint8_t* end, string& out ) @@ -1657,7 +1673,9 @@ handle_udp_packet( UdpThreadClosure* utc ) && getVLIString( &ptr, end, devDesc ) && getVLIString( &ptr, end, model ) && getVLIString( &ptr, end, osVers ) ) { - logf( XW_LOGINFO, "%s: model=%s", __func__, model.c_str() ); + if ( 3 >= clientVers ) { + checkAllAscii( model ); + } registerDevice( relayID, &devID, utc->addr(), clientVers, devDesc, model, osVers ); }