mirror of
https://gitlab.com/comunic/comunicapiv3
synced 2025-01-01 00:18:50 +00:00
Can update following status of a conversation
This commit is contained in:
parent
fad9300771
commit
b15a09cf07
@ -66,7 +66,14 @@ pub fn update_settings(r: &mut HttpRequestHandler) -> RequestResult {
|
|||||||
let conv_id = r.post_conv_id("conversationID")?;
|
let conv_id = r.post_conv_id("conversationID")?;
|
||||||
let is_moderator = conversations_helper::is_user_moderator(r.user_id()?, conv_id)?;
|
let is_moderator = conversations_helper::is_user_moderator(r.user_id()?, conv_id)?;
|
||||||
|
|
||||||
println!("conv id: {} / is moderator: {}", conv_id, is_moderator);
|
// Update following state, if required
|
||||||
|
if r.has_post_parameter("following") {
|
||||||
|
conversations_helper::set_following(
|
||||||
|
r.user_id()?,
|
||||||
|
conv_id,
|
||||||
|
r.post_bool("following")?
|
||||||
|
)?;
|
||||||
|
}
|
||||||
|
|
||||||
r.success("implement it")
|
r.success("Conversation information successfully updated!")
|
||||||
}
|
}
|
@ -115,6 +115,15 @@ pub fn is_user_moderator(user_id: UserID, conv_id: u64) -> ResultBoxError<bool>
|
|||||||
.exec_count()? > 0)
|
.exec_count()? > 0)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Set whether a user is following a conversation or not
|
||||||
|
pub fn set_following(user_id: UserID, conv_id: u64, following: bool) -> ResultBoxError<()> {
|
||||||
|
database::UpdateInfo::new(CONV_USERS_TABLE)
|
||||||
|
.cond_u64("conv_id", conv_id)
|
||||||
|
.cond_user_id("user_id", user_id)
|
||||||
|
.set_legacy_bool("following", following)
|
||||||
|
.exec()
|
||||||
|
}
|
||||||
|
|
||||||
/// Turn a database entry into a ConversationInfo object
|
/// Turn a database entry into a ConversationInfo object
|
||||||
fn db_to_conversation_info(row: &database::RowResult) -> ResultBoxError<Conversation> {
|
fn db_to_conversation_info(row: &database::RowResult) -> ResultBoxError<Conversation> {
|
||||||
let conv_id = row.get_u64("id")?;
|
let conv_id = row.get_u64("id")?;
|
||||||
|
@ -530,3 +530,88 @@ pub fn delete(query: DeleteQuery) -> ResultBoxError<()> {
|
|||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub struct UpdateInfo {
|
||||||
|
table: String,
|
||||||
|
cond: HashMap<String, Value>,
|
||||||
|
set: HashMap<String, Value>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl UpdateInfo {
|
||||||
|
/// Prepare a new update query
|
||||||
|
pub fn new(table: &str) -> UpdateInfo {
|
||||||
|
UpdateInfo {
|
||||||
|
table: table.to_string(),
|
||||||
|
cond: HashMap::new(),
|
||||||
|
set: HashMap::new(),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Filter with a user id
|
||||||
|
pub fn cond_user_id(mut self, name: &str, val: UserID) -> UpdateInfo {
|
||||||
|
self.cond.insert(name.to_string(), Value::Int(val));
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Filter with an unsigned integer
|
||||||
|
pub fn cond_u64(mut self, name: &str, val: u64) -> UpdateInfo {
|
||||||
|
self.cond.insert(name.to_string(), Value::UInt(val));
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Set a new legacy boolean
|
||||||
|
pub fn set_legacy_bool(mut self, name: &str, val: bool) -> UpdateInfo {
|
||||||
|
let num = match val {
|
||||||
|
false => 0,
|
||||||
|
true => 1,
|
||||||
|
};
|
||||||
|
|
||||||
|
self.set.insert(name.to_string(), Value::Int(num));
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Execute the update
|
||||||
|
pub fn exec(self) -> ResultBoxError<()> {
|
||||||
|
update(self)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Execute an update query
|
||||||
|
pub fn update(u: UpdateInfo) -> ResultBoxError<()> {
|
||||||
|
if u.cond.is_empty() {
|
||||||
|
Err(ExecError::boxed_new("Update without conditions blocked for security!"))?;
|
||||||
|
}
|
||||||
|
|
||||||
|
if u.set.is_empty() {
|
||||||
|
Err(ExecError::boxed_new("Update with no change specified useless!"))?;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
let mut query_sql = format!("UPDATE {} SET ", u.table);
|
||||||
|
let mut values = vec![];
|
||||||
|
|
||||||
|
// Prepare updates
|
||||||
|
let updates = u.set.keys()
|
||||||
|
.into_iter()
|
||||||
|
.map(|f| format!("{} = ?", f))
|
||||||
|
.collect::<Vec<String>>()
|
||||||
|
.join(", ");
|
||||||
|
u.set.values().into_iter().for_each(|f| values.push(f));
|
||||||
|
|
||||||
|
// Prepare conditions
|
||||||
|
let conditions = u.cond.keys()
|
||||||
|
.into_iter()
|
||||||
|
.map(|f| format!("{} = ?", f))
|
||||||
|
.collect::<Vec<String>>()
|
||||||
|
.join(" AND ");
|
||||||
|
u.cond.values().into_iter().for_each(|f| values.push(f));
|
||||||
|
|
||||||
|
query_sql = format!("{} {} WHERE {}", query_sql, updates, conditions);
|
||||||
|
|
||||||
|
get_connection()?.exec_drop(
|
||||||
|
query_sql,
|
||||||
|
values,
|
||||||
|
)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user