Deprecate user metadata in DigitalOcean

This commit is contained in:
Ignasi Barrera 2016-12-07 17:16:51 +01:00
parent 3ae2213a7d
commit fa746ff162
2 changed files with 35 additions and 11 deletions

View File

@ -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 java.util.List;
import java.util.Map;
import java.util.Set;
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.options.CreateDropletOptions;
import org.jclouds.domain.LoginCredentials;
import org.jclouds.json.Json;
import org.jclouds.logging.Logger;
import com.google.common.base.Function;
@ -68,18 +66,15 @@ public class DigitalOcean2ComputeServiceAdapter implements ComputeServiceAdapter
private final Predicate<Integer> nodeRunningPredicate;
private final Predicate<Integer> nodeStoppedPredicate;
private final Predicate<Integer> nodeTerminatedPredicate;
private final Json json;
@Inject DigitalOcean2ComputeServiceAdapter(DigitalOcean2Api api,
@Named(TIMEOUT_NODE_RUNNING) Predicate<Integer> nodeRunningPredicate,
@Named(TIMEOUT_NODE_SUSPENDED) Predicate<Integer> nodeStoppedPredicate,
@Named(TIMEOUT_NODE_TERMINATED) Predicate<Integer> nodeTerminatedPredicate,
Json json) {
@Named(TIMEOUT_NODE_TERMINATED) Predicate<Integer> nodeTerminatedPredicate) {
this.api = api;
this.nodeRunningPredicate = nodeRunningPredicate;
this.nodeStoppedPredicate = nodeStoppedPredicate;
this.nodeTerminatedPredicate = nodeTerminatedPredicate;
this.json = json;
}
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.
if (null != templateOptions.getUserData()) {
setUserDataIfSupported(template, options, new String(templateOptions.getUserData()));
}
// Backwards compatible variant, getting userData from userMetaData map.
Map<String, String> metadataAndTags = templateOptions.getUserMetadata();
if (null != metadataAndTags.get("user_data")) {
setUserDataIfSupported(template, options, metadataAndTags.get("user_data"));
} else if (null != templateOptions.getUserMetadata().get("user_data")) {
// Backwards compatible variant, getting userData from userMetaData map.
setUserDataIfSupported(template, options, templateOptions.getUserMetadata().get("user_data"));
}
DropletCreate dropletCreated = api.dropletApi().create(name,

View File

@ -20,6 +20,7 @@ import static com.google.common.base.Objects.equal;
import static com.google.common.base.Preconditions.checkNotNull;
import java.util.Arrays;
import java.util.Map;
import java.util.Set;
import org.jclouds.compute.options.TemplateOptions;
@ -77,6 +78,36 @@ public class DigitalOcean2TemplateOptions extends TemplateOptions implements Clo
this.userData = userData;
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() {
return sshKeyIds;