/* * EuroCarbDB, a framework for carbohydrate bioinformatics * * Copyright (c) 2006-2009, Eurocarb project, or third-party contributors as * indicated by the @author tags or express copyright attribution * statements applied by the authors. * * This copyrighted material is made available to anyone wishing to use, modify, * copy, or redistribute it subject to the terms and conditions of the GNU * Lesser General Public License, as published by the Free Software Foundation. * A copy of this license accompanies this distribution in the file LICENSE.txt. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License * for more details. * * Last commit: $Rev: 1549 $ by $Author: glycoslave $ on $Date:: 2009-07-19 #$ */ package org.eurocarbdb.action.hplc; import org.eurocarbdb.action.*; import org.eurocarbdb.dataaccess.*; import org.eurocarbdb.dataaccess.core.Contributor; import org.eurocarbdb.dataaccess.core.Technique; import org.eurocarbdb.dataaccess.hplc.Profile; import org.eurocarbdb.dataaccess.hplc.Detector; import org.eurocarbdb.dataaccess.hplc.Column; import org.eurocarbdb.dataaccess.hplc.Instrument; import com.opensymphony.xwork.Action; import com.opensymphony.xwork.Preparable; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.eurocarbdb.dataaccess.EntityManager; import static org.eurocarbdb.dataaccess.Eurocarb.getEntityManager; public class CreateParent extends EurocarbAction { private Profile parent = null; private Detector detector = null; private Column column = null; private Instrument instrument = null; private int detector_id; private int instrument_id; private int column_id; private int parent_id = -1; protected static final Log log = LogFactory.getLog( CreateParent.class ); public String execute() throws Exception { EntityManager em = getEntityManager(); if ( parent == null ) { //Eurocarb.getEntityManager().store(parent); return INPUT; } else { detector = Eurocarb.getEntityManager().lookup( Detector.class, detector_id ); instrument = Eurocarb.getEntityManager().lookup( Instrument.class, instrument_id ); column = Eurocarb.getEntityManager().lookup( Column.class, column_id ); if (detector == null) { addFieldError("detector_id", "Invalid detector id"); return INPUT;} Contributor contributor = Contributor.getCurrentContributor(); int contributorIda = contributor.getContributorId(); String contributorId = Integer.toString(contributorIda); log.info("Contributor" + contributorId + "i am here"); parent.setDetector(detector); parent.setInstrument(instrument); parent.setColumn(column); parent.setContributor(Contributor.getCurrentContributor()); parent.setTechnique(Technique.lookupAbbrev("hplc")); parent.setOperator(contributorId); log.info("execute store"); //Eurocarb.getEntityManager().store(parent); em.store(parent); em.flush(); return SUCCESS; } } public Profile getProfile() { return parent; } public void setProfile (Profile parent) { this.parent = parent; } /* public void setProfileId(int id) { this.profile_id = id; } public int getProfileId() { return this.profile_id; } */ // getter and setter for evaluting parent ids public Detector getDetector() { return detector; } public void setDetector (Detector detector) { this.detector = detector; } public void setDetectorId(int id) { this.detector_id = id; } public int getDetectorId() { return this.detector_id; } public Instrument getInstrument() { return instrument; } public void setInstrument (Instrument instrument) { this.instrument = instrument; } public void setInstrumentId(int id) { this.instrument_id = id; } public int getInstrumentId() { return this.instrument_id; } public Column getColumn() { return column; } public void setColumn (Column column) { this.column = column; } public void setColumnId(int id) { this.column_id = id; } public int getColumnId() { return this.column_id; } }