Add documentation for crypto-related classes.

Add documentation for Crypto, CryptoKey, HashingContext, and
X509Certificate.
Add documentation for `StreamPeerSSL.accept_peer`.

Ref #29871.
This commit is contained in:
Fabio Alessandrelli 2019-09-23 18:16:41 +02:00
parent 46f909f8af
commit a20cbf2cca
5 changed files with 72 additions and 1 deletions

View file

@ -1,8 +1,27 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="Crypto" inherits="Reference" category="Core" version="3.2"> <class name="Crypto" inherits="Reference" category="Core" version="3.2">
<brief_description> <brief_description>
Access to advanced cryptographic functionalities.
</brief_description> </brief_description>
<description> <description>
The Crypto class allows you to access some more advanced cryptographic functionalities in Godot.
For now, this includes generating cryptographically secure random bytes, and RSA keys and self-signed X509 certificates generation. More functionalities are planned for future releases.
[codeblock]
extends Node
var crypto = Crypto.new()
var key = CryptoKey.new()
var cert = X509Certificate.new()
func _ready():
# Generate new RSA key.
key = crypto.generate_rsa(4096)
# Generate new self-signed certificate with the given key.
cert = crypto.generate_self_signed_certificate(key, "CN=mydomain.com,O=My Game Company,C=IT")
# Save key and certificate in the user folder.
key.save("user://generated.key")
cert.save("user://generated.crt")
[/codeblock]
</description> </description>
<tutorials> <tutorials>
</tutorials> </tutorials>
@ -13,12 +32,14 @@
<argument index="0" name="size" type="int"> <argument index="0" name="size" type="int">
</argument> </argument>
<description> <description>
Generates a [PoolByteArray] of cryptographically secure random bytes with given [code]size[/code].
</description> </description>
</method> </method>
<method name="generate_rsa"> <method name="generate_rsa">
<return type="CryptoKey"> <return type="CryptoKey">
</return> </return>
<argument index="0" name="size" type="int"> <argument index="0" name="size" type="int">
Generates an RSA [CryptoKey] that can be used for creating self-signed certificates and passed to [method StreamPeerSSL.acccept_stream].
</argument> </argument>
<description> <description>
</description> </description>
@ -35,6 +56,15 @@
<argument index="3" name="not_after" type="String" default="&quot;20340101000000&quot;"> <argument index="3" name="not_after" type="String" default="&quot;20340101000000&quot;">
</argument> </argument>
<description> <description>
Generates a self-signed [X509Certificate] from the given [CryptoKey] and [code]issuer_name[/code]. The certificate validity will be defined by [code]not_before[/code] and [code]not_after[/code] (first valid date and last valid date). The [code]issuer_name[/code] must contain at least "CN=" (common name, i.e. the domain name), "O=" (organization, i.e. your company name), "C=" (country, i.e. 2 lettered ISO-3166 code of the country the organization is based in).
A small example to generate an RSA key and a X509 self-signed certificate.
[codeblock]
var crypto = Crypto.new()
# Generate 4096 bits RSA key.
var key = crypto.generate_rsa(4096)
# Generate self-signed certificate using the given key.
var cert = crypto.generate_self_signed_certificate(key, "CN=example.com,O=A Game Company,C=IT")
[/codeblock]
</description> </description>
</method> </method>
</methods> </methods>

View file

@ -1,8 +1,11 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="CryptoKey" inherits="Resource" category="Core" version="3.2"> <class name="CryptoKey" inherits="Resource" category="Core" version="3.2">
<brief_description> <brief_description>
A cryptographic key (RSA).
</brief_description> </brief_description>
<description> <description>
The CryptoKey class represents a cryptographic key. Keys can be loaded and saved like any other [Resource].
They can be used to generate a self-signed [X509Certificate] via [method Crypto.generate_self_signed] and as private key in [method StreamPeerSSL.accept_stream] along with the appropriate certificate.
</description> </description>
<tutorials> <tutorials>
</tutorials> </tutorials>
@ -13,6 +16,7 @@
<argument index="0" name="path" type="String"> <argument index="0" name="path" type="String">
</argument> </argument>
<description> <description>
Loads a key from [code]path[/code] ("*.key" file).
</description> </description>
</method> </method>
<method name="save"> <method name="save">
@ -21,6 +25,7 @@
<argument index="0" name="path" type="String"> <argument index="0" name="path" type="String">
</argument> </argument>
<description> <description>
Saves a key to the given [code]path[/code] (should be a "*.key" file).
</description> </description>
</method> </method>
</methods> </methods>

View file

@ -1,8 +1,32 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="HashingContext" inherits="Reference" category="Core" version="3.2"> <class name="HashingContext" inherits="Reference" category="Core" version="3.2">
<brief_description> <brief_description>
Context to compute cryptographic hashes over multiple iterations.
</brief_description> </brief_description>
<description> <description>
The HashingContext class provides an interface for computing cryptographic hashes over multiple iterations. This is useful for example when computing hashes of big files (so you don't have to load them all in memory), network streams, and data streams in general (so you don't have to hold buffers).
The [enum HashType] enum shows the supported hashing algorithms.
[codeblock]
const CHUNK_SIZE = 1024
func hash_file(path):
var ctx = HashingContext.new()
var file = File.new()
# Start a SHA-256 context.
ctx.start(HashingContext.HASH_SHA256)
# Check that file exists.
if not file.file_exists(path):
return
# Open the file to hash.
file.open(path, File.READ)
# Update the context after reading each chunk.
while not file.eof_reached():
ctx.update(file.get_buffer(CHUNK_SIZE))
# Get the computed hash.
var res = ctx.finish()
# Print the result as hex string and array.
printt(res.hex_encode(), Array(res))
[/codeblock]
</description> </description>
<tutorials> <tutorials>
</tutorials> </tutorials>
@ -11,6 +35,7 @@
<return type="PoolByteArray"> <return type="PoolByteArray">
</return> </return>
<description> <description>
Closes the current context, and return the computed hash.
</description> </description>
</method> </method>
<method name="start"> <method name="start">
@ -19,6 +44,7 @@
<argument index="0" name="type" type="int" enum="HashingContext.HashType"> <argument index="0" name="type" type="int" enum="HashingContext.HashType">
</argument> </argument>
<description> <description>
Starts a new hash computation of the given [code]type[/code] (e.g. [constant HASH_SHA256] to start computation of a SHA-256).
</description> </description>
</method> </method>
<method name="update"> <method name="update">
@ -27,15 +53,19 @@
<argument index="0" name="chunk" type="PoolByteArray"> <argument index="0" name="chunk" type="PoolByteArray">
</argument> </argument>
<description> <description>
Updates the computation with the given [code]chunk[/code] of data.
</description> </description>
</method> </method>
</methods> </methods>
<constants> <constants>
<constant name="HASH_MD5" value="0" enum="HashType"> <constant name="HASH_MD5" value="0" enum="HashType">
Hashing algorithm: MD5.
</constant> </constant>
<constant name="HASH_SHA1" value="1" enum="HashType"> <constant name="HASH_SHA1" value="1" enum="HashType">
Hashing algorithm: SHA-1.
</constant> </constant>
<constant name="HASH_SHA256" value="2" enum="HashType"> <constant name="HASH_SHA256" value="2" enum="HashType">
Hashing algorithm: SHA-256.
</constant> </constant>
</constants> </constants>
</class> </class>

View file

@ -4,7 +4,7 @@
SSL stream peer. SSL stream peer.
</brief_description> </brief_description>
<description> <description>
SSL stream peer. This object can be used to connect to SSL servers. SSL stream peer. This object can be used to connect to an SSL server or accept a single SSL client connection.
</description> </description>
<tutorials> <tutorials>
<link>https://docs.godotengine.org/en/latest/tutorials/networking/ssl_certificates.html</link> <link>https://docs.godotengine.org/en/latest/tutorials/networking/ssl_certificates.html</link>
@ -22,6 +22,7 @@
<argument index="3" name="chain" type="X509Certificate" default="null"> <argument index="3" name="chain" type="X509Certificate" default="null">
</argument> </argument>
<description> <description>
Accepts a peer connection as a server using the given [code]private_key[/code] and providing the given [code]certificate[/code] to the client. You can pass the optional [code]chain[/code] parameter to provide additional CA chain information along with the certificate.
</description> </description>
</method> </method>
<method name="connect_to_stream"> <method name="connect_to_stream">

View file

@ -1,8 +1,11 @@
<?xml version="1.0" encoding="UTF-8" ?> <?xml version="1.0" encoding="UTF-8" ?>
<class name="X509Certificate" inherits="Resource" category="Core" version="3.2"> <class name="X509Certificate" inherits="Resource" category="Core" version="3.2">
<brief_description> <brief_description>
An X509 certificate (e.g. for SSL).
</brief_description> </brief_description>
<description> <description>
The X509Certificate class represents an X509 certificate. Certificates can be loaded and saved like any other [Resource].
They can be used as the server certificate in [StreamPeerSSL.accept_stream] (along with the proper [CryptoKey]), and to specify the only certificate that should be accepted when connecting to an SSL server via [StreamPeerSSL.connect_to_stream].
</description> </description>
<tutorials> <tutorials>
</tutorials> </tutorials>
@ -13,6 +16,7 @@
<argument index="0" name="path" type="String"> <argument index="0" name="path" type="String">
</argument> </argument>
<description> <description>
Loads a certificate from [code]path[/code] ("*.crt" file).
</description> </description>
</method> </method>
<method name="save"> <method name="save">
@ -21,6 +25,7 @@
<argument index="0" name="path" type="String"> <argument index="0" name="path" type="String">
</argument> </argument>
<description> <description>
Saves a certificate to the given [code]path[/code] (should be a "*.crt" file).
</description> </description>
</method> </method>
</methods> </methods>