ZAP Scanning Report

Site: https://cfas.apprentissage.beta.gouv.fr

Generated on Sun, 29 Jun 2025 10:03:44

ZAP Version: 2.16.1

ZAP by Checkmarx

Summary of Alerts

Risk Level Number of Alerts
High
0
Medium
6
Low
6
Informational
15
False Positives:
0

Summary of Sequences

For each step: result (Pass/Fail) - risk (of highest alert(s) for the step, if any).

Alerts

Name Risk Level Number of Instances
CSP: Failure to Define Directive with No Fallback Medium 4
CSP: Wildcard Directive Medium 4
CSP: script-src unsafe-inline Medium 4
CSP: style-src unsafe-inline Medium 4
Cross-Domain Misconfiguration Medium 1
Source Code Disclosure - SQL Medium 5
Cookie with SameSite Attribute None Low 4
Dangerous JS Functions Low 3
Insufficient Site Isolation Against Spectre Vulnerability Low 12
Permissions Policy Header Not Set Low 11
Strict-Transport-Security Multiple Header Entries (Non-compliant with Spec) Low 12
Vulnerable JS Library Low 1
Authentication Request Identified Informational 1
Base64 Disclosure Informational 11
Content-Type Header Missing Informational 1
Information Disclosure - Sensitive Information in URL Informational 3
Information Disclosure - Suspicious Comments Informational 12
Modern Web Application Informational 11
Non-Storable Content Informational 9
Re-examine Cache-control Directives Informational 11
Sec-Fetch-Dest Header is Missing Informational 3
Sec-Fetch-Mode Header is Missing Informational 3
Sec-Fetch-Site Header is Missing Informational 3
Sec-Fetch-User Header is Missing Informational 3
Session Management Response Identified Informational 5
Storable and Cacheable Content Informational 1
Storable but Non-Cacheable Content Informational 2

Alert Detail

Medium
CSP: Failure to Define Directive with No Fallback
Description
The Content Security Policy fails to define one of the directives that has no fallback. Missing/excluding them is the same as allowing anything.
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info The directive(s): form-action is/are among the directives that do not fallback to default-src.
URL https://cfas.apprentissage.beta.gouv.fr/
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info The directive(s): form-action is/are among the directives that do not fallback to default-src.
URL https://cfas.apprentissage.beta.gouv.fr/robots.txt
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info The directive(s): form-action is/are among the directives that do not fallback to default-src.
URL https://cfas.apprentissage.beta.gouv.fr/stats
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info The directive(s): form-action is/are among the directives that do not fallback to default-src.
Instances 4
Solution
Ensure that your web server, application server, load balancer, etc. is properly configured to set the Content-Security-Policy header.
Reference https://www.w3.org/TR/CSP/
https://caniuse.com/#search=content+security+policy
https://content-security-policy.com/
https://github.com/HtmlUnit/htmlunit-csp
https://developers.google.com/web/fundamentals/security/csp#policy_applies_to_a_wide_variety_of_resources
CWE Id 693
WASC Id 15
Plugin Id 10055
Medium
CSP: Wildcard Directive
Description
Content Security Policy (CSP) is an added layer of security that helps to detect and mitigate certain types of attacks. Including (but not limited to) Cross Site Scripting (XSS), and data injection attacks. These attacks are used for everything from data theft to site defacement or distribution of malware. CSP provides a set of standard HTTP headers that allow website owners to declare approved sources of content that browsers should be allowed to load on that page — covered types are JavaScript, CSS, HTML frames, fonts, images and embeddable objects such as Java applets, ActiveX, audio and video files.
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info The following directives either allow wildcard sources (or ancestors), are not defined, or are overly broadly defined: style-src, font-src
URL https://cfas.apprentissage.beta.gouv.fr/
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info The following directives either allow wildcard sources (or ancestors), are not defined, or are overly broadly defined: style-src, font-src
URL https://cfas.apprentissage.beta.gouv.fr/robots.txt
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info The following directives either allow wildcard sources (or ancestors), are not defined, or are overly broadly defined: style-src, font-src
URL https://cfas.apprentissage.beta.gouv.fr/stats
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info The following directives either allow wildcard sources (or ancestors), are not defined, or are overly broadly defined: style-src, font-src
Instances 4
Solution
Ensure that your web server, application server, load balancer, etc. is properly configured to set the Content-Security-Policy header.
Reference https://www.w3.org/TR/CSP/
https://caniuse.com/#search=content+security+policy
https://content-security-policy.com/
https://github.com/HtmlUnit/htmlunit-csp
https://developers.google.com/web/fundamentals/security/csp#policy_applies_to_a_wide_variety_of_resources
CWE Id 693
WASC Id 15
Plugin Id 10055
Medium
CSP: script-src unsafe-inline
Description
Content Security Policy (CSP) is an added layer of security that helps to detect and mitigate certain types of attacks. Including (but not limited to) Cross Site Scripting (XSS), and data injection attacks. These attacks are used for everything from data theft to site defacement or distribution of malware. CSP provides a set of standard HTTP headers that allow website owners to declare approved sources of content that browsers should be allowed to load on that page — covered types are JavaScript, CSS, HTML frames, fonts, images and embeddable objects such as Java applets, ActiveX, audio and video files.
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info script-src includes unsafe-inline.
URL https://cfas.apprentissage.beta.gouv.fr/
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info script-src includes unsafe-inline.
URL https://cfas.apprentissage.beta.gouv.fr/robots.txt
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info script-src includes unsafe-inline.
URL https://cfas.apprentissage.beta.gouv.fr/stats
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info script-src includes unsafe-inline.
Instances 4
Solution
Ensure that your web server, application server, load balancer, etc. is properly configured to set the Content-Security-Policy header.
Reference https://www.w3.org/TR/CSP/
https://caniuse.com/#search=content+security+policy
https://content-security-policy.com/
https://github.com/HtmlUnit/htmlunit-csp
https://developers.google.com/web/fundamentals/security/csp#policy_applies_to_a_wide_variety_of_resources
CWE Id 693
WASC Id 15
Plugin Id 10055
Medium
CSP: style-src unsafe-inline
Description
Content Security Policy (CSP) is an added layer of security that helps to detect and mitigate certain types of attacks. Including (but not limited to) Cross Site Scripting (XSS), and data injection attacks. These attacks are used for everything from data theft to site defacement or distribution of malware. CSP provides a set of standard HTTP headers that allow website owners to declare approved sources of content that browsers should be allowed to load on that page — covered types are JavaScript, CSS, HTML frames, fonts, images and embeddable objects such as Java applets, ActiveX, audio and video files.
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info style-src includes unsafe-inline.
URL https://cfas.apprentissage.beta.gouv.fr/
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info style-src includes unsafe-inline.
URL https://cfas.apprentissage.beta.gouv.fr/robots.txt
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info style-src includes unsafe-inline.
URL https://cfas.apprentissage.beta.gouv.fr/stats
Method GET
Parameter Content-Security-Policy
Attack
Evidence default-src 'self' https://plausible.io; base-uri 'self' https://stats.beta.gouv.fr; block-all-mixed-content; font-src 'self' https: data:; frame-ancestors 'self' https://cfas.apprentissage.beta.gouv.fr; frame-src 'self' https://plausible.io https://cfas.apprentissage.beta.gouv.fr https://cfas-recette.apprentissage.beta.gouv.fr https://tableau-de-bord-preprod.apprentissage.beta.gouv.fr https://plugins.crisp.chat https://www.youtube.com; img-src 'self' https://files.tableau-de-bord.apprentissage.beta.gouv.fr https://www.notion.so https://img.notionusercontent.com https://mission-apprentissage.notion.site https://stats.beta.gouv.fr data:; object-src 'none'; script-src 'self' 'unsafe-inline' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat ; script-src-attr 'none'; style-src 'self' https: *.plausible.io 'unsafe-inline'; connect-src 'self' https://plausible.io https://stats.beta.gouv.fr https://client.crisp.chat https://plugins.crisp.chat https://sentry.apprentissage.beta.gouv.fr ; upgrade-insecure-requests;
Other Info style-src includes unsafe-inline.
Instances 4
Solution
Ensure that your web server, application server, load balancer, etc. is properly configured to set the Content-Security-Policy header.
Reference https://www.w3.org/TR/CSP/
https://caniuse.com/#search=content+security+policy
https://content-security-policy.com/
https://github.com/HtmlUnit/htmlunit-csp
https://developers.google.com/web/fundamentals/security/csp#policy_applies_to_a_wide_variety_of_resources
CWE Id 693
WASC Id 15
Plugin Id 10055
Medium
Cross-Domain Misconfiguration
Description
Web browser data loading may be possible, due to a Cross Origin Resource Sharing (CORS) misconfiguration on the web server.
URL https://cfas.apprentissage.beta.gouv.fr/js/script.js
Method GET
Parameter
Attack
Evidence access-control-allow-origin: *
Other Info The CORS misconfiguration on the web server permits cross-domain read requests from arbitrary third party domains, using unauthenticated APIs on this domain. Web browser implementations do not permit arbitrary third parties to read the response from authenticated APIs, however. This reduces the risk somewhat. This misconfiguration could be used by an attacker to access data that is available in an unauthenticated manner, but which uses some other form of security, such as IP address white-listing.
Instances 1
Solution
Ensure that sensitive data is not available in an unauthenticated manner (using IP address white-listing, for instance).

Configure the "Access-Control-Allow-Origin" HTTP header to a more restrictive set of domains, or remove all CORS headers entirely, to allow the web browser to enforce the Same Origin Policy (SOP) in a more restrictive manner.
Reference https://vulncat.fortify.com/en/detail?id=desc.config.dotnet.html5_overly_permissive_cors_policy
CWE Id 264
WASC Id 14
Plugin Id 10098
Medium
Source Code Disclosure - SQL
Description
Application Source Code was disclosed by the web server. - SQL
URL https://cfas.apprentissage.beta.gouv.fr/metabase/
Method GET
Parameter
Attack
Evidence Select one or more values from a list or search box.
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/3725a628-f37b-4220-8e55-b63241835b13
Method GET
Parameter
Attack
Evidence Select one or more values from a list or search box.
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/78bc775c-1be5-4e61-b81c-3fe4679e480b
Method GET
Parameter
Attack
Evidence Select one or more values from a list or search box.
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/8af240fe-aaed-466e-a903-537b328a749f
Method GET
Parameter
Attack
Evidence Select one or more values from a list or search box.
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/9808c918-2d2f-4ae5-b0e7-5e1d982e3e66
Method GET
Parameter
Attack
Evidence Select one or more values from a list or search box.
Other Info
Instances 5
Solution
Ensure that application Source Code is not available with alternative extensions, and ensure that source code is not present within other files or data deployed to the web server, or served by the web server.
Reference https://www.wsj.com/articles/BL-CIOB-2999
CWE Id 540
WASC Id 13
Plugin Id 10099
Low
Cookie with SameSite Attribute None
Description
A cookie has been set with its SameSite attribute set to "none", which means that the cookie can be sent as a result of a 'cross-site' request. The SameSite attribute is an effective counter measure to cross-site request forgery, cross-site script inclusion, and timing attacks.
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/3725a628-f37b-4220-8e55-b63241835b13
Method GET
Parameter metabase.DEVICE
Attack
Evidence Set-Cookie: metabase.DEVICE
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/78bc775c-1be5-4e61-b81c-3fe4679e480b
Method GET
Parameter metabase.DEVICE
Attack
Evidence Set-Cookie: metabase.DEVICE
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/8af240fe-aaed-466e-a903-537b328a749f
Method GET
Parameter metabase.DEVICE
Attack
Evidence Set-Cookie: metabase.DEVICE
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/9808c918-2d2f-4ae5-b0e7-5e1d982e3e66
Method GET
Parameter metabase.DEVICE
Attack
Evidence Set-Cookie: metabase.DEVICE
Other Info
Instances 4
Solution
Ensure that the SameSite attribute is set to either 'lax' or ideally 'strict' for all cookies.
Reference https://tools.ietf.org/html/draft-ietf-httpbis-cookie-same-site
CWE Id 1275
WASC Id 13
Plugin Id 10054
Low
Dangerous JS Functions
Description
A dangerous JS function seems to be in use that would leave the site vulnerable.
URL https://cfas.apprentissage.beta.gouv.fr/_next/static/chunks/3528-6b47bedda7c3acc3.js
Method GET
Parameter
Attack
Evidence eval(
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/_next/static/chunks/6544-92fdb0de579df2fd.js
Method GET
Parameter
Attack
Evidence eval(
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/app/dist/vendor.0020672656ebd049.js
Method GET
Parameter
Attack
Evidence eval(
Other Info
Instances 3
Solution
See the references for security advice on the use of these functions.
Reference https://angular.io/guide/security
CWE Id 749
WASC Id
Plugin Id 10110
Low
Insufficient Site Isolation Against Spectre Vulnerability
Description
Cross-Origin-Resource-Policy header is an opt-in header designed to counter side-channels attacks like Spectre. Resource should be specifically set as shareable amongst different origins.
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter Cross-Origin-Resource-Policy
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/auth/inscription
Method GET
Parameter Cross-Origin-Resource-Policy
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/sitemap.xml
Method GET
Parameter Cross-Origin-Resource-Policy
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/stats
Method GET
Parameter Cross-Origin-Resource-Policy
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter Cross-Origin-Embedder-Policy
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/auth/inscription
Method GET
Parameter Cross-Origin-Embedder-Policy
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/sitemap.xml
Method GET
Parameter Cross-Origin-Embedder-Policy
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/stats
Method GET
Parameter Cross-Origin-Embedder-Policy
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter Cross-Origin-Opener-Policy
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/auth/inscription
Method GET
Parameter Cross-Origin-Opener-Policy
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/sitemap.xml
Method GET
Parameter Cross-Origin-Opener-Policy
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/stats
Method GET
Parameter Cross-Origin-Opener-Policy
Attack
Evidence
Other Info
Instances 12
Solution
Ensure that the application/web server sets the Cross-Origin-Resource-Policy header appropriately, and that it sets the Cross-Origin-Resource-Policy header to 'same-origin' for all web pages.

'same-site' is considered as less secured and should be avoided.

If resources must be shared, set the header to 'cross-origin'.

If possible, ensure that the end user uses a standards-compliant and modern web browser that supports the Cross-Origin-Resource-Policy header (https://caniuse.com/mdn-http_headers_cross-origin-resource-policy).
Reference https://developer.mozilla.org/en-US/docs/Web/HTTP/Cross-Origin_Resource_Policy
CWE Id 693
WASC Id 14
Plugin Id 90004
Low
Permissions Policy Header Not Set
Description
Permissions Policy Header is an added layer of security that helps to restrict from unauthorized access or usage of browser/client features by web resources. This policy ensures the user privacy by limiting or specifying the features of the browsers can be used by the web resources. Permissions Policy provides a set of standard HTTP headers that allow website owners to limit which features of browsers can be used by the page such as camera, microphone, location, full screen etc.
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/auth/connexion
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/auth/en-attente-confirmation
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/auth/finalisation
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/auth/inscription
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/cgu
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/modifier-mot-de-passe
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/questions-reponses
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/robots.txt
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/stats
Method GET
Parameter
Attack
Evidence
Other Info
Instances 11
Solution
Ensure that your web server, application server, load balancer, etc. is configured to set the Permissions-Policy header.
Reference https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Permissions-Policy
https://developer.chrome.com/blog/feature-policy/
https://scotthelme.co.uk/a-new-security-header-feature-policy/
https://w3c.github.io/webappsec-feature-policy/
https://www.smashingmagazine.com/2018/12/feature-policy/
CWE Id 693
WASC Id 15
Plugin Id 10063
Low
Strict-Transport-Security Multiple Header Entries (Non-compliant with Spec)
Description
HTTP Strict Transport Security (HSTS) headers were found, a response with multiple HSTS header entries is not compliant with the specification (RFC 6797) and only the first HSTS header will be processed others will be ignored by user agents or the HSTS policy may be incorrectly applied.

HTTP Strict Transport Security (HSTS) is a web security policy mechanism whereby a web server declares that complying user agents (such as a web browser) are to interact with it using only secure HTTPS connections (i.e. HTTP layered over TLS/SSL).
URL https://cfas.apprentissage.beta.gouv.fr/metabase/app/assets/img/apple-touch-icon.png
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/app/assets/img/favicon.ico
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/app/assets/img/site.webmanifest
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/app/dist/runtime.9882a21423cd3741.js
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/app/dist/styles.cc2d97fa68d09f0b.css
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/app/dist/styles.da5e3ca16a7e31e9.js
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/app/dist/vendor-styles.032d797c4c7c2552.css
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/app/dist/vendor-styles.67a50442584ab8fe.js
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/3725a628-f37b-4220-8e55-b63241835b13
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/78bc775c-1be5-4e61-b81c-3fe4679e480b
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/8af240fe-aaed-466e-a903-537b328a749f
Method GET
Parameter
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/9808c918-2d2f-4ae5-b0e7-5e1d982e3e66
Method GET
Parameter
Attack
Evidence
Other Info
Instances 12
Solution
Ensure that only one component in your stack: code, web server, application server, load balancer, etc. is configured to set or add a HTTP Strict-Transport-Security (HSTS) header.
Reference https://datatracker.ietf.org/doc/html/rfc6797#section-8.1
CWE Id 319
WASC Id 15
Plugin Id 10035
Low
Vulnerable JS Library
Description
The identified library appears to be vulnerable.
URL https://cfas.apprentissage.beta.gouv.fr/_next/static/chunks/main-c97f39376af7743b.js
Method GET
Parameter
Attack
Evidence ="15.2.3",X=(0,P.default)(),W=e=>[].slice.call(e),q=!1;class G extends E.default.Component{componentDidCatch(e,t){this.props.fn(e,t)}componentDidMount
Other Info The identified library nextjs, version 15.2.3 is vulnerable. CVE-2025-30218 https://nvd.nist.gov/vuln/detail/CVE-2025-30218 https://github.com/vercel/next.js/security/advisories/GHSA-223j-4rm8-mrmf https://github.com/vercel/next.js https://github.com/advisories/GHSA-223j-4rm8-mrmf https://vercel.com/changelog/cve-2025-30218-5DREmEH765PoeAsrNNQj3O
Instances 1
Solution
Upgrade to the latest version of the affected library.
Reference https://owasp.org/Top10/A06_2021-Vulnerable_and_Outdated_Components/
CWE Id 1395
WASC Id
Plugin Id 10003
Informational
Authentication Request Identified
Description
The given request has been identified as an authentication request. The 'Other Info' field contains a set of key=value lines which identify any relevant fields. If the request is in a context which has an Authentication Method set to "Auto-Detect" then this rule will change the authentication to match the request identified.
URL https://cfas.apprentissage.beta.gouv.fr/auth/connexion?email=zaproxy%40example.com&password=ZAP
Method GET
Parameter email
Attack
Evidence password
Other Info userParam=email userValue=zaproxy@example.com passwordParam=password referer=https://cfas.apprentissage.beta.gouv.fr/auth/connexion
Instances 1
Solution
This is an informational alert rather than a vulnerability and so there is nothing to fix.
Reference https://www.zaproxy.org/docs/desktop/addons/authentication-helper/auth-req-id/
CWE Id
WASC Id
Plugin Id 10111
Informational
Base64 Disclosure
Description
Base64 encoded data was disclosed by the application/web server. Note: in the interests of performance not all base64 strings in the response were analyzed individually, the entire response should be looked at by the analyst/security team/developer(s).
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter
Attack
Evidence so/mission-apprentissage/Journal-des-volutions-5c9bec4ae3c3451da671f3f684ee994f
Other Info ����"����ޞج����.�v��׬��%�ب�Ϲs��s������WZ�_�������
URL https://cfas.apprentissage.beta.gouv.fr/
Method GET
Parameter
Attack
Evidence so/mission-apprentissage/Journal-des-volutions-5c9bec4ae3c3451da671f3f684ee994f
Other Info ����"����ޞج����.�v��׬��%�ب�Ϲs��s������WZ�_�������
URL https://cfas.apprentissage.beta.gouv.fr/accessibilite
Method GET
Parameter
Attack
Evidence /_next/static/jxtO6-3984IzKcV9ROwaC/_buildManifest
Other Info �����쵫bs�����8#2�W�N���������'޲
URL https://cfas.apprentissage.beta.gouv.fr/auth/connexion
Method GET
Parameter
Attack
Evidence so/mission-apprentissage/Journal-des-volutions-5c9bec4ae3c3451da671f3f684ee994f
Other Info ����"����ޞج����.�v��׬��%�ب�Ϲs��s������WZ�_�������
URL https://cfas.apprentissage.beta.gouv.fr/auth/en-attente-confirmation
Method GET
Parameter
Attack
Evidence /_next/static/jxtO6-3984IzKcV9ROwaC/_buildManifest
Other Info �����쵫bs�����8#2�W�N���������'޲
URL https://cfas.apprentissage.beta.gouv.fr/auth/finalisation
Method GET
Parameter
Attack
Evidence /_next/static/jxtO6-3984IzKcV9ROwaC/_buildManifest
Other Info �����쵫bs�����8#2�W�N���������'޲
URL https://cfas.apprentissage.beta.gouv.fr/auth/inscription
Method GET
Parameter
Attack
Evidence /_next/static/jxtO6-3984IzKcV9ROwaC/_buildManifest
Other Info �����쵫bs�����8#2�W�N���������'޲
URL https://cfas.apprentissage.beta.gouv.fr/cgu
Method GET
Parameter
Attack
Evidence /_next/static/jxtO6-3984IzKcV9ROwaC/_buildManifest
Other Info �����쵫bs�����8#2�W�N���������'޲
URL https://cfas.apprentissage.beta.gouv.fr/mentions-legales
Method GET
Parameter
Attack
Evidence /_next/static/jxtO6-3984IzKcV9ROwaC/_buildManifest
Other Info �����쵫bs�����8#2�W�N���������'޲
URL https://cfas.apprentissage.beta.gouv.fr/questions-reponses
Method GET
Parameter
Attack
Evidence /_next/static/jxtO6-3984IzKcV9ROwaC/_buildManifest
Other Info �����쵫bs�����8#2�W�N���������'޲
URL https://cfas.apprentissage.beta.gouv.fr/stats
Method GET
Parameter
Attack
Evidence /_next/static/jxtO6-3984IzKcV9ROwaC/_buildManifest
Other Info �����쵫bs�����8#2�W�N���������'޲
Instances 11
Solution
Manually confirm that the Base64 data does not leak sensitive information, and that the data cannot be aggregated/used to exploit other vulnerabilities.
Reference https://projects.webappsec.org/w/page/13246936/Information%20Leakage
CWE Id 319
WASC Id 13
Plugin Id 10094
Informational
Content-Type Header Missing
Description
The Content-Type header was either missing or empty.
URL https://cfas.apprentissage.beta.gouv.fr/metabase/app/assets/img/site.webmanifest
Method GET
Parameter content-type
Attack
Evidence
Other Info
Instances 1
Solution
Ensure each page is setting the specific and appropriate content-type value for the content being delivered.
Reference https://learn.microsoft.com/en-us/previous-versions/windows/internet-explorer/ie-developer/compatibility/gg622941(v=vs.85)
CWE Id 345
WASC Id 12
Plugin Id 10019
Informational
Information Disclosure - Sensitive Information in URL
Description
The request appeared to contain sensitive information leaked in the URL. This can violate PCI and most organizational compliance policies. You can configure the list of strings for this check to add or remove values specific to your environment.
URL https://cfas.apprentissage.beta.gouv.fr/auth/connexion?email=zaproxy%40example.com&password=ZAP
Method GET
Parameter email
Attack
Evidence zaproxy@example.com
Other Info The URL contains email address(es).
URL https://cfas.apprentissage.beta.gouv.fr/auth/connexion?email=zaproxy%40example.com&password=ZAP
Method GET
Parameter password
Attack
Evidence password
Other Info The URL contains potentially sensitive information. The following string was found via the pattern: pass password
URL https://cfas.apprentissage.beta.gouv.fr/auth/mot-de-passe-oublie?email=zaproxy%40example.com
Method GET
Parameter email
Attack
Evidence zaproxy@example.com
Other Info The URL contains email address(es).
Instances 3
Solution
Do not pass sensitive information in URIs.
Reference
CWE Id 598
WASC Id 13
Plugin Id 10024
Informational
Information Disclosure - Suspicious Comments
Description
The response appears to contain suspicious comments which may help an attacker.
URL https://cfas.apprentissage.beta.gouv.fr/_next/static/chunks/2645-7d4b987e4387ea3a.js
Method GET
Parameter
Attack
Evidence where
Other Info The following pattern was used: \bWHERE\b and was detected in likely comment: "//mui.com/production-error/?code=${e}`);return t.forEach(e=>r.searchParams.append("args[]",e)),`Minified MUI error #${e}; visit ", see evidence field for the suspicious comment/snippet.
URL https://cfas.apprentissage.beta.gouv.fr/_next/static/chunks/3474-0f9dfce41a587792.js
Method GET
Parameter
Attack
Evidence query
Other Info The following pattern was used: \bQUERY\b and was detected in likely comment: "//",e.exports=a(177)}()},9234:(e,t,n)=>{"use strict";n.d(t,{T:()=>c,k:()=>p});var r=n(12115),i=n(9214),o=n(44352),a=n(81622),s=f", see evidence field for the suspicious comment/snippet.
URL https://cfas.apprentissage.beta.gouv.fr/_next/static/chunks/3528-6b47bedda7c3acc3.js
Method GET
Parameter
Attack
Evidence db
Other Info The following pattern was used: \bDB\b and was detected in likely comment: "//www.npmjs.com/package/react-native-get-random-values.")}return H})(),W=/(\d|[a-f])/i,G={toLocalBufferType(e){let t=e?.[Symbol.", see evidence field for the suspicious comment/snippet.
URL https://cfas.apprentissage.beta.gouv.fr/_next/static/chunks/4bd1b696-0e9db5a92aec0997.js
Method GET
Parameter
Attack
Evidence select
Other Info The following pattern was used: \bSELECT\b and was detected in likely comment: "//react.dev/errors/"+e;if(1<arguments.length){n+="?args[]="+encodeURIComponent(arguments[1]);for(var t=2;t<arguments.length;t++)", see evidence field for the suspicious comment/snippet.
URL https://cfas.apprentissage.beta.gouv.fr/_next/static/chunks/968-3c1480cd509d4bde.js
Method GET
Parameter
Attack
Evidence from
Other Info The following pattern was used: \bFROM\b and was detected in likely comment: "//${l}${t&&a?`:${a}`:""}@${r}${i?`:${i}`:""}/${n?`${n}/`:n}${o}`}function ta(e){let t=tr.exec(e);if(!t){(0,N.pq)(()=>{console.er", see evidence field for the suspicious comment/snippet.
URL https://cfas.apprentissage.beta.gouv.fr/_next/static/chunks/app/(home)/layout-ae59704e3ffc07a2.js
Method GET
Parameter
Attack
Evidence select
Other Info The following pattern was used: \bSELECT\b and was detected in likely comment: "//")||/^https?:\/\//.test(u)))return n.createElement("a",Object.assign({href:u,target:"_blank",rel:"noreferrer"},c));if(void 0!=", see evidence field for the suspicious comment/snippet.
URL https://cfas.apprentissage.beta.gouv.fr/_next/static/chunks/app/global-error-8731506d1b4fe6b9.js
Method GET
Parameter
Attack
Evidence from
Other Info The following pattern was used: \bFROM\b and was detected in likely comment: "//fonts.googleapis.com/css","https://use.typekit.net/"].some(t=>e.props.href.startsWith(t))){let t={...e.props||{}};return t["da", see evidence field for the suspicious comment/snippet.
URL https://cfas.apprentissage.beta.gouv.fr/_next/static/chunks/app/not-found-2e36765fd3a4206b.js
Method GET
Parameter
Attack
Evidence from
Other Info The following pattern was used: \bFROM\b and was detected in likely comment: "//fonts.googleapis.com/css","https://use.typekit.net/"].some(t=>e.props.href.startsWith(t))){let t={...e.props||{}};return t["da", see evidence field for the suspicious comment/snippet.
URL https://cfas.apprentissage.beta.gouv.fr/_next/static/chunks/framework-eb3209f1be6b8026.js
Method GET
Parameter
Attack
Evidence select
Other Info The following pattern was used: \bSELECT\b and was detected in likely comment: "//reactjs.org/docs/error-decoder.html?invariant="+e,t=1;t<arguments.length;t++)n+="&args[]="+encodeURIComponent(arguments[t]);re", see evidence field for the suspicious comment/snippet.
URL https://cfas.apprentissage.beta.gouv.fr/_next/static/chunks/polyfills-42372ed130431b0a.js
Method GET
Parameter
Attack
Evidence from
Other Info The following pattern was used: \bFROM\b and was detected in likely comment: "//github.com/zloirock/core-js/blob/v3.38.1/LICENSE",source:"https://github.com/zloirock/core-js"})}),nt=function(t,e){return rt[", see evidence field for the suspicious comment/snippet.
URL https://cfas.apprentissage.beta.gouv.fr/mentions-legales
Method GET
Parameter
Attack
Evidence query
Other Info The following pattern was used: \bQUERY\b and was detected in likely comment: "//prod-files-secure.s3.us-west-2.amazonaws.com/05f81a44-623d-4900-930e-85f69631db13/f9a1d316-c444-4f76-958e-3139764ad844/logo-ge", see evidence field for the suspicious comment/snippet.
URL https://cfas.apprentissage.beta.gouv.fr/politique-de-confidentialite
Method GET
Parameter
Attack
Evidence query
Other Info The following pattern was used: \bQUERY\b and was detected in likely comment: "//prod-files-secure.s3.us-west-2.amazonaws.com/05f81a44-623d-4900-930e-85f69631db13/f9a1d316-c444-4f76-958e-3139764ad844/logo-ge", see evidence field for the suspicious comment/snippet.
Instances 12
Solution
Remove all comments that return information that may help an attacker and fix any underlying problems they refer to.
Reference
CWE Id 615
WASC Id 13
Plugin Id 10027
Informational
Modern Web Application
Description
The application appears to be a modern web application. If you need to explore it automatically then the Ajax Spider may well be more effective than the standard one.
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter
Attack
Evidence <a target="_self" class="fr-btn fr-icon-add-circle-line" id="fr-header-simple-header-with-service-title-and-tagline-quick-access-item-0" href="/auth/inscription">S&#x27;inscrire</a>
Other Info Links have been found with a target of '_self' - this is often used by modern frameworks to force a full page reload.
URL https://cfas.apprentissage.beta.gouv.fr/
Method GET
Parameter
Attack
Evidence <a target="_self" class="fr-btn fr-icon-add-circle-line" id="fr-header-simple-header-with-service-title-and-tagline-quick-access-item-0" href="/auth/inscription">S&#x27;inscrire</a>
Other Info Links have been found with a target of '_self' - this is often used by modern frameworks to force a full page reload.
URL https://cfas.apprentissage.beta.gouv.fr/auth/connexion
Method GET
Parameter
Attack
Evidence <a target="_self" class="fr-btn fr-icon-add-circle-line" id="fr-header-simple-header-with-service-title-and-tagline-quick-access-item-0" href="/auth/inscription">S&#x27;inscrire</a>
Other Info Links have been found with a target of '_self' - this is often used by modern frameworks to force a full page reload.
URL https://cfas.apprentissage.beta.gouv.fr/auth/en-attente-confirmation
Method GET
Parameter
Attack
Evidence <script defer="" nomodule="" src="/_next/static/chunks/polyfills-42372ed130431b0a.js"></script>
Other Info No links have been found while there are scripts, which is an indication that this is a modern web application.
URL https://cfas.apprentissage.beta.gouv.fr/auth/finalisation
Method GET
Parameter
Attack
Evidence <script defer="" nomodule="" src="/_next/static/chunks/polyfills-42372ed130431b0a.js"></script>
Other Info No links have been found while there are scripts, which is an indication that this is a modern web application.
URL https://cfas.apprentissage.beta.gouv.fr/auth/inscription
Method GET
Parameter
Attack
Evidence <script defer="" nomodule="" src="/_next/static/chunks/polyfills-42372ed130431b0a.js"></script>
Other Info No links have been found while there are scripts, which is an indication that this is a modern web application.
URL https://cfas.apprentissage.beta.gouv.fr/cgu
Method GET
Parameter
Attack
Evidence <script defer="" nomodule="" src="/_next/static/chunks/polyfills-42372ed130431b0a.js"></script>
Other Info No links have been found while there are scripts, which is an indication that this is a modern web application.
URL https://cfas.apprentissage.beta.gouv.fr/modifier-mot-de-passe
Method GET
Parameter
Attack
Evidence <script src="/_next/static/chunks/4bd1b696-0e9db5a92aec0997.js" async=""></script>
Other Info No links have been found while there are scripts, which is an indication that this is a modern web application.
URL https://cfas.apprentissage.beta.gouv.fr/questions-reponses
Method GET
Parameter
Attack
Evidence <script defer="" nomodule="" src="/_next/static/chunks/polyfills-42372ed130431b0a.js"></script>
Other Info No links have been found while there are scripts, which is an indication that this is a modern web application.
URL https://cfas.apprentissage.beta.gouv.fr/robots.txt
Method GET
Parameter
Attack
Evidence <script src="/_next/static/chunks/4bd1b696-0e9db5a92aec0997.js" async=""></script>
Other Info No links have been found while there are scripts, which is an indication that this is a modern web application.
URL https://cfas.apprentissage.beta.gouv.fr/stats
Method GET
Parameter
Attack
Evidence <script defer="" nomodule="" src="/_next/static/chunks/polyfills-42372ed130431b0a.js"></script>
Other Info No links have been found while there are scripts, which is an indication that this is a modern web application.
Instances 11
Solution
This is an informational alert and so no changes are required.
Reference
CWE Id
WASC Id
Plugin Id 10109
Informational
Non-Storable Content
Description
The response contents are not storable by caching components such as proxy servers. If the response does not contain sensitive, personal or user-specific information, it may benefit from being stored and cached, to improve performance.
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter
Attack
Evidence no-store
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/
Method GET
Parameter
Attack
Evidence no-store
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/auth/en-attente-confirmation
Method GET
Parameter
Attack
Evidence no-store
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/auth/finalisation
Method GET
Parameter
Attack
Evidence no-store
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/auth/inscription
Method GET
Parameter
Attack
Evidence no-store
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/cgu
Method GET
Parameter
Attack
Evidence no-store
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/modifier-mot-de-passe
Method GET
Parameter
Attack
Evidence no-store
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/questions-reponses
Method GET
Parameter
Attack
Evidence no-store
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/robots.txt
Method GET
Parameter
Attack
Evidence no-store
Other Info
Instances 9
Solution
The content may be marked as storable by ensuring that the following conditions are satisfied:

The request method must be understood by the cache and defined as being cacheable ("GET", "HEAD", and "POST" are currently defined as cacheable)

The response status code must be understood by the cache (one of the 1XX, 2XX, 3XX, 4XX, or 5XX response classes are generally understood)

The "no-store" cache directive must not appear in the request or response header fields

For caching by "shared" caches such as "proxy" caches, the "private" response directive must not appear in the response

For caching by "shared" caches such as "proxy" caches, the "Authorization" header field must not appear in the request, unless the response explicitly allows it (using one of the "must-revalidate", "public", or "s-maxage" Cache-Control response directives)

In addition to the conditions above, at least one of the following conditions must also be satisfied by the response:

It must contain an "Expires" header field

It must contain a "max-age" response directive

For "shared" caches such as "proxy" caches, it must contain a "s-maxage" response directive

It must contain a "Cache Control Extension" that allows it to be cached

It must have a status code that is defined as cacheable by default (200, 203, 204, 206, 300, 301, 404, 405, 410, 414, 501).
Reference https://datatracker.ietf.org/doc/html/rfc7234
https://datatracker.ietf.org/doc/html/rfc7231
https://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html
CWE Id 524
WASC Id 13
Plugin Id 10049
Informational
Re-examine Cache-control Directives
Description
The cache-control header has not been set properly or is missing, allowing the browser and proxies to cache content. For static assets like css, js, or image files this might be intended, however, the resources should be reviewed to ensure that no sensitive content will be cached.
URL https://cfas.apprentissage.beta.gouv.fr/docs/kit-deploiement-tba-op
Method GET
Parameter cache-control
Attack
Evidence s-maxage=1800, stale-while-revalidate=31534200
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/mentions-legales
Method GET
Parameter cache-control
Attack
Evidence s-maxage=1800, stale-while-revalidate=31534200
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/
Method GET
Parameter cache-control
Attack
Evidence max-age=0, no-cache, must-revalidate, proxy-revalidate
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/app/assets/img/browserconfig.xml
Method GET
Parameter cache-control
Attack
Evidence max-age=0, no-cache, must-revalidate, proxy-revalidate
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/3725a628-f37b-4220-8e55-b63241835b13
Method GET
Parameter cache-control
Attack
Evidence max-age=0, no-cache, must-revalidate, proxy-revalidate
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/78bc775c-1be5-4e61-b81c-3fe4679e480b
Method GET
Parameter cache-control
Attack
Evidence max-age=0, no-cache, must-revalidate, proxy-revalidate
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/8af240fe-aaed-466e-a903-537b328a749f
Method GET
Parameter cache-control
Attack
Evidence max-age=0, no-cache, must-revalidate, proxy-revalidate
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/9808c918-2d2f-4ae5-b0e7-5e1d982e3e66
Method GET
Parameter cache-control
Attack
Evidence max-age=0, no-cache, must-revalidate, proxy-revalidate
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/politique-de-confidentialite
Method GET
Parameter cache-control
Attack
Evidence s-maxage=1800, stale-while-revalidate=31534200
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/sitemap.xml
Method GET
Parameter cache-control
Attack
Evidence public, max-age=0
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/stats
Method GET
Parameter cache-control
Attack
Evidence s-maxage=31536000
Other Info
Instances 11
Solution
For secure content, ensure the cache-control HTTP header is set with "no-cache, no-store, must-revalidate". If an asset should be cached consider setting the directives "public, max-age, immutable".
Reference https://cheatsheetseries.owasp.org/cheatsheets/Session_Management_Cheat_Sheet.html#web-content-caching
https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control
https://grayduck.mn/2021/09/13/cache-control-recommendations/
CWE Id 525
WASC Id 13
Plugin Id 10015
Informational
Sec-Fetch-Dest Header is Missing
Description
Specifies how and where the data would be used. For instance, if the value is audio, then the requested resource must be audio data and not any other type of resource.
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter Sec-Fetch-Dest
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/robots.txt
Method GET
Parameter Sec-Fetch-Dest
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/sitemap.xml
Method GET
Parameter Sec-Fetch-Dest
Attack
Evidence
Other Info
Instances 3
Solution
Ensure that Sec-Fetch-Dest header is included in request headers.
Reference https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Sec-Fetch-Dest
CWE Id 352
WASC Id 9
Plugin Id 90005
Informational
Sec-Fetch-Mode Header is Missing
Description
Allows to differentiate between requests for navigating between HTML pages and requests for loading resources like images, audio etc.
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter Sec-Fetch-Mode
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/robots.txt
Method GET
Parameter Sec-Fetch-Mode
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/sitemap.xml
Method GET
Parameter Sec-Fetch-Mode
Attack
Evidence
Other Info
Instances 3
Solution
Ensure that Sec-Fetch-Mode header is included in request headers.
Reference https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Sec-Fetch-Mode
CWE Id 352
WASC Id 9
Plugin Id 90005
Informational
Sec-Fetch-Site Header is Missing
Description
Specifies the relationship between request initiator's origin and target's origin.
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter Sec-Fetch-Site
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/robots.txt
Method GET
Parameter Sec-Fetch-Site
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/sitemap.xml
Method GET
Parameter Sec-Fetch-Site
Attack
Evidence
Other Info
Instances 3
Solution
Ensure that Sec-Fetch-Site header is included in request headers.
Reference https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Sec-Fetch-Site
CWE Id 352
WASC Id 9
Plugin Id 90005
Informational
Sec-Fetch-User Header is Missing
Description
Specifies if a navigation request was initiated by a user.
URL https://cfas.apprentissage.beta.gouv.fr
Method GET
Parameter Sec-Fetch-User
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/robots.txt
Method GET
Parameter Sec-Fetch-User
Attack
Evidence
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/sitemap.xml
Method GET
Parameter Sec-Fetch-User
Attack
Evidence
Other Info
Instances 3
Solution
Ensure that Sec-Fetch-User header is included in user initiated requests.
Reference https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Sec-Fetch-User
CWE Id 352
WASC Id 9
Plugin Id 90005
Informational
Session Management Response Identified
Description
The given response has been identified as containing a session management token. The 'Other Info' field contains a set of header tokens that can be used in the Header Based Session Management Method. If the request is in a context which has a Session Management Method set to "Auto-Detect" then this rule will change the session management to use the tokens identified.
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/3725a628-f37b-4220-8e55-b63241835b13
Method GET
Parameter metabase.DEVICE
Attack
Evidence metabase.DEVICE
Other Info cookie:metabase.DEVICE
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/78bc775c-1be5-4e61-b81c-3fe4679e480b
Method GET
Parameter metabase.DEVICE
Attack
Evidence metabase.DEVICE
Other Info cookie:metabase.DEVICE
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/8af240fe-aaed-466e-a903-537b328a749f
Method GET
Parameter metabase.DEVICE
Attack
Evidence metabase.DEVICE
Other Info cookie:metabase.DEVICE
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/9808c918-2d2f-4ae5-b0e7-5e1d982e3e66
Method GET
Parameter metabase.DEVICE
Attack
Evidence metabase.DEVICE
Other Info cookie:metabase.DEVICE
URL https://cfas.apprentissage.beta.gouv.fr/metabase/public/dashboard/78bc775c-1be5-4e61-b81c-3fe4679e480b
Method GET
Parameter metabase.DEVICE
Attack
Evidence metabase.DEVICE
Other Info cookie:metabase.DEVICE
Instances 5
Solution
This is an informational alert rather than a vulnerability and so there is nothing to fix.
Reference https://www.zaproxy.org/docs/desktop/addons/authentication-helper/session-mgmt-id
CWE Id
WASC Id
Plugin Id 10112
Informational
Storable and Cacheable Content
Description
The response contents are storable by caching components such as proxy servers, and may be retrieved directly from the cache, rather than from the origin server by the caching servers, in response to similar requests from other users. If the response data is sensitive, personal or user-specific, this may result in sensitive information being leaked. In some cases, this may even result in a user gaining complete control of the session of another user, depending on the configuration of the caching components in use in their environment. This is primarily an issue where "shared" caching servers such as "proxy" caches are configured on the local network. This configuration is typically found in corporate or educational environments, for instance.
URL https://cfas.apprentissage.beta.gouv.fr/stats
Method GET
Parameter
Attack
Evidence s-maxage=31536000
Other Info
Instances 1
Solution
Validate that the response does not contain sensitive, personal or user-specific information. If it does, consider the use of the following HTTP response headers, to limit, or prevent the content being stored and retrieved from the cache by another user:

Cache-Control: no-cache, no-store, must-revalidate, private

Pragma: no-cache

Expires: 0

This configuration directs both HTTP 1.0 and HTTP 1.1 compliant caching servers to not store the response, and to not retrieve the response (without validation) from the cache, in response to a similar request.
Reference https://datatracker.ietf.org/doc/html/rfc7234
https://datatracker.ietf.org/doc/html/rfc7231
https://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html
CWE Id 524
WASC Id 13
Plugin Id 10049
Informational
Storable but Non-Cacheable Content
Description
The response contents are storable by caching components such as proxy servers, but will not be retrieved directly from the cache, without validating the request upstream, in response to similar requests from other users.
URL https://cfas.apprentissage.beta.gouv.fr/images/landing-presentation-tdb.svg
Method GET
Parameter
Attack
Evidence max-age=0
Other Info
URL https://cfas.apprentissage.beta.gouv.fr/sitemap.xml
Method GET
Parameter
Attack
Evidence max-age=0
Other Info
Instances 2
Solution
Reference https://datatracker.ietf.org/doc/html/rfc7234
https://datatracker.ietf.org/doc/html/rfc7231
https://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html
CWE Id 524
WASC Id 13
Plugin Id 10049

Sequence Details

With the associated active scan results.