All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.etcd.jetcd.options.DeleteOption Maven / Gradle / Ivy

There is a newer version: 0.8.4
Show newest version
/*
 * Copyright 2016-2021 The jetcd authors
 *
 * 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 io.etcd.jetcd.options;

import java.util.Optional;

import io.etcd.jetcd.ByteSequence;
import io.etcd.jetcd.KV;

import static com.google.common.base.Preconditions.checkNotNull;

public final class DeleteOption {

    public static final DeleteOption DEFAULT = newBuilder().build();

    public static Builder newBuilder() {
        return new Builder();
    }

    public static class Builder {

        private Optional endKey = Optional.empty();
        private boolean prevKV = false;
        private boolean prefix = false;

        private Builder() {
        }

        /**
         * Set the end key of the delete request. If it is set, the delete request will delete the keys
         * from key to endKey (exclusive).
         *
         * 

* If end key is '\0', the range is all keys {@literal >=} * key. * *

* If the end key is one bit larger than the given key, then it deletes all keys with * the prefix (the given key). * *

* If both key and end key are '\0', it deletes all keys. * * @param endKey end key * @return builder */ public Builder withRange(ByteSequence endKey) { this.endKey = Optional.ofNullable(endKey); return this; } /** * Enables 'Delete' requests to delete all the keys by prefix. * *

* * @param prefix flag to delete all the keys by prefix * @return builder */ public DeleteOption.Builder isPrefix(boolean prefix) { this.prefix = prefix; return this; } /** * Enables 'Delete' requests to delete all the keys with matching prefix. * *

* You should pass the key that is passed into * {@link KV#delete(ByteSequence) KV.delete} method * into this method as the given key. * * @param prefix the common prefix of all the keys that you want to delete * @return builder * @deprecated Use {@link #isPrefix(boolean)} instead. */ @Deprecated public Builder withPrefix(ByteSequence prefix) { checkNotNull(prefix, "prefix should not be null"); ByteSequence prefixEnd = OptionsUtil.prefixEndOf(prefix); this.withRange(prefixEnd); return this; } /** * Get the previous key/value pairs before deleting them. * * @param prevKV flag to get previous key/value pairs before deleting them. * @return builder */ public Builder withPrevKV(boolean prevKV) { this.prevKV = prevKV; return this; } public DeleteOption build() { return new DeleteOption(endKey, prevKV, prefix); } } private final Optional endKey; private final boolean prevKV; private final boolean prefix; private DeleteOption(Optional endKey, boolean prevKV, boolean prefix) { this.endKey = endKey; this.prevKV = prevKV; this.prefix = prefix; } public Optional getEndKey() { return endKey; } /** * Whether to get the previous key/value pairs before deleting them. * * @return true if get the previous key/value pairs before deleting them, otherwise false. */ public boolean isPrevKV() { return prevKV; } public boolean isPrefix() { return prefix; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy