/* * Copyright (c) 2008-2013, Hazelcast, Inc. All Rights Reserved. * * 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 cz.cuni.mff.d3s.been.mapstore.mongodb; import com.mongodb.DBObject; /** * MongoDB converter. */ public interface MongoDBConverter { /** * Convert from Hazelcast shared object to a MongoDB object * * @param obj Object from Hazelcast * * @return the MongoDB object */ DBObject toDBObject(Object obj); /** * Convert from MongoDB object to an object shareable in Hazelcast * * @param clazz Class resulting shareable object * @param dbObject MongoDB object to deserialize * * @return The shareable object */ Object toObject(Class clazz, DBObject dbObject); }