diff --git a/parity/run.rs b/parity/run.rs index 5dd0bf43746..d8abf40c000 100644 --- a/parity/run.rs +++ b/parity/run.rs @@ -680,11 +680,15 @@ pub fn execute_impl(cmd: RunCmd, can_restart: bool, logger: Arc) let contract_client = Arc::new(::dapps::FullRegistrar::new(client.clone())); // the updater service + let mut updater_fetch = fetch.clone(); + // parity binaries should be smaller than 128MB + updater_fetch.set_limit(Some(128 * 1024 * 1024)); + let updater = Updater::new( Arc::downgrade(&(service.client() as Arc)), Arc::downgrade(&sync_provider), update_policy, - hash_fetch::Client::with_fetch(contract_client.clone(), fetch.clone(), event_loop.remote()) + hash_fetch::Client::with_fetch(contract_client.clone(), updater_fetch, event_loop.remote()) ); service.add_notify(updater.clone()); diff --git a/util/fetch/src/client.rs b/util/fetch/src/client.rs index b5aebfa0147..bcd534cb34f 100644 --- a/util/fetch/src/client.rs +++ b/util/fetch/src/client.rs @@ -127,6 +127,11 @@ impl Client { }) } + /// Sets a limit on the maximum download size. + pub fn set_limit(&mut self, limit: Option) { + self.limit = limit + } + fn client(&self) -> Result, Error> { { let (ref time, ref client) = *self.client.read(); @@ -150,8 +155,8 @@ impl Fetch for Client { type Result = CpuFuture; fn new() -> Result { - // Max 50MB will be downloaded. - Self::with_limit(Some(50*1024*1024)) + // Max 64MB will be downloaded. + Self::with_limit(Some(64 * 1024 * 1024)) } fn process(&self, f: F) -> BoxFuture where