Skip to content

Commit

Permalink
Merge pull request #329 from PeculiarVentures/fix-issue-328
Browse files Browse the repository at this point in the history
Fix issue 328
  • Loading branch information
rmhrisk authored Aug 27, 2021
2 parents f476868 + 52922ff commit 7f0d042
Show file tree
Hide file tree
Showing 4 changed files with 767 additions and 711 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -5,4 +5,5 @@ build
.nyc_output
coverage
.vs
.vscode
docs
49 changes: 21 additions & 28 deletions src/SignedData.js
Original file line number Diff line number Diff line change
Expand Up @@ -493,38 +493,31 @@ export default class SignedData
}
else // Find by SubjectKeyIdentifier
{
sequence = sequence.then(() =>
Promise.all(Array.from(this.certificates.filter(certificate => (certificate instanceof Certificate)), certificate =>
crypto.digest({ name: "sha-1" }, new Uint8Array(certificate.subjectPublicKeyInfo.subjectPublicKey.valueBlock.valueHex)))
).then(results =>
{
for(const [index, certificate] of this.certificates.entries())
{
if((certificate instanceof Certificate) === false)
sequence = (async () => {
try {
const sid = this.signerInfos[signer].sid;
const keyId = sid.idBlock.isConstructed
? sid.valueBlock.value[0].valueBlock.valueHex // EXPLICIT OCTET STRING
: sid.valueBlock.valueHex; // IMPLICIT OCTET STRING

for (const certificate of this.certificates) {
if (!(certificate instanceof Certificate)) {
continue;

if(isEqualBuffer(results[index], this.signerInfos[signer].sid.valueBlock.valueHex))
}

const digest = await crypto.digest({ name: "sha-1" }, new Uint8Array(certificate.subjectPublicKeyInfo.subjectPublicKey.valueBlock.valueHex));
if(isEqualBuffer(digest, keyId))
{
signerCertificate = certificate;
return Promise.resolve();
break;
}
}

if(extendedMode)
{
return Promise.reject({
date: checkDate,
code: 3,
message: "Unable to find signer certificate",
signatureVerified: null,
signerCertificate: null,
signerCertificateVerified: null
});
if (!signerCertificate) {
throw new Error("Signing certificate not found");
}

return Promise.reject("Unable to find signer certificate");
}, () =>
{
}
catch (e) {
if(extendedMode)
{
return Promise.reject({
Expand All @@ -537,9 +530,9 @@ export default class SignedData
});
}

return Promise.reject("Unable to find signer certificate");
})
);
throw "Unable to find signer certificate";
}
})();
}
//endregion

Expand Down
31 changes: 22 additions & 9 deletions src/SignerInfo.js
Original file line number Diff line number Diff line change
Expand Up @@ -182,15 +182,28 @@ export default class SignerInfo
blockName: "SignerInfo.sid"
}
}),
new asn1js.Primitive({
optional: true,
name: (names.sid || "SignerInfo.sid"),
idBlock: {
tagClass: 3, // CONTEXT-SPECIFIC
tagNumber: 0 // [0]
},
value: [new asn1js.OctetString()]
})
new asn1js.Choice({
value: [
new asn1js.Constructed({
optional: true,
name: (names.sid || "SignerInfo.sid"),
idBlock: {
tagClass: 3, // CONTEXT-SPECIFIC
tagNumber: 0 // [0]
},
value: [new asn1js.OctetString()]
}),
new asn1js.Primitive({
optional: true,
name: (names.sid || "SignerInfo.sid"),
idBlock: {
tagClass: 3, // CONTEXT-SPECIFIC
tagNumber: 0 // [0]
},
value: [new asn1js.OctetString()]
}),
]
}),
]
}),
AlgorithmIdentifier.schema(names.digestAlgorithm || {
Expand Down
Loading

0 comments on commit 7f0d042

Please sign in to comment.