diff --git a/Cargo.lock b/Cargo.lock index 8534604455..2cf97e7ac8 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -8384,8 +8384,6 @@ dependencies = [ "modclub_canister", "modclub_canister_c2c_client", "msgpack", - "nns_governance_canister", - "nns_governance_canister_c2c_client", "online_users_canister", "online_users_canister_c2c_client", "p256_key_pair", diff --git a/backend/canisters/neuron_controller/impl/src/jobs/mod.rs b/backend/canisters/neuron_controller/impl/src/jobs/mod.rs index 664b3f9c29..9bb7274f44 100644 --- a/backend/canisters/neuron_controller/impl/src/jobs/mod.rs +++ b/backend/canisters/neuron_controller/impl/src/jobs/mod.rs @@ -1,7 +1,9 @@ use crate::RuntimeState; pub mod process_neurons; +mod refresh_8_year_neuron; pub(crate) fn start(_state: &RuntimeState) { process_neurons::start_job(); + refresh_8_year_neuron::start_job(); } diff --git a/backend/canisters/neuron_controller/impl/src/jobs/refresh_8_year_neuron.rs b/backend/canisters/neuron_controller/impl/src/jobs/refresh_8_year_neuron.rs new file mode 100644 index 0000000000..be2a007ddb --- /dev/null +++ b/backend/canisters/neuron_controller/impl/src/jobs/refresh_8_year_neuron.rs @@ -0,0 +1,52 @@ +use crate::read_state; +use constants::DAY_IN_MS; +use nns_governance_canister::types::manage_neuron::claim_or_refresh::By; +use nns_governance_canister::types::manage_neuron::{ClaimOrRefresh, Command}; +use nns_governance_canister::types::neuron::DissolveState; +use nns_governance_canister::types::Empty; +use std::time::Duration; +use tracing::info; +use types::Milliseconds; +use utils::canister_timers::run_now_then_interval; + +const REFRESH_NEURON_INTERVAL: Milliseconds = DAY_IN_MS; + +pub fn start_job() { + run_now_then_interval(Duration::from_millis(REFRESH_NEURON_INTERVAL), run); +} + +fn run() { + ic_cdk::spawn(run_async()); +} + +async fn run_async() { + if let Some((nns_governance_canister_id, neuron_id)) = read_state(|state| { + state + .data + .neurons + .active_neurons + .iter() + .max_by_key(|n| { + n.dissolve_state + .as_ref() + .map(|ds| if let DissolveState::DissolveDelaySeconds(dd) = ds { *dd } else { 0 }) + }) + .map(|n| (state.data.nns_governance_canister_id, n.id.clone())) + }) { + if nns_governance_canister_c2c_client::manage_neuron( + nns_governance_canister_id, + &nns_governance_canister::manage_neuron::Args { + id: neuron_id.clone(), + neuron_id_or_subaccount: None, + command: Some(Command::ClaimOrRefresh(ClaimOrRefresh { + by: Some(By::NeuronIdOrSubaccount(Empty {})), + })), + }, + ) + .await + .is_ok() + { + info!(?neuron_id, "Refreshed neuron"); + } + } +} diff --git a/backend/canisters/user_index/impl/Cargo.toml b/backend/canisters/user_index/impl/Cargo.toml index ef25153676..7338f9f1ae 100644 --- a/backend/canisters/user_index/impl/Cargo.toml +++ b/backend/canisters/user_index/impl/Cargo.toml @@ -48,8 +48,6 @@ p256_key_pair = { path = "../../../libraries/p256_key_pair" } modclub_canister = { path = "../../../external_canisters/modclub/api" } modclub_canister_c2c_client = { path = "../../../external_canisters/modclub/c2c_client" } msgpack = { path = "../../../libraries/msgpack" } -nns_governance_canister = { path = "../../../external_canisters/nns_governance/api" } -nns_governance_canister_c2c_client = { path = "../../../external_canisters/nns_governance/c2c_client" } online_users_canister = { path = "../../online_users/api" } online_users_canister_c2c_client = { path = "../../online_users/c2c_client" } proof_of_unique_personhood = { path = "../../../libraries/proof_of_unique_personhood" } diff --git a/backend/canisters/user_index/impl/src/jobs/make_pending_payments.rs b/backend/canisters/user_index/impl/src/jobs/make_pending_payments.rs index 7b44e0a664..bf4c685487 100644 --- a/backend/canisters/user_index/impl/src/jobs/make_pending_payments.rs +++ b/backend/canisters/user_index/impl/src/jobs/make_pending_payments.rs @@ -55,9 +55,6 @@ async fn process_payment(pending_payment: PendingPayment) { PendingPaymentReason::ReferralReward => { inform_referrer(&pending_payment, block_index, state); } - PendingPaymentReason::TopUpNeuron => { - state.data.refresh_nns_neuron(); - } _ => {} }, Ok(Err(_)) => {} diff --git a/backend/canisters/user_index/impl/src/lib.rs b/backend/canisters/user_index/impl/src/lib.rs index 8e80a1ef12..bc5e6dfeca 100644 --- a/backend/canisters/user_index/impl/src/lib.rs +++ b/backend/canisters/user_index/impl/src/lib.rs @@ -19,9 +19,6 @@ use model::pending_modclub_submissions_queue::{PendingModclubSubmission, Pending use model::pending_payments_queue::{PendingPayment, PendingPaymentsQueue}; use model::reported_messages::{ReportedMessages, ReportingMetrics}; use model::user::SuspensionDetails; -use nns_governance_canister::types::manage_neuron::claim_or_refresh::By; -use nns_governance_canister::types::manage_neuron::{ClaimOrRefresh, Command}; -use nns_governance_canister::types::{Empty, ManageNeuron, NeuronId}; use p256_key_pair::P256KeyPair; use serde::{Deserialize, Serialize}; use std::cell::RefCell; @@ -503,26 +500,6 @@ impl Data { }) } - pub fn refresh_nns_neuron(&self) { - if let Some(neuron_id) = self.nns_8_year_neuron.as_ref().map(|n| n.neuron_id) { - ic_cdk::spawn(refresh_nns_neuron_inner(self.nns_governance_canister_id, neuron_id)); - } - - async fn refresh_nns_neuron_inner(nns_governance_canister_id: CanisterId, neuron_id: u64) { - let _ = nns_governance_canister_c2c_client::manage_neuron( - nns_governance_canister_id, - &ManageNeuron { - id: Some(NeuronId { id: neuron_id }), - neuron_id_or_subaccount: None, - command: Some(Command::ClaimOrRefresh(ClaimOrRefresh { - by: Some(By::NeuronIdOrSubaccount(Empty {})), - })), - }, - ) - .await; - } - } - pub fn chit_bands(&self, size: u32, year: u32, month: u8) -> BTreeMap { let mut bands = BTreeMap::new(); let month_key = MonthKey::new(year, month);