io.dapr.client.domain.StateOptions Maven / Gradle / Ivy
/*
* Copyright 2021 The Dapr 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.dapr.client.domain;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonValue;
import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.core.JsonParser;
import com.fasterxml.jackson.databind.DeserializationContext;
import com.fasterxml.jackson.databind.SerializerProvider;
import com.fasterxml.jackson.databind.deser.std.StdDeserializer;
import com.fasterxml.jackson.databind.exc.InvalidFormatException;
import com.fasterxml.jackson.databind.ser.std.StdSerializer;
import io.dapr.utils.DurationUtils;
import java.io.IOException;
import java.time.Duration;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import java.util.Optional;
/**
* A class representing the state options for Dapr state API.
*/
public class StateOptions {
private final Consistency consistency;
private final Concurrency concurrency;
/**
* Represents options for a Dapr state API call.
* @param consistency The consistency mode.
* @param concurrency The concurrency mode.
*/
public StateOptions(Consistency consistency, Concurrency concurrency) {
this.consistency = consistency;
this.concurrency = concurrency;
}
public Concurrency getConcurrency() {
return concurrency;
}
public Consistency getConsistency() {
return consistency;
}
/**
* Returns state options as a Map of option name to value.
* @return A map of state options.
*/
@JsonIgnore
public Map getStateOptionsAsMap() {
Map mapOptions = new HashMap<>();
if (this.getConsistency() != null) {
mapOptions.put("consistency", this.getConsistency().getValue());
}
if (this.getConcurrency() != null) {
mapOptions.put("concurrency", this.getConcurrency().getValue());
}
return Collections.unmodifiableMap(Optional.ofNullable(mapOptions).orElse(Collections.EMPTY_MAP));
}
/**
* Options for Consistency.
*/
public enum Consistency {
EVENTUAL("eventual"),
STRONG("strong");
private final String value;
Consistency(String value) {
this.value = value;
}
@JsonValue
public String getValue() {
return this.value;
}
@JsonCreator
public static Consistency fromValue(String value) {
return Consistency.valueOf(value);
}
}
/**
* Options for Concurrency.
*/
public enum Concurrency {
FIRST_WRITE("first-write"),
LAST_WRITE("last-write");
private final String value;
Concurrency(String value) {
this.value = value;
}
@JsonValue
public String getValue() {
return this.value;
}
@JsonCreator
public static Concurrency fromValue(String value) {
return Concurrency.valueOf(value);
}
}
public static class StateOptionDurationSerializer extends StdSerializer {
public StateOptionDurationSerializer() {
super(Duration.class);
}
public StateOptionDurationSerializer(Class t) {
super(t);
}
@Override
public void serialize(
Duration duration,
JsonGenerator jsonGenerator,
SerializerProvider serializerProvider) throws IOException {
jsonGenerator.writeNumber(duration.toMillis());
}
}
public static class StateOptionDurationDeserializer extends StdDeserializer {
public StateOptionDurationDeserializer(Class> vc) {
super(vc);
}
@Override
public Duration deserialize(
JsonParser jsonParser,
DeserializationContext deserializationContext) throws IOException {
String durationStr = jsonParser.readValueAs(String.class);
Duration duration = null;
if (durationStr != null && !durationStr.trim().isEmpty()) {
try {
duration = DurationUtils.convertDurationFromDaprFormat(durationStr);
} catch (Exception ex) {
throw InvalidFormatException.from(jsonParser, "Unable to parse duration.", ex);
}
}
return duration;
}
}
}