Skip to content

Instantly share code, notes, and snippets.

@d0minicw0ng
Last active April 24, 2017 09:35
Show Gist options
  • Save d0minicw0ng/6442d0479f8fd636521c60ffa93f7233 to your computer and use it in GitHub Desktop.
Save d0minicw0ng/6442d0479f8fd636521c60ffa93f7233 to your computer and use it in GitHub Desktop.
PCI DSS
Storage Permitted Storage Permitted Render Stored Data Unreadable per Requirement 3.4
Cardholder Data Primary Account Number (PAN) Yes Yes
Cardholder Name Yes No
Service Code Yes No
Expiration Date Yes No
Sensitive Authentication Data Full Track Data No Cannot store per Requirement 3.2
CAV2/CVC2/CVV2/CID No Cannot store per Requirement 3.2
PIN/PIN Block No Cannot store per Requirement 3.2

PCI DSS Requirements 3.3 and 3.4 apply only to PAN. If PAN is stored with other elements of cardholder data, only the PAN must be rendered unreadable according to PCI DSS Requirement 3.4.

Sensitive authentication data must not be stored after authorization, even if encrypted. This applies even where there is no PAN in the environment. Organizations should contact their acquirer or the individual payment brands directly to understand whether SAD is permitted to be stored prior to authorization, for how long, and any related usage and protection requirements

@d0minicw0ng
Copy link
Author

Network segmentation of, or isolating (segmenting), the cardholder data environment from the remainder of an entity’s network is not a PCI DSS requirement. However, it is strongly recommended as a method that may reduce:

  • The scope of the PCI DSS assessment
  • The cost of the PCI DSS assessment
  • The cost and difficulty of implementing and maintaining PCI DSS controls
  • The risk to an organization (reduced by consolidating cardholder data into fewer, more controlled locations)

@d0minicw0ng
Copy link
Author

d0minicw0ng commented Apr 6, 2017

Requirement 1: Install and maintain a firewall configuration to protect cardholder data

  • A formal process for approving and testing all network connections and changes to the firewall and router configurations
  • Current network diagram that identifies all connections between the cardholder data environment and other networks, including any wireless networks
  • Current diagram that shows all cardholder data flows across systems and networks
  • Requirements for a firewall at each Internet connection and between any demilitarized zone (DMZ) and the internal network zone
  • Description of groups, roles, and responsibilities for management of network components
  • Documentation of business justification and approval for use of all services, protocols, and ports allowed, including documentation of security features implemented for those protocols considered to be insecure.
  • Requirement to review firewall and router rule sets at least every six months
  • Build firewall and router configurations that restrict connections between untrusted networks and any system components in the cardholder data environment.
  • Restrict inbound and outbound traffic to that which is necessary for the cardholder data environment, and specifically deny all other traffic.
  • Secure and synchronize router configuration files.
  • Install perimeter firewalls between all wireless networks and the cardholder data environment, and configure these firewalls to deny or, if traffic is necessary for business purposes, permit only authorized traffic between the wireless environment and the cardholder data environment.
  • Prohibit direct public access between the Internet and any system component in the cardholder data environment.
  • Implement a DMZ to limit inbound traffic to only system components that provide authorized publicly accessible services, protocols, and ports.
  • Limit inbound Internet traffic to IP addresses within the DMZ.
  • Implement anti-spoofing measures to detect and block forged source IP addresses from entering the network.
    (For example, block traffic originating from the Internet with an internal source address.)
  • Do not allow unauthorized outbound traffic from the cardholder data environment to the Internet.
  • Permit only “established” connections into the network.
  • Place system components that store cardholder data (such as a database) in an internal network zone, segregated from the DMZ and other untrusted networks.
  • Do not disclose private IP addresses and routing information to unauthorized parties.
  • Install personal firewall software or equivalent functionality on any portable computing devices (including company and/or employee-owned) that connect to the Internet when outside the network (for example, laptops used by employees), and which are also used to access the CDE.
  • Ensure that security policies and operational procedures for managing firewalls are documented, in use, and known to all affected parties.

@d0minicw0ng
Copy link
Author

Requirement 2: Do not use vendor-supplied defaults for system passwords and other security parameters

  • Always change vendor-supplied defaults and remove or disable unnecessary default accounts before installing a system on the network.
  • For wireless environments connected to the cardholder data environment or transmitting cardholder data, change ALL wireless vendor defaults at installation, including but not limited to default wireless encryption keys, passwords, and SNMP community strings.
  • Develop configuration standards for all system components. Assure that these standards address all known security vulnerabilities and are consistent with industry-accepted system hardening standards.
  • Implement only one primary function per server to prevent functions that require different security levels from co-existing on the same server.
  • Enable only necessary services, protocols, daemons, etc., as required for the function of the system.
  • Implement additional security features for any required services, protocols, or daemons that are considered to be insecure.
  • Configure system security parameters to prevent misuse.
  • Remove all unnecessary functionality, such as scripts, drivers, features, subsystems, file systems, and unnecessary web servers.
  • Encrypt all non-console administrative access using strong cryptography.
  • Maintain an inventory of system components that are in scope for PCI DSS.
  • Ensure that security policies and operational procedures for managing vendor defaults and other security parameters are documented, in use, and known to all affected parties.
  • Shared hosting providers must protect each entity’s hosted environment and cardholder data. These providers must meet specific requirements as detailed in Appendix A1: Additional PCI DSS Requirements for Shared Hosting Providers.

@d0minicw0ng
Copy link
Author

d0minicw0ng commented Apr 7, 2017

Requirement 3: Protect stored cardholder data

  • Keep cardholder data storage to a minimum by implementing data retention and disposal policies, procedures and processes that include at least the following for all cardholder data (CHD) storage:
    1. Limiting data storage amount and retention time to that which is required for legal, regulatory, and/or business requirements
    2. Specific retention requirements for cardholder data
    3. Processes for secure deletion of data when no longer needed
    4. A quarterly process for identifying and securely deleting stored cardholder data that exceeds defined retention.
  • Do not store sensitive authentication data after authorization (even if encrypted). If sensitive authentication data is received, render all data unrecoverable upon completion of the authorization process. It is permissible for issuers and companies that support issuing services to store sensitive authentication data if there is a business justification and the data is stored securely.
  • Do not store the full contents of any track (from the magnetic stripe located on the back of a card, equivalent data contained on a chip, or elsewhere) after authorization. This data is alternatively called full track, track, track 1, track 2, and magnetic-stripe data.
  • Do not store the card verification code or value (three-digit or four-digit number printed on the front or back of a payment card used to verify card-not- present transactions) after authorization.
  • Do not store the personal identification number (PIN) or the encrypted PIN block after authorization.
  • Mask PAN when displayed (the first six and last four digits are the maximum number of digits to be displayed), such that only personnel with a legitimate business need can see more than the first six/last four digits of the PAN.
  • Render PAN unreadable anywhere it is stored (including on portable digital media, backup media, and in logs) by using any of the following approaches:
    1. One-way hashes based on strong cryptography, (hash must be of the entire PAN)
    2. Truncation (hashing cannot be used to replace the truncated segment of PAN)
    3. Index tokens and pads (pads must be securely stored)
    4. Strong cryptography with associated key-management processes and procedures.
  • If disk encryption is used (rather than file- or column-level database encryption), logical access must be managed separately and independently of native operating system authentication and access control mechanisms (for example, by not using local user account databases or general network login credentials). Decryption keys must not be associated with user accounts.
  • Document and implement procedures to protect keys used to secure stored cardholder data against disclosure and misuse
  • Additional requirement for service providers only: Maintain a documented description of the cryptographic architecture that includes:
    1. Details of all algorithms, protocols, and keys used for the protection of cardholder data, including key strength and expiry date
    2. Description of the key usage for each key
    3. Inventory of any HSMs and other SCDs used for key management
  • Restrict access to cryptographic keys to the fewest number of custodians necessary.
  • Store secret and private keys used to encrypt/decrypt cardholder data in one (or more) of the following forms at all times:
    1. Encrypted with a key-encrypting key that is at least as strong as the data-encrypting key, and that is stored separately from the data-encrypting key
    2. Within a secure cryptographic device (such as a hardware (host) security module (HSM) or PTS-approved point-of-interaction device)
    3. As at least two full-length key components or key shares, in accordance with an industry- accepted method
  • Fully document and implement all key-management processes and procedures for cryptographic keys used for encryption of cardholder data, including the following:
  • Generation of strong cryptographic keys
  • Secure cryptographic key distribution
  • Secure cryptographic key storage
  • Cryptographic key changes for keys that have reached the end of their cryptoperiod (for example, after a defined period of time has passed and/or after a certain amount of cipher-text has been produced by a given key), as defined by the associated application vendor or key owner, and based on industry best practices and guidelines
  • Retirement or replacement (for example, archiving, destruction, and/or revocation) of keys as deemed necessary when the integrity of the key has been weakened (for example, departure of an employee with knowledge of a clear-text key component), or keys are suspected of being compromised.
  • If manual clear-text cryptographic key-management operations are used, these operations must be managed using split knowledge and dual control.
  • Prevention of unauthorized substitution of cryptographic keys.
  • Requirement for cryptographic key custodians to formally acknowledge that they understand and accept their key- custodian responsibilities.
  • Ensure that security policies and operational procedures for protecting stored cardholder data are documented, in use, and known to all affected parties.

@d0minicw0ng
Copy link
Author

Requirement 4: Encrypt transmission of cardholder data across open, public networks

  • Use strong cryptography and security protocols to safeguard sensitive cardholder data during transmission over open, public networks, including the following:
    1. Only trusted keys and certificates are accepted.
    2. The protocol in use only supports secure versions or configurations.
    3. The encryption strength is appropriate for the encryption methodology in use.
  • Ensure wireless networks transmitting cardholder data or connected to the cardholder data environment, use industry best practices to implement strong encryption for authentication and transmission.
  • Never send unprotected PANs by end- user messaging technologies (for example, e- mail, instant messaging, SMS, chat, etc.).
  • Ensure that security policies and operational procedures for encrypting transmissions of cardholder data are documented, in use, and known to all affected parties.

@d0minicw0ng
Copy link
Author

d0minicw0ng commented Apr 18, 2017

Requirement 5: Protect all systems against malware and regularly update anti-virus software or programs

  • Deploy anti-virus software on all systems commonly affected by malicious software (particularly personal computers and servers).
  • Ensure that anti-virus programs are capable of detecting, removing, and protecting against all known types of malicious software.
  • For systems considered to be not commonly affected by malicious software, perform periodic evaluations to identify and evaluate evolving malware threats in order to confirm whether such systems continue to not require anti-virus software.
  • Ensure that all anti-virus mechanisms are maintained as follows:
    1. Are kept current,
    2. Perform periodic scans
    3. Generate audit logs which are retained per PCI DSS Requirement 10.7
  • Ensure that anti-virus mechanisms are actively running and cannot be disabled or altered by users, unless specifically authorized by management on a case-by-case basis for a limited time period
  • Ensure that security policies and operational procedures for protecting systems against malware are documented, in use, and known to all affected parties.

@d0minicw0ng
Copy link
Author

Requirement 6: Develop and maintain secure systems and applications

  • Establish a process to identify security vulnerabilities, using reputable outside sources for security vulnerability information, and assign a risk ranking (for example, as “high,” “medium,” or “low”) to newly discovered security vulnerabilities.
  • Ensure that all system components and software are protected from known vulnerabilities by installing applicable vendor- supplied security patches. Install critical security patches within one month of release.
  • Develop internal and external software applications (including web-based administrative access to applications) securely, as follows:
  1. In accordance with PCI DSS (for example, secure authentication and logging)
  2. Based on industry standards and/or best practices.
  3. Incorporating information security throughout the software-development life cycle
  • Remove development, test and/or custom application accounts, user IDs, and passwords before applications become active or are released to customers.
  • Review custom code prior to release to production or customers in order to identify any potential coding vulnerability (using either manual or automated processes) to include at least the following:
    1. Code changes are reviewed by individuals other than the originating code author, and by individuals knowledgeable about code-review techniques and secure coding practices.
    2. Code reviews ensure code is developed according to secure coding guidelines
    3. Appropriate corrections are implemented prior to release.
    4. Code-review results are reviewed and approved by management prior to release.
  • Separate development/test environments from production environments, and enforce the separation with access controls.
  • Separation of duties between development/test and production environments
  • Production data (live PANs) are not used for testing or development
  • Removal of test data and accounts from system components before the system becomes active / goes into production
  • Documentation of impact
  • Documented change approval by authorized parties
  • Functionality testing to verify that the change does not adversely impact the security of the system
  • Back-out procedures
  • Upon completion of a significant change, all relevant PCI DSS requirements must be implemented on all new or changed systems and networks, and documentation updated as applicable
  • Address common coding vulnerabilities in software-development processes as follows:
    1. Train developers at least annually in up-to-date secure coding techniques, including how to avoid common coding vulnerabilities.
    2. Develop applications based on secure coding guidelines. (Common problems: SQL injection, Buffer Overflows, Insecure Cryptographic Storage, Insecure Communications, Improper Error Handling, XSS, Improper Access Control, CSRF, Broken Authentication And Session Management)
  • For public-facing web applications, address new threats and vulnerabilities on an ongoing basis and ensure these applications are protected against known attacks by either of the following methods:
    1. Reviewing public-facing web applications via manual or automated application vulnerability security assessment tools or methods, at least annually and after any changes
    2. Installing an automated technical solution that detects and prevents web- based attacks (for example, a web-application firewall) in front of public-facing web applications, to continually check all traffic.
  • Ensure that security policies and operational procedures for developing and maintaining secure systems and applications are documented, in use, and known to all affected parties.

@d0minicw0ng
Copy link
Author

Requirement 7: Restrict access to cardholder data by business need to know

  • Limit access to system components and cardholder data to only those individuals whose job requires such access
  • Define access needs for each role, including:
    1. System components and data resources that each role needs to access for their job function
    2. Level of privilege required (for example, user, administrator, etc.) for accessing resources.
  • Restrict access to privileged user IDs to least privileges necessary to perform job responsibilities
  • Assign access based on individual personnel’s job classification and function
  • Require documented approval by authorized parties specifying required privileges
  • Establish an access control system(s) for systems components that restricts access based on a user’s need to know, and is set to “deny all” unless specifically allowed. This access control system(s) must include the following:
    1. Coverage of all system components
    2. Assignment of privileges to individuals based on job classification and function
    3. Default “deny-all” setting
    4. Ensure that security policies and operational procedures for restricting access to cardholder data are documented, in use, and known to all affected parties

@d0minicw0ng
Copy link
Author

Requirement 8: Identify and authenticate access to system components

  • Define and implement policies and procedures to ensure proper user identification management for non-consumer users and administrators on all system components as follows:
    1. Assign all users a unique ID before allowing them to access system components or cardholder data
    2. Control addition, deletion, and modification of user IDs, credentials, and other identifier objects
    3. Immediately revoke access for any terminated users
    4. Remove/disable inactive user accounts within 90 days
    5. Manage IDs used by third parties to access, support, or maintain system components via remote access as follows:
      i. Enabled only during the time period needed and disabled when not in use.
      ii. Monitored when in use
    6. Limit repeated access attempts by locking out the user ID after not more than six attempts
    7. Set the lockout duration to a minimum of 30 minutes or until an administrator enables the user ID
    8. If a session has been idle for more than 15 minutes, require the user to re-authenticate to re-activate the terminal or session
  • In addition to assigning a unique ID, ensure proper user-authentication management for non-consumer users and administrators on all system components by employing at least one of the following methods to authenticate all users:
    1. Something you know, such as a password or passphrase
    2. Something you have, such as a token device or smart card
    3. Something you are, such as a biometric.
  • Using strong cryptography, render all authentication credentials (such as passwords/phrases) unreadable during transmission and storage on all system components
  • Verify user identity before modifying any authentication credential—for example, performing password resets, provisioning new tokens, or generating new keys
  • Passwords/passphrases must meet the following:
    1. Require a minimum length of at least seven characters.
    2. Contain both numeric and alphabetic characters.
    3. Alternatively, the passwords/passphrases must have complexity and strength at least equivalent to the parameters specified above.
  • Change user passwords/passphrases at least once every 90 days
  • Do not allow an individual to submit a new password/passphrase that is the same as any of the last four passwords/passphrases he or she has used
  • Set passwords/passphrases for first-time use and upon reset to a unique value for each user, and change immediately after the first use
  • Secure all individual non-console administrative access and all remote access to the CDE using multi-factor authentication
  • Incorporate multi-factor authentication for all non-console access into the CDE for personnel with administrative access
  • Incorporate multi-factor authentication for all remote network access (both user and administrator, and including third-party access for support or maintenance) originating from outside the entity’s network
  • Document and communicate authentication policies and procedures to all users including:
    1. Guidance on selecting strong authentication credentials
    2. Guidance for how users should protect their authentication credentials
    3. Instructions not to reuse previously used passwords
    4. Instructions to change passwords if there is any suspicion the password could be compromised
  • Do not use group, shared, or generic IDs, passwords, or other authentication methods as follows:
    1. Generic user IDs are disabled or removed.
    2. Shared user IDs do not exist for system administration and other critical functions.
    3. Shared and generic user IDs are not used to administer any system components
  • Additional requirement for service providers only: Service providers with remote access to customer premises (for example, for support of POS systems or servers) must use a unique authentication credential (such as a password/phrase) for each customer
  • Where other authentication mechanisms are used (for example, physical or logical security tokens, smart cards, certificates, etc.), use of these mechanisms must be assigned as follows:
    1. Authentication mechanisms must be assigned to an individual account and not shared among multiple accounts.
    2. Physical and/or logical controls must be in place to ensure only the intended account can use that mechanism to gain access
  • All access to any database containing cardholder data (including access by applications, administrators, and all other users) is restricted as follows:
    1. All user access to, user queries of, and user actions on databases are through programmatic methods.
    2. Only database administrators have the ability to directly access or query databases.
    3. Application IDs for database applications can only be used by the applications (and not by individual users or other non-application processes)
  • Ensure that security policies and operational procedures for identification and authentication are documented, in use, and known to all affected parties

@d0minicw0ng
Copy link
Author

Requirement 9: Restrict physical access to cardholder data

  • Use appropriate facility entry controls to limit and monitor physical access to systems in the cardholder data environment
    1. Use either video cameras or access control mechanisms (or both) to monitor individual physical access to sensitive areas. Review collected data and correlate with other entries. Store for at least three months, unless otherwise restricted by law
    2. Implement physical and/or logical controls to restrict access to publicly accessible network jacks
    3. Restrict physical access to wireless access points, gateways, handheld devices, networking/communications hardware, and telecommunication lines
  • Develop procedures to easily distinguish between onsite personnel and visitors, to include:
    1. Identifying onsite personnel and visitors (for example, assigning badges)
    2. Changes to access requirements
    3. Revoking or terminating onsite personnel and expired visitor identification (such as ID badges)
  • Control physical access for onsite personnel to sensitive areas as follows:
    1. Access must be authorized and based on individual job function.
    2. Access is revoked immediately upon termination, and all physical access mechanisms, such as keys, access cards, etc., are returned or disabled
  • Implement procedures to identify and authorize visitors. Procedures should include the following:
    1. Visitors are authorized before entering, and escorted at all times within, areas where cardholder data is processed or maintained
    2. Visitors are identified and given a badge or other identification that expires and that visibly distinguishes the visitors from onsite personnel
    3. Visitors are asked to surrender the badge or identification before leaving the facility or at the date of expiration
    4. A visitor log is used to maintain a physical audit trail of visitor activity to the facility as well as computer rooms and data centers where cardholder data is stored or transmitted. Document the visitor’s name, the firm represented, and the onsite personnel authorizing physical access on the log. Retain this log for a minimum of three months, unless otherwise restricted by law
  • Physically secure all media
    1. Store media backups in a secure location, preferably an off-site facility, such as an alternate or backup site, or a commercial storage facility. Review the location’s security at least annually
  • Maintain strict control over the internal or external distribution of any kind of media, including the following:
    1. Classify media so the sensitivity of the data can be determined
    2. Send the media by secured courier or other delivery method that can be accurately tracked
    3. Ensure management approves any and all media that is moved from a secured area (including when media is distributed to individuals)
  • Maintain strict control over the storage and accessibility of media
    1. Properly maintain inventory logs of all media and conduct media inventories at least annually
  • Destroy media when it is no longer needed for business or legal reasons as follows:
    1. Shred, incinerate, or pulp hard-copy materials so that cardholder data cannot be reconstructed. Secure storage containers used for materials that are to be destroyed
    2. Render cardholder data on electronic media unrecoverable so that cardholder data cannot be reconstructed
  • Protect devices that capture payment card data via direct physical interaction with the card from tampering and substitution
    1. Maintain an up-to-date list of devices. The list should include the following:
      i. Make, model of device
      ii. Location of device (for example, the address of the site or facility where the device is located)
      iii. Device serial number or other method of unique identification
    2. Periodically inspect device surfaces to detect tampering (for example, addition of card skimmers to devices), or substitution (for example, by checking the serial number or other device characteristics to verify it has not been swapped with a fraudulent device)
    3. Provide training for personnel to be aware of attempted tampering or replacement of devices. Training should include the following:
      i. Verify the identity of any third-party persons claiming to be repair or maintenance personnel, prior to granting them access to modify or troubleshoot devices
      ii. Do not install, replace, or return devices without verification
      iii. Be aware of suspicious behavior around devices (for example, attempts by unknown persons to unplug or open devices)
      iv. Report suspicious behavior and indications of device tampering or substitution to appropriate personnel (for example, to a manager or security officer)
  • Ensure that security policies and operational procedures for restricting physical access to cardholder data are documented, in use, and known to all affected parties

@d0minicw0ng
Copy link
Author

d0minicw0ng commented Apr 24, 2017

Requirement 10: Track and monitor all access to network resources and cardholder data

  • Implement audit trails to link all access to system components to each individual user

  • Implement automated audit trails for all system components to reconstruct the following events:

    1. All individual user accesses to cardholder data
    2. All actions taken by any individual with root or administrative privileges
    3. Access to all audit trails
    4. Invalid logical access attempts
    5. Use of and changes to identification and authentication mechanisms—including but not limited to creation of new accounts and elevation of privileges—and all changes, additions, or deletions to accounts with root or administrative privileges
    6. Initialization, stopping, or pausing of the audit logs
    7. Creation and deletion of system-level objects
  • Record at least the following audit trail entries for all system components for each event:

    1. User identification
      2 Type of event
    2. Date and time
    3. Success or failure indication
    4. Origination of event
    5. Identity or name of affected data, system component, or resource
  • Using time-synchronization technology, synchronize all critical system clocks and times and ensure that the following is implemented for acquiring, distributing, and storing time

    1. Critical systems have the correct and consistent time
    2. Time data is protected
    3. Time settings are received from industry-accepted time sources
    4. Secure audit trails so they cannot be altered
    5. Limit viewing of audit trails to those with a job-related need
    6. Protect audit trail files from unauthorized modifications
    7. Promptly back up audit trail files to a centralized log server or media that is difficult to alter
    8. Write logs for external-facing technologies onto a secure, centralized, internal log server or media device
    9. Use file-integrity monitoring or change-detection software on logs to ensure that existing log data cannot be changed without generating alerts (although new data being added should not cause an alert)
  • Review logs and security events for all system components to identify anomalies or suspicious activity

    1. Review the following at least daily:
      i. All security events
      ii. Logs of all system components that store, process, or transmit CHD and/or SAD
      iii. Logs of all critical system components
      iv. Logs of all servers and system components that perform security functions (for example, firewalls, intrusion-detection systems/intrusion-prevention systems (IDS/IPS), authentication servers, e-commerce redirection servers, etc.)
    2. Review logs of all other system components periodically based on the organization’s policies and risk management strategy, as determined by the organization’s annual risk assessment
    3. Follow up exceptions and anomalies identified during the review process
  • Retain audit trail history for at least one year, with a minimum of three months immediately available for analysis (for example, online, archived, or restorable from backup)

  • Additional requirement for service providers only:

    1. Implement a process for the timely detection and reporting of failures of critical security control systems, including but not limited to failure of:
      i. Firewalls
      ii. IDS/IPS
      iii. FIM
      iv. Anti-virus
      v. Physical access controls
      vi. Logical access controls
      vii. Audit logging mechanisms
      vii. Segmentation controls (if used)

    2. Respond to failures of any critical security controls in a timely manner. Processes for responding to failures in security controls must include:
      i. Restoring security functions
      ii. Identifying and documenting the duration (date and time start to end) of the security failure
      iii. Identifying and documenting cause(s) of failure, including root cause, and documenting remediation required to address root cause
      iv. Identifying and addressing any security issues that arose during the failure
      v. Performing a risk assessment to determine whether further actions are required as a result of the security failure
      vi. Implementing controls to prevent cause of failure from reoccurring
      vii. Resuming monitoring of security controls

  • Ensure that security policies and operational procedures for monitoring all access to network resources and cardholder data are documented, in use, and known to all affected parties

@d0minicw0ng
Copy link
Author

Requirement 11: Regularly test security systems and processes.

  • Implement processes to test for the presence of wireless access points (802.11), and detect and identify all authorized and unauthorized wireless access points on a quarterly basis

    1. Maintain an inventory of authorized wireless access points including a documented business justification
    2. Implement incident response procedures in the event unauthorized wireless access points are detected
  • Run internal and external network vulnerability scans at least quarterly and after any significant change in the network (such as new system component installations, changes in network topology, firewall rule modifications, product upgrades)

    1. Perform quarterly internal vulnerability scans. Address vulnerabilities and perform rescans to verify all “high risk” vulnerabilities are resolved in accordance with the entity’s vulnerability ranking (per Requirement 6.1). Scans must be performed by qualified personnel
    2. Perform quarterly external vulnerability scans, via an Approved Scanning Vendor (ASV) approved by the Payment Card Industry Security Standards Council (PCI SSC). Perform rescans as needed, until passing scans are achieved
    3. Perform internal and external scans, and rescans as needed, after any significant change. Scans must be performed by qualified personnel
  • Implement a methodology for penetration testing that includes the following:

    1. Is based on industry-accepted penetration testing approaches (for example, NIST SP800-115)
    2. Includes coverage for the entire CDE perimeter and critical systems
    3. Includes testing from both inside and outside the network
    4. Includes testing to validate any segmentation and scope-reduction controls
    5. Defines application-layer penetration tests to include, at a minimum, the vulnerabilities listed in Requirement 6.5
    6. Defines network-layer penetration tests to include components that support network functions as well as operating systems
  • Use intrusion-detection and/or intrusion-prevention techniques to detect and/or prevent intrusions into the network. Monitor all traffic at the perimeter of the cardholder data environment as well as at critical points in the cardholder data environment, and alert personnel to suspected compromises. Keep all intrusion-detection and prevention engines, baselines, and signatures up to date

  • Deploy a change-detection mechanism (for example, file-integrity monitoring tools) to alert personnel to unauthorized modification (including changes, additions, and deletions) of critical system files, configuration files, or content files; and configure the software to perform critical file comparisons at least weekly

  • Ensure that security policies and operational procedures for security monitoring and testing are documented, in use, and known to all affected parties

@d0minicw0ng
Copy link
Author

d0minicw0ng commented Apr 24, 2017

Requirement 12: Maintain a policy that addresses information security for all personnel.

  • Establish, publish, maintain, and disseminate a security policy
    1. Review the security policy at least annually and update the policy when the environment changes
  • Implement a risk-assessment process that:
    1. Is performed at least annually and upon significant changes to the environment (for example, acquisition, merger, relocation, etc.),
    2. Identifies critical assets, threats, and vulnerabilities, and
    3. Results in a formal, documented analysis of risk.
  • Develop usage policies for critical technologies and define proper use of these technologies
    1. Explicit approval by authorized parties
    2. Authentication for use of the technology
    3. A list of all such devices and personnel with access
    4. A method to accurately and readily determine owner, contact information, and purpose (for example, labeling, coding, and/or inventorying of devices)
    5. Acceptable uses of the technology
    6. Acceptable network locations for the technologies
    7. List of company-approved products
    8. Automatic disconnect of sessions for remote-access technologies after a specific period of inactivity
    9. Activation of remote-access technologies for vendors and business partners only when needed by vendors and business partners, with immediate deactivation after use
    10. For personnel accessing cardholder data via remote-access technologies, prohibit the copying, moving, and storage of cardholder data onto local hard drives and removable electronic media, unless explicitly authorized for a defined business need.
      Where there is an authorized business need, the usage policies must require the data be protected in accordance with all applicable PCI DSS Requirements
  • Ensure that the security policy and procedures clearly define information security responsibilities for all personnel
  • Assign to an individual or team the following information security management responsibilities:
    1. Establish, document, and distribute security policies and procedures
    2. Monitor and analyze security alerts and information, and distribute to appropriate personnel
    3. Establish, document, and distribute security incident response and escalation procedures to ensure timely and effective handling of all situations
    4. Administer user accounts, including additions, deletions, and modifications
    5. Monitor and control all access to data
  • Implement a formal security awareness program to make all personnel aware of the cardholder data security policy and procedures
    1. Educate personnel upon hire and at least annually
    2. Require personnel to acknowledge at least annually that they have read and understood the security policy and procedures
  • Screen potential personnel prior to hire to minimize the risk of attacks from internal sources. (Examples of background checks include previous employment history, criminal record, credit history, and reference checks.)
  • Maintain and implement policies and procedures to manage service providers with whom cardholder data is shared, or that could affect the security of cardholder data, as follows:
    1. Maintain a list of service providers including a description of the service provided
    2. Maintain a written agreement that includes an acknowledgement that the service providers are responsible for the security of cardholder data the service providers possess or otherwise store, process or transmit on behalf of the customer, or to the extent that they could impact the security of the customer’s cardholder data environment
    3. Ensure there is an established process for engaging service providers including proper due diligence prior to engagement
    4. Maintain a program to monitor service providers’ PCI DSS compliance status at least annually
    5. Maintain information about which PCI DSS requirements are managed by each service provider, and which are managed by the entity
  • Additional requirement for service providers only: Service providers acknowledge in writing to customers that they are responsible for the security of cardholder data the service provider possesses or otherwise stores, processes, or transmits on behalf of the customer, or to the extent that they could impact the security of the customer’s cardholder data environment
  • Implement an incident response plan. Be prepared to respond immediately to a system breach
    1. Create the incident response plan to be implemented in the event of system breach. Ensure the plan addresses the following, at a minimum:
      i. Roles, responsibilities, and communication and contact strategies in the event of a compromise including notification of the payment brands, at a minimum
      ii. Specific incident response procedures
      iii. Business recovery and continuity procedures
      iv. Data backup processes
      v. Analysis of legal requirements for reporting compromises
      vi. Coverage and responses of all critical system components
      vii. Reference or inclusion of incident response procedures from the payment brands
    2. Review and test the plan, including all elements listed in Requirement 12.10.1, at least annually
    3. Designate specific personnel to be available on a 24/7 basis to respond to alerts
    4. Provide appropriate training to staff with security breach response responsibilities
    5. Include alerts from security monitoring systems, including but not limited to intrusion-detection, intrusion-prevention, firewalls, and file-integrity monitoring systems
    6. Develop a process to modify and evolve the incident response plan according to lessons learned and to incorporate industry developments
  • Additional requirement for service providers only: Perform reviews at least quarterly to confirm personnel are following security policies and operational procedures. Reviews must cover the following processes:
    1. Daily log reviews
    2. Firewall rule-set reviews
    3. Applying configuration standards to new systems
    4. Responding to security alerts
    5. Change management processes
  • Additional requirement for service providers only: Maintain documentation of quarterly review process to include:
    1. Documenting results of the reviews
    2. Review and sign-off of results by personnel assigned responsibility for the PCI DSS compliance program

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment