Package com.krminc.phr.api.converter

Source Code of com.krminc.phr.api.converter.AllergyConverter

/**
* Copyright (C) 2012 KRM Associates, Inc. healtheme@krminc.com
*
* 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 com.krminc.phr.api.converter;

import com.krminc.phr.domain.Allergy;
import com.krminc.phr.domain.DataSource;
import java.net.URI;
import java.util.Date;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlTransient;
import javax.xml.bind.annotation.XmlAttribute;
import javax.ws.rs.core.UriBuilder;
import javax.persistence.EntityManager;
import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.krminc.phr.api.converter.util.ConverterUtils;
import com.krminc.phr.domain.HealthRecord;

/**
* Allergy JAXB parser.
*
* @author Daniel Shaw (dshaw.com)
*/
@XmlRootElement(name = "allergy")
public class AllergyConverter {

    final Logger logger = LoggerFactory.getLogger(AllergyConverter.class);
    private Allergy entity;
    private URI uri;
    private int expandLevel;

    public boolean hasError = false;

    /** Creates a new instance of AllergyConverter */
    public AllergyConverter() {
        entity = new Allergy();
    }

    /**
     * Creates a new instance of AllergyConverter.
     *
     * @param entity associated entity
     * @param uri associated uri
     * @param expandLevel indicates the number of levels the entity graph should be expanded@param isUriExtendable indicates whether the uri can be extended
     */
    public AllergyConverter(Allergy entity, URI uri, int expandLevel, boolean isUriExtendable) {
        this.entity = entity;
        this.uri = (isUriExtendable) ? UriBuilder.fromUri(uri).path(entity.getAllergyId() + "/").build() : uri;
        this.expandLevel = expandLevel;
    }

    /**
     * Creates a new instance of AllergyConverter.
     *
     * @param entity associated entity
     * @param uri associated uri
     * @param expandLevel indicates the number of levels the entity graph should be expanded
     */
    public AllergyConverter(Allergy entity, URI uri, int expandLevel) {
        this(entity, uri, expandLevel, false);
    }

    /**
     * Getter for allergyId.
     *
     * @return value for allergyId
     */
    @XmlElement
    public Long getAllergyId() {
        return (expandLevel > 0) ? entity.getAllergyId() : null;
    }

    /**
     * Setter for allergyId.
     *
     * @param value the value to set
     */
    public void setAllergyId(Long value) {
        try {
            entity.setAllergyId(value);
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

    /**
     * Getter for userId.
     *
     * @return value for userId
     */
    @XmlElement
    public Long getHealthRecordId() {
        return (expandLevel > 0) ? entity.getHealthRecordId() : null;
    }

    /**
     * Setter for userId.
     *
     * @param value the value to set
     */
    public void setHealthRecordId(Long value) {
        try {
            entity.setHealthRecordId(value);
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

    /**
     * Getter for dataSourceId.
     *
     * @return value for dataSourceId
     */
    @XmlElement
    public Long getDataSourceId() {
        return (expandLevel > 0) ? entity.getDataSourceId() : null;
    }

    /**
     * Setter for dataSourceId.
     *
     * @param value the value to set
     */
    public void setDataSourceId(Long value) {
        try {
            if (value != 1) {
                throw new Exception();
            }
            entity.setDataSourceId(value);
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

    /**
     * Getter for careDocumentId.
     *
     * @return value for careDocumentId
     */
    @XmlElement
    public Long getCareDocumentId() {
        return (expandLevel > 0) ? entity.getCareDocumentId() : null;
    }

    /**
     * Setter for careDocumentId.
     *
     * @param value the value to set
     */
    public void setCareDocumentId(Long value) {
        try {
            entity.setCareDocumentId(value);
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

    /**
     * Getter for sourceId.
     *
     * @return value for sourceId
     */
    @XmlElement
    public Long getSourceId() {
        return (expandLevel > 0) ? entity.getSourceId() : null;
    }

    /**
     * Setter for sourceId.
     *
     * @param value the value to set
     */
    public void setSourceId(Long value) {
        try {
            if (value != 1) {
                throw new Exception();
            }
            entity.setSourceId(value);
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

    /**
     * Getter for allergyText.
     *
     * @return value for allergyText
     */
    @XmlElement
    public String getAllergyText() {
        return (expandLevel > 0) ? entity.getAllergyText() : null;
    }

    /**
     * Setter for allergyText.
     *
     * @param value the value to set
     */
    public void setAllergyText(String value) {
        try {
            value = ConverterUtils.prepareInput(value);
            //length 0-75
            if (value.length() > 0 && value.length() <= 75) {
                entity.setAllergyText(value);
            } else {
                throw new Exception();
            }
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

    /**
     * Getter for observedDate.
     *
     * @return value for observedDate
     */
    @XmlElement
    @XmlJavaTypeAdapter(DateAdapter.class)
    public Date getObservedDate() {
        return (expandLevel > 0) ? entity.getObservedDate() : null;
    }

    /**
     * Setter for observedDate.
     *
     * @param value the value to set
     */
    public void setObservedDate(Date value) {
        try {
            entity.setObservedDate(value);
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

    /**
     * Getter for addedDate.
     *
     * @return value for addedDate
     */
    @XmlElement
    @XmlJavaTypeAdapter(DateAdapter.class)
    public Date getDateAdded() {
        return (expandLevel > 0) ? entity.getDateAdded() : null;
    }
    /**
     * Getter for severity.
     *
     * @return value for severity
     */
    @XmlElement
    public String getSeverity() {
        return (expandLevel > 0) ? entity.getSeverity() : null;
    }

    /**
     * Setter for severity.
     *
     * @param value the value to set
     */
    public void setSeverity(String value) {
        try {
            value = ConverterUtils.prepareInput(value);
            if (value.length() > 0 && value.length() <= 255) {
                entity.setSeverity(value);
            }
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

    /**
     * Getter for comments.
     *
     * @return value for comments
     */
    @XmlElement
    public String getComments() {
        return (expandLevel > 0) ? entity.getComments() : null;
    }

    /**
     * Setter for comments.
     *
     * @param value the value to set
     */
    public void setComments(String value) {
        try {
            value = ConverterUtils.prepareInput(value);
            if (value.length() > 0 && value.length() <= 512) {
                entity.setComments(value);
            }
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

    /**
     * Getter for reaction.
     *
     * @return value for reaction
     */
    @XmlElement
    public String getReaction() {
        return (expandLevel > 0) ? entity.getReaction() : null;
    }

    /**
     * Setter for reaction.
     *
     * @param value the value to set
     */
    public void setReaction(String value) {
        try {
            value = ConverterUtils.prepareInput(value);
            if (value.length() > 0 && value.length() <= 255) {
                entity.setReaction(value);
            }
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

    /**
     * Getter for mask.
     *
     * @return value for mask
     */
    @XmlElement
    public String getMask() {
        return (expandLevel > 0) ? entity.getMask() : null;
    }

    /**
     * Setter for mask.
     *
     * @param value the value to set
     */
    public void setMask(String value) {
        try {
            if (ConverterUtils.isValidMask(value)) {
                entity.setMask(value.trim());
            } else {
                throw new Exception();
            }
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

    /**
     * Returns the URI associated with this converter.
     *
     * @return the uri
     */
    @XmlAttribute
    public URI getUri() {
        return uri;
    }

    /**
     * Sets the URI for this reference converter.
     *
     */
    public void setUri(URI uri) {
        try {
            this.uri = uri;
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

    /**
     * Returns the Allergy entity.
     *
     * @return an entity
     */
    @XmlTransient
    public Allergy getEntity() {
        if (entity.getAllergyId() == null) {
            AllergyConverter converter = UriResolver.getInstance().resolve(AllergyConverter.class, uri);
            if (converter != null) {
                entity = converter.getEntity();
            }
        }
        return entity;
    }

    /**
     * Returns the resolved Allergy entity.
     *
     * @return an resolved entity
     */
    public Allergy resolveEntity(EntityManager em) {
        HealthRecord healthRecord = entity.getHealthRecord();
        if (healthRecord != null) {
            entity.setHealthRecord(em.getReference(HealthRecord.class, healthRecord.getHealthRecordId()));
        }
        return entity;
    }
}
TOP

Related Classes of com.krminc.phr.api.converter.AllergyConverter

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.