@Override public NonNamespaceOperation<PersistentVolume, PersistentVolumeList, DoneablePersistentVolume, Resource<PersistentVolume, DoneablePersistentVolume>> persistentVolumes() { return delegate.persistentVolumes(); }
@Override public NonNamespaceOperation<PersistentVolume, PersistentVolumeList, DoneablePersistentVolume, Resource<PersistentVolume, DoneablePersistentVolume>> persistentVolumes() { return delegate.persistentVolumes(); }
.build(); client.persistentVolumes().create(pv); log("Successfully created Persistent Volume object"); } catch (KubernetesClientException e) {
@Override public String getFailureMessage() { PersistentVolume pv = client.persistentVolumes().withName(persistentVolume).get(); return "PersistentVolume for " + persistentVolume + " " + (pv == null ? "absent" : "pv=" + pv); } };
protected void doListPersistentVolumesByLabels(Exchange exchange, String operation) throws Exception { PersistentVolumeList pvList = null; Map<String, String> labels = exchange.getIn().getHeader( KubernetesConstants.KUBERNETES_PERSISTENT_VOLUMES_LABELS, Map.class); NonNamespaceOperation<PersistentVolume, PersistentVolumeList, DoneablePersistentVolume, Resource<PersistentVolume, DoneablePersistentVolume>> pvs; pvs = getEndpoint().getKubernetesClient().persistentVolumes(); for (Map.Entry<String, String> entry : labels.entrySet()) { pvs.withLabel(entry.getKey(), entry.getValue()); } pvList = pvs.list(); MessageHelper.copyHeaders(exchange.getIn(), exchange.getOut(), true); exchange.getOut().setBody(pvList.getItems()); }
protected void doList(Exchange exchange, String operation) throws Exception { PersistentVolumeList persistentVolumeList = getEndpoint() .getKubernetesClient().persistentVolumes().list(); MessageHelper.copyHeaders(exchange.getIn(), exchange.getOut(), true); exchange.getOut().setBody(persistentVolumeList.getItems()); }
protected void doGetPersistentVolume(Exchange exchange, String operation) throws Exception { PersistentVolume pv = null; String pvName = exchange.getIn().getHeader( KubernetesConstants.KUBERNETES_PERSISTENT_VOLUME_NAME, String.class); if (ObjectHelper.isEmpty(pvName)) { LOG.error("Get a specific Persistent Volume require specify a Persistent Volume name"); throw new IllegalArgumentException( "Get a specific Persistent Volume require specify a Persistent Volume name"); } pv = getEndpoint().getKubernetesClient().persistentVolumes().withName(pvName).get(); MessageHelper.copyHeaders(exchange.getIn(), exchange.getOut(), true); exchange.getOut().setBody(pv); } }
@Override public Boolean call() { PersistentVolume pv = client.persistentVolumes().withName(persistentVolume).get(); return pv != null && pv.getStatus() != null && pv.getStatus().getPhase().equals(PHASE_AVAILABLE); }
protected void createPersistentVolumes(List<String> volumes) { for (final String persistentVolume : volumes) { PersistentVolume volume = new PersistentVolumeBuilder() .withNewMetadata() .withName(persistentVolume) .withLabels(ImmutableMap.of("type", "local")) // TODO make it configurable .endMetadata() .withNewSpec() .addToCapacity("storage", new QuantityBuilder().withAmount("20").build()) // TODO make it configurable .addToAccessModes("ReadWriteOnce") // TODO make it configurable .withNewHostPath().withPath("/tmp/pv-1").endHostPath() // TODO make it configurable .endSpec() .build(); client.persistentVolumes().create(volume); ExitCondition exitCondition = new ExitCondition() { @Override public Boolean call() { PersistentVolume pv = client.persistentVolumes().withName(persistentVolume).get(); return pv != null && pv.getStatus() != null && pv.getStatus().getPhase().equals(PHASE_AVAILABLE); } @Override public String getFailureMessage() { PersistentVolume pv = client.persistentVolumes().withName(persistentVolume).get(); return "PersistentVolume for " + persistentVolume + " " + (pv == null ? "absent" : "pv=" + pv); } }; waitForExitCondition(exitCondition); } }
protected boolean handleResourceDelete(String resourceType, String resourceName, String namespace) { try { switch (resourceType) { case KubernetesResource.DEPLOYMENT: return client.extensions().deployments().inNamespace(namespace).withName(resourceName).delete(); case KubernetesResource.REPLICA_SET: return client.extensions().replicaSets().inNamespace(namespace).withName(resourceName).delete(); case KubernetesResource.CONFIG_MAP: return client.configMaps().inNamespace(namespace).withName(resourceName).delete(); case KubernetesResource.PERSISTENT_VOLUME: return client.persistentVolumes().withName(resourceName).delete(); case KubernetesResource.SECRET: return client.secrets().inNamespace(namespace).withName(resourceName).delete(); case KubernetesResource.SERVICE: return client.services().inNamespace(namespace).withName(resourceName).delete(); case KubernetesResource.REPLICATION_CONTROLLER: return client.replicationControllers().inNamespace(namespace).withName(resourceName).delete(); case KubernetesResource.NAMESPACE: return client.namespaces().withName(resourceName).delete(); } } catch (KubernetesClientException kce) { LOG.warn("Error deleting resource {}: {}", resourceName, kce); } return false; }