Upsert Media in from_activity()
This commit is contained in:
parent
462c5a1d42
commit
ea1f4d48d5
@ -19,7 +19,7 @@ use url::Url;
|
|||||||
|
|
||||||
const REMOTE_MEDIA_DIRECTORY: &str = "remote";
|
const REMOTE_MEDIA_DIRECTORY: &str = "remote";
|
||||||
|
|
||||||
#[derive(Clone, Identifiable, Queryable)]
|
#[derive(Clone, Identifiable, Queryable, AsChangeset)]
|
||||||
pub struct Media {
|
pub struct Media {
|
||||||
pub id: i32,
|
pub id: i32,
|
||||||
pub file_path: String,
|
pub file_path: String,
|
||||||
@ -225,7 +225,39 @@ impl Media {
|
|||||||
.copy_to(&mut dest)
|
.copy_to(&mut dest)
|
||||||
.ok()?;
|
.ok()?;
|
||||||
|
|
||||||
// TODO: upsert
|
Media::find_by_file_path(conn, &path.to_str()?)
|
||||||
|
.and_then(|mut media| {
|
||||||
|
let mut updated = false;
|
||||||
|
|
||||||
|
let alt_text = image.object_props.content_string().ok()?;
|
||||||
|
let sensitive = image.object_props.summary_string().is_ok();
|
||||||
|
let content_warning = image.object_props.summary_string().ok();
|
||||||
|
if media.alt_text != alt_text {
|
||||||
|
media.alt_text = alt_text;
|
||||||
|
updated = true;
|
||||||
|
}
|
||||||
|
if media.is_remote {
|
||||||
|
media.is_remote = false;
|
||||||
|
updated = true;
|
||||||
|
}
|
||||||
|
if media.remote_url.is_some() {
|
||||||
|
media.remote_url = None;
|
||||||
|
updated = true;
|
||||||
|
}
|
||||||
|
if media.sensitive != sensitive {
|
||||||
|
media.sensitive = sensitive;
|
||||||
|
updated = true;
|
||||||
|
}
|
||||||
|
if media.content_warning != content_warning {
|
||||||
|
media.content_warning = content_warning;
|
||||||
|
updated = true;
|
||||||
|
}
|
||||||
|
if updated {
|
||||||
|
diesel::update(&media).set(&media).execute(&**conn)?;
|
||||||
|
}
|
||||||
|
Ok(media)
|
||||||
|
})
|
||||||
|
.or_else(|_| {
|
||||||
Media::insert(
|
Media::insert(
|
||||||
conn,
|
conn,
|
||||||
NewMedia {
|
NewMedia {
|
||||||
@ -251,6 +283,7 @@ impl Media {
|
|||||||
.id,
|
.id,
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get_media_processor<'a>(conn: &'a Connection, user: Vec<&User>) -> MediaProcessor<'a> {
|
pub fn get_media_processor<'a>(conn: &'a Connection, user: Vec<&User>) -> MediaProcessor<'a> {
|
||||||
|
Loading…
Reference in New Issue
Block a user