diff --git a/.config/ai/scpt b/.config/ai/scpt index 69a235a..1ef6386 160000 --- a/.config/ai/scpt +++ b/.config/ai/scpt @@ -1 +1 @@ -Subproject commit 69a235a0aa7c9965de1d76a70f35099fcdcbedf5 +Subproject commit 1ef638646a11e9ff6cc0aac0813bd808d4163361 diff --git a/docs/wiki.md b/docs/wiki.md index 6cd280f..d087b13 100644 --- a/docs/wiki.md +++ b/docs/wiki.md @@ -72,12 +72,32 @@ $ curl -sLO https://raw.githubusercontent.com/rdmurphy/atproto-openapi-types/mai $ .config/ai/scpt/test/pds.zsh e ``` -## manga +## cmt + +blogなどにblueskyアカウントのpostを表示します。 + +以下でbotがblogのコメントシステムを開きます。 ```sh -$ ai bot --manga_uri at://did:plc:dconvttcori3mrh2wrmehvwt/app.bsky.feed.post/3kp4zdnlo5s2j +@yui.syui.ai /comment https://syui.ai/blog/post/2024/04/25/bluesky/ ``` +開いたbotのpostに返信することで、特定のblog path上でpostを表示します。 + +
+ +```ts + + + + + + +``` + +## example json + ```json [ { @@ -165,10 +185,6 @@ $ ai bot --manga_uri at://did:plc:dconvttcori3mrh2wrmehvwt/app.bsky.feed.post/3k ] ``` -```sh -$ ai bot -a syui.ai --manga_uri at://did:plc:4hqjfn7m6n5hno3doamuhgef/app.bsky.feed.post/3kp5qn72s232q -``` - ```json { "uri": "at://did:plc:uqzpqmrjnptsxezjx4xuh2mn/app.bsky.feed.post/3kp5qniyzm42h", diff --git a/src/bot.rs b/src/bot.rs index d8ebdd8..fec12e6 100644 --- a/src/bot.rs +++ b/src/bot.rs @@ -46,6 +46,7 @@ pub fn c_bot(c: &Context) { cid_root = &n[i].record.reply.as_ref().unwrap().root.cid; uri_root = &n[i].record.reply.as_ref().unwrap().root.uri; } + let check_uri_comment = w_cid(uri_root.to_string(), log_file(&"c1"), false); let mut text = ""; if !n[i].record.text.is_none() { @@ -96,11 +97,6 @@ pub fn c_bot(c: &Context) { admin = c.string_flag("admin").unwrap(); } - let mut manga_uri = "".to_string(); - if c.string_flag("manga_uri").is_ok() { - manga_uri = c.string_flag("manga_uri").unwrap(); - } - let mut avatar = "".to_string(); if let Some(v) = &n[i].author.avatar { avatar = v.to_string(); @@ -423,6 +419,34 @@ pub fn c_bot(c: &Context) { .await; println!("{}", str_rep); w_cid(cid.to_string(), log_file(&"n1"), true); + } else if check_uri_comment == true { + println!("admin:{}", admin); + let output = Command::new(data_scpt(&"ai")) + .arg(&"atproto").arg(&"comment") + .arg(&handle) + .arg(&did) + .arg(&cid) + .arg(&uri) + .arg(&cid_root) + .arg(&uri_root) + .arg(&host) + .arg(&avatar) + .arg(&prompt_chat) + .output() + .expect("zsh"); + let d = String::from_utf8_lossy(&output.stdout); + let d = d.to_string(); + let text_limit = c_char(d); + let str_rep = reply::post_request( + text_limit.to_string(), + cid.to_string(), + uri.to_string(), + cid_root.to_string(), + uri_root.to_string(), + ) + .await; + println!("{}", str_rep); + w_cid(cid.to_string(), log_file(&"n1"), true); } else if { com == "sh" || com == "/sh" } && handle == &admin { println!("admin:{}", admin); let output = Command::new(data_scpt(&"ai")) @@ -486,10 +510,10 @@ pub fn c_bot(c: &Context) { println!("{}", str_rep); w_cid(cid.to_string(), log_file(&"n1"), true); } - } else if uri_root == &manga_uri { - println!("manga_uri:{}", manga_uri); + } else if { com == "comment" || com == "/comment" } && { handle == &admin || handle == "yui.bsky.social" } && check_uri_comment == false { + println!("admin:{}", admin); let output = Command::new(data_scpt(&"ai")) - .arg(&"atproto").arg(&"manga") + .arg(&"atproto").arg(&"comment") .arg(&handle) .arg(&did) .arg(&cid) @@ -514,6 +538,7 @@ pub fn c_bot(c: &Context) { .await; println!("{}", str_rep); w_cid(cid.to_string(), log_file(&"n1"), true); + w_cid(uri_root.to_string(), log_file(&"c1"), true); } else { // openai let str_openai = openai::post_request(prompt_chat.to_string()).await; @@ -565,7 +590,10 @@ pub fn c_bot_feed(c: &Context) { let uri_root = uri; let check_cid = w_cid(cid.to_string(), log_file(&"n1"), false); let check_cid_run = w_cid(cid.to_string(), log_file(&"n2"), false); - + //let mut avatar = "".to_string(); + //if let Some(v) = &n[i].post.author.avatar { + // avatar = v.to_string(); + //} let mut text = ""; if !n[i].post.record.text.is_none() { text = &n[i].post.record.text.as_ref().unwrap(); @@ -950,6 +978,7 @@ pub fn c_bot_feed(c: &Context) { .await; println!("{}", str_rep); w_cid(cid.to_string(), log_file(&"n1"), true); + } else if com == "quiz" || com == "/quiz" { println!("admin:{}", admin); let output = Command::new(data_scpt(&"ai")) diff --git a/src/data.rs b/src/data.rs index 540a36d..c4a8505 100644 --- a/src/data.rs +++ b/src/data.rs @@ -34,6 +34,7 @@ pub fn log_file(s: &str) -> String { match &*s { "n1" => f + &"notify_cid.txt", "n2" => f + &"notify_cid_run.txt", + "c1" => f + &"comment_cid.txt", _ => f + &s, } } diff --git a/src/main.rs b/src/main.rs index 6d20abd..5646f41 100644 --- a/src/main.rs +++ b/src/main.rs @@ -66,9 +66,6 @@ fn main() { Flag::new("feed", FlagType::String) .alias("f"), ) - .flag( - Flag::new("manga_uri", FlagType::String) - ) ) .command( Command::new("follow_all")please reply with your comments here ↓ +
— ai (@yui.syui.ai) Apr 25, 2024 at 20:18