summaryrefslogtreecommitdiffstats
path: root/openstack-examples/src/main/java/com/woorea/openstack/examples/network
diff options
context:
space:
mode:
Diffstat (limited to 'openstack-examples/src/main/java/com/woorea/openstack/examples/network')
-rw-r--r--openstack-examples/src/main/java/com/woorea/openstack/examples/network/QuantumListNetworks.java47
-rw-r--r--openstack-examples/src/main/java/com/woorea/openstack/examples/network/QuantumNetworkCreate.java108
-rw-r--r--openstack-examples/src/main/java/com/woorea/openstack/examples/network/QuantumQueryNetworks.java59
3 files changed, 214 insertions, 0 deletions
diff --git a/openstack-examples/src/main/java/com/woorea/openstack/examples/network/QuantumListNetworks.java b/openstack-examples/src/main/java/com/woorea/openstack/examples/network/QuantumListNetworks.java
new file mode 100644
index 0000000..8e218c2
--- /dev/null
+++ b/openstack-examples/src/main/java/com/woorea/openstack/examples/network/QuantumListNetworks.java
@@ -0,0 +1,47 @@
+package com.woorea.openstack.examples.network;
+
+import com.woorea.openstack.keystone.utils.KeystoneUtils;
+
+import com.woorea.openstack.base.client.OpenStackSimpleTokenProvider;
+import com.woorea.openstack.examples.ExamplesConfiguration;
+import com.woorea.openstack.keystone.Keystone;
+import com.woorea.openstack.keystone.model.Access;
+import com.woorea.openstack.keystone.model.Tenants;
+import com.woorea.openstack.keystone.model.authentication.TokenAuthentication;
+import com.woorea.openstack.keystone.model.authentication.UsernamePassword;
+import com.woorea.openstack.quantum.Quantum;
+import com.woorea.openstack.quantum.model.Network;
+import com.woorea.openstack.quantum.model.Networks;
+
+public class QuantumListNetworks {
+
+ /**
+ * @param args
+ */
+ public static void main(String[] args) {
+ Keystone keystone = new Keystone(ExamplesConfiguration.KEYSTONE_AUTH_URL);
+ // access with unscoped token
+ Access access = keystone.tokens().authenticate(
+ new UsernamePassword(ExamplesConfiguration.KEYSTONE_USERNAME, ExamplesConfiguration.KEYSTONE_PASSWORD))
+ .execute();
+ // use the token in the following requests
+ keystone.setTokenProvider(new OpenStackSimpleTokenProvider(access.getToken().getId()));
+
+ Tenants tenants = keystone.tenants().list().execute();
+ // try to exchange token using the first tenant
+ if (tenants.getList().size() > 0) {
+ // access with tenant
+ access = keystone.tokens().authenticate(new TokenAuthentication(access.getToken().getId())).withTenantId(tenants.getList().get(0).getId()).execute();
+
+ Quantum quantum = new Quantum(KeystoneUtils.findEndpointURL(access.getServiceCatalog(), "network", null, "public"));
+ quantum.setTokenProvider(new OpenStackSimpleTokenProvider(access.getToken().getId()));
+
+ Networks networks = quantum.networks().list().execute();
+ for (Network network : networks) {
+ System.out.println(network);
+ }
+ } else {
+ System.out.println("No tenants found!");
+ }
+ }
+}
diff --git a/openstack-examples/src/main/java/com/woorea/openstack/examples/network/QuantumNetworkCreate.java b/openstack-examples/src/main/java/com/woorea/openstack/examples/network/QuantumNetworkCreate.java
new file mode 100644
index 0000000..7f4dff0
--- /dev/null
+++ b/openstack-examples/src/main/java/com/woorea/openstack/examples/network/QuantumNetworkCreate.java
@@ -0,0 +1,108 @@
+package com.woorea.openstack.examples.network;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Scanner;
+
+import com.woorea.openstack.keystone.utils.KeystoneUtils;
+
+import com.woorea.openstack.base.client.OpenStackSimpleTokenProvider;
+import com.woorea.openstack.examples.ExamplesConfiguration;
+import com.woorea.openstack.keystone.Keystone;
+import com.woorea.openstack.keystone.model.Access;
+import com.woorea.openstack.keystone.model.Tenant;
+import com.woorea.openstack.keystone.model.Tenants;
+import com.woorea.openstack.keystone.model.authentication.TokenAuthentication;
+import com.woorea.openstack.keystone.model.authentication.UsernamePassword;
+import com.woorea.openstack.quantum.Quantum;
+import com.woorea.openstack.quantum.api.NetworksResource;
+import com.woorea.openstack.quantum.api.NetworksResource.Create;
+import com.woorea.openstack.quantum.model.Network;
+import com.woorea.openstack.quantum.model.NetworkForCreate;
+import com.woorea.openstack.quantum.model.Networks;
+import com.woorea.openstack.quantum.model.Port;
+import com.woorea.openstack.quantum.model.PortForCreate;
+import com.woorea.openstack.quantum.model.Router;
+import com.woorea.openstack.quantum.model.RouterForAddInterface;
+import com.woorea.openstack.quantum.model.RouterForCreate;
+import com.woorea.openstack.quantum.model.Subnet;
+import com.woorea.openstack.quantum.model.SubnetForCreate;
+import com.woorea.openstack.quantum.model.Subnets;
+
+public class QuantumNetworkCreate {
+
+ /**
+ * @param args
+ */
+ public static void main(String[] args) {
+ Keystone keystone = new Keystone(
+ ExamplesConfiguration.KEYSTONE_AUTH_URL);
+ // access with unscoped token
+ Access access = keystone
+ .tokens()
+ .authenticate(
+ new UsernamePassword(
+ ExamplesConfiguration.KEYSTONE_USERNAME,
+ ExamplesConfiguration.KEYSTONE_PASSWORD))
+ .execute();
+ // use the token in the following requests
+ keystone.setTokenProvider(new OpenStackSimpleTokenProvider(access
+ .getToken().getId()));
+ keystone.token(access.getToken().getId());
+ Tenants tenants = keystone.tenants().list().execute();
+ // try to exchange token using the first tenant
+
+ if (tenants.getList().size() > 0) {
+ // access with tenant
+ Network network = new Network();
+ access = keystone
+ .tokens()
+ .authenticate(
+ new TokenAuthentication(access.getToken().getId()))
+ .withTenantId("tenantId").execute();
+ Quantum quantum = new Quantum(KeystoneUtils.findEndpointURL(
+ access.getServiceCatalog(), "network", null, "public"));
+ quantum.setTokenProvider(new OpenStackSimpleTokenProvider(access
+ .getToken().getId()));
+ NetworkForCreate netcreate = new NetworkForCreate();
+ netcreate.setTenantId("tenantId");
+ netcreate.setName("net2");
+ netcreate.setAdminStateUp(true);
+
+ network = quantum.networks().create(netcreate).execute();
+
+ // Creating Subnet
+ try {
+ Subnet sub = new Subnet();
+ SubnetForCreate subnet = new SubnetForCreate();
+ subnet.setCidr("");
+ subnet.setName("");
+ subnet.setNetworkId(network.getId());
+ subnet.setIpVersion(4);
+ sub = quantum.subnets().create(subnet).execute();
+ RouterForCreate routerForCreate = new RouterForCreate();
+ routerForCreate.setName("routerName");
+ routerForCreate.setTenantId("tenantId");
+ Router router = quantum.routers().create(routerForCreate)
+ .execute();
+ RouterForAddInterface routerForAdd = new RouterForAddInterface();
+ routerForAdd.setSubnetId(sub.getId());
+ routerForAdd.setRouterId(router.getId());
+ quantum.routers().addInterface(routerForAdd).execute();
+
+ // System.out.println(sub);
+ } catch (Exception e) {
+ System.out.println(e.getMessage());
+ }
+
+ Networks networks = quantum.networks().list().execute();
+
+ for (Network network1 : networks) {
+ System.out.println(network1);
+ }
+ } else {
+ System.out.println("No tenants found!");
+ }
+
+ }
+}
diff --git a/openstack-examples/src/main/java/com/woorea/openstack/examples/network/QuantumQueryNetworks.java b/openstack-examples/src/main/java/com/woorea/openstack/examples/network/QuantumQueryNetworks.java
new file mode 100644
index 0000000..1a427ea
--- /dev/null
+++ b/openstack-examples/src/main/java/com/woorea/openstack/examples/network/QuantumQueryNetworks.java
@@ -0,0 +1,59 @@
+package com.woorea.openstack.examples.network;
+
+import com.woorea.openstack.keystone.utils.KeystoneUtils;
+
+import com.woorea.openstack.base.client.OpenStackSimpleTokenProvider;
+import com.woorea.openstack.examples.ExamplesConfiguration;
+import com.woorea.openstack.keystone.Keystone;
+import com.woorea.openstack.keystone.model.Access;
+import com.woorea.openstack.keystone.model.Tenants;
+import com.woorea.openstack.keystone.model.authentication.TokenAuthentication;
+import com.woorea.openstack.keystone.model.authentication.UsernamePassword;
+import com.woorea.openstack.quantum.Quantum;
+import com.woorea.openstack.quantum.model.Network;
+
+public class QuantumQueryNetworks {
+
+ /**
+ * @param args
+ */
+ public static void main(String[] args) {
+ Keystone keystone = new Keystone(ExamplesConfiguration.KEYSTONE_AUTH_URL);
+ // access with unscoped token
+ Access access = keystone.tokens().authenticate(
+ new UsernamePassword(ExamplesConfiguration.KEYSTONE_USERNAME, ExamplesConfiguration.KEYSTONE_PASSWORD))
+ .execute();
+ // use the token in the following requests
+ keystone.setTokenProvider(new OpenStackSimpleTokenProvider(access.getToken().getId()));
+
+ Tenants tenants = keystone.tenants().list().execute();
+ // try to exchange token using the first tenant
+ if (tenants.getList().size() > 0) {
+ // access with tenant
+ access = keystone.tokens().authenticate(new TokenAuthentication(access.getToken().getId())).withTenantId(tenants.getList().get(0).getId()).execute();
+
+ Quantum quantumClient = new Quantum(KeystoneUtils.findEndpointURL(access.getServiceCatalog(), "network", null, "public"));
+ quantumClient.setTokenProvider(new OpenStackSimpleTokenProvider(access.getToken().getId()));
+
+ Network networkQuery = new Network();
+ networkQuery.setName("benn.cs");
+ networkQuery.setAdminStateUp(true);
+ /*
+ Networks networks = quantumClient.execute(NetworkQuery.queryNetworks(networkQuery));
+
+ for (Network network : networks) {
+ System.out.println(network);
+ }
+
+ Subnet subnetQuery = new Subnet();
+ subnetQuery.setIpversion(Subnet.IpVersion.IPV4);
+ Subnets Subnets = quantumClient.execute(NetworkQuery.querySubnets(subnetQuery));
+ for (Subnet subnet : Subnets) {
+ System.out.println(subnet);
+ }
+ */
+ } else {
+ System.out.println("No tenants found!");
+ }
+ }
+}