parent
92fb8f54ce
commit
9e36add6f9
79
validation/src/create.rs
Normal file
79
validation/src/create.rs
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
use crate::rbx_util::{get_mapinfo,read_dom,MapInfo,ReadDomError,GetMapInfoError,ParseGameIDError};
|
||||||
|
|
||||||
|
#[allow(dead_code)]
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub enum Error{
|
||||||
|
ModelVersionsPage(rbx_asset::cookie::PageError),
|
||||||
|
EmptyVersionsPage,
|
||||||
|
WrongCreatorType,
|
||||||
|
ModelFileDownload(rbx_asset::cookie::GetError),
|
||||||
|
ModelFileDecode(ReadDomError),
|
||||||
|
GetMapInfo(GetMapInfoError),
|
||||||
|
ParseGameID(ParseGameIDError),
|
||||||
|
}
|
||||||
|
impl std::fmt::Display for Error{
|
||||||
|
fn fmt(&self,f:&mut std::fmt::Formatter<'_>)->std::fmt::Result{
|
||||||
|
write!(f,"{self:?}")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
impl std::error::Error for Error{}
|
||||||
|
|
||||||
|
#[allow(nonstandard_style)]
|
||||||
|
pub struct CreateRequest{
|
||||||
|
pub ModelID:u64,
|
||||||
|
}
|
||||||
|
#[allow(nonstandard_style)]
|
||||||
|
pub struct CreateResult{
|
||||||
|
pub AssetOwner:i64,
|
||||||
|
pub DisplayName:String,
|
||||||
|
pub Creator:String,
|
||||||
|
pub GameID:i32,
|
||||||
|
pub AssetID:u64,
|
||||||
|
pub AssetVersion:u64,
|
||||||
|
}
|
||||||
|
impl crate::message_handler::MessageHandler{
|
||||||
|
pub async fn create_inner(&self,create_info:CreateRequest)->Result<CreateResult,Error>{
|
||||||
|
// discover the latest asset version
|
||||||
|
let asset_versions_page=self.cookie_context.get_asset_versions_page(rbx_asset::cookie::AssetVersionsPageRequest{
|
||||||
|
asset_id:create_info.ModelID,
|
||||||
|
cursor:None
|
||||||
|
}).await.map_err(Error::ModelVersionsPage)?;
|
||||||
|
|
||||||
|
// grab version info
|
||||||
|
let first_version=asset_versions_page.data.first().ok_or(Error::EmptyVersionsPage)?;
|
||||||
|
|
||||||
|
if first_version.creatorType!="User"{
|
||||||
|
return Err(Error::WrongCreatorType);
|
||||||
|
}
|
||||||
|
|
||||||
|
let asset_creator_id=first_version.creatorTargetId;
|
||||||
|
let asset_version=first_version.assetVersionNumber;
|
||||||
|
|
||||||
|
// download the map model version
|
||||||
|
let model_data=self.cookie_context.get_asset(rbx_asset::cookie::GetAssetRequest{
|
||||||
|
asset_id:create_info.ModelID,
|
||||||
|
version:Some(asset_version),
|
||||||
|
}).await.map_err(Error::ModelFileDownload)?;
|
||||||
|
|
||||||
|
// decode dom (slow!)
|
||||||
|
let dom=read_dom(&mut std::io::Cursor::new(model_data)).map_err(Error::ModelFileDecode)?;
|
||||||
|
|
||||||
|
// parse create fields out of asset
|
||||||
|
let MapInfo{
|
||||||
|
display_name,
|
||||||
|
creator,
|
||||||
|
game_id,
|
||||||
|
}=get_mapinfo(&dom).map_err(Error::GetMapInfo)?;
|
||||||
|
|
||||||
|
let game_id=game_id.map_err(Error::ParseGameID)?;
|
||||||
|
|
||||||
|
Ok(CreateResult{
|
||||||
|
AssetOwner:asset_creator_id as i64,
|
||||||
|
DisplayName:display_name.unwrap_or_default().to_owned(),
|
||||||
|
Creator:creator.unwrap_or_default().to_owned(),
|
||||||
|
GameID:game_id as i32,
|
||||||
|
AssetID:create_info.ModelID,
|
||||||
|
AssetVersion:asset_version,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
@ -1,16 +1,9 @@
|
|||||||
use crate::nats_types::CreateMapfixRequest;
|
use crate::nats_types::CreateMapfixRequest;
|
||||||
use crate::rbx_util::{MapInfo,get_mapinfo,read_dom,ReadDomError,GetMapInfoError,ParseGameIDError};
|
use crate::create::CreateRequest;
|
||||||
|
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub enum Error{
|
pub enum Error{
|
||||||
ModelVersionsPage(rbx_asset::cookie::PageError),
|
|
||||||
EmptyVersionsPage,
|
|
||||||
WrongCreatorType,
|
|
||||||
ModelFileDownload(rbx_asset::cookie::GetError),
|
|
||||||
ModelFileDecode(ReadDomError),
|
|
||||||
GetMapInfo(GetMapInfoError),
|
|
||||||
ParseGameID(ParseGameIDError),
|
|
||||||
ApiActionMapfixCreate(submissions_api::Error),
|
ApiActionMapfixCreate(submissions_api::Error),
|
||||||
}
|
}
|
||||||
impl std::fmt::Display for Error{
|
impl std::fmt::Display for Error{
|
||||||
@ -22,52 +15,29 @@ impl std::error::Error for Error{}
|
|||||||
|
|
||||||
impl crate::message_handler::MessageHandler{
|
impl crate::message_handler::MessageHandler{
|
||||||
pub async fn create_mapfix(&self,create_info:CreateMapfixRequest)->Result<(),Error>{
|
pub async fn create_mapfix(&self,create_info:CreateMapfixRequest)->Result<(),Error>{
|
||||||
// discover the latest asset version
|
let create_result=self.create_inner(CreateRequest{
|
||||||
let asset_versions_page=self.cookie_context.get_asset_versions_page(rbx_asset::cookie::AssetVersionsPageRequest{
|
ModelID:create_info.ModelID,
|
||||||
asset_id:create_info.ModelID,
|
}).await;
|
||||||
cursor:None
|
|
||||||
}).await.map_err(Error::ModelVersionsPage)?;
|
|
||||||
|
|
||||||
// grab version info
|
match create_result{
|
||||||
let first_version=asset_versions_page.data.first().ok_or(Error::EmptyVersionsPage)?;
|
Ok(create_request)=>{
|
||||||
|
// call create on api
|
||||||
if first_version.creatorType!="User"{
|
self.api.create_mapfix(submissions_api::types::CreateMapfixRequest{
|
||||||
return Err(Error::WrongCreatorType);
|
OperationID:create_info.OperationID,
|
||||||
|
AssetOwner:create_request.AssetOwner,
|
||||||
|
DisplayName:create_request.DisplayName.as_str(),
|
||||||
|
Creator:create_request.Creator.as_str(),
|
||||||
|
GameID:create_request.GameID,
|
||||||
|
AssetID:create_request.AssetID,
|
||||||
|
AssetVersion:create_request.AssetVersion,
|
||||||
|
TargetAssetID:create_info.TargetAssetID,
|
||||||
|
}).await.map_err(Error::ApiActionMapfixCreate)?;
|
||||||
|
},
|
||||||
|
Err(e)=>{
|
||||||
|
println!("oh no! {e}");
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
let asset_creator_id=first_version.creatorTargetId;
|
|
||||||
let asset_version=first_version.assetVersionNumber;
|
|
||||||
|
|
||||||
// download the map model version
|
|
||||||
let model_data=self.cookie_context.get_asset(rbx_asset::cookie::GetAssetRequest{
|
|
||||||
asset_id:create_info.ModelID,
|
|
||||||
version:Some(asset_version),
|
|
||||||
}).await.map_err(Error::ModelFileDownload)?;
|
|
||||||
|
|
||||||
// decode dom (slow!)
|
|
||||||
let dom=read_dom(&mut std::io::Cursor::new(model_data)).map_err(Error::ModelFileDecode)?;
|
|
||||||
|
|
||||||
// parse create fields out of asset
|
|
||||||
let MapInfo{
|
|
||||||
display_name,
|
|
||||||
creator,
|
|
||||||
game_id,
|
|
||||||
}=get_mapinfo(&dom).map_err(Error::GetMapInfo)?;
|
|
||||||
|
|
||||||
let game_id=game_id.map_err(Error::ParseGameID)?;
|
|
||||||
|
|
||||||
// call create on api
|
|
||||||
self.api.create_mapfix(submissions_api::types::CreateMapfixRequest{
|
|
||||||
OperationID:create_info.OperationID,
|
|
||||||
AssetOwner:asset_creator_id as i64,
|
|
||||||
DisplayName:display_name.unwrap_or_default(),
|
|
||||||
Creator:creator.unwrap_or_default(),
|
|
||||||
GameID:game_id as i32,
|
|
||||||
AssetID:create_info.ModelID,
|
|
||||||
AssetVersion:asset_version,
|
|
||||||
TargetAssetID:create_info.TargetAssetID,
|
|
||||||
}).await.map_err(Error::ApiActionMapfixCreate)?;
|
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,16 +1,9 @@
|
|||||||
use crate::nats_types::CreateSubmissionRequest;
|
use crate::nats_types::CreateSubmissionRequest;
|
||||||
use crate::rbx_util::{MapInfo,get_mapinfo,read_dom,ReadDomError,GetMapInfoError,ParseGameIDError};
|
use crate::create::CreateRequest;
|
||||||
|
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub enum Error{
|
pub enum Error{
|
||||||
ModelVersionsPage(rbx_asset::cookie::PageError),
|
|
||||||
EmptyVersionsPage,
|
|
||||||
WrongCreatorType,
|
|
||||||
ModelFileDownload(rbx_asset::cookie::GetError),
|
|
||||||
ModelFileDecode(ReadDomError),
|
|
||||||
GetMapInfo(GetMapInfoError),
|
|
||||||
ParseGameID(ParseGameIDError),
|
|
||||||
ApiActionSubmissionCreate(submissions_api::Error),
|
ApiActionSubmissionCreate(submissions_api::Error),
|
||||||
}
|
}
|
||||||
impl std::fmt::Display for Error{
|
impl std::fmt::Display for Error{
|
||||||
@ -22,51 +15,28 @@ impl std::error::Error for Error{}
|
|||||||
|
|
||||||
impl crate::message_handler::MessageHandler{
|
impl crate::message_handler::MessageHandler{
|
||||||
pub async fn create_submission(&self,create_info:CreateSubmissionRequest)->Result<(),Error>{
|
pub async fn create_submission(&self,create_info:CreateSubmissionRequest)->Result<(),Error>{
|
||||||
// discover the latest asset version
|
let create_result=self.create_inner(CreateRequest{
|
||||||
let asset_versions_page=self.cookie_context.get_asset_versions_page(rbx_asset::cookie::AssetVersionsPageRequest{
|
ModelID:create_info.ModelID,
|
||||||
asset_id:create_info.ModelID,
|
}).await;
|
||||||
cursor:None
|
|
||||||
}).await.map_err(Error::ModelVersionsPage)?;
|
|
||||||
|
|
||||||
// grab version info
|
match create_result{
|
||||||
let first_version=asset_versions_page.data.first().ok_or(Error::EmptyVersionsPage)?;
|
Ok(create_request)=>{
|
||||||
|
// call create on api
|
||||||
if first_version.creatorType!="User"{
|
self.api.create_submission(submissions_api::types::CreateSubmissionRequest{
|
||||||
return Err(Error::WrongCreatorType);
|
OperationID:create_info.OperationID,
|
||||||
|
AssetOwner:create_request.AssetOwner,
|
||||||
|
DisplayName:create_request.DisplayName.as_str(),
|
||||||
|
Creator:create_request.Creator.as_str(),
|
||||||
|
GameID:create_request.GameID,
|
||||||
|
AssetID:create_request.AssetID,
|
||||||
|
AssetVersion:create_request.AssetVersion,
|
||||||
|
}).await.map_err(Error::ApiActionSubmissionCreate)?;
|
||||||
|
},
|
||||||
|
Err(e)=>{
|
||||||
|
println!("oh no! {e}");
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
let asset_creator_id=first_version.creatorTargetId;
|
|
||||||
let asset_version=first_version.assetVersionNumber;
|
|
||||||
|
|
||||||
// download the map model version
|
|
||||||
let model_data=self.cookie_context.get_asset(rbx_asset::cookie::GetAssetRequest{
|
|
||||||
asset_id:create_info.ModelID,
|
|
||||||
version:Some(asset_version),
|
|
||||||
}).await.map_err(Error::ModelFileDownload)?;
|
|
||||||
|
|
||||||
// decode dom (slow!)
|
|
||||||
let dom=read_dom(&mut std::io::Cursor::new(model_data)).map_err(Error::ModelFileDecode)?;
|
|
||||||
|
|
||||||
// parse create fields out of asset
|
|
||||||
let MapInfo{
|
|
||||||
display_name,
|
|
||||||
creator,
|
|
||||||
game_id,
|
|
||||||
}=get_mapinfo(&dom).map_err(Error::GetMapInfo)?;
|
|
||||||
|
|
||||||
let game_id=game_id.map_err(Error::ParseGameID)?;
|
|
||||||
|
|
||||||
// call create on api
|
|
||||||
self.api.create_submission(submissions_api::types::CreateSubmissionRequest{
|
|
||||||
OperationID:create_info.OperationID,
|
|
||||||
AssetOwner:asset_creator_id as i64,
|
|
||||||
DisplayName:display_name.unwrap_or_default(),
|
|
||||||
Creator:creator.unwrap_or_default(),
|
|
||||||
GameID:game_id as i32,
|
|
||||||
AssetID:create_info.ModelID,
|
|
||||||
AssetVersion:asset_version,
|
|
||||||
}).await.map_err(Error::ApiActionSubmissionCreate)?;
|
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,7 @@ mod rbx_util;
|
|||||||
mod message_handler;
|
mod message_handler;
|
||||||
mod nats_types;
|
mod nats_types;
|
||||||
mod types;
|
mod types;
|
||||||
|
mod create;
|
||||||
mod create_mapfix;
|
mod create_mapfix;
|
||||||
mod create_submission;
|
mod create_submission;
|
||||||
mod upload_mapfix;
|
mod upload_mapfix;
|
||||||
|
@ -19,6 +19,8 @@ impl std::fmt::Display for HandleMessageError{
|
|||||||
}
|
}
|
||||||
impl std::error::Error for HandleMessageError{}
|
impl std::error::Error for HandleMessageError{}
|
||||||
|
|
||||||
|
// TODO: update operation on failure
|
||||||
|
|
||||||
pub type MessageResult=Result<async_nats::jetstream::Message,async_nats::jetstream::consumer::pull::MessagesError>;
|
pub type MessageResult=Result<async_nats::jetstream::Message,async_nats::jetstream::consumer::pull::MessagesError>;
|
||||||
|
|
||||||
fn from_slice<'a,T:serde::de::Deserialize<'a>>(slice:&'a [u8])->Result<T,HandleMessageError>{
|
fn from_slice<'a,T:serde::de::Deserialize<'a>>(slice:&'a [u8])->Result<T,HandleMessageError>{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user