浏览代码

obs-outputs: Add bounds checking to b64enc

This fixes "warning: unused parameter 'maxsize' [-Wunused-parameter]"
introduced when authentication was turned on.
Jess Mayo 10 年之前
父节点
当前提交
f1a6b37e8e
共有 1 个文件被更改,包括 12 次插入4 次删除
  1. 12 4
      plugins/obs-outputs/librtmp/rtmp.c

+ 12 - 4
plugins/obs-outputs/librtmp/rtmp.c

@@ -2365,11 +2365,19 @@ b64enc(const unsigned char *input, int length, char *output, int maxsize)
         return 0;
     }
 #elif defined(USE_ONLY_MD5)
-    base64_encodestate state;
+    if ((((length + 2) / 3) * 4) <= maxsize)
+    {
+        base64_encodestate state;
 
-    base64_init_encodestate(&state);
-    output += base64_encode_block((const char *)input, length, output, &state);
-    base64_encode_blockend(output, &state);
+        base64_init_encodestate(&state);
+        output += base64_encode_block((const char *)input, length, output, &state);
+        base64_encode_blockend(output, &state);
+    }
+    else
+    {
+        RTMP_Log(RTMP_LOGDEBUG, "%s, error", __FUNCTION__);
+        return 0;
+    }
 
 #else   /* USE_OPENSSL */
     BIO *bmem, *b64;