/* * Copyright 2015 Open mHealth * * 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.openmhealth.schema.domain.omh; import com.fasterxml.jackson.annotation.JsonInclude; import com.fasterxml.jackson.databind.PropertyNamingStrategy.LowerCaseWithUnderscoresStrategy; import com.fasterxml.jackson.databind.annotation.JsonNaming; import org.openmhealth.schema.serializer.SerializationConstructor; import java.time.OffsetDateTime; import java.util.HashMap; import java.util.Map; import static com.google.common.base.Preconditions.checkArgument; import static com.google.common.base.Preconditions.checkNotNull; /** * The acquisition provenance of a data point, representing how and when the data point was acquired. * * @author Emerson Farrugia * @version 1.0 * @see <a href="http://www.openmhealth.org/documentation/#/schema-docs/schema-library/schemas/omh_header">header</a> */ @JsonInclude(JsonInclude.Include.NON_NULL) @JsonNaming(LowerCaseWithUnderscoresStrategy.class) public class DataPointAcquisitionProvenance implements AdditionalPropertySupport { private String sourceName; private OffsetDateTime sourceCreationDateTime; private DataPointModality modality; private Map<String, Object> additionalProperties = new HashMap<>(); @SerializationConstructor protected DataPointAcquisitionProvenance() { } public static class Builder { private String sourceName; private OffsetDateTime sourceCreationDateTime; private DataPointModality modality; /** * @param sourceName the name of the source of the data point */ public Builder(String sourceName) { checkNotNull(sourceName, "A source name hasn't been specified."); checkArgument(!sourceName.isEmpty(), "An empty source name has been specified."); this.sourceName = sourceName; } /** * @param sourceCreationDateTime the timestamp of data point creation at the source * @return this builder */ public Builder setSourceCreationDateTime(OffsetDateTime sourceCreationDateTime) { this.sourceCreationDateTime = sourceCreationDateTime; return this; } /** * @param modality the modality whereby the measure is obtained * @return this builder */ public Builder setModality(DataPointModality modality) { this.modality = modality; return this; } public DataPointAcquisitionProvenance build() { return new DataPointAcquisitionProvenance(this); } } private DataPointAcquisitionProvenance(Builder builder) { this.sourceName = builder.sourceName; this.sourceCreationDateTime = builder.sourceCreationDateTime; this.modality = builder.modality; } public String getSourceName() { return sourceName; } public OffsetDateTime getSourceCreationDateTime() { return sourceCreationDateTime; } public DataPointModality getModality() { return modality; } @Override public Map<String, Object> getAdditionalProperties() { return this.additionalProperties; } @SuppressWarnings("SimplifiableIfStatement") @Override public boolean equals(Object object) { if (this == object) { return true; } if (object == null || getClass() != object.getClass()) { return false; } DataPointAcquisitionProvenance that = (DataPointAcquisitionProvenance) object; if (!sourceName.equals(that.sourceName)) { return false; } if (sourceCreationDateTime != null ? !sourceCreationDateTime.equals(that.sourceCreationDateTime) : that.sourceCreationDateTime != null) { return false; } return modality == that.modality; } @Override public int hashCode() { int result = sourceName.hashCode(); result = 31 * result + (sourceCreationDateTime != null ? sourceCreationDateTime.hashCode() : 0); result = 31 * result + (modality != null ? modality.hashCode() : 0); return result; } }