import javax.jcr.Node;
import javax.jcr.NodeIterator;
-import javax.jcr.RepositoryException;
-import javax.jcr.Session;
-import javax.jcr.Workspace;
import javax.jcr.query.Query;
-import javax.jcr.query.QueryManager;
import javax.jcr.query.QueryResult;
-import org.argeo.jcr.BeanNodeMapper;
import org.argeo.jcr.JcrUtils;
import org.argeo.slc.SlcException;
import org.argeo.slc.dao.process.SlcExecutionDao;
import org.argeo.slc.process.SlcExecution;
import org.argeo.slc.process.SlcExecutionStep;
-public class SlcExecutionDaoJcr implements SlcExecutionDao {
- private Session session;
- private Workspace workspace;
- private QueryManager queryManager;
-
- private BeanNodeMapper beanNodeMapper = new BeanNodeMapper();
-
- public void init() {
- try {
- workspace = session.getWorkspace();
- queryManager = workspace.getQueryManager();
- } catch (RepositoryException e) {
- throw new SlcException("Cannot initialize DAO", e);
- }
- }
+public class SlcExecutionDaoJcr extends AbstractSlcJcrDao implements
+ SlcExecutionDao {
+ // private final static Log log =
+ // LogFactory.getLog(SlcExecutionDaoJcr.class);
public void addSteps(String slcExecutionId,
List<SlcExecutionStep> additionalSteps) {
public void create(SlcExecution slcExecution) {
try {
- beanNodeMapper.save(getSession(), basePath(slcExecution),
- slcExecution);
- session.save();
+ nodeMapper.save(getSession(), basePath(slcExecution), slcExecution);
+ getSession().save();
} catch (Exception e) {
- throw new SlcException("Cannot import " + slcExecution, e);
+ throw new SlcException("Cannot create slcExecution" + slcExecution,
+ e);
}
}
Calendar cal = new GregorianCalendar();
cal.setTime(new Date());
// cal.setTime(slcExecution.getStartDate());
- return "/slc/processes/" + slcExecution.getHost().replace('.', '/')
- + '/' + JcrUtils.dateAsPath(cal) + "process";
+ String host = slcExecution.getHost();
+ if (host == null)
+ host = "UNKOWNHOST";
+ return "/slc/processes/" + JcrUtils.hostAsPath(host) + '/'
+ + JcrUtils.dateAsPath(cal) + "process";
}
public SlcExecution getSlcExecution(String uuid) {
Node node = JcrUtils.querySingleNode(query);
if (node == null)
return null;
- return (SlcExecution) beanNodeMapper.nodeToBean(node);
+ return (SlcExecution) nodeMapper.load(node);
} catch (Exception e) {
throw new SlcException("Cannot load SLC execution " + uuid, e);
}
NodeIterator iterator = qr.getNodes();
while (iterator.hasNext()) {
Node node = iterator.nextNode();
- SlcExecution slcExecution = (SlcExecution) beanNodeMapper
- .nodeToBean(node);
+ SlcExecution slcExecution = (SlcExecution) nodeMapper
+ .load(node);
res.add(slcExecution);
}
return res;
try {
Query query = queryManager.createQuery(queryString, Query.XPATH);
Node node = JcrUtils.querySingleNode(query);
- beanNodeMapper.update(node, slcExecution);
+ nodeMapper.update(node, slcExecution);
+ getSession().save();
} catch (Exception e) {
throw new SlcException("Cannot update " + slcExecution, e);
}
}
- public void setSession(Session session) {
- this.session = session;
- }
-
- protected Session getSession() {
- return session;
- }
-
- public void setBeanNodeMapper(BeanNodeMapper beanNodeMapper) {
- this.beanNodeMapper = beanNodeMapper;
- }
-
}