Update
This commit is contained in:
		
							parent
							
								
									c61502e6a7
								
							
						
					
					
						commit
						2ac85b4d89
					
				
					 4 changed files with 95 additions and 136 deletions
				
			
		
							
								
								
									
										12
									
								
								.build.yml
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								.build.yml
									
									
									
									
									
								
							|  | @ -1,12 +1,17 @@ | |||
| image: alpine/latest | ||||
| image: debian/bullseye | ||||
| packages: | ||||
|   - curl | ||||
|   - lld | ||||
|   - gcc | ||||
|   - upx | ||||
| sources: | ||||
|   - https://git.sr.ht/~cofob/matrix-dnsbot | ||||
| triggers: | ||||
|   - action: email | ||||
|     condition: failure | ||||
|     to: failure@cofob.ru | ||||
| artifacts: | ||||
|   - matrix-dnsbot/target/release/dnsbot | ||||
| tasks: | ||||
|   - install: | | ||||
|       curl https://sh.rustup.rs -sSf | sh -s -- -y -q --default-toolchain nightly --profile minimal | ||||
|  | @ -18,3 +23,8 @@ tasks: | |||
|       source $HOME/.cargo/env | ||||
|       cd matrix-dnsbot | ||||
|       cargo test | ||||
|   - build: | | ||||
|       source $HOME/.cargo/env | ||||
|       cd matrix-dnsbot | ||||
|       cargo build --release | ||||
|       upx -9 target/release/dnsbot | ||||
|  |  | |||
							
								
								
									
										62
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										62
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							|  | @ -272,17 +272,6 @@ version = "1.0.0" | |||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "065374052e7df7ee4047b1160cca5e1467a12351a40b3da123c870ba0b8eda2a" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "atty" | ||||
| version = "0.2.14" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "d9b39be18770d11421cdb1b9947a45dd3f37e93092cbf377614828a319d5fee8" | ||||
| dependencies = [ | ||||
|  "hermit-abi", | ||||
|  "libc", | ||||
|  "winapi", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "autocfg" | ||||
| version = "1.1.0" | ||||
|  | @ -671,7 +660,6 @@ dependencies = [ | |||
|  "log", | ||||
|  "matrix-sdk", | ||||
|  "matrix-sdk-sled", | ||||
|  "pretty_env_logger", | ||||
|  "regex", | ||||
|  "tokio", | ||||
|  "tracing-subscriber", | ||||
|  | @ -735,19 +723,6 @@ dependencies = [ | |||
|  "syn", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "env_logger" | ||||
| version = "0.7.1" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "44533bbbb3bb3c1fa17d9f2e4e38bbbaf8396ba82193c4cb1b6445d711445d36" | ||||
| dependencies = [ | ||||
|  "atty", | ||||
|  "humantime", | ||||
|  "log", | ||||
|  "regex", | ||||
|  "termcolor", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "event-listener" | ||||
| version = "2.5.2" | ||||
|  | @ -1077,15 +1052,6 @@ version = "1.0.2" | |||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "c4a1e36c821dbe04574f602848a19f742f4fb3c98d40449f11bcad18d6b17421" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "humantime" | ||||
| version = "1.3.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "df004cfca50ef23c36850aaaa59ad52cc70d0e90243c3c7737a4dd32dc7a3c4f" | ||||
| dependencies = [ | ||||
|  "quick-error", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "hyper" | ||||
| version = "0.14.19" | ||||
|  | @ -1763,16 +1729,6 @@ version = "0.2.16" | |||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "eb9f9e6e233e5c4a35559a617bf40a4ec447db2e84c20b55a6f83167b7e57872" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "pretty_env_logger" | ||||
| version = "0.4.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "926d36b9553851b8b0005f1275891b392ee4d2d833852c417ed025477350fb9d" | ||||
| dependencies = [ | ||||
|  "env_logger", | ||||
|  "log", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "proc-macro-crate" | ||||
| version = "1.1.3" | ||||
|  | @ -2363,15 +2319,6 @@ dependencies = [ | |||
|  "winapi", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "termcolor" | ||||
| version = "1.1.3" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "bab24d30b911b2376f3a13cc2cd443142f0c81dda04c118693e35b3835757755" | ||||
| dependencies = [ | ||||
|  "winapi-util", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "thiserror" | ||||
| version = "1.0.31" | ||||
|  | @ -2882,15 +2829,6 @@ version = "0.4.0" | |||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "ac3b87c63620426dd9b991e5ce0329eff545bccbbb34f3be09ff6fb6ab51b7b6" | ||||
| 
 | ||||
| [[package]] | ||||
| name = "winapi-util" | ||||
| version = "0.1.5" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "70ec6ce85bb158151cae5e5c87f95a8e97d2c0c4b001223f33a334e3ce5de178" | ||||
| dependencies = [ | ||||
|  "winapi", | ||||
| ] | ||||
| 
 | ||||
| [[package]] | ||||
| name = "winapi-x86_64-pc-windows-gnu" | ||||
| version = "0.4.0" | ||||
|  |  | |||
|  | @ -20,7 +20,6 @@ anyhow = "^1" | |||
| regex = "^1" | ||||
| lazy_static = "^1.4" | ||||
| tracing-subscriber = "^0.3" | ||||
| pretty_env_logger = "^0.4" | ||||
| async-std-resolver = "^0.21" | ||||
| 
 | ||||
| [profile.dev] | ||||
|  |  | |||
							
								
								
									
										156
									
								
								src/main.rs
									
									
									
									
									
								
							
							
						
						
									
										156
									
								
								src/main.rs
									
									
									
									
									
								
							|  | @ -1,5 +1,7 @@ | |||
| extern crate dotenv; | ||||
| 
 | ||||
| #[macro_use] extern crate log; | ||||
| 
 | ||||
| use std::env; | ||||
| use std::time::Instant; | ||||
| use dotenv::dotenv; | ||||
|  | @ -13,7 +15,6 @@ use matrix_sdk::{ | |||
| 	}, Client, | ||||
| }; | ||||
| use tokio::time::{sleep, Duration}; | ||||
| use log::{info, debug}; | ||||
| use regex::Regex; | ||||
| use lazy_static::lazy_static; | ||||
| use async_std_resolver::resolver_from_system_conf; | ||||
|  | @ -30,79 +31,90 @@ async fn on_room_message(event: OriginalSyncRoomMessageEvent, room: Room) { | |||
| 		}; | ||||
| 
 | ||||
| 		msg_body = msg_body.to_lowercase(); | ||||
| 		let mut i: u8 = 0; | ||||
| 
 | ||||
| 		if msg_body.contains("resolve help") { | ||||
| 			let content = RoomMessageEventContent::text_html( | ||||
| 				"Just send 'resolve (domain)'. 'resolve source' to get the code.", | ||||
| 				"Just send <code>resolve (domain)</code>. <code>resolve source</code> to get the code."); | ||||
| 			room.send(content, None).await.unwrap(); | ||||
| 		} else if msg_body.contains("resolve source") { | ||||
| 			let content = RoomMessageEventContent::text_plain("https://git.sr.ht/~cofob/matrix-dnsbot"); | ||||
| 			room.send(content, None).await.unwrap(); | ||||
| 		} else if msg_body.contains("resolve") { | ||||
| 			let caps = RE.captures(&msg_body); | ||||
| 			match caps { | ||||
| 				Some(cap) => { | ||||
| 					let start = Instant::now(); | ||||
| 					let domain = cap.get(1).unwrap().as_str(); | ||||
| 					let resolver = resolver_from_system_conf().await.unwrap(); | ||||
| 					let lookup = resolver.lookup_ip(domain).await; | ||||
| 					if lookup.is_ok() { | ||||
| 						let lookup = lookup.unwrap(); | ||||
| 						if lookup.iter().count() == 0 { | ||||
| 							let content = RoomMessageEventContent::text_plain("empty"); | ||||
| 							room.send(content, None).await.unwrap(); | ||||
| 							return; | ||||
| 						} | ||||
| 
 | ||||
| 						let mut plain_answer = String::from("IP record"); | ||||
| 						let mut answer = String::from("IP record"); | ||||
| 
 | ||||
| 						if lookup.iter().count() > 1 { | ||||
| 							// lets goooo shitcode
 | ||||
| 							plain_answer.push_str("s for "); | ||||
| 							plain_answer.push_str(domain); | ||||
| 							plain_answer.push(':'); | ||||
| 							answer.push_str("s for <code>"); | ||||
| 							answer.push_str(domain); | ||||
| 							answer.push_str("</code>:"); | ||||
| 						} else { | ||||
| 							plain_answer.push_str(" for "); | ||||
| 							plain_answer.push_str(domain); | ||||
| 							plain_answer.push(':'); | ||||
| 							answer.push_str(" for <code>"); | ||||
| 							answer.push_str(domain); | ||||
| 							answer.push_str("</code>:"); | ||||
| 						} | ||||
| 
 | ||||
| 						for ip in lookup { | ||||
| 							plain_answer.push_str(" '"); | ||||
| 							plain_answer.push_str(&ip.to_string()); | ||||
| 							plain_answer.push_str("';"); | ||||
| 							answer.push_str(" <code>"); | ||||
| 							answer.push_str(&ip.to_string()); | ||||
| 							answer.push_str("</code>;"); | ||||
| 						} | ||||
| 						let end = Instant::now(); | ||||
| 						let delta = end - start; | ||||
| 						plain_answer.push_str(" That took "); | ||||
| 						plain_answer.push_str(&delta.as_millis().to_string()); | ||||
| 						plain_answer.push_str(" ms."); | ||||
| 						answer.push_str(" That took <code>"); | ||||
| 						answer.push_str(&delta.as_millis().to_string()); | ||||
| 						answer.push_str("</code> ms."); | ||||
| 						let content = RoomMessageEventContent::text_html(plain_answer, answer); | ||||
| 						room.send(content, None).await.unwrap(); | ||||
| 					} else { | ||||
| 						let content = RoomMessageEventContent::text_plain("Unexpected error occured. Most likely, the domain simply does not have IP records."); | ||||
| 						room.send(content, None).await.unwrap(); | ||||
| 					} | ||||
| 				} | ||||
|     		_ => debug!("regex not found"), | ||||
| 		for line in msg_body.rsplit('\n') { | ||||
| 			if line.starts_with('>') { | ||||
| 				continue
 | ||||
| 			} | ||||
| 
 | ||||
| 			if line.contains("resolve help") { | ||||
| 				let content = RoomMessageEventContent::text_html( | ||||
| 					"Just send 'resolve (domain)'. 'resolve source' to get the code.", | ||||
| 					"Just send <code>resolve (domain)</code>. <code>resolve source</code> to get the code."); | ||||
| 				room.send(content, None).await.unwrap(); | ||||
| 			} else if line.contains("resolve source") { | ||||
| 				let content = RoomMessageEventContent::text_plain("https://git.sr.ht/~cofob/matrix-dnsbot"); | ||||
| 				room.send(content, None).await.unwrap(); | ||||
| 			} else if line.contains("resolve") { | ||||
| 				i += 1; | ||||
| 				if i >= 6 { | ||||
| 					return; | ||||
| 				} | ||||
| 				let caps = RE.captures(&line); | ||||
| 				match caps { | ||||
| 					Some(cap) => { | ||||
| 						let start = Instant::now(); | ||||
| 						let domain = cap.get(1).unwrap().as_str(); | ||||
| 						let resolver = resolver_from_system_conf().await.unwrap(); | ||||
| 						let lookup = resolver.lookup_ip(domain).await; | ||||
| 						if lookup.is_ok() { | ||||
| 							let lookup = lookup.unwrap(); | ||||
| 							if lookup.iter().count() == 0 { | ||||
| 								let content = RoomMessageEventContent::text_plain("empty"); | ||||
| 								room.send(content, None).await.unwrap(); | ||||
| 								return; | ||||
| 							} | ||||
| 
 | ||||
| 							let mut plain_answer = String::from("IP record"); | ||||
| 							let mut answer = String::from("IP record"); | ||||
| 
 | ||||
| 							if lookup.iter().count() > 1 { | ||||
| 								// lets goooo shitcode
 | ||||
| 								plain_answer.push_str("s for "); | ||||
| 								plain_answer.push_str(domain); | ||||
| 								plain_answer.push(':'); | ||||
| 								answer.push_str("s for <code>"); | ||||
| 								answer.push_str(domain); | ||||
| 								answer.push_str("</code>:"); | ||||
| 							} else { | ||||
| 								plain_answer.push_str(" for "); | ||||
| 								plain_answer.push_str(domain); | ||||
| 								plain_answer.push(':'); | ||||
| 								answer.push_str(" for <code>"); | ||||
| 								answer.push_str(domain); | ||||
| 								answer.push_str("</code>:"); | ||||
| 							} | ||||
| 
 | ||||
| 							for ip in lookup { | ||||
| 								plain_answer.push_str(" `"); | ||||
| 								plain_answer.push_str(&ip.to_string()); | ||||
| 								plain_answer.push_str("`;"); | ||||
| 								answer.push_str(" <code>"); | ||||
| 								answer.push_str(&ip.to_string()); | ||||
| 								answer.push_str("</code>;"); | ||||
| 							} | ||||
| 							let end = Instant::now(); | ||||
| 							let delta = end - start; | ||||
| 							plain_answer.push_str(" That took "); | ||||
| 							plain_answer.push_str(&delta.as_millis().to_string()); | ||||
| 							plain_answer.push_str(" ms."); | ||||
| 							answer.push_str(" That took <code>"); | ||||
| 							answer.push_str(&delta.as_millis().to_string()); | ||||
| 							answer.push_str("</code> ms."); | ||||
| 							let content = RoomMessageEventContent::text_html(plain_answer, answer); | ||||
| 							room.send(content, None).await.unwrap(); | ||||
| 						} else { | ||||
| 							let content = RoomMessageEventContent::text_plain("Unexpected error occured. Most likely, the domain simply does not have IP records."); | ||||
| 							room.send(content, None).await.unwrap(); | ||||
| 						} | ||||
| 					} | ||||
| 					_ => debug!("regex not found"), | ||||
| 				} | ||||
| 			} else if room.is_direct() { | ||||
| 				let content = RoomMessageEventContent::text_plain("I dont understand you! Send `resolve help` to get help."); | ||||
| 				room.send(content, None).await.unwrap(); | ||||
| 			} | ||||
| 		} else if room.is_direct() { | ||||
| 			let content = RoomMessageEventContent::text_plain("I dont understand you! Send `resolve help` to get help."); | ||||
| 			room.send(content, None).await.unwrap(); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue