mirror of
https://github.com/uqbar-dao/nectar.git
synced 2024-12-23 08:32:23 +03:00
register: revert salt weirdness
This commit is contained in:
parent
5bd477b050
commit
a9912e6a37
@ -25,10 +25,13 @@ pub fn encode_keyfile(
|
|||||||
routers: Vec<String>,
|
routers: Vec<String>,
|
||||||
networking_key: &[u8],
|
networking_key: &[u8],
|
||||||
jwt: &[u8],
|
jwt: &[u8],
|
||||||
salt: &[u8],
|
|
||||||
) -> Vec<u8> {
|
) -> Vec<u8> {
|
||||||
let mut disk_key: DiskKey = [0u8; CREDENTIAL_LEN];
|
let mut disk_key: DiskKey = [0u8; CREDENTIAL_LEN];
|
||||||
|
|
||||||
|
let rng = SystemRandom::new();
|
||||||
|
let mut salt = [0u8; 32]; // generate a unique salt
|
||||||
|
rng.fill(&mut salt).unwrap();
|
||||||
|
|
||||||
pbkdf2::derive(
|
pbkdf2::derive(
|
||||||
PBKDF2_ALG,
|
PBKDF2_ALG,
|
||||||
NonZeroU32::new(ITERATIONS).unwrap(),
|
NonZeroU32::new(ITERATIONS).unwrap(),
|
||||||
@ -93,16 +96,15 @@ pub fn decode_keyfile(keyfile: &[u8], password: &str) -> Result<Keyfile, &'stati
|
|||||||
routers,
|
routers,
|
||||||
networking_keypair,
|
networking_keypair,
|
||||||
jwt_secret_bytes,
|
jwt_secret_bytes,
|
||||||
salt,
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_info(keyfile: &[u8]) -> Result<(String, Vec<String>, Vec<u8>), &'static str> {
|
pub fn get_username_and_routers(keyfile: &[u8]) -> Result<(String, Vec<String>), &'static str> {
|
||||||
let (username, routers, _salt, _key_enc, _jwt_enc, password_salt) =
|
let (username, routers, _salt, _key_enc, _jwt_enc) =
|
||||||
bincode::deserialize::<(String, Vec<String>, Vec<u8>, Vec<u8>, Vec<u8>, Vec<u8>)>(keyfile)
|
bincode::deserialize::<(String, Vec<String>, Vec<u8>, Vec<u8>, Vec<u8>)>(keyfile)
|
||||||
.map_err(|_| "failed to deserialize keyfile")?;
|
.map_err(|_| "failed to deserialize keyfile")?;
|
||||||
|
|
||||||
Ok((username, routers, password_salt))
|
Ok((username, routers))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// # Returns
|
/// # Returns
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"files": {
|
"files": {
|
||||||
"main.css": "/static/css/main.dce05a4d.css",
|
"main.css": "/static/css/main.054f6f32.css",
|
||||||
"main.js": "/static/js/main.726c0750.js",
|
"main.js": "/static/js/main.431aef9a.js",
|
||||||
"static/media/unknown.png": "/static/media/unknown.880d04d4611a45ab1001.png",
|
"static/media/unknown.png": "/static/media/unknown.880d04d4611a45ab1001.png",
|
||||||
"static/media/background.jpg": "/static/media/background.01d2427cfc21fb685016.jpg",
|
"static/media/background.jpg": "/static/media/background.01d2427cfc21fb685016.jpg",
|
||||||
"static/media/kinode.svg": "/static/media/kinode.86d0c1a6a4a3ca3be41616b5989d6925.svg",
|
"static/media/kinode.svg": "/static/media/kinode.86d0c1a6a4a3ca3be41616b5989d6925.svg",
|
||||||
@ -9,7 +9,7 @@
|
|||||||
"static/media/logo.svg": "/static/media/logo.45dcb752ac5b825f5e3b9299d2210f0a.svg"
|
"static/media/logo.svg": "/static/media/logo.45dcb752ac5b825f5e3b9299d2210f0a.svg"
|
||||||
},
|
},
|
||||||
"entrypoints": [
|
"entrypoints": [
|
||||||
"static/css/main.dce05a4d.css",
|
"static/css/main.054f6f32.css",
|
||||||
"static/js/main.726c0750.js"
|
"static/js/main.431aef9a.js"
|
||||||
]
|
]
|
||||||
}
|
}
|
@ -1 +1 @@
|
|||||||
<!doctype html><html lang="en"><head><title>Welcome - Kinode</title><meta charset="utf-8"/><meta http-equiv="pragma" content="no-cache"/><meta http-equiv="cache-control" content="no-cache"/><link rel="preconnect" href="https://fonts.googleapis.com"><link rel="preconnect" href="https://fonts.gstatic.com" crossorigin><link href="https://fonts.googleapis.com/css2?family=Barlow+Condensed:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap" rel="stylesheet"><link rel="icon" href=""><meta httpequiv="X-UA-Compatible" content="IE=edge"/><meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1.00001,viewport-fit=cover"/><script defer="defer" src="/static/js/main.726c0750.js"></script><link href="/static/css/main.dce05a4d.css" rel="stylesheet"></head><body><noscript>You need to enable JavaScript to run this app.</noscript><div id="root"></div></body></html>
|
<!doctype html><html lang="en"><head><title>Welcome - Kinode</title><meta charset="utf-8"/><meta http-equiv="pragma" content="no-cache"/><meta http-equiv="cache-control" content="no-cache"/><link rel="preconnect" href="https://fonts.googleapis.com"><link rel="preconnect" href="https://fonts.gstatic.com" crossorigin><link href="https://fonts.googleapis.com/css2?family=Barlow+Condensed:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap" rel="stylesheet"><link rel="icon" href=""><meta httpequiv="X-UA-Compatible" content="IE=edge"/><meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1.00001,viewport-fit=cover"/><script defer="defer" src="/static/js/main.431aef9a.js"></script><link href="/static/css/main.054f6f32.css" rel="stylesheet"></head><body><noscript>You need to enable JavaScript to run this app.</noscript><div id="root"></div></body></html>
|
File diff suppressed because one or more lines are too long
2
kinode/src/register-ui/build/static/js/main.431aef9a.js
Normal file
2
kinode/src/register-ui/build/static/js/main.431aef9a.js
Normal file
File diff suppressed because one or more lines are too long
@ -0,0 +1,137 @@
|
|||||||
|
/*!
|
||||||
|
Copyright (c) 2015 Jed Watson.
|
||||||
|
Based on code that is Copyright 2013-2015, Facebook, Inc.
|
||||||
|
All rights reserved.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Adapted from jQuery UI core
|
||||||
|
*
|
||||||
|
* http://jqueryui.com
|
||||||
|
*
|
||||||
|
* Copyright 2014 jQuery Foundation and other contributors
|
||||||
|
* Released under the MIT license.
|
||||||
|
* http://jquery.org/license
|
||||||
|
*
|
||||||
|
* http://api.jqueryui.com/category/ui-core/
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* The buffer module from node.js, for the browser.
|
||||||
|
*
|
||||||
|
* @author Feross Aboukhadijeh <https://feross.org>
|
||||||
|
* @license MIT
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh <https://feross.org/opensource> */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @license React
|
||||||
|
* react-dom.production.min.js
|
||||||
|
*
|
||||||
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
||||||
|
*
|
||||||
|
* This source code is licensed under the MIT license found in the
|
||||||
|
* LICENSE file in the root directory of this source tree.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @license React
|
||||||
|
* react-jsx-runtime.production.min.js
|
||||||
|
*
|
||||||
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
||||||
|
*
|
||||||
|
* This source code is licensed under the MIT license found in the
|
||||||
|
* LICENSE file in the root directory of this source tree.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @license React
|
||||||
|
* react.production.min.js
|
||||||
|
*
|
||||||
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
||||||
|
*
|
||||||
|
* This source code is licensed under the MIT license found in the
|
||||||
|
* LICENSE file in the root directory of this source tree.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @license React
|
||||||
|
* scheduler.production.min.js
|
||||||
|
*
|
||||||
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
||||||
|
*
|
||||||
|
* This source code is licensed under the MIT license found in the
|
||||||
|
* LICENSE file in the root directory of this source tree.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @license React
|
||||||
|
* use-sync-external-store-shim.production.min.js
|
||||||
|
*
|
||||||
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
||||||
|
*
|
||||||
|
* This source code is licensed under the MIT license found in the
|
||||||
|
* LICENSE file in the root directory of this source tree.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @license React
|
||||||
|
* use-sync-external-store-shim/with-selector.production.min.js
|
||||||
|
*
|
||||||
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
||||||
|
*
|
||||||
|
* This source code is licensed under the MIT license found in the
|
||||||
|
* LICENSE file in the root directory of this source tree.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @remix-run/router v1.15.2
|
||||||
|
*
|
||||||
|
* Copyright (c) Remix Software Inc.
|
||||||
|
*
|
||||||
|
* This source code is licensed under the MIT license found in the
|
||||||
|
* LICENSE.md file in the root directory of this source tree.
|
||||||
|
*
|
||||||
|
* @license MIT
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* React Router DOM v6.22.2
|
||||||
|
*
|
||||||
|
* Copyright (c) Remix Software Inc.
|
||||||
|
*
|
||||||
|
* This source code is licensed under the MIT license found in the
|
||||||
|
* LICENSE.md file in the root directory of this source tree.
|
||||||
|
*
|
||||||
|
* @license MIT
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* React Router v6.22.2
|
||||||
|
*
|
||||||
|
* Copyright (c) Remix Software Inc.
|
||||||
|
*
|
||||||
|
* This source code is licensed under the MIT license found in the
|
||||||
|
* LICENSE.md file in the root directory of this source tree.
|
||||||
|
*
|
||||||
|
* @license MIT
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* [js-sha3]{@link https://github.com/emn178/js-sha3}
|
||||||
|
*
|
||||||
|
* @version 0.5.7
|
||||||
|
* @author Chen, Yi-Cyuan [emn178@gmail.com]
|
||||||
|
* @copyright Chen, Yi-Cyuan 2015-2016
|
||||||
|
* @license MIT
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* [js-sha3]{@link https://github.com/emn178/js-sha3}
|
||||||
|
*
|
||||||
|
* @version 0.8.0
|
||||||
|
* @author Chen, Yi-Cyuan [emn178@gmail.com]
|
||||||
|
* @copyright Chen, Yi-Cyuan 2015-2018
|
||||||
|
* @license MIT
|
||||||
|
*/
|
@ -233,9 +233,9 @@ pub async fn register(
|
|||||||
}
|
}
|
||||||
|
|
||||||
async fn get_unencrypted_info(keyfile: Option<Vec<u8>>) -> Result<impl Reply, Rejection> {
|
async fn get_unencrypted_info(keyfile: Option<Vec<u8>>) -> Result<impl Reply, Rejection> {
|
||||||
let (name, allowed_routers, salt) = {
|
let (name, allowed_routers) = {
|
||||||
match keyfile {
|
match keyfile {
|
||||||
Some(encoded_keyfile) => match keygen::get_info(&encoded_keyfile) {
|
Some(encoded_keyfile) => match keygen::get_username_and_routers(&encoded_keyfile) {
|
||||||
Ok(k) => k,
|
Ok(k) => k,
|
||||||
Err(_) => {
|
Err(_) => {
|
||||||
return Ok(warp::reply::with_status(
|
return Ok(warp::reply::with_status(
|
||||||
@ -255,11 +255,17 @@ async fn get_unencrypted_info(keyfile: Option<Vec<u8>>) -> Result<impl Reply, Re
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
// do we need password salt here for the FE to hash the login password?
|
// do we need password salt here for the FE to hash the login password?
|
||||||
|
println!(
|
||||||
|
"unencrypted info return: {:?}",
|
||||||
|
UnencryptedIdentity {
|
||||||
|
name: name.clone(),
|
||||||
|
allowed_routers: allowed_routers.clone(),
|
||||||
|
}
|
||||||
|
);
|
||||||
return Ok(warp::reply::with_status(
|
return Ok(warp::reply::with_status(
|
||||||
warp::reply::json(&UnencryptedIdentity {
|
warp::reply::json(&UnencryptedIdentity {
|
||||||
name,
|
name,
|
||||||
allowed_routers,
|
allowed_routers,
|
||||||
salt: base64::encode(&salt),
|
|
||||||
}),
|
}),
|
||||||
StatusCode::OK,
|
StatusCode::OK,
|
||||||
)
|
)
|
||||||
@ -267,6 +273,7 @@ async fn get_unencrypted_info(keyfile: Option<Vec<u8>>) -> Result<impl Reply, Re
|
|||||||
}
|
}
|
||||||
|
|
||||||
async fn generate_networking_info(our_temp_id: Arc<Identity>) -> Result<impl Reply, Rejection> {
|
async fn generate_networking_info(our_temp_id: Arc<Identity>) -> Result<impl Reply, Rejection> {
|
||||||
|
println!("temp ID {:?}", our_temp_id.as_ref());
|
||||||
Ok(warp::reply::json(our_temp_id.as_ref()))
|
Ok(warp::reply::json(our_temp_id.as_ref()))
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -283,6 +290,7 @@ async fn handle_keyfile_vet(
|
|||||||
let decoded_keyfile =
|
let decoded_keyfile =
|
||||||
keygen::decode_keyfile(&encoded_keyfile, &payload.password).map_err(|_| warp::reject())?;
|
keygen::decode_keyfile(&encoded_keyfile, &payload.password).map_err(|_| warp::reject())?;
|
||||||
|
|
||||||
|
println!("vetted decoded keyfile: {:?}", decoded_keyfile);
|
||||||
Ok(warp::reply::json(&KeyfileVetted {
|
Ok(warp::reply::json(&KeyfileVetted {
|
||||||
username: decoded_keyfile.username,
|
username: decoded_keyfile.username,
|
||||||
networking_key: format!(
|
networking_key: format!(
|
||||||
@ -300,44 +308,46 @@ async fn handle_boot(
|
|||||||
networking_keypair: Arc<Vec<u8>>,
|
networking_keypair: Arc<Vec<u8>>,
|
||||||
) -> Result<impl Reply, Rejection> {
|
) -> Result<impl Reply, Rejection> {
|
||||||
let mut our = our.as_ref().clone();
|
let mut our = our.as_ref().clone();
|
||||||
|
println!("bootinfo while booting: {:?}", info.clone());
|
||||||
|
println!("our while booting: {:?}", our.clone());
|
||||||
|
|
||||||
our.name = info.username;
|
our.name = info.username;
|
||||||
if info.direct {
|
if info.direct {
|
||||||
our.allowed_routers = vec![];
|
our.allowed_routers = vec![];
|
||||||
} else {
|
} else {
|
||||||
our.ws_routing = None;
|
our.ws_routing = None;
|
||||||
}
|
}
|
||||||
|
|
||||||
let jwt_seed = SystemRandom::new();
|
let jwt_seed = SystemRandom::new();
|
||||||
let mut jwt_secret = [0u8, 32];
|
let mut jwt_secret = [0u8, 32];
|
||||||
ring::rand::SecureRandom::fill(&jwt_seed, &mut jwt_secret).unwrap();
|
ring::rand::SecureRandom::fill(&jwt_seed, &mut jwt_secret).unwrap();
|
||||||
|
|
||||||
let salt = base64::decode(&info.salt).map_err(|_| warp::reject())?;
|
// let salt = base64::decode(&info.salt).map_err(|_| warp::reject())?;
|
||||||
let sig = Signature::from_base64(&info.signature).map_err(|_| warp::reject())?;
|
//let sig = Signature::from_base64(&info.signature).map_err(|_| warp::reject())?;
|
||||||
|
|
||||||
let now = SystemTime::now()
|
let now = SystemTime::now()
|
||||||
.duration_since(UNIX_EPOCH)
|
.duration_since(UNIX_EPOCH)
|
||||||
.expect("Time went backwards")
|
.expect("Time went backwards")
|
||||||
.as_secs();
|
.as_secs();
|
||||||
|
|
||||||
if info.timestamp < now + 120 {
|
// if info.timestamp < now + 120 {
|
||||||
return Ok(warp::reply::with_status(
|
// return Ok(warp::reply::with_status(
|
||||||
warp::reply::json(&"Timestamp is outdated."),
|
// warp::reply::json(&"Timestamp is outdated."),
|
||||||
StatusCode::UNAUTHORIZED,
|
// StatusCode::UNAUTHORIZED,
|
||||||
)
|
// )
|
||||||
.into_response());
|
// .into_response());
|
||||||
}
|
// }
|
||||||
|
|
||||||
// verify eth signature
|
// verify eth signature, fetch from eth?
|
||||||
let sign_data = serde_json::to_vec(&serde_json::json!({
|
// let sign_data = serde_json::to_vec(&serde_json::json!({
|
||||||
"password": info.password,
|
// "password": info.password,
|
||||||
"timestamp": info.timestamp,
|
// "timestamp": info.timestamp,
|
||||||
}))
|
// }))
|
||||||
.unwrap();
|
// .unwrap();
|
||||||
|
|
||||||
// check chain for address match...?
|
// check chain for address match...?
|
||||||
let _signer = sig
|
// let _signer = sig
|
||||||
.recover_address_from_msg(&sign_data)
|
// .recover_address_from_msg(&sign_data)
|
||||||
.map_err(|_| warp::reject())?;
|
// .map_err(|_| warp::reject())?;
|
||||||
|
|
||||||
let decoded_keyfile = Keyfile {
|
let decoded_keyfile = Keyfile {
|
||||||
username: our.name.clone(),
|
username: our.name.clone(),
|
||||||
@ -345,7 +355,6 @@ async fn handle_boot(
|
|||||||
networking_keypair: signature::Ed25519KeyPair::from_pkcs8(networking_keypair.as_ref())
|
networking_keypair: signature::Ed25519KeyPair::from_pkcs8(networking_keypair.as_ref())
|
||||||
.unwrap(),
|
.unwrap(),
|
||||||
jwt_secret_bytes: jwt_secret.to_vec(),
|
jwt_secret_bytes: jwt_secret.to_vec(),
|
||||||
salt,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
let encoded_keyfile = keygen::encode_keyfile(
|
let encoded_keyfile = keygen::encode_keyfile(
|
||||||
@ -354,7 +363,6 @@ async fn handle_boot(
|
|||||||
decoded_keyfile.routers.clone(),
|
decoded_keyfile.routers.clone(),
|
||||||
&networking_keypair,
|
&networking_keypair,
|
||||||
&decoded_keyfile.jwt_secret_bytes,
|
&decoded_keyfile.jwt_secret_bytes,
|
||||||
&decoded_keyfile.salt,
|
|
||||||
);
|
);
|
||||||
|
|
||||||
success_response(sender, our, decoded_keyfile, encoded_keyfile).await
|
success_response(sender, our, decoded_keyfile, encoded_keyfile).await
|
||||||
@ -429,6 +437,7 @@ async fn handle_login(
|
|||||||
sender: Arc<RegistrationSender>,
|
sender: Arc<RegistrationSender>,
|
||||||
encoded_keyfile: Option<Vec<u8>>,
|
encoded_keyfile: Option<Vec<u8>>,
|
||||||
) -> Result<impl Reply, Rejection> {
|
) -> Result<impl Reply, Rejection> {
|
||||||
|
println!("login info: {:?}", info);
|
||||||
if encoded_keyfile.is_none() {
|
if encoded_keyfile.is_none() {
|
||||||
return Ok(warp::reply::with_status(
|
return Ok(warp::reply::with_status(
|
||||||
warp::reply::json(&"Keyfile not present"),
|
warp::reply::json(&"Keyfile not present"),
|
||||||
@ -521,7 +530,6 @@ async fn confirm_change_network_keys(
|
|||||||
networking_keypair: signature::Ed25519KeyPair::from_pkcs8(networking_keypair.as_ref())
|
networking_keypair: signature::Ed25519KeyPair::from_pkcs8(networking_keypair.as_ref())
|
||||||
.unwrap(),
|
.unwrap(),
|
||||||
jwt_secret_bytes: old_decoded_keyfile.jwt_secret_bytes,
|
jwt_secret_bytes: old_decoded_keyfile.jwt_secret_bytes,
|
||||||
salt: old_decoded_keyfile.salt,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
let encoded_keyfile = keygen::encode_keyfile(
|
let encoded_keyfile = keygen::encode_keyfile(
|
||||||
@ -530,7 +538,6 @@ async fn confirm_change_network_keys(
|
|||||||
decoded_keyfile.routers.clone(),
|
decoded_keyfile.routers.clone(),
|
||||||
&networking_keypair,
|
&networking_keypair,
|
||||||
&decoded_keyfile.jwt_secret_bytes,
|
&decoded_keyfile.jwt_secret_bytes,
|
||||||
&decoded_keyfile.salt,
|
|
||||||
);
|
);
|
||||||
|
|
||||||
success_response(sender, our.clone(), decoded_keyfile, encoded_keyfile).await
|
success_response(sender, our.clone(), decoded_keyfile, encoded_keyfile).await
|
||||||
|
@ -763,7 +763,6 @@ pub struct Keyfile {
|
|||||||
pub routers: Vec<String>,
|
pub routers: Vec<String>,
|
||||||
pub networking_keypair: signature::Ed25519KeyPair,
|
pub networking_keypair: signature::Ed25519KeyPair,
|
||||||
pub jwt_secret_bytes: Vec<u8>,
|
pub jwt_secret_bytes: Vec<u8>,
|
||||||
pub salt: Vec<u8>,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Serialize, Deserialize)]
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
||||||
@ -785,9 +784,8 @@ pub struct BootInfo {
|
|||||||
pub username: String,
|
pub username: String,
|
||||||
pub reset: bool,
|
pub reset: bool,
|
||||||
pub direct: bool,
|
pub direct: bool,
|
||||||
pub signature: String,
|
// pub signature: String,
|
||||||
pub salt: String,
|
// pub timestamp: u64,
|
||||||
pub timestamp: u64,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Serialize, Deserialize)]
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
||||||
@ -819,17 +817,6 @@ pub struct Identity {
|
|||||||
pub struct UnencryptedIdentity {
|
pub struct UnencryptedIdentity {
|
||||||
pub name: NodeId,
|
pub name: NodeId,
|
||||||
pub allowed_routers: Vec<NodeId>,
|
pub allowed_routers: Vec<NodeId>,
|
||||||
pub salt: String,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
||||||
pub struct IdentityTransaction {
|
|
||||||
pub from: String,
|
|
||||||
pub signature: Option<String>,
|
|
||||||
pub to: String, // contract address
|
|
||||||
pub town_id: u32,
|
|
||||||
pub calldata: Identity,
|
|
||||||
pub nonce: String,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
Loading…
Reference in New Issue
Block a user