Apache NiFi Security
Apache NiFi welcomes the responsible reporting of security vulnerabilities. Project Management Committee members will collaborate and respond to potential vulnerabilities, providing an assessment of the concern and a plan of action to remediate verified issues.
Reporting Policy
Please read the Apache Project Security for Committers policy for general guidelines applicable disclosure of security issues for Apache Software Foundation projects.
Do not perform the following actions after discovering a potential security concern:
- Open a Jira disclosing a security vulnerability to the public
- Send a message to the project mailing lists disclosing a security vulnerability to the public
- Send a message to the project Slack instance disclosing a security vulnerability to the public
Reporting Guidelines
Configuring dangerous operating system commands or custom scripts is not a project security vulnerability. Authenticated and authorized users are responsible for the security of operating system commands and custom code.
Apache NiFi provides a framework for developing processing pipelines using standard and custom components. The framework supports configurable permissions that enable authorized users to execute code using several standard components. Components such as ExecuteProcess and ExecuteStreamCommand support running operating system commands, while other scripted components support executing custom code using different programming languages. Configuring these components with untrusted commands or arguments is contrary to best practices, but it does not constitute of security issue for remediation.
Reporting Process
- Notify the project on initial discovery of a potential security vulnerability
- Provide a reasonable amount of time for an initial assessment and remediation plan
- Limit interaction to accounts under direct control or accounts with explicit permission of the owner
- Avoid privacy violations, destruction of data, and interruption or degradation of services
- Avoid spamming, social engineering, and methods to manipulate project members
Reporting Methods
- Security Mailing List: security@nifi.apache.org
- Members of the Project Management Committee monitor this private mailing list and respond to disclosures
Severity Ratings
Severity ratings represent the determination of project members based on an evaluation of Common Vulnerability Scoring System calculations.
- Critical: Arbitrary code execution from a remote attacker
- High: Compromise of integrity or availability through resource exhaustion
- Medium: Requires special configuration settings and significant mitigations are available
- Low: Minimal impact and significant difficulty of exploitation
Published Vulnerabilities
The following announcements include published vulnerabilities that apply directly to Apache NiFi components.
CVE-2024-45477
- Title: Improper Neutralization of Input in Parameter Description
- Published: 2024-10-28
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.10.0 to 1.27.0 and 2.0.0-M1 to 2.0.0-M3
- Fixed Versions: 1.28.0 and 2.0.0-M4
- Reporter: Muhammad Hazim Bin Nor Aizi
- References
- CVE Record: CVE-2024-45477
- NVD Record: CVE-2024-45477
- Apache Jira Issue: NIFI-13675
- GitHub Pull Request: 9195
Apache NiFi 1.10.0 through 1.27.0 and 2.0.0-M1 through 2.0.0-M3 support a description field for Parameters in a Parameter Context configuration that is vulnerable to cross-site scripting. An authenticated user, authorized to configure a Parameter Context, can enter arbitrary JavaScript code, which the client browser will execute within the session context of the authenticated user. Upgrading to Apache NiFi 1.28.0 or 2.0.0-M4 is the recommended mitigation.
CVE-2024-37389
- Title: Improper Neutralization of Input in Parameter Context Description
- Published: 2024-07-08
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.10.0 to 1.26.0 and 2.0.0-M1 to 2.0.0-M3
- Fixed Versions: 1.27.0 and 2.0.0-M4
- Reporter: Akbar Kustirama at abay.sh, GitHub user abaykan
- References
- CVE Record: CVE-2024-37389
- NVD Record: CVE-2024-37389
- Apache Jira Issue: NIFI-13374
- GitHub Pull Request: 8938
Apache NiFi 1.10.0 through 1.26.0 and 2.0.0-M1 through 2.0.0-M3 support a description field in the Parameter Context configuration that is vulnerable to cross-site scripting. An authenticated user, authorized to configure a Parameter Context, can enter arbitrary JavaScript code, which the client browser will execute within the session context of the authenticated user. Upgrading to Apache NiFi 1.27.0 or 2.0.0-M4 is the recommended mitigation.
CVE-2023-49145
- Title: Improper Neutralization of Input in Advanced User Interface for Jolt
- Published: 2023-11-27
- Severity: High
- Products: Apache NiFi
- Affected Versions: 0.7.0 to 1.23.2
- Fixed Versions: 1.24.0
- Reporter: Dr. Oliver Matula, DB Systel GmbH
- References
- CVE Record: CVE-2023-49145
- NVD Record: CVE-2023-49145
- Apache Jira Issue: NIFI-12403
- GitHub Pull Request: 8060
Apache NiFi 0.7.0 through 1.23.2 include the JoltTransformJSON Processor, which provides an advanced configuration user interface that is vulnerable to DOM-based cross-site scripting. If an authenticated user, who is authorized to configure a JoltTransformJSON Processor, visits a crafted URL, then arbitrary JavaScript code can be executed within the session context of the authenticated user. Upgrading to Apache NiFi 1.24.0 or 2.0.0-M1 is the recommended mitigation.
CVE-2023-40037
- Title: Incomplete Validation of JDBC and JNDI Connection URLs
- Published: 2023-08-18
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.21.0 to 1.23.0
- Fixed Versions: 1.23.1
- Reporter: Matei 'Mal' Badanoiu
- References
- CVE Record: CVE-2023-40037
- NVD Record: CVE-2023-40037
- Apache Jira Issue: NIFI-11920
- GitHub Pull Request: 7586
Apache NiFi 1.21.0 through 1.23.0 support JDBC and JNDI JMS access in several Processors and Controller Services with connection URL validation that does not provide sufficient protection against crafted inputs. An authenticated and authorized user can bypass connection URL validation using custom input formatting. The resolution enhances connection URL validation and introduces validation for additional related properties. Upgrading to Apache NiFi 1.23.1 is the recommended mitigation.
CVE-2023-36542
- Title: Potential Code Injection with Properties Referencing Remote Resources
- Published: 2023-07-28
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 0.0.2 to 1.22.0
- Fixed Versions: 1.23.0
- Reporter: nbxiglk
- References
- CVE Record: CVE-2023-36542
- NVD Record: CVE-2023-36542
- Apache Jira Issue: NIFI-11744
- GitHub Pull Request: 7426
Apache NiFi 0.0.2 through 1.22.0 include Processors and Controller Services that support HTTP URL references for retrieving drivers, which allows an authenticated and authorized user to configure a location that enables custom code execution. The resolution introduces a new Required Permission for referencing remote resources, restricting configuration of these components to privileged users. The permission prevents unprivileged users from configuring Processors and Controller Services annotated with the new Reference Remote Resources restriction. Upgrading to Apache NiFi 1.23.0 is the recommended mitigation.
CVE-2023-34468
- Title: Potential Code Injection with Database Services using H2
- Published: 2023-06-12
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 0.0.2 to 1.21.0
- Fixed Versions: 1.22.0
- Reporter: Matei 'Mal' Badanoiu
- References
- CVE Record: CVE-2023-34468
- NVD Record: CVE-2023-34468
- Apache Jira Issue: NIFI-11653
- GitHub Pull Request: 7349
The DBCPConnectionPool and HikariCPConnectionPool Controller Services in Apache NiFi 0.0.2 through 1.21.0 allow an authenticated and authorized user to configure a Database URL with the H2 driver that enables custom code execution. The resolution validates the Database URL and rejects H2 JDBC locations. Upgrading to NiFi 1.22.0 disables H2 JDBC URLs in the default configuration.
CVE-2023-34212
- Title: Potential Deserialization of Untrusted Data with JNDI in JMS Components
- Published: 2023-06-12
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.8.0 to 1.21.0
- Fixed Versions: 1.22.0
- Reporter: Veraxy00 of Qianxin TI Center and Matei 'Mal' Badanoiu
- References
- CVE Record: CVE-2023-34212
- NVD Record: CVE-2023-34212
- Apache Jira Issue: NIFI-11614
- GitHub Pull Request: 7313
The JndiJmsConnectionFactoryProvider Controller Service along with the ConsumeJMS and PublishJMS Processors, in Apache NiFi 1.8.0 through 1.21.0 allow an authenticated and authorized user to configure URL and library properties that enable deserialization of untrusted data from a remote location. The resolution validates the JNDI URL and restricts locations to a set of allowed schemes. Upgrading to NiFi 1.22.0 disables LDAP for JNDI URLs in the default configuration.
CVE-2023-22832
- Title: Improper Restriction of XML External Entity References in ExtractCCDAAttributes
- Published: 2023-02-09
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.2.0 to 1.19.1
- Fixed Versions: 1.20.0
- Reporter: Yi Cai of Chaitin Tech
- References
- CVE Record: CVE-2023-22832
- NVD Record: CVE-2023-22832
- Apache Jira Issue: NIFI-11029
- GitHub Pull Request: 6828
The ExtractCCDAAttributes Processor in Apache NiFi 1.2.0 through 1.19.1 does not restrict XML External Entity references. Flow configurations that include the ExtractCCDAAttributes Processor are vulnerable to malicious XML documents that contain Document Type Declarations with XML External Entity references. The resolution disables Document Type Declarations and disallows XML External Entity resolution in the ExtractCCDAAttributes Processor. Upgrading to NiFi 1.20.0 disables Document Type Declarations in the default configuration for ExtractCCDAAttributes.
CVE-2022-33140
- Title: Improper Neutralization of Command Elements in Shell User Group Provider
- Published: 2022-06-15
- Severity: High
- Products: Apache NiFi and Apache NiFi Registry
- Affected Versions: 1.10.0 to 1.16.2
- Fixed Versions: 1.20.0
- Reporter: Anonymous
- References
- CVE Record: CVE-2022-33140
- NVD Record: CVE-2022-33140
- Apache Jira Issue: NIFI-10114
- GitHub Pull Request: 6122
The optional ShellUserGroupProvider in Apache NiFi 1.10.0 to 1.16.2 and Apache NiFi Registry 0.6.0 to 1.16.2 does not neutralize arguments for group resolution commands, allowing injection of operating system commands on Linux and macOS platforms. The ShellUserGroupProvider is not included in the default configuration. Command injection requires ShellUserGroupProvider to be one of the enabled User Group Providers in the Authorizers configuration. Command injection also requires an authenticated user with elevated privileges. Apache NiFi requires an authenticated user with authorization to modify access policies to execute the command. Apache NiFi Registry requires an authenticated user with authorization to read user groups to execute the command. NiFi and NiFi Registry version 1.16.3 has completely removed the shell commands from the ShellUserGroupProvider that received user arguments.
CVE-2022-29265
- Title: Improper Restriction of XML External Entity References in Multiple Components
- Published: 2022-04-29
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 0.0.1 to 1.16.0
- Fixed Versions: 1.16.1
- Reporter: David Handermann at exceptionfactory.com
- References
- CVE Record: CVE-2022-29265
- NVD Record: CVE-2022-29265
- Apache Jira Issue: NIFI-9901
- GitHub Pull Request: 5962
Multiple components in Apache NiFi 0.0.1 to 1.16.0 do not restrict XML External Entity references in the default configuration. The Standard Content Viewer service attempts to resolve XML External Entity references when viewing formatted XML files. The following Processors attempt to resolve XML External Entity references when configured with default property values: EvaluateXPath, EvaluateXQuery, and ValidateXml. Apache NiFi flow configurations that include these Processors are vulnerable to malicious XML documents that contain Document Type Declarations with XML External Entity references. Upgrading to NiFi 1.16.1 disables Document Type Declarations in the default configuration for these processors, and disallows XML External Entity resolution in standard services.
CVE-2022-26850
- Title: Insufficiently Protected Credentials for Single-User Authentication
- Published: 2022-03-27
- Severity: Low
- Products: Apache NiFi
- Affected Versions: 1.14.0 to 1.15.3
- Fixed Versions: 1.16.0
- Reporter: Jonathan Leitschuh at twitter.com/jlleitschuh
- References
- CVE Record: CVE-2022-26850
- NVD Record: CVE-2022-26850
- Apache Jira Issue: NIFI-9785
- GitHub Pull Request: 5856
When creating or updating credentials for single-user access, NiFi wrote a copy of the Login Identity Providers configuration to the operating system temporary directory. The Login Identity Providers configuration file contains the username and a bcrypt hash of the configured password. On most platforms, the operating system temporary directory has global read permissions. NiFi immediately moved the temporary file to the final configuration directory, which significantly limited the window of opportunity for access. Bcrypt is a password-hashing algorithm that incorporates a random salt and a specified cost factor, designed to maintain resistance to brute-force attacks. Use of the bcrypt algorithm minimizes the impact of disclosing the single-user credentials stored in Login Identity Providers. NiFi 1.16.0 includes updates to replace the Login Identity Providers configuration without writing a file to the operating system temporary directory.
CVE-2021-44145
- Title: Potential Information Disclosure through XML External Entity Resoltion in TransformXML
- Published: 2021-12-15
- Severity: Low
- Products: Apache NiFi
- Affected Versions: 0.1.0 to 1.15.0
- Fixed Versions: 1.15.1
- Reporter: DangKhai at Viettel Cyber Security
- References
- CVE Record: CVE-2021-44145
- NVD Record: CVE-2021-44145
- Apache Jira Issue: NIFI-9399
- GitHub Pull Request: 5542
In the TransformXML processor, an authenticated user could configure an XSLT file which, if it included malicious external entity calls, may reveal sensitive information. The Secure processing property in TransformXML will now apply to the configured XSLT file as well as flow files being transformed. Users running any previous NiFi release should upgrade to 1.15.1.
CVE-2020-9486
- Title: Potential Information Disclosure in Application Logs
- Published: 2020-08-18
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.10.0 to 1.11.4
- Fixed Versions: 1.12.0
- Reporter: Andy LoPresto and Pierre Villard
- References
- CVE Record: CVE-2020-9486
- NVD Record: CVE-2020-9486
- Apache Jira Issue: NIFI-7377
- GitHub Pull Request: 4222
The NiFi stateless execution engine produced log output which included sensitive property values. When a flow was triggered, the flow definition configuration JSON was printed, potentially containing sensitive values in plaintext. NiFi 1.12.0 implemented Argon2 secure hashing to provide a deterministic loggable value which does not reveal the sensitive value. Users running any previous NiFi release should upgrade to 1.12.0.
CVE-2020-9487
- Title: Potential Denial of Service with Token Authentication Requests
- Published: 2020-08-18
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.0.0 to 1.11.4
- Fixed Versions: 1.12.0
- Reporter: Dennis Detering, IT Security Consultant at Spike Reply
- References
- CVE Record: CVE-2020-9487
- NVD Record: CVE-2020-9487
- Apache Jira Issue: NIFI-7385
- GitHub Pull Request: 4271
The NiFi download token (one-time password) mechanism used a fixed cache size and did not authenticate a request to create a download token, only when attempting to use the token to access the content. An unauthenticated user could repeatedly request download tokens, preventing legitimate users from requesting download tokens. NiFi 1.12.0 disabled anonymous authentication, implemented a multi-indexed cache, and limited token creation requests to one concurrent request per user. Users running any previous NiFi release should upgrade to 1.12.0.
CVE-2020-9491
- Title: Insecure TLS Protocol Versions for Cluster Communication
- Published: 2020-08-18
- Severity: High
- Products: Apache NiFi
- Affected Versions: 1.2.0 to 1.11.4
- Fixed Versions: 1.12.0
- Reporter: Juan Carlos Sequeiros and Andy LoPresto
- References
- CVE Record: CVE-2020-9491
- NVD Record: CVE-2020-9491
- Apache Jira Issue: NIFI-7407
- GitHub Pull Request: 4263
The NiFi UI and API were protected by mandating TLS v1.2, as well as listening connections established by processors like ListenHTTP and HandleHttpRequest. However intra-cluster communication such as cluster request replication, Site-to-Site, and load balanced queues continued to support TLS 1.0 or 1.1. NiFI 1.12.0 refactored disparate internal SSL and TLS code, reducing exposure for extension and framework developers to low-level primitives. NiFi 1.12. also added support for TLS v1.3 on supporting JVMs. This version restricted all incoming TLS communications to TLS 1.2 or higher. Users running any previous NiFi release should upgrade to 1.12.0.
CVE-2020-13940
- Title: Potential Information Disclosure through XML External Entity Resolution in Notification Service
- Published: 2020-08-18
- Severity: Low
- Products: Apache NiFi
- Affected Versions: 1.0.0 to 1.11.4
- Fixed Versions: 1.12.0
- Reporter: Matt Burgess and Andy LoPresto
- References
- CVE Record: CVE-2020-13940
- NVD Record: CVE-2020-13940
- Apache Jira Issue: NIFI-7680
- GitHub Pull Request: 4436
The notification service manager and various policy authorizer and user group provider objects allowed trusted administrators to inadvertently configure a potentially malicious XML file. The XML file has the ability to make external calls to services through XML External Entity resolution. NiFi 1.12.0 introduced an XML validator to prevent malicious code from being parsed and executed. Users running any previous NiFi release should upgrade to 1.12.0.
CVE-2020-9482
- Title: Application Bearer Token Remains Valid After Logout Completion
- Published: 2020-04-07
- Severity: Medium
- Products: Apache NiFi Registry
- Affected Versions: 0.1.0 to 0.5.0
- Fixed Versions: 0.6.0
- Reporter: Andy LoPresto
- References
- CVE Record: CVE-2020-9482
- NVD Record: CVE-2020-9482
- Apache Jira Issue: NIFIREG-361
If NiFi Registry uses an authentication mechanism other than PKI, when the user clicks Log Out, NiFi Registry invalidates the authentication token on the client side but not on the server side. This permits the user's client-side token to be used for up to 12 hours after logging out to make API requests to NiFi Registry. NiFi Registry 0.6.0 invalidates the server-side authentication token immediately after the user clicks the Log Out link.
CVE-2020-1942
- Title: Potential Information Disclosure in Application Logs
- Published: 2020-02-04
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 0.0.1 to 1.11.0
- Fixed Versions: 1.11.1
- Reporter: Andy LoPresto
- References
- CVE Record: CVE-2020-1942
- NVD Record: CVE-2020-1942
- Apache Jira Issue: NIFI-7079
- GitHub Pull Request: 4208
The flow fingerprint factory generated flow fingerprints which included sensitive property descriptor values. In the event a node attempted to join a cluster and the cluster flow was not inheritable, the flow fingerprint of both the cluster and local flow was printed, potentially containing sensitive values in plaintext. NiFi 1.11.1i implemented Argon2 secure hashing to provide a deterministic loggable value which does not reveal the sensitive value. Users running any previous NiFi release should upgrade to 1.11.1.
CVE-2020-1928
- Title: Potential Information Disclosure in Application Debug Logs
- Published: 2020-01-22
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.10.0
- Fixed Versions: 1.11.0
- Reporter: Andy LoPresto
- References
- CVE Record: CVE-2020-1928
- NVD Record: CVE-2020-1928
- Apache Jira Issue: NIFI-6948
- GitHub Pull Request: 3935
The sensitive parameter parser would log parsed property descriptor values for debugging purposes. This would expose literal values entered a sensitive property when no parameter was present. NiFi 1.11.0 removed debug logging from the class. Users running the 1.10.0 release should upgrade to 1.11.0.
CVE-2020-1933
- Title: Potential Cross-Site Scripting in Uploaded Templates
- Published: 2020-01-22
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.0.0 to 1.10.0
- Fixed Versions: 1.11.0
- Reporter: Jakub Palaczynski of ING Tech Poland
- References
- CVE Record: CVE-2020-1933
- NVD Record: CVE-2020-1933
- Apache Jira Issue: NIFI-7023
- GitHub Pull Request: 3991
Malicious scripts could be injected to the UI through action by an unaware authenticated user in Firefox. Did not appear to occur in other browsers. NiFi 1.11.0 adds sanitization of the error response ensures the XSS would not be executed. Users running earlier versions should upgrade to 1.11.0.
CVE-2019-10080
- Title: Potential Information Disclosure through XML External Entity Resolution in File Lookup Service
- Published: 2019-11-04
- Severity: Low
- Products: Apache NiFi
- Affected Versions: 1.3.0 to 1.9.2
- Fixed Versions: 1.10.0
- Reporter: RunningSnail
- References
- CVE Record: CVE-2019-10080
- NVD Record: CVE-2019-10080
- Apache Jira Issue: NIFI-6301
- GitHub Pull Request: 3507
The XMLFileLookupService allowed trusted users to inadvertently configure a potentially malicious XML file. The XML file has the ability to make external calls to services using XML External Entity resolution and reveal information such as the versions of Java, Jersey, and Apache that the NiFI instance uses. NiFi 1.10.0 adds a validator to ensure the XML file is not malicious. Users running a prior release should upgrade to 1.10.0.
CVE-2019-12421
- Title: Application Bearer Token Remains Valid After Logout Completion
- Published: 2019-11-04
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.0.0 to 1.9.2
- Fixed Versions: 1.10.0
- Reporter: Abdu Sahin
- References
- CVE Record: CVE-2019-12421
- NVD Record: CVE-2019-12421
- Apache Jira Issue: NIFI-6085
- GitHub Pull Request: 3362
If NiFi uses an authentication mechanism other than PKI, when the user clicks Log Out, NiFi invalidates the authentication token on the client side but not on the server side. This permits the user's client-side token to be used for up to 12 hours after logging out to make API requests to NiFi. NiFi 1.10.0 invalidates the server-side authentication token immediately after the user clicks the Log Out link. Users running a prior release should upgrade to 1.10.0.
CVE-2019-10083
- Title: Potential Information Disclosure in Process Group Resources
- Published: 2019-11-04
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.0.0 to 1.9.2
- Fixed Versions: 1.10.0
- Reporter: Mark Payne
- References
- CVE Record: CVE-2019-10083
- NVD Record: CVE-2019-10083
- Apache Jira Issue: NIFI-6302
- GitHub Pull Request: 3477
When updating a Process Group via the API, the response to the request includes all of its contents (at the top most level, not recursively). The response included details about processors and controller services which the user may not have had read access to. Requests to update or remove the process group will no longer return the contents of the process group in the response in Apache NiFi 1.10.0. Users running a prior release should upgrade to 1.10.0.
CVE-2018-17192
- Title: Improper Restriction of Browser Frame Access
- Published: 2018-10-26
- Severity: Low
- Products: Apache NiFi
- Affected Versions: 1.0.0 to 1.6.0
- Fixed Versions: 1.8.0
- Reporter: Suchithra V N
- References
- CVE Record: CVE-2018-17192
- NVD Record: CVE-2018-17192
- Apache Jira Issue: NIFI-5258
- GitHub Pull Request: 2759
The X-Frame-Options headers were applied inconsistently on some HTTP responses, resulting in duplicate or missing security headers. Some browsers would interpret these results incorrectly, allowing clickjacking attacks. NiFi 1.8.0 consistently applies the security headers including X-Frame-Options. Users running a prior release should upgrade to 1.8.0.
CVE-2018-17193
- Title: Improper Neutralization of Input in Proxy Request Headers
- Published: 2018-10-26
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.0.0 to 1.7.1
- Fixed Versions: 1.8.0
- Reporter: Dan Fike with assistance from Patrick White
- References
- CVE Record: CVE-2018-17193
- NVD Record: CVE-2018-17193
- Apache Jira Issue: NIFI-5442
- GitHub Pull Request: 2908
The message-page.jsp error page used the value of the HTTP request header X-ProxyContextPath without sanitization, resulting in a potential reflected cross-site scripting attack. NiFi 1.8.0 correctly parses and sanitizes the request attribute value. Users running a prior release should upgrade to 1.8.0.
CVE-2018-17194
- Title: Potential Denial of Service with HTTP DELETE Cluster Replication Requests
- Published: 2018-10-26
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.0.0 to 1.7.1
- Fixed Versions: 1.8.0
- Reporter: Mike Cole and Andy LoPresto
- References
- CVE Record: CVE-2018-17194
- NVD Record: CVE-2018-17194
- Apache Jira Issue: NIFI-5628
- GitHub Pull Request: 3035
When a client request to a cluster node was replicated to other nodes in the cluster for verification, the Content-Length was forwarded. On a DELETE request, the body was ignored, but if the initial request had a Content-Length value other than 0, the receiving nodes would wait for the body and eventually timeout. NiFi 1.8.0 checks DELETE requests and overwrites non-zero Content-Length header. Users running a prior release should upgrade to 1.8.0.
CVE-2018-17195
- Title: Potential Cross-Site Request Forgery in Template Upload Resources
- Published: 2018-10-26
- Severity: Critical
- Products: Apache NiFi
- Affected Versions: 1.0.0 to 1.7.1
- Fixed Versions: 1.8.0
- Reporter: Mike Cole
- References
- CVE Record: CVE-2018-17195
- NVD Record: CVE-2018-17195
- Apache Jira Issue: NIFI-5595
- GitHub Pull Request: 3024
The template upload API endpoint accepted requests from different domain when sent in conjunction with ARP spoofing and meddler in the middle (MITM) intervention, resulting in cross-site request forgery. The required attack vector is complex, requiring a scenario with client certificate authentication, same subnet access, and injecting malicious code into an unprotected (plaintext HTTP) website which the targeted user later visits, but the possible damage warranted a Critical severity level. NiFi 1.8.0 applies Cross-Origin Resource Sharing (CORS) policy request filtering. Users running a prior release should upgrade to 1.8.0.
CVE-2018-1309
- Title: Improper Restriction of XML External Entity References in SplitXml
- Published: 2018-04-08
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 0.1.0 to 1.5.0
- Fixed Versions: 1.6.0
- Reporter: 圆珠笔
- References
- CVE Record: CVE-2018-1309
- NVD Record: CVE-2018-1309
- Apache Jira Issue: NIFI-4869
- GitHub Pull Request: 2466
Malicious XML content could cause information disclosure or remote code execution in the SplitXml Processor. NiFi 1.6.0 disables external general entity parsing and disallows document type declarations in SplitXml. Users running a prior release should upgrade to 1.6.0.
CVE-2018-1310
- Title: Potential Denial of Service in JMS Processors
- Published: 2018-04-08
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 0.1.0 to 1.5.0
- Fixed Versions: 1.6.0
- Reporter: 圆珠笔
- References
- CVE Record: CVE-2018-1310
- NVD Record: CVE-2018-1310
- Apache Jira Issue: NIFI-4870
- GitHub Pull Request: 2469
Malicious JMS content could cause denial of service in impacted Processors. See ActiveMQ CVE-2015-5254 announcement for more information. NiFi 1.6.0 upgrades the activemq-client library to 5.15.3. Users running a prior release should upgrade to 1.6.0.
CVE-2017-12632
- Title: Improper Input Validation of HTTP Host Request Headers
- Published: 2018-01-12
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 0.1.0 to 1.4.0
- Fixed Versions: 1.5.0
- Reporter: Mike Cole
- References
- CVE Record: CVE-2017-12632
- NVD Record: CVE-2017-12632
- Apache Jira Issue: NIFI-4501
- GitHub Pull Request: 2279
A malicious host header in an incoming HTTP request could cause NiFi to load resources from an external server. NiFi 1.5.0 sanitizes host headers and compares to a controlled whitelist property. Users running a prior release should upgrade to 1.5.0.
CVE-2017-15697
- Title: Potential Cross-Site Scripting in Proxy Request Headers
- Published: 2018-01-12
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.0.0 to 1.4.0
- Fixed Versions: 1.5.0
- Reporter: Andy LoPresto
- References
- CVE Record: CVE-2017-15697
- NVD Record: CVE-2017-15697
- Apache Jira Issue: NIFI-4501
- GitHub Pull Request: 2279
A malicious X-ProxyContextPath or X-Forwarded-Context header containing external resources or embedded code could cause remote code execution. NiFi 1.5.0 includes corrected handling of these headers. Users running a prior release should upgrade to 1.5.0.
CVE-2017-12623
- Title: Improper Restriction of XML External Entity References in Template Upload Resources
- Published: 2017-10-02
- Severity: High
- Products: Apache NiFi
- Affected Versions: 1.0.0 to 1.3.0
- Fixed Versions: 1.4.0
- Reporter: Paweł Gocyla with further information from Mike Cole
- References
- CVE Record: CVE-2017-12623
- NVD Record: CVE-2017-12623
- Apache Jira Issue: NIFI-4353
- GitHub Pull Request: 2128
Any authenticated user (valid client certificate but without ACL permissions) could upload a template which contained malicious code and accessed sensitive files via an XML External Entity (XXE) attack. NiFi 1.14.0 properly handles XML External Entities. Users running a prior release should upgrade to 1.4.0.
CVE-2017-15703
- Title: Deserialization of Untrusted Data in Template Upload Resources
- Published: 2017-10-02
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.0.0 to 1.3.0
- Fixed Versions: 1.4.0
- Reporter: Mike Cole
- References
- CVE Record: CVE-2017-15703
- NVD Record: CVE-2017-15703
- Apache Jira Issue: NIFI-4357
- GitHub Pull Request: 2134
Any authenticated user (valid client certificate but without ACL permissions) could upload a template which contained malicious code and cause a denial of service via Java deserialization. NiFi 1.4.0 properly handles Java deserialization. Users running a prior release should upgrade to 1.4.0.
CVE-2017-7665
- Title: Potential Cross-Site Scripting in User Interface Components
- Published: 2017-05-08
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 0.0.1 to 0.7.3 and 1.0.0 to 1.2.0
- Fixed Versions: 0.7.4 and 1.3.0
- Reporter: Matt Gilman
- References
- CVE Record: CVE-2017-7665
- NVD Record: CVE-2017-7665
- Apache Jira Issue: NIFI-3906
- GitHub Pull Request: 1818
There are certain user input components in the Apache NiFi UI which had been guarding for some forms of cross-site scripting issues but were insufficient. NiFi 0.7.4 and 1.3.0 add more complete user input sanitization. Users running a prior release should upgrade to 0.7.4 or 1.3.0.
CVE-2017-7667
- Title: Potential Cross-Frame Scripting from Improper Frame Access Restrictions
- Published: 2017-05-08
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 0.0.1 to 0.7.3 and 1.0.0 to 1.2.0
- Fixed Versions: 0.7.4 and 1.3.0
- Reporter: Matt Gilman
- References
- CVE Record: CVE-2017-7667
- NVD Record: CVE-2017-7667
- Apache Jira Issue: NIFI-3907
Apache NiFi needs to establish the response header telling browsers to only allow framing with the same origin. NiFi 0.7.4 and 1.3.0 set the response header. Users running a prior release should upgrade to 0.7.4 or 1.3.0.
CVE-2017-5635
- Title: Improper Authentication of Replicated Cluster HTTP Requests
- Published: 2017-02-20
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 0.7.0 to 0.7.1 and 1.1.0 to 1.1.1
- Fixed Versions: 0.7.2 and 1.1.2
- Reporter: Leonardo Dias and Matt Gilman
- References
- CVE Record: CVE-2017-5635
- NVD Record: CVE-2017-5635
- Apache Jira Issue: NIFI-3487
In a cluster environment, if an anonymous user request is replicated to another node, the originating node identity is used rather than the anonymous user. NiFi 0.7.2 and 1.1.2 remove the negative check for anonymous user before building the proxy chain and throwing an exception, and evaluating each user in the proxy chain iteration and comparing against a static constant anonymous user. Users running a prior release should upgrade to 0.7.2 or 1.1.2.
CVE-2017-5636
- Title: Improper Authentication of Replicated Cluster HTTP Requests
- Published: 2017-02-20
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 0.7.0 to 0.7.1 and 1.1.0 to 1.1.1
- Fixed Versions: 0.7.2 and 1.1.2
- Reporter: Andy LoPresto
- References
- CVE Record: CVE-2017-5636
- NVD Record: CVE-2017-5636
- Apache Jira Issue: NIFI-3487
In a cluster environment, the proxy chain serialization and deserialization is vulnerable to an injection attack where a carefully crafted username could impersonate another user and gain their permissions on a replicated request to another node. NiFi 0.7.2 and 1.1.2 modify the tokenization code and sanitization of user-provided input. Users running a prior release should upgrade to 0.7.2 or 1.1.2.
CVE-2016-8748
- Title: Potential Cross-Site Scripting in Connection Details Dialog
- Published: 2016-12-19
- Severity: Medium
- Products: Apache NiFi
- Affected Versions: 1.0.0 and 1.1.0
- Fixed Versions: 1.0.1 and 1.1.1
- Reporter: Matt Gilman
- References
- CVE Record: CVE-2016-8748
- NVD Record: CVE-2016-8748
- Apache Jira Issue: NIFI-3154
- GitHub Pull Request: 1305
There is a cross-site scripting vulnerability in connection details dialog when accessed by an authorized user. The user supplied text was not being properly handled when added to the DOM. The vulnerability was resolved after reviewing the pull request when merging changes. Users running a prior release should upgrade to 1.0.1 or 1.1.1.