Add boilerplate for retrieve hook

This commit is contained in:
Matthias Beyer 2016-07-15 22:41:59 +02:00
parent bcd728a930
commit 9ef0271893
1 changed files with 54 additions and 0 deletions

View File

@ -0,0 +1,54 @@
use toml::Value;
use libimagstore::storeid::StoreId;
use libimagstore::hook::Hook;
use libimagstore::hook::result::HookResult;
use libimagstore::hook::position::HookPosition;
use libimagstore::hook::accessor::{HookDataAccessor, HookDataAccessorProvider};
use libimagstore::hook::accessor::StoreIdAccessor;
#[derive(Debug)]
pub struct RetrieveHook {
position: HookPosition,
config: Option<Value>,
}
impl RetrieveHook {
pub fn new(p: HookPosition) -> RetrieveHook {
RetrieveHook {
position: p,
config: None,
}
}
}
impl Hook for RetrieveHook {
fn name(&self) -> &'static str {
"stdhook_git_retrieve"
}
fn set_config(&mut self, config: &Value) {
self.config = Some(config.clone());
}
}
impl HookDataAccessorProvider for RetrieveHook {
fn accessor(&self) -> HookDataAccessor {
HookDataAccessor::StoreIdAccess(self)
}
}
impl StoreIdAccessor for RetrieveHook {
fn access(&self, id: &StoreId) -> HookResult<()> {
debug!("[GIT RETRIEVE HOOK]: {:?}", id);
Ok(())
}
}