Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add an example of oracle data use #93

Merged
merged 5 commits into from
Nov 15, 2024
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
32 changes: 32 additions & 0 deletions examples/oracle-example/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
[package]
name = "oracle-example"
version = "0.1.0"
authors = ["Entropy Cryptography <[email protected]>"]
homepage = "https://entropy.xyz/"
license = "Unlicense"
repository = "https://github.com/entropyxyz/programs"
edition = "2021"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
JesseAbram marked this conversation as resolved.
Show resolved Hide resolved

# This is required to compile programs to a wasm module and for use in rust libs
[lib]
crate-type = ["cdylib", "rlib"]

[dependencies]
entropy-programs-core = { workspace = true }
schemars = {version = "0.8.16", optional = true}
serde = { version = "1.0", default-features = false, features = ["alloc", "derive"] }
codec = { package = "parity-scale-codec", version = "3.0.0", default-features = false }
# These are used by `cargo component`
[package.metadata.component]
package = "entropy:oracle-example"

[package.metadata.component.target]
path = "../../wit"

[package.metadata.component.dependencies]


[features]
std = ["schemars"]
85 changes: 85 additions & 0 deletions examples/oracle-example/src/lib.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
//! This example shows how to write a contrieved and basic program: checking the length of the data to be signed.

#![cfg_attr(not(feature = "std"), no_std)]

extern crate alloc;

use alloc::{string::ToString, vec::Vec};
use codec::Decode;
use entropy_programs_core::{bindgen::Error, bindgen::*, export_program, prelude::*};
use serde::{Deserialize, Serialize};
/// JSON-deserializable struct that will be used to derive the program-JSON interface.
#[cfg_attr(feature = "std", derive(schemars::JsonSchema))]
#[derive(Debug, PartialEq, Eq, Clone, Serialize, Deserialize)]
pub struct UserConfig {}

/// JSON representation of the auxiliary data
#[cfg_attr(feature = "std", derive(schemars::JsonSchema))]
#[derive(Debug, PartialEq, Eq, Clone, Serialize, Deserialize)]
pub struct AuxData {}

// TODO confirm this isn't an issue for audit
register_custom_getrandom!(always_fail);

pub struct OracleExample;

impl Program for OracleExample {
fn evaluate(
_signature_request: SignatureRequest,
_config: Option<Vec<u8>>,
oracle_data: Option<Vec<Vec<u8>>>,
) -> Result<(), Error> {
let data = oracle_data.ok_or(Error::Evaluation("No oracle data provided.".to_string()))?;
let block_number = u32::decode(&mut data[0].as_ref())
.map_err(|_| Error::Evaluation("Unable to decode oracle data".to_string()))?;
// our program just checks that the block number is greater than 100
if block_number > 100 {
return Err(Error::Evaluation("Block Number too large".to_string()));
}

Ok(())
}

/// Since we don't use a custom hash function, we can just return `None` here.
fn custom_hash(_data: Vec<u8>) -> Option<Vec<u8>> {
None
}
}

export_program!(OracleExample);

// write a test that calls evaluate and passes it the proper parameters
#[cfg(test)]
mod tests {
use super::*;
use alloc::vec;
use codec::Encode;

#[test]
fn test_should_sign() {
let signature_request = SignatureRequest {
message: "".to_string().into_bytes(),
auxilary_data: None,
};

assert!(
OracleExample::evaluate(signature_request, None, Some(vec![99u32.encode()])).is_ok()
);
}

#[test]
fn test_should_error() {
// data being checked is under 10 bytes in length
JesseAbram marked this conversation as resolved.
Show resolved Hide resolved
let signature_request = SignatureRequest {
message: "".to_string().into_bytes(),
auxilary_data: None,
};

assert_eq!(
OracleExample::evaluate(signature_request, None, Some(vec![101u32.encode()]))
.unwrap_err()
.to_string(),
"Error::Evaluation(\"Block Number too large\")"
);
}
}
Loading