/*
* Copyright (c) 2015, Jurriaan Mous and contributors as indicated by the @author tags.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package mousio.etcd4j.requests;
import io.netty.handler.codec.http.HttpMethod;
import mousio.client.retry.RetryPolicy;
import mousio.etcd4j.transport.EtcdClientImpl;
import java.util.concurrent.TimeUnit;
/**
* An Etcd Key Put Request
*/
public class EtcdKeyPutRequest extends EtcdKeyRequest {
/**
* Constructs an EtcdKeysRequest
*
* @param clientImpl the client to handle this request
* @param key key to change
* @param retryHandler Handles retries on fails
*/
public EtcdKeyPutRequest(EtcdClientImpl clientImpl, String key, RetryPolicy retryHandler) {
super(clientImpl, HttpMethod.PUT, retryHandler, key);
}
/**
* Set the value for the request
*
* @param value to set on key
* @return Itself for chaining
*/
public EtcdKeyPutRequest value(String value) {
this.requestParams.put("value", value);
return this;
}
/**
* Set the Time to live for a key in seconds
*
* @param ttl time to live in seconds
* @return Itself for chaining
*/
public EtcdKeyPutRequest ttl(Integer ttl) {
this.requestParams.put("ttl", (ttl == null) ? "" : ttl + "");
return this;
}
/**
* Set Time to live on a refresh request.
* Requires previous value to exist
*
* @param ttl time to live in seconds
* @return Itself for chaining
*/
public EtcdKeyPutRequest refresh(Integer ttl) {
this.requestParams.put("refresh", "true");
this.prevExist(true);
return ttl(ttl);
}
/**
* Set that operation is on a directory
*
* @return Itself for chaining
*/
public EtcdKeyPutRequest isDir() {
this.requestParams.put("dir", "true");
return this;
}
/**
* Set that previous value should exist
*
* @return Itself for chaining
* @deprecated As of release 0.4.13 replaced by {@link #prevExist(boolean)}
*/
@Deprecated
public EtcdKeyPutRequest prevExist() {
this.requestParams.put("prevExist", "true");
return this;
}
/**
* Set that previous value should exist
*
* @param prevExists boolean to indicate if previous value should or should not exist.
* @return Itself for chaining
*/
public EtcdKeyPutRequest prevExist(boolean prevExists) {
this.requestParams.put("prevExist", String.valueOf(prevExists));
return this;
}
/**
* Set the previous index to check
*
* @param prevIndex to set on key
* @return Itself for chaining
*/
public EtcdKeyPutRequest prevIndex(long prevIndex) {
this.requestParams.put("prevIndex", prevIndex + "");
return this;
}
/**
* Set the prev value to check
*
* @param value to set on key
* @return Itself for chaining
*/
public EtcdKeyPutRequest prevValue(String value) {
this.requestParams.put("prevValue", value);
return this;
}
@Override public EtcdKeyPutRequest timeout(long timeout, TimeUnit unit) {
super.timeout(timeout, unit);
return this;
}
@Override public EtcdKeyPutRequest setRetryPolicy(RetryPolicy retryPolicy) {
super.setRetryPolicy(retryPolicy);
return this;
}
}