:mod:`aesio` ============ .. py:module:: aesio .. autoapi-nested-parse:: AES encryption routines The `AES` module contains classes used to implement encryption and decryption. It aims to be low overhead in terms of memory. .. raw:: html

Available on these boards

.. py:data:: MODE_ECB :annotation: :int .. py:data:: MODE_CBC :annotation: :int .. py:data:: MODE_CTR :annotation: :int .. py:class:: AES(key: _typing.ReadableBuffer, mode: int = 0, iv: Optional[_typing.ReadableBuffer] = None, segment_size: int = 8) Encrypt and decrypt AES streams Create a new AES state with the given key. :param ~_typing.ReadableBuffer key: A 16-, 24-, or 32-byte key :param int mode: AES mode to use. One of: `MODE_ECB`, `MODE_CBC`, or `MODE_CTR` :param ~_typing.ReadableBuffer iv: Initialization vector to use for CBC or CTR mode Additional arguments are supported for legacy reasons. Encrypting a string:: import aesio from binascii import hexlify key = b'Sixteen byte key' inp = b'CircuitPython!!!' # Note: 16-bytes long outp = bytearray(len(inp)) cipher = aesio.AES(key, aesio.MODE_ECB) cipher.encrypt_into(inp, outp) hexlify(outp) .. py:method:: encrypt_into(src: _typing.ReadableBuffer, dest: _typing.WriteableBuffer) -> None Encrypt the buffer from ``src`` into ``dest``. For ECB mode, the buffers must be 16 bytes long. For CBC mode, the buffers must be a multiple of 16 bytes, and must be equal length. For CTX mode, there are no restrictions. .. py:method:: decrypt_into(src: _typing.ReadableBuffer, dest: _typing.WriteableBuffer) -> None Decrypt the buffer from ``src`` into ``dest``. For ECB mode, the buffers must be 16 bytes long. For CBC mode, the buffers must be a multiple of 16 bytes, and must be equal length. For CTX mode, there are no restrictions.