1
0

add card
All checks were successful
Gitea Actions Demo / Explore-Gitea-Actions (push) Successful in 10s

This commit is contained in:
syui 2024-11-08 19:44:17 +09:00
parent d2a394cec2
commit f4948f319e
Signed by: syui
GPG Key ID: 5417CFEBAD92DF56
2 changed files with 118 additions and 0 deletions

View File

@ -30,6 +30,7 @@ pub mod notify_read;
pub mod openai; pub mod openai;
pub mod post; pub mod post;
pub mod post_link; pub mod post_link;
pub mod post_card;
pub mod profile; pub mod profile;
pub mod refresh; pub mod refresh;
pub mod reply; pub mod reply;
@ -154,6 +155,35 @@ fn main() {
.alias("c"), .alias("c"),
) )
) )
.command(
Command::new("card")
.description("-v <at://verify> -i <int:id> -p <int:cp> -r <int:rank> -c <collection> -a <author>")
.action(card)
.flag(
Flag::new("id", FlagType::Int)
.alias("i"),
)
.flag(
Flag::new("cp", FlagType::Int)
.alias("p"),
)
.flag(
Flag::new("rank", FlagType::Int)
.alias("r"),
)
.flag(
Flag::new("col", FlagType::String)
.alias("c"),
)
.flag(
Flag::new("author", FlagType::String)
.alias("a"),
)
.flag(
Flag::new("verify", FlagType::String)
.alias("v"),
)
)
.command( .command(
Command::new("like") Command::new("like")
.description("like <cid> -u <uri>") .description("like <cid> -u <uri>")
@ -474,6 +504,48 @@ fn like(c: &Context) {
return res; return res;
} }
//fn card(c: &Context) {
// refresh(c);
// let m = c.args[0].to_string();
// let h = async {
// let author = c.string_flag("author").unwrap_or_else(|_| "syui".to_string());
// let verify = c.string_flag("verify").unwrap_or_else(|_| "at://did:plc:4hqjfn7m6n5hno3doamuhgef/app.bsky.feed.post/3lafcod6drd2c".to_string());
// let col = c.string_flag("col").unwrap_or_else(|_| "ai.syui.card".to_string());
// let id = c.int_flag("id")?.try_into()?;
// let cp = c.int_flag("cp")?.try_into()?;
// let rank = c.int_flag("rank")?.try_into()?;
// let str = post_card::post_request(m, id, cp, rank, col, author);
// println!("{}", str.await);
// };
// let res = tokio::runtime::Runtime::new().unwrap().block_on(h);
// return res;
//}
async fn c_card(c: &Context) -> Result<(), Box<dyn std::error::Error>> {
//let m = c.args[0].to_string();
let author = c.string_flag("author").unwrap_or_else(|_| "syui".to_string());
let verify = c.string_flag("verify").unwrap_or_else(|_| "at://did:plc:4hqjfn7m6n5hno3doamuhgef/app.bsky.feed.post/3lafcod6drd2c".to_string());
let col = c.string_flag("col").unwrap_or_else(|_| "ai.syui.card".to_string());
let rare = c.string_flag("rare").unwrap_or_else(|_| "normal".to_string());
let id = c.int_flag("id")?.try_into()?;
let cp = c.int_flag("cp")?.try_into()?;
let rank = c.int_flag("rank")?.try_into()?;
let str = post_card::post_request(verify, id, cp, rank, rare, col, author);
println!("{}", str.await);
Ok(())
}
fn card(c: &Context) {
refresh(c);
tokio::runtime::Runtime::new()
.unwrap()
.block_on(async {
if let Err(e) = c_card(c).await {
eprintln!("Error: {}", e);
}
});
}
fn repost(c: &Context) { fn repost(c: &Context) {
refresh(c); refresh(c);
let m = c.args[0].to_string(); let m = c.args[0].to_string();

46
src/post_card.rs Normal file
View File

@ -0,0 +1,46 @@
extern crate reqwest;
use crate::data_toml;
use crate::data_refresh;
use crate::url;
use iso8601_timestamp::Timestamp;
use serde_json::json;
pub async fn post_request(verify: String, id: i32, cp: i32, rank: i32, rare: String, col: String, author: String) -> String {
let token = data_refresh(&"access");
let did = data_toml(&"did");
let handle = data_toml(&"handle");
let url = url(&"record_create");
let d = Timestamp::now_utc();
let d = d.to_string();
let post = Some(json!({
"repo": handle.to_string(),
"did": did.to_string(),
"collection": col.to_string(),
"record": {
"id": id,
"cp": cp,
"rank": rank,
"rare": rare.to_string(),
"author": author.to_string(),
"verify": verify.to_string(),
"createdAt": d.to_string(),
},
}));
let client = reqwest::Client::new();
let res = client
.post(url)
.json(&post)
.header("Authorization", "Bearer ".to_owned() + &token)
.send()
.await
.unwrap()
.text()
.await
.unwrap();
return res;
}