Skip to content

Commit

Permalink
feat: add wallet migration to askar
Browse files Browse the repository at this point in the history
Signed-off-by: Ondrej Prazak <[email protected]>
  • Loading branch information
Ondrej Prazak committed Mar 13, 2024
1 parent c2bbc5f commit ef0638a
Show file tree
Hide file tree
Showing 47 changed files with 1,376 additions and 1,204 deletions.
26 changes: 22 additions & 4 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -100,7 +100,8 @@ jobs:
runs-on: ubuntu-20.04
strategy:
matrix:
wallet: ["vdrtools_wallet", "askar_wallet"]
main_wallet: ["main_vdrtools_wallet,vdrtools_wallet", "main_askar_wallet,askar_wallet"]
target_wallet: ["target_vdrtools_wallet,vdrtools_wallet", "target_askar_wallet,askar_wallet"]
steps:
- name: "Git checkout"
uses: actions/checkout@v3
Expand All @@ -115,8 +116,8 @@ jobs:
sudo apt-get update -y
sudo apt-get install -y libsodium-dev libssl-dev libzmq3-dev
sudo snap install --edge --classic just
- name: "Verify clippy across the entire workspace with default features"
run: just clippy-workspace ${{ matrix.wallet }}
- name: "Verify clippy across the entire workspace"
run: just clippy-workspace ${{ matrix.main_wallet }} ${{ matrix.target_wallet }}

aries_vcx_clippy:
runs-on: ubuntu-20.04
Expand Down Expand Up @@ -277,6 +278,23 @@ jobs:
- name: "Run workspace unit tests"
run: just test-unit

test-wallet-migrator:
needs: workflow-setup
runs-on: ubuntu-20.04
steps:
- name: "Git checkout"
uses: actions/checkout@v3
- name: "Setup rust testing environment"
uses: ./.github/actions/setup-testing-rust
with:
rust-toolchain-version: ${{ env.RUST_TOOLCHAIN_VERSION }}
default: true
skip-docker-setup: true
- name: "Install just"
run: sudo snap install --edge --classic just
- name: "Run wallet migration tests"
run: just test-wallet-migrator

test-intergation-aries-vcx-core:
needs: workflow-setup
runs-on: ubuntu-20.04
Expand Down Expand Up @@ -399,7 +417,7 @@ jobs:
runs-on: ubuntu-20.04
strategy:
matrix:
wallet: ["vdrtools_wallet", "askar_wallet"]
wallet: ["main_vdrtools_wallet,target_askar_wallet", "main_askar_wallet,target_askar_wallet"]
steps:
- name: "Git checkout"
uses: actions/checkout@v3
Expand Down
44 changes: 44 additions & 0 deletions Cargo.lock

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

4 changes: 2 additions & 2 deletions aries/aries_vcx_core/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -13,12 +13,12 @@ vdr_proxy_ledger = ["credx", "dep:indy-vdr-proxy-client"]
# Feature flag to allow legacy proof verification
legacy_proof = []

askar_wallet = ["dep:aries-askar", "dep:bs58"]
askar_wallet = ["dep:aries-askar"]

[dependencies]
agency_client = { path = "../misc/legacy/agency_client" }
aries-askar = { version = "=0.3.0", optional = true }
bs58 = { version = "0.5", optional = true }
bs58 = { version = "0.5" }
indy-vdr = { git = "https://github.com/hyperledger/indy-vdr.git", rev = "c143268", default-features = false, features = ["log"] }
indy-credx = { git = "https://github.com/hyperledger/indy-shared-rs", tag = "v1.1.0", optional = true }
# anoncreds = { git = "https://github.com/hyperledger/anoncreds-rs", tag = "v0.2.0-dev.5", optional = true }
Expand Down
10 changes: 10 additions & 0 deletions aries/aries_vcx_core/src/wallet/agency_client_wallet.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ use super::{
did_data::DidData,
did_wallet::DidWallet,
issuer_config::IssuerConfig,
key_value::KeyValue,
record::{AllRecords, Record},
record_category::RecordCategory,
record_wallet::RecordWallet,
Expand Down Expand Up @@ -44,6 +45,15 @@ impl BaseWallet for AgencyClientWallet {
"configure_issuer",
))
}

async fn create_key(
&self,
name: &str,
value: KeyValue,
tags: &RecordTags,
) -> VcxCoreResult<()> {
Err(unimplemented_agency_client_wallet_method("create_key"))
}
}

#[allow(unused_variables)]
Expand Down
10 changes: 4 additions & 6 deletions aries/aries_vcx_core/src/wallet/askar/askar_did_wallet.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@ use crate::{
wallet::{
base_wallet::{did_data::DidData, did_wallet::DidWallet, record_category::RecordCategory},
structs_io::UnpackMessageOutput,
utils::did_from_key,
},
};

Expand Down Expand Up @@ -112,8 +111,7 @@ impl DidWallet for AskarWallet {
let mut tx = self.transaction().await?;
if let Some(did_value) = self.find_did(&mut tx, did, RecordCategory::TmpDid).await? {
tx.remove(&RecordCategory::TmpDid.to_string(), did).await?;
tx.remove_key(&did_from_key(did_value.verkey().clone()))
.await?;
tx.remove_key(&did_value.verkey().base58()).await?;
self.update_did(
&mut tx,
did,
Expand All @@ -136,7 +134,7 @@ impl DidWallet for AskarWallet {
if let Some(key) = self
.session()
.await?
.fetch_key(&did_from_key(key.to_owned()), false)
.fetch_key(&key.base58(), false)
.await?
{
let local_key = key.load_local_key()?;
Expand All @@ -154,7 +152,7 @@ impl DidWallet for AskarWallet {
if let Some(key) = self
.session()
.await?
.fetch_key(&did_from_key(key.to_owned()), false)
.fetch_key(&key.base58(), false)
.await?
{
let local_key = key.load_local_key()?;
Expand Down Expand Up @@ -183,7 +181,7 @@ impl DidWallet for AskarWallet {
let mut session = self.session().await?;

let my_key = self
.fetch_local_key(&mut session, &did_from_key(sender_verkey))
.fetch_local_key(&mut session, &sender_verkey.base58())
.await?;
enc_key.pack_authcrypt(recipient_keys, my_key)?
} else {
Expand Down
32 changes: 7 additions & 25 deletions aries/aries_vcx_core/src/wallet/askar/askar_utils.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,20 +7,17 @@ use serde::Deserialize;

use crate::{
errors::error::{AriesVcxCoreErrorKind, VcxCoreResult},
wallet::{askar::AriesVcxCoreError, utils::random_seed},
wallet::{
askar::AriesVcxCoreError, base_wallet::base58_string::Base58String, utils::random_seed,
},
};

pub fn local_key_to_bs58_name(local_key: &LocalKey) -> VcxCoreResult<String> {
let res = local_key_to_bs58_public_key(local_key)?;
Ok(res[0..16].to_string())
pub fn local_key_to_bs58_public_key(local_key: &LocalKey) -> VcxCoreResult<Base58String> {
Ok(Base58String::from_bytes(&local_key.to_public_bytes()?))
}

pub fn local_key_to_bs58_public_key(local_key: &LocalKey) -> VcxCoreResult<String> {
Ok(bs58::encode(local_key.to_public_bytes()?).into_string())
}

pub fn local_key_to_bs58_private_key(local_key: &LocalKey) -> VcxCoreResult<String> {
Ok(bs58::encode(local_key.to_secret_bytes()?).into_string())
pub fn local_key_to_bs58_private_key(local_key: &LocalKey) -> VcxCoreResult<Base58String> {
Ok(Base58String::from_bytes(&local_key.to_secret_bytes()?))
}

pub fn local_key_to_public_key(local_key: &LocalKey) -> VcxCoreResult<Key> {
Expand All @@ -46,21 +43,6 @@ pub fn from_json_str<T: for<'a> Deserialize<'a>>(json: &str) -> VcxCoreResult<T>
.map_err(|err| AriesVcxCoreError::from_msg(AriesVcxCoreErrorKind::InvalidJson, err))
}

pub fn bytes_to_bs58(bytes: &[u8]) -> String {
bs58::encode(bytes).into_string()
}

pub fn bs58_to_bytes(key: &[u8]) -> VcxCoreResult<Vec<u8>> {
bs58::decode(key)
.into_vec()
.map_err(|err| AriesVcxCoreError::from_msg(AriesVcxCoreErrorKind::WalletError, err))
}

pub fn bytes_to_string(vec: Vec<u8>) -> VcxCoreResult<String> {
String::from_utf8(vec)
.map_err(|err| AriesVcxCoreError::from_msg(AriesVcxCoreErrorKind::InvalidInput, err))
}

pub fn value_from_entry(entry: Entry) -> VcxCoreResult<String> {
Ok(std::str::from_utf8(&entry.value)
.map_err(|err| AriesVcxCoreError::from_msg(AriesVcxCoreErrorKind::WalletError, err))?
Expand Down
13 changes: 0 additions & 13 deletions aries/aries_vcx_core/src/wallet/askar/key_value.rs

This file was deleted.

26 changes: 22 additions & 4 deletions aries/aries_vcx_core/src/wallet/askar/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,15 @@ use async_trait::async_trait;
use public_key::Key;

use self::{
askar_utils::local_key_to_bs58_name, askar_wallet_config::AskarWalletConfig,
askar_utils::local_key_to_bs58_public_key, askar_wallet_config::AskarWalletConfig,
rng_method::RngMethod,
};
use super::base_wallet::{did_value::DidValue, record_category::RecordCategory, BaseWallet};
use super::{
base_wallet::{
did_value::DidValue, key_value::KeyValue, record_category::RecordCategory, BaseWallet,
},
record_tags::RecordTags,
};
use crate::errors::error::{AriesVcxCoreError, AriesVcxCoreErrorKind, VcxCoreResult};

mod all_askar_records;
Expand All @@ -22,7 +27,6 @@ pub mod askar_wallet_config;
mod entry;
mod entry_tags;
pub mod key_method;
mod key_value;
mod pack;
mod packing_types;
mod partial_record;
Expand All @@ -45,6 +49,20 @@ impl BaseWallet for AskarWallet {
async fn close_wallet(&self) -> VcxCoreResult<()> {
todo!()
}

async fn create_key(
&self,
name: &str,
value: KeyValue,
tags: &RecordTags,
) -> VcxCoreResult<()> {
let mut session = self.session().await?;
let tg: Vec<_> = tags.clone().into();
let key = LocalKey::from_secret_bytes(KeyAlg::Ed25519, &value.signkey().decode()?[0..32])?;
Ok(session
.insert_key(name, &key, None, Some(&tg), None)
.await?)
}
}

impl AskarWallet {
Expand Down Expand Up @@ -112,7 +130,7 @@ impl AskarWallet {
rng_method: RngMethod,
) -> Result<(String, LocalKey), AriesVcxCoreError> {
let key = LocalKey::from_seed(alg, seed, rng_method.into())?;
let key_name = local_key_to_bs58_name(&key)?;
let key_name = local_key_to_bs58_public_key(&key)?.into_inner();
session
.insert_key(&key_name, &key, None, None, None)
.await?;
Expand Down
12 changes: 9 additions & 3 deletions aries/aries_vcx_core/src/wallet/askar/pack.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,18 @@ use aries_askar::kms::{
use public_key::Key;

use super::{
askar_utils::{bs58_to_bytes, bytes_to_bs58, ed25519_to_x25519},
askar_utils::ed25519_to_x25519,
packing_types::{
Base64String, Jwe, JweAlg, ProtectedData, ProtectedHeaderEnc, ProtectedHeaderTyp, Recipient,
Jwe, JweAlg, ProtectedData, ProtectedHeaderEnc, ProtectedHeaderTyp, Recipient,
},
};
use crate::{
errors::error::{AriesVcxCoreError, AriesVcxCoreErrorKind, VcxCoreResult},
wallet::{
base_wallet::base64_string::Base64String,
utils::{bs58_to_bytes, bytes_to_bs58},
},
};
use crate::errors::error::{AriesVcxCoreError, AriesVcxCoreErrorKind, VcxCoreResult};

fn check_supported_key_alg(key: &LocalKey) -> VcxCoreResult<()> {
let supported_algs = vec![Ed25519];
Expand Down
Loading

0 comments on commit ef0638a

Please sign in to comment.