<?xml version="1.0" encoding="utf-8"?>
<resources>
    <string name="">SSL/TLS Certificate</string>
    <string name="">Certificate Authority</string>
    <string name="">A Certificate Authority (CA) is a trusted entity that signs digital certificates, enabling users to verify their authenticity. Rather than storing every individual certificate for each server (which would be impractical due to the sheer volume and frequent renewals), users can store a limited set of root certificates to authenticate server certificates as needed.</string>
    <string name="">Boost.Asio provides various methods for loading certificate authority certificates:</string>
    <string name="">* [@boost:/doc/html/boost_asio/reference/ssl__context/add_certificate_authority.html `net::ssl::context::add_certificate_authority`]\n* [@boost:/doc/html/boost_asio/reference/ssl__context/add_verify_path.html `net::ssl::context::add_verify_path`]\n* [@boost:/doc/html/boost_asio/reference/ssl__context/load_verify_file.html `net::ssl::context::load_verify_file`]\n* [@boost:/doc/html/boost_asio/reference/ssl__context/set_default_verify_paths.html `net::ssl::context::set_default_verify_paths`]</string>
    <string name="">It is important to set up peer verification so that the TLS/SSL handshake fails if certificate verification is unsuccessful:</string>
    <string name="">A client must also verify that the hostname or IP address in the certificate matches the expected one. The [@boost:/doc/html/boost_asio/reference/ssl__host_name_verification.html `net::ssl::host_name_verification`] helper function object can perform this verification according to the rules described in RFC 6125:</string>
    <string name="">A server can also request and verify a client certificate to authenticate the client:</string>
    <string name="">Server Certificate</string>
    <string name="">A Server Certificate is a digital certificate that confirms a server\'s identity as the legitimate destination for a client. It contains a verifiable signature that ensures it was issued by a trusted certificate authority (CA).</string>
    <string name="">When a server certificate is issued by an intermediate certificate authority, and the client lacks those intermediate certificates, the server should provide all the relevant certificates to the client. This allows the client to verify the final certificate in the chain against the root certificate.</string>
    <string name="">The following Boost.Asio methods can be used for loading a certificate or a certificate chain:</string>
    <string name="">* [@boost:/doc/html/boost_asio/reference/ssl__context/use_certificate.html `net::ssl::context::use_certificate`]\n* [@boost:/doc/html/boost_asio/reference/ssl__context/use_certificate_file.html `net::ssl::context::use_certificate_file`]\n* [@boost:/doc/html/boost_asio/reference/ssl__context/use_certificate_chain.html `net::ssl::context::use_certificate_chain`]\n* [@boost:/doc/html/boost_asio/reference/ssl__context/use_certificate_chain_file.html `net::ssl::context::use_certificate_chain_file`]</string>
    <string name="">Client Certificate</string>
    <string name="">A server can authenticate clients by requiring and verifying their certificates, preventing access for those without a valid certificate and private key. The server enforces this by modifying peer verification settings:</string>
    <string name="">If used, the necessary CA certificates must be loaded into the server\'s SSL context to enable verification of the client\'s certificate.</string>
    <string name="">Common Name and Subject Alternative Name</string>
    <string name="">The Subject Alternative Name (SAN) is an extension in X.509 certificates that allows multiple domain names, subdomains, or IP addresses to be associated with a single SSL/TLS certificate. Before that it was the Common Name field in the certificate subject which could contain a single hostname.</string>
    <string name="">recommends that if a certificate includes a SAN dNSName field, the client must ignore the subject CN field. Some modern browsers, such as Google Chrome, check only the SAN section in an SSL/TLS certificate and reject certificates that contain only the CN field.</string>
    <string name="">Private Key</string>
    <string name="">The private key of a certificate is required during the SSL/TLS handshake to prove that the certificate\'s provider is its rightful owner</string>
    <string name="">The following Boost.Asio methods can be used for loading a private key:</string>
    <string name="">* [@boost:/doc/html/boost_asio/reference/ssl__context/use_private_key.html `net::ssl::context::use_private_key`]\n* [@boost:/doc/html/boost_asio/reference/ssl__context/use_private_key_file.html `net::ssl::context::use_private_key_file`]\n* [@boost:/doc/html/boost_asio/reference/ssl__context/use_rsa_private_key.html `net::ssl::context::use_rsa_private_key`]\n* [@boost:/doc/html/boost_asio/reference/ssl__context/use_rsa_private_key_file.html `net::ssl::context::use_rsa_private_key_file`]</string>
    <string name="">If the private key is secured with a password, the [@boost:/doc/html/boost_asio/reference/ssl__context/set_password_callback.html net::ssl::context::set_password_callback] allows specifying a callable object to retrieve the password.</string>
    <string name="">Self-Signed and Self-Issued Certificates</string>
    <string name="">A self-issued certificate is a certificate where the issuer and subject are the same entity.</string>
    <string name="">A self-signed certificate is a self-issued certificate in which the digital signature can be verified using the public key within the certificate.</string>
    <string name="">Installing an untrusted, self-issued, or self-signed CA certificate poses a</string>
    <string name="">Diffie-Hellman (DH) Parameters</string>
    <string name="">Diffie-Hellman (DH) key exchange is a cryptographic protocol that allows two parties to securely establish a shared secret over an insecure communication channel. The key exchange process involves both parties agreeing on a set of parameters, known as Diffie-Hellman parameters, which include a large prime number `p` and a generator `g`. Since generating these parameters is a computationally expensive task, a user might prefer to provide a precomputed value at startup.</string>
    <string name="">The following Boost.Asio methods can be used for loading DH parameters:</string>
    <string name="">* [@boost:/doc/html/boost_asio/reference/ssl__context/use_tmp_dh.html `net::ssl::context::use_tmp_dh`]\n* [@boost:/doc/html/boost_asio/reference/ssl__context/use_tmp_dh_file.html `net::ssl::context::use_tmp_dh_file`]</string>
    <string name="">If no DH parameter is provided, OpenSSL will refuse to perform any handshake that uses DHE-based cipher suites but will still work with other cipher suites, such as those based on ECDHE.</string>
    <string name="">A Self-Issued Certificate Example</string>
    <string name="">In the following example, we will generate a self-signed CA certificate and use it to issue both server and client certificates.</string>
    <string name="">* Generate a CA certificate:</string>
    <string name="">``` openssl req -new -newkey rsa:4096 -keyout ca.key -x509 -out ca.crt -subj \"/CN=localhost\" -days 365 ```</string>
    <string name="">* Generate a Server CSR:</string>
    <string name="">``` openssl req -new -newkey rsa:4096 -keyout server.key -out server.csr -subj \"/CN=localhost\" -addext \"subjectAltName=DNS:localhost,IP:127.0.0.1\" ```</string>
    <string name="">* Sign the Server CSR using our CA:</string>
    <string name="">``` openssl x509 -req -in server.csr -CA ca.crt -CAkey ca.key -copy_extensions copy -days 365 -out server.crt ```</string>
    <string name="">* Generate a Client CSR:</string>
    <string name="">``` openssl req -new -newkey rsa:4096 -keyout client.key -out client.csr -subj \"/CN=client.1\" ```</string>
    <string name="">* Sign the Client CSR using our CA:</string>
    <string name="">``` openssl x509 -req -in client.csr -CA ca.crt -CAkey ca.key -days 365 -out client.crt ```</string>
    <string name="">* Generate a DH parameters file:</string>
    <string name="">``` openssl dhparam -out dh4096.pem 4096 ```</string>
    <string name="">Server example: [path_link example/doc/ssl/server.cpp server.cpp]</string>
    <string name="">Note that the server is configured in such a way that it requests and verifies the client certificate. You can disable this by commenting out the related line in the example.</string>
    <string name="">You can test the server using this cURL command:</string>
    <string name="">``` curl https://localhost:8080 --cacert ca.crt --cert client.crt --key client.key ```</string>
    <string name="">Also, you can use the client example: [path_link example/doc/ssl/client.cpp client.cpp]</string>
</resources>
