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

org.cloudfoundry.identity.uaa.audit.event.SystemDeletable Maven / Gradle / Ivy

/*
 * *****************************************************************************
 *      Cloud Foundry
 *      Copyright (c) [2009-2015] Pivotal Software, Inc. All Rights Reserved.
 *
 *      This product is licensed to you under the Apache License, Version 2.0 (the "License").
 *      You may not use this product except in compliance with the License.
 *
 *      This product includes a number of subcomponents with
 *      separate copyright notices and license terms. Your use of these
 *      subcomponents is subject to the terms and conditions of the
 *      subcomponent's license, as noted in the LICENSE file.
 * *****************************************************************************
 */

package org.cloudfoundry.identity.uaa.audit.event;

import org.apache.commons.logging.Log;
import org.cloudfoundry.identity.uaa.constants.OriginKeys;
import org.cloudfoundry.identity.uaa.mfa.MfaProvider;
import org.cloudfoundry.identity.uaa.provider.IdentityProvider;
import org.cloudfoundry.identity.uaa.scim.ScimUser;
import org.cloudfoundry.identity.uaa.user.UaaUser;
import org.cloudfoundry.identity.uaa.zone.IdentityZone;
import org.cloudfoundry.identity.uaa.zone.IdentityZoneHolder;
import org.springframework.context.ApplicationListener;
import org.springframework.security.oauth2.provider.ClientDetails;

public interface SystemDeletable extends ApplicationListener {
    default void onApplicationEvent(EntityDeletedEvent event) {
        if (event==null || event.getDeleted()==null) {
            return;
        } else if (event.getDeleted() instanceof IdentityZone) {
            String zoneId = ((IdentityZone)event.getDeleted()).getId();
            getLogger().debug(String.format("Received zone deletion event for id:%s", zoneId));
            if (isUaaZone(zoneId)) {
                getLogger().debug("Attempt to delete default zone ignored:"+event.getDeleted());
                return;
            }
            deleteByIdentityZone(zoneId);
        } else if (event.getDeleted() instanceof IdentityProvider) {
            String zoneId = ((IdentityProvider)event.getDeleted()).getIdentityZoneId();
            String origin = ((IdentityProvider)event.getDeleted()).getOriginKey();
            getLogger().debug(String.format("Received provider deletion event for zone_id:%s and origin:%s", zoneId, origin));
            if (OriginKeys.UAA.equals(origin)) {
                getLogger().debug("Attempt to delete default UAA provider ignored:"+event.getDeleted());
                return;
            }
            deleteByOrigin(origin, zoneId);
        } else if (event.getDeleted() instanceof ClientDetails) {
            String clientId = ((ClientDetails) event.getDeleted()).getClientId();
            String zoneId = IdentityZoneHolder.get().getId();
            getLogger().debug(String.format("Received client deletion event for zone_id:%s and client:%s", zoneId, clientId));
            deleteByClient(clientId, zoneId);
        } else if (event.getDeleted() instanceof UaaUser) {
            String userId = ((UaaUser) event.getDeleted()).getId();
            String zoneId = ((UaaUser) event.getDeleted()).getZoneId();
            getLogger().debug(String.format("Received UAA user deletion event for zone_id:%s and user:%s", zoneId, userId));
            deleteByUser(userId, zoneId);
        } else if (event.getDeleted() instanceof ScimUser) {
            String userId = ((ScimUser) event.getDeleted()).getId();
            String zoneId = ((ScimUser) event.getDeleted()).getZoneId();
            getLogger().debug(String.format("Received SCIM user deletion event for zone_id:%s and user:%s", zoneId, userId));
            deleteByUser(userId, zoneId);
        } else if (event.getDeleted() instanceof MfaProvider) {
            String providerId = ((MfaProvider) event.getDeleted()).getId();
            String zoneId = IdentityZoneHolder.get().getId();
            deleteByMfaProvider(providerId, zoneId);
        } else {
            getLogger().debug("Unsupported deleted event for deletion of object:"+event.getDeleted());
        }
    }

    default void onApplicationEvent(AbstractUaaEvent event) {
        if (event instanceof EntityDeletedEvent) {
            onApplicationEvent((EntityDeletedEvent)event);
        }
    }

    default boolean isUaaZone(String zoneId) {
        return IdentityZone.getUaa().getId().equals(zoneId);
    }

    default int deleteByIdentityZone(String zoneId) {
        return 0;
    }

    default int deleteByOrigin(String origin, String zoneId) {
        return 0;
    }

    default int deleteByClient(String clientId, String zoneId) {
        return 0;
    }

    default int deleteByUser(String userId, String zoneId) {
        return 0;
    }

    default int deleteByMfaProvider(String id, String zoneId) {
        return 0;
    }

    Log getLogger();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy