DISCORD AUTH!, but broke some endpoints
							parent
							
								
									4c74e84da4
								
							
						
					
					
						commit
						b4332bb9fc
					
				|  | @ -251,6 +251,16 @@ dependencies = [ | ||||||
|  "unicode-width", |  "unicode-width", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "core-foundation" | ||||||
|  | version = "0.9.3" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "194a7a9e6de53fa55116934067c844d9d749312f75c6f6d0980e8c252f8c2146" | ||||||
|  | dependencies = [ | ||||||
|  |  "core-foundation-sys", | ||||||
|  |  "libc", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "core-foundation-sys" | name = "core-foundation-sys" | ||||||
| version = "0.8.3" | version = "0.8.3" | ||||||
|  | @ -401,6 +411,36 @@ dependencies = [ | ||||||
|  "num-traits 0.1.43", |  "num-traits 0.1.43", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "errno" | ||||||
|  | version = "0.2.8" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "f639046355ee4f37944e44f60642c6f3a7efa3cf6b78c78a0d989a8ce6c396a1" | ||||||
|  | dependencies = [ | ||||||
|  |  "errno-dragonfly", | ||||||
|  |  "libc", | ||||||
|  |  "winapi", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "errno-dragonfly" | ||||||
|  | version = "0.1.2" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "aa68f1b12764fab894d2755d2518754e71b4fd80ecfb822714a1206c2aab39bf" | ||||||
|  | dependencies = [ | ||||||
|  |  "cc", | ||||||
|  |  "libc", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "fastrand" | ||||||
|  | version = "1.9.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "e51093e27b0797c359783294ca4f0a911c270184cb10f85783b118614a1501be" | ||||||
|  | dependencies = [ | ||||||
|  |  "instant", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "flate2" | name = "flate2" | ||||||
| version = "1.0.25" | version = "1.0.25" | ||||||
|  | @ -430,6 +470,21 @@ version = "1.0.7" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1" | checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1" | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "foreign-types" | ||||||
|  | version = "0.3.2" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "f6f339eb8adc052cd2ca78910fda869aefa38d22d5cb648e6485e4d3fc06f3b1" | ||||||
|  | dependencies = [ | ||||||
|  |  "foreign-types-shared", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "foreign-types-shared" | ||||||
|  | version = "0.1.1" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b" | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "form_urlencoded" | name = "form_urlencoded" | ||||||
| version = "1.1.0" | version = "1.1.0" | ||||||
|  | @ -675,6 +730,19 @@ dependencies = [ | ||||||
|  "tokio-rustls", |  "tokio-rustls", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "hyper-tls" | ||||||
|  | version = "0.5.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "d6183ddfa99b85da61a140bea0efc93fdf56ceaa041b37d553518030827f9905" | ||||||
|  | dependencies = [ | ||||||
|  |  "bytes", | ||||||
|  |  "hyper", | ||||||
|  |  "native-tls", | ||||||
|  |  "tokio", | ||||||
|  |  "tokio-native-tls", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "iana-time-zone" | name = "iana-time-zone" | ||||||
| version = "0.1.53" | version = "0.1.53" | ||||||
|  | @ -719,6 +787,25 @@ dependencies = [ | ||||||
|  "hashbrown", |  "hashbrown", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "instant" | ||||||
|  | version = "0.1.12" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "7a5bbe824c507c5da5956355e86a746d82e0e1464f65d862cc5e71da70e94b2c" | ||||||
|  | dependencies = [ | ||||||
|  |  "cfg-if", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "io-lifetimes" | ||||||
|  | version = "1.0.5" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "1abeb7a0dd0f8181267ff8adc397075586500b81b28a73e8a0208b00fc170fb3" | ||||||
|  | dependencies = [ | ||||||
|  |  "libc", | ||||||
|  |  "windows-sys 0.45.0", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "ipnet" | name = "ipnet" | ||||||
| version = "2.7.1" | version = "2.7.1" | ||||||
|  | @ -761,6 +848,12 @@ dependencies = [ | ||||||
|  "cc", |  "cc", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "linux-raw-sys" | ||||||
|  | version = "0.1.4" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "f051f77a7c8e6957c0696eac88f26b0117e54f52d3fc682ab19397a8812846a4" | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "lock_api" | name = "lock_api" | ||||||
| version = "0.4.9" | version = "0.4.9" | ||||||
|  | @ -823,14 +916,17 @@ dependencies = [ | ||||||
|  "axum", |  "axum", | ||||||
|  "chrono", |  "chrono", | ||||||
|  "futures", |  "futures", | ||||||
|  |  "reqwest", | ||||||
|  "serde", |  "serde", | ||||||
|  "serde_json", |  "serde_json", | ||||||
|  "serenity", |  "serenity", | ||||||
|  "songbird", |  "songbird", | ||||||
|  |  "thiserror", | ||||||
|  "tokio", |  "tokio", | ||||||
|  "tower-http", |  "tower-http", | ||||||
|  "tracing", |  "tracing", | ||||||
|  "tracing-subscriber", |  "tracing-subscriber", | ||||||
|  |  "uuid 1.3.0", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
|  | @ -879,6 +975,24 @@ dependencies = [ | ||||||
|  "getrandom", |  "getrandom", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "native-tls" | ||||||
|  | version = "0.2.11" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "07226173c32f2926027b63cce4bcd8076c3552846cbe7925f3aaffeac0a3b92e" | ||||||
|  | dependencies = [ | ||||||
|  |  "lazy_static", | ||||||
|  |  "libc", | ||||||
|  |  "log", | ||||||
|  |  "openssl", | ||||||
|  |  "openssl-probe", | ||||||
|  |  "openssl-sys", | ||||||
|  |  "schannel", | ||||||
|  |  "security-framework", | ||||||
|  |  "security-framework-sys", | ||||||
|  |  "tempfile", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "nu-ansi-term" | name = "nu-ansi-term" | ||||||
| version = "0.46.0" | version = "0.46.0" | ||||||
|  | @ -939,6 +1053,51 @@ version = "0.3.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "624a8340c38c1b80fd549087862da4ba43e08858af025b236e509b6649fc13d5" | checksum = "624a8340c38c1b80fd549087862da4ba43e08858af025b236e509b6649fc13d5" | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "openssl" | ||||||
|  | version = "0.10.45" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "b102428fd03bc5edf97f62620f7298614c45cedf287c271e7ed450bbaf83f2e1" | ||||||
|  | dependencies = [ | ||||||
|  |  "bitflags", | ||||||
|  |  "cfg-if", | ||||||
|  |  "foreign-types", | ||||||
|  |  "libc", | ||||||
|  |  "once_cell", | ||||||
|  |  "openssl-macros", | ||||||
|  |  "openssl-sys", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "openssl-macros" | ||||||
|  | version = "0.1.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "b501e44f11665960c7e7fcf062c7d96a14ade4aa98116c004b2e37b5be7d736c" | ||||||
|  | dependencies = [ | ||||||
|  |  "proc-macro2", | ||||||
|  |  "quote", | ||||||
|  |  "syn", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "openssl-probe" | ||||||
|  | version = "0.1.5" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "ff011a302c396a5197692431fc1948019154afc178baf7d8e37367442a4601cf" | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "openssl-sys" | ||||||
|  | version = "0.9.80" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "23bbbf7854cd45b83958ebe919f0e8e516793727652e27fda10a8384cfc790b7" | ||||||
|  | dependencies = [ | ||||||
|  |  "autocfg", | ||||||
|  |  "cc", | ||||||
|  |  "libc", | ||||||
|  |  "pkg-config", | ||||||
|  |  "vcpkg", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "ordered-float" | name = "ordered-float" | ||||||
| version = "2.10.0" | version = "2.10.0" | ||||||
|  | @ -1164,11 +1323,13 @@ dependencies = [ | ||||||
|  "http-body", |  "http-body", | ||||||
|  "hyper", |  "hyper", | ||||||
|  "hyper-rustls", |  "hyper-rustls", | ||||||
|  |  "hyper-tls", | ||||||
|  "ipnet", |  "ipnet", | ||||||
|  "js-sys", |  "js-sys", | ||||||
|  "log", |  "log", | ||||||
|  "mime", |  "mime", | ||||||
|  "mime_guess", |  "mime_guess", | ||||||
|  |  "native-tls", | ||||||
|  "once_cell", |  "once_cell", | ||||||
|  "percent-encoding", |  "percent-encoding", | ||||||
|  "pin-project-lite", |  "pin-project-lite", | ||||||
|  | @ -1178,6 +1339,7 @@ dependencies = [ | ||||||
|  "serde_json", |  "serde_json", | ||||||
|  "serde_urlencoded", |  "serde_urlencoded", | ||||||
|  "tokio", |  "tokio", | ||||||
|  |  "tokio-native-tls", | ||||||
|  "tokio-rustls", |  "tokio-rustls", | ||||||
|  "tokio-util", |  "tokio-util", | ||||||
|  "tower-service", |  "tower-service", | ||||||
|  | @ -1205,6 +1367,20 @@ dependencies = [ | ||||||
|  "winapi", |  "winapi", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "rustix" | ||||||
|  | version = "0.36.8" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "f43abb88211988493c1abb44a70efa56ff0ce98f233b7b276146f1f3f7ba9644" | ||||||
|  | dependencies = [ | ||||||
|  |  "bitflags", | ||||||
|  |  "errno", | ||||||
|  |  "io-lifetimes", | ||||||
|  |  "libc", | ||||||
|  |  "linux-raw-sys", | ||||||
|  |  "windows-sys 0.45.0", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "rustls" | name = "rustls" | ||||||
| version = "0.20.8" | version = "0.20.8" | ||||||
|  | @ -1248,6 +1424,15 @@ dependencies = [ | ||||||
|  "zeroize", |  "zeroize", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "schannel" | ||||||
|  | version = "0.1.21" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "713cfb06c7059f3588fb8044c0fad1d09e3c01d225e25b9220dbfdcf16dbb1b3" | ||||||
|  | dependencies = [ | ||||||
|  |  "windows-sys 0.42.0", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "scoped-tls" | name = "scoped-tls" | ||||||
| version = "1.0.1" | version = "1.0.1" | ||||||
|  | @ -1276,6 +1461,29 @@ dependencies = [ | ||||||
|  "untrusted", |  "untrusted", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "security-framework" | ||||||
|  | version = "2.8.2" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "a332be01508d814fed64bf28f798a146d73792121129962fdf335bb3c49a4254" | ||||||
|  | dependencies = [ | ||||||
|  |  "bitflags", | ||||||
|  |  "core-foundation", | ||||||
|  |  "core-foundation-sys", | ||||||
|  |  "libc", | ||||||
|  |  "security-framework-sys", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "security-framework-sys" | ||||||
|  | version = "2.8.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "31c9bb296072e961fcbd8853511dd39c2d8be2deb1e17c6860b1d30732b323b4" | ||||||
|  | dependencies = [ | ||||||
|  |  "core-foundation-sys", | ||||||
|  |  "libc", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "serde" | name = "serde" | ||||||
| version = "1.0.152" | version = "1.0.152" | ||||||
|  | @ -1475,7 +1683,7 @@ dependencies = [ | ||||||
|  "tracing-futures", |  "tracing-futures", | ||||||
|  "typemap_rev", |  "typemap_rev", | ||||||
|  "url", |  "url", | ||||||
|  "uuid", |  "uuid 0.8.2", | ||||||
|  "xsalsa20poly1305", |  "xsalsa20poly1305", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | @ -1541,6 +1749,19 @@ version = "0.1.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "2047c6ded9c721764247e62cd3b03c09ffc529b2ba5b10ec482ae507a4a70160" | checksum = "2047c6ded9c721764247e62cd3b03c09ffc529b2ba5b10ec482ae507a4a70160" | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "tempfile" | ||||||
|  | version = "3.4.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "af18f7ae1acd354b992402e9ec5864359d693cd8a79dcbef59f76891701c1e95" | ||||||
|  | dependencies = [ | ||||||
|  |  "cfg-if", | ||||||
|  |  "fastrand", | ||||||
|  |  "redox_syscall", | ||||||
|  |  "rustix", | ||||||
|  |  "windows-sys 0.42.0", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "termcolor" | name = "termcolor" | ||||||
| version = "1.2.0" | version = "1.2.0" | ||||||
|  | @ -1662,6 +1883,16 @@ dependencies = [ | ||||||
|  "syn", |  "syn", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "tokio-native-tls" | ||||||
|  | version = "0.3.1" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "bbae76ab933c85776efabc971569dd6119c580d8f5d448769dec1764bf796ef2" | ||||||
|  | dependencies = [ | ||||||
|  |  "native-tls", | ||||||
|  |  "tokio", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "tokio-rustls" | name = "tokio-rustls" | ||||||
| version = "0.23.4" | version = "0.23.4" | ||||||
|  | @ -1925,12 +2156,27 @@ dependencies = [ | ||||||
|  "getrandom", |  "getrandom", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "uuid" | ||||||
|  | version = "1.3.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "1674845326ee10d37ca60470760d4288a6f80f304007d92e5c53bab78c9cfd79" | ||||||
|  | dependencies = [ | ||||||
|  |  "getrandom", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "valuable" | name = "valuable" | ||||||
| version = "0.1.0" | version = "0.1.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| checksum = "830b7e5d4d90034032940e4ace0d9a9a057e7a45cd94e6c007832e39edb82f6d" | checksum = "830b7e5d4d90034032940e4ace0d9a9a057e7a45cd94e6c007832e39edb82f6d" | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "vcpkg" | ||||||
|  | version = "0.2.15" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "accd4ea62f7bb7a82fe23066fb0957d48ef677f6eeb8215f372f52e48bb32426" | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "version_check" | name = "version_check" | ||||||
| version = "0.9.4" | version = "0.9.4" | ||||||
|  |  | ||||||
|  | @ -9,11 +9,14 @@ edition = "2021" | ||||||
| axum = "0.6.9" | axum = "0.6.9" | ||||||
| chrono = "0.4.23" | chrono = "0.4.23" | ||||||
| futures = "0.3.26" | futures = "0.3.26" | ||||||
|  | reqwest = "0.11.14" | ||||||
| serde = "1.0.152" | serde = "1.0.152" | ||||||
| serde_json = "1.0.93" | serde_json = "1.0.93" | ||||||
| serenity = { version = "0.11.5", default-features = false, features = ["client", "gateway", "rustls_backend", "model", "cache", "voice"] } | serenity = { version = "0.11.5", default-features = false, features = ["client", "gateway", "rustls_backend", "model", "cache", "voice"] } | ||||||
| songbird = { version = "0.3.0", features = [ "builtin-queue" ] } | songbird = { version = "0.3.0", features = [ "builtin-queue" ] } | ||||||
|  | thiserror = "1.0.38" | ||||||
| tokio = { version = "1.25.0", features = ["rt-multi-thread", "macros", "signal"] } | tokio = { version = "1.25.0", features = ["rt-multi-thread", "macros", "signal"] } | ||||||
| tower-http = { version = "0.4.0", features = ["cors"] } | tower-http = { version = "0.4.0", features = ["cors"] } | ||||||
| tracing = "0.1.37" | tracing = "0.1.37" | ||||||
| tracing-subscriber = "0.3.16" | tracing-subscriber = "0.3.16" | ||||||
|  | uuid = { version = "1.3.0", features = ["v4"] } | ||||||
|  |  | ||||||
							
								
								
									
										22
									
								
								src/main.rs
								
								
								
								
							
							
						
						
									
										22
									
								
								src/main.rs
								
								
								
								
							|  | @ -15,7 +15,7 @@ use std::env; | ||||||
| use std::net::SocketAddr; | use std::net::SocketAddr; | ||||||
| use std::sync::Arc; | use std::sync::Arc; | ||||||
| use tokio::sync::mpsc; | use tokio::sync::mpsc; | ||||||
| use tower_http::cors::CorsLayer; | use tower_http::cors::{Any, CorsLayer}; | ||||||
| 
 | 
 | ||||||
| use serde::Deserialize; | use serde::Deserialize; | ||||||
| use serenity::async_trait; | use serenity::async_trait; | ||||||
|  | @ -118,14 +118,22 @@ fn spawn_api(settings: Arc<Mutex<Settings>>) -> tokio::task::JoinHandle<()> { | ||||||
|     tokio::spawn(async move { |     tokio::spawn(async move { | ||||||
|         let api = Router::new() |         let api = Router::new() | ||||||
|             .route("/health", get(routes::health)) |             .route("/health", get(routes::health)) | ||||||
|             .route("/me/:user", get(routes::me)) |             .route("/me", get(routes::me)) | ||||||
|             .route("/intros/:guild", get(routes::intros)) |             .route("/intros/:guild", get(routes::intros)) | ||||||
|             .route("/intros/:guild/:channel/:user/:intro", post(routes::add_intro_to_user)) |             .route( | ||||||
|             .route("/intros/:guild/:channel/:user/:intro/remove", post(routes::remove_intro_to_user)) |                 "/intros/:guild/:channel/:user/:intro", | ||||||
|  |                 post(routes::add_intro_to_user), | ||||||
|  |             ) | ||||||
|  |             .route( | ||||||
|  |                 "/intros/:guild/:channel/:user/:intro/remove", | ||||||
|  |                 post(routes::remove_intro_to_user), | ||||||
|  |             ) | ||||||
|  |             .route("/auth", get(routes::auth)) | ||||||
|             .layer( |             .layer( | ||||||
|                 CorsLayer::new() |                 CorsLayer::new() | ||||||
|                     .allow_origin("*".parse::<HeaderValue>().unwrap()) |                     .allow_origin(Any) | ||||||
|                     .allow_methods([Method::GET]), |                     .allow_headers(Any) | ||||||
|  |                     .allow_methods([Method::GET, Method::POST]), | ||||||
|             ) |             ) | ||||||
|             .with_state(settings); |             .with_state(settings); | ||||||
|         let addr = SocketAddr::from(([0, 0, 0, 0], 7756)); |         let addr = SocketAddr::from(([0, 0, 0, 0], 7756)); | ||||||
|  | @ -257,7 +265,7 @@ async fn spawn_bot(settings: Arc<Mutex<Settings>>) -> Vec<tokio::task::JoinHandl | ||||||
|                             None => { |                             None => { | ||||||
|                                 error!( |                                 error!( | ||||||
|                                     "Failed to find intro for user {} on guild {} in channel {}, IntroIndex: {}", |                                     "Failed to find intro for user {} on guild {} in channel {}, IntroIndex: {}", | ||||||
|                                     member.user.name, 
 |                                     member.user.name, | ||||||
|                                     channel.guild_id.as_u64(), |                                     channel.guild_id.as_u64(), | ||||||
|                                     channel.name(), |                                     channel.name(), | ||||||
|                                     intro.index |                                     intro.index | ||||||
|  |  | ||||||
							
								
								
									
										113
									
								
								src/routes.rs
								
								
								
								
							
							
						
						
									
										113
									
								
								src/routes.rs
								
								
								
								
							|  | @ -1,15 +1,21 @@ | ||||||
| use std::{collections::HashMap, sync::Arc}; | use std::{collections::HashMap, sync::Arc}; | ||||||
| 
 | 
 | ||||||
| use axum::{ | use axum::{ | ||||||
|     extract::{Path, State}, |     body::StreamBody, | ||||||
|  |     extract::{Path, Query, State}, | ||||||
|  |     http::HeaderMap, | ||||||
|  |     response::IntoResponse, | ||||||
|     Json, |     Json, | ||||||
| }; | }; | ||||||
| use serde::Serialize; | use futures::Stream; | ||||||
|  | use reqwest::StatusCode; | ||||||
|  | use serde::{Deserialize, Serialize}; | ||||||
| use serde_json::{json, Value}; | use serde_json::{json, Value}; | ||||||
| use tokio::sync::Mutex; | use tokio::sync::Mutex; | ||||||
| use tracing::error; | use tracing::{error, info}; | ||||||
|  | use uuid::Uuid; | ||||||
| 
 | 
 | ||||||
| use crate::settings::{GuildSettings, Intro, IntroIndex, Settings, UserSettings}; | use crate::settings::{Auth, AuthUser, GuildSettings, Intro, IntroIndex, Settings, UserSettings}; | ||||||
| 
 | 
 | ||||||
| #[derive(Serialize)] | #[derive(Serialize)] | ||||||
| pub(crate) enum IntroResponse<'a> { | pub(crate) enum IntroResponse<'a> { | ||||||
|  | @ -47,11 +53,92 @@ pub(crate) async fn health(State(state): State<Arc<Mutex<Settings>>>) -> Json<Va | ||||||
|     Json(json!(*settings)) |     Json(json!(*settings)) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #[derive(Debug, thiserror::Error)] | ||||||
|  | pub(crate) enum Error { | ||||||
|  |     #[error("{0}")] | ||||||
|  |     AuthError(String), | ||||||
|  |     #[error("{0}")] | ||||||
|  |     GetUser(#[from] reqwest::Error), | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | impl IntoResponse for Error { | ||||||
|  |     fn into_response(self) -> axum::response::Response { | ||||||
|  |         let body = match self { | ||||||
|  |             Self::AuthError(msg) => msg, | ||||||
|  |             Self::GetUser(error) => error.to_string(), | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         (StatusCode::INTERNAL_SERVER_ERROR, body).into_response() | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[derive(Deserialize)] | ||||||
|  | struct DiscordUser { | ||||||
|  |     pub username: String, | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | pub(crate) async fn auth( | ||||||
|  |     State(settings): State<Arc<Mutex<Settings>>>, | ||||||
|  |     Query(params): Query<HashMap<String, String>>, | ||||||
|  | ) -> Result<Json<Value>, Error> { | ||||||
|  |     let Some(code) = params.get("code") else { | ||||||
|  |         return Err(Error::AuthError("no code".to_string())); | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     info!("attempting to get access token with code {}", code); | ||||||
|  | 
 | ||||||
|  |     let mut data = HashMap::new(); | ||||||
|  |     data.insert("client_id", "577634620728934400"); | ||||||
|  |     data.insert("client_secret", "CLIENT_SECRET_HERE"); | ||||||
|  |     data.insert("grant_type", "authorization_code"); | ||||||
|  |     data.insert("code", code); | ||||||
|  |     data.insert("redirect_uri", "http://localhost:5173/auth"); | ||||||
|  | 
 | ||||||
|  |     let client = reqwest::Client::new(); | ||||||
|  | 
 | ||||||
|  |     let auth: Auth = client | ||||||
|  |         .post("https://discord.com/api/oauth2/token") | ||||||
|  |         .form(&data) | ||||||
|  |         .send() | ||||||
|  |         .await | ||||||
|  |         .map_err(|err| Error::AuthError(err.to_string()))? | ||||||
|  |         .json() | ||||||
|  |         .await | ||||||
|  |         .map_err(|err| Error::AuthError(err.to_string()))?; | ||||||
|  |     let token = Uuid::new_v4().to_string(); | ||||||
|  | 
 | ||||||
|  |     // Get authorized username
 | ||||||
|  |     let user: DiscordUser = client | ||||||
|  |         .get("https://discord.com/api/v10/users/@me") | ||||||
|  |         .bearer_auth(&auth.access_token) | ||||||
|  |         .send() | ||||||
|  |         .await? | ||||||
|  |         .json() | ||||||
|  |         .await?; | ||||||
|  | 
 | ||||||
|  |     let mut settings = settings.lock().await; | ||||||
|  |     settings.auth_users.insert( | ||||||
|  |         token.clone(), | ||||||
|  |         AuthUser { | ||||||
|  |             auth, | ||||||
|  |             name: user.username.clone(), | ||||||
|  |         }, | ||||||
|  |     ); | ||||||
|  | 
 | ||||||
|  |     Ok(Json(json!({"token": token, "username": user.username}))) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| pub(crate) async fn add_intro_to_user( | pub(crate) async fn add_intro_to_user( | ||||||
|     State(state): State<Arc<Mutex<Settings>>>, |     State(state): State<Arc<Mutex<Settings>>>, | ||||||
|     Path((guild, channel, user, intro_index)): Path<(u64, String, String, usize)>, |     headers: HeaderMap, | ||||||
|  |     Path((guild, channel, intro_index)): Path<(u64, String, usize)>, | ||||||
| ) { | ) { | ||||||
|     let mut settings = state.lock().await; |     let mut settings = state.lock().await; | ||||||
|  |     let Some(token) = headers.get("token").and_then(|v| v.to_str().ok()) else { return; }; | ||||||
|  |     let user = match settings.auth_users.get(token) { | ||||||
|  |         Some(user) => user.name.clone(), | ||||||
|  |         None => return, | ||||||
|  |     }; | ||||||
| 
 | 
 | ||||||
|     let Some(guild) = settings.guilds.get_mut(&guild) else { return; }; |     let Some(guild) = settings.guilds.get_mut(&guild) else { return; }; | ||||||
|     let Some(channel) = guild.channels.get_mut(&channel) else { return; }; |     let Some(channel) = guild.channels.get_mut(&channel) else { return; }; | ||||||
|  | @ -69,9 +156,15 @@ pub(crate) async fn add_intro_to_user( | ||||||
| 
 | 
 | ||||||
| pub(crate) async fn remove_intro_to_user( | pub(crate) async fn remove_intro_to_user( | ||||||
|     State(state): State<Arc<Mutex<Settings>>>, |     State(state): State<Arc<Mutex<Settings>>>, | ||||||
|     Path((guild, channel, user, intro_index)): Path<(u64, String, String, usize)>, |     headers: HeaderMap, | ||||||
|  |     Path((guild, channel, intro_index)): Path<(u64, String, usize)>, | ||||||
| ) { | ) { | ||||||
|     let mut settings = state.lock().await; |     let mut settings = state.lock().await; | ||||||
|  |     let Some(token) = headers.get("token").and_then(|v| v.to_str().ok()) else { return; }; | ||||||
|  |     let user = match settings.auth_users.get(token) { | ||||||
|  |         Some(user) => user.name.clone(), | ||||||
|  |         None => return, | ||||||
|  |     }; | ||||||
| 
 | 
 | ||||||
|     let Some(guild) = settings.guilds.get_mut(&guild) else { return; }; |     let Some(guild) = settings.guilds.get_mut(&guild) else { return; }; | ||||||
|     let Some(channel) = guild.channels.get_mut(&channel) else { return; }; |     let Some(channel) = guild.channels.get_mut(&channel) else { return; }; | ||||||
|  | @ -102,9 +195,15 @@ pub(crate) async fn intros( | ||||||
| 
 | 
 | ||||||
| pub(crate) async fn me( | pub(crate) async fn me( | ||||||
|     State(state): State<Arc<Mutex<Settings>>>, |     State(state): State<Arc<Mutex<Settings>>>, | ||||||
|     Path(user): Path<String>, |     headers: HeaderMap, | ||||||
| ) -> Json<Value> { | ) -> Json<Value> { | ||||||
|     let settings = state.lock().await; |     let settings = state.lock().await; | ||||||
|  |     let Some(token) = headers.get("token").and_then(|v| v.to_str().ok()) else { return Json(json!(MeResponse::NoUserFound)); }; | ||||||
|  | 
 | ||||||
|  |     let user = match settings.auth_users.get(token) { | ||||||
|  |         Some(user) => user.name.clone(), | ||||||
|  |         None => return Json(json!(MeResponse::NoUserFound)), | ||||||
|  |     }; | ||||||
| 
 | 
 | ||||||
|     let mut me = Me { |     let mut me = Me { | ||||||
|         username: user.clone(), |         username: user.clone(), | ||||||
|  |  | ||||||
|  | @ -3,6 +3,21 @@ use std::{collections::HashMap, sync::Arc}; | ||||||
| use serde::{Deserialize, Serialize}; | use serde::{Deserialize, Serialize}; | ||||||
| use serenity::prelude::TypeMapKey; | use serenity::prelude::TypeMapKey; | ||||||
| 
 | 
 | ||||||
|  | #[derive(Debug, Clone, Serialize, Deserialize)] | ||||||
|  | pub(crate) struct Auth { | ||||||
|  |     pub(crate) access_token: String, | ||||||
|  |     pub(crate) token_type: String, | ||||||
|  |     pub(crate) expires_in: usize, | ||||||
|  |     pub(crate) refresh_token: String, | ||||||
|  |     pub(crate) scope: String, | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[derive(Debug, Clone, Serialize, Deserialize)] | ||||||
|  | pub(crate) struct AuthUser { | ||||||
|  |     pub auth: Auth, | ||||||
|  |     pub name: String, | ||||||
|  | } | ||||||
|  | 
 | ||||||
| #[derive(Debug, Clone, Serialize, Deserialize)] | #[derive(Debug, Clone, Serialize, Deserialize)] | ||||||
| #[serde(rename_all = "camelCase")] | #[serde(rename_all = "camelCase")] | ||||||
| pub(crate) struct Settings { | pub(crate) struct Settings { | ||||||
|  | @ -11,6 +26,9 @@ pub(crate) struct Settings { | ||||||
|     #[serde(default)] |     #[serde(default)] | ||||||
|     pub(crate) run_bot: bool, |     pub(crate) run_bot: bool, | ||||||
|     pub(crate) guilds: HashMap<u64, GuildSettings>, |     pub(crate) guilds: HashMap<u64, GuildSettings>, | ||||||
|  | 
 | ||||||
|  |     #[serde(skip)] | ||||||
|  |     pub(crate) auth_users: HashMap<String, AuthUser>, | ||||||
| } | } | ||||||
| impl TypeMapKey for Settings { | impl TypeMapKey for Settings { | ||||||
|     type Value = Arc<Settings>; |     type Value = Arc<Settings>; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue