package com.jeesite.modules.util;
import BP.Tools.DateUtils;
import com.jeesite.modules.entityk.JdbcTemplate;
import com.jeesite.modules.sys.utils.CompanyUtils;
import com.jeesite.modules.sys.utils.EmpUtils;
import com.jeesite.modules.sys.utils.UserUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Component;
import java.net.InetAddress;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
/**
* @description:
* @author: yangkai
* @date: 2019/12/26
*/
@Component
public class LogUtils {
/**
* saveLog 方法
* 说明:日志保存
* 创建人:yangkai
* @param archtypeid:档案id
* @param archlevel:档案类型(文件,案卷,项目,盒)
* @param op:日志说明
* @param id:详情id(文件id,案卷id,项目id,盒id)
* @return void
* @throws
*/
public static void saveLog(String archtypeid,String archlevel,String op,String id)throws Exception{
String queryName="";
if("文件".equals(archlevel)){
queryName="doctableid";
}else if("案卷".equals(archlevel)){
queryName="voltableid";
}else if("项目".equals(archlevel)){
queryName="projtableid";
}else if("盒".equals(archlevel)){
queryName="boxtableid";
}else {
}
Map<String,Object> s_archive_type= JdbcTemplate.getJdbcTemplate("edoc").queryForMap("SELECT name,"+queryName+" FROM s_archive_type WHERE id="+archtypeid);
String archtypename=String.valueOf(s_archive_type.get("name"));
String tableid=String.valueOf(s_archive_type.get(queryName));
Map<String,Object> temp= JdbcTemplate.getJdbcTemplate("edoc").queryForMap("SELECT status,archcode,title,security FROM "+tableid+" WHERE id="+id);
List<String> values=new ArrayList<>();
values.add(CompanyUtils.getCurrentFond().getId());
values.add(IDUtil.getID());
values.add(InetAddress.getLocalHost().getHostAddress());
values.add(UserUtils.getUser().getUserCode());
values.add(UserUtils.getUser().getUserName());
values.add(EmpUtils.getOffice().getOfficeCode());
values.add(EmpUtils.getOffice().getOfficeName());
values.add(id);
values.add(tableid);
values.add(temp.get("status").toString());
values.add(archtypeid);
values.add(archtypename);
values.add(archlevel);
values.add(temp.get("archcode").toString());
values.add(temp.get("title").toString());
values.add(temp.get("security").toString());
values.add(op);
values.add(DateUtils.getCurrentDate());
values.add(UserUtils.getUser().getUserCode());
values.add("null");
values.add("null");
/**/
String[] strings=StringUtils.split(Thread.currentThread().getStackTrace()[2].getClassName(),".");
int num=strings.length;
/**/
values.add(strings[num-1]);
values.add(Thread.currentThread().getStackTrace()[2].getMethodName());
values.add("null");
values.add(CompanyUtils.getCurrentFond().getId());
for (int i = 0; i < values.size(); i++) {
if("null".equals(values.get(i))){
} else if(!StringUtils.isNumeric(values.get(i))){//判断参数是否是纯数字
values.set(i,"'"+values.get(i)+"'");
} else {
}
}
System.out.println("INSERT INTO log_archive (fondsid,id,ip,userid,username,deptid,deptname,archid,tableid,status,archtypeid,archtypename,archlevel,archcode,archtitle,secret,op,optime,oper,special,opcount,controller,action,type,comid) " +
"VALUES ("+ StringUtils.join(values,",") +")");
JdbcTemplate.getJdbcTemplate("edoc").execute("INSERT INTO log_archive (fondsid,id,ip,userid,username,deptid,deptname,archid,tableid,status,archtypeid,archtypename,archlevel,archcode,archtitle,secret,op,optime,oper,special,opcount,controller,action,type,comid) " +
"VALUES ("+ StringUtils.join(values,",") +")");
}
}