1"""Apache plugin constants.""" 2import pkg_resources 3 4from certbot.compat import os 5 6MOD_SSL_CONF_DEST = "options-ssl-apache.conf" 7"""Name of the mod_ssl config file as saved 8in `certbot.configuration.NamespaceConfig.config_dir`.""" 9 10 11UPDATED_MOD_SSL_CONF_DIGEST = ".updated-options-ssl-apache-conf-digest.txt" 12"""Name of the hash of the updated or informed mod_ssl_conf as saved 13in `certbot.configuration.NamespaceConfig.config_dir`.""" 14 15# NEVER REMOVE A SINGLE HASH FROM THIS LIST UNLESS YOU KNOW EXACTLY WHAT YOU ARE DOING! 16ALL_SSL_OPTIONS_HASHES = [ 17 '2086bca02db48daf93468332543c60ac6acdb6f0b58c7bfdf578a5d47092f82a', 18 '4844d36c9a0f587172d9fa10f4f1c9518e3bcfa1947379f155e16a70a728c21a', 19 '5a922826719981c0a234b1fbcd495f3213e49d2519e845ea0748ba513044b65b', 20 '4066b90268c03c9ba0201068eaa39abbc02acf9558bb45a788b630eb85dadf27', 21 'f175e2e7c673bd88d0aff8220735f385f916142c44aa83b09f1df88dd4767a88', 22 'cfdd7c18d2025836ea3307399f509cfb1ebf2612c87dd600a65da2a8e2f2797b', 23 '80720bd171ccdc2e6b917ded340defae66919e4624962396b992b7218a561791', 24 'c0c022ea6b8a51ecc8f1003d0a04af6c3f2bc1c3ce506b3c2dfc1f11ef931082', 25 '717b0a89f5e4c39b09a42813ac6e747cfbdeb93439499e73f4f70a1fe1473f20', 26 '0fcdc81280cd179a07ec4d29d3595068b9326b455c488de4b09f585d5dafc137', 27 '86cc09ad5415cd6d5f09a947fe2501a9344328b1e8a8b458107ea903e80baa6c', 28 '06675349e457eae856120cdebb564efe546f0b87399f2264baeb41e442c724c7', 29 '5cc003edd93fb9cd03d40c7686495f8f058f485f75b5e764b789245a386e6daf', 30 '007cd497a56a3bb8b6a2c1aeb4997789e7e38992f74e44cc5d13a625a738ac73', 31 '34783b9e2210f5c4a23bced2dfd7ec289834716673354ed7c7abf69fe30192a3', 32] 33"""SHA256 hashes of the contents of previous versions of all versions of MOD_SSL_CONF_SRC""" 34 35AUGEAS_LENS_DIR = pkg_resources.resource_filename( 36 "certbot_apache", os.path.join("_internal", "augeas_lens")) 37"""Path to the Augeas lens directory""" 38 39REWRITE_HTTPS_ARGS = [ 40 "^", "https://%{SERVER_NAME}%{REQUEST_URI}", "[L,NE,R=permanent]"] 41"""Apache version<2.3.9 rewrite rule arguments used for redirections to 42https vhost""" 43 44REWRITE_HTTPS_ARGS_WITH_END = [ 45 "^", "https://%{SERVER_NAME}%{REQUEST_URI}", "[END,NE,R=permanent]"] 46"""Apache version >= 2.3.9 rewrite rule arguments used for redirections to 47 https vhost""" 48 49OLD_REWRITE_HTTPS_ARGS = [ 50 ["^", "https://%{SERVER_NAME}%{REQUEST_URI}", "[L,QSA,R=permanent]"], 51 ["^", "https://%{SERVER_NAME}%{REQUEST_URI}", "[END,QSA,R=permanent]"]] 52 53HSTS_ARGS = ["always", "set", "Strict-Transport-Security", 54 "\"max-age=31536000\""] 55"""Apache header arguments for HSTS""" 56 57UIR_ARGS = ["always", "set", "Content-Security-Policy", 58 "upgrade-insecure-requests"] 59 60HEADER_ARGS = {"Strict-Transport-Security": HSTS_ARGS, 61 "Upgrade-Insecure-Requests": UIR_ARGS} 62 63AUTOHSTS_STEPS = [60, 300, 900, 3600, 21600, 43200, 86400] 64"""AutoHSTS increase steps: 1min, 5min, 15min, 1h, 6h, 12h, 24h""" 65 66AUTOHSTS_PERMANENT = 31536000 67"""Value for the last max-age of HSTS""" 68 69AUTOHSTS_FREQ = 172800 70"""Minimum time since last increase to perform a new one: 48h""" 71 72MANAGED_COMMENT = "DO NOT REMOVE - Managed by Certbot" 73MANAGED_COMMENT_ID = MANAGED_COMMENT+", VirtualHost id: {0}" 74"""Managed by Certbot comments and the VirtualHost identification template""" 75