Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(torii-core): store update member #2182

Merged
merged 38 commits into from
Aug 1, 2024
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
Show all changes
38 commits
Select commit Hold shift + click to select a range
98801d3
feat(torii-core): store update member
Larkooo Jul 17, 2024
3f6908e
feat; add set_model_member for updating specific member
Larkooo Jul 17, 2024
8aba41c
chore: format
Larkooo Jul 17, 2024
65b2c39
chore: update log to include member nname
Larkooo Jul 17, 2024
b54901c
fmt
Larkooo Jul 17, 2024
349b327
refactor: clean code & add is event message
Larkooo Jul 17, 2024
9dd48d8
fmt
Larkooo Jul 17, 2024
b0d9fd5
chore
Larkooo Jul 17, 2024
71af001
feat: emit the store member update from the world
glihm Jul 18, 2024
9343249
fix: ensure event messages are emitted with the correct selector
glihm Jul 18, 2024
a900617
merge main
glihm Jul 18, 2024
acf7c60
fix: cairo fmt
glihm Jul 18, 2024
8bcaf36
fix: fix test typo
glihm Jul 18, 2024
91949d5
wip:
glihm Jul 18, 2024
7fa5f5a
fix: simple types model memebr update
Larkooo Jul 18, 2024
8d14285
chore; pass memmber type to func
Larkooo Jul 18, 2024
7e4c56c
chore: clean code
Larkooo Jul 18, 2024
6f23b9a
fmt
Larkooo Jul 18, 2024
59736ee
wip
Larkooo Jul 19, 2024
98b7d48
fix: upsert to avoid constraint CHECK failing
Larkooo Jul 19, 2024
5d8e141
fmt
Larkooo Jul 19, 2024
ba34cd3
Merge remote-tracking branch 'upstream/main' into store-update-member
Larkooo Jul 29, 2024
2e87cde
fix: figure out way to fix upsert issue to reuse func
Larkooo Jul 29, 2024
ddb37c3
refactor: refactor recursive set to handle store update member
Larkooo Jul 29, 2024
ac41ee0
fix: fix world typo and merge
glihm Jul 30, 2024
58eef8d
merge main
glihm Jul 30, 2024
8805fa0
fix: struct from ty as mutable
Larkooo Jul 30, 2024
c6bfb58
fix: compilable torii
Larkooo Jul 30, 2024
e4a734d
feat: wrap up store update member
Larkooo Jul 30, 2024
1a585b5
fmt
Larkooo Jul 30, 2024
d81a2d7
fix fmt
Larkooo Jul 30, 2024
ac8b09d
fmt
Larkooo Jul 30, 2024
14861ad
cairo fmt
Larkooo Jul 30, 2024
a87133d
fix: update example to set array with new model API
glihm Jul 30, 2024
92ec2fe
fix: handle arrays
Larkooo Jul 31, 2024
d6c939e
fix: correctly handle arrays
Larkooo Jul 31, 2024
652a1f4
chore
Larkooo Jul 31, 2024
72cc8df
fix: test
Larkooo Jul 31, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions bin/torii/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ use torii_core::processors::register_model::RegisterModelProcessor;
use torii_core::processors::store_del_record::StoreDelRecordProcessor;
use torii_core::processors::store_set_record::StoreSetRecordProcessor;
use torii_core::processors::store_transaction::StoreTransactionProcessor;
use torii_core::processors::store_update_member::StoreUpdateMemberProcessor;
use torii_core::processors::store_update_record::StoreUpdateRecordProcessor;
use torii_core::simple_broker::SimpleBroker;
use torii_core::sql::Sql;
Expand Down Expand Up @@ -172,6 +173,7 @@ async fn main() -> anyhow::Result<()> {
Box::new(StoreDelRecordProcessor),
Box::new(EventMessageProcessor),
Box::new(StoreUpdateRecordProcessor),
Box::new(StoreUpdateMemberProcessor),
glihm marked this conversation as resolved.
Show resolved Hide resolved
],
transaction: vec![Box::new(StoreTransactionProcessor)],
..Processors::default()
Expand Down
1 change: 1 addition & 0 deletions crates/torii/core/src/processors/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ pub mod register_model;
pub mod store_del_record;
pub mod store_set_record;
pub mod store_transaction;
pub mod store_update_member;
pub mod store_update_record;

const MODEL_INDEX: usize = 0;
Expand Down
99 changes: 99 additions & 0 deletions crates/torii/core/src/processors/store_update_member.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
use anyhow::{Context, Error, Result};
use async_trait::async_trait;
use dojo_world::contracts::model::ModelReader;
use dojo_world::contracts::naming;
use dojo_world::contracts::world::WorldContractReader;
use num_traits::ToPrimitive;
use starknet::core::types::{Event, TransactionReceiptWithBlockInfo};
use starknet::core::utils::get_selector_from_name;
use starknet::providers::Provider;
use tracing::info;

use super::EventProcessor;
use crate::processors::{ENTITY_ID_INDEX, MODEL_INDEX};
use crate::sql::Sql;

pub(crate) const LOG_TARGET: &str = "torii_core::processors::store_update_record";

const MEMBER_INDEX: usize = 2;

#[derive(Default, Debug)]
pub struct StoreUpdateMemberProcessor;

#[async_trait]
impl<P> EventProcessor<P> for StoreUpdateMemberProcessor
where
P: Provider + Send + Sync + std::fmt::Debug,
{
fn event_key(&self) -> String {
"StoreUpdateMember".to_string()
}

fn validate(&self, event: &Event) -> bool {
if event.keys.len() > 1 {
info!(
target: LOG_TARGET,
event_key = %<StoreUpdateMemberProcessor as EventProcessor<P>>::event_key(self),
invalid_keys = %<StoreUpdateMemberProcessor as EventProcessor<P>>::event_keys_as_string(self, event),
"Invalid event keys."
);
return false;
}
true
}

async fn process(
&self,
_world: &WorldContractReader<P>,
db: &mut Sql,
_block_number: u64,
block_timestamp: u64,
_transaction_receipt: &TransactionReceiptWithBlockInfo,
event_id: &str,
event: &Event,
) -> Result<(), Error> {
let selector = event.data[MODEL_INDEX];
let entity_id = event.data[ENTITY_ID_INDEX];
let member_selector = event.data[MEMBER_INDEX];

let model = db.model(selector).await?;
let schema = model.schema().await?;
let mut ty = schema
.as_struct()
.expect("model schema must be a struct")
.children
.iter()
.find(|c| {
get_selector_from_name(&c.name).expect("invalid selector for member name")
== member_selector
})
.context("member not found")?
.ty
.clone();

info!(
target: LOG_TARGET,
name = %model.name(),
entity_id = format!("{:#x}", entity_id),
member = %ty.name(),
"Store update member.",
);

let values_start = MEMBER_INDEX + 1;
let values_end: usize =
values_start + event.data[values_start].to_usize().context("invalid usize")?;

// Skip the length to only get the values as they will be deserialized.
let values = event.data[values_start + 1..=values_end].to_vec();

let tag = naming::get_tag(model.namespace(), model.name());

// Keys are read from the db, since we don't have access to them when only
// the entity id is passed.
let keys = db.get_entity_keys(entity_id, &tag).await?;
let mut keys_and_unpacked = [keys, values].concat();

ty.deserialize(&mut keys_and_unpacked)?;
db.set_model_member(entity_id, false, &schema.name(), &ty, event_id, block_timestamp).await
}
}
37 changes: 34 additions & 3 deletions crates/torii/core/src/sql.rs
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,8 @@ use crate::types::{
};
use crate::utils::{must_utc_datetime_from_timestamp, utc_dt_string_from_timestamp};

type IsEventMessage = bool;

pub const FELT_DELIMITER: &str = "/";

#[cfg(test)]
Expand Down Expand Up @@ -271,6 +273,31 @@ impl Sql {
Ok(())
}

pub async fn set_model_member(
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ohayo, Sensei! Reminder: Add tests.

The set_model_member function is well-implemented and crucial for updating model members. However, it lacks test coverage, which is essential for ensuring its reliability and correctness.

Do you want me to generate the unit testing code or open a GitHub issue to track this task?

&mut self,
entity_id: Felt,
is_event_message: bool,
model_tag: &str,
member: &Ty,
event_id: &str,
block_timestamp: u64,
) -> Result<()> {
let entity_id = format!("{:#x}", entity_id);
let path = vec![model_tag.to_string()];
// update model member
self.build_set_entity_queries_recursive(
Larkooo marked this conversation as resolved.
Show resolved Hide resolved
path,
event_id,
(&entity_id, is_event_message),
member,
block_timestamp,
&vec![],
);
self.query_queue.execute_all().await?;

Ok(())
}
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reminder: Add tests.

The set_model_member function is well-implemented and crucial for updating model members. However, it lacks test coverage, which is essential for ensuring its reliability and correctness.

Do you want me to generate the unit testing code or open a GitHub issue to track this task?


pub async fn delete_entity(&mut self, entity_id: Felt, entity: Ty) -> Result<()> {
let entity_id = format!("{:#x}", entity_id);
let path = vec![entity.name()];
Expand Down Expand Up @@ -556,12 +583,12 @@ impl Sql {
}
}

fn build_set_entity_queries_recursive(
pub fn build_set_entity_queries_recursive(
&mut self,
path: Vec<String>,
event_id: &str,
// The id of the entity and if the entity is an event message
entity_id: (&str, bool),
entity_id: (&str, IsEventMessage),
entity: &Ty,
block_timestamp: u64,
indexes: &Vec<i64>,
Expand Down Expand Up @@ -658,7 +685,11 @@ impl Sql {
Ty::Enum(e) => {
if e.options.iter().all(
|o| {
if let Ty::Tuple(t) = &o.ty { t.is_empty() } else { false }
if let Ty::Tuple(t) = &o.ty {
t.is_empty()
} else {
false
}
},
) {
return;
Expand Down
Loading