mirror of https://github.com/apache/jclouds.git
Deprecate user metadata in DigitalOcean
This commit is contained in:
parent
3ae2213a7d
commit
fa746ff162
|
@ -28,7 +28,6 @@ import static org.jclouds.compute.config.ComputeServiceProperties.TIMEOUT_NODE_S
|
||||||
import static org.jclouds.compute.config.ComputeServiceProperties.TIMEOUT_NODE_TERMINATED;
|
import static org.jclouds.compute.config.ComputeServiceProperties.TIMEOUT_NODE_TERMINATED;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
|
@ -48,7 +47,6 @@ import org.jclouds.digitalocean2.domain.Region;
|
||||||
import org.jclouds.digitalocean2.domain.Size;
|
import org.jclouds.digitalocean2.domain.Size;
|
||||||
import org.jclouds.digitalocean2.domain.options.CreateDropletOptions;
|
import org.jclouds.digitalocean2.domain.options.CreateDropletOptions;
|
||||||
import org.jclouds.domain.LoginCredentials;
|
import org.jclouds.domain.LoginCredentials;
|
||||||
import org.jclouds.json.Json;
|
|
||||||
import org.jclouds.logging.Logger;
|
import org.jclouds.logging.Logger;
|
||||||
|
|
||||||
import com.google.common.base.Function;
|
import com.google.common.base.Function;
|
||||||
|
@ -68,18 +66,15 @@ public class DigitalOcean2ComputeServiceAdapter implements ComputeServiceAdapter
|
||||||
private final Predicate<Integer> nodeRunningPredicate;
|
private final Predicate<Integer> nodeRunningPredicate;
|
||||||
private final Predicate<Integer> nodeStoppedPredicate;
|
private final Predicate<Integer> nodeStoppedPredicate;
|
||||||
private final Predicate<Integer> nodeTerminatedPredicate;
|
private final Predicate<Integer> nodeTerminatedPredicate;
|
||||||
private final Json json;
|
|
||||||
|
|
||||||
@Inject DigitalOcean2ComputeServiceAdapter(DigitalOcean2Api api,
|
@Inject DigitalOcean2ComputeServiceAdapter(DigitalOcean2Api api,
|
||||||
@Named(TIMEOUT_NODE_RUNNING) Predicate<Integer> nodeRunningPredicate,
|
@Named(TIMEOUT_NODE_RUNNING) Predicate<Integer> nodeRunningPredicate,
|
||||||
@Named(TIMEOUT_NODE_SUSPENDED) Predicate<Integer> nodeStoppedPredicate,
|
@Named(TIMEOUT_NODE_SUSPENDED) Predicate<Integer> nodeStoppedPredicate,
|
||||||
@Named(TIMEOUT_NODE_TERMINATED) Predicate<Integer> nodeTerminatedPredicate,
|
@Named(TIMEOUT_NODE_TERMINATED) Predicate<Integer> nodeTerminatedPredicate) {
|
||||||
Json json) {
|
|
||||||
this.api = api;
|
this.api = api;
|
||||||
this.nodeRunningPredicate = nodeRunningPredicate;
|
this.nodeRunningPredicate = nodeRunningPredicate;
|
||||||
this.nodeStoppedPredicate = nodeStoppedPredicate;
|
this.nodeStoppedPredicate = nodeStoppedPredicate;
|
||||||
this.nodeTerminatedPredicate = nodeTerminatedPredicate;
|
this.nodeTerminatedPredicate = nodeTerminatedPredicate;
|
||||||
this.json = json;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setUserDataIfSupported(Template template, CreateDropletOptions.Builder options, String userData) {
|
private void setUserDataIfSupported(Template template, CreateDropletOptions.Builder options, String userData) {
|
||||||
|
@ -110,11 +105,9 @@ public class DigitalOcean2ComputeServiceAdapter implements ComputeServiceAdapter
|
||||||
// Encoding tags or anything else than user_data in here breaks their functionality.
|
// Encoding tags or anything else than user_data in here breaks their functionality.
|
||||||
if (null != templateOptions.getUserData()) {
|
if (null != templateOptions.getUserData()) {
|
||||||
setUserDataIfSupported(template, options, new String(templateOptions.getUserData()));
|
setUserDataIfSupported(template, options, new String(templateOptions.getUserData()));
|
||||||
}
|
} else if (null != templateOptions.getUserMetadata().get("user_data")) {
|
||||||
// Backwards compatible variant, getting userData from userMetaData map.
|
// Backwards compatible variant, getting userData from userMetaData map.
|
||||||
Map<String, String> metadataAndTags = templateOptions.getUserMetadata();
|
setUserDataIfSupported(template, options, templateOptions.getUserMetadata().get("user_data"));
|
||||||
if (null != metadataAndTags.get("user_data")) {
|
|
||||||
setUserDataIfSupported(template, options, metadataAndTags.get("user_data"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
DropletCreate dropletCreated = api.dropletApi().create(name,
|
DropletCreate dropletCreated = api.dropletApi().create(name,
|
||||||
|
|
|
@ -20,6 +20,7 @@ import static com.google.common.base.Objects.equal;
|
||||||
import static com.google.common.base.Preconditions.checkNotNull;
|
import static com.google.common.base.Preconditions.checkNotNull;
|
||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import org.jclouds.compute.options.TemplateOptions;
|
import org.jclouds.compute.options.TemplateOptions;
|
||||||
|
@ -78,6 +79,36 @@ public class DigitalOcean2TemplateOptions extends TemplateOptions implements Clo
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Key value metadata is not supported in DigitalOcean. Use
|
||||||
|
* {@link #userData(byte[])} instead.
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
@Override
|
||||||
|
public TemplateOptions userMetadata(Map<String, String> userMetadata) {
|
||||||
|
return super.userMetadata(userMetadata);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Key value metadata is not supported in DigitalOcean. Use
|
||||||
|
* {@link #userData(byte[])} instead.
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
@Override
|
||||||
|
public TemplateOptions userMetadata(String key, String value) {
|
||||||
|
return super.userMetadata(key, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated Key value metadata is not supported in DigitalOcean. User data
|
||||||
|
* can be retrieved with {@link #getUserData()}.
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
@Override
|
||||||
|
public Map<String, String> getUserMetadata() {
|
||||||
|
return super.getUserMetadata();
|
||||||
|
}
|
||||||
|
|
||||||
public Set<Integer> getSshKeyIds() {
|
public Set<Integer> getSshKeyIds() {
|
||||||
return sshKeyIds;
|
return sshKeyIds;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue