Skip to content

Commit

Permalink
Update from upstream
Browse files Browse the repository at this point in the history
  • Loading branch information
slowli committed Nov 15, 2023
2 parents 908b7c1 + bdf9ed0 commit 904a89f
Show file tree
Hide file tree
Showing 12 changed files with 132 additions and 69 deletions.
1 change: 1 addition & 0 deletions node/Cargo.lock

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

2 changes: 1 addition & 1 deletion node/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ thiserror = "1.0.40"
time = "0.3.23"
# TODO(gprusak): only concurrency crate should depend on tokio.
# All the other crates should depend on concurrency.
tokio = { version = "1.28.1", features = ["full"] }
tokio = { version = "1.34.0", features = ["full"] }
tracing = { version = "0.1.37", features = ["attributes"] }
tracing-subscriber = { version = "0.3.16", features = ["env-filter", "fmt"] }
vise = { version = "0.1.0", git = "https://github.com/matter-labs/vise.git", rev = "dd05139b76ab0843443ab3ff730174942c825dae" }
Expand Down
11 changes: 7 additions & 4 deletions node/deny.toml
Original file line number Diff line number Diff line change
Expand Up @@ -48,18 +48,21 @@ multiple-versions = "deny"
# Certain crates/versions that will be skipped when doing duplicate detection.
skip = [
# Old versions required by tempfile and prost-build.
{ name = "bitflags", version = "=1.3.2" },
{ name = "bitflags", version = "1.3.2" },

# Old version required by tracing-subscriber.
{ name = "regex-automata", version = "=0.1.10" },
{ name = "regex-syntax", version = "=0.6.29" },
{ name = "regex-automata", version = "0.1.10" },
{ name = "regex-syntax", version = "0.6.29" },

# Old versions required by hyper.
{ name = "socket2", version = "=0.4.10" },
{ name = "socket2", version = "0.4.10" },

# Old versions required by pairing_ce & ff_ce.
{ name = "rand", version = "0.4" },
{ name = "syn", version = "1.0" },

# Old versions required by criterion.
{ name = "itertools", version = "0.10.5" }
]

[sources]
Expand Down
21 changes: 17 additions & 4 deletions node/libs/protobuf/src/bin/conformance_test/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,21 @@ use zksync_concurrency::{ctx, io};

mod proto;

/// Decodes a generated proto message from json for arbitrary ReflectMessage.
fn decode_json_proto<T: ReflectMessage + Default>(json: &str) -> anyhow::Result<T> {
let mut d = serde_json::Deserializer::from_str(json);
let p: T = zksync_protobuf::serde::deserialize_proto(&mut d)?;
d.end()?;
Ok(p)
}

/// Encodes a generated proto message to json for arbitrary ReflectMessage.
fn encode_json_proto<T: ReflectMessage>(x: &T) -> String {
let mut s = serde_json::Serializer::pretty(vec![]);
zksync_protobuf::serde::serialize_proto(x, &mut s).unwrap();
String::from_utf8(s.into_inner()).unwrap()
}

/// Runs the test server.
async fn run() -> anyhow::Result<()> {
let ctx = &ctx::root();
Expand Down Expand Up @@ -41,7 +56,7 @@ async fn run() -> anyhow::Result<()> {
use proto::TestAllTypesProto3 as T;
let p = match payload {
proto::conformance_request::Payload::JsonPayload(payload) => {
match zksync_protobuf::decode_json_proto(&payload) {
match decode_json_proto(&payload) {
Ok(p) => p,
Err(_) => return Ok(R::Skipped("unsupported fields".to_string())),
}
Expand All @@ -65,9 +80,7 @@ async fn run() -> anyhow::Result<()> {
.requested_output_format
.context("missing output format")?;
match proto::WireFormat::try_from(format).context("unknown format")? {
proto::WireFormat::Json => {
anyhow::Ok(R::JsonPayload(zksync_protobuf::encode_json_proto(&p)))
}
proto::WireFormat::Json => anyhow::Ok(R::JsonPayload(encode_json_proto(&p))),
proto::WireFormat::Protobuf => {
// Reencode the parsed proto.
anyhow::Ok(R::ProtobufPayload(zksync_protobuf::canonical_raw(
Expand Down
32 changes: 32 additions & 0 deletions node/libs/protobuf/src/build.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ pub use prost;
use prost::Message as _;
pub use prost_reflect;
use prost_reflect::prost_types;
pub use serde;
use std::sync::RwLock;

/// Global descriptor pool.
Expand Down Expand Up @@ -81,5 +82,36 @@ macro_rules! impl_reflect_message {
};
}

/// Implements `serde::Serialize` compatible with protobuf json encoding.
#[macro_export]
macro_rules! impl_serde_serialize {
($ty:ty) => {
impl $crate::build::serde::Serialize for $ty {
fn serialize<S: $crate::build::serde::Serializer>(
&self,
s: S,
) -> Result<S::Ok, S::Error> {
$crate::serde_serialize(self, s)
}
}
};
}

/// Implements `serde::Deserialize` compatible with protobuf json encoding.
#[macro_export]
macro_rules! impl_serde_deserialize {
($ty:ty) => {
impl<'de> $crate::build::serde::Deserialize<'de> for $ty {
fn deserialize<D: $crate::build::serde::Deserializer<'de>>(
d: D,
) -> Result<Self, D::Error> {
$crate::serde_deserialize(d)
}
}
};
}

pub use declare_descriptor;
pub use impl_reflect_message;
pub use impl_serde_deserialize;
pub use impl_serde_serialize;
1 change: 1 addition & 0 deletions node/libs/protobuf/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
pub mod build;
pub mod proto;
mod proto_fmt;
pub mod serde;
mod std_conv;
pub mod testonly;

Expand Down
34 changes: 0 additions & 34 deletions node/libs/protobuf/src/proto_fmt.rs
Original file line number Diff line number Diff line change
Expand Up @@ -265,40 +265,6 @@ pub fn decode<T: ProtoFmt>(bytes: &[u8]) -> anyhow::Result<T> {
T::read(&<T as ProtoFmt>::Proto::decode(bytes)?)
}

/// Encodes a generated proto message to json.
/// WARNING: this function uses reflection, so it is not very efficient.
pub fn encode_json_proto<T: ReflectMessage>(x: &T) -> String {
let mut s = serde_json::Serializer::pretty(vec![]);
let opts = prost_reflect::SerializeOptions::new();
x.transcode_to_dynamic()
.serialize_with_options(&mut s, &opts)
.unwrap();
String::from_utf8(s.into_inner()).unwrap()
}

/// Encodes a proto message to json.
/// WARNING: this function uses reflection, so it is not very efficient.
pub fn encode_json<T: ProtoFmt>(x: &T) -> String {
encode_json_proto(&x.build())
}

/// Decodes a generated proto message from json.
/// WARNING: this function uses reflection, so it is not very efficient.
pub fn decode_json_proto<T: ReflectMessage + Default>(json: &str) -> anyhow::Result<T> {
let mut d = serde_json::de::Deserializer::from_str(json);
let mut p = T::default();
let msg = prost_reflect::DynamicMessage::deserialize(p.descriptor(), &mut d)?;
d.end()?;
p.merge(msg.encode_to_vec().as_slice()).unwrap();
Ok(p)
}

/// Decodes a proto message from json.
/// WARNING: this function uses reflection, so it is not very efficient.
pub fn decode_json<T: ProtoFmt>(json: &str) -> anyhow::Result<T> {
T::read(&decode_json_proto(json)?)
}

/// Trait defining a proto representation for a type.
pub trait ProtoFmt: Sized {
/// Proto message type representing Self.
Expand Down
37 changes: 37 additions & 0 deletions node/libs/protobuf/src/serde.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
//! Implementation of serde traits for structs implementing ProtoFmt.
//! This serde implementation is compatible with protobuf json mapping,
//! therefore it is suitable for version control.
//! WARNING: Currently this serde implementation uses reflection,
//! so it is not very efficient.
use crate::ProtoFmt;
use prost::Message as _;
use prost_reflect::ReflectMessage;

/// Implementation of serde::Serialize for arbitrary ReflectMessage.
pub fn serialize_proto<T: ReflectMessage, S: serde::Serializer>(
x: &T,
s: S,
) -> Result<S::Ok, S::Error> {
let opts = prost_reflect::SerializeOptions::new();
x.transcode_to_dynamic().serialize_with_options(s, &opts)
}

/// Implementation of serde::Serialize for arbitrary ProtoFmt.
pub fn serialize<T: ProtoFmt, S: serde::Serializer>(x: &T, s: S) -> Result<S::Ok, S::Error> {
serialize_proto(&x.build(), s)
}

/// Implementation of serde::Deserialize for arbitrary ReflectMessage.
pub fn deserialize_proto<'de, T: ReflectMessage + Default, D: serde::Deserializer<'de>>(
d: D,
) -> Result<T, D::Error> {
let mut p = T::default();
let msg = prost_reflect::DynamicMessage::deserialize(p.descriptor(), d)?;
p.merge(msg.encode_to_vec().as_slice()).unwrap();
Ok(p)
}

/// Implementation of serde::Deserialize for arbitrary ProtoFmt.
pub fn deserialize<'de, T: ProtoFmt, D: serde::Deserializer<'de>>(d: D) -> Result<T, D::Error> {
T::read(&deserialize_proto(d)?).map_err(serde::de::Error::custom)
}
27 changes: 13 additions & 14 deletions node/libs/protobuf_build/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -140,11 +140,6 @@ pub struct Config {
}

impl Config {
/// Location of the protobuf_build crate, visible from the generated code.
fn this_crate(&self) -> RustName {
self.protobuf_crate.clone().join(RustName::ident("build"))
}

/// Generates implementation of `prost_reflect::ReflectMessage` for a rust type generated
/// from a message of the given `proto_name`.
fn reflect_impl(&self, proto_name: &ProtoName) -> anyhow::Result<syn::Item> {
Expand All @@ -153,10 +148,10 @@ impl Config {
.unwrap()
.to_rust_type()?;
let proto_name = proto_name.to_string();
let this = self.this_crate();
Ok(syn::parse_quote! {
#this::impl_reflect_message!(#rust_name, &DESCRIPTOR, #proto_name);
})
let protobuf_crate = &self.protobuf_crate;
Ok(
syn::parse_quote! { #protobuf_crate::build::impl_reflect_message!(#rust_name, &DESCRIPTOR, #proto_name); },
)
}

/// Validates this configuration.
Expand Down Expand Up @@ -319,7 +314,11 @@ impl Config {
// Generate code out of compiled proto files.
let mut output = RustModule::default();
let mut config = prost_build::Config::new();
let prost_path = self.this_crate().join(RustName::ident("prost"));
let prost_path = self
.protobuf_crate
.clone()
.join(RustName::ident("build"))
.join(RustName::ident("prost"));
config.prost_path(prost_path.to_string());
config.skip_protoc_run();
for (root_path, manifest) in self.dependencies.iter().zip(&dependency_manifests) {
Expand Down Expand Up @@ -352,18 +351,18 @@ impl Config {

// Generate the descriptor.
let root_paths_for_deps = self.dependencies.iter();
let this = self.this_crate();
let protobuf_crate = &self.protobuf_crate;
let descriptor_path = descriptor_path.display().to_string();
output.append_item(syn::parse_quote! {
#this::declare_descriptor!(DESCRIPTOR => #descriptor_path, #(#root_paths_for_deps),*);
#protobuf_crate::build::declare_descriptor!(DESCRIPTOR => #descriptor_path, #(#root_paths_for_deps),*);
});

// Generate the reflection code.
for proto_name in extract_message_names(&descriptor) {
let impl_item = self
let item = self
.reflect_impl(&proto_name)
.with_context(|| format!("reflect_impl({proto_name})"))?;
output.append_item(impl_item);
output.append_item(item);
}

// Save output.
Expand Down
1 change: 1 addition & 0 deletions node/tools/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ zksync_protobuf.workspace = true
anyhow.workspace = true
clap.workspace = true
rand.workspace = true
serde_json.workspace = true
tokio.workspace = true
tracing.workspace = true
tracing-subscriber.workspace = true
Expand Down
13 changes: 8 additions & 5 deletions node/tools/src/bin/localnet_config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,13 @@ use zksync_consensus_executor::{ConsensusConfig, ExecutorConfig, GossipConfig};
use zksync_consensus_roles::{node, validator};
use zksync_consensus_tools::NodeConfig;

/// Encodes a generated proto message to json for arbitrary ProtoFmt.
fn encode_json<T: zksync_protobuf::ProtoFmt>(x: &T) -> String {
let mut s = serde_json::Serializer::pretty(vec![]);
zksync_protobuf::serde::serialize(x, &mut s).unwrap();
String::from_utf8(s.into_inner()).unwrap()
}

/// Replaces IP of the address with UNSPECIFIED (aka INADDR_ANY) of the corresponding IP type.
/// Opening a listener socket with an UNSPECIFIED IP, means that the new connections
/// on any network interface of the VM will be accepted.
Expand Down Expand Up @@ -110,11 +117,7 @@ fn main() -> anyhow::Result<()> {
let _ = fs::remove_dir_all(&root);
fs::create_dir_all(&root).with_context(|| format!("create_dir_all({:?})", root))?;

fs::write(
root.join("config.json"),
zksync_protobuf::encode_json(&node_cfg),
)
.context("fs::write()")?;
fs::write(root.join("config.json"), encode_json(&node_cfg)).context("fs::write()")?;
fs::write(
root.join("validator_key"),
&TextFmt::encode(&validator_keys[i]),
Expand Down
21 changes: 14 additions & 7 deletions node/tools/src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,14 @@ use zksync_consensus_executor::{proto, ConsensusConfig, ExecutorConfig};
use zksync_consensus_roles::{node, validator};
use zksync_protobuf::{read_optional, read_required, ProtoFmt};

/// Decodes a proto message from json for arbitrary ProtoFmt.
fn decode_json<T: ProtoFmt>(json: &str) -> anyhow::Result<T> {
let mut d = serde_json::Deserializer::from_str(json);
let p: T = zksync_protobuf::serde::deserialize(&mut d)?;
d.end()?;
Ok(p)
}

/// This struct holds the file path to each of the config files.
#[derive(Debug)]
pub struct ConfigPaths<'a> {
Expand Down Expand Up @@ -75,13 +83,12 @@ impl Configs {
args.config.display()
)
})?;
let node_config: NodeConfig =
zksync_protobuf::decode_json(&node_config).with_context(|| {
format!(
"failed decoding JSON node config at `{}`",
args.config.display()
)
})?;
let node_config: NodeConfig = decode_json(&node_config).with_context(|| {
format!(
"failed decoding JSON node config at `{}`",
args.config.display()
)
})?;

let validator_key: Option<validator::SecretKey> = args
.validator_key
Expand Down

0 comments on commit 904a89f

Please sign in to comment.