package com.product.mobile.core.controller;
import javax.servlet.http.HttpServletRequest;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import com.product.core.config.CoreConst;
import com.product.core.controller.support.AbstractBaseController;
import com.product.core.entity.FieldSetEntity;
import com.product.core.entity.RequestParameterEntity;
import com.product.core.log.SystemLogger;
import com.product.core.spring.context.SpringMVCContextHolder;
import com.product.mobile.core.config.MobileCoreCode;
import com.product.module.sys.version.ApiVersion;
/**
* APP鏃ュ織璁板綍锛屽瓨鍌ㄥ埌鏃ュ織琛ㄤ腑锛屾垨鎵撳嵃鍒板悗鍙般€�
*
* @author shicf
*/
@RequestMapping("/api/mobile")
@RestController
public class MobileLoggerController extends AbstractBaseController {
/**
* @param request
* @return
*/
@RequestMapping(value = "/system/log/{version}", method = RequestMethod.POST)
@ApiVersion(1)
public String writeLog(HttpServletRequest request) {
FieldSetEntity fse = null;
Object bean = request.getAttribute(CoreConst.API_POST_REQUEST_DATA);
RequestParameterEntity reqp=null;
if (bean != null) {
reqp = (RequestParameterEntity) bean;
fse = reqp.getFormData();
}
if (bean == null || fse == null) {
SpringMVCContextHolder.getSystemLogger().error(MobileCoreCode.SYSTEM_FORM_NODATA.getValue(),
MobileCoreCode.SYSTEM_FORM_NODATA.getText());
return this.error(MobileCoreCode.SYSTEM_FORM_NODATA.getValue(),
MobileCoreCode.SYSTEM_FORM_NODATA.getText());
}
if(fse.getString("log_type")==null || SystemLogger.LOG_TYPES_INFO.equals(fse.getString("log_type"))) {//鏅€氭棩蹇�
if(fse.getBoolean("isSave")) {
SpringMVCContextHolder.getSystemLogger().writeLog(fse.getString(CoreConst.CLIENT_TYPE)+"----- "+fse.getString("content"), reqp);
}else {
SpringMVCContextHolder.getSystemLogger().info(fse.getString(CoreConst.CLIENT_TYPE)+"------ "+fse.getString("content"));
}
}else if( SystemLogger.LOG_TYPES_ERROR.equals(fse.getString("log_type"))) {
if(fse.getBoolean("isSave")) {
SpringMVCContextHolder.getSystemLogger().writeLog(fse.getString(CoreConst.CLIENT_TYPE)+"------ "+fse.getString("content"), reqp);
}else {
SpringMVCContextHolder.getSystemLogger().error(fse.getString(CoreConst.CLIENT_TYPE)+"----- "+fse.getString("content"));
}
}
return this.OK();
}
}