jklm initial implementation

This commit is contained in:
Athou
2013-05-24 09:21:20 +02:00
parent 89ffd89a31
commit 4ba0ed4bf7
3 changed files with 31 additions and 9 deletions

15
pom.xml
View File

@@ -31,6 +31,16 @@
<enabled>true</enabled> <enabled>true</enabled>
</snapshots> </snapshots>
</repository> </repository>
<repository>
<id>jklm.releases</id>
<url>http://mvn.jkeylockmanager.de</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories> </repositories>
<build> <build>
@@ -234,6 +244,11 @@
<artifactId>joda-time</artifactId> <artifactId>joda-time</artifactId>
<version>2.2</version> <version>2.2</version>
</dependency> </dependency>
<dependency>
<groupId>de.jkeylockmanager</groupId>
<artifactId>jkeylockmanager</artifactId>
<version>1.0.0</version>
</dependency>
<dependency> <dependency>
<groupId>net.java.dev.rome</groupId> <groupId>net.java.dev.rome</groupId>

View File

@@ -14,7 +14,6 @@ import javax.inject.Singleton;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import com.commafeed.backend.LockMap;
import com.commafeed.backend.dao.FeedDAO; import com.commafeed.backend.dao.FeedDAO;
import com.commafeed.backend.dao.FeedSubscriptionDAO; import com.commafeed.backend.dao.FeedSubscriptionDAO;
import com.commafeed.backend.model.ApplicationSettings; import com.commafeed.backend.model.ApplicationSettings;
@@ -26,13 +25,17 @@ import com.commafeed.backend.pubsubhubbub.SubscriptionHandler;
import com.commafeed.backend.services.ApplicationSettingsService; import com.commafeed.backend.services.ApplicationSettingsService;
import com.commafeed.backend.services.FeedUpdateService; import com.commafeed.backend.services.FeedUpdateService;
import de.jkeylockmanager.manager.KeyLockManager;
import de.jkeylockmanager.manager.KeyLockManagers;
import de.jkeylockmanager.manager.LockCallback;
@Singleton @Singleton
public class FeedRefreshUpdater { public class FeedRefreshUpdater {
protected static Logger log = LoggerFactory protected static Logger log = LoggerFactory
.getLogger(FeedRefreshUpdater.class); .getLogger(FeedRefreshUpdater.class);
private static LockMap<String> lockMap = new LockMap<String>(); private static final KeyLockManager lockManager = KeyLockManagers.newLock();
@Inject @Inject
FeedUpdateService feedUpdateService; FeedUpdateService feedUpdateService;
@@ -107,11 +110,14 @@ public class FeedRefreshUpdater {
} }
private void updateEntry(Feed feed, FeedEntry entry, private void updateEntry(final Feed feed, final FeedEntry entry,
List<FeedSubscription> subscriptions) { final List<FeedSubscription> subscriptions) {
synchronized (lockMap.get(entry.getGuid())) { lockManager.executeLocked(entry.getGuid(), new LockCallback() {
feedUpdateService.updateEntry(feed, entry, subscriptions); @Override
} public void doInLock() throws Exception {
feedUpdateService.updateEntry(feed, entry, subscriptions);
}
});
} }
private void handlePubSub(final Feed feed) { private void handlePubSub(final Feed feed) {

View File

@@ -46,8 +46,9 @@ public class UserService {
PasswordEncryptionService encryptionService; PasswordEncryptionService encryptionService;
public User login(String name, String password) { public User login(String name, String password) {
Preconditions.checkNotNull(name); if (name == null || password == null) {
Preconditions.checkNotNull(password); return null;
}
User user = userDAO.findByName(name); User user = userDAO.findByName(name);
if (user != null && !user.isDisabled()) { if (user != null && !user.isDisabled()) {