trade_product.rs (5468B)
1 use radroots_replica_db_schema::trade_product::{ 2 ITradeProductCreate, ITradeProductCreateResolve, ITradeProductDelete, 3 ITradeProductDeleteResolve, ITradeProductFieldsFilter, ITradeProductFindMany, 4 ITradeProductFindManyResolve, ITradeProductFindOne, ITradeProductFindOneResolve, 5 ITradeProductUpdate, ITradeProductUpdateResolve, TradeProduct, TradeProductQueryBindValues, 6 }; 7 use radroots_sql_core::error::SqlError; 8 use radroots_sql_core::{SqlExecutor, utils}; 9 use radroots_types::types::{IError, IResult, IResultList}; 10 use serde_json::Value; 11 12 const TABLE_NAME: &str = "trade_product"; 13 14 pub fn create( 15 exec: &dyn SqlExecutor, 16 opts: &ITradeProductCreate, 17 ) -> Result<ITradeProductCreateResolve, IError<SqlError>> { 18 let field_map = utils::to_object_map(opts).expect("serialize object map"); 19 let id = utils::uuidv4(); 20 let now = utils::time_created_on(); 21 let meta: [(&str, Value); 3] = [ 22 ("id", Value::from(id.clone())), 23 ("created_at", Value::from(now.clone())), 24 ("updated_at", Value::from(now.clone())), 25 ]; 26 let (sql, bind_values) = utils::build_insert_query_with_meta(TABLE_NAME, &meta, &field_map); 27 let params_json = utils::to_params_json(bind_values).expect("serialize bind params"); 28 let _ = exec.exec(&sql, ¶ms_json)?; 29 let on = TradeProductQueryBindValues::Id { id: id.clone() }; 30 let result = find_one_by_on(exec, &on)?.ok_or(IError::from(SqlError::NotFound(id.clone())))?; 31 Ok(IResult { result }) 32 } 33 34 pub fn find_one( 35 exec: &dyn SqlExecutor, 36 opts: &ITradeProductFindOne, 37 ) -> Result<ITradeProductFindOneResolve, IError<SqlError>> { 38 let result = match opts { 39 ITradeProductFindOne::On(args) => find_one_by_on(exec, &args.on)?, 40 }; 41 Ok(IResult { result }) 42 } 43 44 pub fn find_many( 45 exec: &dyn SqlExecutor, 46 opts: &ITradeProductFindMany, 47 ) -> Result<ITradeProductFindManyResolve, IError<SqlError>> { 48 let results = find_many_filter(exec, &opts.filter)?; 49 Ok(IResultList { results }) 50 } 51 52 fn find_many_filter( 53 exec: &dyn SqlExecutor, 54 filter: &Option<ITradeProductFieldsFilter>, 55 ) -> Result<Vec<TradeProduct>, IError<SqlError>> { 56 let (sql, bind_values) = utils::build_select_query_with_meta(TABLE_NAME, filter.as_ref()); 57 let params_json = utils::to_params_json(bind_values).expect("serialize bind params"); 58 let json = exec.query_raw(&sql, ¶ms_json)?; 59 let rows: Vec<TradeProduct> = utils::parse_json(&json)?; 60 Ok(rows) 61 } 62 63 fn find_one_by_on( 64 exec: &dyn SqlExecutor, 65 on: &TradeProductQueryBindValues, 66 ) -> Result<Option<TradeProduct>, IError<SqlError>> { 67 let (column, value) = on.to_filter_param(); 68 let sql = format!("SELECT * FROM {TABLE_NAME} WHERE {column} = ? LIMIT 1;"); 69 let params_json = utils::to_params_json(vec![value]).expect("serialize bind params"); 70 let json = exec.query_raw(&sql, ¶ms_json)?; 71 let mut rows: Vec<TradeProduct> = utils::parse_json(&json)?; 72 Ok(rows.pop()) 73 } 74 75 fn select_by_id(exec: &dyn SqlExecutor, id: &str) -> Result<TradeProduct, IError<SqlError>> { 76 let params_json = 77 utils::to_params_json(vec![Value::from(id.to_owned())]).expect("serialize bind params"); 78 let sql = format!("SELECT * FROM {TABLE_NAME} WHERE id = ?;"); 79 let json = exec.query_raw(&sql, ¶ms_json)?; 80 let mut rows: Vec<TradeProduct> = utils::parse_json(&json)?; 81 rows.pop() 82 .ok_or(IError::from(SqlError::NotFound(id.to_owned()))) 83 } 84 85 pub fn update( 86 exec: &dyn SqlExecutor, 87 opts: &ITradeProductUpdate, 88 ) -> Result<ITradeProductUpdateResolve, IError<SqlError>> { 89 let mut updates = 90 utils::to_partial_object_map(&opts.fields).expect("serialize partial object map"); 91 if updates.is_empty() { 92 return Err(IError::from(SqlError::InvalidArgument(String::from( 93 "no fields to update", 94 )))); 95 } 96 updates.insert( 97 String::from("updated_at"), 98 Value::from(utils::time_created_on()), 99 ); 100 let mut set_parts = Vec::with_capacity(updates.len()); 101 let mut bind_values = Vec::with_capacity(updates.len() + 1); 102 for (column, value) in updates { 103 set_parts.push(format!("{column} = ?")); 104 bind_values.push(utils::to_db_bind_value(&value)); 105 } 106 let id_for_lookup = match &opts.on { 107 TradeProductQueryBindValues::Id { id } => id.clone(), 108 }; 109 bind_values.push(Value::from(id_for_lookup.clone())); 110 let sql = format!( 111 "UPDATE {TABLE_NAME} SET {} WHERE id = ?;", 112 set_parts.join(", ") 113 ); 114 let params_json = utils::to_params_json(bind_values).expect("serialize bind params"); 115 let _ = exec.exec(&sql, ¶ms_json)?; 116 let updated = select_by_id(exec, &id_for_lookup)?; 117 Ok(IResult { result: updated }) 118 } 119 120 pub fn delete( 121 exec: &dyn SqlExecutor, 122 opts: &ITradeProductDelete, 123 ) -> Result<ITradeProductDeleteResolve, IError<SqlError>> { 124 let id_for_lookup = match opts { 125 ITradeProductDelete::On(args) => match &args.on { 126 TradeProductQueryBindValues::Id { id } => id.clone(), 127 }, 128 }; 129 let params_json = utils::to_params_json(vec![Value::from(id_for_lookup.clone())]) 130 .expect("serialize bind params"); 131 let sql = format!("DELETE FROM {TABLE_NAME} WHERE id = ?;"); 132 let outcome = exec.exec(&sql, ¶ms_json)?; 133 if outcome.changes == 0 { 134 return Err(IError::from(SqlError::NotFound(id_for_lookup.clone()))); 135 } 136 Ok(IResult { 137 result: id_for_lookup, 138 }) 139 }