mirror of
https://github.com/TeamPiped/piped-proxy.git
synced 2025-01-10 11:30:35 +05:30
parent
feaceaa14b
commit
ec006b3999
15
src/main.rs
15
src/main.rs
@ -13,6 +13,7 @@ use std::io::ErrorKind;
|
|||||||
use std::net::TcpListener;
|
use std::net::TcpListener;
|
||||||
use std::os::unix::net::UnixListener;
|
use std::os::unix::net::UnixListener;
|
||||||
use std::str::FromStr;
|
use std::str::FromStr;
|
||||||
|
use std::time::{SystemTime, UNIX_EPOCH};
|
||||||
use std::{env, io};
|
use std::{env, io};
|
||||||
|
|
||||||
#[cfg(not(any(feature = "reqwest-native-tls", feature = "reqwest-rustls")))]
|
#[cfg(not(any(feature = "reqwest-native-tls", feature = "reqwest-rustls")))]
|
||||||
@ -281,6 +282,20 @@ async fn index(req: HttpRequest) -> Result<HttpResponse, Box<dyn Error>> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
let video_playback = req.path().eq("/videoplayback");
|
let video_playback = req.path().eq("/videoplayback");
|
||||||
|
|
||||||
|
if video_playback {
|
||||||
|
if let Some(expiry) = query.get("expire") {
|
||||||
|
let expiry = expiry.parse::<i64>()?;
|
||||||
|
let now = SystemTime::now();
|
||||||
|
let now = now.duration_since(UNIX_EPOCH)
|
||||||
|
.expect("Time went backwards")
|
||||||
|
.as_secs() as i64;
|
||||||
|
if now < expiry {
|
||||||
|
return Err("Expire time in past".into());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
let is_android = video_playback && query.get("c").unwrap_or("").eq("ANDROID");
|
let is_android = video_playback && query.get("c").unwrap_or("").eq("ANDROID");
|
||||||
let is_web = video_playback && query.get("c").unwrap_or("").eq("WEB");
|
let is_web = video_playback && query.get("c").unwrap_or("").eq("WEB");
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user