summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--adenosine-cli/Cargo.toml1
-rw-r--r--adenosine-cli/src/bin/adenosine.rs44
-rw-r--r--adenosine-cli/src/lib.rs7
3 files changed, 32 insertions, 20 deletions
diff --git a/adenosine-cli/Cargo.toml b/adenosine-cli/Cargo.toml
index 24207fd..55ac268 100644
--- a/adenosine-cli/Cargo.toml
+++ b/adenosine-cli/Cargo.toml
@@ -25,6 +25,7 @@ lazy_static = "*"
dotenv = "*"
data-encoding = "*"
rand = "*"
+time = { version = "*", features = ["formatting"] }
# uncertain about these...
anyhow = "1.0"
diff --git a/adenosine-cli/src/bin/adenosine.rs b/adenosine-cli/src/bin/adenosine.rs
index 0f04926..f593b11 100644
--- a/adenosine-cli/src/bin/adenosine.rs
+++ b/adenosine-cli/src/bin/adenosine.rs
@@ -117,8 +117,10 @@ enum RepoCommand {
#[derive(StructOpt)]
enum BskyCommand {
- /// Fetch the home feed, or account feed for a specific user
+ /// Fetch the account feed for a specific user (or self, by default)
Feed { name: Option<DidOrHost> },
+ /// Fetch timeline for currently logged-in account
+ Timeline,
/// Fetch notification feed
Notifications,
/// Create a new 'post' record
@@ -127,9 +129,9 @@ enum BskyCommand {
Repost { uri: AtUri },
/// Create a 'like' record for the target by AT URI
Like { uri: AtUri },
- // TODO: Repost { uri: String, },
/// Create a 'follow' record for the target by AT URI
Follow { uri: DidOrHost },
+ // TODO: Unlike { uri: String, },
// TODO: Unfollow { uri: String, },
/* TODO:
Follows {
@@ -302,7 +304,6 @@ fn run(opt: Opt) -> Result<()> {
xrpc_client.get(&Nsid::from_str("com.atproto.repo.describe")?, Some(params))?
}
Command::Resolve { name } => {
- let mut params: HashMap<String, String> = HashMap::new();
params.insert("name".to_string(), name.to_string());
xrpc_client.get(&Nsid::from_str("com.atproto.handle.resolve")?, Some(params))?
}
@@ -319,7 +320,7 @@ fn run(opt: Opt) -> Result<()> {
if let Some(c) = cid {
params.insert("cid".to_string(), c);
}
- xrpc_client.get(&Nsid::from_str("com.atproto.repoGetRecord")?, Some(params))?
+ xrpc_client.get(&Nsid::from_str("com.atproto.repo.getRecord")?, Some(params))?
}
Command::Ls { uri } => {
// TODO: option to print fully-qualified path?
@@ -345,7 +346,7 @@ fn run(opt: Opt) -> Result<()> {
params.insert("collection".to_string(), uri.collection.unwrap());
let records = xrpc_client
.get(
- &Nsid::from_str("com.atproto.repoListRecords")?,
+ &Nsid::from_str("com.atproto.repo.listRecords")?,
Some(params),
)?
.ok_or(anyhow!("expected a repoListRecords response"))?;
@@ -515,19 +516,22 @@ fn run(opt: Opt) -> Result<()> {
Command::Bsky {
cmd: BskyCommand::Feed { name },
} => {
- if let Some(name) = name {
- params.insert("author".to_string(), name.to_string());
- xrpc_client.get(
- &Nsid::from_str("app.bsky.feed.getAuthorFeed")?,
- Some(params),
- )?
- } else {
- xrpc_client.get(&Nsid::from_str("app.bsky.feed.getTimeline")?, None)?
- }
+ // TODO: not expect here
+ let name = name
+ .map(|v| v.to_string())
+ .unwrap_or(jwt_did.expect("feed name or logged in"));
+ params.insert("author".to_string(), name.to_string());
+ xrpc_client.get(
+ &Nsid::from_str("app.bsky.feed.getAuthorFeed")?,
+ Some(params),
+ )?
}
Command::Bsky {
+ cmd: BskyCommand::Timeline,
+ } => xrpc_client.get(&Nsid::from_str("app.bsky.feed.getTimeline")?, None)?,
+ Command::Bsky {
cmd: BskyCommand::Notifications,
- } => xrpc_client.get(&Nsid::from_str("app.bsky.getNotifications")?, None)?,
+ } => xrpc_client.get(&Nsid::from_str("app.bsky.notifications.get")?, None)?,
Command::Bsky {
cmd: BskyCommand::Post { text },
} => {
@@ -557,7 +561,7 @@ fn run(opt: Opt) -> Result<()> {
Some(params),
Some(json!({
"subject": uri.to_string(),
- // TODO: "createdAt": now_timestamp(),
+ "createdAt": created_at_now(),
})),
)?
}
@@ -573,8 +577,8 @@ fn run(opt: Opt) -> Result<()> {
&Nsid::from_str("com.atproto.repo.createRecord")?,
Some(params),
Some(json!({
- "subject": uri.to_string(),
- // TODO: "createdAt": now_timestamp(),
+ "subject": { "uri": uri.to_string(), "cid": "TODO" },
+ "createdAt": created_at_now(),
})),
)?
}
@@ -593,8 +597,8 @@ fn run(opt: Opt) -> Result<()> {
&Nsid::from_str("com.atproto.repo.createRecord")?,
Some(params),
Some(json!({
- "subject": uri.to_string(),
- // TODO: "createdAt": now_timestamp(),
+ "subject": { "did": uri.to_string() },
+ "createdAt": created_at_now(),
})),
)?
}
diff --git a/adenosine-cli/src/lib.rs b/adenosine-cli/src/lib.rs
index aed8480..ce08078 100644
--- a/adenosine-cli/src/lib.rs
+++ b/adenosine-cli/src/lib.rs
@@ -315,3 +315,10 @@ pub fn value_from_fields(fields: Vec<ArgField>) -> Value {
}
Value::Object(serde_json::map::Map::from_iter(map.into_iter()))
}
+
+/// Helper to generate the current timestamp as right now, UTC, formatted as a string
+pub fn created_at_now() -> String {
+ let now = time::OffsetDateTime::now_utc();
+ now.format(&time::format_description::well_known::Rfc3339)
+ .unwrap()
+}