net.nemerosa.ontrack.model.security.AccountService Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ontrack-model Show documentation
Show all versions of ontrack-model Show documentation
Ontrack module: ontrack-model
package net.nemerosa.ontrack.model.security;
import net.nemerosa.ontrack.model.Ack;
import net.nemerosa.ontrack.model.structure.ID;
import net.nemerosa.ontrack.model.structure.NameDescription;
import net.nemerosa.ontrack.model.structure.Project;
import java.util.Collection;
import java.util.List;
import java.util.Optional;
/**
* Management of accounts.
*/
public interface AccountService {
/**
* Completes an account with the list of its authorisations.
*
* @param raw Account without authorisations
* @return Account with authorisations
*/
Account withACL(AuthenticatedAccount raw);
/**
* List of accounts
*/
List getAccounts();
/**
* Creates a built-in account
*/
Account create(AccountInput input);
/**
* Creates an account and allows for further customisation
*
* @param input Account data
* @param authenticationSourceMode Authentication mode
* @see AuthenticationSourceService#getAuthenticationSource(String)
*/
Account create(AccountInput input, String authenticationSourceMode);
/**
* Looks for an account using its user name and his authentication source.
*
* @param username User name
* @param sourceProvider Provider of the source
* @return Account
*/
Optional findUserByNameAndSource(String username, AuthenticationSourceProvider sourceProvider);
/**
* Gets an account using its ID
*/
Account getAccount(ID accountId);
/**
* Updating an existing account
*
* @param accountId ID of the account to update
* @param input Update data
* @return Updated account
*/
Account updateAccount(ID accountId, AccountInput input);
/**
* Deletes an account
*/
Ack deleteAccount(ID accountId);
/**
* List of account groups
*/
List getAccountGroups();
/**
* Creation of an account group
*/
AccountGroup createGroup(NameDescription nameDescription);
/**
* Getting a group
*/
AccountGroup getAccountGroup(ID groupId);
/**
* Updating a group
*/
AccountGroup updateGroup(ID groupId, NameDescription input);
/**
* Deleting a group.
*/
Ack deleteGroup(ID groupId);
/**
* Returns the list of all account groups, together with the status for their selection
* in the given account ID. The account ID may not be {@link net.nemerosa.ontrack.model.structure.ID#isSet() set},
* meaning that none of the groups will be selected.
*
* @param accountId Account ID to get the groups for, or not {@link net.nemerosa.ontrack.model.structure.ID#isSet() set}
* @return List of groups with their selection status
*/
List getAccountGroupsForSelection(ID accountId);
/**
* Searches for a list of permission targets using the token
as a part in the
* name of the permission target.
*/
Collection searchPermissionTargets(String token);
/**
* Saves the permission for the {@link net.nemerosa.ontrack.model.security.PermissionTarget} defined
* by the type
and id
.
*/
Ack saveGlobalPermission(PermissionTargetType type, int id, PermissionInput input);
/**
* Gets the list of global permissions.
*/
Collection getGlobalPermissions();
/**
* Deletes a permission
*/
Ack deleteGlobalPermission(PermissionTargetType type, int id);
/**
* Gets the list of permissions for a project.
*
* @param projectId ID of the project
*/
Collection getProjectPermissions(ID projectId);
/**
* Saves the project permission for the {@link net.nemerosa.ontrack.model.security.PermissionTarget} defined
* by the type
and id
.
*/
Ack saveProjectPermission(ID projectId, PermissionTargetType type, int id, PermissionInput input);
/**
* Deletes a project permission.
*/
Ack deleteProjectPermission(ID projectId, PermissionTargetType type, int id);
/**
* Gets the list of project permissions for a given account
*
* @param account Account to get the permissions for
* @return List of project roles
*/
Collection getProjectPermissionsForAccount(Account account);
/**
* Gets the optional global role for an account
*
* @param account Account
* @return Optional role
*/
Optional getGlobalRoleForAccount(Account account);
/**
* Gets the list of accounts associated with this account group.
*
* @param accountGroup Account group
* @return List of accounts
*/
List getAccountsForGroup(AccountGroup accountGroup);
/**
* Gets the optional global role for an account group.
*
* @param group Account group
* @return Optional role
*/
Optional getGlobalRoleForAccountGroup(AccountGroup group);
/**
* Gets the list of project permissions for a given account group
*
* @param group Account group to get the permissions for
* @return List of project roles
*/
Collection getProjectPermissionsForAccountGroup(AccountGroup group);
/**
* List of groups having the given global role
*
* @param globalRole Global role to search for
* @return List of matching account groups
*/
Collection findAccountGroupsByGlobalRole(GlobalRole globalRole);
/**
* List of accounts having the given global role
*
* @param globalRole Global role to search for
* @return List of matching accounts
*/
Collection findAccountsByGlobalRole(GlobalRole globalRole);
/**
* List of groups having the given project role
*
* @param project Project
* @param projectRole Role to search for
* @return List of matching account groups
*/
Collection findAccountGroupsByProjectRole(Project project, ProjectRole projectRole);
/**
* List of accounts having the given project role
*
* @param project Project
* @param projectRole Role to search for
* @return List of matching accounts
*/
Collection findAccountsByProjectRole(Project project, ProjectRole projectRole);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy