.. Reminder for header structure: Parts (H1) : #################### with overline Chapters (H2) : ******************** with overline Sections (H3) : ==================== Subsections (H4) : -------------------- Subsubsections (H5): ^^^^^^^^^^^^^^^^^^^^ Paragraphs (H6) : """""""""""""""""""" .. meta:: :description: Presentation of the security principles in WAPT :keywords: Cybersecurity, WAPT, documentation .. |ok| image:: wapt-resources/icon-ok.png :scale: 15% :align: middle :alt: OK ############################################### Presentation of the security principles in WAPT ############################################### +------------------------+--------------------------------+ | Date | |today| | +------------------------+--------------------------------+ | Written by | Hubert TOUVET, Vincent CARDON | +------------------------+--------------------------------+ | Applicable for WAPT | >= 2.3.0.13180 | +------------------------+--------------------------------+ | Version of the Document| 2.3.0.0-0 | +------------------------+--------------------------------+ | Git hash | |git_hash| | +------------------------+--------------------------------+ .. figure:: wapt-resources/icon_cyber-security.png :align: center :alt: Logo Cybersecurity .. contents:::local: Here are documented the advanced security principles included in WAPT. The reading of this portion of the documentation is not essential for your daily usage of WAPT; it is however recommended for you to better understand some architectural choices made by the developers of the software. .. _security_principles: ************************ Preamble and definitions ************************ .. attention:: The WAPT service operates as a **privileged** system account. ******************************************* Technical environment for product operation ******************************************* Scope of the Target of Evaluation ================================= The assessment covers: * a WAPT Server and its repository (waptserver and waptrepo); * a WAPT Agent, with waptexit enabled (wapttray disabled); * the WAPT Console management console; * network communications between these components. * secure management of WAPT packets: - secure deployment of one or more WAPT packages; - secure deployment of a WAPT package update; - uninstalling a WAPT package. Secure management is based on the use of differentiated certificates between the deployment manager (standard X509 certificate) and the WAPT package designer (X509 certificate with Code-Signing attribute). The operations that are part of the TOE's external perimeter, and therefore not part of the scope of the evaluation, are: * Writing the WAPT script in Python, and supplying all the other files needed to create the WAPT package. * The manages private keys for signing packets, and manages and revokes SSL certificates. Evaluation platform =================== The assessment will cover: * WAPT Server (waptserver and waptrepo) installed on up-to-date Rocky Linux 9 (RedHat 9 clone) with SELinux and firewalld enabled. * A WAPT Agent installed on Windows 10. * The management console (WAPT Console) installed on Windows 10. The console is connected to the WAPT Server via a local network. This console-hosting workstation may also have access to an uncontrolled network, through which it obtains packages (software or software updates) that the Business Administrator then wishes to integrate into his private WAPT repository. The evaluation platform's workstations and administration console are linked to an Active Directory authentication domain. WAPT operation on Linux and macOS client platforms (agent, administration console) will not be evaluated. The HTTPS certificate for the Nginx server used in the evaluation is a self-signed certificate generated during WAPT installation. It is deployed at the same time as the agents and is pinned to the WAPT Server certificate. .. _Python 3.9 sources: https://www.python.org/ftp/python/3.9.19/Python-3.9.19.tgz .. _Lazarus sources: https://gitlab.com/freepascal.org/lazarus/lazarus.git .. _FPC sources: https://gitlab.com/freepascal.org/fpc/source.git/ .. _OpenSSL sources: https://www.openssl.org/source/openssl-3.1.5.tar.gz .. _Nginx SPNego sources: https://github.com/stnoonan/spnego-http-auth-nginx-module .. _mORMot sources: https://github.com/synopse/mORMot2 List of third-party components integrated into WAPT (COTS) ========================================================== .. list-table:: Third-party components integrated into the WAPT Server waptserver :header-rows: 1 :widths: auto :align: center * - Conponent - Version - hashupdated to the latest version - Maintained - Origin * - Nginx - 1.22.1 - Yes (distribution) - Yes (distribution) - RHEL9.1 distribution * - nginx-mod-http-auth-spnego - 1.22.1 - Yes (upstream) - Yes (upstream) - compiled from nginx and `Nginx SPNego sources`_ (hash git bd4e8c3) * - PosgreSQL - 13.18 - Yes (distribution) - Yes (distribution) - RHEL9.1 distribution * - python 3.9 - 3.9.19 - Yes (upstream branch 3.9) - Yes (upstream branch 3.9) - compiled from `Python 3.9 sources`_ * - kerberos MIT - 1.19.1 - Yes (distribution) - Yes (distribution) - RHEL9.1 distribution * - OpenSSL for python and Freepascal compiled modules - 3.1.5 - Yes (upstream) - Yes (upstream) - Compiled from `OpenSSL sources`_ * - Python modules - see below for list - - - installed by pip command .. list-table:: Third-party components integrated into the WAPT Agent waptservice :header-rows: 1 :widths: auto :align: center * - Conponent - Version - hashupdated to the latest version - Maintained - Origin * - python 3.9 - 3.9.19 - Yes (upstream branch 3.9) - Yes (upstream branch 3.9) - compiled from `Python 3.9 sources`_ * - OpenSSL for python and Freepascal compiled modules - 3.1.5 - Yes (upstream) - Yes (upstream) - Compiled from `OpenSSL sources`_ * - Python modules - see below for list - - - installed by pip command .. list-table:: Third-party components integrated into the WAPT-specific binaries: waptconsole, wapt-get, waptexit, wapttray, waptdeploy, waptlicences :header-rows: 1 :widths: auto :align: center * - Conponent - Version - hashupdated to the latest version - Maintained - Origin * - lazarus 2.3 - 2.3 fixed tag_2_3 - Yes (upstream) - Yes (upstream) - `Lazarus sources`_ * - freepascal 3.2.3 - 3.2.3 fixed tag_3_2 - Yes (upstream) - Yes (upstream) - `FPC sources`_ * - mormot2 - 2.3 Git Sha1 c3a060ea35e380a7e5f26ec6e23c5005a5d79f36 - Yes (upstream) - Yes (upstream) - `mORMot sources`_ Python agent and server modules ------------------------------- Python modules are imported in source form from Pypi.org and compiled in wheel form and stored on an internal pip repository. The WAPT build farm does not provide a direct connection to the Internet for Python module installations. The "Target platform" column indicates wheel packages that are only installed on certain target architectures. .. list-table:: Python modules common to Agents and WAPT Server :header-rows: 1 :widths: auto :align: center * - Python modules common to Agents and Server - Version - Target platform * - arpy - 2.3.0 - * - babel - 2.16.0 - * - beautifulsoup4 - 4.12.3 - * - bidict - 0.23.1 - * - blinker - 1.9.0 - * - certifi - 2024.12.14 - * - cffi - 1.17.1 - sys_platform == 'win32' or sys_platform == 'darwin' * - chardet - 5.2.0 - * - cheroot - 10.0.1 - * - click - 8.1.7 - * - configparser - 7.1.0 - * - cryptography - 44.0.0 - * - decorator - 5.1.1 - * - distro - 1.9.0 - * - dnspython - 2.7.0 - sys_platform == 'linux' or sys_platform == 'darwin' * - flask - 3.1.0 - * - future - 1.0.0 - * - h11 - 0.14.0 - * - idna - 3.10 - * - importlib_metadata - 8.5.0 - * - iniparse - 0.5 - * - ipaddress - 1.0.23 - * - itsdangerous - 2.2.0 - * - jaraco.functools - 4.1.0 - * - jinja2 - 3.1.4 - * - markupsafe - 3.0.2 - * - more-itertools - 10.5.0 - * - packaging - 24.2 - sys_platform == 'darwin' * - psutil - 6.1.0 - * - pyad - 0.6.0 - sys_platform == 'win32' * - pyasn1 - 0.6.1 - * - pycparser - 2.22 - * - py_cpuinfo - 9.0.0 - * - pyopenssl - 24.3.0 - * - pyparsing - 3.2.0 - sys_platform == 'linux' or sys_platform == 'darwin' * - python-engineio - 4.11.1 - * - python-pam - 2.0.2 - sys_platform == 'linux' or sys_platform == 'darwin' * - python-socketio - 5.11.4 - * - pytz - 2024.2 - * - pywin32 - 308 - sys_platform == 'win32' * - requests - 2.32.3 - * - rpmfile - 2.1.0 - * - setproctitle - 1.3.4 - * - simple_websocket - 1.1.0 - * - six - 1.17.0 - * - soupsieve - 2.6 - * - smmap - 5.0.1 - * - ujson - 5.5.0 - * - urllib3 - 2.2.3 - * - wakeonlan - 3.1.0 - * - websocket-client - 1.8.0 - * - werkzeug - 3.1.3 - * - winsys - 1.2 - sys_platform == 'win32' * - wmi - 1.5.1 - sys_platform == 'win32' * - wsproto - 1.2.0 - * - zipp - 3.21.0 - .. list-table:: Python modules specific to the WAPT Server :header-rows: 1 :widths: auto :align: center * - Server-specific Python modules - Version - Target platform * - cachelib - 0.13.0 - * - dnspython - 2.7.0 - * - eventlet - 0.38.2 - * - flask-babel - 4.0.0 - * - flask-socketio - 5.4.1 - * - flask-session - 0.8.0 - * - hashring - 1.5.1 - sys_platform == 'linux' * - greenlet - 3.1.1 - * - huey - 2.5.2 - * - monotonic - 1.6 - * - msgspec - 0.18.6 - * - passlib - 1.7.4 - * - peewee - 3.17.8 - * - pefile - 2024.8.26 - * - psycopg2 - 2.9.9 - * - psycogreen - 1.0.2 - * - pylibmc - 1.6.3 - sys_platform == 'linux' * - uwsgi - 2.0.28 - sys_platform == 'linux' Specific patches ---------------- .. list-table:: Python modules specific to the WAPT Server :header-rows: 1 :widths: auto :align: center * - Python module - Version * - description - iniparse * - 0.5 - The REM keyword (remark) must be followed by a space to be a remark. * - certified - 2023.7.22 * - Importing root certificates from system stores for Windows and macOS - cryptography * - 41.0.4 - Disable loading of legacy algorithms. Vulnerabilities identified -------------------------- The latest version of the *kerberos* python module is affected by vulnerability CVE-2015-3206. **The checkPassword function in python-kerberos does not authenticate the KDC it attempts to communicate with, which allows remote attackers to cause a denial of service (bad response), or have other unspecified impact by performing a man-in-the-middle attack.** This function is not used in the WAPT product. ******************************** Sensitive assets to be protected ******************************** Preamble and definitions ======================== **Please note**: The WAPT service operates as a privileged system account. Perimeter to be secured ======================= B1 WAPT packages ---------------- The WAPT packages to be deployed are one of the main sensitive assets to be protected. They must be protected in terms of availability on the repository, and integrity during deployment. **Security needs**: integrity, authenticity, availability B2 Actions triggered on the client workstation from the console --------------------------------------------------------------- Actions are sent to agents from the console (via a signed json payload). These actions can be updating the workstation, deploying/uninstalling a particular package, rebooting the machines.... These actions are sensitive assets that need to be protected in terms of integrity and authenticity. **Need for security**: integrity, authenticity B3. Cryptographic hardware -------------------------- Cryptographic material is a sensitive asset and must be protected. It serves as authentication data, and is used for encryption. **Security requirements: integrity, confidentiality, availability** There are several cryptographic materials in a WAPT deployment: The private key of the server for HTTPS communication. The private key of the workstation corresponding to the WAPT Agent certificate. The private key of the WAPT administrator corresponding to the code-signing certificate. The private key of the WAPT administrator corresponding to the non-code-signing certificate. The password of the WAPT administrator to connect to the WAPT Server. The Kerberos tokens of the WAPT administrator (service ticket for the WAPT Server). B4. Communications ------------------ Communications between the central server and the agents, and between the console and the server, are a sensitive asset and must be protected. **Security needs**: integrity, confidentiality, authenticity. B5. Inventory data ------------------ Information on the deployment status of packages, as well as the hardware and software configuration of client workstations, is a sensitive asset and must be protected. **Security needs**: integrity, confidentiality. B6. The newspapers ------------------ The logs generated by WAPT on the central server and agents are a sensitive asset and must be protected. **Security needs**: integrity, availability, confidentiality. B7. Configuration values ------------------------ Server configuration values (https server keys, database access configuration, server authentication configuration) are a sensitive asset and must be protected. **Security needs**: integrity, confidentiality, availability. B8. WAPT executables installed ------------------------------ WAPT executables installed on managed client workstations (wapt directory contents including binaries, dlls, configuration files and database) are a sensitive asset and must be protected. **Need for security**: integrity. B9. Host system --------------- The host systems, which here include the server hosting the WAPT Server, the administration workstations hosting the administration console and the user workstations equipped with the WAPT Agent, are a sensitive asset and must be protected. **Security requirements**: integrity, confidentiality, availability. ********************** Environmental measures ********************** A WAPT operator will have to choose and follow a suitable methodology for: * Ensure safe downloading of all other files used to make up a WAPT package. * Write the python setup.py script for installing a WAPT package in such a way as to avoid any exploitable security or confidentiality holes. * Securely manage private keys for signing packets. * Securely manage Certification and Revocation Authorities for SSL and HTTPS certificates. Description of typical WAPT users ================================= The following roles must be understood in order to evaluate the security principles present in WAPT: End user -------- A User is an individual equipped with a machine running the WAPT Agent. He can update his machine according to the settings defined by the deployment manager. Professional administrator: deployment manager ---------------------------------------------- A Deployment Manager is an individual who can sign packages NOT containing python code (usually group, unit and host packages) and upload them to the main repository. He defines deployment profiles (a set of WPAT packages assigned to workstations). He is identified by the absence of the Code-Signing attribute in his certificate. Professional administrator: package developer --------------------------------------------- A Package Developer is an individual who can sign packages, whether or not the packages CONTAIN python code, and upload them to the main repository. The package developer is identified by the Code-Signing attribute of his certificate. Job administrator: SuperAdmin ----------------------------- The SuperAdmin is an individual with full rights within WAPT. In particular, he defines ACLs and creates other administrators. System administrator: Local administrator ----------------------------------------- A Local Administrator is a user with local administration rights on WAPT-equipped workstations. It is used for initial WAPT Agent deployment, if required. Description of WAPT operating environment assumptions ===================================================== The following assumptions about the WAPT operating environment must be considered: H1. WAPT Business Administrators are trained -------------------------------------------- Business administrators are trusted and trained in the use of WAPT. In particular, they must ensure that their identifiers and security keys remain secret and protected. H2. WAPT-subjacent systems are healthy -------------------------------------- The operating systems on which WAPT Agents run implement adequate protection mechanisms (containment, access control, etc.) parameterized and configured according to best practices. Operating systems are up to date with patches in force at the time of installation, and are sound and free of viruses, Trojans, etc. H3. The binaries required to run WAPT are intact ------------------------------------------------ All the libraries and tools required to install WAPT are considered safe. H4. WAPT packages are securely constructed ------------------------------------------ It is the responsibility of the Administrator to ensure that files intended for inclusion in WAPT packages come from secure sources, and are free from viruses, Trojan horses, etc., in particular. Administrators are also responsible for writing and incorporating safe setup.py scripts into WAPT packages. H5. Client Users are not Local Administrators --------------------------------------------- A User does not have administrative rights to his or her workstation. Otherwise, the User is considered a Local Administrator. In particular, the User does not have write access to the WAPT client installation directory. H6. Local administrators of client workstations are trained ----------------------------------------------------------- The Local Administrator of a client workstation must be trained in WAPT operation, or else must not modify the installation files in the WAPT installation folder. H7. The WAPT Server is for dedicated use only. ---------------------------------------------- The server on which WAPT is installed is dedicated exclusively to WAPT. H8. Passwords comply with minimum security criteria --------------------------------------------------- Passwords used by Administrators are supposed to comply with ANSSI minimum security criteria. H9. The Windows environment is configured according to best practices --------------------------------------------------------------------- The underlying environment is configured according to the best practices described in the ANSSI workstation hardening guide. ****************** Threat description ****************** Threatening agents to be considered for safety assessment include: * Unauthorized entities: a human attacker or an entity that interacts with WAPT but does not have legitimate access to it. * Malicious end-user: an end-user with access to a workstation on which the WAPT Agent is installed, seeking to elevate his or her privileges on the workstation. Business Administrators and Local Administrators are not considered as attackers. The threats to the WAPT sensitive assets defined above are as follows: T01. Installation of a corrupt package ====================================== This threat corresponds to an attacker who manages to use a component of the WAPT Agent to deploy a corrupted packet, bypassing the security normally provided by the packet signature. T02. Alteration of configuration values ======================================= This threat corresponds to an attacker succeeding in modifying or deleting the settings of a WAPT element defined by a legitimate WAPT administrator. T03. Illegitimate access ======================== This threat corresponds to an attacker succeeding in recovering an Administrator's authentication data, bypassing the authentication mechanism in order to access or alter a sensitive asset stored on the server. It also corresponds to an attacker who could impersonate a WAPT Agent. T04. Network listening ====================== This threat corresponds to an attacker succeeding in intercepting and gaining knowledge of network communications between agents and the server hosting WAPT. T05. Network traffic alteration (Man In the Middle type) ======================================================== This threat corresponds to an attacker succeeding in modifying network communications between agents and the server hosting WAPT, or network communications between the console and the WAPT Server. T06. Log alteration =================== This threat corresponds to an attacker succeeding in corrupting the logs sent back from the agents and stored in the database. T07. Cryptographic hardware recovery ==================================== This threat corresponds to an attacker succeeding in recovering or gaining knowledge of cryptographic keys. T08. Alteration of cryptographic hardware ========================================= This threat corresponds to an attacker illegitimately corrupting cryptographic keys. T09. Denial of service ====================== This threat corresponds to an attacker affecting the availability of sensitive assets. T10. Alteration or sending of an unwanted action on the workstation =================================================================== This threat corresponds to an attacker who manages to generate or modify the json stream containing actions and execute them on the workstation. T11. Elevation of workstation privileges ======================================== This threat corresponds to an attacker who manages to elevate his privileges on the workstation using the WAPT environment. ************************************ Functions implemented by the product ************************************ Safety functions (SF) ===================== SF1. Secure communications -------------------------- Agent-initiated communications ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The agent downloads its packages from an https server, which checks that the repository certificate comes from an authority present in its **/ssl/server** directory. The https server checks that the client certificate comes from an authority in the repository's client trust store. Requests from the agent to the server use the https protocol. The agent checks that the server's certificate comes from an authority present in its **/ssl/server** directory. The agent establishes a websocket tunnel to the server to receive console actions. The **websocket** connection is encapsulated in a TLS tunnel. The agent checks that the server's certificate comes from an authority present in its **/ssl/server** directory. Console-initiated communications ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The console downloads packages from repositories, verifying that the certificate comes from an authority present in its **%localappdata%/waptconsole/ssl/server** directory. Repository https servers are configured to accept only client certificates from trusted authorities. Console requests to the WAPT Server use the https protocol. The console checks that the server certificate comes from an authority present in its **/ssl/server** directory. The WAPT Server is configured to accept only client certificates from trusted authorities. Agent websocket connection ^^^^^^^^^^^^^^^^^^^^^^^^^^ * Agents request an authentication token from the server, signed with their private key. This token is verified by the WAPT Server during the websocket connection. * Access to the WAPT Server to obtain the token and establish the websocket connection is protected by client certificate authentication. .. _signing_inventory_updates: Agent login for inventory feedback ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ * Agents sign their inventory data with their private key, and the server verifies the key and signature using the public certificate stored in its database during initial agent registration. * Access to the WAPT Server is protected by client certificate authentication. Connecting agents to download packages ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Access to the WAPT packet repository(s) is protected by client certificate authentication. Server authentication by agents ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ When the agent connects to the server via HTTPS requests, it checks that the server certificate is valid and that it comes from a trusted certification authority. When installing the agent, you choose to use: * The system certificate store. * Or a WAPT-specific store stored in the **\ssl\server** folder (certificate pinning). For the purposes of the evaluation, this second option is chosen. Authentication of deposit(s) by agents ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ When the agent connects to a repository via HTTPS requests, it checks that the repository certificate is valid and that it comes from a trusted certification authority. When installing the agent, you choose to use: * The system certificate store. * Or a WAPT-specific store stored in the \ssl\server folder (certificate pinning). For the purposes of the evaluation, this second option is chosen. SF2. Identification, authentication and access control ------------------------------------------------------ Initial WAPT Agent registration ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ To exist in the database and thus appear in the WAPT Console, a machine must register with the WAPT Server using the **register** command. The **register** action is performed automatically when the WAPT Agent is installed or updated, if the machine is correctly registered with a Kerberos machine account in the organization's Active Directory domain. If the machine does not present the WAPT Server with a valid kerberos ticket, then the **register** action fails before requiring database access. During registration, the client station generates an RSA key pair in the local private directory and sends the server a certificate signature request with the kerberos ticket. If the Kerberos ticket is valid, the WAPT Server registers the WAPT Agent in its database, signs the CSR (Certificate Signing Request), stores the certificate in its database and sends the signed certificate back to the WAPT Agent. If a WAPT Agent is already registered, it can re-register without a kerberos ticket, using the signed certificate of its current server. If kerberos authentication fails or is unavailable, the Nginx server sends an unauthorized status, and the client asks the Local Administrator to enter the credentials of a WAPT Server account with the admin or register_host privilege. This account is defined on the WAPT Server locally, or authenticated by an LDAP / Active Directory directory. **Note:** The Kerberos method assumes that the Active Directory server responds at the time of registration. Local actions on agents ^^^^^^^^^^^^^^^^^^^^^^^ The workstation User can interact with the WAPT Agent through local HTTP actions. The User is identified by his username, which determines the properties of his local session. User actions (installations, uninstallations, package updates) are authenticated by the local service using a token deposited in the personal directory associated with the User's session. Access to actions is conditional on the User's account belonging to local system security groups (see self-service rules defined by a self-service package). Business administrator authentication on the WAPT Console ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The HTTPS connection from the management console to the server is first authenticated by the Business Administrator's client certificate. The initial login request is authenticated by the Business Administrator's **kerberos** session ticket. It is used to retrieve a session token that will authenticate subsequent requests. The WAPT ACLs associated with the Business Administrator's account determine the server's accessible functions. They are intended to facilitate organization and are not considered a security feature. SF3. Data protection -------------------- Access to WAPT Agent installation directory ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The **** installation directory (**C:\Program Files (x86)\wapt** by default) is readable and editable: * Local Administrators through local access to the WAPT Agent installation directory. * Business administrators through the WAPT Agent update deployment mechanism. Users do not have write access to the WAPT Agent installation directory. Access restrictions to the **** folder are based on the operating system's standard ACL mechanism and are applied during WAPT Agent installation. Access to the /private storage directory ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The **/private** directory (**C:\Program Files (x86)\wapt/private** by default) contains: * The private key/certificate pair identifying the agent to the server. * Persistent package data in the **/private/persistent** subdirectory. No access rights to the directory are granted to any User. Only the WAPT Agent and Local Administrators have read and write access to this directory. Access restrictions to the **/private** folder are based on the operating system's standard ACL mechanism and are applied during WAPT Agent installation. Access to the administrator's private key/certificate pair for the role ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The private key must be stored by the Business Administrator in a folder that only he or she can browse, and which he or she considers secure. When keys are generated by the console, it is suggested that they be stored in the Business Administrator's personal directory in a /private folder. The key is encrypted by a key derived from a strong password supplied by the Business Administrator. SF4. Cryptographic functions: Authenticity and integrity -------------------------------------------------------- Signature of control file attributes ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ A package's metadata (attributes) are defined in a package text file called **control**. A checksum of all the attributes in the **control** file is generated, then signed by the package developer's private key. The signature is added to the **control** file. When updating available packages, the agent is thus able to check that the package Developer's certificate comes from an authority present in its local **/ssl** directory. The public key is used to verify the signature of the packet's attributes and authenticate it. The checksum signature verifies the integrity of the **control** file. Signing WAPT packets ^^^^^^^^^^^^^^^^^^^^ Packages are ZIP archives. When the package is signed, a **manifest** file is generated containing the list of files in the archive, along with the checksum for each file. The checksum of this **manifest** file is signed by the package developer's private key. The agent is thus able to check that the Package Developer's certificate comes from an authority present in its local **/ssl** directory. The public key is used to verify the **manifest** file signature and authenticate the packet. The **manifest** file's file list and checksums are used to verify the integrity of the files making up the WAPT packet. Signature of actions sent to WAPT Agents ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ An action is defined by a set of properties encoded in JSON by the WAPT Console. A checksum of the JSON data is generated, then signed by the Administrator's private key. The signature is added to the JSON data. When the action is received, the agent is thus able to check that the certificate that signed the action comes from an authority present in its local **/ssl** directory. The public key is used to verify the action's signature and authenticate it. The checksum signature verifies the integrity of the action. SF5. Tamper protection ---------------------- All binaries distributed by WAPT: the installer and included binaries are signed by Tranquil IT, with an EV Code-Signing certificate issued by an authority recognized by Microsoft. During updates, the signature of the agent installer is verified by the waptdeploy utility. The fingerprint of the signing certificate must be part of the list of Tranquil IT certificates compiled in waptdeploy. waptdeploy also checks that the fingerprint of the downloaded installer matches the one supplied as an argument (argument --hash). The --hash argument is stored in a GPO, so can only be modified by an organization administrator. If a user uses self-service to uninstall a WAPT package imposed by a business administrator, the package will be reinstalled the next time the system is updated (by shutting down or taking explicit action). SF6. Logging ------------ The agent, WAPT Server and NGINX https server processes generate traces of their respective operations in text files protected for reading and writing by file system ACLs. The WAPT administration console does not log anything on its own; it merely queries the WAPT Server. The latest status of each installed package is stored in a local agent database, write-protected by the file system's ACLs. This data is sent to the WAPT Server and stored in a PostgreSQL database, access to which is restricted to the "wapt" account, owner of the WAPT Server process. When the agent sends its logs to the WAPT Server, it signs them with its private key. The server process verifies the authenticity and integrity of this data using the agent's certificate/public key stored in the server database. This information can be accessed via the administration console. However, you must have the admin or view role on the server to access it. Functions not evaluated ----------------------- The functions listed below are active in the product version delivered for evaluation, but will not be evaluated: * Functional restrictions linked to WAPT ACLs (evaluation is carried out with an account that has the admin ACL, i.e. full rights). This element is essentially organizational. Disabled functions ------------------ The functions listed below require configuration to operate. Specific documentation is available if these functions are not implemented. These functions are: * WADS (initial deployment of workstations, Microsoft MDT equivalent). * WAPT Windows Updates (Microsoft WSUS equivalent). * Secondary deposits. * Peercache. ************** Cover matrices ************** Threats and sensitive assets ============================ The following matrix shows the coverage of threats to sensitive assets (the letters **D, I, C** and **A** stand for **Availability, Integrity, Confidentiality and Authenticity respectively**). .. list-table:: Threat coverage of sensitive assets :header-rows: 1 :widths: auto :align: center * - - B1 WAPT packages - B2 Actions triggered on the client workstation from the console - B3. Cryptographic hardware - B4. Communications - B5. Inventory data - B6. The newspapers - B7. Configuration values - B8. WAPT executables installed - B9. Host system * - T01. Installation of a corrupt package - - - D,I,C,A - I,C - - - - I - D,I,C,A * - T02. Alteration of configuration values - - - D,I,C,A - - - - I, D - - * - T03. Illegitimate access - D - - C - - I,C - D - I,C - I - * - T04. Network listening - - - C - C - C - - - - * - T05. Network traffic alteration (Man In the Middle type) - D,I - - C - D - D - - - - * - T06. Log alteration - - - - - - I, A, D - - - * - T07. Cryptographic hardware recovery - D,I,C,A - D,I,C,A - D,I,C,A - D,I,C,A - D,I,C,A - D,I,C,A - D,I,C,A - D,I,C,A - D,I,C,A * - T08. Alteration of cryptographic hardware - D,I,C,A - D,I,C,A - D,I,C,A - D,I,C,A - D,I,C,A - D,I,C,A - D,I,C,A - D,I,C,A - D,I,C,A * - T09. Denial of service - - - - D - D - D - - - D * - T10. Alteration or sending of an unwanted action on the workstation - - - I,A - - - - I - - D,I * - T11. Elevation of workstation privileges - - - - C,I - I - I - I - D,I,C,A - D,I,C,A Threats and security functions ============================== .. list-table:: Threat coverage by security functions :header-rows: 1 :widths: auto :align: center * - - SF1. Secure communications - SF2. Identification, authentication and access control - SF3. Data protection - SF4. Cryptographic functions: Authenticity and integrity - SF5. Tamper protection - SF6. Logging * - T01. Installation of a corrupt package - - - X - X - - * - T02. Alteration of configuration values - - X - X - X - - * - T03. Illegitimate access - - X - - X - - * - T04. Network listening - X - - - - - * - T05. Network traffic alteration (Man In the Middle type) - X - - - - - * - T06. Log alteration - X - - - X - - X * - T07. Cryptographic hardware recovery - - - X - X - - * - T08. Alteration of cryptographic hardware - - - X - - - * - T09. Denial of service - - X - X - - - * - T10. Alteration or sending of an unwanted action on the workstation - X - - X - X - - * - T11. Elevation of workstation privileges - - - - - X -