X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=runtime%2Forg.argeo.slc.support.jcr%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fjcr%2Fdao%2FAbstractSlcJcrDao.java;h=09dce97d39c84ef3c0a943caf24c83a7222ce148;hb=4663b42433ba4a16c81d90927aecff2a923cd7a4;hp=328ec10d534e18e19b4a5670979959ce1518ceba;hpb=dfe0c5ca8925056d9483a180d72ab7607e28b03a;p=gpl%2Fargeo-slc.git diff --git a/runtime/org.argeo.slc.support.jcr/src/main/java/org/argeo/slc/jcr/dao/AbstractSlcJcrDao.java b/runtime/org.argeo.slc.support.jcr/src/main/java/org/argeo/slc/jcr/dao/AbstractSlcJcrDao.java index 328ec10d5..09dce97d3 100644 --- a/runtime/org.argeo.slc.support.jcr/src/main/java/org/argeo/slc/jcr/dao/AbstractSlcJcrDao.java +++ b/runtime/org.argeo.slc.support.jcr/src/main/java/org/argeo/slc/jcr/dao/AbstractSlcJcrDao.java @@ -1,27 +1,57 @@ +/* + * Copyright (C) 2010 Mathieu Baudier + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + package org.argeo.slc.jcr.dao; import java.util.Calendar; import java.util.Date; import java.util.GregorianCalendar; +import javax.jcr.NamespaceRegistry; +import javax.jcr.RepositoryException; import javax.jcr.Session; +import javax.jcr.query.Query; +import org.argeo.ArgeoException; import org.argeo.jcr.JcrUtils; +import org.argeo.jcr.NodeMapper; import org.argeo.jcr.NodeMapperProvider; import org.argeo.slc.runtime.SlcAgentDescriptor; import org.argeo.slc.test.TestResult; - +import org.argeo.slc.test.TestRunDescriptor; public abstract class AbstractSlcJcrDao { private Session session; - //We inject the nodeMapperProvider that define a default node mapper as an + // protected Workspace workspace; + // protected QueryManager queryManager; + protected NodeMapper nodeMapper; + + // We inject the nodeMapperProvider that define a default node mapper as an // entry point of the NodeMapper private NodeMapperProvider nodeMapperProvider; - - + public void init() { + nodeMapper = getNodeMapperProvider().findNodeMapper(null); + // JcrUtils.registerNamespaceSafely(session, "slc", + // "http://www.argeo.org/slc/0.12"); + + } + public void setSession(Session session) { this.session = session; } @@ -29,31 +59,39 @@ public abstract class AbstractSlcJcrDao { protected Session getSession() { return session; } - + // IoC public void setNodeMapperProvider(NodeMapperProvider nodeMapperProvider) { this.nodeMapperProvider = nodeMapperProvider; } - + // TODO : define a strategy to define basePathes protected String basePath(TestResult testResult) { Calendar cal = new GregorianCalendar(); cal.setTime(new Date()); - // cal.setTime(slcExecution.getStartDate()); - return "/slc/testresult/" + JcrUtils.dateAsPath(cal) + "testresult"; + return "/slc/testresults/" + JcrUtils.dateAsPath(cal) + "testresult"; } - + protected String basePath(SlcAgentDescriptor slcAgentDescriptor) { - Calendar cal = new GregorianCalendar(); - cal.setTime(new Date()); - // cal.setTime(slcExecution.getStartDate()); return "/slc/agents/" - + JcrUtils.hostAsPath(slcAgentDescriptor.getHost() + "/agent"); + + JcrUtils.hostAsPath(slcAgentDescriptor.getHost()) + "/agent"; } - protected NodeMapperProvider getNodeMapperProvider(){ + protected String basePath(TestRunDescriptor testRunDescriptor) { + return "/slc/testruns/" + testRunDescriptor.getSlcExecutionUuid() + + "/testrun"; + } + + protected NodeMapperProvider getNodeMapperProvider() { return this.nodeMapperProvider; } - + protected Query createQuery(String query, String type) { + try { + return getSession().getWorkspace().getQueryManager().createQuery( + query, type); + } catch (RepositoryException e) { + throw new ArgeoException("Cannot create query " + query, e); + } + } }