All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.arbeitsagentur.opdt.keycloak.cassandra.userSession.CassandraAuthenticatedClientSessionAdapter Maven / Gradle / Ivy

/*
 * Copyright 2022 IT-Systemhaus der Bundesagentur fuer Arbeit
 *
 * 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 de.arbeitsagentur.opdt.keycloak.cassandra.userSession;

import de.arbeitsagentur.opdt.keycloak.cassandra.userSession.persistence.entities.AuthenticatedClientSessionValue;
import lombok.AllArgsConstructor;
import lombok.EqualsAndHashCode;
import org.keycloak.models.*;
import de.arbeitsagentur.opdt.keycloak.mapstorage.common.TimeAdapter;

import java.util.Map;

import static de.arbeitsagentur.opdt.keycloak.cassandra.userSession.expiration.CassandraSessionExpiration.setClientSessionExpiration;

@EqualsAndHashCode(of = "userSession")
@AllArgsConstructor
public abstract class CassandraAuthenticatedClientSessionAdapter implements AuthenticatedClientSessionModel {
    protected KeycloakSession session;
    protected RealmModel realm;
    protected CassandraUserSessionAdapter userSession;
    protected AuthenticatedClientSessionValue clientSessionEntity;

    @Override
    public String getId() {
        return clientSessionEntity.getId();
    }

    @Override
    public int getTimestamp() {
        Long timestamp = clientSessionEntity.getTimestamp();
        return timestamp != null ? TimeAdapter.fromLongWithTimeInSecondsToIntegerWithTimeInSeconds(TimeAdapter.fromMilliSecondsToSeconds(timestamp)) : 0;
    }

    @Override
    public void setTimestamp(int timestamp) {
        clientSessionEntity.setTimestamp(TimeAdapter.fromSecondsToMilliseconds(timestamp));

        // whenever the timestamp is changed recompute the expiration time
        setClientSessionExpiration(clientSessionEntity, userSession.getSessionExpirationData(), getClient());
        userSession.markAsUpdated();
    }

    @Override
    public UserSessionModel getUserSession() {
        return userSession;
    }

    @Override
    public String getCurrentRefreshToken() {
        return clientSessionEntity.getCurrentRefreshToken();
    }

    @Override
    public void setCurrentRefreshToken(String currentRefreshToken) {
        clientSessionEntity.setCurrentRefreshToken(currentRefreshToken);
        userSession.markAsUpdated();
    }

    @Override
    public int getCurrentRefreshTokenUseCount() {
        Integer currentRefreshTokenUseCount = clientSessionEntity.getCurrentRefreshTokenUseCount();
        return currentRefreshTokenUseCount != null ? currentRefreshTokenUseCount : 0;
    }

    @Override
    public void setCurrentRefreshTokenUseCount(int currentRefreshTokenUseCount) {
        clientSessionEntity.setCurrentRefreshTokenUseCount(currentRefreshTokenUseCount);
        userSession.markAsUpdated();
    }

    @Override
    public String getNote(String name) {
        return clientSessionEntity.getNotes().get(name);
    }

    @Override
    public void setNote(String name, String value) {
        if (value == null) {
            removeNote(name);
            return;
        }

        clientSessionEntity.getNotes().put(name, value);

        userSession.markAsUpdated();
    }

    @Override
    public void removeNote(String name) {
        clientSessionEntity.getNotes().remove(name);
        userSession.markAsUpdated();
    }

    @Override
    public Map getNotes() {
        return clientSessionEntity.getNotes();
    }

    @Override
    public String getRedirectUri() {
        return clientSessionEntity.getRedirectUri();
    }

    @Override
    public void setRedirectUri(String uri) {
        clientSessionEntity.setRedirectUri(uri);
        userSession.markAsUpdated();
    }

    @Override
    public RealmModel getRealm() {
        return realm;
    }

    @Override
    public ClientModel getClient() {
        return realm.getClientById(clientSessionEntity.getClientId());
    }

    @Override
    public String getAction() {
        return clientSessionEntity.getAction();
    }

    @Override
    public void setAction(String action) {
        clientSessionEntity.setAction(action);
        userSession.markAsUpdated();
    }

    @Override
    public String getProtocol() {
        return clientSessionEntity.getAuthMethod();
    }

    @Override
    public void setProtocol(String method) {
        clientSessionEntity.setAuthMethod(method);
        userSession.markAsUpdated();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy