Florian Schaal
2014-09-26 26a9140960cd7a53cb4f52f3a69bad04482b7d46
 changed regex for private-key
1 files modified
4 ■■■■ changed files
interface/lib/classes/validate_dkim.inc.php 4 ●●●● patch | view | raw | blame | history
interface/lib/classes/validate_dkim.inc.php
@@ -73,7 +73,7 @@
     * @return boolean - true if $POST contains a real key-file
     */
    function validate_post($key, $value, $dkim_strength) {
        $value=str_replace("\n", "", $value);
        $value=str_replace(array("\n", "-----BEGIN RSA PRIVATE KEY-----", "-----END RSA PRIVATE KEY-----", " "), "", $value);
        switch ($key) {
        case 'public':
            if (preg_match("/(^-----BEGIN PUBLIC KEY-----)[a-zA-Z0-9\r\n\/\+=]{1,221}(-----END PUBLIC KEY-----(\n|\r)?$)/", $value) === 1) { return true; } else { return false; }
@@ -82,7 +82,7 @@
            if ( $dkim_strength == 1024 ) $range = "{812,816}";
            if ( $dkim_strength == 2048 ) $range = "{1588,1592}";
            if ( $dkim_strength == 4096 ) $range = "{3132,3136}";
            if (preg_match("/^-----BEGIN RSA PRIVATE KEY-----[a-zA-Z0-9\/\+=]".$range."-----END RSA PRIVATE KEY-----$/", $value) === 1) return true; else return false;
            if ( preg_match("/^[a-zA-Z0-9\/\+=]".$range."$/", $value ) === 1) return true; else return false;
            break;
        }
    }