From 26a29763aa23bf394dbb36a35a09937660168dc2 Mon Sep 17 00:00:00 2001 From: eranda Date: Fri, 19 Aug 2011 19:42:16 +0000 Subject: Making REST services from the datastores(Apache Cassandra, Apacha CouchDB and Apache Hadoop/hbase) git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@1159757 13f79535-47bb-0310-9956-ffa450edef68 --- collaboration/GSoC-2011-Eranda/cassandra/pom.xml | 29 ++++++--- .../tuscany/nosqldatastore/DatastoreService.java | 67 ++++++++++++++++++++ .../nosqldatastore/DatastoreServiceImpl.java | 71 ++++++++++++++++++++++ .../main/resources/META-INF/sca-contribution.xml | 7 +++ .../src/main/resources/datastore.composite | 16 +++++ collaboration/GSoC-2011-Eranda/couchdb/pom.xml | 16 ++++- .../tuscany/nosqldatastore/DatastoreService.java | 67 ++++++++++++++++++++ .../nosqldatastore/DatastoreServiceImpl.java | 71 ++++++++++++++++++++++ .../main/resources/META-INF/sca-contribution.xml | 7 +++ .../couchdb/src/main/resources/datastore.composite | 16 +++++ collaboration/GSoC-2011-Eranda/hbase/pom.xml | 18 +++++- .../tuscany/nosqldatastore/DatastoreService.java | 67 ++++++++++++++++++++ .../nosqldatastore/DatastoreServiceImpl.java | 71 ++++++++++++++++++++++ .../main/resources/META-INF/sca-contribution.xml | 7 +++ .../hbase/src/main/resources/datastore.composite | 16 +++++ 15 files changed, 534 insertions(+), 12 deletions(-) create mode 100644 collaboration/GSoC-2011-Eranda/cassandra/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreService.java create mode 100644 collaboration/GSoC-2011-Eranda/cassandra/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreServiceImpl.java create mode 100644 collaboration/GSoC-2011-Eranda/cassandra/src/main/resources/META-INF/sca-contribution.xml create mode 100644 collaboration/GSoC-2011-Eranda/cassandra/src/main/resources/datastore.composite create mode 100644 collaboration/GSoC-2011-Eranda/couchdb/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreService.java create mode 100644 collaboration/GSoC-2011-Eranda/couchdb/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreServiceImpl.java create mode 100644 collaboration/GSoC-2011-Eranda/couchdb/src/main/resources/META-INF/sca-contribution.xml create mode 100644 collaboration/GSoC-2011-Eranda/couchdb/src/main/resources/datastore.composite create mode 100644 collaboration/GSoC-2011-Eranda/hbase/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreService.java create mode 100644 collaboration/GSoC-2011-Eranda/hbase/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreServiceImpl.java create mode 100644 collaboration/GSoC-2011-Eranda/hbase/src/main/resources/META-INF/sca-contribution.xml create mode 100644 collaboration/GSoC-2011-Eranda/hbase/src/main/resources/datastore.composite diff --git a/collaboration/GSoC-2011-Eranda/cassandra/pom.xml b/collaboration/GSoC-2011-Eranda/cassandra/pom.xml index 1194cdfd26..bc74631d4e 100644 --- a/collaboration/GSoC-2011-Eranda/cassandra/pom.xml +++ b/collaboration/GSoC-2011-Eranda/cassandra/pom.xml @@ -22,39 +22,52 @@ under the License. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> 4.0.0 org.apache.tuscany - nosql-datastore + nosql-datastore-cassandra 0.0.1 - jar tuscany http://maven.apache.org UTF-8 + 0.7.1 + 0.7.0-29 + 2.0-M5 - me.prettyprint hector-core - 0.7.0-29 + ${hector.version} org.apache.cassandra cassandra-javautils - 0.7.1 + ${cassandra.version} org.apache.cassandra cassandra-all - 0.7.4 + ${cassandra.version} + + + org.apache.tuscany.sca + tuscany-sca-api + ${tuscany.version} + provided + + + javax.ws.rs + jsr311-api + 1.1.1 + provided junit junit - 4.8.2 + 4.8.1 + test - diff --git a/collaboration/GSoC-2011-Eranda/cassandra/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreService.java b/collaboration/GSoC-2011-Eranda/cassandra/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreService.java new file mode 100644 index 0000000000..e63fb16bf5 --- /dev/null +++ b/collaboration/GSoC-2011-Eranda/cassandra/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreService.java @@ -0,0 +1,67 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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.apache.tuscany.nosqldatastore; + +import org.apache.tuscany.nosqldatastore.exception.*; +import org.oasisopen.sca.annotation.Remotable; + +import javax.ws.rs.*; + +@Remotable +public interface DatastoreService { + + @GET + @Path("echoTest") + String echoTest(@QueryParam("database") String database); + + @POST + @Path("addEntry") + void addEntry(@QueryParam("database") String database, + @QueryParam("group") String group, + @QueryParam("key") String key, + @QueryParam("value") String value) throws DuplicateEntryException, SessionException; + + @POST + @Path("updateEntry") + void updateEntry(@QueryParam("database") String database, + @QueryParam("group") String group, + @QueryParam("key") String key, + @QueryParam("value") String value) throws EntryNotFoundException, SessionException; + + @POST + @Path("deleteEntry") + void deleteEntry(@QueryParam("database") String database, + @QueryParam("group") String group, + @QueryParam("key") String key) throws EntryNotFoundException, SessionException; + + @GET + @Path("getEntry") + String getEntry(@QueryParam("database") String database, + @QueryParam("group") String group, + @QueryParam("key") String key) throws EntryNotFoundException, SessionException; + + @DELETE + @Path("deleteGroup") + void deleteGroup(@QueryParam("database") String database, + @QueryParam("group") String group) throws GroupNotFoundException, SessionException; + + @DELETE + @Path("deleteDatabase") + void deleteDatabase(@QueryParam("database") String database) throws DatabaseNotFoundException, SessionException; +} diff --git a/collaboration/GSoC-2011-Eranda/cassandra/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreServiceImpl.java b/collaboration/GSoC-2011-Eranda/cassandra/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreServiceImpl.java new file mode 100644 index 0000000000..6c63f74cef --- /dev/null +++ b/collaboration/GSoC-2011-Eranda/cassandra/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreServiceImpl.java @@ -0,0 +1,71 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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.apache.tuscany.nosqldatastore; + +import org.apache.tuscany.nosqldatastore.exception.*; +import org.oasisopen.sca.annotation.Init; +import org.oasisopen.sca.annotation.Scope; + +@Scope("COMPOSITE") +public class DatastoreServiceImpl implements DatastoreService{ + + private Session session; + + @Init + public void init(){ + session = (new SessionFactory()).getCassandraSession(); + } + + public String echoTest(String database){ + return "Database "+database; + } + + public void addEntry(String database, String group, String key, String value) throws DuplicateEntryException, SessionException { + Database db = session.getDatabase(database); + Group grp = db.getGroup(group); + grp.addEntry(key, value); + } + + public void updateEntry(String database, String group, String key, String value) throws EntryNotFoundException, SessionException { + Database db = session.getDatabase(database); + Group grp = db.getGroup(group); + grp.updateEntry(key, value); + } + + public void deleteEntry(String database, String group, String key) throws EntryNotFoundException, SessionException { + Database db = session.getDatabase(database); + Group grp = db.getGroup(group); + grp.deleteEntry(key); + } + + public String getEntry(String database, String group, String key) throws EntryNotFoundException, SessionException { + Database db = session.getDatabase(database); + Group grp = db.getGroup(group); + return grp.getEntry(key); + } + + public void deleteGroup(String database, String group) throws GroupNotFoundException, SessionException { + Database db = session.getDatabase(database); + db.deleteGroup(group); + } + + public void deleteDatabase(String database) throws DatabaseNotFoundException, SessionException { + session.deleteDatabase(database); + } +} diff --git a/collaboration/GSoC-2011-Eranda/cassandra/src/main/resources/META-INF/sca-contribution.xml b/collaboration/GSoC-2011-Eranda/cassandra/src/main/resources/META-INF/sca-contribution.xml new file mode 100644 index 0000000000..b9960d1bac --- /dev/null +++ b/collaboration/GSoC-2011-Eranda/cassandra/src/main/resources/META-INF/sca-contribution.xml @@ -0,0 +1,7 @@ + + + + + + diff --git a/collaboration/GSoC-2011-Eranda/cassandra/src/main/resources/datastore.composite b/collaboration/GSoC-2011-Eranda/cassandra/src/main/resources/datastore.composite new file mode 100644 index 0000000000..bf67ad5eee --- /dev/null +++ b/collaboration/GSoC-2011-Eranda/cassandra/src/main/resources/datastore.composite @@ -0,0 +1,16 @@ + + + + + + + + + + + + + diff --git a/collaboration/GSoC-2011-Eranda/couchdb/pom.xml b/collaboration/GSoC-2011-Eranda/couchdb/pom.xml index 32c17907ad..4e3aff6542 100644 --- a/collaboration/GSoC-2011-Eranda/couchdb/pom.xml +++ b/collaboration/GSoC-2011-Eranda/couchdb/pom.xml @@ -30,13 +30,27 @@ under the License. http://maven.apache.org UTF-8 + 0.10.0-1 + 2.0-M5 com.google.code.jcouchdb jcouchdb - 0.10.0-1 + ${jcouchdb.version} + + + org.apache.tuscany.sca + tuscany-sca-api + ${tuscany.version} + provided + + + javax.ws.rs + jsr311-api + 1.1.1 + provided junit diff --git a/collaboration/GSoC-2011-Eranda/couchdb/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreService.java b/collaboration/GSoC-2011-Eranda/couchdb/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreService.java new file mode 100644 index 0000000000..e63fb16bf5 --- /dev/null +++ b/collaboration/GSoC-2011-Eranda/couchdb/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreService.java @@ -0,0 +1,67 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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.apache.tuscany.nosqldatastore; + +import org.apache.tuscany.nosqldatastore.exception.*; +import org.oasisopen.sca.annotation.Remotable; + +import javax.ws.rs.*; + +@Remotable +public interface DatastoreService { + + @GET + @Path("echoTest") + String echoTest(@QueryParam("database") String database); + + @POST + @Path("addEntry") + void addEntry(@QueryParam("database") String database, + @QueryParam("group") String group, + @QueryParam("key") String key, + @QueryParam("value") String value) throws DuplicateEntryException, SessionException; + + @POST + @Path("updateEntry") + void updateEntry(@QueryParam("database") String database, + @QueryParam("group") String group, + @QueryParam("key") String key, + @QueryParam("value") String value) throws EntryNotFoundException, SessionException; + + @POST + @Path("deleteEntry") + void deleteEntry(@QueryParam("database") String database, + @QueryParam("group") String group, + @QueryParam("key") String key) throws EntryNotFoundException, SessionException; + + @GET + @Path("getEntry") + String getEntry(@QueryParam("database") String database, + @QueryParam("group") String group, + @QueryParam("key") String key) throws EntryNotFoundException, SessionException; + + @DELETE + @Path("deleteGroup") + void deleteGroup(@QueryParam("database") String database, + @QueryParam("group") String group) throws GroupNotFoundException, SessionException; + + @DELETE + @Path("deleteDatabase") + void deleteDatabase(@QueryParam("database") String database) throws DatabaseNotFoundException, SessionException; +} diff --git a/collaboration/GSoC-2011-Eranda/couchdb/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreServiceImpl.java b/collaboration/GSoC-2011-Eranda/couchdb/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreServiceImpl.java new file mode 100644 index 0000000000..a153f0ce0f --- /dev/null +++ b/collaboration/GSoC-2011-Eranda/couchdb/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreServiceImpl.java @@ -0,0 +1,71 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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.apache.tuscany.nosqldatastore; + +import org.apache.tuscany.nosqldatastore.exception.*; +import org.oasisopen.sca.annotation.Init; +import org.oasisopen.sca.annotation.Scope; + +@Scope("COMPOSITE") +public class DatastoreServiceImpl implements DatastoreService{ + + private Session session; + + @Init + public void init(){ + session = (new SessionFactory()).getCouchDBSession(); + } + + public String echoTest(String database){ + return "Database "+database; + } + + public void addEntry(String database, String group, String key, String value) throws DuplicateEntryException, SessionException { + Database db = session.getDatabase(database); + Group grp = db.getGroup(group); + grp.addEntry(key, value); + } + + public void updateEntry(String database, String group, String key, String value) throws EntryNotFoundException, SessionException { + Database db = session.getDatabase(database); + Group grp = db.getGroup(group); + grp.updateEntry(key, value); + } + + public void deleteEntry(String database, String group, String key) throws EntryNotFoundException, SessionException { + Database db = session.getDatabase(database); + Group grp = db.getGroup(group); + grp.deleteEntry(key); + } + + public String getEntry(String database, String group, String key) throws EntryNotFoundException, SessionException { + Database db = session.getDatabase(database); + Group grp = db.getGroup(group); + return grp.getEntry(key); + } + + public void deleteGroup(String database, String group) throws GroupNotFoundException, SessionException { + Database db = session.getDatabase(database); + db.deleteGroup(group); + } + + public void deleteDatabase(String database) throws DatabaseNotFoundException, SessionException { + session.deleteDatabase(database); + } +} diff --git a/collaboration/GSoC-2011-Eranda/couchdb/src/main/resources/META-INF/sca-contribution.xml b/collaboration/GSoC-2011-Eranda/couchdb/src/main/resources/META-INF/sca-contribution.xml new file mode 100644 index 0000000000..b9960d1bac --- /dev/null +++ b/collaboration/GSoC-2011-Eranda/couchdb/src/main/resources/META-INF/sca-contribution.xml @@ -0,0 +1,7 @@ + + + + + + diff --git a/collaboration/GSoC-2011-Eranda/couchdb/src/main/resources/datastore.composite b/collaboration/GSoC-2011-Eranda/couchdb/src/main/resources/datastore.composite new file mode 100644 index 0000000000..bf67ad5eee --- /dev/null +++ b/collaboration/GSoC-2011-Eranda/couchdb/src/main/resources/datastore.composite @@ -0,0 +1,16 @@ + + + + + + + + + + + + + diff --git a/collaboration/GSoC-2011-Eranda/hbase/pom.xml b/collaboration/GSoC-2011-Eranda/hbase/pom.xml index a726ce23fb..518ccf7114 100644 --- a/collaboration/GSoC-2011-Eranda/hbase/pom.xml +++ b/collaboration/GSoC-2011-Eranda/hbase/pom.xml @@ -30,21 +30,33 @@ under the License. http://maven.apache.org UTF-8 + 0.90.3 + 2.0-M5 - org.apache.hbase hbase - 0.90.3 + ${hbase.version} junit junit 4.8.2 + + org.apache.tuscany.sca + tuscany-sca-api + ${tuscany.version} + provided + + + javax.ws.rs + jsr311-api + 1.1.1 + provided + - diff --git a/collaboration/GSoC-2011-Eranda/hbase/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreService.java b/collaboration/GSoC-2011-Eranda/hbase/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreService.java new file mode 100644 index 0000000000..e63fb16bf5 --- /dev/null +++ b/collaboration/GSoC-2011-Eranda/hbase/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreService.java @@ -0,0 +1,67 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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.apache.tuscany.nosqldatastore; + +import org.apache.tuscany.nosqldatastore.exception.*; +import org.oasisopen.sca.annotation.Remotable; + +import javax.ws.rs.*; + +@Remotable +public interface DatastoreService { + + @GET + @Path("echoTest") + String echoTest(@QueryParam("database") String database); + + @POST + @Path("addEntry") + void addEntry(@QueryParam("database") String database, + @QueryParam("group") String group, + @QueryParam("key") String key, + @QueryParam("value") String value) throws DuplicateEntryException, SessionException; + + @POST + @Path("updateEntry") + void updateEntry(@QueryParam("database") String database, + @QueryParam("group") String group, + @QueryParam("key") String key, + @QueryParam("value") String value) throws EntryNotFoundException, SessionException; + + @POST + @Path("deleteEntry") + void deleteEntry(@QueryParam("database") String database, + @QueryParam("group") String group, + @QueryParam("key") String key) throws EntryNotFoundException, SessionException; + + @GET + @Path("getEntry") + String getEntry(@QueryParam("database") String database, + @QueryParam("group") String group, + @QueryParam("key") String key) throws EntryNotFoundException, SessionException; + + @DELETE + @Path("deleteGroup") + void deleteGroup(@QueryParam("database") String database, + @QueryParam("group") String group) throws GroupNotFoundException, SessionException; + + @DELETE + @Path("deleteDatabase") + void deleteDatabase(@QueryParam("database") String database) throws DatabaseNotFoundException, SessionException; +} diff --git a/collaboration/GSoC-2011-Eranda/hbase/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreServiceImpl.java b/collaboration/GSoC-2011-Eranda/hbase/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreServiceImpl.java new file mode 100644 index 0000000000..7049129046 --- /dev/null +++ b/collaboration/GSoC-2011-Eranda/hbase/src/main/java/org/apache/tuscany/nosqldatastore/DatastoreServiceImpl.java @@ -0,0 +1,71 @@ +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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.apache.tuscany.nosqldatastore; + +import org.apache.tuscany.nosqldatastore.exception.*; +import org.oasisopen.sca.annotation.Init; +import org.oasisopen.sca.annotation.Scope; + +@Scope("COMPOSITE") +public class DatastoreServiceImpl implements DatastoreService{ + + private Session session; + + @Init + public void init(){ + session = (new SessionFactory()).getHBaseSession(); + } + + public String echoTest(String database){ + return "Database "+database; + } + + public void addEntry(String database, String group, String key, String value) throws DuplicateEntryException, SessionException { + Database db = session.getDatabase(database); + Group grp = db.getGroup(group); + grp.addEntry(key, value); + } + + public void updateEntry(String database, String group, String key, String value) throws EntryNotFoundException, SessionException { + Database db = session.getDatabase(database); + Group grp = db.getGroup(group); + grp.updateEntry(key, value); + } + + public void deleteEntry(String database, String group, String key) throws EntryNotFoundException, SessionException { + Database db = session.getDatabase(database); + Group grp = db.getGroup(group); + grp.deleteEntry(key); + } + + public String getEntry(String database, String group, String key) throws EntryNotFoundException, SessionException { + Database db = session.getDatabase(database); + Group grp = db.getGroup(group); + return grp.getEntry(key); + } + + public void deleteGroup(String database, String group) throws GroupNotFoundException, SessionException { + Database db = session.getDatabase(database); + db.deleteGroup(group); + } + + public void deleteDatabase(String database) throws DatabaseNotFoundException, SessionException { + session.deleteDatabase(database); + } +} diff --git a/collaboration/GSoC-2011-Eranda/hbase/src/main/resources/META-INF/sca-contribution.xml b/collaboration/GSoC-2011-Eranda/hbase/src/main/resources/META-INF/sca-contribution.xml new file mode 100644 index 0000000000..b9960d1bac --- /dev/null +++ b/collaboration/GSoC-2011-Eranda/hbase/src/main/resources/META-INF/sca-contribution.xml @@ -0,0 +1,7 @@ + + + + + + diff --git a/collaboration/GSoC-2011-Eranda/hbase/src/main/resources/datastore.composite b/collaboration/GSoC-2011-Eranda/hbase/src/main/resources/datastore.composite new file mode 100644 index 0000000000..bf67ad5eee --- /dev/null +++ b/collaboration/GSoC-2011-Eranda/hbase/src/main/resources/datastore.composite @@ -0,0 +1,16 @@ + + + + + + + + + + + + + -- cgit v1.2.3