spawn thread
This commit is contained in:
parent
4dbdcd6797
commit
2a25ad669b
3 changed files with 62 additions and 51 deletions
|
@ -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)
|
||||||
|
|
|
@ -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")
|
||||||
|
|
101
src/service.rs
101
src/service.rs
|
@ -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(),
|
||||||
|
))
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
|
|
Loading…
Reference in a new issue