mirror of
https://github.com/logos-blockchain/lssa.git
synced 2026-06-28 03:49:52 +00:00
BREAKING CHANGE:
- Crate `nssa` renamed to `lee`; update `Cargo.toml` dependencies from `nssa = { workspace = true }` to `lee = { workspace = true }`.
- Crate `nssa_core` renamed to `lee_core`; update similarly.
- Crate `key_protocol` moved under `lee`; update `Cargo.toml` dependencies from `key_protocol = { workspace = true }` to `lee_key_protocol = { workspace = true }`.
- Type `NSSATransaction` (in `common`) renamed to `LeeTransaction`.
- Error type `nssa::error::NssaError` renamed to `lee::error::LeeError`.
- Error type `nssa_core::error::NssaCoreError` renamed to `lee_core::error::LeeCoreError`.
- All `use nssa::` and `use nssa_core::` import paths must be updated to `use lee::` and `use lee_core::` respectively.
- Guest programs must replace `write_nssa_outputs` with `write_lee_outputs`.
- The sequencer RocksDB column family for the chain state was renamed. Existing databases are incompatible and must be wiped before running the new version.
- Domain separators updated: `"NSSA_seed"` → `"LEE_seed"` (key derivation), `"NSSA/v0.2/KDF-SHA256/"` → `"LEE/v0.2/KDF-SHA256/"` (encryption KDF), `"/NSSA/v0.2/AccountId/PDA/"` →
`"/LEE/v0.2/AccountId/PDA/"` (public PDA address derivation). All previously derived keys, encrypted outputs, and public PDA addresses are invalidated.
54 lines
1.5 KiB
Rust
54 lines
1.5 KiB
Rust
pub use lee_core::program::PdaSeed;
|
|
use lee_core::{account::AccountId, program::ProgramId};
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
const VAULT_SEED_DOMAIN_SEPARATOR: &[u8] = b"/LEZ/v0.3/VaultSeed/00000000000/";
|
|
|
|
const _: () = assert!(
|
|
VAULT_SEED_DOMAIN_SEPARATOR.len() == 32,
|
|
"Domain separator must be exactly 32 bytes long"
|
|
);
|
|
|
|
#[derive(Serialize, Deserialize)]
|
|
pub enum Instruction {
|
|
/// Transfers native tokens from sender to recipient's vault.
|
|
///
|
|
/// Required accounts (3):
|
|
/// - Sender account
|
|
/// - Recipient account
|
|
/// - Recipient vault PDA account
|
|
Transfer {
|
|
recipient_id: AccountId,
|
|
amount: u128,
|
|
},
|
|
|
|
/// Claims native tokens from owner's vault into owner's account.
|
|
///
|
|
/// Required accounts (2):
|
|
/// - Owner account
|
|
/// - Owner vault PDA account
|
|
Claim { amount: u128 },
|
|
}
|
|
|
|
#[must_use]
|
|
pub fn compute_vault_seed(owner_id: AccountId) -> PdaSeed {
|
|
use risc0_zkvm::sha::{Impl, Sha256 as _};
|
|
|
|
let mut bytes = [0_u8; 64];
|
|
bytes[..32].copy_from_slice(VAULT_SEED_DOMAIN_SEPARATOR);
|
|
bytes[32..64].copy_from_slice(&owner_id.to_bytes());
|
|
|
|
PdaSeed::new(
|
|
Impl::hash_bytes(&bytes)
|
|
.as_bytes()
|
|
.try_into()
|
|
.expect("Hash output must be exactly 32 bytes long"),
|
|
)
|
|
}
|
|
|
|
#[must_use]
|
|
pub fn compute_vault_account_id(vault_program_id: ProgramId, owner_id: AccountId) -> AccountId {
|
|
let seed = compute_vault_seed(owner_id);
|
|
AccountId::for_public_pda(&vault_program_id, &seed)
|
|
}
|