|
|
|
"""
|
|
|
|
pygments.lexers.asc
|
|
|
|
~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
Lexer for various ASCII armored files.
|
|
|
|
|
|
|
|
:copyright: Copyright 2006-2023 by the Pygments team, see AUTHORS.
|
|
|
|
:license: BSD, see LICENSE for details.
|
|
|
|
"""
|
|
|
|
import re
|
|
|
|
|
|
|
|
from pygments.lexer import RegexLexer, bygroups
|
|
|
|
from pygments.token import Comment, Generic, Name, Operator, String, Whitespace
|
|
|
|
|
|
|
|
__all__ = ['AscLexer']
|
|
|
|
|
|
|
|
|
|
|
|
class AscLexer(RegexLexer):
|
|
|
|
"""
|
|
|
|
Lexer for ASCII armored files, containing `-----BEGIN/END ...-----` wrapped
|
|
|
|
base64 data.
|
|
|
|
|
|
|
|
.. versionadded:: 2.10
|
|
|
|
"""
|
|
|
|
name = 'ASCII armored'
|
|
|
|
aliases = ['asc', 'pem']
|
|
|
|
filenames = [
|
|
|
|
'*.asc', # PGP; *.gpg, *.pgp, and *.sig too, but those can be binary
|
|
|
|
'*.pem', # X.509; *.cer, *.crt, *.csr, and key etc too, but those can be binary
|
|
|
|
'id_dsa', 'id_ecdsa', 'id_ecdsa_sk', 'id_ed25519', 'id_ed25519_sk',
|
|
|
|
'id_rsa', # SSH private keys
|
|
|
|
]
|
|
|
|
mimetypes = ['application/pgp-keys', 'application/pgp-encrypted',
|
|
|
|
'application/pgp-signature', 'application/pem-certificate-chain']
|
|
|
|
|
|
|
|
flags = re.MULTILINE
|
|
|
|
|
|
|
|
tokens = {
|
|
|
|
'root': [
|
|
|
|
(r'\s+', Whitespace),
|
|
|
|
(r'^-----BEGIN [^\n]+-----$', Generic.Heading, 'data'),
|
|
|
|
(r'\S+', Comment),
|
|
|
|
],
|
|
|
|
'data': [
|
|
|
|
(r'\s+', Whitespace),
|
|
|
|
(r'^([^:]+)(:)([ \t]+)(.*)',
|
|
|
|
bygroups(Name.Attribute, Operator, Whitespace, String)),
|
|
|
|
(r'^-----END [^\n]+-----$', Generic.Heading, 'root'),
|
|
|
|
(r'\S+', String),
|
|
|
|
],
|
|
|
|
}
|
|
|
|
|
|
|
|
def analyse_text(text):
|
|
|
|
if re.search(r'^-----BEGIN [^\n]+-----\r?\n', text):
|
|
|
|
return True
|