*Rename types

(cherry picked from commit b8506def7a)
This commit is contained in:
Michaël Van Canneyt 2021-11-08 19:09:15 +01:00 committed by marcoonthegit
parent 989dcc7528
commit 92b3df8bee

View File

@ -5,7 +5,7 @@ unit testsha256;
interface
uses
Classes, SysUtils, fpcunit, testutils, testregistry, sha256, sha512, hashutils;
Classes, SysUtils, fpcunit, testutils, testregistry, ecc, sha256, hashutils;
type
@ -25,10 +25,100 @@ type
procedure TestHMACStream;
end;
{ TTestECDSASHA256 }
TTestECDSASHA256 = Class(TTestCase)
// base64url encoded
Const
aInput =
'eyJ0eXAiOiJKV1QiLCJhbGciOiJFUzI1NiJ9.' +
'eyJpYXQiOjE1MTYyMzkwMjIsImV4cCI6MTUxNjI0OTAyMiwiaXNzIjoiRGVscGhpIEpPU0UgYW5kIEpXVCBMaWJyYXJ5In0';
aOutput =
'4QDMKAvHwb6pA5fN0oQjlzuKmPIlNpmIQ8vPH7zy4fjZdtcPVJMtfiVhztwQldQL9A5yzBKI8q2puVygm-2Adw';
// Private key in PEM format
Const APrivateKeyPem =
'-----BEGIN EC PRIVATE KEY-----'+ #10+
'MHcCAQEEIFzS3/5bCnrlpa4902/zkYzURF6E2D8pazgnJu4smhpQoAoGCCqGSM49'+ #10+
'AwEHoUQDQgAEqTjyg2z65i+zbyUZW8BQ+K87DNsICRaEH7Fy7Rm3MseXy9ItSCQU'+ #10+
'VeJbtO6kYUA00mx7bKoC1sx5sbtFExnYPQ=='+ #10+
'-----END EC PRIVATE KEY-----';
Published
Procedure TestSignVerify;
Procedure TestVerify;
Procedure TestVerifyFromKey;
end;
implementation
uses
basenenc;
pem, ecdsa, basenenc, rsa;
{ TTestECDSASHA256 }
procedure TTestECDSASHA256.TestSignVerify;
var
aPrivateKey : TEccPrivateKey;
aPublicKey : TEccPublicKey;
aSignature : TECCSignature;
X,Y : Ansistring;
S : TStringStream;
begin
S:=TStringStream.Create(APrivateKeyPem);
try
AssertTrue('Loaded key',PemLoadECDSA(S,aPrivateKey,aPublicKey,X,Y));
AssertTrue('Encrypted',TECDSA.SignSHA256(aInput,aPrivateKey,aSignature));
EccPublicKeyFromPrivateKey(aPublicKey,aPrivateKey);
AssertTrue('Verified our own',TECDSA.SignSHA256(aInput,aPrivateKey,aSignature));
finally
S.Free;
end;
end;
procedure TTestECDSASHA256.TestVerify;
var
aPrivateKey : TEccPrivateKey;
aPublicKey : TEccPublicKey;
aSignature : TECCSignature;
X,Y : Ansistring;
S : TStringStream;
begin
S:=TStringStream.Create(APrivateKeyPem);
try
AssertTrue('Loaded key',PemLoadECDSA(S,aPrivateKey,aPublicKey,X,Y));
AssertTrue('Encrypted',TECDSA.SignSHA256(aInput,aPrivateKey,aSignature));
// Now verify with result of someone else (random elements)
BytesToVar(Base64URL.Decode(aOutput),aSignature,SizeOf(aSignature));
AssertTrue('Verified other',TECDSA.VerifySHA256(aInput,aPrivateKey,aSignature));
finally
S.Free;
end;
end;
procedure TTestECDSASHA256.TestVerifyFromKey;
Const
// from JWT.IO
aInput2 = 'eyJhbGciOiJFUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiYWRtaW4iOnRydWUsImlhdCI6MTUxNjIzOTAyMn0';
aOutput2 = 'tyh-VfuzIxCyGYDlkBA7DfyjrqmSHu6pQ2hoZuFqUSLPNY2N0mpHb3nk5K17HWP_3cYHBw7AhHale5wky6-sVA';
aPrivateKey2: TEccPrivateKey = ($7a,$f6,$73,$2f,$58,$1d,$00,$5a,$fc,$f2,$16,$f6,$38,$5f,$f6,
$37,$10,$29,$24,$2c,$c6,$08,$40,$dd,$7d,$2a,$7a,$55,$03,$b7,
$d2,$1c);
var
aSignature : TECCSignature;
begin
BytesToVar(Base64URL.Decode(aOutput2),aSignature,SizeOf(aSignature));
AssertTrue('Verified other',TECDSA.VerifySHA256(aInput2,aPrivateKey2,aSignature));
end;
{ TTestSHA256 }
Procedure TTestSHA256.TestHexString(Const aString,aDigest : String);
@ -114,6 +204,6 @@ begin
end;
initialization
RegisterTest(TTestSHA256);
RegisterTests([TTestSHA256,TTestECDSASHA256]);
end.