Skip to content

Commit

Permalink
generate secret from OS
Browse files Browse the repository at this point in the history
Signed-off-by: ozkanonur <work@onurozkan.dev>
  • Loading branch information
onur-ozkan committed Apr 11, 2023
1 parent 9bf8d32 commit 9e998ce
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 7 deletions.
14 changes: 10 additions & 4 deletions mm2src/coins/tendermint/tendermint_coin.rs
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,6 @@ use mm2_number::MmNumber;
use parking_lot::Mutex as PaMutex;
use primitives::hash::H256;
use prost::{DecodeError, Message};
use rand::{thread_rng, Rng};
use rpc::v1::types::Bytes as BytesJson;
use serde_json::{self as json, Value as Json};
use std::collections::HashMap;
Expand Down Expand Up @@ -1461,7 +1460,11 @@ impl TendermintCoin {
amount: BigDecimal,
) -> TradePreimageResult<TradeFee> {
const TIME_LOCK: u64 = 1750;
let sec: [u8; 32] = thread_rng().gen();

let mut sec = [0u8; 32];
common::os_rng(&mut sec);
drop_mutability!(sec);

let to_address = account_id_from_pubkey_hex(&self.account_prefix, DEX_FEE_ADDR_PUBKEY)
.map_err(|e| MmError::new(TradePreimageError::InternalError(e.into_inner().to_string())))?;

Expand Down Expand Up @@ -2627,7 +2630,6 @@ pub mod tendermint_coin_tests {
use common::{block_on, DEX_FEE_ADDR_RAW_PUBKEY};
use cosmrs::proto::cosmos::tx::v1beta1::{GetTxRequest, GetTxResponse, GetTxsEventResponse};
use crypto::privkey::key_pair_from_seed;
use rand::{thread_rng, Rng};
use std::mem::discriminant;

pub const IRIS_TESTNET_HTLC_PAIR1_SEED: &str = "iris test seed";
Expand Down Expand Up @@ -2731,7 +2733,11 @@ pub mod tendermint_coin_tests {
const UAMOUNT: u64 = 1;
let amount: cosmrs::Decimal = UAMOUNT.into();
let amount_dec = big_decimal_from_sat_unsigned(UAMOUNT, coin.decimals);
let sec: [u8; 32] = thread_rng().gen();

let mut sec = [0u8; 32];
common::os_rng(&mut sec);
drop_mutability!(sec);

let time_lock = 1000;

let create_htlc_tx = coin
Expand Down
4 changes: 4 additions & 0 deletions mm2src/common/common.rs
Original file line number Diff line number Diff line change
Expand Up @@ -138,6 +138,7 @@ use futures01::{future, Future};
use http::header::CONTENT_TYPE;
use http::Response;
use parking_lot::{Mutex as PaMutex, MutexGuard as PaMutexGuard};
use rand::RngCore;
use rand::{rngs::SmallRng, SeedableRng};
use serde::{de, ser};
use serde_json::{self as json, Value as Json};
Expand Down Expand Up @@ -745,6 +746,9 @@ pub fn writeln(line: &str) {

pub fn small_rng() -> SmallRng { SmallRng::seed_from_u64(now_ms()) }

#[inline(always)]
pub fn os_rng(dest: &mut [u8]) { rand::rngs::OsRng.fill_bytes(dest); }

#[derive(Debug, Clone)]
/// Ordered from low to height inclusive range.
pub struct OrdRange<T>(RangeInclusive<T>);
Expand Down
8 changes: 5 additions & 3 deletions mm2src/mm2_main/src/lp_swap/maker_swap.rs
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,6 @@ use mm2_err_handle::prelude::*;
use mm2_number::{BigDecimal, MmNumber};
use parking_lot::Mutex as PaMutex;
use primitives::hash::{H256, H264};
use rand::Rng;
use rpc::v1::types::{Bytes as BytesJson, H256 as H256Json, H264 as H264Json};
use std::any::TypeId;
use std::path::PathBuf;
Expand Down Expand Up @@ -238,8 +237,11 @@ impl MakerSwap {
#[inline]
fn r(&self) -> RwLockReadGuard<MakerSwapMut> { self.mutable.read().unwrap() }

#[inline]
pub fn generate_secret() -> [u8; 32] { rand::thread_rng().gen() }
pub fn generate_secret() -> [u8; 32] {
let mut sec = [0u8; 32];
common::os_rng(&mut sec);
sec
}

#[inline]
fn secret_hash(&self) -> Vec<u8> {
Expand Down

0 comments on commit 9e998ce

Please sign in to comment.