Skip to content

Commit

Permalink
extract offchain-message crate
Browse files Browse the repository at this point in the history
  • Loading branch information
kevinheavey committed Nov 5, 2024
1 parent a8ef164 commit 0b5e2b5
Show file tree
Hide file tree
Showing 7 changed files with 84 additions and 17 deletions.
19 changes: 18 additions & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 2 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,7 @@ members = [
"sdk/msg",
"sdk/native-token",
"sdk/nonce",
"sdk/offchain-message",
"sdk/package-metadata",
"sdk/package-metadata-macro",
"sdk/packet",
Expand Down Expand Up @@ -470,6 +471,7 @@ solana-net-utils = { path = "net-utils", version = "=2.2.0" }
solana-nohash-hasher = "0.2.1"
solana-nonce = { path = "sdk/nonce", version = "=2.2.0" }
solana-notifier = { path = "notifier", version = "=2.2.0" }
solana-offchain-message = { path = "sdk/offchain-message", version = "=2.2.0" }
solana-package-metadata = { path = "sdk/package-metadata", version = "=2.2.0" }
solana-package-metadata-macro = { path = "sdk/package-metadata-macro", version = "=2.2.0" }
solana-packet = { path = "sdk/packet", version = "=2.2.0" }
Expand Down
15 changes: 14 additions & 1 deletion programs/sbf/Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 2 additions & 1 deletion sdk/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ full = [
"digest",
"solana-pubkey/rand",
"dep:solana-keypair",
"dep:solana-offchain-message",
"dep:solana-precompile-error",
"dep:solana-presigner",
"dep:solana-seed-derivable",
Expand Down Expand Up @@ -80,7 +81,6 @@ log = { workspace = true }
memmap2 = { workspace = true, optional = true }
num-derive = { workspace = true }
num-traits = { workspace = true }
num_enum = { workspace = true }
qualifier_attr = { workspace = true, optional = true }
rand = { workspace = true, optional = true }
rand0-7 = { workspace = true, optional = true }
Expand Down Expand Up @@ -109,6 +109,7 @@ solana-inflation = { workspace = true, features = ["serde"] }
solana-instruction = { workspace = true }
solana-keypair = { workspace = true, optional = true }
solana-native-token = { workspace = true }
solana-offchain-message = { workspace = true, optional = true }
solana-packet = { workspace = true, features = ["bincode", "serde"] }
solana-precompile-error = { workspace = true, optional = true }
solana-presigner = { workspace = true, optional = true }
Expand Down
32 changes: 32 additions & 0 deletions sdk/offchain-message/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
[package]
name = "solana-offchain-message"
description = "Solana offchain message signing"
documentation = "https://docs.rs/solana-offchain-message"
version = { workspace = true }
authors = { workspace = true }
repository = { workspace = true }
homepage = { workspace = true }
license = { workspace = true }
edition = { workspace = true }

[dependencies]
num_enum = { workspace = true }
solana-hash = { workspace = true }
solana-packet = { workspace = true }
solana-pubkey = { workspace = true, optional = true }
solana-sanitize = { workspace = true }
solana-sha256-hasher = { workspace = true }
solana-signature = { workspace = true }
solana-signer = { workspace = true }

[dev-dependencies]
solana-keypair = { workspace = true }
solana-offchain-message = { path = ".", features = ["dev-context-only-utils"] }
static_assertions = { workspace = true }

[features]
dev-context-only-utils = ["verify"]
verify = ["dep:solana-pubkey", "solana-signature/verify"]

[package.metadata.docs.rs]
targets = ["x86_64-unknown-linux-gnu"]
26 changes: 13 additions & 13 deletions sdk/src/offchain_message.rs → sdk/offchain-message/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,15 +1,11 @@
//! Off-chain message container for storing non-transaction messages.
#![cfg(feature = "full")]

use {
crate::{
hash::Hash,
pubkey::Pubkey,
signature::{Signature, Signer},
},
num_enum::{IntoPrimitive, TryFromPrimitive},
solana_hash::Hash,
solana_sanitize::SanitizeError,
solana_signature::Signature,
solana_signer::Signer,
};

#[cfg(test)]
Expand Down Expand Up @@ -46,11 +42,10 @@ pub enum MessageFormat {
pub mod v0 {
use {
super::{is_printable_ascii, is_utf8, MessageFormat, OffchainMessage as Base},
crate::{
hash::{Hash, Hasher},
packet::PACKET_DATA_SIZE,
},
solana_hash::Hash,
solana_packet::PACKET_DATA_SIZE,
solana_sanitize::SanitizeError,
solana_sha256_hasher::Hasher,
};

/// OffchainMessage Version 0.
Expand Down Expand Up @@ -239,15 +234,20 @@ impl OffchainMessage {
Ok(signer.sign_message(&self.serialize()?))
}

#[cfg(feature = "verify")]
/// Verify that the message signature is valid for the given public key
pub fn verify(&self, signer: &Pubkey, signature: &Signature) -> Result<bool, SanitizeError> {
pub fn verify(
&self,
signer: &solana_pubkey::Pubkey,
signature: &Signature,
) -> Result<bool, SanitizeError> {
Ok(signature.verify(signer.as_ref(), &self.serialize()?))
}
}

#[cfg(test)]
mod tests {
use {super::*, crate::signature::Keypair, std::str::FromStr};
use {super::*, solana_keypair::Keypair, std::str::FromStr};

#[test]
fn test_offchain_message_ascii() {
Expand Down
4 changes: 3 additions & 1 deletion sdk/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,6 @@ pub mod log;
pub mod native_loader;
pub mod net;
pub mod nonce_account;
pub mod offchain_message;
pub mod poh_config;
pub mod precompiles;
pub mod program_utils;
Expand Down Expand Up @@ -122,6 +121,9 @@ pub use solana_feature_set as feature_set;
pub use solana_fee_structure as fee;
#[deprecated(since = "2.1.0", note = "Use `solana-inflation` crate instead")]
pub use solana_inflation as inflation;
#[cfg(feature = "full")]
#[deprecated(since = "2.1.0", note = "Use `solana-offchain-message` crate instead")]
pub use solana_offchain_message as offchain_message;
#[deprecated(since = "2.1.0", note = "Use `solana-packet` crate instead")]
pub use solana_packet as packet;
#[deprecated(since = "2.1.0", note = "Use `solana-program-memory` crate instead")]
Expand Down

0 comments on commit 0b5e2b5

Please sign in to comment.