PathogenSymptomMapServiceImpl.java

/*
 * Copyright 2026 Global Crop Diversity Trust
 * Licensed under the Apache License, Version 2.0
 * See LICENSE file in project root folder or http://www.apache.org/licenses/LICENSE-2.0
 */

package org.gringlobal.service.impl;

import javax.validation.Valid;
import javax.validation.constraints.NotNull;

import org.gringlobal.model.community.PathogenSymptomMap;
import org.gringlobal.persistence.community.PathogenSymptomMapRepository;
import org.gringlobal.service.PathogenSymptomMapService;

import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.validation.annotation.Validated;

@Service
@Validated
public class PathogenSymptomMapServiceImpl extends CRUDService2Impl<PathogenSymptomMap, PathogenSymptomMapRepository> implements PathogenSymptomMapService {

	@Override
	@Transactional
	@PreAuthorize("hasAuthority('GROUP_ADMINS') or @ggceSec.actionAllowed('Pathogen', 'WRITE')")
	public PathogenSymptomMap create(PathogenSymptomMap source) {
		PathogenSymptomMap saved = new PathogenSymptomMap();
		saved.apply(source);
		return repository.save(saved);
	}

	@Override
	@PreAuthorize("hasAuthority('GROUP_ADMINS') or @ggceSec.actionAllowed('Pathogen', 'WRITE')")
	public PathogenSymptomMap createFast(PathogenSymptomMap source) {
		return super.createFast(source);
	}

	@Override
	@Transactional
	@PreAuthorize("hasAuthority('GROUP_ADMINS') or @ggceSec.actionAllowed('Pathogen', 'WRITE')")
	public PathogenSymptomMap update(PathogenSymptomMap input, PathogenSymptomMap target) {
		target.apply(input);
		return _lazyLoad(repository.save(target));
	}

	@Override
	@Transactional
	@PreAuthorize("hasAuthority('GROUP_ADMINS') or @ggceSec.actionAllowed('Pathogen', 'WRITE')")
	public PathogenSymptomMap updateFast(@NotNull @Valid PathogenSymptomMap updated, PathogenSymptomMap target) {
		target.apply(updated);
		return repository.save(target);
	}

	@Override
	@Transactional
	@PreAuthorize("hasAuthority('GROUP_ADMINS') or @ggceSec.actionAllowed('Pathogen', 'WRITE')")
	public PathogenSymptomMap remove(PathogenSymptomMap entity) {
		return super.remove(entity);
	}

}