Solana Connector
This connector supports SVM compatible EOA accounts such as Phantom and Backpack.
predicate;
use std::{
    crypto:: {
        signature::Signature,
        ed25519::Ed25519,
        message::Message,
        public_key::PublicKey,
    },
    b512::B512,
    hash::{
        Hash,
        sha256,
    },
    ecr::{
        EcRecoverError,
        ed_verify,
    },
    tx::{
        tx_id,
        tx_witness_data,
    },
    bytes::Bytes,
};
const ASCII_MAP: [u8; 16] = [
    48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 97, 98, 99, 100, 101, 102
];
pub fn b256_to_ascii_bytes(val: b256) -> Bytes {
    let bytes = Bytes::from(val);
    let mut ascii_bytes = Bytes::with_capacity(64);
    let mut idx = 0;
    while idx < 32 {
        let b = bytes.get(idx).unwrap();
        ascii_bytes.push(ASCII_MAP[(b >> 4).as_u64()]);
        ascii_bytes.push(ASCII_MAP[(b & 15).as_u64()]);
	    idx = idx + 1;
    }
    ascii_bytes
}
configurable {
    SIGNER: b256 = b256::zero(),
}
fn main(witness_index: u64) -> bool {
    let witness_signature: B512 = tx_witness_data(witness_index).unwrap();
    let encoded = b256_to_ascii_bytes(tx_id());
    let signature = Signature::Ed25519(Ed25519::from(witness_signature));
    let pub_key = PublicKey::from(SIGNER);
    let message = Message::from(encoded);
    let result = signature.verify(pub_key, message);
    if result.is_ok() {
        return true;
    }
    // Otherwise, an invalid signature has been passed and we invalidate the Tx.
    false
}