com.mizhousoft.bmc.profile.controller.IdleTimeoutController Maven / Gradle / Ivy
package com.mizhousoft.bmc.profile.controller;
import org.apache.shiro.SecurityUtils;
import org.apache.shiro.session.Session;
import org.apache.shiro.subject.Subject;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import com.mizhousoft.bmc.BMCException;
import com.mizhousoft.bmc.auditlog.constants.AuditLogResult;
import com.mizhousoft.bmc.auditlog.controller.BaseAuditController;
import com.mizhousoft.bmc.auditlog.domain.OperationLog;
import com.mizhousoft.bmc.auditlog.util.AuditLogUtils;
import com.mizhousoft.bmc.profile.request.IdleTimeoutRequest;
import com.mizhousoft.bmc.system.domain.IdleTimeout;
import com.mizhousoft.bmc.system.service.IdleTimeoutService;
import com.mizhousoft.boot.authentication.context.SecurityContext;
import com.mizhousoft.boot.authentication.context.SecurityContextHolder;
import com.mizhousoft.commons.web.ActionRespBuilder;
import com.mizhousoft.commons.web.ActionResponse;
import com.mizhousoft.commons.web.AssertionException;
import com.mizhousoft.commons.web.i18n.util.I18nUtils;
import jakarta.servlet.http.HttpServletRequest;
/**
* 修改闲置超时时间控制器
*
* @version
*/
@RestController
public class IdleTimeoutController extends BaseAuditController
{
private static final Logger LOG = LoggerFactory.getLogger(IdleTimeoutController.class);
@Autowired
private IdleTimeoutService idleTimeoutService;
@RequestMapping(value = "/setting/idletimeout/fetchIdletimeout.action", method = RequestMethod.GET)
public ModelMap fetch()
{
ModelMap map = new ModelMap();
SecurityContext securityContext = SecurityContextHolder.getContext();
long accountId = securityContext.getAuthentication().getAccountId();
IdleTimeout idleTimeout = idleTimeoutService.queryIdleTimeout(accountId);
map.put("idleTimeout", idleTimeout);
return map;
}
@RequestMapping(value = "/setting/idletimeout/modifyIdletimeout.action", method = RequestMethod.POST)
public ActionResponse modify(@RequestBody IdleTimeoutRequest idleTimeoutRequest, HttpServletRequest request)
{
ActionResponse response = null;
OperationLog operLog = null;
try
{
idleTimeoutRequest.validate();
SecurityContext securityContext = SecurityContextHolder.getContext();
long accountId = securityContext.getAuthentication().getAccountId();
IdleTimeout idleTimeout = new IdleTimeout();
idleTimeout.setAccountId(accountId);
idleTimeout.setTimeout(idleTimeoutRequest.getTimeout());
idleTimeoutService.modifyIdleTimeout(accountId, idleTimeout);
Subject subject = SecurityUtils.getSubject();
Session currentSessison = subject.getSession();
long maxIdleTimeInMillis = idleTimeoutRequest.getTimeout() * 60 * 1000;
currentSessison.setTimeout(maxIdleTimeInMillis);
request.getSession().setMaxInactiveInterval(idleTimeoutRequest.getTimeout() * 60);
response = ActionRespBuilder.buildSucceedResp();
operLog = buildOperLog(AuditLogResult.Success, idleTimeoutRequest.toString(), null);
}
catch (BMCException | AssertionException e)
{
LOG.error("Modify account idle timeout failed.", e);
String error = I18nUtils.getMessage(e.getErrorCode(), e.getCodeParams());
response = ActionRespBuilder.buildFailedResp(error);
operLog = buildOperLog(AuditLogResult.Failure, e.getMessage(), idleTimeoutRequest.toString());
}
AuditLogUtils.addOperationLog(operLog);
return response;
}
/**
* {@inheritDoc}
*/
@Override
protected String getAuditOperation()
{
return "bmc.idletimeout.modify.operation";
}
/**
* {@inheritDoc}
*/
@Override
protected String getAuditSource()
{
return "bmc.idletimeout.source";
}
}