diff options
author | 2025-03-03 06:10:46 +0000 | |
---|---|---|
committer | 2025-03-03 06:11:47 +0000 | |
commit | 9baf682466d191f23dc830a9897948d84068b3cc (patch) | |
tree | 45382f3793459502e53d73cf72e52ee2da8cd0d0 | |
parent | 542a8e299c7bfe85419d52120bdc3d7a92dcfe38 (diff) | |
download | luz-9baf682466d191f23dc830a9897948d84068b3cc.tar.gz luz-9baf682466d191f23dc830a9897948d84068b3cc.tar.bz2 luz-9baf682466d191f23dc830a9897948d84068b3cc.zip |
feat(luz): initial message timestamp support
-rw-r--r-- | luz/Cargo.toml | 3 | ||||
-rw-r--r-- | luz/migrations/20240113011930_luz.sql | 1 | ||||
-rw-r--r-- | luz/src/chat.rs | 2 | ||||
-rw-r--r-- | luz/src/connection/read.rs | 2 | ||||
-rw-r--r-- | luz/src/db/mod.rs | 11 | ||||
-rw-r--r-- | luz/src/lib.rs | 2 | ||||
-rw-r--r-- | luz/src/main.rs | 2 |
7 files changed, 16 insertions, 7 deletions
diff --git a/luz/Cargo.toml b/luz/Cargo.toml index 90d321c..d6920e9 100644 --- a/luz/Cargo.toml +++ b/luz/Cargo.toml @@ -8,7 +8,7 @@ futures = "0.3.31" jabber = { version = "0.1.0", path = "../jabber" } peanuts = { version = "0.1.0", path = "../../peanuts" } jid = { version = "0.1.0", path = "../jid", features = ["sqlx"] } -sqlx = { version = "0.8.3", features = ["sqlite", "runtime-tokio", "uuid"] } +sqlx = { version = "0.8.3", features = ["sqlite", "runtime-tokio", "uuid", "chrono"] } stanza = { version = "0.1.0", path = "../stanza" } tokio = "1.42.0" tokio-stream = "0.1.17" @@ -17,3 +17,4 @@ tracing = "0.1.41" tracing-subscriber = "0.3.19" uuid = { version = "1.13.1", features = ["v4"] } thiserror = "2.0.11" +chrono = "0.4.40" diff --git a/luz/migrations/20240113011930_luz.sql b/luz/migrations/20240113011930_luz.sql index 7b33dd3..148598b 100644 --- a/luz/migrations/20240113011930_luz.sql +++ b/luz/migrations/20240113011930_luz.sql @@ -83,6 +83,7 @@ create table messages ( -- user is the current "owner" of the message -- TODO: queued messages offline -- TODO: timestamp + timestamp text not null, -- TODO: icky -- the user to show it coming from (not necessarily the original sender) diff --git a/luz/src/chat.rs b/luz/src/chat.rs index 8bb81db..97518da 100644 --- a/luz/src/chat.rs +++ b/luz/src/chat.rs @@ -1,3 +1,4 @@ +use chrono::{DateTime, Utc}; use jid::JID; use uuid::Uuid; @@ -7,6 +8,7 @@ pub struct Message { // does not contain full user information #[sqlx(rename = "from_jid")] pub from: JID, + pub timestamp: DateTime<Utc>, // TODO: originally_from // TODO: message edits // TODO: message timestamp diff --git a/luz/src/connection/read.rs b/luz/src/connection/read.rs index aadf476..80322ce 100644 --- a/luz/src/connection/read.rs +++ b/luz/src/connection/read.rs @@ -6,6 +6,7 @@ use std::{ time::Duration, }; +use chrono::{DateTime, Utc}; use jabber::{connection::Tls, jabber_stream::bound_stream::BoundJabberReader}; use stanza::client::Stanza; use tokio::{ @@ -188,6 +189,7 @@ async fn handle_stanza( .map(|id| Uuid::from_str(&id).unwrap_or_else(|_| Uuid::new_v4())) .unwrap_or_else(|| Uuid::new_v4()), from: from.clone(), + timestamp: Utc::now(), body: Body { // TODO: should this be an option? body: stanza_message diff --git a/luz/src/db/mod.rs b/luz/src/db/mod.rs index 9f12ef3..673ba48 100644 --- a/luz/src/db/mod.rs +++ b/luz/src/db/mod.rs @@ -358,7 +358,7 @@ impl Db { let bare_jid = message.from.as_bare(); let resource = message.from.resourcepart; let chat_id = self.read_chat_id(chat).await?; - sqlx::query!("insert into messages (id, body, chat_id, from_jid, from_resource) values (?, ?, ?, ?, ?)", message.id, message.body.body, chat_id, bare_jid, resource).execute(&self.db).await?; + sqlx::query!("insert into messages (id, body, chat_id, from_jid, from_resource, timestamp) values (?, ?, ?, ?, ?, ?)", message.id, message.body.body, chat_id, bare_jid, resource, message.timestamp).execute(&self.db).await?; Ok(()) } @@ -452,10 +452,11 @@ impl Db { // TODO: paging pub(crate) async fn read_message_history(&self, chat: JID) -> Result<Vec<Message>, Error> { let chat_id = self.read_chat_id(chat).await?; - let messages: Vec<Message> = sqlx::query_as("select * from messages where chat_id = ?") - .bind(chat_id) - .fetch_all(&self.db) - .await?; + let messages: Vec<Message> = + sqlx::query_as("select * from messages where chat_id = ? order by timestamp asc") + .bind(chat_id) + .fetch_all(&self.db) + .await?; Ok(messages) } diff --git a/luz/src/lib.rs b/luz/src/lib.rs index 0bbccf9..c84d5ff 100644 --- a/luz/src/lib.rs +++ b/luz/src/lib.rs @@ -6,6 +6,7 @@ use std::{ }; use chat::{Body, Chat, Message}; +use chrono::Utc; use connection::{write::WriteMessage, SupervisorSender}; use db::Db; use error::{ @@ -996,6 +997,7 @@ impl CommandMessage { id, from: owned_jid, body, + timestamp: Utc::now(), }; info!("send message {:?}", message); if let Err(e) = db diff --git a/luz/src/main.rs b/luz/src/main.rs index 4b74b39..2bfd086 100644 --- a/luz/src/main.rs +++ b/luz/src/main.rs @@ -16,7 +16,7 @@ async fn main() { .await .unwrap(); let (luz, mut recv) = - LuzHandle::new("test@blos.sm".try_into().unwrap(), "slayed".to_string(), db).unwrap(); + LuzHandle::new("test@blos.sm".try_into().unwrap(), "slayed".to_string(), db); tokio::spawn(async move { while let Some(msg) = recv.recv().await { |