--- /dev/null
+/*
+ * Copyright (C) 2014 EBay Software Foundation
+ *
+ * This program and the accompanying materials are made available under the
+ * terms of the Eclipse Public License v1.0 which accompanies this distribution,
+ * and is available at http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Authors : Sudheendra Murthy
+ */
+
+package org.opendaylight.ovsdb.lib.impl;
+
+import com.fasterxml.jackson.databind.JsonNode;
+import com.fasterxml.jackson.databind.ObjectMapper;
+import com.google.common.base.Function;
+import com.google.common.util.concurrent.Futures;
+import com.google.common.util.concurrent.ListenableFuture;
+import org.opendaylight.ovsdb.lib.operations.Operation;
+import org.opendaylight.ovsdb.lib.operations.OperationResult;
+
+import java.util.ArrayList;
+import java.util.List;
+
+public class FutureTransformUtils {
+ private static final ObjectMapper objectMapper = new ObjectMapper();
+
+ public final static ListenableFuture<List<OperationResult>> transformTransactResponse
+ (ListenableFuture<List<JsonNode>> transactResponseFuture, final List<Operation> operations) {
+ return Futures.transform(transactResponseFuture, new Function<List<JsonNode>, List<OperationResult>>() {
+ @Override
+ public List<OperationResult> apply(List<JsonNode> jsonNodes) {
+ final List<OperationResult> operationResults = new ArrayList<>();
+ for (int i = 0; i < jsonNodes.size(); i++) {
+ JsonNode jsonNode = jsonNodes.get(i);
+ OperationResult or;
+ if (jsonNode.size() > 0) {
+ Operation op = operations.get(i);
+ switch (op.getOp()) {
+ case "select":
+ or = new OperationResult();
+ or.setRows(op.getTableSchema().createRows(jsonNode));
+
+ break;
+
+ default:
+ or = objectMapper.convertValue(jsonNode, OperationResult.class);
+
+ break;
+ }
+ } else {
+ or = new OperationResult();
+ }
+
+ operationResults.add(or);
+ }
+
+ return operationResults;
+ }
+ });
+ }
+}
*/
package org.opendaylight.ovsdb.lib.impl;
+import com.fasterxml.jackson.databind.JsonNode;
+import com.fasterxml.jackson.databind.ObjectMapper;
+import com.fasterxml.jackson.databind.node.ObjectNode;
+import com.google.common.base.Function;
+import com.google.common.collect.ImmutableMap;
+import com.google.common.collect.Lists;
+import com.google.common.collect.Maps;
+import com.google.common.util.concurrent.Futures;
+import com.google.common.util.concurrent.ListenableFuture;
+import com.google.common.util.concurrent.SettableFuture;
import io.netty.channel.Channel;
-
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Map;
-import java.util.Queue;
-import java.util.UUID;
-import java.util.concurrent.ExecutionException;
-import java.util.concurrent.ExecutorService;
-
import org.opendaylight.ovsdb.lib.EchoServiceCallbackFilters;
import org.opendaylight.ovsdb.lib.LockAquisitionCallback;
import org.opendaylight.ovsdb.lib.LockStolenCallback;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
-import com.fasterxml.jackson.databind.JsonNode;
-import com.fasterxml.jackson.databind.node.ObjectNode;
-import com.google.common.base.Function;
-import com.google.common.collect.ImmutableMap;
-import com.google.common.collect.Lists;
-import com.google.common.collect.Maps;
-import com.google.common.util.concurrent.Futures;
-import com.google.common.util.concurrent.ListenableFuture;
-import com.google.common.util.concurrent.SettableFuture;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.Queue;
+import java.util.UUID;
+import java.util.concurrent.ExecutionException;
+import java.util.concurrent.ExecutorService;
public class OvsdbClientImpl implements OvsdbClient {
private OvsdbRPC.Callback rpcCallback;
private OvsdbConnectionInfo connectionInfo;
private Channel channel;
+ private static final ObjectMapper objectMapper = new ObjectMapper();
public OvsdbClientImpl(OvsdbRPC rpc, Channel channel, ConnectionType type, ExecutorService executorService) {
this.rpc = rpc;
builder.addOperation(o);
}
- return rpc.transact(builder);
+ return FutureTransformUtils.transformTransactResponse(rpc.transact(builder), operations);
}
@Override
*/
package org.opendaylight.ovsdb.lib.message;
-import java.util.List;
-
-import org.opendaylight.ovsdb.lib.operations.OperationResult;
-
import com.fasterxml.jackson.databind.JsonNode;
import com.google.common.util.concurrent.ListenableFuture;
-
import org.opendaylight.ovsdb.lib.jsonrpc.Params;
+import java.util.List;
+
public interface OvsdbRPC {
public static final String REGISTER_CALLBACK_METHOD = "registerCallback";
public ListenableFuture<List<String>> list_dbs();
- public ListenableFuture<List<OperationResult>> transact(TransactBuilder transact);
+ public ListenableFuture<List<JsonNode>> transact(TransactBuilder transact);
public ListenableFuture<Response> cancel(String id);
import java.lang.reflect.Constructor;
import java.util.Iterator;
import java.util.List;
+import java.util.ArrayList;
import java.util.Map;
import java.util.Set;
return new Row<>(this, columns);
}
+ public ArrayList<Row<E>> createRows(JsonNode rowsNode) {
+ ArrayList<Row<E>> rows = Lists.newArrayList();
+ for (JsonNode rowNode : rowsNode.get("rows")) {
+ rows.add(createRow((ObjectNode)rowNode));
+ }
+
+ return rows;
+ }
+
/*
* RFC 7047 Section 3.2 specifies 2 internally generated columns in each table
* namely _uuid and _version which are not exposed in get_schema call.
String namedUuid = "br_test";
int insertOperationIndex = 0;
- UUID parentTable = getOpenVSwitchTableUuid();
+ UUID parentTable = selectOpenVSwitchTableUuid();
TransactionBuilder transactionBuilder = ovs.transactBuilder()
/*
* Make sure that the position of insert operation matches the insertOperationIndex.
GenericTableSchema ovsTable = dbSchema.table("Open_vSwitch", GenericTableSchema.class);
ColumnSchema<GenericTableSchema, Set<UUID>> bridges = ovsTable.multiValuedColumn("bridges", UUID.class);
ColumnSchema<GenericTableSchema, UUID> _uuid = ovsTable.column("_uuid", UUID.class);
- UUID parentTable = getOpenVSwitchTableUuid();
+ UUID parentTable = selectOpenVSwitchTableUuid();
ListenableFuture<List<OperationResult>> results = ovs.transactBuilder()
.add(op.delete(bridge)