Skip to content

Calling validate_sign with both cert and multicerts should not ignore cert #333

@networkException

Description

@networkException

When providing both a value for cert and multicerts to

def validate_sign(xml, cert=None, fingerprint=None, fingerprintalg='sha1', validatecert=False, debug=False, xpath=None, multicerts=None):

the branching will ignore the value given for cert

# If multiple certs are provided, I may ignore cert and
# fingerprint provided by the method and just check the
# certs multicerts
fingerprint = fingerprintalg = None
for cert in multicerts:
if OneLogin_Saml2_Utils.validate_node_sign(signature_node, elem, cert, fingerprint, fingerprintalg, validatecert, False, raise_exceptions=False):
return True

While reading the code / comment clarifies this behavior, the parameter documentation doesn't mention it making this function behave somewhat unexpected leading to security issues at worst.

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions