#instructions #data #ed25519 #deserialize #solana #signature #offset

solana-ed25519-instruction

Deserialization for Ed25519 instruction data

3 unstable releases

0.2.1 Sep 5, 2024
0.2.0 Sep 5, 2024
0.1.0 Sep 1, 2024

#3 in #instruction


Used in solana-transaction-intros…

MIT license

7KB

Ed25519 Signature Readme

Overview

This Rust module provides a structured way to deserialize and work with Ed25519 signatures in the context of Solana's BPF programs. It allows for deserialization of signature data, extraction of public keys (signers), and retrieval of signed data, making it easier to validate and work with Ed25519 signatures on the Solana blockchain.

Features

  • Ed25519 Signature Handling: Provides a structured representation of Ed25519 signature data, including multiple signatures and their associated offsets.
  • Borsh Deserialization: Implements the BorshDeserialize trait for easy deserialization from byte streams, making it compatible with the Borsh serialization format commonly used in Solana programs.
  • Efficient Access: Provides methods to extract public keys (signers), signatures, and signed data directly from the deserialized data without additional allocations.

Example Usage

Deserialize Ed25519Signature from Bytes

use solana_program::pubkey::Pubkey;
use borsh::BorshDeserialize;

let mut input = /* some byte array containing Ed25519 signature data */;
let signature = Ed25519Signature::deserialize_reader(&mut input).unwrap();

Extract Signers and Signatures

let signer_pubkey: &Pubkey = signature.0[0].get_signer(&input_data);
let signature_data: &[u8; 64] = signature.0[0].get_signature(&input_data);

Retrieve Signed Data

let signed_data = signature.0[0].get_data(&input_data);

Details

Ed25519Signature Structure

The Ed25519Signature struct is a wrapper around a Vec<Ed25519SignatureOffsets>, where each Ed25519SignatureOffsets struct represents a single signature and its associated offsets within the instruction data.

Borsh Integration

The Ed25519Signature and related structs implement the BorshDeserialize trait, allowing them to be deserialized from a byte stream using the Borsh serialization format. This makes it easy to work with Solana programs that utilize Borsh for data serialization.

Methods

  • get_signer(&self, data: &[u8]) -> &Pubkey: Retrieves the public key (signer) associated with the signature.
  • get_signature(&self, data: &[u8]) -> &[u8; 64]: Retrieves the signature data.
  • get_data(&self, data: &[u8]) -> Vec: Retrieves the signed data.

Testing

To ensure the correctness of the deserialization and data extraction, it is recommended to write unit tests that validate the behavior of these methods with known inputs.

Example Test

#[test]
fn test_signature_extraction() {
    let mut input = /* byte array containing Ed25519 signature data */;
    let signature = Ed25519Signature::deserialize_reader(&mut input).unwrap();
    let signer = signature.0[0].get_signer(&input_data);
    assert_eq!(signer, &expected_pubkey);
}

License

This project is licensed under the MIT License. See the LICENSE file for details.

Dependencies

~12–20MB
~316K SLoC