spawn thread

This commit is contained in:
Michael 2018-08-16 21:06:23 +00:00
parent 4dbdcd6797
commit 2a25ad669b
3 changed files with 62 additions and 51 deletions

View file

@ -36,6 +36,8 @@ struct Config {
secret: String, secret: String,
#[serde(default)] #[serde(default)]
disable_hmac_verify: bool, disable_hmac_verify: bool,
#[serde(default = "default_path")]
path: PathBuf,
} }
#[derive(Serialize, Deserialize)] #[derive(Serialize, Deserialize)]
@ -54,6 +56,10 @@ struct GithubPayload {
repository: RepositoryInfo, repository: RepositoryInfo,
} }
fn default_path() -> PathBuf {
PathBuf::from(".")
}
fn main() -> Result<(), Error> { fn main() -> Result<(), Error> {
let args = Opt::from_args(); let args = Opt::from_args();
let config: Config = serde_json::from_str(&args.config)?; let config: Config = serde_json::from_str(&args.config)?;
@ -86,8 +92,7 @@ fn main() -> Result<(), Error> {
let payload: GithubPayload = serde_json::from_str(&payload.body)?; let payload: GithubPayload = serde_json::from_str(&payload.body)?;
let mut target_path = PathBuf::from(env::var("DIP_WORKDIR")?); let mut target_path = PathBuf::from(env::var("DIP_WORKDIR")?);
target_path.push("repository"); target_path.push(&config.path);
println!("{:?}", &target_path);
Command::new("git") Command::new("git")
.arg("clone") .arg("clone")
.arg(&payload.repository.clone_url) .arg(&payload.repository.clone_url)

View file

@ -20,6 +20,9 @@ pub enum Action {
} }
impl Handler { impl Handler {
pub fn config(&self) -> &TomlValue {
&self.config
}
pub fn from(config: &TomlValue) -> Result<Self, Error> { pub fn from(config: &TomlValue) -> Result<Self, Error> {
let handler = config let handler = config
.get("type") .get("type")

View file

@ -1,4 +1,5 @@
use std::collections::HashMap; use std::collections::HashMap;
use std::thread;
use futures::{future, Future, Stream}; use futures::{future, Future, Stream};
use hyper::{Body, Error, Request, Response, StatusCode}; use hyper::{Body, Error, Request, Response, StatusCode};
@ -42,56 +43,58 @@ pub fn dip_service(req: Request<Body>) -> Box<Future<Item = Response<Body>, Erro
}) })
.collect::<HashMap<_, _>>(); .collect::<HashMap<_, _>>();
let method = req.method().as_str().to_owned(); let method = req.method().as_str().to_owned();
// probably not idiomatically the best way to do it
// i was just trying to get something working
let body = req.into_body();
Box::new(body.concat2().map(move |body| {
let req_obj = json!({
"body": String::from_utf8(body.to_vec()).unwrap(),
"headers": headers,
"method": method,
});
let hooks = HOOKS.lock().unwrap();
{
let mut temp_dir = Temp::new_dir().unwrap();
let temp_path = temp_dir.to_path_buf();
assert!(temp_path.exists());
let hook = hooks.get(&name).unwrap(); // spawn job
let (code, msg) = hook.iter() thread::spawn(move || {
.fold(Ok(req_obj), |prev, handler| { req.into_body().concat2().map(move |body| {
prev.and_then(|val| handler.run(&temp_path, val)) let body = String::from_utf8(body.to_vec()).unwrap();
}) let req_obj = json!({
.map(|res| { "body": body,
( "headers": headers,
StatusCode::ACCEPTED, "method": method,
format!( });
"stdout:\n{}\n\nstderr:\n{}", let hooks = HOOKS.lock().unwrap();
res.get("stdout").and_then(|v| v.as_str()).unwrap_or(""), {
res.get("stderr").and_then(|v| v.as_str()).unwrap_or(""), let mut temp_dir = Temp::new_dir().unwrap();
), let temp_path = temp_dir.to_path_buf();
) assert!(temp_path.exists());
})
.unwrap_or_else(|err| (StatusCode::BAD_REQUEST, format!("Error: {:?}", err)));
temp_dir.release();
Response::builder()
.status(code)
.body(Body::from(msg))
.unwrap_or_else(|err| Response::new(Body::from(format!("{}", err))))
}
}))
}
/* pub fn dip_service( let hook = hooks.get(&name).unwrap();
req: Request<Body>, let (code, msg) = hook.iter()
) -> Box<Future<Item = Response<Body>, Error = String> + Send> { .fold(Ok(req_obj), |prev, handler| {
let uri = req.uri().path().to_owned(); prev.and_then(|val| {
Box::new(future::ok(service_fn(req).unwrap_or_else(|err| { println!("Running {}...", handler.config());
eprintln!("Error from '{}': {}", uri, err); let result = handler.run(&temp_path, val);
println!("{:?}", result);
result
})
})
.map(|res| {
(
StatusCode::ACCEPTED,
format!(
"stdout:\n{}\n\nstderr:\n{}",
res.get("stdout").and_then(|v| v.as_str()).unwrap_or(""),
res.get("stderr").and_then(|v| v.as_str()).unwrap_or(""),
),
)
})
.unwrap_or_else(|err| (StatusCode::BAD_REQUEST, format!("Error: {:?}", err)));
temp_dir.release();
Response::builder()
.status(code)
.body(Body::from(msg))
.unwrap_or_else(|err| Response::new(Body::from(format!("{}", err))))
}
})
});
Box::new(future::ok(
Response::builder() Response::builder()
.status(StatusCode::NOT_FOUND) .status(StatusCode::ACCEPTED)
.body(Body::from(NOTFOUND)) // TODO: assign job a uuid and do some logging
.unwrap() .body(Body::from(format!("job {} started", -1)))
}))) .unwrap(),
))
} }
*/