/* * Copyright 2016 Red Hat, Inc. and/or its affiliates * and other contributors as indicated by the @author tags. * * 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 org.keycloak.models.sessions.infinispan.mapreduce; import org.infinispan.distexec.mapreduce.Collector; import org.infinispan.distexec.mapreduce.Mapper; import org.keycloak.models.sessions.infinispan.entities.ClientInitialAccessEntity; import org.keycloak.models.sessions.infinispan.entities.SessionEntity; import java.io.Serializable; /** * @author <a href="mailto:sthorger@redhat.com">Stian Thorgersen</a> */ public class ClientInitialAccessMapper implements Mapper<String, SessionEntity, String, Object>, Serializable { public ClientInitialAccessMapper(String realm) { this.realm = realm; } private enum EmitValue { KEY, ENTITY } private String realm; private EmitValue emit = EmitValue.ENTITY; private Integer expired; public static ClientInitialAccessMapper create(String realm) { return new ClientInitialAccessMapper(realm); } public ClientInitialAccessMapper emitKey() { emit = EmitValue.KEY; return this; } public ClientInitialAccessMapper expired(int time) { this.expired = time; return this; } @Override public void map(String key, SessionEntity e, Collector collector) { if (!realm.equals(e.getRealm())) { return; } if (!(e instanceof ClientInitialAccessEntity)) { return; } ClientInitialAccessEntity entity = (ClientInitialAccessEntity) e; boolean include = false; if (expired != null) { if (entity.getRemainingCount() <= 0) { include = true; } else if (entity.getExpiration() > 0 && (entity.getTimestamp() + entity.getExpiration()) < expired) { include = true; } } else { include = true; } if (include) { switch (emit) { case KEY: collector.emit(key, key); break; case ENTITY: collector.emit(key, entity); break; } } } }