Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[#1858] Remove 'updateOnly' param in setCommandHandlingAdapterInstance #2000

Merged
merged 1 commit into from
Jun 3, 2020
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -231,30 +231,6 @@ public Future<V> put(final K key, final V value, final long lifespan, final Time

}

/**
* Replaces the entry for a key only if currently mapped to a given value.
*
* @param key The key.
* @param oldValue The value to overwrite.
* @param newValue The value to store.
* @param lifespan The lifespan of the entry. A negative value is interpreted as an unlimited lifespan.
* @param lifespanUnit The time unit for the lifespan.
* @return A succeeded future containing a boolean, indicating whether the value was replaced or not.
* A failed future if the value could not be stored in the cache.
* @throws NullPointerException if any of the parameters is {@code null}.
*/
@Override
public Future<Boolean> replace(final K key, final V oldValue, final V newValue, final long lifespan,
final TimeUnit lifespanUnit) {
Objects.requireNonNull(key);
Objects.requireNonNull(oldValue);
Objects.requireNonNull(newValue);
Objects.requireNonNull(lifespanUnit);

return withCache(cache -> cache.replaceAsync(key, oldValue, newValue, lifespan, lifespanUnit));

}

/**
* Remove a key/value mapping from the cache.
*
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -63,20 +63,6 @@ public interface Cache<K, V> {
*/
Future<V> put(K key, V value, long lifespan, TimeUnit lifespanUnit);

/**
* Replaces the entry for a key only if currently mapped to a given value.
*
* @param key The key.
* @param oldValue The value to overwrite.
* @param newValue The value to store.
* @param lifespan The lifespan of the entry. A negative value is interpreted as an unlimited lifespan.
* @param lifespanUnit The time unit for the lifespan.
* @return A succeeded future containing a boolean, indicating whether the value was replaced or not.
* A failed future if the value could not be stored in the cache.
* @throws NullPointerException if any of the parameters is {@code null}.
*/
Future<Boolean> replace(K key, V oldValue, V newValue, long lifespan, TimeUnit lifespanUnit);

/**
* Gets a value from the cache.
*
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -117,8 +117,8 @@ public Future<JsonObject> getLastKnownGatewayForDevice(final String deviceId, fi

@Override
public Future<Void> setCommandHandlingAdapterInstance(final String deviceId, final String adapterInstanceId,
final Duration lifespan, final boolean updateOnly, final SpanContext context) {
return cache.setCommandHandlingAdapterInstance(tenantId, deviceId, adapterInstanceId, lifespan, updateOnly, context);
final Duration lifespan, final SpanContext context) {
return cache.setCommandHandlingAdapterInstance(tenantId, deviceId, adapterInstanceId, lifespan, context);
}

@Override
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -146,46 +146,25 @@ public Future<JsonObject> getLastKnownGatewayForDevice(final String tenantId, fi

@Override
public Future<Void> setCommandHandlingAdapterInstance(final String tenantId, final String deviceId,
final String adapterInstanceId, final Duration lifespan, final boolean updateOnly, final SpanContext context) {
final String adapterInstanceId, final Duration lifespan, final SpanContext context) {
Objects.requireNonNull(tenantId);
Objects.requireNonNull(deviceId);
Objects.requireNonNull(adapterInstanceId);

// sanity check, preventing an ArithmeticException in lifespan.toMillis()
final long lifespanMillis = lifespan == null || lifespan.isNegative()
|| lifespan.getSeconds() > (Long.MAX_VALUE / 1000L) ? -1 : lifespan.toMillis();
final String key = getAdapterInstanceEntryKey(tenantId, deviceId);
if (updateOnly) {
return cache.replace(key, adapterInstanceId, adapterInstanceId, lifespanMillis, TimeUnit.MILLISECONDS)
.recover(t -> {
LOG.debug("failed to update command handling adapter instance [tenant: {}, device-id: {}, adapter-instance: {}, lifespan: {}ms]",
tenantId, deviceId, adapterInstanceId, lifespanMillis, t);
return Future.failedFuture(new ServerErrorException(HttpURLConnection.HTTP_INTERNAL_ERROR, t));
})
.compose(replaced -> {
if (replaced) {
LOG.debug("updated command handling adapter instance [tenant: {}, device-id: {}, adapter-instance: {}, lifespan: {}ms]",
tenantId, deviceId, adapterInstanceId, lifespanMillis);
return Future.succeededFuture();
} else {
LOG.debug("cannot update non-existing command handling adapter instance entry [tenant: {}, device-id: {}, adapter-instance: {}, lifespan: {}ms]",
tenantId, deviceId, adapterInstanceId, lifespanMillis);
return Future.failedFuture(new ClientErrorException(HttpURLConnection.HTTP_PRECON_FAILED));
}
});
} else {
return cache.put(key, adapterInstanceId, lifespanMillis, TimeUnit.MILLISECONDS)
.recover(t -> {
LOG.debug("failed to set command handling adapter instance [tenant: {}, device-id: {}, adapter-instance: {}, lifespan: {}ms]",
tenantId, deviceId, adapterInstanceId, lifespanMillis, t);
return Future.failedFuture(new ServerErrorException(HttpURLConnection.HTTP_INTERNAL_ERROR, t));
})
.map(replacedValue -> {
LOG.debug("set command handling adapter instance [tenant: {}, device-id: {}, adapter-instance: {}, lifespan: {}ms]",
tenantId, deviceId, adapterInstanceId, lifespanMillis);
return (Void) null;
});
}
return cache.put(getAdapterInstanceEntryKey(tenantId, deviceId), adapterInstanceId, lifespanMillis, TimeUnit.MILLISECONDS)
.map(replacedValue -> {
LOG.debug("set command handling adapter instance [tenant: {}, device-id: {}, adapter-instance: {}, lifespan: {}ms]",
tenantId, deviceId, adapterInstanceId, lifespanMillis);
return (Void) null;
})
.recover(t -> {
LOG.debug("failed to set command handling adapter instance [tenant: {}, device-id: {}, adapter-instance: {}, lifespan: {}ms]",
tenantId, deviceId, adapterInstanceId, lifespanMillis, t);
return Future.failedFuture(new ServerErrorException(HttpURLConnection.HTTP_INTERNAL_ERROR, t));
});
}

@Override
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -76,8 +76,6 @@ public interface DeviceConnectionInfo {
* @param adapterInstanceId The protocol adapter instance id.
* @param lifespan The lifespan of the mapping entry. Using a negative duration or {@code null} here is
* interpreted as an unlimited lifespan.
* @param updateOnly If {@code true}, this operation will only update an existing mapping entry with the given
* lifespan, provided such an entry with the given device id and adapter instance id exists.
* @param context The currently active OpenTracing span context or {@code null} if no span is currently active.
* Implementing classes should use this as the parent for any span they create for tracing
* the execution of this operation.
Expand All @@ -88,7 +86,7 @@ public interface DeviceConnectionInfo {
* @throws NullPointerException if any of the parameters except context is {@code null}.
*/
Future<Void> setCommandHandlingAdapterInstance(String tenantId, String deviceId, String adapterInstanceId,
Duration lifespan, boolean updateOnly, SpanContext context);
Duration lifespan, SpanContext context);

/**
* Removes the mapping information that associates the given device with the given protocol adapter instance
Expand Down
Loading