Sirikata
|
00001 /* Sirikata 00002 * CassandraPersistedObjectSet.hpp 00003 * 00004 * Copyright (c) 2010, Stanford University 00005 * All rights reserved. 00006 * 00007 * Redistribution and use in source and binary forms, with or without 00008 * modification, are permitted provided that the following conditions are 00009 * met: 00010 * * Redistributions of source code must retain the above copyright 00011 * notice, this list of conditions and the following disclaimer. 00012 * * Redistributions in binary form must reproduce the above copyright 00013 * notice, this list of conditions and the following disclaimer in 00014 * the documentation and/or other materials provided with the 00015 * distribution. 00016 * * Neither the name of Sirikata nor the names of its contributors may 00017 * be used to endorse or promote products derived from this software 00018 * without specific prior written permission. 00019 * 00020 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS 00021 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 00022 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A 00023 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER 00024 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00025 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00026 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00027 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 00028 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00029 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00030 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00031 */ 00032 00033 #ifndef __SIRIKATA_OH_CASSANDRA_PERSISTED_OBJECT_SET_HPP__ 00034 #define __SIRIKATA_OH_CASSANDRA_PERSISTED_OBJECT_SET_HPP__ 00035 00036 #include <sirikata/oh/PersistedObjectSet.hpp> 00037 #include <sirikata/cassandra/Cassandra.hpp> 00038 00039 namespace Sirikata { 00040 namespace OH { 00041 00051 class CassandraPersistedObjectSet : public PersistedObjectSet { 00052 public: 00056 typedef std::tr1::function<void(bool success)> RequestCallback; 00057 00058 CassandraPersistedObjectSet(ObjectHostContext* ctx, const String& host, int port, const String& oh_id); 00059 virtual ~CassandraPersistedObjectSet(); 00060 00061 /* Service Interface */ 00062 virtual void start(); 00063 virtual void stop(); 00064 00065 virtual void requestPersistedObject(const UUID& internal_id, const String& script_type, const String& script_args, const String& script_contents, RequestCallback cb, const String& timestamp="current"); 00066 00067 private: 00068 00069 void initDB(); 00070 void performUpdate(const UUID& internal_id, const String& script_type, const String& script_args, const String& script_contents, RequestCallback cb, const String& timestamp="current"); 00071 00072 ObjectHostContext* mContext; 00073 String mDBHost; 00074 int mDBPort; 00075 String mOHostID; // Object Host ID 00076 CassandraDBPtr mDB; 00077 00078 // FIXME because we don't have proper multithreaded support in cppoh, we 00079 // need to allocate our own thread dedicated to IO 00080 Network::IOService* mIOService; 00081 Network::IOWork* mWork; 00082 Thread* mThread; 00083 }; 00084 00085 } //end namespace OH 00086 } //end namespace Sirikata 00087 00088 #endif //__SIRIKATA_OH_CASSANDRA_PERSISTED_OBJECT_SET_HPP__