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);
	}
}