Skip to content

An Arduino library implementing Arm's Platform Security Architecture (PSA) APIs

License

Notifications You must be signed in to change notification settings

machinefi/psa-crypto-arduino

Repository files navigation

PSACrypto Arduino Library

License GitHub release Unit Tests Arduino CI Code Formatting Release-please

PSACrypto is an Arduino library that implements the cryptography functionality of the Platform Security Architecture (PSA) API. It provides a standardized and easy-to-use interface for cryptographic operations on Arduino boards, ensuring secure communication, data integrity, and confidentiality.

PSACrypto is designed specifically for building Decentralized Infrastructure Networks (DePIN) projects.
To find more examples of DePIN projects, you can visit DePIN Scan

Features

  • Secure Key Generation: Generate secure cryptographic keys for various algorithms.
  • Hash Functions: Compute hash values using cryptographic hash functions.
  • Symmetric Encryption: Encrypt and decrypt data using symmetric encryption algorithms.
  • Asymmetric Encryption: Perform public key encryption and decryption operations.
  • Random Number Generation: Generate random numbers for secure cryptographic operations.

Installation

Arduino IDE

To install the PSACrypto library using the Arduino IDE, follow these steps:

  1. Open the Arduino IDE.
  2. Go to Sketch > Include Library > Manage Libraries.
  3. The Library Manager window will open, showing a list of available libraries.
  4. In the search bar, type "PSACrypto" and press Enter.
  5. Locate the "PSACrypto" library in the search results.
  6. Click on the library entry to open its details.
  7. Click the "Install" button to install the library.
  8. Wait for the installation process to complete.
  9. After installation, close the Library Manager window.
  10. The PSACrypto library is now installed and ready to be used.

Manual Installation

To install the PSACrypto library manually, follow these steps:

  1. Download the PSACrypto library from the GitHub repository.
  2. Extract the downloaded ZIP file.
  3. Rename the extracted folder to "PSACrypto".
  4. Move the "PSACrypto" folder to your Arduino libraries directory. The default locations are:
    • Windows: Documents\Arduino\libraries
    • Mac: Documents/Arduino/libraries
    • Linux: Arduino/libraries
  5. Restart the Arduino IDE.
  6. The PSACrypto library should now be available under Sketch > Include Library menu.
  7. You can now include the library in your Arduino sketches and use its features.

PlatformIO

To install the PSACrypto library using PlatformIO, follow these steps:

  1. Create a new PlatformIO project or open an existing one.
  2. Open the platformio.ini file located in the root of your project.
  3. Add the following line to the [env:<your_board>] section:
lib_deps =
    PSACrypto

Replace <your_board> with the target board/platform for your project (e.g., esp32, arduino_due, etc.).

  1. Save the platformio.ini file.
  2. PlatformIO will automatically install the PSACrypto library and its dependencies when you build/upload your project.

Usage

Arduino IDE

  1. Open the Arduino IDE.
  2. Go to File > Examples > PSACrypto to access the example sketches.
  3. Select an example sketch to open it.
  4. Modify the sketch as needed to fit your requirements.
  5. Upload the sketch to your Arduino board.
  6. Open the Serial Monitor to view the output.

PlatformIO

  1. Open your PlatformIO project.
  2. Navigate to the src folder.
  3. Create a new .cpp file or open an existing one.
  4. Include the PSACrypto library by adding the following line at the top of your file:
# include <PSACrypto.h>

For detailed information on using the PSACrypto library, including usage examples and API reference, please refer to the Documentation.

Compatible Hardware

The PSACrypto library has been tested and is compatible with the following hardware:

  • ESP32
  • Arduino Nano 33 IoT

Please note that the library may also work with other Arduino-compatible boards, but it has specifically been tested and verified with the above-mentioned hardware.

It's recommended to check the official documentation of your specific board or consult the manufacturer's specifications to ensure compatibility with the PSACrypto library.

Contributing

Contributions are welcome! Please follow the guidelines in CONTRIBUTING.md to contribute to this project.

License

This library is licensed under Apache License 2.0. See the LICENSE file for more information.

Credits

About

An Arduino library implementing Arm's Platform Security Architecture (PSA) APIs

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages