package com.dacrt.SBIABackend.security.controler;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.dao.DataAccessException;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.dacrt.SBIABackend.dto.Mensaje;
//import com.dacrt.SBIABackend.security.dto.DetalleUsuarioRequestDto;
//import com.dacrt.SBIABackend.security.dto.DetalleUsuarioResponseDto;
import com.dacrt.SBIABackend.security.dto.ParametrosSeguridadDto;
import com.dacrt.SBIABackend.security.service.ParametrosSeguridadService;

@RestController
@RequestMapping("/parametrosseguridad")
//@CrossOrigin(origins = "http://vpskromasys2.hostnetcom.com:8081")
//@CrossOrigin(origins = "http://vpskromasys2.hostnetcom.com:8083")
@CrossOrigin(origins = "*")
public class ParametrosSeguridadController {
	
	@Autowired
	ParametrosSeguridadService parametrosSeguridadService;
	
	Logger logger = LoggerFactory.getLogger(ParametrosSeguridadController.class);
	
	java.util.Date fechaActual = new java.util.Date();

	@GetMapping("/detail")
	public ResponseEntity<ParametrosSeguridadDto> getParametrosSeguridad() {

		ParametrosSeguridadDto parametrosSeguridadDto = parametrosSeguridadService.getParametrosSeguridad();
		return new ResponseEntity<>(parametrosSeguridadDto, HttpStatus.OK);
	}
	
	@PreAuthorize("hasRole('ROLE_ADMIN')")
	@PutMapping("/update")
	public ResponseEntity<ParametrosSeguridadDto> editParametrosSeguridad(
			@RequestBody final ParametrosSeguridadDto parametrosSeguridadDto) {
		try {

			parametrosSeguridadService.editParametrosSeguridad(parametrosSeguridadDto);

			ParametrosSeguridadDto detalleUsuario = parametrosSeguridadService.getParametrosSeguridad();

			return new ResponseEntity<>(detalleUsuario, HttpStatus.OK);
		} catch (DataAccessException ex) {
			logger.error(ex.getMessage());
			return new ResponseEntity(new Mensaje(ex.getMessage()), HttpStatus.METHOD_NOT_ALLOWED);
		}
	}	
}
