package org.ovirt.engine.core.bll.profiles; import java.util.Collections; import java.util.List; import javax.inject.Inject; import org.ovirt.engine.core.bll.MultiLevelAdministrationHandler; import org.ovirt.engine.core.bll.PredefinedRoles; import org.ovirt.engine.core.bll.context.CommandContext; import org.ovirt.engine.core.bll.utils.PermissionSubject; import org.ovirt.engine.core.common.AuditLogType; import org.ovirt.engine.core.common.VdcObjectType; import org.ovirt.engine.core.common.action.DiskProfileParameters; import org.ovirt.engine.core.common.businessentities.Permission; import org.ovirt.engine.core.common.businessentities.profiles.DiskProfile; import org.ovirt.engine.core.common.errors.EngineMessage; import org.ovirt.engine.core.dao.profiles.DiskProfileDao; import org.ovirt.engine.core.dao.profiles.ProfilesDao; public class AddDiskProfileCommand extends AddProfileCommandBase<DiskProfileParameters, DiskProfile, DiskProfileValidator> { @Inject private DiskProfileDao diskProfileDao; public AddDiskProfileCommand(DiskProfileParameters parameters, CommandContext cmdContext) { super(parameters, cmdContext); } @Override protected DiskProfileValidator getProfileValidator() { return new DiskProfileValidator(getProfile()); } @Override protected ProfilesDao<DiskProfile> getProfileDao() { return diskProfileDao; } @Override public List<PermissionSubject> getPermissionCheckSubjects() { return Collections.singletonList(new PermissionSubject(getParameters().getProfile() != null ? getParameters().getProfile() .getStorageDomainId() : null, VdcObjectType.Storage, getActionType().getActionGroup())); } @Override protected void setActionMessageParameters() { super.setActionMessageParameters(); addValidationMessage(EngineMessage.VAR__TYPE__DISK_PROFILE); } @Override public AuditLogType getAuditLogTypeValue() { return getSucceeded() ? AuditLogType.USER_ADDED_DISK_PROFILE : AuditLogType.USER_FAILED_TO_ADD_DISK_PROFILE; } @Override protected void addPermissions() { MultiLevelAdministrationHandler.addPermission(new Permission(MultiLevelAdministrationHandler.EVERYONE_OBJECT_ID, PredefinedRoles.DISK_PROFILE_USER.getId(), getProfileId(), VdcObjectType.DiskProfile)); } }