Add boilerplate for retrieve hook
This commit is contained in:
parent
bcd728a930
commit
9ef0271893
1 changed files with 54 additions and 0 deletions
|
@ -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(())
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue