2021-01-04 15:18:51 +01:00
|
|
|
// Copyright (C) 2020 Éloïs SANCHEZ.
|
|
|
|
//
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU Affero General Public License as
|
|
|
|
// published by the Free Software Foundation, either version 3 of the
|
|
|
|
// License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU Affero General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU Affero General Public License
|
|
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
#![allow(clippy::missing_safety_doc, clippy::not_unsafe_ptr_arg_deref)]
|
|
|
|
|
2021-01-09 21:12:52 +01:00
|
|
|
mod r#async;
|
2021-01-04 15:18:51 +01:00
|
|
|
mod dewif;
|
2021-01-09 21:12:52 +01:00
|
|
|
mod error;
|
2021-01-09 23:39:04 +01:00
|
|
|
mod inputs;
|
2021-01-10 22:08:54 +01:00
|
|
|
mod legacy;
|
2021-01-04 15:18:51 +01:00
|
|
|
mod mnemonic;
|
2021-01-09 23:39:04 +01:00
|
|
|
mod secret_code;
|
2021-01-04 15:18:51 +01:00
|
|
|
|
2021-01-09 21:12:52 +01:00
|
|
|
use crate::error::{DartRes, DubpError};
|
2021-01-09 23:39:04 +01:00
|
|
|
use crate::inputs::*;
|
2021-01-09 21:12:52 +01:00
|
|
|
use crate::r#async::exec_async;
|
2021-01-09 23:39:04 +01:00
|
|
|
use crate::secret_code::gen_secret_code;
|
2021-01-08 01:49:54 +01:00
|
|
|
use allo_isolate::{IntoDart, Isolate};
|
2021-01-04 15:18:51 +01:00
|
|
|
use dup_crypto::{
|
|
|
|
bases::b58::ToBase58,
|
|
|
|
dewif::{Currency, DewifReadError, ExpectedCurrency, G1_CURRENCY, G1_TEST_CURRENCY},
|
|
|
|
keys::{
|
|
|
|
ed25519::KeyPairFromSeed32Generator, KeyPair as _, KeyPairEnum, Signator as _,
|
|
|
|
Signature as _,
|
|
|
|
},
|
|
|
|
mnemonic::{Language, Mnemonic, MnemonicType},
|
|
|
|
};
|
2021-01-09 21:12:52 +01:00
|
|
|
use fast_threadpool::{ThreadPool, ThreadPoolConfig, ThreadPoolSyncHandler};
|
|
|
|
use once_cell::sync::Lazy;
|
2021-01-04 15:18:51 +01:00
|
|
|
use std::{ffi::CStr, io, os::raw};
|
|
|
|
use thiserror::Error;
|
|
|
|
|
|
|
|
#[no_mangle]
|
2021-01-09 23:39:04 +01:00
|
|
|
pub extern "C" fn change_dewif_secret_code(
|
2021-01-04 15:18:51 +01:00
|
|
|
port: i64,
|
|
|
|
currency: *const raw::c_char,
|
|
|
|
dewif: *const raw::c_char,
|
|
|
|
old_pin: *const raw::c_char,
|
2021-01-09 22:03:19 +01:00
|
|
|
member_wallet: u32,
|
2021-01-09 23:39:04 +01:00
|
|
|
secret_code_type: u32,
|
2021-01-10 15:45:55 +01:00
|
|
|
system_memory: i64,
|
2021-01-08 01:49:54 +01:00
|
|
|
) {
|
2021-01-09 21:12:52 +01:00
|
|
|
exec_async(
|
|
|
|
port,
|
|
|
|
|| {
|
|
|
|
let currency = char_ptr_to_str(currency)?;
|
|
|
|
let dewif = char_ptr_to_str(dewif)?;
|
|
|
|
let old_pin = char_ptr_to_str(old_pin)?;
|
2021-01-09 22:03:19 +01:00
|
|
|
let member_wallet = member_wallet != 0;
|
2021-01-09 23:39:04 +01:00
|
|
|
let secret_code_type = SecretCodeType::from(secret_code_type);
|
2021-01-10 15:45:55 +01:00
|
|
|
Ok((
|
|
|
|
currency,
|
|
|
|
dewif,
|
|
|
|
old_pin,
|
|
|
|
member_wallet,
|
|
|
|
secret_code_type,
|
|
|
|
system_memory,
|
|
|
|
))
|
2021-01-09 22:03:19 +01:00
|
|
|
},
|
2021-01-10 15:45:55 +01:00
|
|
|
|(currency, dewif, old_pin, member_wallet, secret_code_type, system_memory)| {
|
|
|
|
dewif::change_secret_code(
|
|
|
|
currency,
|
|
|
|
dewif,
|
|
|
|
old_pin,
|
|
|
|
member_wallet,
|
|
|
|
secret_code_type,
|
|
|
|
system_memory,
|
|
|
|
)
|
2021-01-09 21:12:52 +01:00
|
|
|
},
|
|
|
|
)
|
2021-01-04 15:18:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#[no_mangle]
|
|
|
|
pub extern "C" fn gen_dewif(
|
|
|
|
port: i64,
|
|
|
|
currency: *const raw::c_char,
|
|
|
|
language: u32,
|
|
|
|
mnemonic: *const raw::c_char,
|
2021-01-09 22:03:19 +01:00
|
|
|
member_wallet: u32,
|
2021-01-09 23:39:04 +01:00
|
|
|
secret_code_type: u32,
|
2021-01-10 15:45:55 +01:00
|
|
|
system_memory: i64,
|
2021-01-08 01:49:54 +01:00
|
|
|
) {
|
2021-01-09 21:12:52 +01:00
|
|
|
exec_async(
|
|
|
|
port,
|
|
|
|
|| {
|
|
|
|
let currency = char_ptr_to_str(currency)?;
|
2021-01-09 23:39:04 +01:00
|
|
|
let language = u32_to_language(language)?;
|
2021-01-09 21:12:52 +01:00
|
|
|
let mnemonic = char_ptr_to_str(mnemonic)?;
|
2021-01-09 22:03:19 +01:00
|
|
|
let member_wallet = member_wallet != 0;
|
2021-01-09 23:39:04 +01:00
|
|
|
let secret_code_type = SecretCodeType::from(secret_code_type);
|
|
|
|
Ok((
|
|
|
|
currency,
|
|
|
|
language,
|
|
|
|
mnemonic,
|
|
|
|
member_wallet,
|
|
|
|
secret_code_type,
|
2021-01-10 15:45:55 +01:00
|
|
|
system_memory,
|
2021-01-09 23:39:04 +01:00
|
|
|
))
|
2021-01-09 22:03:19 +01:00
|
|
|
},
|
2021-01-10 15:45:55 +01:00
|
|
|
|(currency, language, mnemonic, member_wallet, secret_code_type, system_memory)| {
|
2021-01-09 23:39:04 +01:00
|
|
|
dewif::gen_dewif(
|
|
|
|
currency,
|
|
|
|
language,
|
|
|
|
mnemonic,
|
|
|
|
member_wallet,
|
|
|
|
secret_code_type,
|
2021-01-10 15:45:55 +01:00
|
|
|
system_memory,
|
2021-01-09 23:39:04 +01:00
|
|
|
)
|
2021-01-09 21:12:52 +01:00
|
|
|
},
|
|
|
|
)
|
2021-01-04 15:18:51 +01:00
|
|
|
}
|
|
|
|
|
2021-02-06 19:52:42 +01:00
|
|
|
#[no_mangle]
|
|
|
|
pub extern "C" fn gen_dewif_from_legacy(
|
|
|
|
port: i64,
|
|
|
|
currency: *const raw::c_char,
|
|
|
|
salt: *const raw::c_char,
|
|
|
|
password: *const raw::c_char,
|
|
|
|
member_wallet: u32,
|
|
|
|
secret_code_type: u32,
|
|
|
|
system_memory: i64,
|
|
|
|
) {
|
|
|
|
exec_async(
|
|
|
|
port,
|
|
|
|
|| {
|
|
|
|
let currency = char_ptr_to_str(currency)?;
|
|
|
|
let salt = char_ptr_to_str(salt)?.to_owned();
|
|
|
|
let password = char_ptr_to_str(password)?.to_owned();
|
|
|
|
let member_wallet = member_wallet != 0;
|
|
|
|
let secret_code_type = SecretCodeType::from(secret_code_type);
|
|
|
|
Ok((
|
|
|
|
currency,
|
|
|
|
salt,
|
|
|
|
password,
|
|
|
|
member_wallet,
|
|
|
|
secret_code_type,
|
|
|
|
system_memory,
|
|
|
|
))
|
|
|
|
},
|
|
|
|
|(currency, salt, password, member_wallet, secret_code_type, system_memory)| {
|
|
|
|
legacy::gen_dewif_from_legacy(
|
|
|
|
currency,
|
|
|
|
salt,
|
|
|
|
password,
|
|
|
|
member_wallet,
|
|
|
|
secret_code_type,
|
|
|
|
system_memory,
|
|
|
|
)
|
|
|
|
},
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2021-01-04 15:18:51 +01:00
|
|
|
#[no_mangle]
|
2021-01-08 01:49:54 +01:00
|
|
|
pub extern "C" fn gen_mnemonic(port: i64, language: u32) {
|
2021-01-10 10:27:31 +01:00
|
|
|
exec_async(port, || u32_to_language(language), mnemonic::gen_mnemonic)
|
2021-01-04 15:18:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#[no_mangle]
|
|
|
|
pub extern "C" fn get_dewif_pubkey(
|
|
|
|
port: i64,
|
|
|
|
currency: *const raw::c_char,
|
|
|
|
dewif: *const raw::c_char,
|
|
|
|
pin: *const raw::c_char,
|
2021-01-08 01:49:54 +01:00
|
|
|
) {
|
2021-01-09 21:12:52 +01:00
|
|
|
exec_async(
|
|
|
|
port,
|
|
|
|
|| {
|
2021-01-09 22:03:19 +01:00
|
|
|
let currency = parse_currency(char_ptr_to_str(currency)?)?;
|
2021-01-09 21:12:52 +01:00
|
|
|
let dewif = char_ptr_to_str(dewif)?;
|
|
|
|
let pin = char_ptr_to_str(pin)?;
|
|
|
|
Ok((currency, dewif, pin))
|
|
|
|
},
|
|
|
|
|(currency, dewif, pin)| dewif::get_pubkey(currency, dewif, pin),
|
|
|
|
)
|
2021-01-04 15:18:51 +01:00
|
|
|
}
|
|
|
|
|
2021-01-10 22:08:54 +01:00
|
|
|
#[no_mangle]
|
|
|
|
pub extern "C" fn get_legacy_pubkey(
|
|
|
|
port: i64,
|
|
|
|
salt: *const raw::c_char,
|
|
|
|
password: *const raw::c_char,
|
|
|
|
) {
|
|
|
|
exec_async(
|
|
|
|
port,
|
|
|
|
|| {
|
|
|
|
let salt = char_ptr_to_str(salt)?;
|
|
|
|
let password = char_ptr_to_str(password)?;
|
|
|
|
Ok((salt, password))
|
|
|
|
},
|
|
|
|
|(salt, password)| Ok::<_, DubpError>(legacy::get_pubkey(salt, password)),
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2021-01-04 15:18:51 +01:00
|
|
|
#[no_mangle]
|
|
|
|
pub extern "C" fn mnemonic_to_pubkey(
|
|
|
|
port: i64,
|
|
|
|
language: u32,
|
|
|
|
mnemonic_phrase: *const raw::c_char,
|
2021-01-08 01:49:54 +01:00
|
|
|
) {
|
2021-01-09 21:12:52 +01:00
|
|
|
exec_async(
|
|
|
|
port,
|
|
|
|
|| {
|
2021-01-10 10:27:31 +01:00
|
|
|
let language = u32_to_language(language)?;
|
2021-01-09 21:12:52 +01:00
|
|
|
let mnemonic_phrase = char_ptr_to_str(mnemonic_phrase)?;
|
|
|
|
Ok((language, mnemonic_phrase))
|
|
|
|
},
|
|
|
|
|(language, mnemonic_phrase)| mnemonic::mnemonic_to_pubkey(language, mnemonic_phrase),
|
|
|
|
)
|
2021-01-04 15:18:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#[no_mangle]
|
|
|
|
pub extern "C" fn sign(
|
|
|
|
port: i64,
|
|
|
|
currency: *const raw::c_char,
|
|
|
|
dewif: *const raw::c_char,
|
|
|
|
pin: *const raw::c_char,
|
|
|
|
msg: *const raw::c_char,
|
2021-01-08 01:49:54 +01:00
|
|
|
) {
|
2021-01-09 21:12:52 +01:00
|
|
|
exec_async(
|
|
|
|
port,
|
|
|
|
|| {
|
|
|
|
let currency = char_ptr_to_str(currency)?;
|
|
|
|
let dewif = char_ptr_to_str(dewif)?;
|
|
|
|
let pin = char_ptr_to_str(pin)?;
|
|
|
|
let msg = char_ptr_to_str(msg)?;
|
|
|
|
Ok((currency, dewif, pin, msg))
|
|
|
|
},
|
|
|
|
|(currency, dewif, pin, msg)| dewif::sign(currency, dewif, pin, msg),
|
|
|
|
)
|
2021-01-04 15:18:51 +01:00
|
|
|
}
|
|
|
|
|
2021-01-10 22:08:54 +01:00
|
|
|
#[no_mangle]
|
|
|
|
pub extern "C" fn sign_legacy(
|
|
|
|
port: i64,
|
|
|
|
salt: *const raw::c_char,
|
|
|
|
password: *const raw::c_char,
|
|
|
|
msg: *const raw::c_char,
|
|
|
|
) {
|
|
|
|
exec_async(
|
|
|
|
port,
|
|
|
|
|| {
|
|
|
|
let salt = char_ptr_to_str(salt)?;
|
|
|
|
let password = char_ptr_to_str(password)?;
|
|
|
|
let msg = char_ptr_to_str(msg)?;
|
|
|
|
Ok((salt, password, msg))
|
|
|
|
},
|
|
|
|
|(salt, password, msg)| Ok::<_, DubpError>(legacy::sign(salt, password, msg)),
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2021-01-04 15:18:51 +01:00
|
|
|
#[no_mangle]
|
|
|
|
pub extern "C" fn sign_several(
|
|
|
|
port: i64,
|
|
|
|
currency: *const raw::c_char,
|
|
|
|
dewif: *const raw::c_char,
|
|
|
|
pin: *const raw::c_char,
|
2021-01-09 21:12:52 +01:00
|
|
|
msgs_len: u32,
|
2021-01-04 17:08:43 +01:00
|
|
|
msgs: *const *const raw::c_char,
|
2021-01-08 01:49:54 +01:00
|
|
|
) {
|
2021-01-09 21:12:52 +01:00
|
|
|
exec_async(
|
|
|
|
port,
|
|
|
|
|| {
|
|
|
|
let currency = char_ptr_to_str(currency)?;
|
|
|
|
let dewif = char_ptr_to_str(dewif)?;
|
|
|
|
let pin = char_ptr_to_str(pin)?;
|
|
|
|
let msgs = char_ptr_prt_to_vec_str(msgs, msgs_len)?;
|
|
|
|
Ok((currency, dewif, pin, msgs))
|
|
|
|
},
|
|
|
|
|(currency, dewif, pin, msgs)| dewif::sign_several(currency, dewif, pin, &msgs),
|
|
|
|
)
|
2021-01-04 15:18:51 +01:00
|
|
|
}
|