improvements
This commit is contained in:
parent
2fedf3ff85
commit
b5ce47f182
@ -18,4 +18,4 @@ uuid = { version = "0.7", features = ["serde", "v4"] }
|
|||||||
[dependencies.rocket_contrib]
|
[dependencies.rocket_contrib]
|
||||||
version = "0.4.4"
|
version = "0.4.4"
|
||||||
default-features = false
|
default-features = false
|
||||||
features = ["json", "uuid"]
|
features = ["json", "uuid", "serve"]
|
||||||
|
161
src/main.rs
161
src/main.rs
@ -9,6 +9,7 @@ use serde_json::Value;
|
|||||||
use serde_json::json;
|
use serde_json::json;
|
||||||
use serde::{Serialize, Deserialize};
|
use serde::{Serialize, Deserialize};
|
||||||
use rocket_contrib::uuid::Uuid;
|
use rocket_contrib::uuid::Uuid;
|
||||||
|
use rocket_contrib::serve::StaticFiles;
|
||||||
|
|
||||||
use std::sync::Mutex;
|
use std::sync::Mutex;
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
@ -26,140 +27,10 @@ struct SharedState {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[get("/")]
|
#[get("/")]
|
||||||
fn index() -> &'static str {
|
fn index() -> String {
|
||||||
r#"#! /usr/bin/env nix-shell
|
format!("Wecome to the AV1Master Server version {version}\n
|
||||||
#! nix-shell -i bash -p bash curl jq libaom ffmpeg-full
|
This currently requires a working <a href=\"https://nixos.org/nix/\">nix</a> installion\n
|
||||||
|
curl -L {baseurl}/client.sh > client.sh && chmod +x ./client.sh && ./client.sh {baseurl}", version=VERSION, baseurl="https://av1.dodsorf.as")
|
||||||
set -euo pipefail
|
|
||||||
IFS=$'\n\t'
|
|
||||||
|
|
||||||
base_url="$1"
|
|
||||||
version="0.2.0"
|
|
||||||
|
|
||||||
while true; do
|
|
||||||
sleep 30
|
|
||||||
set +e
|
|
||||||
upsteam_version=`curl -s "$base_url"/version`
|
|
||||||
retval=$?
|
|
||||||
set -e
|
|
||||||
if [ $retval -ne 0 ]; then
|
|
||||||
echo "Is the Job Server Down?"
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
if [[ $version != $upsteam_version ]]; then
|
|
||||||
echo "Wrong version: client version is $version, while job server requires $upstream_version"
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
|
|
||||||
set +e
|
|
||||||
job=`curl -s "$base_url"/request_job | jq`
|
|
||||||
retval=$?
|
|
||||||
set -e
|
|
||||||
if [[ $job = "null" ]] || [ $retval -ne 0 ]; then
|
|
||||||
echo "No Jobs Available ¯\_(ツ)_/¯"
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Got new job!"
|
|
||||||
echo "$job" | jq
|
|
||||||
|
|
||||||
job_id=`echo "$job" | jq -r .id`
|
|
||||||
|
|
||||||
echo "Reserving Job"
|
|
||||||
set +e
|
|
||||||
curl -s "$base_url"/edit_status/"$job_id"/reserved
|
|
||||||
retval=$?
|
|
||||||
set -e
|
|
||||||
if [ $retval -ne 0 ]; then
|
|
||||||
echo "Is the Job Server Down?"
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
echo "Reserved!"
|
|
||||||
|
|
||||||
source=`echo $job | jq -r .description.file_url`
|
|
||||||
sourceext=${source##*.}
|
|
||||||
echo "Downloading source file: $source"
|
|
||||||
|
|
||||||
source=`echo $job | jq -r .description.file_url`
|
|
||||||
|
|
||||||
name=`echo $job | jq -r .description.file_name`
|
|
||||||
input="$name.$job_id.$sourceext"
|
|
||||||
|
|
||||||
set +e
|
|
||||||
curl "$source" -o "$input"
|
|
||||||
retval=$?
|
|
||||||
set -e
|
|
||||||
if [ $retval -ne 0 ]; then
|
|
||||||
echo "Could not Download file!"
|
|
||||||
curl -s -L "$base_url"/edit_status/"$job_id"/error || true
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
echo "Starting Encode"
|
|
||||||
|
|
||||||
height=`echo $job | jq -r .description.resolution[0]`
|
|
||||||
width=`echo $job | jq -r .description.resolution[1]`
|
|
||||||
|
|
||||||
echo $job | jq
|
|
||||||
|
|
||||||
aomenco=`echo $job | jq -r .description.options.aomenc`
|
|
||||||
aomenco=${aomenco//[^a-zA-Z0-9_\- =]/}
|
|
||||||
ffmpego=`echo $job | jq -r .description.options.ffmpeg`
|
|
||||||
ffmpego=${ffmpego//[^a-zA-Z0-9_\- =:]/}
|
|
||||||
|
|
||||||
two_pass=`echo $job | jq -r .description.options.two_pass`
|
|
||||||
|
|
||||||
if [[ $two_pass = true ]]; then
|
|
||||||
set +e
|
|
||||||
eval 'ffmpeg -nostats -hide_banner -loglevel warning \
|
|
||||||
-i "'$input'" '$ffmpego' -vf scale='$height':'$width' -pix_fmt yuv422p -f yuv4mpegpipe - | aomenc - --i422 '$aomenco' \
|
|
||||||
--pass=1 --passes=2 --fpf="'$input'.fpf" --webm -o "'$input'.out.webm"'
|
|
||||||
|
|
||||||
retval=$?
|
|
||||||
if [ $retval -ne 0 ]; then
|
|
||||||
echo "Error running encode pass 1"
|
|
||||||
curl -s -L "$base_url"/edit_status/"$job_id"/error || true
|
|
||||||
echo ""
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
|
|
||||||
eval 'ffmpeg -nostats -hide_banner -loglevel warning \
|
|
||||||
-i "'$input'" '$ffmpego' -vf scale='$height':'$width' -pix_fmt yuv422p -f yuv4mpegpipe - | aomenc - --i422 '$aomenco' \
|
|
||||||
--pass=2 --passes=2 --fpf="'$input'.fpf" --webm -o "'$input'.out.webm"'
|
|
||||||
|
|
||||||
retval=$?
|
|
||||||
if [ $retval -ne 0 ]; then
|
|
||||||
echo "Error running encode pass 2"
|
|
||||||
curl -s -L "$base_url"/edit_status/"$job_id"/error || true
|
|
||||||
echo ""
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
set -e
|
|
||||||
|
|
||||||
else
|
|
||||||
set +e
|
|
||||||
eval 'ffmpeg -nostats -hide_banner -loglevel warning \
|
|
||||||
-i "'$input'" '$ffmpego' -vf scale='$height':'$width' -pix_fmt yuv422p -f yuv4mpegpipe - | aomenc - --i422 '$aomenco' \
|
|
||||||
--passes=1 --fpf="'$input'.fpf" --webm -o "'$input'.out.webm"'
|
|
||||||
|
|
||||||
retval=$?
|
|
||||||
if [ $retval -ne 0 ]; then
|
|
||||||
echo "Error running encode"
|
|
||||||
curl -s -L "$base_url"/edit_status/"$job_id"/error || true
|
|
||||||
echo ""
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
set -e
|
|
||||||
fi
|
|
||||||
|
|
||||||
set +e
|
|
||||||
curl -s -L "$base_url"/edit_status/"$job_id"/completed
|
|
||||||
set -e
|
|
||||||
|
|
||||||
done
|
|
||||||
"#
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[get("/version")]
|
#[get("/version")]
|
||||||
@ -202,15 +73,28 @@ fn get_job(id: Uuid, shared: State<SharedState>) -> Result<Json<Value>, NotFound
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
pub struct RealIP(std::net::IpAddr);
|
||||||
|
|
||||||
|
impl<'a, 'r> rocket::request::FromRequest<'a, 'r> for RealIP {
|
||||||
|
type Error = ();
|
||||||
|
fn from_request(request: &'a rocket::Request<'r>) -> rocket::request::Outcome<Self, Self::Error> {
|
||||||
|
match request.client_ip() {
|
||||||
|
Some(ip) => rocket::Outcome::Success(RealIP(ip)),
|
||||||
|
None => rocket::Outcome::Failure((rocket::http::Status::from_code(401).unwrap(), ()))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[get("/edit_status/<id>/<status>")]
|
#[get("/edit_status/<id>/<status>")]
|
||||||
fn edit_status(id: Uuid, status: String, shared: State<SharedState>, remote_addr: SocketAddr) -> Result<String, Box<std::error::Error>> {
|
fn edit_status(id: Uuid, status: String, shared: State<SharedState>, remote_addr: RealIP) -> Result<String, Box<std::error::Error>> {
|
||||||
let mut list = shared.jobs.lock().unwrap();
|
let mut list = shared.jobs.lock().unwrap();
|
||||||
let job = list.get_mut(&id).ok_or("what")?;
|
let job = list.get_mut(&id).ok_or("what")?;
|
||||||
let status = match status.as_str() {
|
let status = match status.as_str() {
|
||||||
"queued" => Ok(EStatus::Queued),
|
"queued" => Ok(EStatus::Queued),
|
||||||
"reserved" => Ok(EStatus::Reserved(remote_addr.to_string())),
|
"reserved" => Ok(EStatus::Reserved(remote_addr.0.to_string())),
|
||||||
"completed" => Ok(EStatus::Completed(remote_addr.to_string())),
|
"completed" => Ok(EStatus::Completed(remote_addr.0.to_string())),
|
||||||
"error" => Ok(EStatus::Error(remote_addr.to_string())),
|
"error" => Ok(EStatus::Error(remote_addr.0.to_string())),
|
||||||
_ => Err("Not a valid status, valid statuses are queued, reserved, completed, and error")
|
_ => Err("Not a valid status, valid statuses are queued, reserved, completed, and error")
|
||||||
}?;
|
}?;
|
||||||
|
|
||||||
@ -232,6 +116,7 @@ fn add_job(message: Json<workunit::WDesc>, shared: State<SharedState>) {
|
|||||||
fn main() {
|
fn main() {
|
||||||
rocket::ignite()
|
rocket::ignite()
|
||||||
.manage(SharedState::default())
|
.manage(SharedState::default())
|
||||||
|
.mount("/", StaticFiles::from("src/static")) // switch to templates or something cause this is dumb
|
||||||
.mount("/", routes![index, version, get_jobs, get_job, request_job, edit_status, add_job])
|
.mount("/", routes![index, version, get_jobs, get_job, request_job, edit_status, add_job])
|
||||||
.launch();
|
.launch();
|
||||||
}
|
}
|
@ -10,14 +10,14 @@ version="0.2.0"
|
|||||||
while true; do
|
while true; do
|
||||||
sleep 30
|
sleep 30
|
||||||
set +e
|
set +e
|
||||||
upsteam_version=`curl -s "$base_url"/version`
|
upstream_version=`curl -s "$base_url"/version`
|
||||||
retval=$?
|
retval=$?
|
||||||
set -e
|
set -e
|
||||||
if [ $retval -ne 0 ]; then
|
if [ $retval -ne 0 ]; then
|
||||||
echo "Is the Job Server Down?"
|
echo "Is the Job Server Down?"
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
if [[ $version != $upsteam_version ]]; then
|
if [[ $version != $upstream_version ]]; then
|
||||||
echo "Wrong version: client version is $version, while job server requires $upstream_version"
|
echo "Wrong version: client version is $version, while job server requires $upstream_version"
|
||||||
break
|
break
|
||||||
fi
|
fi
|
||||||
@ -32,9 +32,9 @@ while true; do
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Got new job!"
|
echo "Got new job!"
|
||||||
echo "$job" | jq
|
printf "%s\n" "$job" | jq
|
||||||
|
|
||||||
job_id=`echo "$job" | jq -r .id`
|
job_id=`printf "%s\n" "$job" | jq -r .id`
|
||||||
|
|
||||||
echo "Reserving Job"
|
echo "Reserving Job"
|
||||||
set +e
|
set +e
|
||||||
@ -47,13 +47,13 @@ while true; do
|
|||||||
fi
|
fi
|
||||||
echo "Reserved!"
|
echo "Reserved!"
|
||||||
|
|
||||||
source=`echo $job | jq -r .description.file_url`
|
source=`printf "%s\n" "$job" | jq -r .description.file_url`
|
||||||
sourceext=${source##*.}
|
sourceext=${source##*.}
|
||||||
echo "Downloading source file: $source"
|
echo "Downloading source file: $source"
|
||||||
|
|
||||||
source=`echo $job | jq -r .description.file_url`
|
source=`printf "%s\n" "$job" | jq -r .description.file_url`
|
||||||
|
|
||||||
name=`echo $job | jq -r .description.file_name`
|
name=`printf "%s\n" "$job" | jq -r .description.file_name`
|
||||||
input="$name.$job_id.$sourceext"
|
input="$name.$job_id.$sourceext"
|
||||||
|
|
||||||
set +e
|
set +e
|
||||||
@ -63,6 +63,7 @@ while true; do
|
|||||||
if [ $retval -ne 0 ]; then
|
if [ $retval -ne 0 ]; then
|
||||||
echo "Could not Download file!"
|
echo "Could not Download file!"
|
||||||
curl -s -L "$base_url"/edit_status/"$job_id"/error || true
|
curl -s -L "$base_url"/edit_status/"$job_id"/error || true
|
||||||
|
echo ""
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -70,17 +71,17 @@ while true; do
|
|||||||
|
|
||||||
echo "Starting Encode"
|
echo "Starting Encode"
|
||||||
|
|
||||||
height=`echo $job | jq -r .description.resolution[0]`
|
height=`printf "%s\n" $job | jq -r .description.resolution[0]`
|
||||||
width=`echo $job | jq -r .description.resolution[1]`
|
width=`printf "%s\n" $job | jq -r .description.resolution[1]`
|
||||||
|
|
||||||
echo $job | jq
|
printf "%s\n" "$job" | jq
|
||||||
|
|
||||||
aomenco=`echo $job | jq -r .description.options.aomenc`
|
aomenco=`printf "%s\n" "$job" | jq -r .description.options.aomenc`
|
||||||
aomenco=${aomenco//[^a-zA-Z0-9_\- =]/}
|
aomenco=${aomenco//[^a-zA-Z0-9_\- =]/}
|
||||||
ffmpego=`echo $job | jq -r .description.options.ffmpeg`
|
ffmpego=`printf "%s\n" "$job" | jq -r .description.options.ffmpeg`
|
||||||
ffmpego=${ffmpego//[^a-zA-Z0-9_\- =:]/}
|
ffmpego=${ffmpego//[^a-zA-Z0-9_\- =:]/}
|
||||||
|
|
||||||
two_pass=`echo $job | jq -r .description.options.two_pass`
|
two_pass=`printf "%s\n" "$job" | jq -r .description.options.two_pass`
|
||||||
|
|
||||||
if [[ $two_pass = true ]]; then
|
if [[ $two_pass = true ]]; then
|
||||||
set +e
|
set +e
|
@ -2,6 +2,8 @@ use serde::{Serialize, Deserialize};
|
|||||||
use serde_repr::*;
|
use serde_repr::*;
|
||||||
use uuid::Uuid;
|
use uuid::Uuid;
|
||||||
|
|
||||||
|
use std::net::IpAddr;
|
||||||
|
|
||||||
#[derive(Default, Debug, Serialize, Deserialize, Clone)]
|
#[derive(Default, Debug, Serialize, Deserialize, Clone)]
|
||||||
pub struct WUnit {
|
pub struct WUnit {
|
||||||
pub id: Uuid,
|
pub id: Uuid,
|
||||||
|
Loading…
Reference in New Issue
Block a user