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

net.nemerosa.ontrack.model.security.AccountGroupMappingService.kt Maven / Gradle / Ivy

package net.nemerosa.ontrack.model.security

import net.nemerosa.ontrack.model.Ack
import net.nemerosa.ontrack.model.structure.ID

/**
 * Management of mappings between provided groups (by a LDAP system for example)
 * and actual Ontrack [group][AccountGroup].
 */
interface AccountGroupMappingService {
    /**
     * For the given [mapping][AuthenticationSource.id] type, collects the [AccountGroup] which are associated
     * with the [mappedName] name.
     *
     * @param authenticationSource    Authentication source
     * @param mappedName Mapping name, for example: "Administrator"
     * @return List of mapped groups
     */
    fun getGroups(authenticationSource: AuthenticationSource, mappedName: String): Collection

    /**
     * Gets ALL the mappings
     */
    val mappings: List

    /**
     * For the given [mapping][AuthenticationSource.id] type, collects the [mappings][AccountGroupMapping].
     *
     * @param authenticationSource    Authentication source
     * @return List of mappings
     */
    fun getMappings(authenticationSource: AuthenticationSource): List

    /**
     * Creates a new mapping
     *
     * @param authenticationSource Authentication source
     * @param input   Input data for the mapping
     * @return Created mapping
     */
    fun newMapping(authenticationSource: AuthenticationSource, input: AccountGroupMappingInput): AccountGroupMapping

    /**
     * Gets a mapping by its ID
     *
     * @param authenticationSource Authentication source
     * @param id      ID of the mapping
     * @return Mapping
     */
    fun getMapping(authenticationSource: AuthenticationSource, id: ID): AccountGroupMapping

    /**
     * Updates a mapping
     *
     * @param authenticationSource Authentication source
     * @param id      ID of the mapping
     * @param input   Input data for the mapping
     * @return Updated mapping
     */
    fun updateMapping(authenticationSource: AuthenticationSource, id: ID, input: AccountGroupMappingInput): AccountGroupMapping

    /**
     * Deletes a mapping
     *
     * @param authenticationSource Authentication source
     * @param id      ID of the mapping
     * @return Acknowledgment
     */
    fun deleteMapping(authenticationSource: AuthenticationSource, id: ID): Ack

    /**
     * Gets the list of mappings for a given group.
     *
     * @param group Group to get the mappings to
     * @return List of mappings (never null)
     */
    fun getMappingsForGroup(group: AccountGroup): List

    /**
     * Deletes all mappings associated to this [source].
     */
    fun deleteMappingsBySource(source: AuthenticationSource)

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy