Skip to content

Commit

Permalink
KEYCLOAK-2713 Fix error at startup
Browse files Browse the repository at this point in the history
  • Loading branch information
mposolda committed Mar 24, 2016
1 parent 0f5caff commit c9545e1
Show file tree
Hide file tree
Showing 10 changed files with 26 additions and 14 deletions.
Expand Up @@ -40,7 +40,6 @@
import org.keycloak.models.KeycloakSession;
import org.keycloak.models.KeycloakSessionFactory;
import org.keycloak.provider.ServerInfoAwareProviderFactory;
import org.keycloak.services.scheduled.ScheduledTaskRunner;
import org.keycloak.timer.TimerProvider;

/**
Expand Down Expand Up @@ -274,7 +273,7 @@ protected String detectDialect(Connection connection) {
protected void startGlobalStats(KeycloakSession session, int globalStatsIntervalSecs) {
logger.debugf("Started Hibernate statistics with the interval %s seconds", globalStatsIntervalSecs);
TimerProvider timer = session.getProvider(TimerProvider.class);
timer.schedule(new ScheduledTaskRunner(session.getKeycloakSessionFactory(), new HibernateStatsReporter(emf)), globalStatsIntervalSecs * 1000, "ReportHibernateGlobalStats");
timer.scheduleTask(new HibernateStatsReporter(emf), globalStatsIntervalSecs * 1000, "ReportHibernateGlobalStats");
}


Expand Down
Expand Up @@ -27,7 +27,7 @@
import org.hibernate.stat.Statistics;
import org.jboss.logging.Logger;
import org.keycloak.models.KeycloakSession;
import org.keycloak.services.scheduled.ScheduledTask;
import org.keycloak.timer.ScheduledTask;

/**
* @author <a href="mailto:mposolda@redhat.com">Marek Posolda</a>
Expand Down
Expand Up @@ -15,7 +15,7 @@
* limitations under the License.
*/

package org.keycloak.services.scheduled;
package org.keycloak.timer;

import org.keycloak.models.KeycloakSession;

Expand Down
Expand Up @@ -24,7 +24,9 @@
*/
public interface TimerProvider extends Provider {

public void schedule(Runnable runnable, long interval, String taskName);
public void schedule(Runnable runnable, long intervalMillis, String taskName);

public void scheduleTask(ScheduledTask scheduledTask, long intervalMillis, String taskName);

public void cancelTask(String taskName);

Expand Down
Expand Up @@ -20,6 +20,7 @@
import org.keycloak.events.EventStoreProvider;
import org.keycloak.models.KeycloakSession;
import org.keycloak.models.RealmModel;
import org.keycloak.timer.ScheduledTask;

/**
* @author <a href="mailto:sthorger@redhat.com">Stian Thorgersen</a>
Expand Down
Expand Up @@ -20,6 +20,7 @@
import org.keycloak.models.KeycloakSession;
import org.keycloak.models.RealmModel;
import org.keycloak.models.UserSessionProvider;
import org.keycloak.timer.ScheduledTask;

/**
* @author <a href="mailto:sthorger@redhat.com">Stian Thorgersen</a>
Expand Down
Expand Up @@ -23,6 +23,7 @@
import org.keycloak.cluster.ExecutionResult;
import org.keycloak.models.KeycloakSession;
import org.keycloak.models.KeycloakSessionFactory;
import org.keycloak.timer.ScheduledTask;

/**
* Ensures that there are not concurrent executions of same task (either on this host or any other cluster host)
Expand Down
Expand Up @@ -17,13 +17,10 @@

package org.keycloak.services.scheduled;

import java.util.concurrent.Callable;

import org.keycloak.cluster.ClusterProvider;
import org.keycloak.cluster.ExecutionResult;
import org.keycloak.models.KeycloakSession;
import org.keycloak.models.KeycloakSessionFactory;
import org.keycloak.services.ServicesLogger;
import org.keycloak.timer.ScheduledTask;

/**
* @author <a href="mailto:sthorger@redhat.com">Stian Thorgersen</a>
Expand Down
Expand Up @@ -18,6 +18,9 @@
package org.keycloak.timer.basic;

import org.jboss.logging.Logger;
import org.keycloak.models.KeycloakSession;
import org.keycloak.services.scheduled.ScheduledTaskRunner;
import org.keycloak.timer.ScheduledTask;
import org.keycloak.timer.TimerProvider;

import java.util.Timer;
Expand All @@ -30,16 +33,18 @@ public class BasicTimerProvider implements TimerProvider {

private static final Logger logger = Logger.getLogger(BasicTimerProvider.class);

private final KeycloakSession session;
private final Timer timer;
private final BasicTimerProviderFactory factory;

public BasicTimerProvider(Timer timer, BasicTimerProviderFactory factory) {
public BasicTimerProvider(KeycloakSession session, Timer timer, BasicTimerProviderFactory factory) {
this.session = session;
this.timer = timer;
this.factory = factory;
}

@Override
public void schedule(final Runnable runnable, final long interval, String taskName) {
public void schedule(final Runnable runnable, final long intervalMillis, String taskName) {
TimerTask task = new TimerTask() {
@Override
public void run() {
Expand All @@ -53,8 +58,14 @@ public void run() {
existingTask.cancel();
}

logger.debugf("Starting task '%s' with interval '%d'", taskName, interval);
timer.schedule(task, interval, interval);
logger.debugf("Starting task '%s' with interval '%d'", taskName, intervalMillis);
timer.schedule(task, intervalMillis, intervalMillis);
}

@Override
public void scheduleTask(ScheduledTask scheduledTask, long intervalMillis, String taskName) {
ScheduledTaskRunner scheduledTaskRunner = new ScheduledTaskRunner(session.getKeycloakSessionFactory(), scheduledTask);
this.schedule(scheduledTaskRunner, intervalMillis, taskName);
}

@Override
Expand Down
Expand Up @@ -39,7 +39,7 @@ public class BasicTimerProviderFactory implements TimerProviderFactory {

@Override
public TimerProvider create(KeycloakSession session) {
return new BasicTimerProvider(timer, this);
return new BasicTimerProvider(session, timer, this);
}

@Override
Expand Down

0 comments on commit c9545e1

Please sign in to comment.