Skip to content

Commit

Permalink
RFC 7468 allows a larger character set in PEM label
Browse files Browse the repository at this point in the history
  • Loading branch information
space88man committed Mar 21, 2024
1 parent b763a75 commit d3c459b
Showing 1 changed file with 8 additions and 2 deletions.
10 changes: 8 additions & 2 deletions asn1crypto/pem.py
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,11 @@ def armor(type_name, der_bytes, headers=None):
return output.getvalue()


# RFC 7468#page-5
LABEL_CHARS = '[!-,.-~]' # 0x21-0x2C, 0x2E-0x7E
LABEL_PAT = re.compile(f'^(?:---- |-----)BEGIN ({LABEL_CHARS}([- ]?{LABEL_CHARS})*)?(?: ----|-----)'.encode('ascii'))


def _unarmor(pem_bytes):
"""
Convert a PEM-encoded byte string into one or more DER-encoded byte strings
Expand Down Expand Up @@ -150,8 +155,9 @@ def _unarmor(pem_bytes):

if state == "trash":
# Look for a starting line since some CA cert bundle show the cert
# into in a parsed format above each PEM block
type_name_match = re.match(b'^(?:---- |-----)BEGIN ([A-Z0-9 ]+)(?: ----|-----)', line)
# info in a parsed format above each PEM block

type_name_match = LABEL_PAT.match(line)
if not type_name_match:
continue
object_type = type_name_match.group(1).decode('ascii')
Expand Down

0 comments on commit d3c459b

Please sign in to comment.