Files
nuclei-templates/http/misconfiguration/http-missing-security-headers.yaml

101 lines
2.9 KiB
YAML
Raw Normal View History

2021-07-28 14:40:20 +02:00
id: http-missing-security-headers
info:
name: HTTP Missing Security Headers
2023-05-20 14:02:26 +02:00
author: socketz,geeknik,G4L1T0,convisoappsec,kurohost,dawid-czarnecki,forgedhallpass,jub0bs
2021-07-28 14:40:20 +02:00
severity: info
description: |
This template searches for missing HTTP security headers. The impact of these missing headers can vary.
metadata:
max-request: 1
2023-10-14 16:57:55 +05:30
tags: misconfig,headers,generic
2021-07-28 14:40:20 +02:00
http:
2021-07-28 14:40:20 +02:00
- method: GET
path:
- "{{BaseURL}}"
2021-09-03 22:24:11 +05:30
host-redirects: true
2021-07-28 14:40:20 +02:00
max-redirects: 3
2023-10-14 16:57:55 +05:30
2021-07-28 14:40:20 +02:00
matchers-condition: or
matchers:
- type: dsl
2021-09-03 22:24:11 +05:30
name: strict-transport-security
dsl:
- "!regex('(?i)strict-transport-security', header)"
- "status_code != 301 && status_code != 302"
condition: and
2021-09-03 22:24:11 +05:30
- type: dsl
2021-09-03 22:24:11 +05:30
name: content-security-policy
dsl:
- "!regex('(?i)content-security-policy', header)"
- "status_code != 301 && status_code != 302"
condition: and
2021-09-03 22:24:11 +05:30
- type: dsl
name: permissions-policy
dsl:
- "!regex('(?i)permissions-policy', header)"
- "status_code != 301 && status_code != 302"
condition: and
- type: dsl
2021-09-03 22:24:11 +05:30
name: x-frame-options
dsl:
- "!regex('(?i)x-frame-options', header)"
- "status_code != 301 && status_code != 302"
condition: and
2021-09-03 22:24:11 +05:30
- type: dsl
2021-09-03 22:24:11 +05:30
name: x-content-type-options
dsl:
- "!regex('(?i)x-content-type-options', header)"
- "status_code != 301 && status_code != 302"
condition: and
2021-09-03 22:24:11 +05:30
- type: dsl
2021-09-03 22:24:11 +05:30
name: x-permitted-cross-domain-policies
dsl:
- "!regex('(?i)x-permitted-cross-domain-policies', header)"
- "status_code != 301 && status_code != 302"
condition: and
2021-09-03 22:24:11 +05:30
- type: dsl
2021-09-03 22:24:11 +05:30
name: referrer-policy
dsl:
- "!regex('(?i)referrer-policy', header)"
- "status_code != 301 && status_code != 302"
condition: and
2021-09-03 22:24:11 +05:30
- type: dsl
2021-09-03 22:24:11 +05:30
name: clear-site-data
dsl:
- "!regex('(?i)clear-site-data', header)"
- "status_code != 301 && status_code != 302"
condition: and
2021-09-03 22:24:11 +05:30
- type: dsl
2021-09-03 22:24:11 +05:30
name: cross-origin-embedder-policy
dsl:
- "!regex('(?i)cross-origin-embedder-policy', header)"
- "status_code != 301 && status_code != 302"
condition: and
2021-09-03 22:24:11 +05:30
- type: dsl
2021-09-03 22:24:11 +05:30
name: cross-origin-opener-policy
dsl:
- "!regex('(?i)cross-origin-opener-policy', header)"
- "status_code != 301 && status_code != 302"
condition: and
2021-09-03 22:24:11 +05:30
- type: dsl
2021-09-03 22:24:11 +05:30
name: cross-origin-resource-policy
dsl:
- "!regex('(?i)cross-origin-resource-policy', header)"
- "status_code != 301 && status_code != 302"
condition: and
# digest: 4a0a004730450220085d54de6f23590ea9d6512c0ee0f85547ee0d82efb868bcaa773c0cb2deeac30221009e9cb57db7ce4f940a9f24b5eff0288e9a1ea6f024462225e1c0638bcaaedcb3:922c64590222798bb761d5b6d8e72950