package com.taiwanlife.teamwalk.api.aop.aspectj;
import com.taiwanlife.teamwalk.api.util.ApiLogUtils;
import com.taiwanlife.teamwalk.common.entity.member.MbrMemberAccessLog;
import com.taiwanlife.teamwalk.common.entity.system.SysApiLog;
import com.taiwanlife.teamwalk.common.repository.member.MemberAccessLogRepository;
import com.taiwanlife.teamwalk.common.repository.member.MemberRepository;
import com.taiwanlife.teamwalk.common.repository.system.ApiLogRepository;
import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.security.core.Authentication;
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.stereotype.Component;
import org.springframework.stereotype.Service;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import jakarta.annotation.Resource;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import jakarta.transaction.Transactional;
import java.io.BufferedReader;
import java.time.LocalDateTime;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
@Slf4j
@Aspect
@Component
public class ApiLogAspectj {
@Value("${spring.profiles.active}")
private String hostIP;
@Resource
private ApiLogRepository apiLogRepository;
@Resource
private MemberAccessLogRepository memberAccessLogRepository;
@Resource
MemberRepository memberRepository;
@Before("execution(* com.taiwanlife.teamwalk.api.controller.rest..*.*(..)) && " +
"!execution(* com.taiwanlife.teamwalk.api.controller.rest.system.ImageController.*(..))")
@Modifying
@Transactional
public void doBefore(JoinPoint joinPoint) throws Throwable {
if (log.isDebugEnabled()) {
log.debug("[START] doBefore() ...");
}
Authentication authentication = SecurityContextHolder.getContext().getAuthentication();
if (authentication != null && authentication.isAuthenticated()) {
String username = authentication.getName();
HttpServletRequest request = ((ServletRequestAttributes) (RequestContextHolder.currentRequestAttributes())).getRequest();
String url = request.getRequestURL().toString();
String method = request.getMethod();
Map<String, String[]> parameters = request.getParameterMap();
StringBuilder reqContent = new StringBuilder();
int keyIdx = 0;
Iterator iterator = parameters.entrySet().iterator();
String[] vals;
while(iterator.hasNext( )) {
Map.Entry entry = (Map.Entry) iterator.next();
if (keyIdx != 0) {
reqContent.append("; ");
} else {
reqContent.append("Params: {");
}
reqContent.append((String) entry.getKey()).append(": ");
vals = (String[]) entry.getValue();
int idx = 0;
for (String val : vals) {
if (idx != 0) {
reqContent.append(", ");
}
reqContent.append(val);
idx++;
}
if (keyIdx == parameters.keySet().size() - 1) {
reqContent.append("}");
}
keyIdx++;
}
if (reqContent.toString().equals("")) {
BufferedReader br = request.getReader();
String str;
boolean isFirstLine = true;
while ((str = br.readLine()) != null) {
if (!str.trim().equals("")) {
if (isFirstLine) {
reqContent.append("Body: ");
isFirstLine = false;
}
reqContent.append(str.trim());
}
}
}
if (reqContent.toString().equals("")) {
reqContent.append("** NONE **");
}
SysApiLog sysApiLog = new SysApiLog();
sysApiLog.setLogAt(LocalDateTime.now());
sysApiLog.setUrl(url);
sysApiLog.setHttpMethod(method);
sysApiLog.setHttpCode(""); // 先預設空白
sysApiLog.setFromIp(request.getRemoteAddr());
sysApiLog.setUsername(username);
sysApiLog.setClientDevice(request.getHeader("User-Agent"));
sysApiLog.setRequest(reqContent.toString());
sysApiLog.setResponse(""); // 先預設空白
/*
if (log.isDebugEnabled()) {
log.debug("Call apiLogRepository.save()...");
}
apiLogRepository.save(sysApiLog);
*/
log.debug(new StringBuffer().append("[API REQ] | ")
.append(LocalDateTime.now()).append(" | ") // log_at
.append("").append(" | ") // log_at_resp
.append(url).append(" | ") // url
.append(method).append(" | ") // http_method
.append("").append(" | ") // http_code
.append(request.getRemoteAddr()).append(" | ") // from ip
.append(username).append(" | ") // username
.append(request.getHeader("User-Agent")).append(" | ") // client device
.append(reqContent.toString()).append(" | ") // request
.append("") // response
.toString()
);
if (log.isDebugEnabled()) {
log.debug("Call ApiLogUtils.setApiLog()...");
}
ApiLogUtils.setApiLog(sysApiLog);
MbrMemberAccessLog accessLog = new MbrMemberAccessLog();
accessLog.setLogAt(LocalDateTime.now());
accessLog.setUrl(url);
accessLog.setHttpMethod(method);
accessLog.setFromIp(request.getRemoteAddr());
accessLog.setUsername(username);
accessLog.setRequest(reqContent.toString());
accessLog.setEnv(hostIP);
accessLog.setHostIp(request.getServerName());
accessLog.setThreadId(Long.valueOf(Thread.currentThread().getId()).intValue());
if (log.isDebugEnabled()) {
log.debug("Call memberAccessLogRepository.save()...");
}
memberAccessLogRepository.save(accessLog);
}
if (log.isDebugEnabled()) {
log.debug("[END] doBefore().");
}
}
@AfterReturning(
pointcut = "execution(* com.taiwanlife.teamwalk.api.controller.rest..*.*(..)) && " +
"!execution(* com.taiwanlife.teamwalk.api.controller.rest.system.ImageController.*(..))",
returning = "rtv")
@Modifying
@Transactional
public void doAfter(JoinPoint point, Object rtv) {
if (log.isDebugEnabled()) {
log.debug("[START] doAfter() ...");
log.debug("Call ApiLogUtils.getApiLog()...");
}
SysApiLog sysApiLogForReq = ApiLogUtils.getApiLog();
HttpServletResponse response = ((ServletRequestAttributes) RequestContextHolder.currentRequestAttributes())
.getResponse();
if (sysApiLogForReq != null) {
/*
SysApiLog sysApiLog = new SysApiLog();
// 從舊物件抄寫過來
sysApiLog.setLogAt(sysApiLogForReq.getLogAt());
sysApiLog.setUrl(sysApiLogForReq.getUrl());
sysApiLog.setHttpMethod(sysApiLogForReq.getHttpMethod());
sysApiLog.setFromIp(sysApiLogForReq.getFromIp());
sysApiLog.setUsername(sysApiLogForReq.getUsername());
sysApiLog.setClientDevice(sysApiLogForReq.getClientDevice());
sysApiLog.setRequest(sysApiLogForReq.getRequest());
sysApiLog.setHttpCode(Integer.toString(response.getStatus()));
int startIdx = rtv.toString().indexOf(",") + 1;
int endIdx = rtv.toString().lastIndexOf(",");
if (startIdx > 0) {
if (endIdx > startIdx) {
sysApiLog.setResponse(rtv.toString().substring(rtv.toString().indexOf(",") + 1, rtv.toString().lastIndexOf(",")));
} else {
sysApiLog.setResponse(rtv.toString().substring(rtv.toString().indexOf(",") + 1));
}
}
sysApiLog.setLogAtResp(LocalDateTime.now());
if (log.isDebugEnabled()) {
log.debug("Call apiLogRepository.save()...");
}
apiLogRepository.save(sysApiLog);
*/
int startIdx = rtv.toString().indexOf(",") + 1;
int endIdx = rtv.toString().lastIndexOf(",");
String resp = null;
if (startIdx > 0) {
if (endIdx > startIdx) {
resp = rtv.toString().substring(rtv.toString().indexOf(",") + 1, rtv.toString().lastIndexOf(","));
} else {
resp = rtv.toString().substring(rtv.toString().indexOf(",") + 1);
}
}
log.debug(new StringBuffer().append("[API RESP] | ")
.append(sysApiLogForReq.getLogAt()).append(" | ") // log_at
.append(LocalDateTime.now()).append(" | ") // log_at_resp
.append(sysApiLogForReq.getUrl()).append(" | ") // url
.append(sysApiLogForReq.getHttpMethod()).append(" | ") // http_method
.append(response.getStatus()).append(" | ") // http_code
.append(sysApiLogForReq.getFromIp()).append(" | ") // from ip
.append(sysApiLogForReq.getUsername()).append(" | ") // username
.append(sysApiLogForReq.getClientDevice()).append(" | ")// client device
.append(sysApiLogForReq.getRequest()).append(" | ") // request
.append(resp) // response
.toString()
);
}
if (log.isDebugEnabled()) {
log.debug("Call ApiLogUtils.removeApiLog()...");
}
ApiLogUtils.removeApiLog();
if (log.isDebugEnabled()) {
log.debug("[END] doAfter().");
}
}
}
package com.taiwanlife.teamwalk.api.aop.aspectj;



import com.taiwanlife.teamwalk.api.util.ApiLogUtils;

import com.taiwanlife.teamwalk.common.entity.member.MbrMemberAccessLog;

import com.taiwanlife.teamwalk.common.entity.system.SysApiLog;

import com.taiwanlife.teamwalk.common.repository.member.MemberAccessLogRepository;

import com.taiwanlife.teamwalk.common.repository.member.MemberRepository;

import com.taiwanlife.teamwalk.common.repository.system.ApiLogRepository;

import lombok.extern.slf4j.Slf4j;

import org.aspectj.lang.JoinPoint;

import org.aspectj.lang.annotation.AfterReturning;

import org.aspectj.lang.annotation.Aspect;

import org.aspectj.lang.annotation.Before;

import org.springframework.beans.factory.annotation.Value;

import org.springframework.data.jpa.repository.Modifying;

import org.springframework.security.core.Authentication;

import org.springframework.security.core.context.SecurityContextHolder;

import org.springframework.stereotype.Component;

import org.springframework.stereotype.Service;

import org.springframework.web.context.request.RequestContextHolder;

import org.springframework.web.context.request.ServletRequestAttributes;



import jakarta.annotation.Resource;

import jakarta.servlet.http.HttpServletRequest;

import jakarta.servlet.http.HttpServletResponse;

import jakarta.transaction.Transactional;

import java.io.BufferedReader;

import java.time.LocalDateTime;

import java.util.Iterator;

import java.util.Map;

import java.util.Set;



@Slf4j

@Aspect

@Component

public class ApiLogAspectj {

    @Value("${spring.profiles.active}")

    private String hostIP;



    @Resource

    private ApiLogRepository apiLogRepository;



    @Resource

    private MemberAccessLogRepository memberAccessLogRepository;



    @Resource

    MemberRepository memberRepository;





    @Before("execution(* com.taiwanlife.teamwalk.api.controller.rest..*.*(..)) && " +

            "!execution(* com.taiwanlife.teamwalk.api.controller.rest.system.ImageController.*(..))")

    @Modifying

    @Transactional

    public void doBefore(JoinPoint joinPoint) throws Throwable {

        if (log.isDebugEnabled()) {

            log.debug("[START] doBefore() ...");

        }



        Authentication authentication = SecurityContextHolder.getContext().getAuthentication();

        if (authentication != null && authentication.isAuthenticated()) {

            String username = authentication.getName();



            HttpServletRequest request = ((ServletRequestAttributes) (RequestContextHolder.currentRequestAttributes())).getRequest();



            String url = request.getRequestURL().toString();

            String method = request.getMethod();



            Map<String, String[]> parameters = request.getParameterMap();



            StringBuilder reqContent = new StringBuilder();

            int keyIdx = 0;



            Iterator iterator = parameters.entrySet().iterator();

            String[] vals;

            while(iterator.hasNext( )) {

                Map.Entry entry = (Map.Entry) iterator.next();



                if (keyIdx != 0) {

                    reqContent.append("; ");

                } else {

                    reqContent.append("Params: {");

                }



                reqContent.append((String) entry.getKey()).append(": ");



                vals = (String[]) entry.getValue();



                int idx = 0;

                for (String val : vals) {

                    if (idx != 0) {

                        reqContent.append(", ");

                    }



                    reqContent.append(val);



                    idx++;

                }



                if (keyIdx == parameters.keySet().size() - 1) {

                    reqContent.append("}");

                }



                keyIdx++;

            }



            if (reqContent.toString().equals("")) {

                BufferedReader br = request.getReader();



                String str;

                boolean isFirstLine = true;

                while ((str = br.readLine()) != null) {

                    if (!str.trim().equals("")) {

                        if (isFirstLine) {

                            reqContent.append("Body: ");



                            isFirstLine = false;

                        }



                        reqContent.append(str.trim());

                    }

                }

            }



            if (reqContent.toString().equals("")) {

                reqContent.append("** NONE **");

            }





            SysApiLog sysApiLog = new SysApiLog();



            sysApiLog.setLogAt(LocalDateTime.now());

            sysApiLog.setUrl(url);

            sysApiLog.setHttpMethod(method);

            sysApiLog.setHttpCode("");  // 先預設空白

            sysApiLog.setFromIp(request.getRemoteAddr());

            sysApiLog.setUsername(username);

            sysApiLog.setClientDevice(request.getHeader("User-Agent"));

            sysApiLog.setRequest(reqContent.toString());

            sysApiLog.setResponse("");  // 先預設空白



            /*

            if (log.isDebugEnabled()) {

                log.debug("Call apiLogRepository.save()...");

            }



            apiLogRepository.save(sysApiLog);

            */



            log.debug(new StringBuffer().append("[API REQ] | ")

                    .append(LocalDateTime.now()).append(" | ")     // log_at

                    .append("").append(" | ")                      // log_at_resp

                    .append(url).append(" | ")                     // url

                    .append(method).append(" | ")                  // http_method

                    .append("").append(" | ")                      // http_code

                    .append(request.getRemoteAddr()).append(" | ") // from ip

                    .append(username).append(" | ")                // username

                    .append(request.getHeader("User-Agent")).append(" | ")  // client device

                    .append(reqContent.toString()).append(" | ")   // request

                    .append("")                                    // response

                    .toString()

            );



            if (log.isDebugEnabled()) {

                log.debug("Call ApiLogUtils.setApiLog()...");

            }



            ApiLogUtils.setApiLog(sysApiLog);



            MbrMemberAccessLog accessLog = new MbrMemberAccessLog();



            accessLog.setLogAt(LocalDateTime.now());

            accessLog.setUrl(url);

            accessLog.setHttpMethod(method);

            accessLog.setFromIp(request.getRemoteAddr());

            accessLog.setUsername(username);

            accessLog.setRequest(reqContent.toString());

            accessLog.setEnv(hostIP);

            accessLog.setHostIp(request.getServerName());

            accessLog.setThreadId(Long.valueOf(Thread.currentThread().getId()).intValue());



            if (log.isDebugEnabled()) {

                log.debug("Call memberAccessLogRepository.save()...");

            }



            memberAccessLogRepository.save(accessLog);

        }



        if (log.isDebugEnabled()) {

            log.debug("[END] doBefore().");

        }

    }



    @AfterReturning(

            pointcut = "execution(* com.taiwanlife.teamwalk.api.controller.rest..*.*(..)) && " +

                       "!execution(* com.taiwanlife.teamwalk.api.controller.rest.system.ImageController.*(..))",

            returning = "rtv")

    @Modifying

    @Transactional

    public void doAfter(JoinPoint point, Object rtv) {

        if (log.isDebugEnabled()) {

            log.debug("[START] doAfter() ...");

            log.debug("Call ApiLogUtils.getApiLog()...");

        }



        SysApiLog sysApiLogForReq = ApiLogUtils.getApiLog();



        HttpServletResponse response = ((ServletRequestAttributes) RequestContextHolder.currentRequestAttributes())

                .getResponse();



        if (sysApiLogForReq != null) {

            /*

            SysApiLog sysApiLog = new SysApiLog();



            // 從舊物件抄寫過來

            sysApiLog.setLogAt(sysApiLogForReq.getLogAt());

            sysApiLog.setUrl(sysApiLogForReq.getUrl());

            sysApiLog.setHttpMethod(sysApiLogForReq.getHttpMethod());

            sysApiLog.setFromIp(sysApiLogForReq.getFromIp());

            sysApiLog.setUsername(sysApiLogForReq.getUsername());

            sysApiLog.setClientDevice(sysApiLogForReq.getClientDevice());

            sysApiLog.setRequest(sysApiLogForReq.getRequest());



            sysApiLog.setHttpCode(Integer.toString(response.getStatus()));



            int startIdx = rtv.toString().indexOf(",") + 1;

            int endIdx = rtv.toString().lastIndexOf(",");



            if (startIdx > 0) {

                if (endIdx > startIdx) {

                    sysApiLog.setResponse(rtv.toString().substring(rtv.toString().indexOf(",") + 1, rtv.toString().lastIndexOf(",")));

                } else {

                    sysApiLog.setResponse(rtv.toString().substring(rtv.toString().indexOf(",") + 1));

                }

            }



            sysApiLog.setLogAtResp(LocalDateTime.now());



            if (log.isDebugEnabled()) {

                log.debug("Call apiLogRepository.save()...");

            }



            apiLogRepository.save(sysApiLog);

            */



            int startIdx = rtv.toString().indexOf(",") + 1;

            int endIdx = rtv.toString().lastIndexOf(",");



            String resp = null;

            if (startIdx > 0) {

                if (endIdx > startIdx) {

                    resp = rtv.toString().substring(rtv.toString().indexOf(",") + 1, rtv.toString().lastIndexOf(","));

                } else {

                    resp = rtv.toString().substring(rtv.toString().indexOf(",") + 1);

                }

            }



            log.debug(new StringBuffer().append("[API RESP] | ")

                    .append(sysApiLogForReq.getLogAt()).append(" | ")       // log_at

                    .append(LocalDateTime.now()).append(" | ")              // log_at_resp

                    .append(sysApiLogForReq.getUrl()).append(" | ")         // url

                    .append(sysApiLogForReq.getHttpMethod()).append(" | ")  // http_method

                    .append(response.getStatus()).append(" | ")             // http_code

                    .append(sysApiLogForReq.getFromIp()).append(" | ")      // from ip

                    .append(sysApiLogForReq.getUsername()).append(" | ")    // username

                    .append(sysApiLogForReq.getClientDevice()).append(" | ")// client device

                    .append(sysApiLogForReq.getRequest()).append(" | ")     // request

                    .append(resp)                                           // response

                    .toString()

            );

        }



        if (log.isDebugEnabled()) {

            log.debug("Call ApiLogUtils.removeApiLog()...");

        }



        ApiLogUtils.removeApiLog();



        if (log.isDebugEnabled()) {

            log.debug("[END] doAfter().");

        }

    }

}
