]> git.ipfire.org Git - people/pmueller/ipfire-2.x.git/commitdiff
ovpnmain.cgi: Fix OTP secret handling
authorTimo Eissler <timo.eissler@ipfire.org>
Tue, 7 Jun 2022 09:20:56 +0000 (11:20 +0200)
committerMichael Tremer <michael.tremer@ipfire.org>
Fri, 17 Jun 2022 10:20:19 +0000 (10:20 +0000)
Convert stored hex OTP secret to binary prior to converting to base32.

html/cgi-bin/ovpnmain.cgi

index ee7b38f3f9c5a04891058a508aaae36b2861e35a..71c79ef471db4926017e3cb0845d25ce8dfdd570 100644 (file)
@@ -2655,7 +2655,7 @@ else
       darkcolor     => Imager::Color->new(0, 0, 0),
    );
    my $cn = $confighash{$cgiparams{'KEY'}}[2];
-   my $secret = encode_base32($confighash{$cgiparams{'KEY'}}[44]);
+   my $secret = encode_base32(pack('H*', $confighash{$cgiparams{'KEY'}}[44]));
    my $issuer = "$mainsettings{'HOSTNAME'}.$mainsettings{'DOMAINNAME'}";
    my $qrcodeimg = $qrcode->plot("otpauth://totp/$cn?secret=$secret&issuer=$issuer");
    my $qrcodeimgdata;