Skip to content

Commit

Permalink
Merge branch 'main' into skip-migration
Browse files Browse the repository at this point in the history
  • Loading branch information
lambda-0x committed Jun 8, 2024
2 parents c63a0af + 9ea6574 commit ae97033
Show file tree
Hide file tree
Showing 6 changed files with 79 additions and 39 deletions.
8 changes: 4 additions & 4 deletions bin/sozo/src/args.rs
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ pub struct SozoArgs {

#[arg(long)]
#[arg(env = "SOZO_OFFLINE")]
#[arg(hide_short_help = true)]
#[arg(hide_short_help = true, global = true)]
#[arg(help = "Run without accessing the network.")]
pub offline: bool,

Expand Down Expand Up @@ -70,15 +70,15 @@ impl SozoArgs {
#[derive(Parser, Clone, Debug)]
#[group(multiple = false)]
pub struct ProfileSpec {
#[arg(short = 'P', long)]
#[arg(short = 'P', long, global = true)]
#[arg(help = "Specify profile to use by name.")]
pub profile: Option<SmolStr>,

#[arg(long, hide_short_help = true)]
#[arg(long, hide_short_help = true, global = true)]
#[arg(help = "Use release profile.")]
pub release: bool,

#[arg(long, hide_short_help = true)]
#[arg(long, hide_short_help = true, global = true)]
#[arg(help = "Use dev profile.")]
pub dev: bool,
}
Expand Down
59 changes: 54 additions & 5 deletions crates/dojo-world/src/metadata.rs
Original file line number Diff line number Diff line change
Expand Up @@ -112,17 +112,31 @@ pub fn dojo_metadata_from_workspace(ws: &Workspace<'_>) -> DojoMetadata {
if let Ok(manifest) = BaseManifest::load_from_path(&manifest_dir.join(BASE_DIR)) {
for model in manifest.models {
let name = model.name.to_string();
dojo_metadata.artifacts.insert(
dojo_metadata.resources_artifacts.insert(
name.clone(),
build_artifact_from_name(&sources_dir, &abis_dir.join("models"), &name),
ResourceMetadata {
name: name.clone(),
artifacts: build_artifact_from_name(
&sources_dir,
&abis_dir.join("models"),
&name,
),
},
);
}

for contract in manifest.contracts {
let name = contract.name.to_string();
dojo_metadata.artifacts.insert(
dojo_metadata.resources_artifacts.insert(
name.clone(),
build_artifact_from_name(&sources_dir, &abis_dir.join("contracts"), &name),
ResourceMetadata {
name: name.clone(),
artifacts: build_artifact_from_name(
&sources_dir,
&abis_dir.join("contracts"),
&name,
),
},
);
}
}
Expand All @@ -139,12 +153,19 @@ pub struct ProjectMetadata {
pub skip_migration: Option<Vec<String>>,
}

/// Metadata for a user defined resource (models, contracts).
#[derive(Default, Serialize, Deserialize, Debug, Clone)]
pub struct ResourceMetadata {
pub name: String,
pub artifacts: ArtifactMetadata,
}

/// Metadata collected from the project configuration and the Dojo workspace
#[derive(Default, Deserialize, Debug, Clone)]
pub struct DojoMetadata {
pub world: WorldMetadata,
pub env: Option<Environment>,
pub artifacts: HashMap<String, ArtifactMetadata>,
pub resources_artifacts: HashMap<String, ResourceMetadata>,
pub skip_migration: Option<Vec<String>>,
}

Expand Down Expand Up @@ -347,6 +368,34 @@ impl ArtifactMetadata {
}
}

impl ResourceMetadata {
pub async fn upload(&self) -> Result<String> {
let mut meta = self.clone();
let client =
IpfsClient::from_str(IPFS_CLIENT_URL)?.with_credentials(IPFS_USERNAME, IPFS_PASSWORD);

if let Some(Uri::File(abi)) = &self.artifacts.abi {
let abi_data = std::fs::read(abi)?;
let reader = Cursor::new(abi_data);
let response = client.add(reader).await?;
meta.artifacts.abi = Some(Uri::Ipfs(format!("ipfs://{}", response.hash)))
};

if let Some(Uri::File(source)) = &self.artifacts.source {
let source_data = std::fs::read(source)?;
let reader = Cursor::new(source_data);
let response = client.add(reader).await?;
meta.artifacts.source = Some(Uri::Ipfs(format!("ipfs://{}", response.hash)))
};

let serialized = json!(meta).to_string();
let reader = Cursor::new(serialized);
let response = client.add(reader).await?;

Ok(response.hash)
}
}

impl DojoMetadata {
pub fn env(&self) -> Option<&Environment> {
self.env.as_ref()
Expand Down
13 changes: 9 additions & 4 deletions crates/dojo-world/src/metadata_test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -174,13 +174,18 @@ async fn get_full_dojo_metadata_from_workspace() {

dbg!(&artifacts);
for (abi_subdir, name) in artifacts {
let artifact = dojo_metadata.artifacts.get(&name);
assert!(artifact.is_some(), "bad artifact for {}", name);
let artifact = artifact.unwrap();
let resource = dojo_metadata.resources_artifacts.get(&name);
assert!(resource.is_some(), "bad resource metadata for {}", name);
let resource = resource.unwrap();

let sanitized_name = name.replace("::", "_");

check_artifact(artifact.clone(), sanitized_name, &abis_dir.join(abi_subdir), &sources_dir);
check_artifact(
resource.artifacts.clone(),
sanitized_name,
&abis_dir.join(abi_subdir),
&sources_dir,
);
}
}

Expand Down
15 changes: 6 additions & 9 deletions crates/sozo/ops/src/migration/migrate.rs
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ use dojo_world::manifest::{
AbiFormat, BaseManifest, DeploymentManifest, DojoContract, DojoModel, Manifest,
ManifestMethods, WorldContract as ManifestWorldContract, WorldMetadata,
};
use dojo_world::metadata::{dojo_metadata_from_workspace, ArtifactMetadata};
use dojo_world::metadata::{dojo_metadata_from_workspace, ResourceMetadata};
use dojo_world::migration::class::ClassMigration;
use dojo_world::migration::contract::ContractMigration;
use dojo_world::migration::strategy::{generate_salt, prepare_for_migration, MigrationStrategy};
Expand Down Expand Up @@ -255,13 +255,12 @@ where
/// on success.
async fn upload_on_ipfs_and_create_resource(
ui: &Ui,
element_name: String,
resource_id: FieldElement,
artifact: ArtifactMetadata,
metadata: ResourceMetadata,
) -> Result<world::ResourceMetadata> {
match artifact.upload().await {
match metadata.upload().await {
Ok(hash) => {
ui.print_sub(format!("{}: ipfs://{}", element_name, hash));
ui.print_sub(format!("{}: ipfs://{}", metadata.name, hash));
create_resource_metadata(resource_id, hash)
}
Err(_) => Err(anyhow!("Failed to upload IPFS resource.")),
Expand Down Expand Up @@ -330,10 +329,9 @@ where
// models
if !migration_output.models.is_empty() {
for model_name in migration_output.models {
if let Some(m) = dojo_metadata.artifacts.get(&model_name) {
if let Some(m) = dojo_metadata.resources_artifacts.get(&model_name) {
ipfs.push(upload_on_ipfs_and_create_resource(
&ui,
model_name.clone(),
get_selector_from_name(&model_name).expect("ASCII model name"),
m.clone(),
));
Expand All @@ -346,10 +344,9 @@ where

if !migrated_contracts.is_empty() {
for contract in migrated_contracts {
if let Some(m) = dojo_metadata.artifacts.get(&contract.name) {
if let Some(m) = dojo_metadata.resources_artifacts.get(&contract.name) {
ipfs.push(upload_on_ipfs_and_create_resource(
&ui,
contract.name.clone(),
contract.contract_address,
m.clone(),
));
Expand Down
8 changes: 4 additions & 4 deletions crates/sozo/ops/src/tests/migration.rs
Original file line number Diff line number Diff line change
Expand Up @@ -484,19 +484,19 @@ async fn check_artifact_metadata<P: starknet::providers::Provider + Sync>(
) {
let resource = world_reader.metadata(&resource_id).call().await.unwrap();

let expected_artifact = dojo_metadata.artifacts.get(element_name);
let expected_resource = dojo_metadata.resources_artifacts.get(element_name);
assert!(
expected_artifact.is_some(),
expected_resource.is_some(),
"Unable to find local artifact metadata for {}",
element_name
);
let expected_artifact = expected_artifact.unwrap();
let expected_resource = expected_resource.unwrap();

check_ipfs_metadata(
client,
element_name,
&resource.metadata_uri.to_string().unwrap(),
expected_artifact,
&expected_resource.artifacts,
)
.await;
}
15 changes: 2 additions & 13 deletions crates/torii/core/src/processors/metadata_update.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,11 @@ use anyhow::{Error, Result};
use async_trait::async_trait;
use base64::engine::general_purpose;
use base64::Engine as _;
use cainome::cairo_serde::{ByteArray, CairoSerde};
use dojo_world::contracts::world::WorldContractReader;
use dojo_world::metadata::{Uri, WorldMetadata};
use reqwest::Client;
use starknet::core::types::{Event, MaybePendingTransactionReceipt};
use starknet::core::utils::parse_cairo_short_string;
use starknet::providers::Provider;
use starknet_crypto::FieldElement;
use tokio_util::bytes::Bytes;
Expand Down Expand Up @@ -58,18 +58,7 @@ where
event: &Event,
) -> Result<(), Error> {
let resource = &event.data[0];
let uri_len: u8 = event.data[1].try_into().unwrap();

let uri_str = if uri_len > 0 {
event.data[2..=uri_len as usize + 1]
.iter()
.map(parse_cairo_short_string)
.collect::<Result<Vec<_>, _>>()?
.concat()
} else {
"".to_string()
};

let uri_str = ByteArray::cairo_deserialize(&event.data, 1)?.to_string()?;
info!(
target: LOG_TARGET,
resource = %format!("{:#x}", resource),
Expand Down

0 comments on commit ae97033

Please sign in to comment.