Skip to content

Commit

Permalink
Merge branch 'master' into end_call
Browse files Browse the repository at this point in the history
  • Loading branch information
hpeebles authored Dec 16, 2024
2 parents 795636e + b2d6ede commit ca42f23
Show file tree
Hide file tree
Showing 20 changed files with 63 additions and 103 deletions.
6 changes: 6 additions & 0 deletions backend/canisters/storage_bucket/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,12 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/).

### Changed

- Push any remaining events still queued in the old events system ([#7065](https://github.com/open-chat-labs/open-chat/pull/7065))

## [[2.0.1522](https://github.com/open-chat-labs/open-chat/releases/tag/v2.0.1522-storage_bucket)] - 2024-12-16

### Changed

- Expose size of each virtual stable memory in metrics ([#6981](https://github.com/open-chat-labs/open-chat/pull/6981))
- Avoid having to regenerate rng seed after each upgrade ([#7043](https://github.com/open-chat-labs/open-chat/pull/7043))
- Use `GroupedTimerJobQueue` to sync events to storage index ([#7047](https://github.com/open-chat-labs/open-chat/pull/7047))
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
use crate::model::index_sync_state::EventToSync;
use crate::model::index_event_batch::EventToSync;
use crate::{mutate_state, RuntimeState};
use ic_cdk_timers::TimerId;
use std::cell::Cell;
Expand Down
4 changes: 2 additions & 2 deletions backend/canisters/storage_bucket/impl/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
use crate::model::files::{Files, RemoveFileResult};
use crate::model::index_event_batch::IndexEventBatch;
use crate::model::index_sync_state::{EventToSync, IndexSyncState};
use crate::model::index_event_batch::{EventToSync, IndexEventBatch};
use crate::model::index_sync_state::IndexSyncState;
use crate::model::users::Users;
use candid::{CandidType, Principal};
use canister_state_macros::canister_state;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
use crate::lifecycle::{init_env, init_state};
use crate::memory::get_upgrades_memory;
use crate::model::index_event_batch::EventToSync;
use crate::Data;
use canister_logger::LogEntry;
use canister_tracing_macros::trace;
Expand All @@ -14,9 +15,26 @@ fn post_upgrade(args: Args) {
let memory = get_upgrades_memory();
let reader = get_reader(&memory);

let (data, errors, logs, traces): (Data, Vec<LogEntry>, Vec<LogEntry>, Vec<LogEntry>) =
let (mut data, errors, logs, traces): (Data, Vec<LogEntry>, Vec<LogEntry>, Vec<LogEntry>) =
msgpack::deserialize(reader).unwrap();

data.index_event_sync_queue.set_defer_processing(true);
#[allow(deprecated)]
{
if let Some(args) = data.index_sync_state.args_to_retry.take() {
for added in args.files_added {
data.push_event_to_index(EventToSync::FileAdded(added));
}
for removed in args.files_removed {
data.push_event_to_index(EventToSync::FileRemoved(removed));
}
}
for event in std::mem::take(&mut data.index_sync_state.queue) {
data.push_event_to_index(event)
}
}
data.index_event_sync_queue.set_defer_processing(false);

canister_logger::init_with_logs(data.test_mode, errors, logs, traces);

let env = init_env(data.rng_seed);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,22 @@
use crate::model::index_sync_state::EventToSync;
use crate::model::users::FileStatusInternal;
use crate::{mutate_state, DATA_LIMIT_BYTES, MAX_EVENTS_TO_SYNC_PER_BATCH};
use candid::Deserialize;
use serde::Serialize;
use timer_job_queues::{TimerJobItem, TimerJobItemGroup};
use types::CanisterId;
use types::{CanisterId, FileAdded, FileRemoved};
use utils::canister::should_retry_failed_c2c_call;

pub struct IndexEventBatch {
canister_id: CanisterId,
events: Vec<(EventToSync, u64)>,
}

#[derive(Serialize, Deserialize)]
pub enum EventToSync {
FileAdded(FileAdded),
FileRemoved(FileRemoved),
}

impl TimerJobItem for IndexEventBatch {
async fn process(&self) -> Result<(), bool> {
let mut args = storage_index_canister::c2c_sync_bucket::Args::default();
Expand Down
Original file line number Diff line number Diff line change
@@ -1,22 +1,13 @@
use crate::model::index_event_batch::EventToSync;
use serde::{Deserialize, Serialize};
use std::collections::VecDeque;
use storage_index_canister::c2c_sync_bucket::Args;
use types::{FileAdded, FileRemoved};

// We want to send events to the index in order, so while a sync is in progress we avoid sending
// more events in case the first batch fails and the second succeeds. If a sync fails, the args that
// were sent are stored so that they can be retried again.
#[derive(Serialize, Deserialize, Default)]
pub struct IndexSyncState {
queue: VecDeque<EventToSync>,
in_progress: bool,
args_to_retry: Option<Args>,
}

impl IndexSyncState {}

#[derive(Serialize, Deserialize)]
pub enum EventToSync {
FileAdded(FileAdded),
FileRemoved(FileRemoved),
pub queue: VecDeque<EventToSync>,
pub args_to_retry: Option<Args>,
}
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
use crate::guards::caller_is_storage_index_canister;
use crate::model::files::RemoveFileResult;
use crate::model::index_sync_state::EventToSync;
use crate::model::index_event_batch::EventToSync;
use crate::{mutate_state, RuntimeState, MAX_EVENTS_TO_SYNC_PER_BATCH};
use canister_tracing_macros::trace;
use ic_cdk::update;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
use crate::guards::caller_is_known_user;
use crate::model::files::ForwardFileResult;
use crate::model::index_sync_state::EventToSync;
use crate::model::index_event_batch::EventToSync;
use crate::model::users::{FileStatusInternal, IndexSyncComplete};
use crate::{mutate_state, RuntimeState};
use canister_tracing_macros::trace;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
use crate::guards::caller_is_known_user;
use crate::model::files::{PutChunkArgs, PutChunkResult};
use crate::model::index_sync_state::EventToSync;
use crate::model::index_event_batch::EventToSync;
use crate::model::users::{FileStatusInternal, IndexSyncComplete};
use crate::{mutate_state, RuntimeState};
use canister_tracing_macros::trace;
Expand Down
2 changes: 2 additions & 0 deletions backend/canisters/storage_index/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/).

## [unreleased]

## [[2.0.1521](https://github.com/open-chat-labs/open-chat/releases/tag/v2.0.1521-storage_index)] - 2024-12-16

### Changed

- Update the canister creation fee to 0.5T ([#6700](https://github.com/open-chat-labs/open-chat/pull/6700))
Expand Down
8 changes: 1 addition & 7 deletions backend/canisters/storage_index/impl/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
use crate::model::bucket_event_batch::BucketEventBatch;
use crate::model::bucket_sync_state::EventToSync;
use crate::model::bucket_event_batch::{BucketEventBatch, EventToSync};
use crate::model::buckets::{BucketRecord, Buckets};
use crate::model::files::Files;
use candid::{CandidType, Principal};
Expand Down Expand Up @@ -104,7 +103,6 @@ struct Data {
pub users: HashMap<Principal, UserRecordInternal>,
pub files: Files,
pub buckets: Buckets,
#[serde(default = "bucket_event_sync_queue")]
pub bucket_event_sync_queue: GroupedTimerJobQueue<BucketEventBatch>,
pub canisters_requiring_upgrade: CanistersRequiringUpgrade,
pub total_cycles_spent_on_canisters: Cycles,
Expand All @@ -113,10 +111,6 @@ struct Data {
pub test_mode: bool,
}

fn bucket_event_sync_queue() -> GroupedTimerJobQueue<BucketEventBatch> {
GroupedTimerJobQueue::new(5, false)
}

impl Data {
fn new(
user_controllers: Vec<Principal>,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,17 +14,9 @@ fn post_upgrade(args: Args) {
let memory = get_upgrades_memory();
let reader = get_reader(&memory);

let (mut data, errors, logs, traces): (Data, Vec<LogEntry>, Vec<LogEntry>, Vec<LogEntry>) =
let (data, errors, logs, traces): (Data, Vec<LogEntry>, Vec<LogEntry>, Vec<LogEntry>) =
msgpack::deserialize(reader).unwrap();

data.bucket_event_sync_queue.set_defer_processing(true);
for bucket in data.buckets.iter_mut() {
#[allow(deprecated)]
data.bucket_event_sync_queue
.push_many(bucket.canister_id, bucket.sync_state.take());
}
data.bucket_event_sync_queue.set_defer_processing(false);

canister_logger::init_with_logs(data.test_mode, errors, logs, traces);

let env = init_env(data.rng_seed);
Expand Down
Original file line number Diff line number Diff line change
@@ -1,14 +1,24 @@
use crate::model::bucket_sync_state::EventToSync;
use crate::MAX_EVENTS_TO_SYNC_PER_BATCH;
use candid::Principal;
use serde::{Deserialize, Serialize};
use timer_job_queues::{TimerJobItem, TimerJobItemGroup};
use types::CanisterId;
use types::{AccessorId, CanisterId, FileId};
use utils::canister::should_retry_failed_c2c_call;

pub struct BucketEventBatch {
canister_id: CanisterId,
events: Vec<EventToSync>,
}

#[derive(Serialize, Deserialize, Clone)]
pub enum EventToSync {
UserAdded(Principal),
UserRemoved(Principal),
AccessorRemoved(AccessorId),
UserIdUpdated(Principal, Principal),
FileToRemove(FileId),
}

impl TimerJobItem for BucketEventBatch {
async fn process(&self) -> Result<(), bool> {
let mut args = storage_bucket_canister::c2c_sync_index::Args::default();
Expand Down

This file was deleted.

9 changes: 0 additions & 9 deletions backend/canisters/storage_index/impl/src/model/buckets.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
use crate::model::bucket_sync_state::BucketSyncState;
use crate::BucketMetrics;
use serde::{Deserialize, Serialize};
use std::collections::HashMap;
Expand Down Expand Up @@ -96,10 +95,6 @@ impl Buckets {
pub fn iter_full_buckets(&self) -> impl Iterator<Item = &BucketRecord> {
self.full_buckets.values()
}

pub fn iter_mut(&mut self) -> impl Iterator<Item = &mut BucketRecord> {
self.active_buckets.iter_mut().chain(self.full_buckets.values_mut())
}
}

#[derive(Serialize, Deserialize)]
Expand All @@ -108,20 +103,16 @@ pub struct BucketRecord {
pub wasm_version: BuildVersion,
pub bytes_used: u64,
pub bytes_remaining: i64,
#[deprecated]
pub sync_state: BucketSyncState,
pub cycle_top_ups: Vec<CyclesTopUp>,
}

impl BucketRecord {
pub fn new(canister_id: CanisterId, wasm_version: BuildVersion) -> BucketRecord {
#[allow(deprecated)]
BucketRecord {
canister_id,
wasm_version,
bytes_used: 0,
bytes_remaining: 0,
sync_state: BucketSyncState::default(),
cycle_top_ups: Vec::new(),
}
}
Expand Down
1 change: 0 additions & 1 deletion backend/canisters/storage_index/impl/src/model/mod.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
pub mod bucket_event_batch;
pub mod bucket_sync_state;
pub mod buckets;
pub mod files;
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use crate::guards::caller_is_user_controller;
use crate::model::bucket_sync_state::EventToSync;
use crate::model::bucket_event_batch::EventToSync;
use crate::{mutate_state, RuntimeState, UserRecordInternal};
use canister_tracing_macros::trace;
use ic_cdk::update;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use crate::guards::caller_is_user_controller;
use crate::model::bucket_sync_state::EventToSync;
use crate::model::bucket_event_batch::EventToSync;
use crate::{mutate_state, RuntimeState};
use canister_api_macros::update;
use canister_tracing_macros::trace;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use crate::guards::caller_is_user_controller;
use crate::model::bucket_sync_state::EventToSync;
use crate::model::bucket_event_batch::EventToSync;
use crate::{mutate_state, RuntimeState};
use canister_tracing_macros::trace;
use ic_cdk::update;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use crate::guards::caller_is_user_controller;
use crate::model::bucket_sync_state::EventToSync;
use crate::model::bucket_event_batch::EventToSync;
use crate::{mutate_state, RuntimeState};
use canister_tracing_macros::trace;
use ic_cdk::update;
Expand Down

0 comments on commit ca42f23

Please sign in to comment.