io.gravitee.gateway.services.sync.cache.task.IncrementalApiKeyRefresher Maven / Gradle / Ivy
/**
* Copyright (C) 2015 The Gravitee team (http://gravitee.io)
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.gravitee.gateway.services.sync.cache.task;
import io.gravitee.repository.management.api.search.ApiKeyCriteria;
import java.util.Collection;
import java.util.List;
/**
* @author David BRASSELY (david.brassely at graviteesource.com)
* @author GraviteeSource Team
*/
public class IncrementalApiKeyRefresher extends ApiKeyRefresher {
private static final int TIMEFRAME_BEFORE_DELAY = 10 * 60 * 1000;
private static final int TIMEFRAME_AFTER_DELAY = 1 * 60 * 1000;
private final Collection plans;
private final long lastRefreshAt, nextLastRefreshAt;
/*
private long minTime;
private long maxTime;
private long avgTime;
private long totalTime;
private long count;
private long errorsCount;
private Throwable lastException;
*/
public IncrementalApiKeyRefresher(final long lastRefreshAt, final long nextLastRefreshAt, final List plans) {
this.lastRefreshAt = lastRefreshAt;
this.nextLastRefreshAt = nextLastRefreshAt;
this.plans = plans;
}
@Override
public Result call() {
//long start = System.currentTimeMillis();
//long nextLastRefreshAt = System.currentTimeMillis();
return doRefresh(
new ApiKeyCriteria.Builder()
.plans(plans)
.includeRevoked(true)
.from(lastRefreshAt - TIMEFRAME_BEFORE_DELAY)
.to(nextLastRefreshAt + TIMEFRAME_AFTER_DELAY)
.build()
);
/*
try {
apiKeyRepository
.findByCriteria(criteriaBuilder.build())
.forEach(this::saveOrUpdate);
lastRefreshAt = nextLastRefreshAt;
} catch (Exception ex) {
errorsCount++;
logger.error("Unexpected error while refreshing api-keys", ex);
lastException = ex;
}
count++;
long end = System.currentTimeMillis();
long diff = end - start;
totalTime += diff;
if (count == 1) {
minTime = diff;
} else {
if (diff > maxTime) {
maxTime = diff;
}
if (diff < minTime) {
minTime = diff;
}
}
avgTime = totalTime / count;
*/
}
/*
public long getLastRefreshAt() {
return lastRefreshAt;
}
public long getCount() {
return count;
}
public long getMinTime() {
return minTime;
}
public long getMaxTime() {
return maxTime;
}
public long getAvgTime() {
return avgTime;
}
public long getTotalTime() {
return totalTime;
}
public long getErrorsCount() {
return errorsCount;
}
public Throwable getLastException() {
return lastException;
}
*/
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy