Skip to content

Commit

Permalink
feat: add get_public_keys api and code optimization
Browse files Browse the repository at this point in the history
1. add  get_public_keys api
2. remove btc_get_xpub api
3. get_extended_public_key interface removes ed25519 curve support
  • Loading branch information
xiaoguang1010 committed Mar 1, 2024
1 parent 93ba478 commit fc24d5a
Show file tree
Hide file tree
Showing 7 changed files with 268 additions and 134 deletions.
8 changes: 8 additions & 0 deletions imkey-core/ikc-proto/src/api.proto
Original file line number Diff line number Diff line change
Expand Up @@ -155,4 +155,12 @@ message PublicKeyDerivation {
string chainType = 1;
string path = 2;
string curve = 3;
}

message GetPublicKeysParam {
repeated PublicKeyDerivation derivations = 1;
}

message GetPublicKeysResult {
repeated string publicKeys = 1;
}
11 changes: 0 additions & 11 deletions imkey-core/ikc-proto/src/btc.proto
Original file line number Diff line number Diff line change
Expand Up @@ -32,14 +32,3 @@ message BtcTxOutput {
string txHash = 2;
string wtxHash = 3;
}

message BtcXpubReq {
string network = 1;
string path = 2;
}

message BtcXpubRes {
string xpub = 1;
}


14 changes: 0 additions & 14 deletions imkey-core/ikc-wallet/coin-bitcoin/src/btcapi.rs
Original file line number Diff line number Diff line change
Expand Up @@ -56,17 +56,3 @@ pub struct BtcTxOutput {
#[prost(string, tag = "3")]
pub wtx_hash: ::prost::alloc::string::String,
}
#[allow(clippy::derive_partial_eq_without_eq)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct BtcXpubReq {
#[prost(string, tag = "1")]
pub network: ::prost::alloc::string::String,
#[prost(string, tag = "2")]
pub path: ::prost::alloc::string::String,
}
#[allow(clippy::derive_partial_eq_without_eq)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct BtcXpubRes {
#[prost(string, tag = "1")]
pub xpub: ::prost::alloc::string::String,
}
12 changes: 12 additions & 0 deletions imkey-core/ikc/src/api.rs
Original file line number Diff line number Diff line change
Expand Up @@ -257,3 +257,15 @@ pub struct PublicKeyDerivation {
#[prost(string, tag = "3")]
pub curve: ::prost::alloc::string::String,
}
#[allow(clippy::derive_partial_eq_without_eq)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct GetPublicKeysParam {
#[prost(message, repeated, tag = "1")]
pub derivations: ::prost::alloc::vec::Vec<PublicKeyDerivation>,
}
#[allow(clippy::derive_partial_eq_without_eq)]
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct GetPublicKeysResult {
#[prost(string, repeated, tag = "1")]
pub public_keys: ::prost::alloc::vec::Vec<::prost::alloc::string::String>,
}
10 changes: 0 additions & 10 deletions imkey-core/ikc/src/btc_address.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,19 +5,9 @@ use crate::error_handling::Result;
use crate::message_handler::encode_message;
use bitcoin::network::constants::Network;
use coin_bitcoin::address::BtcAddress;
use coin_bitcoin::btcapi::{BtcXpubReq, BtcXpubRes};
use ikc_common::utility::network_convert;
use prost::Message;

pub fn get_btc_xpub(data: &[u8]) -> Result<Vec<u8>> {
let input: BtcXpubReq = BtcXpubReq::decode(data).expect("imkey_illegal_param");
let network = network_convert(input.network.as_ref());
let xpub = BtcAddress::get_xpub(network, input.path.as_ref())?;

let address_message = BtcXpubRes { xpub };
encode_message(address_message)
}

pub fn get_address(param: &AddressParam) -> Result<Vec<u8>> {
let network = network_convert(param.network.as_ref());
let account_path = param.path.to_string();
Expand Down
48 changes: 40 additions & 8 deletions imkey-core/ikc/src/handler.rs
Original file line number Diff line number Diff line change
@@ -1,9 +1,14 @@
use crate::api::{AccountResponse, DeriveAccountsParam, DeriveAccountsResult, DeriveSubAccountsParam, DeriveSubAccountsResult, GetExtendedPublicKeysParam, GetExtendedPublicKeysResult};
use crate::api::{
AccountResponse, DeriveAccountsParam, DeriveAccountsResult, DeriveSubAccountsParam,
DeriveSubAccountsResult, GetExtendedPublicKeysParam, GetExtendedPublicKeysResult,
GetPublicKeysParam, GetPublicKeysResult,
};
use crate::message_handler::encode_message;
use crate::Result;
use anyhow::anyhow;
use bitcoin::hashes::hex::ToHex;
use bitcoin::util::bip32::ExtendedPubKey;
use bitcoin::Network;
use coin_bch::address::BchAddress;
use coin_bitcoin::address::BtcAddress;
use coin_btc_fork::address::BtcForkAddress;
Expand All @@ -19,11 +24,10 @@ use ikc_common::curve::CurveType;
use ikc_common::path::get_account_path;
use ikc_common::utility::{
encrypt_xpub, extended_pub_key_derive, from_ss58check_with_version, get_xpub_prefix,
network_convert, to_ss58check_with_version, uncompress_pubkey_2_compress,
hex_to_bytes, network_convert, to_ss58check_with_version, uncompress_pubkey_2_compress,
};
use prost::Message;
use std::str::FromStr;
use bitcoin::Network;

pub(crate) fn derive_accounts(data: &[u8]) -> Result<Vec<u8>> {
let param: DeriveAccountsParam =
Expand Down Expand Up @@ -197,20 +201,48 @@ pub(crate) fn derive_sub_accounts(data: &[u8]) -> Result<Vec<u8>> {
pub(crate) fn get_extended_public_keys(data: &[u8]) -> Result<Vec<u8>> {
let param: GetExtendedPublicKeysParam = GetExtendedPublicKeysParam::decode(data)?;
let mut extended_public_keys = vec![];
for public_key_derivation in param.derivations.iter(){
for public_key_derivation in param.derivations.iter() {
// if "".eq(&public_key_derivation.path) || &public_key_derivation.path.split("/") { }
let extended_public_key = match public_key_derivation.curve.as_str() {
"secp256k1" => BtcAddress::get_xpub(Network::Bitcoin, public_key_derivation.path.as_str())?,
"ed25519" => SubstrateAddress::get_public_key(public_key_derivation.path.as_str(), &AddressType::Polkadot)?,
"secp256k1" => {
BtcAddress::get_xpub(Network::Bitcoin, public_key_derivation.path.as_str())?
}
_ => return Err(anyhow!("unsupported_curve_type")),
};
extended_public_keys.push(extended_public_key);
}
encode_message(GetExtendedPublicKeysResult{
extended_public_keys
encode_message(GetExtendedPublicKeysResult {
extended_public_keys,
})
}

pub(crate) fn get_public_keys(data: &[u8]) -> Result<Vec<u8>> {
let param: GetPublicKeysParam = GetPublicKeysParam::decode(data)?;
let mut public_keys = vec![];
for public_key_derivation in param.derivations.iter() {
let mut public_key = match public_key_derivation.curve.as_str() {
"secp256k1" => uncompress_pubkey_2_compress(&BtcAddress::get_pub_key(
public_key_derivation.path.as_str(),
)?),
"ed25519" => SubstrateAddress::get_public_key(
public_key_derivation.path.as_str(),
&AddressType::Polkadot,
)?,
_ => return Err(anyhow!("unsupported_curve_type")),
};
if !public_key.starts_with("0x") {
public_key = format!("0x{}", public_key);
};
let public_key = match public_key_derivation.chain_type.as_str() {
"EOS" => EosPubkey::from_pub_key(hex_to_bytes(&public_key)?.as_slice())?,
_ => public_key,
};
public_keys.push(public_key);
}

encode_message(GetPublicKeysResult { public_keys })
}

#[cfg(test)]
mod test {
use crate::api::derive_accounts_param::Derivation;
Expand Down
Loading

0 comments on commit fc24d5a

Please sign in to comment.