Delete pending messages for an unlinked device
// FREEBIE
This commit is contained in:
parent
0bc494245d
commit
a211f6aed9
|
@ -210,7 +210,7 @@ public class WhisperServerService extends Application<WhisperServerConfiguration
|
||||||
environment.jersey().register(new AuthValueFactoryProvider.Binder());
|
environment.jersey().register(new AuthValueFactoryProvider.Binder());
|
||||||
|
|
||||||
environment.jersey().register(new AccountController(pendingAccountsManager, accountsManager, rateLimiters, smsSender, messagesManager, new TimeProvider(), authorizationKey, config.getTestDevices()));
|
environment.jersey().register(new AccountController(pendingAccountsManager, accountsManager, rateLimiters, smsSender, messagesManager, new TimeProvider(), authorizationKey, config.getTestDevices()));
|
||||||
environment.jersey().register(new DeviceController(pendingDevicesManager, accountsManager, rateLimiters));
|
environment.jersey().register(new DeviceController(pendingDevicesManager, accountsManager, messagesManager, rateLimiters));
|
||||||
environment.jersey().register(new DirectoryController(rateLimiters, directory));
|
environment.jersey().register(new DirectoryController(rateLimiters, directory));
|
||||||
environment.jersey().register(new FederationControllerV1(accountsManager, attachmentController, messageController, keysControllerV1));
|
environment.jersey().register(new FederationControllerV1(accountsManager, attachmentController, messageController, keysControllerV1));
|
||||||
environment.jersey().register(new FederationControllerV2(accountsManager, attachmentController, messageController, keysControllerV2));
|
environment.jersey().register(new FederationControllerV2(accountsManager, attachmentController, messageController, keysControllerV2));
|
||||||
|
|
|
@ -32,6 +32,7 @@ import org.whispersystems.textsecuregcm.limits.RateLimiters;
|
||||||
import org.whispersystems.textsecuregcm.storage.Account;
|
import org.whispersystems.textsecuregcm.storage.Account;
|
||||||
import org.whispersystems.textsecuregcm.storage.AccountsManager;
|
import org.whispersystems.textsecuregcm.storage.AccountsManager;
|
||||||
import org.whispersystems.textsecuregcm.storage.Device;
|
import org.whispersystems.textsecuregcm.storage.Device;
|
||||||
|
import org.whispersystems.textsecuregcm.storage.MessagesManager;
|
||||||
import org.whispersystems.textsecuregcm.storage.PendingDevicesManager;
|
import org.whispersystems.textsecuregcm.storage.PendingDevicesManager;
|
||||||
import org.whispersystems.textsecuregcm.util.Util;
|
import org.whispersystems.textsecuregcm.util.Util;
|
||||||
import org.whispersystems.textsecuregcm.util.VerificationCode;
|
import org.whispersystems.textsecuregcm.util.VerificationCode;
|
||||||
|
@ -65,14 +66,17 @@ public class DeviceController {
|
||||||
|
|
||||||
private final PendingDevicesManager pendingDevices;
|
private final PendingDevicesManager pendingDevices;
|
||||||
private final AccountsManager accounts;
|
private final AccountsManager accounts;
|
||||||
|
private final MessagesManager messages;
|
||||||
private final RateLimiters rateLimiters;
|
private final RateLimiters rateLimiters;
|
||||||
|
|
||||||
public DeviceController(PendingDevicesManager pendingDevices,
|
public DeviceController(PendingDevicesManager pendingDevices,
|
||||||
AccountsManager accounts,
|
AccountsManager accounts,
|
||||||
|
MessagesManager messages,
|
||||||
RateLimiters rateLimiters)
|
RateLimiters rateLimiters)
|
||||||
{
|
{
|
||||||
this.pendingDevices = pendingDevices;
|
this.pendingDevices = pendingDevices;
|
||||||
this.accounts = accounts;
|
this.accounts = accounts;
|
||||||
|
this.messages = messages;
|
||||||
this.rateLimiters = rateLimiters;
|
this.rateLimiters = rateLimiters;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -100,6 +104,7 @@ public class DeviceController {
|
||||||
|
|
||||||
account.removeDevice(deviceId);
|
account.removeDevice(deviceId);
|
||||||
accounts.update(account);
|
accounts.update(account);
|
||||||
|
messages.clear(account.getNumber(), deviceId);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Timed
|
@Timed
|
||||||
|
|
|
@ -60,6 +60,9 @@ public abstract class Messages {
|
||||||
@SqlUpdate("DELETE FROM messages WHERE " + DESTINATION + " = :destination")
|
@SqlUpdate("DELETE FROM messages WHERE " + DESTINATION + " = :destination")
|
||||||
abstract void clear(@Bind("destination") String destination);
|
abstract void clear(@Bind("destination") String destination);
|
||||||
|
|
||||||
|
@SqlUpdate("DELETE FROM messages WHERE " + DESTINATION + " = :destination AND " + DESTINATION_DEVICE + " = :destination_device")
|
||||||
|
abstract void clear(@Bind("destination") String destination, @Bind("destination_device") long destinationDevice);
|
||||||
|
|
||||||
@SqlUpdate("DELETE FROM messages WHERE " + TIMESTAMP + " < :timestamp")
|
@SqlUpdate("DELETE FROM messages WHERE " + TIMESTAMP + " < :timestamp")
|
||||||
public abstract void removeOld(@Bind("timestamp") long timestamp);
|
public abstract void removeOld(@Bind("timestamp") long timestamp);
|
||||||
|
|
||||||
|
|
|
@ -29,6 +29,10 @@ public class MessagesManager {
|
||||||
this.messages.clear(destination);
|
this.messages.clear(destination);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void clear(String destination, long deviceId) {
|
||||||
|
this.messages.clear(destination, deviceId);
|
||||||
|
}
|
||||||
|
|
||||||
public Optional<OutgoingMessageEntity> delete(String destination, String source, long timestamp) {
|
public Optional<OutgoingMessageEntity> delete(String destination, String source, long timestamp) {
|
||||||
return Optional.fromNullable(this.messages.remove(destination, source, timestamp));
|
return Optional.fromNullable(this.messages.remove(destination, source, timestamp));
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,6 +30,7 @@ import org.whispersystems.textsecuregcm.limits.RateLimiters;
|
||||||
import org.whispersystems.textsecuregcm.mappers.DeviceLimitExceededExceptionMapper;
|
import org.whispersystems.textsecuregcm.mappers.DeviceLimitExceededExceptionMapper;
|
||||||
import org.whispersystems.textsecuregcm.storage.Account;
|
import org.whispersystems.textsecuregcm.storage.Account;
|
||||||
import org.whispersystems.textsecuregcm.storage.AccountsManager;
|
import org.whispersystems.textsecuregcm.storage.AccountsManager;
|
||||||
|
import org.whispersystems.textsecuregcm.storage.MessagesManager;
|
||||||
import org.whispersystems.textsecuregcm.storage.PendingDevicesManager;
|
import org.whispersystems.textsecuregcm.storage.PendingDevicesManager;
|
||||||
import org.whispersystems.textsecuregcm.tests.util.AuthHelper;
|
import org.whispersystems.textsecuregcm.tests.util.AuthHelper;
|
||||||
import org.whispersystems.textsecuregcm.util.VerificationCode;
|
import org.whispersystems.textsecuregcm.util.VerificationCode;
|
||||||
|
@ -48,8 +49,12 @@ import static org.mockito.Mockito.*;
|
||||||
public class DeviceControllerTest {
|
public class DeviceControllerTest {
|
||||||
@Path("/v1/devices")
|
@Path("/v1/devices")
|
||||||
static class DumbVerificationDeviceController extends DeviceController {
|
static class DumbVerificationDeviceController extends DeviceController {
|
||||||
public DumbVerificationDeviceController(PendingDevicesManager pendingDevices, AccountsManager accounts, RateLimiters rateLimiters) {
|
public DumbVerificationDeviceController(PendingDevicesManager pendingDevices,
|
||||||
super(pendingDevices, accounts, rateLimiters);
|
AccountsManager accounts,
|
||||||
|
MessagesManager messages,
|
||||||
|
RateLimiters rateLimiters)
|
||||||
|
{
|
||||||
|
super(pendingDevices, accounts, messages, rateLimiters);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -60,6 +65,7 @@ public class DeviceControllerTest {
|
||||||
|
|
||||||
private PendingDevicesManager pendingDevicesManager = mock(PendingDevicesManager.class);
|
private PendingDevicesManager pendingDevicesManager = mock(PendingDevicesManager.class);
|
||||||
private AccountsManager accountsManager = mock(AccountsManager.class );
|
private AccountsManager accountsManager = mock(AccountsManager.class );
|
||||||
|
private MessagesManager messagesManager = mock(MessagesManager.class);
|
||||||
private RateLimiters rateLimiters = mock(RateLimiters.class );
|
private RateLimiters rateLimiters = mock(RateLimiters.class );
|
||||||
private RateLimiter rateLimiter = mock(RateLimiter.class );
|
private RateLimiter rateLimiter = mock(RateLimiter.class );
|
||||||
private Account account = mock(Account.class );
|
private Account account = mock(Account.class );
|
||||||
|
@ -74,6 +80,7 @@ public class DeviceControllerTest {
|
||||||
.addProvider(new ConstraintViolationExceptionMapper())
|
.addProvider(new ConstraintViolationExceptionMapper())
|
||||||
.addResource(new DumbVerificationDeviceController(pendingDevicesManager,
|
.addResource(new DumbVerificationDeviceController(pendingDevicesManager,
|
||||||
accountsManager,
|
accountsManager,
|
||||||
|
messagesManager,
|
||||||
rateLimiters))
|
rateLimiters))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue