Package org.openmhealth.reference.domain.mongodb

Source Code of org.openmhealth.reference.domain.mongodb.MongoData

/*******************************************************************************
* Copyright 2013 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.reference.domain.mongodb;

import org.mongojack.MongoCollection;
import org.openmhealth.reference.data.DataSet;
import org.openmhealth.reference.domain.Data;
import org.openmhealth.reference.domain.MetaData;
import org.openmhealth.reference.domain.Schema;
import org.openmhealth.reference.exception.OmhException;

import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.databind.JsonNode;

/**
* <p>
* A MongoDB extension of the {@link Data} type.
* </p>
*
* <p>
* This class is immutable.
* </p>
*
* @author John Jenkins
*/
@MongoCollection(name = DataSet.DB_NAME)
public class MongoData extends Data implements MongoDbObject {
  /**
   * The ID for this class which is used for serialization.
   */
  private static final long serialVersionUID = 1L;
 
  /**
   * The database ID for this object.
   */
  @JsonIgnore
  private final String dbId;

  /**
   * Creates a new data object. This should only be used by serialization
   * methods when they are pulling already-validated data from the database.
   *
   * @param owner
   *       The identifier for the user that owns the data.
   *
   * @param schemaId
   *       The ID of the schema that was used to validate this data.
   *
   * @param schemaVersion
   *       The version of the schema that was used to validate this data.
   *
   * @param metaData
   *        The meta-data for this data.
   *
   * @param data
   *        The data.
   *
   * @throws OmhException
   *         Any of the parameters is null.
   */
  @JsonCreator
  private MongoData(
    @JsonProperty(DATABASE_FIELD_ID) final String dbId,
    @JsonProperty(JSON_KEY_OWNER) final String owner,
    @JsonProperty(Schema.JSON_KEY_ID) final String schemaId,
    @JsonProperty(Schema.JSON_KEY_VERSION) final long schemaVersion,
    @JsonProperty(JSON_KEY_METADATA) final MetaData metaData,
    @JsonProperty(JSON_KEY_DATA) final JsonNode data)
    throws OmhException {

    super(owner, schemaId, schemaVersion, metaData, data);
   
    // Store the MongoDB ID.
    if(dbId == null) {
      throw new OmhException("The MongoDB ID is missing.");
    }
    else {
      this.dbId = dbId;
    }
  }

  /*
   * (non-Javadoc)
   * @see org.openmhealth.reference.data.mongodb.MongoDbObject#getDatabaseId()
   */
  @Override
  public String getDatabaseId() {
    return dbId;
  }
}
TOP

Related Classes of org.openmhealth.reference.domain.mongodb.MongoData

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.