--- /dev/null
+/*****************************************************************************
+ * Copyright Igor Barma, Eric Brun, Alexandre Desoubeaux, Christian Martel,
+ * (2 décembre 2008)
+ *
+ * Ce logiciel est un programme informatique servant à l'évaluation des
+ * compétences.
+ *
+ * Ce logiciel est régi par la licence CeCILL soumise au droit français et
+ * respectant les principes de diffusion des logiciels libres. Vous pouvez
+ * utiliser, modifier et/ou redistribuer ce programme sous les conditions
+ * de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA
+ * sur le site "http://www.cecill.info".
+ *
+ * En contrepartie de l'accessibilité au code source et des droits de copie,
+ * de modification et de redistribution accordés par cette licence, il n'est
+ * offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons,
+ * seule une responsabilité restreinte pèse sur l'auteur du programme, le
+ * titulaire des droits patrimoniaux et les concédants successifs.
+ *
+ * A cet égard l'attention de l'utilisateur est attirée sur les risques
+ * associés au chargement, à l'utilisation, à la modification et/ou au
+ * développement et à la reproduction du logiciel par l'utilisateur étant
+ * donné sa spécificité de logiciel libre, qui peut le rendre complexe à
+ * manipuler et qui le réserve donc à des développeurs et des professionnels
+ * avertis possédant des connaissances informatiques approfondies. Les
+ * utilisateurs sont donc invités à charger et tester l'adéquation du
+ * logiciel à leurs besoins dans des conditions permettant d'assurer la
+ * sécurité de leurs systèmes et ou de leurs données et, plus généralement,
+ * à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.
+ *
+ * Le fait que vous puissiez accéder à cet en-tête signifie que vous avez
+ * pris connaissance de la licence CeCILL, et que vous en avez accepté les
+ * termes.
+ *******************************************************************************/
+package com.pentila.evalcomp.manager;
+
+import java.util.Set;
+
+import com.pentila.evalcomp.dao.IMethodValidationDAO;
+import com.pentila.evalcomp.dao.IMethodValidationInstanceDAO;
+import com.pentila.evalcomp.domain.definition.MethodValidation;
+import com.pentila.evalcomp.domain.definition.MethodValidationInstance;
+import com.pentila.evalcomp.domain.plan.PlanComponent;
+import com.pentila.evalcomp.manager.interfacedef.IMethodValidationBase;
+
+// TODO: Auto-generated Javadoc
+/**
+ * The Class MethodValidationManager.
+ */
+public class MethodValidationManager implements IMethodValidationBase {
+
+ /** The logger. */
+ org.slf4j.Logger logger = org.slf4j.LoggerFactory
+ .getLogger(MethodValidationManager.class);
+
+ /** The method validation dao. */
+ IMethodValidationDAO methodValidationDAO;
+
+ /** The method validation instance dao. */
+ IMethodValidationInstanceDAO methodValidationInstanceDAO;
+
+ /**
+ * Gets the method validation dao.
+ *
+ * @return the method validation dao
+ */
+ public IMethodValidationDAO getMethodValidationDAO() {
+ return methodValidationDAO;
+ }
+
+ /**
+ * Sets the method validation dao.
+ *
+ * @param methodValidationDAO
+ * the new method validation dao
+ */
+ public void setMethodValidationDAO(IMethodValidationDAO methodValidationDAO) {
+ this.methodValidationDAO = methodValidationDAO;
+ }
+
+ /**
+ * Gets the method validation instance dao.
+ *
+ * @return the method validation instance dao
+ */
+ public IMethodValidationInstanceDAO getMethodValidationInstanceDAO() {
+ return methodValidationInstanceDAO;
+ }
+
+ /**
+ * Sets the method validation instance dao.
+ *
+ * @param methodValidationInstanceDAO
+ * the new method validation instance dao
+ */
+ public void setMethodValidationInstanceDAO(
+ IMethodValidationInstanceDAO methodValidationInstanceDAO) {
+ this.methodValidationInstanceDAO = methodValidationInstanceDAO;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @seecom.pentila.evalcomp.manager.interfacedef.IMethodValidationBase#
+ * createInstance(com.pentila.evalcomp.domain.plan.PlanComponent,
+ * java.lang.Long)
+ */
+ public MethodValidationInstance createInstance(PlanComponent pc, Long mvid) {
+
+ MethodValidation mv = methodValidationDAO.get(mvid);
+
+ boolean theorique = false;
+ if (mv.getType().equals("T")){
+ theorique = true;
+ }
+
+
+ if (!theorique && pc.getMethodValidationInstance()!= null){
+ methodValidationInstanceDAO.delete(pc.getMethodValidationInstance());
+ pc.getMethodValidationInstances().remove(pc.getMethodValidationInstance());
+ methodValidationInstanceDAO.flush();
+ }else if (theorique && pc.getMethodValidationInstanceTheorique()!= null){
+ methodValidationInstanceDAO.delete(pc.getMethodValidationInstanceTheorique());
+ pc.getMethodValidationInstances().remove(pc.getMethodValidationInstanceTheorique());
+ methodValidationInstanceDAO.flush();
+ }
+
+
+
+ MethodValidationInstance mvi = new MethodValidationInstance();
+
+ mvi.setMethodValidation(mv);
+
+ mvi.setPlanComponent(pc);
+ methodValidationInstanceDAO.saveOrUpdate(mvi);
+
+ return mvi;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @seecom.pentila.evalcomp.manager.interfacedef.IMethodValidationBase#
+ * editMethodValidationInstance
+ * (com.pentila.evalcomp.domain.definition.MethodValidationInstance)
+ */
+ public MethodValidationInstance editMethodValidationInstance(
+ MethodValidationInstance mvi) {
+ methodValidationInstanceDAO.saveOrUpdate(mvi);
+
+ return mvi;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @seecom.pentila.evalcomp.manager.interfacedef.IMethodValidationBase#
+ * getMethodValidations()
+ */
+ public Set<MethodValidation> getMethodValidations() {
+ return methodValidationDAO.getAll();
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @seecom.pentila.evalcomp.manager.interfacedef.IMethodValidationBase#
+ * deleteMethodValidationInstance
+ * (com.pentila.evalcomp.domain.definition.MethodValidationInstance)
+ */
+ public void deleteMethodValidationInstance(
+ MethodValidationInstance methodValidationInstance) {
+ methodValidationInstanceDAO.delete(methodValidationInstance);
+
+ }
+
+}