| Finding ID | Severity | Title | Description | 
                                                                        
                            | V-222662 | High | Default passwords must be changed. | Default passwords can easily be compromised by attackers allowing immediate access to the applications. | 
                                                                        
                            | V-222659 | High | The application must be decommissioned when maintenance or support is no longer available. | Unsupported software products should not be used because fixes to newly identified bugs will not be implemented by the vendor or development team. The lack of security updates can result in potential vulnerabilities.
When maintenance updates and patches are no longer available, the application is no longer considered supported, and... | 
                                                                        
                            | V-222658 | High | All products must be supported by the vendor or the development team. | Unsupported commercial and government developed software products should not be used because fixes to newly identified bugs will not be implemented by the vendor or development team. The lack of security updates can result in potential vulnerabilities. | 
                                                                        
                            | V-222643 | High | The application must have the capability to mark sensitive/classified output when required. | Failure to properly mark output could result in a disclosure of sensitive or classified data which is an immediate loss in confidentiality. | 
                                                                        
                            | V-222642 | High | The application must not contain embedded authentication data. | Authentication data stored in code could potentially be read and used by anonymous users to gain access to a backend database or application servers. This could lead to compromise of application data. | 
                                                                        
                            | V-222620 | High | Application web servers must be on a separate network segment from the application and database servers if it is a tiered application operating in the DoD DMZ. | A tiered application usually consists of 3 tiers, the web layer (presentation tier), the application layer (application logic tier), and the database layer (data storage tier).
Using one system for hosting all 3 tiers introduces risk that if one tier is compromised, there are no additional protection layers available to... | 
                                                                        
                            | V-222612 | High | The application must not be vulnerable to overflow attacks. | A buffer overflow occurs when a program exceeds the amount of data allocated to a buffer. The buffer is a sequential section of memory and when the data is written outside the memory bounds, the program can crash or malicious code can be executed.
Security safeguards employed to protect memory... | 
                                                                        
                            | V-222609 | High | The application must not be subject to input handling vulnerabilities. | A common application vulnerability is unpredictable behavior due to improper input validation. This requirement guards against adverse or unintended system behavior caused by invalid inputs, where information system responses to the invalid input may be disruptive or cause the system to fail into an unsafe state.
Data received from the... | 
                                                                        
                            | V-222608 | High | The application must not be vulnerable to XML-oriented attacks. | Extensible Markup Language (XML) is widely employed in web technology and applications like web services (SOAP, REST, and WSDL) and is also used for configuration files. XML vulnerability examples include XML injection, XML Spoofing, XML-based Denial of Service attacks and information disclosure attacks.
When utilizing XML, web applications must take... | 
                                                                        
                            | V-222607 | High | The application must not be vulnerable to SQL Injection. | SQL Injection is a code injection attack against database applications. Malicious SQL statements are inserted into an application data entry field where they are submitted to the database and executed. This is a direct result of not validating input that is used by the application to perform a command or... | 
                                                                        
                            | V-222604 | High | The application must protect from command injection. | A command injection attack is an attack on a vulnerable application where improperly validated input is passed to a command shell setup in the application. The result is the ability of an attacker to execute OS commands via the application.
A command injection allows an attacker to execute their own... | 
                                                                        
                            | V-222602 | High | The application must protect from Cross-Site Scripting (XSS) vulnerabilities. |  | 
                                                                        
                            | V-222601 | High | The application must not store sensitive information in hidden fields. | Hidden fields allow developers to process application data without having to display it on the screen.  Using hidden fields to pass data in forms is a common practice among web applications and by itself is not a security risk.  
However, hidden fields are not secure and can be easily manipulated... | 
                                                                        
                            | V-222596 | High | The application must protect the confidentiality and integrity of transmitted information. | Without protection of the transmitted information, confidentiality and integrity may be compromised since unprotected communications can be intercepted and either read or altered.
This requirement applies  to those applications that transmit data, or allow access to data non-locally. Application and data owners have a responsibility for ensuring data integrity and... | 
                                                                        
                            | V-222589 | High | The application must use appropriate cryptography in order to protect stored DOD information when required by the information owner or DOD policy. | Applications handling data requiring "data at rest" protections must employ cryptographic mechanisms to prevent unauthorized disclosure and modification of the information at rest.
Selection of a cryptographic mechanism is based on the need to protect the confidentiality of organizational information. The strength of mechanism is commensurate with the security category... | 
                                                                        
                            | V-222588 | High | The application must implement approved cryptographic mechanisms to prevent unauthorized modification of organization-defined information at rest on organization-defined information system components. | Applications handling data requiring "data at rest" protections must employ cryptographic mechanisms to prevent unauthorized disclosure and modification of the information at rest.
Selection of a cryptographic mechanism is based on the need to protect the integrity of organizational information. The strength of the mechanism is commensurate with the security... | 
                                                                        
                            | V-222585 | High | The application must fail to a secure state if system initialization fails, shutdown fails, or aborts fail. | Failure to a known safe state helps prevent systems from failing to a state that may cause loss of data or unauthorized access to system resources. Applications or systems that fail suddenly and with no incorporated failure state planning may leave the hosting system available but with a reduced security... | 
                                                                        
                            | V-222578 | High | The application must destroy the session ID value and/or cookie on logoff or browser close. | Many web development frameworks such as PHP, .NET, and ASP include their own mechanisms for session management. Whenever possible it is recommended to utilize the provided session management framework.
Session cookies contain application session information that can be used to impersonate the web application user or hijack their application session.... | 
                                                                        
                            | V-222577 | High | The application must not expose session IDs. | Authenticity protection provides protection against man-in-the-middle attacks/session hijacking and the insertion of false information into sessions.
Application communication sessions are protected utilizing transport encryption protocols, such as SSL or TLS. SSL/TLS provides web applications with a means to be able to authenticate user sessions and encrypt application traffic. Session authentication... | 
                                                                        
                            | V-222555 | High | The application must use mechanisms meeting the requirements of applicable federal laws, Executive Orders, directives, policies, regulations, standards, and guidance for authentication to a cryptographic module. | A cryptographic module is a hardware or software device or component that performs cryptographic operations securely within a physical or logical boundary, using a hardware, software or hybrid cryptographic engine contained within the boundary, and cryptographic keys that do not leave the boundary.
Based on the criticality of the application,... | 
                                                                        
                            | V-222554 | High | The application must not display passwords/PINs as clear text. | To prevent the compromise of authentication information such as passwords during the authentication process, the feedback from the information system must not provide any information that would allow an unauthorized user to compromise the authentication mechanism.
Obfuscation of user-provided information when typed into the system is a method used in... | 
                                                                        
                            | V-222551 | High | The application, when using PKI-based authentication, must enforce authorized access to the corresponding private key. | If the private key is discovered, an attacker can use the key to authenticate as an authorized user and gain access to the network infrastructure.
The cornerstone of the PKI is the private key used to encrypt or digitally sign information.
If the private key is stolen, this will lead... | 
                                                                        
                            | V-222550 | High | The application, when utilizing PKI-based authentication, must validate certificates by constructing a certification path (which includes status information) to an accepted trust anchor. | Without path validation, an informed trust decision by the relying party cannot be made when presented with any certificate not already explicitly trusted.
A trust anchor is an authoritative entity represented via a public key and associated data. It is used in the context of public key infrastructures, X.509 digital... | 
                                                                        
                            | V-222543 | High | The application must transmit only cryptographically-protected passwords. | Use of passwords for application authentication is intended only for limited situations and should not be used as a replacement for two-factor CAC-enabled authentication.
Examples of situations where a user ID and password might be used include but are not limited to:
- When the application user base does not... | 
                                                                        
                            | V-222542 | High | The application must only store cryptographic representations of passwords. | Use of passwords for application authentication is intended only for limited situations and should not be used as a replacement for two-factor CAC-enabled authentication.
Examples of situations where a user ID and password might be used include but are not limited to:
- When the application user base does not... | 
                                                                        
                            | V-222536 | High | The application must enforce a minimum 15-character password length. | The shorter the password, the lower the number of possible combinations that need to be tested before the password is compromised.
Use of passwords for application authentication is intended only for limited situations and should not be used as a replacement for two-factor CAC-enabled authentication.
Examples of situations where a... | 
                                                                        
                            | V-222522 | High | The application must uniquely identify and authenticate organizational users (or processes acting on behalf of organizational users). | To assure accountability and prevent unauthenticated access, organizational users must be identified and authenticated to prevent potential misuse and compromise of the system.
Organizational users include organizational employees or individuals the organization deems to have equivalent status of employees (e.g., contractors). 
Organizational users (and any processes acting on behalf of... | 
                                                                        
                            | V-222432 | High | The application must enforce the limit of three consecutive invalid logon attempts by a user during a 15 minute time period. | By limiting the number of failed logon attempts, the risk of unauthorized system access via user password guessing, otherwise known as brute forcing, is reduced.
Limits are imposed by locking the account.
User notification when three failed logon attempts are exceeded is an operational consideration determined by the application owner.... | 
                                                                        
                            | V-222430 | High | The application must execute without excessive account permissions. | Applications are often designed to utilize a user account.  The account represents a means to control application permissions and access to OS resources, application resources or both.  
When the application is designed and installed, care must be taken not to assign excessive permissions to the user account that is used... | 
                                                                        
                            | V-222425 | High | The application must enforce approved authorizations for logical access to information and system resources in accordance with applicable access control policies. | To mitigate the risk of unauthorized access to sensitive information by entities that have been issued certificates by DoD-approved PKIs, all DoD systems (e.g., networks, web servers, and web portals) must be properly configured to incorporate access control methods that do not rely solely on the possession of a certificate... | 
                                                                        
                            | V-222404 | High | The application must use both the NotBefore and NotOnOrAfter elements or OneTimeUse element when using the Conditions element in a SAML assertion. |  | 
                                                                        
                            | V-222403 | High | The application must use the NotOnOrAfter condition when using the SubjectConfirmation element in a SAML assertion. |  | 
                                                                        
                            | V-222400 | High | Validity periods must be verified on all application messages using WS-Security or SAML assertions. | When using WS-Security in SOAP messages, the application should check the validity of the time stamps with creation and expiration times. Time stamps that are not validated may lead to a replay event and provide immediate unauthorized access of the application. Unauthorized access results in an immediate loss of confidentiality. | 
                                                                        
                            | V-222399 | High | Messages protected with WS_Security must use time stamps with creation and expiration times. | The lack of time stamps could lead to the eventual replay of the message, leaving the application susceptible to replay events which may result in an immediate loss of confidentiality. | 
                                                                        
                            | V-265634 | Medium | The application must implement NSA-approved cryptography to protect classified information in accordance with applicable federal laws, Executive Orders, directives, policies, regulations, and standards. | Use of weak or untested encryption algorithms undermines the purposes of utilizing encryption to protect classified data. The application must implement cryptographic modules adhering to the higher standards approved by the federal government since this provides assurance they have been tested and validated.
 
Advanced Encryption Standard (AES)
Symmetric block cipher... | 
                                                                        
                            | V-222673 | Medium | The Program Manager must verify all levels of program management, designers, developers, and testers receive annual security training pertaining to their job function. | Many application team members may not be aware of the security implications regarding the code that they design, write and test.  To address this concern, the Program Manager will ensure all levels of program management receive security training regarding the necessity, impact, and benefits of integrating secure development practices into... | 
                                                                        
                            | V-222671 | Medium | Connections between the DoD enclave and the Internet or other public or commercial wide area networks must require a DMZ. | In order to protect DoD data and systems, all remote access to DoD information systems must be mediated through a managed access control point, such as a remote access server in a DMZ. | 
                                                                        
                            | V-222668 | Medium | The system must alert an administrator when low resource conditions are encountered. | In order to prevent DoS type attacks, applications should be monitored when resource conditions reach a predefined threshold. This could indicate the onset of a DoS attack or could be the precursor to an application outage. | 
                                                                        
                            | V-222667 | Medium | Protections against DoS attacks must be implemented. | Known DoS threats documented in the threat model should be mitigated, to prevent DoS type attacks. | 
                                                                        
                            | V-222666 | Medium | Production database exports must have database administration credentials and sensitive data removed before releasing the export. | Production database exports are often used to populate development databases. Test and development environments do not typically have the same rigid security protections that production environments do. When production data is used in test and development, the production database exports will need to be scrubbed to prevent information like passwords... | 
                                                                        
                            | V-222665 | Medium | The designer must ensure uncategorized or emerging mobile code is not used in applications. | By definition, mobile code is software obtained from remote systems outside the enclave boundary, transferred across a network, and then downloaded and executed on a local system without explicit installation or execution by the recipient.  
For a complete list of mobile code categorizations, refer to the overview document included with... | 
                                                                        
                            | V-222664 | Medium | If the application contains classified data, a Security Classification Guide must exist containing data elements and their classification. | Without a classification guide the marking, storage, and output media of classified material can be inadvertently mixed with unclassified material, leading to its possible loss or compromise. | 
                                                                        
                            | V-222663 | Medium | An Application Configuration Guide must be created and included with the application. | The Application Configuration Guide is any document or collection of documents used to configure the application.  These documents may be part of a user guide, secure configuration guide, or any guidance that satisfies the requirements provided herein.  
Configuration examples include but are not limited to:
 - Encryption Settings
 - PKI... | 
                                                                        
                            | V-222661 | Medium | Unnecessary built-in application accounts must be disabled. | Default passwords and properties of built-in accounts are often publicly available. Anyone with necessary knowledge, internal or external, can compromise an application using built-in accounts.
Built-in accounts are those that are added as part of the installation of the application software. These accounts exist for many common Commercial Off-the-Shelf (COTS)... | 
                                                                        
                            | V-222657 | Medium | The application development team must provide an application incident response plan. | An application incident response process is managed by the development team and should include a method for individuals to submit potential security vulnerabilities to the development or maintenance team. 
The plan should dictate what is to be done with the reported vulnerabilities. Reported vulnerabilities must be tracked throughout the process... | 
                                                                        
                            | V-222656 | Medium | The application must not be subject to error handling vulnerabilities. | Error handling is the failure to check the return values of functions or catch top level exceptions within a program. Improper error handling in an application can lead to an application failure or possibly result in the application entering an insecure state. 
The primary way to detect error handling vulnerabilities... | 
                                                                        
                            | V-222655 | Medium | Threat models must be documented and reviewed for each application release and updated as required by design and functionality changes or when new threats are discovered. | Threat modeling is an approach for analyzing the security of an application. It is a structured approach that enables you to identify, quantify, and address the security risks associated with an application. Threat modeling is not an approach to reviewing code, but it does complement the security code review process.... | 
                                                                        
                            | V-222652 | Medium | Security flaws must be fixed or addressed in the project plan. | This requirement is meant to apply to developers or organizations that are doing application development work.
Application development efforts include the creation of a project plan to track and organize the development work.
If security flaws are not tracked within the project plan, it is possible the flaws will be... | 
                                                                        
                            | V-222651 | Medium | The changes to the application must be assessed for IA and accreditation impact prior to implementation. | When changes are made to an application, either in the code or in the configuration of underlying components such as the OS or the web or application server, there is the potential for security vulnerabilities to be opened up on the system.
IA assessment of proposed changes is necessary to... | 
                                                                        
                            | V-222650 | Medium | Flaws found during a code review must be tracked in a defect tracking system. | This requirement is meant to apply to developers or organizations that are doing application development work.
If flaws are not tracked they may possibly be forgotten to be included in a release. Tracking flaws in the configuration management repository will help identify code elements to be changed, as well as... | 
                                                                        
                            | V-222648 | Medium | An application code review must be performed on the application. | A code review is a systematic evaluation of computer source code conducted for the purposes of identifying and remediating the security flaws in the software.
This requirement is meant to apply to developers or organizations that are doing application development work and have the responsibility for maintaining the application source... | 
                                                                        
                            | V-222646 | Medium | At least one tester must be designated to test for security flaws in addition to functional testing. | If there is no person designated to test for security flaws, vulnerabilities can potentially be missed during testing.
This requirement is meant to apply to developers or organizations that are doing development work. | 
                                                                        
                            | V-222645 | Medium | Application files must be cryptographically hashed prior to deploying to DoD operational networks. | When application code and binaries are transferred from one environment to another, there is the potential for malware to be introduced into either the application code or even the application binaries themselves. Care must be taken to ensure that application code and binaries are validated for integrity prior to deployment... | 
                                                                        
                            | V-222641 | Medium | The application must use encryption to implement key exchange and authenticate endpoints prior to establishing a communication channel for key exchange. | If the application does not use encryption and authenticate endpoints prior to establishing a communication channel and prior to transmitting encryption keys, these keys may be intercepted, and could be used to decrypt the traffic of the current session, leading to potential loss or compromise of DoD data. | 
                                                                        
                            | V-222640 | Medium | Procedures must be in place to assure the appropriate physical and technical protection of the backup and restoration of the application. | Protection of backup and restoration assets is essential for the successful restore of operations after a catastrophic failure or damage to the system or data files. Failure to follow proper procedures may result in the permanent loss of system data and/or the loss of system capability resulting in failure of... | 
                                                                        
                            | V-222639 | Medium | Back-up copies of the application software or source code must be stored in a fire-rated container or stored separately (offsite). | Application developers and application administrators must take steps to ensure continuity of development effort and operations should a disaster strike.  
Steps include protecting back-up copies of development code and application software.
Improper storage of the back-up copies can result in extended outages of the information system in the event of... | 
                                                                        
                            | V-222638 | Medium | Data backup must be performed at required intervals in accordance with DoD policy. | Without proper backups, the application is not protected from the loss of data or the operating environment in the event of hardware or software failure. | 
                                                                        
                            | V-222637 | Medium | Recovery procedures and technical system features must exist so recovery is performed in a secure and verifiable manner. The ISSO will document circumstances inhibiting a trusted recovery. | Without a disaster recovery plan, the application is susceptible to interruption in service due to damage within the processing site.
If the application is part of the site’s disaster recovery plan, ensure that the plan contains detailed instructions pertaining to the application. Verify that recovery procedures indicate the steps needed... | 
                                                                        
                            | V-222636 | Medium | A contingency plan must exist in accordance with DOD policy based on the application's availability requirements. | Contingency planning for systems is part of an overall program for achieving continuity of operations for organizational mission and business functions. Contingency planning addresses system restoration and implementation of alternative mission or business processes when systems are compromised or breached. 
All applications must document procedures to include business recovery plans,... | 
                                                                        
                            | V-222635 | Medium | The application must not be hosted on a general purpose machine if the application is designated as critical or high availability by the ISSO. | Critical applications should not be hosted on a multi-purpose server with other applications. Applications that share resources are susceptible to the other shared application security defects. Even if the critical application is designed and deployed securely, an application that is not designed and deployed securely, can cause resource issues and... | 
                                                                        
                            | V-222634 | Medium | The application services and interfaces must be compatible with and ready for IPv6 networks. | If the application has not been upgraded to execute on an IPv6-only network, there is a possibility the application will not execute properly, and as a result, a denial of service could occur.
In order to operate on an IPV6 network, the application must be capable of making IPV6 compatible... | 
                                                                        
                            | V-222633 | Medium | A Configuration Control Board (CCB) that meets at least every release cycle, for managing the Configuration Management (CM) process must be established. | Software Configuration Management (SCM) is very important in tracking code releases, baselines, and managing access to the configuration management repository. An SCM plan or charter identifies what should be under configuration management control. Without an SCM plan and a CCB, application releases can't be tracked and vulnerabilities can be inserted... | 
                                                                        
                            | V-222632 | Medium | A Software Configuration Management (SCM) plan describing the configuration control and change management process of application objects developed by the organization and the roles and responsibilities of the organization must be created and maintained. | Software Configuration Management (SCM) is very important in tracking code releases, baselines, and managing access to the configuration management repository. The SCM plan identifies what should be under configuration management control.
Without an SCM plan that addresses code security issues, code releases can be tracked and vulnerabilities can be inserted... | 
                                                                        
                            | V-222631 | Medium | Access privileges to the Configuration Management (CM) repository must be reviewed every three months. | A Configuration Management (CM) repository is used to manage application code versions and to securely store application code.
Incorrect access privileges to the CM repository can lead to malicious code or unintentional code being introduced into the application.
This requirement is intended to be applied to application developers or organizations... | 
                                                                        
                            | V-222630 | Medium | The Configuration Management (CM) repository must be properly patched and STIG compliant. | A Configuration Management (CM) repository is used to manage application code versions and to securely store application code.
Failure to properly apply security patches and secure the software Configuration Management system could affect the confidentiality and integrity of the application source-code.  
Compromise of the Configuration Management system could lead to... | 
                                                                        
                            | V-222629 | Medium | The application must be registered with the DoD Ports and Protocols Database. | Failure to register the applications usage of ports, protocols, and services with the DoD PPS Database may result in a Denial of Service (DoS) because of enclave boundary protections at other end points within the network. | 
                                                                        
                            | V-222628 | Medium | New IP addresses, data services, and associated ports used by the application must be submitted to the appropriate approving authority for the organization, which in turn will be submitted through the DoD Ports, Protocols, and Services Management (DoD PPSM) | Failure to comply with DoD Ports, Protocols, and Services (PPS) Vulnerability Analysis and associated PPS mitigations may result in compromise of enclave boundary protections and/or functionality of the application. | 
                                                                        
                            | V-222627 | Medium | The ISSO must ensure if a DoD STIG or NSA guide is not available, a third-party product will be configured by following available guidance. | Not all COTS products are covered by a STIG. Those products not covered by a STIG, should follow commercially accepted best practices, independent testing results and vendors lock down guides and recommendations if they are available. | 
                                                                        
                            | V-222626 | Medium | The designer must ensure the application does not store configuration and control files in the same directory as user data. | Application configuration settings and user data are required to be stored in separate locations in order to prevent application users from possibly being able to access application configuration settings or application data files. Without proper access controls and separation of application configuration settings from user data, there is the potential... | 
                                                                        
                            | V-222625 | Medium | Execution flow diagrams and design documents must be created to show how deadlock and recursion issues in web services are being mitigated. | In order to understand data flows within web services, the process flow of data must be developed and documented.
There are several different ways that web service deadlock occurs, many times it is due to when a client invokes a synchronous method on a web service, the client will block... | 
                                                                        
                            | V-222624 | Medium | The ISSO must ensure active vulnerability testing is performed. | Use of automated scanning tools accompanied with manual testing/validation which confirms or expands on the automated test results is an accepted best practice when performing application security testing. Automated scanning tools expedite and help to standardize security testing, they can incorporate known attack methods and procedures, test for libraries and... | 
                                                                        
                            | V-222623 | Medium | The ISSO must report all suspected violations of IA policies in accordance with DoD information system IA procedures. | Violations of IA policies must be reviewed and reported. If there are no policies regarding the reporting of IA violations, IA violations may not be tracked or addressed in a proper manner. | 
                                                                        
                            | V-222622 | Medium | The ISSO must review audit trails periodically based on system documentation recommendations or immediately upon system security events. | Without access control the data is not secure. It can be compromised, misused, or changed by unauthorized access at any time. | 
                                                                        
                            | V-222621 | Medium | The ISSO must ensure application audit trails are retained for at least 1 year for applications without SAMI data, and 5 years for applications including SAMI data. | Log files are a requirement to trace intruder activity or to audit user activity. | 
                                                                        
                            | V-222619 | Medium | The ISSO must ensure an account management process is implemented, verifying only authorized users can gain access to the application, and individual accounts designated as inactive, suspended, or terminated are promptly removed. | A comprehensive account management process will ensure that only authorized users can gain access to applications and that individual accounts designated as inactive, suspended, or terminated are promptly deactivated. Such a process greatly reduces the risk that accounts will be misused, hijacked, or data compromised. | 
                                                                        
                            | V-222618 | Medium | Unsigned Category 1A mobile code must not be used in the application in accordance with DoD policy. | Use of un-trusted Level 1A mobile code technologies can introduce security vulnerabilities and malicious code into the client system.
1A code is defined as:
- ActiveX controls
- Mobile code script (JavaScript, VBScript)
- Windows Scripting Host (WSH) (downloaded via URL or email)
When JavaScript and VBScript execute within the... | 
                                                                        
                            | V-222616 | Medium | The application must perform verification of the correct operation of security functions: upon system startup and/or restart; upon command by a user with privileged access; and/or every 30 days. | Without verification, security functions may not operate correctly and this failure may go unnoticed.
Security function is defined as the hardware, software, and/or firmware of the information system responsible for enforcing the system security policy and supporting the isolation of code and data on which the protection is based. Security... | 
                                                                        
                            | V-222615 | Medium | The application performing organization-defined security functions must verify correct operation of security functions. | Without verification, security functions may not operate correctly and this failure may go unnoticed.
Security function is defined as the hardware, software, and/or firmware of the information system responsible for enforcing the system security policy and supporting the isolation of code and data on which the protection is based. Security... | 
                                                                        
                            | V-222614 | Medium | Security-relevant software updates and patches must be kept up to date. |  | 
                                                                        
                            | V-222613 | Medium | The application must remove organization-defined software components after updated versions have been installed. | Previous versions of software components that are not removed from the information system after updates have been installed may be exploited by adversaries. Some information technology products may remove older versions of software automatically from the information system. | 
                                                                        
                            | V-222611 | Medium | The application must reveal error messages only to the ISSO, ISSM, or SA. | Only authorized personnel should be aware of errors and the details of the errors. Error messages are an indicator of an organization's operational state or can identify application components. Additionally, Personally Identifiable Information (PII) and operational information must not be revealed through error messages to unauthorized personnel or their designated... | 
                                                                        
                            | V-222610 | Medium | The application must generate error messages that provide information necessary for corrective actions without revealing information that could be exploited by adversaries. | Only authorized personnel should be aware of errors and the details of the errors. Error messages are an indicator of an organization's operational state or can identify application components. Additionally, Personally Identifiable Information (PII) and operational information must not be revealed through error messages to unauthorized personnel or their designated... | 
                                                                        
                            | V-222606 | Medium | The application must validate all input. | Checking the valid syntax and semantics of information system inputs (e.g., character set, length, numerical range, and acceptable values) verifies that inputs match specified definitions for format and content. Software applications typically follow well-defined protocols that use structured messages (i.e., commands or queries) to communicate between software modules or system... | 
                                                                        
                            | V-222605 | Medium | The application must protect from canonical representation vulnerabilities. | Canonical representation vulnerabilities can occur when a data conversion process does not convert the data to its simplest form resulting in the possible misrepresentation of the data.
The application may behave in an unexpected manner when acting on input that has not been sanitized or normalized.
Vulnerable application code is... | 
                                                                        
                            | V-222603 | Medium | The application must protect from Cross-Site Request Forgery (CSRF) vulnerabilities. | Cross-Site Request Forgery (CSRF) is an attack where a website user is forced to execute an unwanted action on a website that he or she is currently authenticated to. An attacker, through social engineering (e.g., e-mail or chat) creates a hyperlink which executes unwanted actions on the website the victim... | 
                                                                        
                            | V-222600 | Medium | The application must not disclose unnecessary information to users. | Applications should not disclose information not required for the transaction. (e.g., a web application should not divulge the fact there is a SQL server database and/or its version).
These events usually occur when the web application has not been configured to send specific error messages for error events. Instead, when... | 
                                                                        
                            | V-222599 | Medium | The application must maintain the confidentiality and integrity of information during reception. | Data is subject to manipulation and other integrity related attacks whenever that data is transferred across a network. To protect data integrity during transmission, the application must implement mechanisms to ensure the integrity of all transmitted information. All transmitted information means that the protections are not restricted to just the... | 
                                                                        
                            | V-222598 | Medium | The application must maintain the confidentiality and integrity of information during preparation for transmission. | Data is subject to manipulation and other integrity related attacks whenever that data is transferred across a network. To protect data integrity during transmission, the application must implement mechanisms to ensure the integrity of all transmitted information. All transmitted information means that the protections are not restricted to just the... | 
                                                                        
                            | V-222597 | Medium | The application must implement cryptographic mechanisms to prevent unauthorized disclosure of information and/or detect changes to information during transmission unless otherwise protected by alternative physical safeguards, such as, at a minimum, a Protected Distribution System (PDS). | Data is subject to manipulation and other integrity related attacks whenever that data is transferred across a network. To protect data integrity during transmission, the application must implement mechanisms to ensure the integrity of all transmitted information.
All transmitted information means that the protections are not restricted to just the... | 
                                                                        
                            | V-222595 | Medium | The web service design must include redundancy mechanisms when used with high-availability systems. | DoS is a condition when a resource is not available for legitimate users. When this occurs, the organization either cannot accomplish its mission or must operate at degraded capacity.
In the case of application DoS attacks, care must be taken when designing the application to ensure the application makes the... | 
                                                                        
                            | V-222594 | Medium | The application must restrict the ability to launch Denial of Service (DoS) attacks against itself or other information systems. | Denial of Service (DoS) is a condition where a resource is not available for legitimate users. When this occurs, the organization either cannot accomplish its mission or must operate at degraded capacity.
Individuals of concern can include hostile insiders or external adversaries that have access or have successfully breached the... | 
                                                                        
                            | V-222593 | Medium | XML-based applications must mitigate DoS attacks by using XML filters, parser options, or gateways. | DoS is a condition when a resource is not available for legitimate users. When this occurs, the organization either cannot accomplish its mission or must operate at degraded capacity.
XML-based applications are susceptible to DoS attacks due to the nature of XML parsing being processor intensive and complicated.
Best practice... | 
                                                                        
                            | V-222592 | Medium | Applications must prevent unauthorized and unintended information transfer via shared system resources. | Preventing unauthorized information transfers mitigates the risk of information, including encrypted representations of information, produced by the actions of prior users/roles (or the actions of processes acting on behalf of prior users/roles) from being available to any current users/roles (or current processes) that obtain access to shared system resources (e.g.,... | 
                                                                        
                            | V-222591 | Medium | The application must maintain a separate execution domain for each executing process. | Applications can maintain separate execution domains for each executing process by assigning each process a separate address space. Each process has a distinct address space so that communication between processes is performed in a manner controlled through the security functions, and one process cannot modify the executing code of another... | 
                                                                        
                            | V-222590 | Medium | The application must isolate security functions from non-security functions. | An isolation boundary provides access control and protects the integrity of the hardware, software, and firmware that perform security functions.
Security functions are the hardware, software, and/or firmware of the information system responsible for enforcing the system security policy and supporting the isolation of code and data on which the... | 
                                                                        
                            | V-222587 | Medium | The application must protect the confidentiality and integrity of stored information when required by DoD policy or the information owner. | Information at rest refers to the state of information when it is located on a secondary storage device (e.g., disk drive and tape drive) within an organizational information system. Mobile devices, laptops, desktops, and storage devices can be either lost or stolen, and the contents of their data storage (e.g.,... | 
                                                                        
                            | V-222586 | Medium | In the event of a system failure, applications must preserve any information necessary to determine cause of failure and any information necessary to return to operations with least disruption to mission processes. | Failure to a known state can address safety or security in accordance with the mission/business needs of the organization. Failure to a known secure state helps prevent a loss of confidentiality, integrity, or availability in the event of a failure of the information system or a component of the system.... | 
                                                                        
                            | V-222584 | Medium | The application must only allow the use of DoD-approved certificate authorities for verification of the establishment of protected sessions. | Untrusted Certificate Authorities (CA) can issue certificates, but they may be issued by organizations or individuals that seek to compromise DoD systems or by organizations with insufficient security controls. If the CA used for verifying the certificate is not a DoD-approved CA, trust of this CA has not been established.... | 
                                                                        
                            | V-222583 | Medium | The application must generate a unique session identifier using a FIPS 140-2/140-3 approved random number generator. | The application server will use session IDs to communicate between modules or applications within the application server and between the application server and users. The session ID allows the application to track the communications along with credentials that may have been used to authenticate users or modules.
Unique session IDs... | 
                                                                        
                            | V-222582 | Medium | The application must not re-use or recycle session IDs. | Many web development frameworks such as PHP, .NET, and ASP include their own mechanisms for session management. Whenever possible it is recommended to utilize the provided session management framework.
Session identifiers are assigned to application users so they can be uniquely identified. This allows the user to customize their web... | 
                                                                        
                            | V-222581 | Medium | Applications must not use URL embedded session IDs. | Many web development frameworks such as PHP, .NET, and ASP include their own mechanisms for session management. Whenever possible it is recommended to utilize the provided session management framework.
Using a session ID that is copied to the URL introduces the risks that the session ID information will be written... | 
                                                                        
                            | V-222580 | Medium | Applications must validate session identifiers. | Many web development frameworks such as PHP, .NET, and ASP include their own mechanisms for session management. Whenever possible it is recommended to utilize the provided session management framework. | 
                                                                        
                            | V-222579 | Medium | Applications must use system-generated session identifiers that protect against session fixation. | Session fixation allows an attacker to hijack a valid user’s application session. The attack focuses on the manner in which a web application manages the user’s session ID. Applications become vulnerable when they do not assign a new session ID when authenticating users thereby using the existing session ID.
Many... | 
                                                                        
                            | V-222576 | Medium | The application must set the secure flag on session cookies. | Many web development frameworks such as PHP, .NET, ASP as well as application servers include their own mechanisms for session management. Whenever possible it is recommended to utilize the provided session management framework.
Setting the secure bit on session cookie ensures the session cookie is only sent via TLS/SSL HTTPS... | 
                                                                        
                            | V-222575 | Medium | The application must set the HTTPOnly flag on session cookies. | HTTPOnly is a flag included in a Set-Cookie HTTP response header. If the HTTPOnly flag is included in the HTTP response header, the cookie cannot be accessed through client side scripts like JavaScript.
If the HTTPOnly flag is set, even if a cross-site scripting (XSS) flaw in the application exists,... | 
                                                                        
                            | V-222574 | Medium | The application user interface must be either physically or logically separated from data storage and management interfaces. | Application management functionality includes functions necessary for administration and requires privileged user access. Allowing non-privileged users to access application management functionality capabilities increases the risk that non-privileged users may obtain elevated privileges.
The separation of user functionality from information system management functionality is either physical or logical and is accomplished... | 
                                                                        
                            | V-222573 | Medium | Applications making SAML assertions must use FIPS-approved random numbers in the generation of SessionIndex in the SAML element AuthnStatement. | A predictable SessionIndex could lead to an attacker computing a future SessionIndex, thereby, possibly compromising the application.
Use of weak or untested encryption algorithms undermines the purposes of utilizing encryption to protect data. The application must implement cryptographic modules adhering to the higher standards approved by the federal government since... | 
                                                                        
                            | V-222572 | Medium | The application must utilize FIPS-validated cryptographic modules when protecting unclassified information that requires cryptographic protection. | Use of weak or untested encryption algorithms undermines the purposes of utilizing encryption to protect data. The application must implement cryptographic modules adhering to the higher standards approved by the federal government since this provides assurance they have been tested and validated. | 
                                                                        
                            | V-222571 | Medium | The application must utilize FIPS-validated cryptographic modules when generating cryptographic hashes. | Use of weak or untested encryption algorithms undermines the purposes of utilizing encryption to protect data. The application must implement cryptographic modules adhering to the higher standards approved by the federal government since this provides assurance they have been tested and validated.
If the application resides on a National Security... | 
                                                                        
                            | V-222570 | Medium | The application must utilize FIPS-validated cryptographic modules when signing application components. | Applications that distribute components of the application must sign the components to provide an identity assurance to consumers of the application component. Components can include application messages or application code.
Use of weak or untested encryption algorithms undermines the purposes of utilizing encryption to validate the author of application components.... | 
                                                                        
                            | V-222568 | Medium | The application must terminate all network connections associated with a communications session at the end of the session. | Networked applications routinely open connections to and from other systems as part of their design and function.  When connections are opened by the application, system resources are consumed.  Terminating the network connection at the end of the application session frees up these resources for later use and aids in maintaining... | 
                                                                        
                            | V-222567 | Medium | The application must not be vulnerable to race conditions. | A race condition is a timing event within an application that can become a security vulnerability.  A race condition can occur when a pair of programming calls operating simultaneously do not work in a sequential or coordinated manner.  A race condition is a timing event within software that can become... | 
                                                                        
                            | V-222566 | Medium | The application must terminate all sessions and network connections when nonlocal maintenance is completed. | If a maintenance session or connection remains open after maintenance is completed, it may be hijacked by an attacker and used to compromise or damage the system.
Nonlocal maintenance and diagnostic activities are those activities conducted by individuals communicating through a network, either an external network (e.g., the Internet) or... | 
                                                                        
                            | V-222565 | Medium | The application must employ strong authenticators in the establishment of non-local maintenance and diagnostic sessions. | If maintenance tools are used by unauthorized personnel, they may accidentally or intentionally damage or compromise the system. The act of managing systems and applications includes the ability to access sensitive application information, such as, system configuration details, diagnostic information, user information, and potentially sensitive application data.
Non-local maintenance and... | 
                                                                        
                            | V-222564 | Medium | Applications used for non-local maintenance sessions must verify remote disconnection at the termination of non-local maintenance and diagnostic sessions. | Non-local maintenance and diagnostic activities are those activities conducted by individuals communicating through a network, either an external network (e.g., the Internet) or an internal network. Local maintenance and diagnostic activities are those activities carried out by individuals physically present at the information system or information system component and not... | 
                                                                        
                            | V-222563 | Medium | Applications used for non-local maintenance sessions must implement cryptographic mechanisms to protect the confidentiality of non-local maintenance and diagnostic communications. | Privileged access contains control and configuration information which is particularly sensitive, so additional protections are necessary. This is maintained by using cryptographic mechanisms to protect confidentiality.
Non-local maintenance and diagnostic activities are those activities conducted by individuals communicating through a network, either an external network (e.g., the Internet) or an... | 
                                                                        
                            | V-222562 | Medium | Applications used for non-local maintenance sessions must implement cryptographic mechanisms to protect the integrity of non-local maintenance and diagnostic communications. | Privileged access contains control and configuration information which is particularly sensitive, so additional protections are necessary. This is maintained by using cryptographic mechanisms to protect integrity.
Non-local maintenance and diagnostic activities are those activities conducted by individuals communicating through a network, either an external network (e.g., the Internet) or an... | 
                                                                        
                            | V-222561 | Medium | Applications used for non-local maintenance sessions must audit non-local maintenance and diagnostic sessions for organization-defined auditable events. | Non-local maintenance and diagnostic activities are those activities conducted by individuals communicating through a network, either an external network (e.g., the Internet) or an internal network. Local maintenance and diagnostic activities are those activities carried out by individuals physically present at the information system or information system component and not... | 
                                                                        
                            | V-222560 | Medium | The application must conform to Federal Identity, Credential, and Access Management (FICAM)-issued profiles. | FICAM establishes a federated identity framework for the federal government. FICAM provides governmentwide services for common Identity, Credential, and Access Management (ICAM) requirements. The FICAM Trust Framework Solutions (TFS) is the federated identity framework for the U.S. federal government.
The TFS is a process by which Industry Trust Frameworks (the... | 
                                                                        
                            | V-222559 | Medium | The application must accept Federal Identity, Credential, and Access Management (FICAM)-approved third-party credentials. | FICAM establishes a federated identity framework for the federal government. FICAM provides government-wide services for common Identity, Credential and Access Management (ICAM) requirements. The FICAM Trust Framework Solutions (TFS) is the federated identity framework for the U.S. federal government.
 The TFS is a process by which Industry Trust Frameworks (The... | 
                                                                        
                            | V-222558 | Medium | The application must electronically verify Personal Identity Verification (PIV) credentials from other federal agencies. | Inappropriate access may be granted to unauthorized users if federal agency PIV credentials are not electronically verified.
Personal Identity Verification (PIV) credentials are those credentials issued by federal agencies that conform to FIPS Publication 201 and supporting guidance documents. OMB Memorandum 11-11 requires federal agencies to continue implementing the requirements... | 
                                                                        
                            | V-222557 | Medium | The application must accept Personal Identity Verification (PIV) credentials from other federal agencies. | Access may be denied to authorized users if federal agency PIV credentials are not accepted.
Personal Identity Verification (PIV) credentials are those credentials issued by federal agencies that conform to FIPS Publication 201 and supporting guidance documents. OMB Memorandum 11-11 requires federal agencies to continue implementing the requirements specified in... | 
                                                                        
                            | V-222556 | Medium | The application must uniquely identify and authenticate non-organizational users (or processes acting on behalf of non-organizational users). | Lack of authentication and identification enables non-organizational users to gain access to the application or possibly other information systems and provides an opportunity for intruders to compromise resources within the application or information system.
Non-organizational users include all information system users other than organizational users which include organizational employees or... | 
                                                                        
                            | V-222553 | Medium | The application, for PKI-based authentication, must implement a local cache of revocation data to support path discovery and validation in case of the inability to access revocation information via the network. | A local cache of revocation data is also known as a CRL list. This list contains a list of revoked certificates and can be periodically downloaded to ensure certificates can still be checked for revocation when network access is not available or access to the Online Certificate Status Protocol (OCSP)... | 
                                                                        
                            | V-222552 | Medium | The application must map the authenticated identity to the individual user or group account for PKI-based authentication. | Without mapping the certificate used to authenticate to a corresponding user account, the ability to determine the identity of the individual user or group will not be available for forensic analysis.
Some CAs will include identifying information like an email address within the certificate itself. When the email is assigned... | 
                                                                        
                            | V-222549 | Medium | The application must terminate existing user sessions upon account deletion. | The application must ensure that a user does not retain any rights that may have been granted or retain access to the application after the user's authorization or role within the application has been deleted or modified.  This means once a user's role/account within the application has been modified, deleted... | 
                                                                        
                            | V-222548 | Medium | The application password must not be changeable by users other than the administrator or the user with which the password is associated. | If the application allows user A to change user B's password,  user B can be locked out of the application, and user A is provided the ability to grant themselves access to the application as user B.  This violates application integrity and availability principles.
Many applications provide a password reset... | 
                                                                        
                            | V-222547 | Medium | The application must allow the use of a temporary password for system logons with an immediate change to a permanent password. | Use of passwords for application authentication is intended only for limited situations and should not be used as a replacement for two-factor CAC-enabled authentication.
Examples of situations where a user ID and password might be used include but are not limited to:
- When the application user base does not... | 
                                                                        
                            | V-222546 | Medium | The application must prohibit password reuse for a minimum of five generations. | Use of passwords for application authentication is intended only for limited situations and should not be used as a replacement for two-factor CAC-enabled authentication.
Examples of situations where a user ID and password might be used include but are not limited to:
- When the application user base does not... | 
                                                                        
                            | V-222545 | Medium | The application must enforce a 60-day maximum password lifetime restriction. | Use of passwords for application authentication is intended only for limited situations and should not be used as a replacement for two-factor CAC-enabled authentication.
Examples of situations where a user ID and password might be used include but are not limited to:
- When the application user base does not... | 
                                                                        
                            | V-222544 | Medium | The application must enforce 24 hours/1 day as the minimum password lifetime. | Use of passwords for application authentication is intended only for limited situations and should not be used as a replacement for two-factor CAC-enabled authentication.
Examples of situations where a user ID and password might be used include but are not limited to:
- When the application user base does not... | 
                                                                        
                            | V-222541 | Medium | The application must require the change of at least eight of the total number of characters when passwords are changed. | Use of passwords for application authentication is intended only for limited situations and should not be used as a replacement for two-factor CAC-enabled authentication.
Examples of situations where a user ID and password might be used include but are not limited to:
- When the application user base does not... | 
                                                                        
                            | V-222540 | Medium | The application must enforce password complexity by requiring that at least one special character be used. | Use of passwords for application authentication is intended only for limited situations and should not be used as a replacement for two-factor CAC-enabled authentication.
Examples of situations where a user ID and password might be used include but are not limited to:
- When the application user base does not... | 
                                                                        
                            | V-222539 | Medium | The application must enforce password complexity by requiring that at least one numeric character be used. | Use of passwords for application authentication is intended only for limited situations and should not be used as a replacement for two-factor CAC-enabled authentication.
Examples of situations where a user ID and password might be used include but are not limited to:
- When the application user base does not... | 
                                                                        
                            | V-222538 | Medium | The application must enforce password complexity by requiring that at least one lowercase character be used. | Use of passwords for application authentication is intended only for limited situations and should not be used as a replacement for two-factor CAC-enabled authentication.
Examples of situations where a user ID and password might be used include but are not limited to:
- When the application user base does not... | 
                                                                        
                            | V-222537 | Medium | The application must enforce password complexity by requiring that at least one uppercase character be used. | Use of passwords for application authentication is intended only for limited situations and should not be used as a replacement for two-factor CAC-enabled authentication.
Examples of situations where a user ID and password might be used include but are not limited to:
- When the application user base does not... | 
                                                                        
                            | V-222535 | Medium | The application must disable device identifiers after 35 days of inactivity unless a cryptographic certificate is used for authentication. | Device identifiers are used to identify hardware devices that interact with the application much like a user account is used to identify an application user. Examples of hardware devices include but are not limited to mobile phones, application gateways, or other types of smart hardware.
This requirement does not apply... | 
                                                                        
                            | V-222534 | Medium | Service-Oriented Applications handling non-releasable data must authenticate endpoint devices via mutual SSL/TLS. | Without identifying devices, unidentified or unknown devices may be introduced, thereby facilitating malicious activity.
One way SSL/TLS authentication is the typical form of  authentication done between a web browser client and a web server. The client requests the server certificate to validate the server's identity and establish a secure connection.... | 
                                                                        
                            | V-222533 | Medium | The application must authenticate all network connected endpoint devices before establishing any connection. | Without authenticating devices, unidentified or unknown devices may be introduced, thereby facilitating malicious activity.
For distributed architectures (e.g., service-oriented architectures), the decisions regarding the validation of authentication claims may be made by services separate from the services acting on those decisions.
In such situations, it is necessary to provide authentication... | 
                                                                        
                            | V-222532 | Medium | The application must utilize mutual authentication when endpoint device non-repudiation protections are required by DoD policy or by the data owner. | Without identifying devices, unidentified or unknown devices may be introduced, thereby facilitating malicious activity.
With one way SSL authentication which is the typical form of SSL authentication done between a web browser client and a web server, the client requests the server certificate to validate the server's identity and establish... | 
                                                                        
                            | V-222531 | Medium | The application must implement replay-resistant authentication mechanisms for network access to nonprivileged accounts. | A replay attack is a man-in-the-middle style attack which allows an attacker to repeat or alter a valid data transmission that may enable unauthorized access to the application. Authentication sessions between the authenticating client and the application server validating the user credentials must not be vulnerable to a replay attack.... | 
                                                                        
                            | V-222530 | Medium | The application must implement replay-resistant authentication mechanisms for network access to privileged accounts. | A replay attack may enable an unauthorized user to gain access to the application. Authentication sessions between the authenticator and the application validating the user credentials must not be vulnerable to a replay attack.
An authentication process resists replay attacks if it is impractical to achieve a successful authentication by... | 
                                                                        
                            | V-222529 | Medium | The application must ensure users are authenticated with an individual authenticator prior to using a group authenticator. | To ensure individual accountability and prevent unauthorized access, application users must be individually identified and authenticated. Individual accountability mandates that each user is uniquely identified.
A group authenticator is a shared account or some other form of authentication that allows multiple unique individuals to access the application using a single... | 
                                                                        
                            | V-222528 | Medium | The application must use multifactor (e.g., CAC, Alt. Token) authentication for local access to nonprivileged accounts. | To assure accountability, prevent unauthenticated access, and prevent misuse of the system, privileged users must utilize multifactor authentication (MFA) for local access.
MFA is defined as using two or more factors to achieve authentication.
Factors include:
(i) Something a user knows (e.g., password/PIN);
(ii) Something a user has (e.g., cryptographic... | 
                                                                        
                            | V-222527 | Medium | The application must use multifactor (Alt. Token) authentication for local access to privileged accounts. | Multifactor authentication (MFA) requires using two or more factors to achieve authentication and access.
Factors include:
(i) something a user knows (e.g., password/PIN);
(ii) something a user has (e.g., cryptographic identification device, token); or
(iii) something a user is (e.g., biometric).
MFA decreases the attack surface by virtue of the... | 
                                                                        
                            | V-222526 | Medium | The application must use multifactor (e.g., CAC, Alt. Token) authentication for network access to non-privileged accounts. | To assure accountability and prevent unauthenticated access, non-privileged users must utilize multifactor authentication to prevent potential misuse and compromise of the system.
Multifactor authentication uses two or more factors to achieve authentication.
Factors include:
(i) Something you know (e.g., password/PIN);
(ii) Something you have (e.g., cryptographic identification device, CAC/SIPRNet token);... | 
                                                                        
                            | V-222525 | Medium | The application must electronically verify Personal Identity Verification (PIV) credentials. | The use of PIV credentials facilitates standardization and reduces the risk of unauthorized access.
DoD has mandated the use of the CAC to support identity management and personal authentication for systems covered under HSPD 12, as well as a primary component of layered protection for national security systems.
If the... | 
                                                                        
                            | V-222524 | Medium | The application must accept Personal Identity Verification (PIV) credentials. | The use of PIV credentials facilitates standardization and reduces the risk of unauthorized access.
DoD has mandated the use of the CAC to support identity management and personal authentication for systems covered under HSPD 12, as well as a primary component of layered protection for national security systems. | 
                                                                        
                            | V-222523 | Medium | The application must use multifactor (Alt. Token) authentication for network access to privileged accounts. | Multifactor authentication requires using two or more factors to achieve authentication and access.
Factors include:
(i) something a user knows (e.g., password/PIN);
(ii) something a user has (e.g., cryptographic identification device, token); or
(iii) something a user is (e.g., biometric).
Multifactor authentication decreases the attack surface by virtue of the... | 
                                                                        
                            | V-222521 | Medium | The application must require devices to reauthenticate when organization-defined circumstances or situations requiring reauthentication. | Without reauthenticating devices, unidentified or unknown devices may be introduced; thereby facilitating malicious activity.
In addition to the reauthentication requirements associated with session locks, organizations may require reauthentication of devices, including (but not limited to), the following other situations:
(i) When authenticators change;
(ii) When roles change;
(iii) When security... | 
                                                                        
                            | V-222520 | Medium | The application must require users to reauthenticate when organization-defined circumstances or situations require reauthentication. | Without reauthentication, users may access resources or perform tasks for which they do not have authorization.
When applications provide the capability to change security roles or escalate the functional capability of the application, it is critical the user reauthenticate.
In addition to the reauthentication requirements associated with session locks, organizations... | 
                                                                        
                            | V-222519 | Medium | The application must be configured to use only functions, ports, and protocols permitted to it in the PPSM CAL. | In order to prevent unauthorized connection of devices, unauthorized transfer of information, or unauthorized tunneling (i.e., embedding of data types within data types), organizations must disable or restrict unused or unnecessary physical and logical ports/protocols on information systems.
Applications are capable of providing a wide variety of functions and services.... | 
                                                                        
                            | V-222518 | Medium | The application must be configured to disable non-essential capabilities. | It is detrimental for applications to provide, or install by default, functionality exceeding requirements or mission objectives. These unnecessary capabilities or services are often overlooked and therefore may remain unsecured. They increase the risk to the platform by providing additional attack vectors.
Applications are capable of providing a wide variety... | 
                                                                        
                            | V-222517 | Medium | The application must employ a deny-all, permit-by-exception (whitelist) policy to allow the execution of authorized software programs. | Utilizing a whitelist provides a configuration management method for allowing the execution of only authorized software. Using only authorized software decreases risk by limiting the number of potential vulnerabilities.
The organization must identify authorized software programs and permit execution of authorized software. The process used to identify software programs that... | 
                                                                        
                            | V-222516 | Medium | The application must prevent program execution in accordance with organization-defined policies regarding software program usage and restrictions, and/or rules authorizing the terms and conditions of software program usage. | Control of application execution is a mechanism used to prevent execution of unauthorized applications in order to follow the rules of least privilege. Some applications may provide a capability that runs counter to the mission or provides users with functionality that exceeds mission requirements.
Some of the functions and services,... | 
                                                                        
                            | V-222515 | Medium | An application vulnerability assessment must be conducted. | An application vulnerability assessment is a test conducted in order to identify weaknesses and security vulnerabilities that may exist within an application.  The testing must cover all aspects and components of the application architecture.  If an application consists of a web server and a database, then both components must be... | 
                                                                        
                            | V-222514 | Medium | The applications must limit privileges to change the software resident within software libraries. | If the application were to allow any user to make changes to software libraries, then those changes might be implemented without undergoing the appropriate testing and approvals that are part of a robust change management process.
This requirement applies to applications with software libraries that are accessible and configurable, as... | 
                                                                        
                            | V-222513 | Medium | The application must have the capability to prevent the installation of patches, service packs, or application components without verification the software component has been digitally signed using a certificate that is recognized and approved by the organization. | Changes to any software components can have significant effects on the overall security of the application. Verifying software components have been digitally signed using a certificate that is recognized and approved by the organization ensures the software has not been tampered with and that it has been provided by a... | 
                                                                        
                            | V-222512 | Medium | The application must audit who makes configuration changes to the application. | Without auditing the enforcement of access restrictions against changes to the application configuration, it will be difficult to identify attempted attacks and an audit trail will not be available for forensic investigation for after-the-fact actions.
Enforcement actions are the methods or mechanisms used to prevent unauthorized changes to configuration settings.... | 
                                                                        
                            | V-222511 | Medium | The application must enforce access restrictions associated with changes to application configuration. | Failure to provide logical access restrictions associated with changes to application configuration may have significant effects on the overall security of the system.
When dealing with access restrictions pertaining to change control, it should be noted that any changes to the hardware, software, and/or firmware components of the information system... | 
                                                                        
                            | V-222510 | Medium | The application must prohibit user installation of software without explicit privileged status. | Allowing regular users to install software without explicit privileges creates the risk that untested or potentially malicious software will be installed on the system. Explicit privileges (escalated or administrative privileges) provide the regular user with explicit capabilities and control that exceeds the rights of a regular user.
Application functionality will... | 
                                                                        
                            | V-222509 | Medium | The integrity of the audit tools must be validated by checking the files for changes in the cryptographic hash value. | Protecting the integrity of the tools used for auditing purposes is a critical step to ensuring the integrity of audit data. Audit data includes all information (e.g., audit records, audit settings, and audit reports) needed to successfully audit information system activity.
Audit tools include, but are not limited to, vendor... | 
                                                                        
                            | V-222508 | Medium | Application audit tools must be cryptographically hashed. | Protecting the integrity of the tools used for auditing purposes is a critical step to ensuring the integrity of audit data. Audit data includes all information (e.g., audit records, audit settings, and audit reports) needed to successfully audit information system activity.
Audit tools include, but are not limited to, vendor... | 
                                                                        
                            | V-222507 | Medium | The application must use cryptographic mechanisms to protect the integrity of audit information. | Audit records may be tampered with; if the integrity of audit data were to become compromised, then forensic analysis and discovery of the true source of potentially malicious system activity is impossible to achieve.
Protection of audit records and audit data is of critical importance. Cryptographic mechanisms are the industry... | 
                                                                        
                            | V-222506 | Medium | The application must back up audit records at least every seven days onto a different system or system component than the system or component being audited. | Protection of log data includes assuring log data is not accidentally lost or deleted. Backing up audit records to a different system or onto separate media than the system being audited on an organizationally defined frequency helps to assure in the event of a catastrophic system failure, the audit records... | 
                                                                        
                            | V-222505 | Medium | The application must protect audit tools from unauthorized deletion. | Protecting audit data also includes identifying and protecting the tools used to view and manipulate log data. Therefore, protecting audit tools is necessary to prevent unauthorized operation on audit data.
Applications providing tools to interface with audit data will leverage user permissions and roles identifying the user accessing the tools... | 
                                                                        
                            | V-222504 | Medium | The application must protect audit tools from unauthorized modification. | Protecting audit data also includes identifying and protecting the tools used to view and manipulate log data. Therefore, protecting audit tools is necessary to prevent unauthorized operation on audit data.
Applications providing tools to interface with audit data will leverage user permissions and roles identifying the user accessing the tools... | 
                                                                        
                            | V-222503 | Medium | The application must protect audit tools from unauthorized access. | Protecting audit data also includes identifying and protecting the tools used to view and manipulate log data. Therefore, protecting audit tools is necessary to prevent unauthorized operation on audit data.
Applications providing tools to interface with audit data will leverage user permissions and roles identifying the user accessing the tools... | 
                                                                        
                            | V-222502 | Medium | The application must protect audit information from unauthorized deletion. | If audit data were to become compromised, then forensic analysis and discovery of the true source of potentially malicious system activity is impossible to achieve.
To ensure the veracity of audit data, the information system and/or the application must protect audit information from unauthorized deletion. This requirement can be achieved... | 
                                                                        
                            | V-222501 | Medium | The application must protect audit information from unauthorized modification. | If audit data were to become compromised, then forensic analysis and discovery of the true source of potentially malicious system activity is impossible to achieve.
To ensure the veracity of audit data, the information system and/or the application must protect audit information from unauthorized modification.
This requirement can be achieved... | 
                                                                        
                            | V-222500 | Medium | The application must protect audit information from any type of unauthorized read access. | If audit data were to become compromised, then competent forensic analysis and discovery of the true source of potentially malicious system activity is difficult if not impossible to achieve. In addition, access to audit records provides information an attacker could potentially use to his or her advantage.
To ensure the... | 
                                                                        
                            | V-222499 | Medium | The application must record time stamps for audit records that meet a granularity of one second for a minimum degree of precision. | Without sufficient granularity of time stamps, it is not possible to adequately determine the chronological order of records.
Time stamps generated by the application include date and time. Granularity of time measurements refers to the degree of synchronization between information system clocks and reference clocks. | 
                                                                        
                            | V-222498 | Medium | The application must record time stamps for audit records that can be mapped to Coordinated Universal Time (UTC) or Greenwich Mean Time (GMT). | If time stamps are not consistently applied and there is no common time reference, it is difficult to perform forensic analysis.
Time stamps generated by the application include date and time. Time is commonly expressed in Coordinated Universal Time (UTC), a modern continuation of Greenwich Mean Time (GMT), or local... | 
                                                                        
                            | V-222497 | Medium | The applications must use internal system clocks to generate time stamps for audit records. | Without an internal clock used as the reference for the time stored on each event to provide a trusted common reference for the time, forensic analysis would be impeded. Determining the correct time a particular event occurred on a system is critical when conducting forensic analysis and investigating system events.... | 
                                                                        
                            | V-222496 | Medium | The application must provide a report generation capability that does not alter original content or time ordering of audit records. | If the audit report generation capability alters the original content or time ordering of audit records, the integrity of the audit records is compromised, and the records are no longer usable for forensic analysis. Time ordering refers to the chronological organization of records based on time stamps. The degree of... | 
                                                                        
                            | V-222495 | Medium | The application must provide an audit reduction capability that does not alter original content or time ordering of audit records. | If the audit reduction capability alters the content or time ordering of audit records, the integrity of the audit records is compromised, and the records are no longer usable for forensic analysis. Time ordering refers to the chronological organization of records based on time stamps. The degree of time stamp... | 
                                                                        
                            | V-222494 | Medium | The application must provide a report generation capability that supports after-the-fact investigations of security incidents. | If the report generation capability does not support after-the-fact investigations, it is difficult to establish, correlate, and investigate the events leading up to an outage or attack, or identify those responses for one. This capability is also required to comply with applicable Federal laws and DoD policies.
The report generation... | 
                                                                        
                            | V-222493 | Medium | The application must provide a report generation capability that supports on-demand reporting requirements. | The report generation capability must support on-demand reporting in order to facilitate the organization's ability to generate incident reports as needed to better handle larger-scale or more complex security incidents.
The report generation capability provided by the application must be capable of generating on-demand (i.e., customizable, ad-hoc, and as-needed) reports.... | 
                                                                        
                            | V-222492 | Medium | The application must provide a report generation capability that supports on-demand audit review and analysis. | The report generation capability must support on-demand review and analysis in order to facilitate the organization's ability to generate incident reports as needed to better handle larger-scale or more complex security incidents.
Report generation must be capable of generating on-demand (i.e., customizable, ad-hoc, and as-needed) reports. On-demand reporting allows personnel... | 
                                                                        
                            | V-222491 | Medium | The application must provide an audit reduction capability that supports after-the-fact investigations of security incidents. | If the audit reduction capability does not support after-the-fact investigations, it is difficult to establish, correlate, and investigate the events leading up to an outage or attack, or identify those responses for one. This capability is also required to comply with applicable Federal laws and DoD policies.
Audit reduction capability... | 
                                                                        
                            | V-222490 | Medium | The application must provide an audit reduction capability that supports on-demand audit review and analysis. | The ability to perform on-demand audit review and analysis, including after the audit data has been subjected to audit reduction, greatly facilitates the organization's ability to generate incident reports as needed to better handle larger-scale or more complex security incidents.
Audit reduction is a technique used to reduce the volume... | 
                                                                        
                            | V-222489 | Medium | The application must provide an audit reduction capability that supports on-demand reporting requirements. | The ability to generate on-demand reports, including after the audit data has been subjected to audit reduction, greatly facilitates the organization's ability to generate incident reports as needed to better handle larger-scale or more complex security incidents.
Audit reduction is a process that manipulates collected audit information and organizes such... | 
                                                                        
                            | V-222488 | Medium | The application must provide the capability to filter audit records for events of interest based upon organization-defined criteria. | The ability to specify the event criteria that are of interest provides the persons reviewing the logs with the ability to quickly isolate and identify these events without having to review entries that are of little or no consequence to the investigation. Without this capability, forensic investigations are impeded.
Events... | 
                                                                        
                            | V-222487 | Medium | The application must provide the capability to centrally review and analyze audit records from multiple components within the system. | Successful incident response and auditing relies on timely, accurate system information and analysis in order to allow the organization to identify and respond to potential incidents in a proficient manner. If the application does not provide the ability to centrally review the application logs, forensic analysis is negatively impacted.
Segregation... | 
                                                                        
                            | V-222486 | Medium | The application must shut down by default upon audit failure (unless availability is an overriding concern). | It is critical that when the application is at risk of failing to process audit logs as required, it take action to mitigate the failure. Audit processing failures include: software/hardware errors; failures in the audit capturing mechanisms; and audit storage capacity being reached or exceeded. Responses to audit failure depend... | 
                                                                        
                            | V-222485 | Medium | The application must alert the ISSO and SA (at a minimum) in the event of an audit processing failure. | It is critical for the appropriate personnel to be aware if a system is at risk of failing to process audit logs as required. Without this notification, the security personnel may be unaware of an impending failure of the audit capability and system operation may be adversely affected. 
Audit processing... | 
                                                                        
                            | V-222484 | Medium | Applications categorized as having a moderate or high impact must provide an immediate real-time alert to the SA and ISSO (at a minimum) for all audit failure events. | Applications that are categorized as having a high or moderate impact on the organization must provide immediate alerts when encountering failures with the application audit system.  It is critical for the appropriate personnel to be aware if a system is at risk of failing to process audit logs as required.... | 
                                                                        
                            | V-222483 | Medium | The application must provide an immediate warning to the SA and ISSO (at a minimum) when allocated audit record storage volume reaches 75% of repository maximum audit record storage capacity. | If security personnel are not notified immediately upon storage volume utilization reaching 75%, they are unable to plan for storage capacity expansion.
Due to variances in application usage and audit records storage usage, the SA and the ISSO may evaluate usage patterns and determine if a higher percentage of usage... | 
                                                                        
                            | V-222482 | Medium | The application must be configured to write application logs to a centralized log repository. | Information stored in one location is vulnerable to accidental or incidental deletion or alteration.  In addition, attackers often manipulate logs to hide or obfuscate their activity.
Off-loading is a common process in information systems with limited audit storage capacity or when trying to assure log availability and integrity.
This requirement... | 
                                                                        
                            | V-222481 | Medium | The application must off-load audit records onto a different system or media than the system being audited. | Information stored in one location is vulnerable to accidental or incidental deletion or alteration.  In addition, attackers often manipulate logs to hide or obfuscate their activity.
The goal is to off-load application logs to a separate server as quickly and efficiently as possible so as to mitigate these risks.  
A... | 
                                                                        
                            | V-222480 | Medium | The application must provide centralized management and configuration of the content to be captured in audit records generated by all application components. | Without the ability to centrally manage the content captured in the audit records, identification, troubleshooting, and correlation of suspicious behavior would be difficult and could lead to a delayed or incomplete analysis of an ongoing attack.
This requirement requires that the content captured in audit records be managed from a... | 
                                                                        
                            | V-222479 | Medium | The application must implement transaction recovery logs when transaction based. | Without required logging and access control, security issues related to data changes will not be identified. This could lead to security compromises such as data misuse, unauthorized changes, or unauthorized access.
Transaction logs contain a sequential record of all changes to the database. Using a transaction log helps with maintaining... | 
                                                                        
                            | V-222478 | Medium | The application must generate audit records containing the full-text recording of privileged commands or the individual identities of group account users. | Reconstruction of harmful events or forensic analysis is not possible if audit records do not contain enough information.
Organizations consider limiting the additional audit information to only that information explicitly needed for specific audit requirements. The additional information required is dependent on the type of information (i.e., sensitivity of the... | 
                                                                        
                            | V-222477 | Medium | The application must generate audit records containing information that establishes the identity of any individual or process associated with the event. | Without information that establishes the identity of the subjects (i.e., users or processes acting on behalf of users) associated with the events, security personnel cannot determine responsibility for the potentially harmful event.
Event identifiers (if authenticated or otherwise known) include, but are not limited to, user database tables, primary key... | 
                                                                        
                            | V-222476 | Medium | The application must produce audit records that contain information to establish the outcome of the events. | Without information about the outcome of events, security personnel cannot make an accurate assessment as to whether an attack was successful or if changes were made to the security state of the system.
Event outcomes can include indicators of event success or failure and event-specific results (e.g., the security state... | 
                                                                        
                            | V-222475 | Medium | When using centralized logging; the application must include a unique identifier in order to distinguish itself from other application logs. | Without establishing the source, it is impossible to establish, correlate, and investigate the events leading up to an outage or attack.
In the case of centralized logging, or other instances where log files are consolidated, there is risk that the application's log data could be co-mingled with other log data.... | 
                                                                        
                            | V-222474 | Medium | The application must produce audit records containing enough information to establish which component, feature or function of the application triggered the audit event. | It is impossible to establish, correlate, and investigate the events relating to an incident if the details regarding the source of the event it not available.
In order to compile an accurate risk assessment, and provide forensic analysis, it is essential for security personnel to know where within the application... | 
                                                                        
                            | V-222473 | Medium | The application must produce audit records containing information to establish when (date and time) the events occurred. | Without establishing when events occurred, it is impossible to establish, correlate, and investigate the events relating to an incident.
In order to compile an accurate risk assessment, and provide forensic analysis, it is essential for security personnel to know when events occurred (date and time). | 
                                                                        
                            | V-222472 | Medium | The application must log user actions involving changes to data. | When users change/modify application data, there is risk of data compromise if the account used to access is compromised or access is granted improperly. To be able to investigate which account accessed data, the account making the data changes must be logged. Without establishing when the data change event occurred,... | 
                                                                        
                            | V-222471 | Medium | The application must log user actions involving access to data. | When users access application data, there is risk of data compromise or seepage if the account used to access is compromised or access is granted improperly. To be able to investigate which account accessed data, the account access must be logged. Without establishing when the access event occurred, it would... | 
                                                                        
                            | V-222470 | Medium | The application must log destination IP addresses. | The IP addresses of the systems that the application connects to are an important aspect of identifying application network related activity. Recording the IP addresses of the system the application connects to in the application logs provides forensic evidence and aids in investigating and correlating the sources of malicious behavior... | 
                                                                        
                            | V-222469 | Medium | The application must log application shutdown events. | Forensics is a large part of security incident response.  Applications must provide a record of their actions so application events can be investigated post-event.  
Attackers may attempt to shut off the application logging capability to cover their activity while on the system.  Recording the shutdown event and the time it... | 
                                                                        
                            | V-222468 | Medium | The application must initiate session auditing upon startup. | If the application does not begin logging upon startup, important log events could be missed. | 
                                                                        
                            | V-222467 | Medium | The application must generate audit records for all account creations, modifications, disabling, and termination events. | When application user accounts are created, modified, disabled or terminated the event must be logged.
Centralized management of user accounts allows for rapid response to user related security events and also provides ease of management.
Allowing the centralized user management solution to log these events is acceptable practice; however, if... | 
                                                                        
                            | V-222466 | Medium | The application must generate audit records for all direct access to the information system. | Without generating audit records that are specific to the security and mission needs of the organization, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
When an application provides direct access to underlying OS features and functions, that... | 
                                                                        
                            | V-222465 | Medium | The application must generate audit records when successful/unsuccessful accesses to objects occur. | Without generating audit records that are specific to the security and mission needs of the organization, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
Application objects are system or application components that comprise the application. This includes... | 
                                                                        
                            | V-222464 | Medium | The application must generate audit records showing starting and ending time for user access to the system. | Knowing when a user’s application session began and when it ended is critical information that aids in forensic analysis. | 
                                                                        
                            | V-222463 | Medium | The application must generate audit records for privileged activities or other system-level access. | Privileged activities include the tasks or actions taken by users in an administrative role (admin, backup operator, manager, etc.) which are used to manage or reconfigure application function. Examples include but are not limited to:
Modifying application logging verbosity, starting or stopping of application services, application user account management, managing... | 
                                                                        
                            | V-222462 | Medium | The application must generate audit records when successful/unsuccessful logon attempts occur. | Without generating audit records that are specific to the security and mission needs of the organization, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
Audit records can be generated from various components within the information system (e.g.,... | 
                                                                        
                            | V-222461 | Medium | The application must generate audit records when successful/unsuccessful attempts to delete categories of information (e.g., classification levels) occur. | Without generating audit records that are specific to the security and mission needs of the organization, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
Audit records can be generated from various components within the information system (e.g.,... | 
                                                                        
                            | V-222460 | Medium | The application must generate audit records when successful/unsuccessful attempts to delete application database security objects occur. | Without generating audit records that are specific to the security and mission needs of the organization, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
Audit records can be generated from various components within the information system (e.g.,... | 
                                                                        
                            | V-222459 | Medium | The application must generate audit records when successful/unsuccessful attempts to delete security levels occur. | A security level denotes a permissions or authorization capability within the application. This is most often associated with a user role. Attempts to delete a security level can be construed as an attempt to change the configuration of the application so as to delete an existing security role. Some applications... | 
                                                                        
                            | V-222458 | Medium | The application must generate audit records when successful/unsuccessful attempts to delete privileges occur. | Without generating audit records that are specific to the security and mission needs of the organization, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
Audit records can be generated from various components within the information system (e.g.,... | 
                                                                        
                            | V-222457 | Medium | The application must generate audit records when successful/unsuccessful attempts to modify categories of information (e.g., classification levels) occur. | Without generating audit records that are specific to the security and mission needs of the organization, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
Audit records can be generated from various components within the information system (e.g.,... | 
                                                                        
                            | V-222456 | Medium | The application must generate audit records when successful/unsuccessful attempts to modify security levels occur. | A security level denotes a permissions or authorization capability within the application. This is most often associated with a user role. Attempts to modify a security level can be construed as an attempt to change the configuration of the application so as to create a new security role or modify... | 
                                                                        
                            | V-222455 | Medium | The application must generate audit records when successful/unsuccessful attempts to modify security objects occur. | Without generating audit records that are specific to the security and mission needs of the organization, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
Audit records can be generated from various components within the information system (e.g.,... | 
                                                                        
                            | V-222454 | Medium | The application must generate audit records when successful/unsuccessful attempts to modify privileges occur. | Without generating audit records that are specific to the security and mission needs of the organization, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
Audit records can be generated from various components within the information system (e.g.,... | 
                                                                        
                            | V-222453 | Medium | The application must generate audit records when successful/unsuccessful attempts to access categories of information (e.g., classification levels) occur. | Without generating audit records that are specific to the security and mission needs of the organization, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
Categories of information is information that is identified as being sensitive or requiring... | 
                                                                        
                            | V-222452 | Medium | The application must generate audit records when successful/unsuccessful attempts to access security levels occur. | A security level denotes a permissions or authorization capability within the application. This is most often associated with a user role. Attempts to access a security level can occur when a user attempts an action such as escalating their privilege from within the application itself. Attempts to access a security... | 
                                                                        
                            | V-222451 | Medium | The application must generate audit records when successful/unsuccessful attempts to access security objects occur. | Security objects represent application objects that provide or require security protections or have a security role within the application. Examples include but are not limited to, files, application modules, folders, and database records. Essentially, if permissions are assigned to protect it, it can be considered a security object. Without generating... | 
                                                                        
                            | V-222450 | Medium | The application must generate audit records when successful/unsuccessful attempts to grant privileges occur. | Without generating audit records that are specific to the security and mission needs of the organization, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
Audit records can be generated from various components within the information system (e.g.,... | 
                                                                        
                            | V-222449 | Medium | The application must record the username or user ID of the user associated with the event. | When users conduct activity within an application, that user’s identity must be recorded in the audit log. Failing to record the identity of the user responsible for the activity within the application is detrimental to forensic analysis. | 
                                                                        
                            | V-222448 | Medium | The application must provide audit record generation capability for connecting system IP addresses. | Without the capability to generate audit records, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
Audit records can be generated from various components within the application (e.g., process, module). Certain specific application functionalities may be audited as... | 
                                                                        
                            | V-222447 | Medium | The application must provide audit record generation capability for HTTP headers including User-Agent, Referer, GET, and POST. | HTTP header information is a critical component of data that is used when evaluating forensic activity.
Without the capability to generate audit records, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
Audit records can be generated from... | 
                                                                        
                            | V-222446 | Medium | The application must record a time stamp indicating when the event occurred. | It is important to include the time stamps for when an event occurred. Failure to include time stamps in the event logs is detrimental to forensic analysis. | 
                                                                        
                            | V-222445 | Medium | The application must provide audit record generation capability for session timeouts. | When a user's session times out, it is important to be able to identify these events in the application logs.
Without the capability to generate audit records, it would be difficult to establish, correlate, and investigate the events relating to an incident, or identify those responsible for one.
Audit records... | 
                                                                        
                            | V-222444 | Medium | The application must not write sensitive data into the application logs. | It is important to identify and exclude certain types of data that is written into the logs. If the logs are compromised and sensitive data is included in the logs, this could assist an attacker in furthering their attack or it could completely compromise the system.
Examples of such data... | 
                                                                        
                            | V-222443 | Medium | The application must provide audit record generation capability for the renewal of session IDs. | Application design sometimes requires the renewal of session IDs in order to continue approved user access to the application.
Session renewal is done on a case by case basis under circumstances defined by the application architecture. The following are some examples of when session renewal must be done; whenever there... | 
                                                                        
                            | V-222442 | Medium | The application must provide audit record generation capability for the destruction of session IDs. | Applications should destroy session IDs at the end of a user session in order to terminate user access to the application session and to reduce the possibility of an unauthorized attacker high jacking the session and impersonating the user. It is important to log when session IDs are destroyed for... | 
                                                                        
                            | V-222441 | Medium | The application must provide audit record generation capability for the creation of session IDs. | Applications create session IDs at the onset of a user session in order to manage user access to the application and differentiate between different user sessions. It is important to log the creation of these session ID creation events for forensic purposes.
It is equally important to not log the... | 
                                                                        
                            | V-222439 | Medium | For applications providing audit record aggregation, the application must compile audit records from organization-defined information system components into a system-wide audit trail that is time-correlated with an organization-defined level of tolerance for the relationship between time stamps of individual records in the audit trail. | Without the ability to collate records based on the time when the events occurred, the ability to perform forensic analysis and investigations across multiple components is significantly degraded.
Audit trails are time-correlated if the time stamps in the individual audit records can be reliably related to the time stamps in... | 
                                                                        
                            | V-222438 | Medium | The application must protect against an individual (or process acting on behalf of an individual) falsely denying having performed organization-defined actions to be covered by non-repudiation. | Without non-repudiation, it is impossible to positively attribute an action to an individual (or process acting on behalf of an individual).
Non-repudiation services can be used to determine if information originated from a particular individual, or if an individual took specific actions (e.g., sending an email, signing a contract, approving... | 
                                                                        
                            | V-222433 | Medium | The application administrator must follow an approved process to unlock locked user accounts. | Once a user account has been locked, it must be unlocked by an administrator.
An ISSM and ISSO approved process must be created and followed to ensure the user requesting access is properly authenticated prior to access being re-established.
The process must include having the user provide information only the... | 
                                                                        
                            | V-222431 | Medium | The application must audit the execution of privileged functions. | Misuse of privileged functions, either intentionally or unintentionally by authorized users, or by unauthorized external entities that have compromised information system accounts, is a serious and ongoing concern and can have significant adverse impacts on organizations. Auditing the use of privileged functions is one way to detect such misuse, and... | 
                                                                        
                            | V-222429 | Medium | The application must prevent non-privileged users from executing privileged functions to include disabling, circumventing, or altering implemented security safeguards/countermeasures. | Preventing non-privileged users from executing privileged functions mitigates the risk that unauthorized individuals or processes may gain unnecessary access to information or privileges.
Privileged functions include, for example, establishing accounts, performing system integrity checks, or administering cryptographic key management activities. Non-privileged users are individuals that do not possess appropriate authorizations.... | 
                                                                        
                            | V-222428 | Medium | The application must enforce approved authorizations for controlling the flow of information between interconnected systems based on organization-defined information flow control policies. | A mechanism to detect and prevent unauthorized communication flow must be configured or provided as part of the system design. If information flow is not enforced based on approved authorizations, the system may become compromised. Information flow control regulates where information is allowed to travel within a system and between... | 
                                                                        
                            | V-222427 | Medium | The application must enforce approved authorizations for controlling the flow of information within the system based on organization-defined information flow control policies. | A mechanism to detect and prevent unauthorized communication flow must be configured or provided as part of the system design. If information flow is not enforced based on approved authorizations, the system may become compromised. Information flow control regulates where information is allowed to travel within a system and between... | 
                                                                        
                            | V-222426 | Medium | The application must enforce organization-defined discretionary access control policies over defined subjects and objects. | Discretionary Access Control allows users to determine who is allowed to access their data. To mitigate the risk of unauthorized access to sensitive information by entities that have been issued certificates by DoD-approved PKIs, all DoD systems (e.g., networks, web servers, and web portals) must be properly configured to incorporate... | 
                                                                        
                            | V-222424 | Medium | The application must utilize organization-defined data mining detection techniques for organization-defined data storage objects to adequately detect data mining attempts. | Failure to protect organizational information from data mining may result in a compromise of information.
Data mining occurs when the application is programmatically probed and data is automatically extracted. While there are valid uses for data mining within data sets, the organization should be mindful that adversaries may attempt to... | 
                                                                        
                            | V-222423 | Medium | Application data protection requirements must be identified and documented. | Failure to protect organizational information from data mining may result in a compromise of information. In order to assign the appropriate data protections, application data must be identified and then protection requirements assigned. Access to sensitive data and sensitive data objects should be restricted to those authorized to access the... | 
                                                                        
                            | V-222421 | Medium | The application must automatically audit account enabling actions. | When application accounts are enabled, user accessibility is affected. Accounts are utilized for identifying individual application users or for identifying the application processes themselves. In order to detect and respond to events affecting user accessibility and application processing, applications must audit account removal actions and, as required, notify the appropriate... | 
                                                                        
                            | V-222416 | Medium | The application must automatically audit account removal actions. | When application accounts are removed, user accessibility is affected. Accounts are utilized for identifying individual application users or for identifying the application processes themselves. In order to detect and respond to events affecting user accessibility and application processing, applications must audit account removal actions and, as required, notify the appropriate... | 
                                                                        
                            | V-222415 | Medium | The application must automatically audit account disabling actions. | When application accounts are disabled, user accessibility is affected. Accounts are utilized for identifying individual application users or for identifying the application processes themselves. In order to detect and respond to events affecting user accessibility and application processing, applications must audit account disabling actions and, as required, notify the appropriate... | 
                                                                        
                            | V-222414 | Medium | The application must automatically audit account modification. | One way for an attacker to establish persistent access is for the attacker to modify or copy an existing account. Auditing of account modification is one method for mitigating this risk. A comprehensive account management process will ensure an audit trail documents the modification of application user accounts. Such a... | 
                                                                        
                            | V-222413 | Medium | The application must automatically audit account creation. | Once an attacker establishes initial access to a system, the attacker often attempts to create a persistent method of re-establishing access. One way to accomplish this is for the attacker to simply create a new account. Auditing of account creation is one method for mitigating this risk. A comprehensive account... | 
                                                                        
                            | V-222412 | Medium | Unnecessary application accounts must be disabled, or deleted. | Test or demonstration accounts are sometimes created during the application installation process. This creates a security risk as these accounts often remain after the initial installation process and can be used to gain unauthorized access to the application. Applications must be designed and configured to disable or delete any unnecessary... | 
                                                                        
                            | V-222409 | Medium | The application must automatically remove or disable temporary user accounts 72 hours after account creation. | If temporary user accounts remain active when no longer needed or for an excessive period, these accounts may be used to gain unauthorized access. To mitigate this risk, automated termination of all temporary accounts must be set upon account creation.
Temporary accounts are established as part of normal account activation... | 
                                                                        
                            | V-222408 | Medium | Shared/group account credentials must be terminated when members leave the group. | If shared/group account credentials are not terminated when individuals leave the group, the user that left the group can still gain access even though they are no longer authorized. A shared/group account credential is a shared form of authentication that allows multiple individuals to access the application using a single... | 
                                                                        
                            | V-222407 | Medium | The application must provide automated mechanisms for supporting account management functions. | Enterprise environments make application account management challenging and complex. A manual process for account management functions adds the risk of a potential oversight or other error.
Manual examples include but are not limited to admin staff logging into the system or systems and manually performing step by step actions affecting... | 
                                                                        
                            | V-222406 | Medium | The application must ensure messages are encrypted when the SessionIndex is tied to privacy data. | When the SessionIndex is tied to privacy data (e.g., attributes containing privacy data) the message should be encrypted. If the message is not encrypted there is the possibility of compromise of privacy data. | 
                                                                        
                            | V-222405 | Medium | The application must ensure if a OneTimeUse element is used in an assertion, there is only one of the same used in the Conditions element portion of an assertion. |  | 
                                                                        
                            | V-222402 | Medium | The application must ensure encrypted assertions, or equivalent confidentiality protections are used when assertion data is passed through an intermediary, and confidentiality of the assertion data is required when passing through the intermediary. |  | 
                                                                        
                            | V-222401 | Medium | The application must ensure each unique asserting party provides unique assertion ID references for each SAML assertion. |  | 
                                                                        
                            | V-222398 | Medium | Applications with SOAP messages requiring integrity must include the following message elements:-Message ID-Service Request-Timestamp-SAML Assertion (optionally included in messages) and all elements of the message must be digitally signed. | Digitally signed SOAP messages provide message integrity and authenticity of the signer of the message independent of the transport layer. Service requests may be intercepted and changed in transit and the data integrity may be at risk if the SOAP message is not digitally signed.
Functional architecture aspects of the... | 
                                                                        
                            | V-222397 | Medium | The application must implement cryptographic mechanisms to protect the integrity of remote access sessions. | Without integrity protection mechanisms, unauthorized individuals may gain access to sensitive information via a remote access session.
Remote access is access to DoD nonpublic information systems by an authorized user (or an information system) communicating through an external, non-organization-controlled network. Remote access methods include, for example, dial-up, broadband, and wireless.... | 
                                                                        
                            | V-222396 | Medium | The application must implement DoD-approved encryption to protect the confidentiality of remote access sessions. | Without confidentiality protection mechanisms, unauthorized individuals may gain access to sensitive information via a remote access session.
Remote access is access to DoD nonpublic information systems by an authorized user (or an information system) communicating through an external, non-organization-controlled network. Remote access methods include, for example, dial-up, broadband, and wireless.... | 
                                                                        
                            | V-222395 | Medium | The application must associate organization-defined types of security attributes having organization-defined security attribute values with information in transmission. | Without the association of security attributes to information, there is no basis for the application to make security related access-control decisions.
Security attributes are abstractions representing the basic properties or characteristics of an entity (e.g., subjects and objects) with respect to safeguarding information.
These attributes are typically associated with internal... | 
                                                                        
                            | V-222394 | Medium | The application must associate organization-defined types of security attributes having organization-defined security attribute values with information in process. | Without the association of security attributes to information, there is no basis for the application to make security related access-control decisions.
Security attributes are abstractions representing the basic properties or characteristics of an entity (e.g., subjects and objects) with respect to safeguarding information.
These attributes are typically associated with internal... | 
                                                                        
                            | V-222393 | Medium | The application must associate organization-defined types of security attributes having organization-defined security attribute values with information in storage. | Without the association of security attributes to information, there is no basis for the application to make security related access-control decisions.
Security attributes are abstractions representing the basic properties or characteristics of an entity (e.g., subjects and objects) with respect to safeguarding information.
These attributes are typically associated with internal... | 
                                                                        
                            | V-222391 | Medium | Applications requiring user access authentication must provide a logoff capability for user initiated communication session. | If a user cannot explicitly end an application session, the session may remain open and be exploited by an attacker.  Applications providing user access must provide the ability for users to manually terminate their sessions and log off. | 
                                                                        
                            | V-222390 | Medium | The application must automatically terminate the admin user session and log off admin users after a 10 minute idle time period is exceeded. | Leaving an admin user's application session established for an indefinite period of time increases the risk of session hijacking.
Session termination terminates an individual user's logical application session after 10 minutes of application inactivity at which time the user must re-authenticate and a new session must be established if the... | 
                                                                        
                            | V-222389 | Medium | The application must automatically terminate the non-privileged user session and log off non-privileged users after a 15 minute idle time period has elapsed. | Leaving a user’s application session established for an indefinite period of time increases the risk of session hijacking.
Session termination terminates an individual user's logical application session after 15 minutes of application inactivity at which time the user must re-authenticate and a new session must be established if the user... | 
                                                                        
                            | V-222388 | Medium | The application must clear temporary storage and cookies when the session is terminated. | Persistent cookies are a primary means by which a web application will store application state and user information.  Since HTTP is a stateless protocol, this persistence allows the web application developer to provide a robust and customizable user experience.
However, if a web application stores user authentication information within a... | 
                                                                        
                            | V-222387 | Medium | The application must provide a capability to limit the number of logon sessions per user. | Application management includes the ability to control the number of users and user sessions that utilize an application. Limiting the number of allowed users and sessions per user is helpful in limiting risks related to DoS attacks.
This requirement may be met via the application or by utilizing information system... | 
                                                                        
                            | V-222672 | Low | The application must generate audit records when concurrent logons from different workstations occur. | When an application provides users with the ability to concurrently logon, an event must be recorded that indicates the user has logged on from different workstations. It is important to ensure that audit logs differentiate between the two sessions.
The event data must include the user ID, the workstation information... | 
                                                                        
                            | V-222670 | Low | The application must provide notifications or alerts when product update and security related patches are available. | An application vulnerability management and update process must be in place to notify and provide users and administrators with a means of obtaining security patches and updates for the application.
An important part of the maintenance phase of an application is managing vulnerabilities for updated versions of the application after... | 
                                                                        
                            | V-222669 | Low | At least one application administrator must be registered to receive update notifications, or security alerts, when automated alerts are available. | Administrators should register for updates to all COTS and custom-developed software, so when security flaws are identified, they can be tracked for testing and updates of the application can be applied.
Admin personnel should be registered to receive updates to all components of the application, such as Web Server, Application... | 
                                                                        
                            | V-222660 | Low | Procedures must be in place to notify users when an application is decommissioned. | When maintenance no longer exists for an application, there are no individuals responsible for making security updates. The application support staff should maintain procedures for decommissioning. The decommissioning process should include notifying users of the pending decommissioning event. If the users are not informed of the decommissioning event, attackers may... | 
                                                                        
                            | V-222654 | Low | The designer must create and update the Design Document for each release of the application. | This requirement is meant to apply to developers or organizations that are doing application development work.
The application design document or configuration guide includes configuration settings, recommendations and best practices that pertain to the secure deployment of the application.
It also contains the detailed functional architecture as well as any... | 
                                                                        
                            | V-222653 | Low | The application development team must follow a set of coding standards. | Coding standards are guidelines established by the development team or individual developers that recommend programming style, practices and methods.  The coding standards employed will vary based upon the programming language that is being used to develop the application and the development team.
Coding standards often cover the use of white... | 
                                                                        
                            | V-222649 | Low | Code coverage statistics must be maintained for each release of the application. | This requirement is meant to apply to developers or organizations that are doing application development work.
Code coverage statistics describes the overall functionality provided by the application and how much of the source code has been tested during the release cycle.
To avoid the potential for testing the same pieces... | 
                                                                        
                            | V-222647 | Low | Test procedures must be created and at least annually executed to ensure system initialization, shutdown, and aborts are configured to verify the system remains in a secure state. | Secure state assurance cannot be accomplished without testing the system state at least annually to ensure the system remains in a secure state upon initialization, shutdown, and aborts. | 
                                                                        
                            | V-222644 | Low | Prior to each release of the application, updates to system, or applying patches; tests plans and procedures must be created and executed. | Without test plans and procedures for application releases or updates, unexpected results may occur which could lead to a denial of service to the application or components.
This requirement is meant to apply to developers or organizations that are doing development work when releasing a version update or a patch... | 
                                                                        
                            | V-222617 | Low | The application must notify the ISSO and ISSM of failed security verification tests. | If personnel are not notified of failed security verification tests, they will not be able to take corrective action and the unsecure condition(s) will remain.
Security function is defined as the hardware, software, and/or firmware of the information system responsible for enforcing the system security policy and supporting the isolation... | 
                                                                        
                            | V-222437 | Low | The application must display the time and date of the users last successful logon. | Providing a last successful logon date and time stamp notification to the user when they authenticate and access the application allows the user to determine if their application account has been used without their knowledge. 
Armed with that information, the user can notify the application administrator and initiate a forensics... | 
                                                                        
                            | V-222436 | Low | The publicly accessible application must display the Standard Mandatory DoD Notice and Consent Banner before granting access to the application. |  | 
                                                                        
                            | V-222435 | Low | The application must retain the Standard Mandatory DoD Notice and Consent Banner on the screen until users acknowledge the usage conditions and take explicit actions to log on for further access. | The banner must be acknowledged by the user prior to allowing the user access to the application. This provides assurance that the user has seen the message and accepted the conditions for access. If the consent banner is not acknowledged by the user, DoD will not be in compliance with... | 
                                                                        
                            | V-222434 | Low | The application must display the Standard Mandatory DoD Notice and Consent Banner before granting access to the application. |  | 
                                                                        
                            | V-222422 | Low | The application must notify system administrators (SAs) and information system security officers (ISSOs) of account enabling actions. | Once an attacker establishes access to a system, the attacker often attempts to create a persistent method of re-establishing access. One way to accomplish this is for the attacker to enable an account. Notification of account enabling is one method for mitigating this risk. A comprehensive account management process will... | 
                                                                        
                            | V-222420 | Low | The application must notify system administrators (SAs) and information system security officers (ISSOs) of account removal actions. | Once an attacker establishes access to a system, the attacker often attempts to create a persistent method of re-establishing access. One way to accomplish this is for the attacker to remove an account. Notification of account removal is one method for mitigating this risk. A comprehensive account management process will... | 
                                                                        
                            | V-222419 | Low | The application must notify system administrators (SAs) and information system security officers (ISSOs) of account disabling actions. | Once an attacker establishes access to a system, the attacker often attempts to create a persistent method of re-establishing access. One way to accomplish this is for the attacker to simply create a new account. Notification of account creation is one method for mitigating this risk. A comprehensive account management... | 
                                                                        
                            | V-222418 | Low | The application must notify system administrators (SAs) and information system security officers (ISSOs) when accounts are modified. | Once an attacker establishes access to a system, the attacker often attempts to create a persistent method of re-establishing access. One way to accomplish this is for the attacker to simply create a new account. Notification of account creation is one method for mitigating this risk. A comprehensive account management... | 
                                                                        
                            | V-222417 | Low | The application must notify system administrators (SAs) and information system security officers (ISSOs) when accounts are created. | Once an attacker establishes access to a system, the attacker often attempts to create a persistent method of re-establishing access. One way to accomplish this is for the attacker to simply create a new account. Notification of account creation is one method for mitigating this risk. A comprehensive account management... | 
                                                                        
                            | V-222411 | Low | The application must automatically disable accounts after a 35 day period of account inactivity. | Attackers that are able to exploit an inactive account can potentially obtain and maintain undetected access to an application. Owners of inactive accounts will not notice if unauthorized access to their user account has been obtained. Applications need to track periods of user inactivity and disable accounts after 35 days... | 
                                                                        
                            | V-222410 | Low | The application must have a process, feature or function that prevents removal or disabling of emergency accounts. | Emergency accounts are administrator accounts which are established in response to crisis situations where the need for rapid account activation is required. Therefore, emergency account activation may bypass normal account authorization processes.
If these accounts are automatically disabled, system maintenance during emergencies may not be possible, thus adversely affecting system... | 
                                                                        
                            | V-222392 | Low | The application must display an explicit logoff message to users indicating the reliable termination of authenticated communications sessions. | If a user is not explicitly notified that their application session has been terminated, they cannot be certain that their session did not remain open. Applications with a user access interface must provide an explicit logoff message to the user upon successful termination of the user session. |