com.bazaarvoice.emodb.queue.client.DedupQueueServiceAuthenticatorProxy Maven / Gradle / Ivy
package com.bazaarvoice.emodb.queue.client;
import com.bazaarvoice.emodb.queue.api.AuthDedupQueueService;
import com.bazaarvoice.emodb.queue.api.DedupQueueService;
import com.bazaarvoice.emodb.queue.api.Message;
import com.bazaarvoice.emodb.queue.api.MoveQueueStatus;
import com.bazaarvoice.ostrich.partition.PartitionKey;
import java.time.Duration;
import java.util.Collection;
import java.util.List;
import java.util.Map;
/**
* DedupQueueService instance that takes an {@link AuthDedupQueueService} and API key and proxies all calls using
* the API key.
*
* Note: The {@link PartitionKey} annotations must match those from AuthDedupQueueService.
*/
class DedupQueueServiceAuthenticatorProxy implements DedupQueueService {
private final AuthDedupQueueService _authDedupQueueService;
private final String _apiKey;
DedupQueueServiceAuthenticatorProxy(AuthDedupQueueService authDedupQueueService, String apiKey) {
_authDedupQueueService = authDedupQueueService;
_apiKey = apiKey;
}
@Override
public void send(String queue, Object message) {
_authDedupQueueService.send(_apiKey, queue, message);
}
@Override
public void sendAll(Map> messagesByQueue) {
_authDedupQueueService.sendAll(_apiKey, messagesByQueue);
}
@Override
public MoveQueueStatus getMoveStatus(String reference) {
return _authDedupQueueService.getMoveStatus(_apiKey, reference);
}
@Override
public long getClaimCount(@PartitionKey String queue) {
return _authDedupQueueService.getClaimCount(_apiKey, queue);
}
@Override
public String moveAsync(String from, String to) {
return _authDedupQueueService.moveAsync(_apiKey, from, to);
}
@Override
public void unclaimAll(@PartitionKey String queue) {
_authDedupQueueService.unclaimAll(_apiKey, queue);
}
@Override
public void renew(@PartitionKey String queue, Collection messageIds, Duration claimTtl) {
_authDedupQueueService.renew(_apiKey, queue, messageIds, claimTtl);
}
@Override
public void sendAll(String queue, Collection> messages) {
_authDedupQueueService.sendAll(_apiKey, queue, messages);
}
@Override
public void purge(@PartitionKey String queue) {
_authDedupQueueService.purge(_apiKey, queue);
}
@Override
public long getMessageCount(@PartitionKey String queue) {
return _authDedupQueueService.getMessageCount(_apiKey, queue);
}
@Override
public List poll(@PartitionKey String queue, Duration claimTtl, int limit) {
return _authDedupQueueService.poll(_apiKey, queue, claimTtl, limit);
}
@Override
public long getMessageCountUpTo(@PartitionKey String queue, long limit) {
return _authDedupQueueService.getMessageCountUpTo(_apiKey, queue, limit);
}
@Override
public List peek(@PartitionKey String queue, int limit) {
return _authDedupQueueService.peek(_apiKey, queue, limit);
}
@Override
public void acknowledge(@PartitionKey String queue, Collection messageIds) {
_authDedupQueueService.acknowledge(_apiKey, queue, messageIds);
}
AuthDedupQueueService getProxiedInstance() {
return _authDedupQueueService;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy