AppUserGuiSettingServiceImpl.java
/*
* Copyright 2026 Global Crop Diversity Trust
*
* 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 org.genesys.server.service.impl;
import org.genesys.blocks.security.SecurityContextUtil;
import org.genesys.server.model.impl.AppUserGuiSetting;
import org.genesys.server.model.impl.QAppUserGuiSetting;
import org.genesys.server.persistence.AppUserGuiSettingRepository;
import org.genesys.server.service.AppUserGuiSettingService;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.security.access.prepost.PostAuthorize;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.validation.annotation.Validated;
import javax.validation.constraints.NotNull;
import java.util.List;
@Transactional(readOnly = true)
@PreAuthorize("isAuthenticated()")
@Validated
@Service
public class AppUserGuiSettingServiceImpl extends CRUDService2Impl<AppUserGuiSetting, AppUserGuiSettingRepository> implements AppUserGuiSettingService {
@Override
@Transactional
public AppUserGuiSetting create(AppUserGuiSetting source) {
return createFast(source);
}
@Override
@Transactional
public AppUserGuiSetting createFast(AppUserGuiSetting source) {
AppUserGuiSetting setting = new AppUserGuiSetting();
setting.apply(source);
return repository.save(setting);
}
@Override
@Transactional
@PreAuthorize("hasRole('ADMINISTRATOR') || principal.id == #target.createdBy")
public AppUserGuiSetting update(AppUserGuiSetting updated, AppUserGuiSetting target) {
return updateFast(updated, target);
}
@Override
@Transactional
@PreAuthorize("hasRole('ADMINISTRATOR') || principal.id == #target.createdBy")
public AppUserGuiSetting updateFast(AppUserGuiSetting updated, AppUserGuiSetting target) {
target.apply(updated);
return repository.save(target);
}
@Override
public AppUserGuiSetting getSetting(@NotNull String appName, String formName, @NotNull String resourceName, @NotNull String resourceKey) {
var me = SecurityContextUtil.getCurrentUser();
var qSetting = QAppUserGuiSetting.appUserGuiSetting;
var expression = qSetting.appName.eq(appName)
.and(qSetting.resourceName.eq(resourceName))
.and(qSetting.resourceKey.eq(resourceKey))
.and(qSetting.createdBy.eq(me.getId()))
.and(formName == null ? qSetting.formName.isNull() : qSetting.formName.eq(formName))
;
return repository.findOne(expression).orElse(null);
}
@Override
public List<AppUserGuiSetting> listForApp(@NotNull String appName) {
var me = SecurityContextUtil.getCurrentUser();
return (List<AppUserGuiSetting>) repository.findAll(
QAppUserGuiSetting.appUserGuiSetting.createdBy.eq(me.getId())
.and(QAppUserGuiSetting.appUserGuiSetting.appName.eq(appName)));
}
@Override
public Page<AppUserGuiSetting> list(Pageable page) {
var me = SecurityContextUtil.getCurrentUser();
return repository.findAll(QAppUserGuiSetting.appUserGuiSetting.createdBy.eq(me.getId()), page);
}
@Override
@PostAuthorize("hasRole('ADMINISTRATOR') || principal.id == returnObject.createdBy")
public AppUserGuiSetting get(long id) {
return super.get(id);
}
@Override
@Transactional
@PreAuthorize("hasRole('ADMINISTRATOR') || principal.id == #entity.createdBy")
public AppUserGuiSetting remove(AppUserGuiSetting entity) {
entity = repository.getReferenceById(entity.getId());
return super.remove(entity);
}
}