Package com.krminc.phr.api.converter

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

/**
* 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.
*/
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/

package com.krminc.phr.api.converter;

import com.krminc.phr.domain.Visit;
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.joda.time.DateTime;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.krminc.phr.api.converter.util.ConverterUtils;
import com.krminc.phr.domain.HealthRecord;

/**
*
* @author cmccall
*/

@XmlRootElement(name = "visit")
public class VisitConverter {
    private Visit entity;
    private URI uri;
    private int expandLevel;

    final Logger logger = LoggerFactory.getLogger(VisitConverter.class);
    public boolean hasError = false;

    /** Creates a new instance of VisitConverter */
    public VisitConverter() {
        entity = new Visit();
    }

    /**
     * Creates a new instance of VisitConverter.
     *
     * @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 VisitConverter(Visit entity, URI uri, int expandLevel, boolean isUriExtendable) {
        this.entity = entity;
        this.uri = (isUriExtendable) ? UriBuilder.fromUri(uri).path(entity.getVisitId() + "/").build() : uri;
        this.expandLevel = expandLevel;
    }

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

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

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

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

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

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

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

    /**
     * Setter for ObservedDate.
     *
     * @param value the value to set
     */
    public void setVisitDate(String value) {
        try {
            value = ConverterUtils.prepareInput(value);
            DateTime date = new DateTime(value);
            this.setVisitDate(date.toDate());
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

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

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

    /**
     * Setter for visitTime.
     *
     * @param value the value to set
     */
    public void setVisitTime(String value) {
        try {
            value = ConverterUtils.prepareInput(value);
            DateTime date = new DateTime(value);
            this.setVisitTime(date.toDate());
        }
        catch(Exception ex) {
            hasError = true;
        }
    }

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

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

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

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

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

    /**
     * Setter for provider.
     *
     * @param value the value to set
     */
    public void setProvider(String value) {
        try {
            value = ConverterUtils.prepareInput(value);
            if (value.length() > 0) {
                if (value.length() <=255) {
                    entity.setProvider(value);
                } else {
                    throw new Exception();
                }
            }
        }
        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);
            entity.setComments(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 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 HealthRecordId.
     *
     * @return value for HealthRecordId
     */
    @XmlElement
    public Long getHealthRecordId() {
        return (expandLevel > 0) ? entity.getHealthRecordId() : null;
    }

    /**
     * Setter for HealthRecordId.
     *
     * @param value the value to set
     */
    public void setHealthRecordId(Long value) {
        try {
            entity.setHealthRecordId(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 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 Visit entity.
     *
     * @return an entity
     */
    @XmlTransient
    public Visit getEntity() {
        if (entity.getVisitId() == null) {
            VisitConverter converter = UriResolver.getInstance().resolve(VisitConverter.class, uri);
            if (converter != null) {
                entity = converter.getEntity();
            }
        }
        return entity;
    }

    /**
     * Returns the resolved Visit entity.
     *
     * @return an resolved entity
     */
    public Visit 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.VisitConverter

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.