fix ivyz7c9d
fix external_logger
This commit is contained in:
		| @@ -22,19 +22,9 @@ func ProcessIVYZ7C9DRequest(ctx context.Context, params []byte, deps *processors | |||||||
| 		return nil, fmt.Errorf("%s: %w", processors.ErrInvalidParam, err) | 		return nil, fmt.Errorf("%s: %w", processors.ErrInvalidParam, err) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	encryptedName, err := deps.ZhichaService.Encrypt(paramsDto.Name) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return nil, fmt.Errorf("%s: %w", processors.ErrSystem, err) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	encryptedIDCard, err := deps.ZhichaService.Encrypt(paramsDto.IDCard) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return nil, fmt.Errorf("%s: %w", processors.ErrSystem, err) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	reqData := map[string]interface{}{ | 	reqData := map[string]interface{}{ | ||||||
| 		"name":      encryptedName, | 		"name":      paramsDto.Name, | ||||||
| 		"idCard":    encryptedIDCard, | 		"idCard":    paramsDto.IDCard, | ||||||
| 		"returnURL": paramsDto.ReturnURL, | 		"returnURL": paramsDto.ReturnURL, | ||||||
| 		"orderId":   paramsDto.UniqueID, | 		"orderId":   paramsDto.UniqueID, | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -71,19 +71,6 @@ func (w *WestDexService) generateRequestID() string { | |||||||
| 	return fmt.Sprintf("westdex_%x", hash[:8]) | 	return fmt.Sprintf("westdex_%x", hash[:8]) | ||||||
| } | } | ||||||
|  |  | ||||||
| // buildLogData 构建包含transactionId的日志数据 |  | ||||||
| func (w *WestDexService) buildLogData(data map[string]interface{}, transactionID string) map[string]interface{} { |  | ||||||
| 	if transactionID == "" { |  | ||||||
| 		return data |  | ||||||
| 	} |  | ||||||
| 	 |  | ||||||
| 	logData := data |  | ||||||
| 	if logData == nil { |  | ||||||
| 		logData = make(map[string]interface{}) |  | ||||||
| 	} |  | ||||||
| 	logData["transaction_id"] = transactionID |  | ||||||
| 	return logData |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // buildRequestURL 构建请求URL | // buildRequestURL 构建请求URL | ||||||
| func (w *WestDexService) buildRequestURL(code string) string { | func (w *WestDexService) buildRequestURL(code string) string { | ||||||
| @@ -95,7 +82,7 @@ func (w *WestDexService) buildRequestURL(code string) string { | |||||||
| func (w *WestDexService) CallAPI(ctx context.Context, code string, reqData map[string]interface{}) (resp []byte, err error) { | func (w *WestDexService) CallAPI(ctx context.Context, code string, reqData map[string]interface{}) (resp []byte, err error) { | ||||||
| 	startTime := time.Now() | 	startTime := time.Now() | ||||||
| 	requestID := w.generateRequestID() | 	requestID := w.generateRequestID() | ||||||
| 	 |  | ||||||
| 	// 从ctx中获取transactionId | 	// 从ctx中获取transactionId | ||||||
| 	var transactionID string | 	var transactionID string | ||||||
| 	if ctxTransactionID, ok := ctx.Value("transaction_id").(string); ok { | 	if ctxTransactionID, ok := ctx.Value("transaction_id").(string); ok { | ||||||
| @@ -107,14 +94,14 @@ func (w *WestDexService) CallAPI(ctx context.Context, code string, reqData map[s | |||||||
|  |  | ||||||
| 	// 记录请求日志 | 	// 记录请求日志 | ||||||
| 	if w.logger != nil { | 	if w.logger != nil { | ||||||
| 		w.logger.LogRequest(requestID, code, reqUrl, w.buildLogData(reqData, transactionID)) | 		w.logger.LogRequest(requestID, transactionID, code, reqUrl, reqData) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	jsonData, marshalErr := json.Marshal(reqData) | 	jsonData, marshalErr := json.Marshal(reqData) | ||||||
| 	if marshalErr != nil { | 	if marshalErr != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, marshalErr.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, marshalErr.Error()) | ||||||
| 		if w.logger != nil { | 		if w.logger != nil { | ||||||
| 			w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 			w.logger.LogError(requestID, transactionID, code, err, reqData) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -124,7 +111,7 @@ func (w *WestDexService) CallAPI(ctx context.Context, code string, reqData map[s | |||||||
| 	if newRequestErr != nil { | 	if newRequestErr != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, newRequestErr.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, newRequestErr.Error()) | ||||||
| 		if w.logger != nil { | 		if w.logger != nil { | ||||||
| 			w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 			w.logger.LogError(requestID, transactionID, code, err, reqData) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -138,7 +125,7 @@ func (w *WestDexService) CallAPI(ctx context.Context, code string, reqData map[s | |||||||
| 	if clientDoErr != nil { | 	if clientDoErr != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, clientDoErr.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, clientDoErr.Error()) | ||||||
| 		if w.logger != nil { | 		if w.logger != nil { | ||||||
| 			w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 			w.logger.LogError(requestID, transactionID, code, err, reqData) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -147,7 +134,7 @@ func (w *WestDexService) CallAPI(ctx context.Context, code string, reqData map[s | |||||||
| 		if closeErr != nil { | 		if closeErr != nil { | ||||||
| 			// 记录关闭错误 | 			// 记录关闭错误 | ||||||
| 			if w.logger != nil { | 			if w.logger != nil { | ||||||
| 				w.logger.LogError(requestID, code, fmt.Errorf("关闭响应体失败: %w", closeErr), w.buildLogData(reqData, transactionID)) | 				w.logger.LogError(requestID, transactionID, code, fmt.Errorf("关闭响应体失败: %w", closeErr), reqData) | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	}(httpResp.Body) | 	}(httpResp.Body) | ||||||
| @@ -162,32 +149,32 @@ func (w *WestDexService) CallAPI(ctx context.Context, code string, reqData map[s | |||||||
| 		if ReadErr != nil { | 		if ReadErr != nil { | ||||||
| 			err = fmt.Errorf("%w: %s", ErrSystem, ReadErr.Error()) | 			err = fmt.Errorf("%w: %s", ErrSystem, ReadErr.Error()) | ||||||
| 			if w.logger != nil { | 			if w.logger != nil { | ||||||
| 				w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 				w.logger.LogError(requestID, transactionID, code, err, reqData) | ||||||
| 			} | 			} | ||||||
| 			return nil, err | 			return nil, err | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		// 记录响应日志 |  | ||||||
| 		if w.logger != nil { |  | ||||||
| 			w.logger.LogResponse(requestID, code, httpResp.StatusCode, bodyBytes, duration) |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		// 手动调用 json.Unmarshal 触发自定义的 UnmarshalJSON 方法 | 		// 手动调用 json.Unmarshal 触发自定义的 UnmarshalJSON 方法 | ||||||
| 		var westDexResp WestResp | 		var westDexResp WestResp | ||||||
| 		UnmarshalErr := json.Unmarshal(bodyBytes, &westDexResp) | 		UnmarshalErr := json.Unmarshal(bodyBytes, &westDexResp) | ||||||
| 		if UnmarshalErr != nil { | 		if UnmarshalErr != nil { | ||||||
| 			err = UnmarshalErr | 			err = UnmarshalErr | ||||||
| 			if w.logger != nil { | 			if w.logger != nil { | ||||||
| 				w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 				w.logger.LogError(requestID, transactionID, code, err, reqData) | ||||||
| 			} | 			} | ||||||
| 			return nil, err | 			return nil, err | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | 		// 记录响应日志,包含响应ID | ||||||
|  | 		if w.logger != nil { | ||||||
|  | 			w.logger.LogResponseWithID(requestID, transactionID, code, httpResp.StatusCode, bodyBytes, duration, westDexResp.ID) | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		if westDexResp.Code != "00000" && westDexResp.Code != "200" && westDexResp.Code != "0" { | 		if westDexResp.Code != "00000" && westDexResp.Code != "200" && westDexResp.Code != "0" { | ||||||
| 			if westDexResp.Data == "" { | 			if westDexResp.Data == "" { | ||||||
| 				err = fmt.Errorf("%w: %s", ErrSystem, westDexResp.Message) | 				err = fmt.Errorf("%w: %s", ErrSystem, westDexResp.Message) | ||||||
| 				if w.logger != nil { | 				if w.logger != nil { | ||||||
| 					w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 					w.logger.LogErrorWithResponseID(requestID, transactionID, code, err, reqData, westDexResp.ID) | ||||||
| 				} | 				} | ||||||
| 				return nil, err | 				return nil, err | ||||||
| 			} | 			} | ||||||
| @@ -195,14 +182,14 @@ func (w *WestDexService) CallAPI(ctx context.Context, code string, reqData map[s | |||||||
| 			if DecryptErr != nil { | 			if DecryptErr != nil { | ||||||
| 				err = fmt.Errorf("%w: %s", ErrSystem, DecryptErr.Error()) | 				err = fmt.Errorf("%w: %s", ErrSystem, DecryptErr.Error()) | ||||||
| 				if w.logger != nil { | 				if w.logger != nil { | ||||||
| 					w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 					w.logger.LogErrorWithResponseID(requestID, transactionID, code, err, reqData, westDexResp.ID) | ||||||
| 				} | 				} | ||||||
| 				return nil, err | 				return nil, err | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			// 记录业务错误日志 | 			// 记录业务错误日志,包含响应ID | ||||||
| 			if w.logger != nil { | 			if w.logger != nil { | ||||||
| 				w.logger.LogError(requestID, code, fmt.Errorf("%w: %s", ErrDatasource, westDexResp.Message), w.buildLogData(reqData, transactionID)) | 				w.logger.LogErrorWithResponseID(requestID, transactionID, code, fmt.Errorf("%w: %s", ErrDatasource, westDexResp.Message), reqData, westDexResp.ID) | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			// 记录性能日志(失败) | 			// 记录性能日志(失败) | ||||||
| @@ -214,7 +201,7 @@ func (w *WestDexService) CallAPI(ctx context.Context, code string, reqData map[s | |||||||
| 		if westDexResp.Data == "" { | 		if westDexResp.Data == "" { | ||||||
| 			err = fmt.Errorf("%w: %s", ErrSystem, westDexResp.Message) | 			err = fmt.Errorf("%w: %s", ErrSystem, westDexResp.Message) | ||||||
| 			if w.logger != nil { | 			if w.logger != nil { | ||||||
| 				w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 				w.logger.LogErrorWithResponseID(requestID, transactionID, code, err, reqData, westDexResp.ID) | ||||||
| 			} | 			} | ||||||
| 			return nil, err | 			return nil, err | ||||||
| 		} | 		} | ||||||
| @@ -223,7 +210,7 @@ func (w *WestDexService) CallAPI(ctx context.Context, code string, reqData map[s | |||||||
| 		if DecryptErr != nil { | 		if DecryptErr != nil { | ||||||
| 			err = fmt.Errorf("%w: %s", ErrSystem, DecryptErr.Error()) | 			err = fmt.Errorf("%w: %s", ErrSystem, DecryptErr.Error()) | ||||||
| 			if w.logger != nil { | 			if w.logger != nil { | ||||||
| 				w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 				w.logger.LogErrorWithResponseID(requestID, transactionID, code, err, reqData, westDexResp.ID) | ||||||
| 			} | 			} | ||||||
| 			return nil, err | 			return nil, err | ||||||
| 		} | 		} | ||||||
| @@ -237,7 +224,7 @@ func (w *WestDexService) CallAPI(ctx context.Context, code string, reqData map[s | |||||||
| 	// 记录HTTP错误 | 	// 记录HTTP错误 | ||||||
| 	err = fmt.Errorf("%w: 西部请求失败Code: %d", ErrSystem, httpResp.StatusCode) | 	err = fmt.Errorf("%w: 西部请求失败Code: %d", ErrSystem, httpResp.StatusCode) | ||||||
| 	if w.logger != nil { | 	if w.logger != nil { | ||||||
| 		w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 		w.logger.LogError(requestID, transactionID, code, err, reqData) | ||||||
| 		// 注意:通用日志系统不包含性能日志功能 | 		// 注意:通用日志系统不包含性能日志功能 | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -248,7 +235,7 @@ func (w *WestDexService) CallAPI(ctx context.Context, code string, reqData map[s | |||||||
| func (w *WestDexService) G05HZ01CallAPI(ctx context.Context, code string, reqData map[string]interface{}) (resp []byte, err error) { | func (w *WestDexService) G05HZ01CallAPI(ctx context.Context, code string, reqData map[string]interface{}) (resp []byte, err error) { | ||||||
| 	startTime := time.Now() | 	startTime := time.Now() | ||||||
| 	requestID := w.generateRequestID() | 	requestID := w.generateRequestID() | ||||||
| 	 |  | ||||||
| 	// 从ctx中获取transactionId | 	// 从ctx中获取transactionId | ||||||
| 	var transactionID string | 	var transactionID string | ||||||
| 	if ctxTransactionID, ok := ctx.Value("transaction_id").(string); ok { | 	if ctxTransactionID, ok := ctx.Value("transaction_id").(string); ok { | ||||||
| @@ -260,14 +247,14 @@ func (w *WestDexService) G05HZ01CallAPI(ctx context.Context, code string, reqDat | |||||||
|  |  | ||||||
| 	// 记录请求日志 | 	// 记录请求日志 | ||||||
| 	if w.logger != nil { | 	if w.logger != nil { | ||||||
| 		w.logger.LogRequest(requestID, code, reqUrl, w.buildLogData(reqData, transactionID)) | 		w.logger.LogRequest(requestID, transactionID, code, reqUrl, reqData) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	jsonData, marshalErr := json.Marshal(reqData) | 	jsonData, marshalErr := json.Marshal(reqData) | ||||||
| 	if marshalErr != nil { | 	if marshalErr != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, marshalErr.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, marshalErr.Error()) | ||||||
| 		if w.logger != nil { | 		if w.logger != nil { | ||||||
| 			w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 			w.logger.LogError(requestID, transactionID, code, err, reqData) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -277,7 +264,7 @@ func (w *WestDexService) G05HZ01CallAPI(ctx context.Context, code string, reqDat | |||||||
| 	if newRequestErr != nil { | 	if newRequestErr != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, newRequestErr.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, newRequestErr.Error()) | ||||||
| 		if w.logger != nil { | 		if w.logger != nil { | ||||||
| 			w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 			w.logger.LogError(requestID, transactionID, code, err, reqData) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -291,7 +278,7 @@ func (w *WestDexService) G05HZ01CallAPI(ctx context.Context, code string, reqDat | |||||||
| 	if clientDoErr != nil { | 	if clientDoErr != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, clientDoErr.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, clientDoErr.Error()) | ||||||
| 		if w.logger != nil { | 		if w.logger != nil { | ||||||
| 			w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 			w.logger.LogError(requestID, transactionID, code, err, reqData) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -300,7 +287,7 @@ func (w *WestDexService) G05HZ01CallAPI(ctx context.Context, code string, reqDat | |||||||
| 		if closeErr != nil { | 		if closeErr != nil { | ||||||
| 			// 记录关闭错误 | 			// 记录关闭错误 | ||||||
| 			if w.logger != nil { | 			if w.logger != nil { | ||||||
| 				w.logger.LogError(requestID, code, fmt.Errorf("关闭响应体失败: %w", closeErr), w.buildLogData(reqData, transactionID)) | 				w.logger.LogError(requestID, transactionID, code, fmt.Errorf("关闭响应体失败: %w", closeErr), reqData) | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	}(httpResp.Body) | 	}(httpResp.Body) | ||||||
| @@ -313,37 +300,37 @@ func (w *WestDexService) G05HZ01CallAPI(ctx context.Context, code string, reqDat | |||||||
| 		if ReadErr != nil { | 		if ReadErr != nil { | ||||||
| 			err = fmt.Errorf("%w: %s", ErrSystem, ReadErr.Error()) | 			err = fmt.Errorf("%w: %s", ErrSystem, ReadErr.Error()) | ||||||
| 			if w.logger != nil { | 			if w.logger != nil { | ||||||
| 				w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 				w.logger.LogError(requestID, transactionID, code, err, reqData) | ||||||
| 			} | 			} | ||||||
| 			return nil, err | 			return nil, err | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		// 记录响应日志 |  | ||||||
| 		if w.logger != nil { |  | ||||||
| 			w.logger.LogResponse(requestID, code, httpResp.StatusCode, bodyBytes, duration) |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		var westDexResp G05HZ01WestResp | 		var westDexResp G05HZ01WestResp | ||||||
| 		UnmarshalErr := json.Unmarshal(bodyBytes, &westDexResp) | 		UnmarshalErr := json.Unmarshal(bodyBytes, &westDexResp) | ||||||
| 		if UnmarshalErr != nil { | 		if UnmarshalErr != nil { | ||||||
| 			err = fmt.Errorf("%w: %s", ErrSystem, UnmarshalErr.Error()) | 			err = fmt.Errorf("%w: %s", ErrSystem, UnmarshalErr.Error()) | ||||||
| 			if w.logger != nil { | 			if w.logger != nil { | ||||||
| 				w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 				w.logger.LogError(requestID, transactionID, code, err, reqData) | ||||||
| 			} | 			} | ||||||
| 			return nil, err | 			return nil, err | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | 		// 记录响应日志,包含响应ID | ||||||
|  | 		if w.logger != nil { | ||||||
|  | 			w.logger.LogResponseWithID(requestID, transactionID, code, httpResp.StatusCode, bodyBytes, duration, westDexResp.ID) | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		if westDexResp.Code != "0000" { | 		if westDexResp.Code != "0000" { | ||||||
| 			if westDexResp.Data == nil { | 			if westDexResp.Data == nil { | ||||||
| 				err = fmt.Errorf("%w: %s", ErrSystem, westDexResp.Message) | 				err = fmt.Errorf("%w: %s", ErrSystem, westDexResp.Message) | ||||||
| 				if w.logger != nil { | 				if w.logger != nil { | ||||||
| 					w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 					w.logger.LogErrorWithResponseID(requestID, transactionID, code, err, reqData, westDexResp.ID) | ||||||
| 				} | 				} | ||||||
| 				return nil, err | 				return nil, err | ||||||
| 			} else { | 			} else { | ||||||
| 				// 记录业务错误日志 | 				// 记录业务错误日志,包含响应ID | ||||||
| 				if w.logger != nil { | 				if w.logger != nil { | ||||||
| 					w.logger.LogError(requestID, code, fmt.Errorf("%w: %s", ErrSystem, string(westDexResp.Data)), w.buildLogData(reqData, transactionID)) | 					w.logger.LogErrorWithResponseID(requestID, transactionID, code, fmt.Errorf("%w: %s", ErrSystem, string(westDexResp.Data)), reqData, westDexResp.ID) | ||||||
| 				} | 				} | ||||||
|  |  | ||||||
| 				// 记录性能日志(失败) | 				// 记录性能日志(失败) | ||||||
| @@ -356,7 +343,7 @@ func (w *WestDexService) G05HZ01CallAPI(ctx context.Context, code string, reqDat | |||||||
| 		if westDexResp.Data == nil { | 		if westDexResp.Data == nil { | ||||||
| 			err = fmt.Errorf("%w: %s", ErrSystem, westDexResp.Message) | 			err = fmt.Errorf("%w: %s", ErrSystem, westDexResp.Message) | ||||||
| 			if w.logger != nil { | 			if w.logger != nil { | ||||||
| 				w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 				w.logger.LogErrorWithResponseID(requestID, transactionID, code, err, reqData, westDexResp.ID) | ||||||
| 			} | 			} | ||||||
| 			return nil, err | 			return nil, err | ||||||
| 		} | 		} | ||||||
| @@ -369,7 +356,7 @@ func (w *WestDexService) G05HZ01CallAPI(ctx context.Context, code string, reqDat | |||||||
| 		// 记录HTTP错误 | 		// 记录HTTP错误 | ||||||
| 		err = fmt.Errorf("%w: 西部请求失败Code: %d", ErrSystem, httpResp.StatusCode) | 		err = fmt.Errorf("%w: 西部请求失败Code: %d", ErrSystem, httpResp.StatusCode) | ||||||
| 		if w.logger != nil { | 		if w.logger != nil { | ||||||
| 			w.logger.LogError(requestID, code, err, w.buildLogData(reqData, transactionID)) | 			w.logger.LogError(requestID, transactionID, code, err, reqData) | ||||||
| 			// 注意:通用日志系统不包含性能日志功能 | 			// 注意:通用日志系统不包含性能日志功能 | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
|   | |||||||
| @@ -64,7 +64,7 @@ func (y *YushanService) CallAPI(ctx context.Context, code string, params map[str | |||||||
|  |  | ||||||
| 	// 记录请求日志 | 	// 记录请求日志 | ||||||
| 	if y.logger != nil { | 	if y.logger != nil { | ||||||
| 		y.logger.LogRequest(requestID, code, y.config.URL, y.buildLogData(params, transactionID)) | 		y.logger.LogRequest(requestID, transactionID, code, y.config.URL, params) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	// 获取当前时间戳 | 	// 获取当前时间戳 | ||||||
| @@ -86,7 +86,7 @@ func (y *YushanService) CallAPI(ctx context.Context, code string, params map[str | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | ||||||
| 		if y.logger != nil { | 		if y.logger != nil { | ||||||
| 			y.logger.LogError(requestID, code, err, y.buildLogData(params, transactionID)) | 			y.logger.LogError(requestID, transactionID, code, err, params) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -96,7 +96,7 @@ func (y *YushanService) CallAPI(ctx context.Context, code string, params map[str | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | ||||||
| 		if y.logger != nil { | 		if y.logger != nil { | ||||||
| 			y.logger.LogError(requestID, code, err, y.buildLogData(params, transactionID)) | 			y.logger.LogError(requestID, transactionID, code, err, params) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -115,7 +115,7 @@ func (y *YushanService) CallAPI(ctx context.Context, code string, params map[str | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | ||||||
| 		if y.logger != nil { | 		if y.logger != nil { | ||||||
| 			y.logger.LogError(requestID, code, err, y.buildLogData(params, transactionID)) | 			y.logger.LogError(requestID, transactionID, code, err, params) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -127,7 +127,7 @@ func (y *YushanService) CallAPI(ctx context.Context, code string, params map[str | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | ||||||
| 		if y.logger != nil { | 		if y.logger != nil { | ||||||
| 			y.logger.LogError(requestID, code, err, y.buildLogData(params, transactionID)) | 			y.logger.LogError(requestID, transactionID, code, err, params) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -137,7 +137,7 @@ func (y *YushanService) CallAPI(ctx context.Context, code string, params map[str | |||||||
| 	body, err := io.ReadAll(resp.Body) | 	body, err := io.ReadAll(resp.Body) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		if y.logger != nil { | 		if y.logger != nil { | ||||||
| 			y.logger.LogError(requestID, code, err, y.buildLogData(params, transactionID)) | 			y.logger.LogError(requestID, transactionID, code, err, params) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -151,7 +151,7 @@ func (y *YushanService) CallAPI(ctx context.Context, code string, params map[str | |||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | 			err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | ||||||
| 			if y.logger != nil { | 			if y.logger != nil { | ||||||
| 				y.logger.LogError(requestID, code, err, y.buildLogData(params, transactionID)) | 				y.logger.LogError(requestID, transactionID, code, err, params) | ||||||
| 			} | 			} | ||||||
| 			return nil, err | 			return nil, err | ||||||
| 		} | 		} | ||||||
| @@ -162,7 +162,7 @@ func (y *YushanService) CallAPI(ctx context.Context, code string, params map[str | |||||||
| 	// 记录响应日志 | 	// 记录响应日志 | ||||||
| 	if y.logger != nil { | 	if y.logger != nil { | ||||||
| 		duration := time.Since(startTime) | 		duration := time.Since(startTime) | ||||||
| 		y.logger.LogResponse(requestID, code, resp.StatusCode, respData, duration) | 		y.logger.LogResponse(requestID, transactionID, code, resp.StatusCode, respData, duration) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if retCode == "100000" { | 	if retCode == "100000" { | ||||||
| @@ -174,7 +174,7 @@ func (y *YushanService) CallAPI(ctx context.Context, code string, params map[str | |||||||
| 		if !retData.Exists() { | 		if !retData.Exists() { | ||||||
| 			err = fmt.Errorf("%w: %s", ErrDatasource, "羽山请求retdata为空") | 			err = fmt.Errorf("%w: %s", ErrDatasource, "羽山请求retdata为空") | ||||||
| 			if y.logger != nil { | 			if y.logger != nil { | ||||||
| 				y.logger.LogError(requestID, code, err, y.buildLogData(params, transactionID)) | 				y.logger.LogError(requestID, transactionID, code, err, params) | ||||||
| 			} | 			} | ||||||
| 			return nil, err | 			return nil, err | ||||||
| 		} | 		} | ||||||
| @@ -182,7 +182,7 @@ func (y *YushanService) CallAPI(ctx context.Context, code string, params map[str | |||||||
| 	} else { | 	} else { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrDatasource, "羽山请求未知的状态码") | 		err = fmt.Errorf("%w: %s", ErrDatasource, "羽山请求未知的状态码") | ||||||
| 		if y.logger != nil { | 		if y.logger != nil { | ||||||
| 			y.logger.LogError(requestID, code, err, y.buildLogData(params, transactionID)) | 			y.logger.LogError(requestID, transactionID, code, err, params) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -195,20 +195,6 @@ func (y *YushanService) generateRequestID() string { | |||||||
| 	return fmt.Sprintf("yushan_%x", hash[:8]) | 	return fmt.Sprintf("yushan_%x", hash[:8]) | ||||||
| } | } | ||||||
|  |  | ||||||
| // buildLogData 构建包含transactionId的日志数据 |  | ||||||
| func (y *YushanService) buildLogData(data map[string]interface{}, transactionID string) map[string]interface{} { |  | ||||||
| 	if transactionID == "" { |  | ||||||
| 		return data |  | ||||||
| 	} |  | ||||||
| 	 |  | ||||||
| 	logData := data |  | ||||||
| 	if logData == nil { |  | ||||||
| 		logData = make(map[string]interface{}) |  | ||||||
| 	} |  | ||||||
| 	logData["transaction_id"] = transactionID |  | ||||||
| 	return logData |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // GenerateRandomString 生成一个32位的随机字符串订单号 | // GenerateRandomString 生成一个32位的随机字符串订单号 | ||||||
| func (y *YushanService) GenerateRandomString() (string, error) { | func (y *YushanService) GenerateRandomString() (string, error) { | ||||||
| 	// 创建一个16字节的数组 | 	// 创建一个16字节的数组 | ||||||
|   | |||||||
| @@ -63,20 +63,6 @@ func (z *ZhichaService) generateRequestID() string { | |||||||
| 	return fmt.Sprintf("zhicha_%x", hash[:8]) | 	return fmt.Sprintf("zhicha_%x", hash[:8]) | ||||||
| } | } | ||||||
|  |  | ||||||
| // buildLogData 构建包含transactionId的日志数据 |  | ||||||
| func (z *ZhichaService) buildLogData(data map[string]interface{}, transactionID string) map[string]interface{} { |  | ||||||
| 	if transactionID == "" { |  | ||||||
| 		return data |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	logData := data |  | ||||||
| 	if logData == nil { |  | ||||||
| 		logData = make(map[string]interface{}) |  | ||||||
| 	} |  | ||||||
| 	logData["transaction_id"] = transactionID |  | ||||||
| 	return logData |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // generateSign 生成签名 | // generateSign 生成签名 | ||||||
| func (z *ZhichaService) generateSign(timestamp int64) string { | func (z *ZhichaService) generateSign(timestamp int64) string { | ||||||
| 	// 第一步:对app_secret进行MD5加密 | 	// 第一步:对app_secret进行MD5加密 | ||||||
| @@ -103,14 +89,14 @@ func (z *ZhichaService) CallAPI(ctx context.Context, proID string, params map[st | |||||||
|  |  | ||||||
| 	// 记录请求日志 | 	// 记录请求日志 | ||||||
| 	if z.logger != nil { | 	if z.logger != nil { | ||||||
| 		z.logger.LogRequest(requestID, "handle", z.config.URL, z.buildLogData(params, transactionID)) | 		z.logger.LogRequest(requestID, transactionID, proID, z.config.URL, params) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	jsonData, marshalErr := json.Marshal(params) | 	jsonData, marshalErr := json.Marshal(params) | ||||||
| 	if marshalErr != nil { | 	if marshalErr != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, marshalErr.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, marshalErr.Error()) | ||||||
| 		if z.logger != nil { | 		if z.logger != nil { | ||||||
| 			z.logger.LogError(requestID, "handle", err, z.buildLogData(params, transactionID)) | 			z.logger.LogError(requestID, transactionID, proID, err, params) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -120,7 +106,7 @@ func (z *ZhichaService) CallAPI(ctx context.Context, proID string, params map[st | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | ||||||
| 		if z.logger != nil { | 		if z.logger != nil { | ||||||
| 			z.logger.LogError(requestID, "handle", err, z.buildLogData(params, transactionID)) | 			z.logger.LogError(requestID, transactionID, proID, err, params) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -142,7 +128,7 @@ func (z *ZhichaService) CallAPI(ctx context.Context, proID string, params map[st | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | ||||||
| 		if z.logger != nil { | 		if z.logger != nil { | ||||||
| 			z.logger.LogError(requestID, "handle", err, z.buildLogData(params, transactionID)) | 			z.logger.LogError(requestID, transactionID, proID, err, params) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -153,7 +139,7 @@ func (z *ZhichaService) CallAPI(ctx context.Context, proID string, params map[st | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | 		err = fmt.Errorf("%w: %s", ErrSystem, err.Error()) | ||||||
| 		if z.logger != nil { | 		if z.logger != nil { | ||||||
| 			z.logger.LogError(requestID, "handle", err, z.buildLogData(params, transactionID)) | 			z.logger.LogError(requestID, transactionID, proID, err, params) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -161,14 +147,14 @@ func (z *ZhichaService) CallAPI(ctx context.Context, proID string, params map[st | |||||||
| 	// 记录响应日志 | 	// 记录响应日志 | ||||||
| 	if z.logger != nil { | 	if z.logger != nil { | ||||||
| 		duration := time.Since(startTime) | 		duration := time.Since(startTime) | ||||||
| 		z.logger.LogResponse(requestID, "handle", response.StatusCode, respBody, duration) | 		z.logger.LogResponse(requestID, transactionID, proID, response.StatusCode, respBody, duration) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	// 检查HTTP状态码 | 	// 检查HTTP状态码 | ||||||
| 	if response.StatusCode != http.StatusOK { | 	if response.StatusCode != http.StatusOK { | ||||||
| 		err = fmt.Errorf("%w: HTTP状态码 %d", ErrDatasource, response.StatusCode) | 		err = fmt.Errorf("%w: HTTP状态码 %d", ErrDatasource, response.StatusCode) | ||||||
| 		if z.logger != nil { | 		if z.logger != nil { | ||||||
| 			z.logger.LogError(requestID, "handle", err, z.buildLogData(params, transactionID)) | 			z.logger.LogError(requestID, transactionID, proID, err, params) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -178,7 +164,7 @@ func (z *ZhichaService) CallAPI(ctx context.Context, proID string, params map[st | |||||||
| 	if err := json.Unmarshal(respBody, &zhichaResp); err != nil { | 	if err := json.Unmarshal(respBody, &zhichaResp); err != nil { | ||||||
| 		err = fmt.Errorf("%w: 响应解析失败: %s", ErrSystem, err.Error()) | 		err = fmt.Errorf("%w: 响应解析失败: %s", ErrSystem, err.Error()) | ||||||
| 		if z.logger != nil { | 		if z.logger != nil { | ||||||
| 			z.logger.LogError(requestID, "handle", err, z.buildLogData(params, transactionID)) | 			z.logger.LogError(requestID, transactionID, proID, err, params) | ||||||
| 		} | 		} | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -193,7 +179,7 @@ func (z *ZhichaService) CallAPI(ctx context.Context, proID string, params map[st | |||||||
|  |  | ||||||
| 		// 记录智查金控的详细错误信息到日志 | 		// 记录智查金控的详细错误信息到日志 | ||||||
| 		if z.logger != nil { | 		if z.logger != nil { | ||||||
| 			z.logger.LogError(requestID, "handle", zhichaErr, z.buildLogData(params, transactionID)) | 			z.logger.LogError(requestID, transactionID, proID, zhichaErr, params) | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		// 对外统一返回数据源异常错误 | 		// 对外统一返回数据源异常错误 | ||||||
|   | |||||||
| @@ -152,7 +152,7 @@ func createFileWriter(logDir, level string, config ExternalServiceLevelFileConfi | |||||||
| 		// 按天分隔:logs/westdex/2024-01-01/westdex_info.log | 		// 按天分隔:logs/westdex/2024-01-01/westdex_info.log | ||||||
| 		date := time.Now().Format("2006-01-02") | 		date := time.Now().Format("2006-01-02") | ||||||
| 		dateDir := filepath.Join(logDir, date) | 		dateDir := filepath.Join(logDir, date) | ||||||
| 		 |  | ||||||
| 		// 确保日期目录存在 | 		// 确保日期目录存在 | ||||||
| 		if err := os.MkdirAll(dateDir, 0755); err != nil { | 		if err := os.MkdirAll(dateDir, 0755); err != nil { | ||||||
| 			// 如果创建日期目录失败,回退到根目录 | 			// 如果创建日期目录失败,回退到根目录 | ||||||
| @@ -175,10 +175,11 @@ func createFileWriter(logDir, level string, config ExternalServiceLevelFileConfi | |||||||
| } | } | ||||||
|  |  | ||||||
| // LogRequest 记录请求日志 | // LogRequest 记录请求日志 | ||||||
| func (e *ExternalServiceLogger) LogRequest(requestID, apiCode string, url interface{}, params interface{}) { | func (e *ExternalServiceLogger) LogRequest(requestID, transactionID, apiCode string, url interface{}, params interface{}) { | ||||||
| 	e.logger.Info(fmt.Sprintf("%s API请求", e.serviceName), | 	e.logger.Info(fmt.Sprintf("%s API请求", e.serviceName), | ||||||
| 		zap.String("service", e.serviceName), | 		zap.String("service", e.serviceName), | ||||||
| 		zap.String("request_id", requestID), | 		zap.String("request_id", requestID), | ||||||
|  | 		zap.String("transaction_id", transactionID), | ||||||
| 		zap.String("api_code", apiCode), | 		zap.String("api_code", apiCode), | ||||||
| 		zap.Any("url", url), | 		zap.Any("url", url), | ||||||
| 		zap.Any("params", params), | 		zap.Any("params", params), | ||||||
| @@ -187,10 +188,11 @@ func (e *ExternalServiceLogger) LogRequest(requestID, apiCode string, url interf | |||||||
| } | } | ||||||
|  |  | ||||||
| // LogResponse 记录响应日志 | // LogResponse 记录响应日志 | ||||||
| func (e *ExternalServiceLogger) LogResponse(requestID, apiCode string, statusCode int, response []byte, duration time.Duration) { | func (e *ExternalServiceLogger) LogResponse(requestID, transactionID, apiCode string, statusCode int, response []byte, duration time.Duration) { | ||||||
| 	e.logger.Info(fmt.Sprintf("%s API响应", e.serviceName), | 	e.logger.Info(fmt.Sprintf("%s API响应", e.serviceName), | ||||||
| 		zap.String("service", e.serviceName), | 		zap.String("service", e.serviceName), | ||||||
| 		zap.String("request_id", requestID), | 		zap.String("request_id", requestID), | ||||||
|  | 		zap.String("transaction_id", transactionID), | ||||||
| 		zap.String("api_code", apiCode), | 		zap.String("api_code", apiCode), | ||||||
| 		zap.Int("status_code", statusCode), | 		zap.Int("status_code", statusCode), | ||||||
| 		zap.String("response", string(response)), | 		zap.String("response", string(response)), | ||||||
| @@ -199,11 +201,27 @@ func (e *ExternalServiceLogger) LogResponse(requestID, apiCode string, statusCod | |||||||
| 	) | 	) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // LogResponseWithID 记录包含响应ID的响应日志 | ||||||
|  | func (e *ExternalServiceLogger) LogResponseWithID(requestID, transactionID, apiCode string, statusCode int, response []byte, duration time.Duration, responseID string) { | ||||||
|  | 	e.logger.Info(fmt.Sprintf("%s API响应", e.serviceName), | ||||||
|  | 		zap.String("service", e.serviceName), | ||||||
|  | 		zap.String("request_id", requestID), | ||||||
|  | 		zap.String("transaction_id", transactionID), | ||||||
|  | 		zap.String("api_code", apiCode), | ||||||
|  | 		zap.Int("status_code", statusCode), | ||||||
|  | 		zap.String("response", string(response)), | ||||||
|  | 		zap.Duration("duration", duration), | ||||||
|  | 		zap.String("response_id", responseID), | ||||||
|  | 		zap.String("timestamp", time.Now().Format(time.RFC3339)), | ||||||
|  | 	) | ||||||
|  | } | ||||||
|  |  | ||||||
| // LogError 记录错误日志 | // LogError 记录错误日志 | ||||||
| func (e *ExternalServiceLogger) LogError(requestID, apiCode string, err error, params interface{}) { | func (e *ExternalServiceLogger) LogError(requestID, transactionID, apiCode string, err error, params interface{}) { | ||||||
| 	e.logger.Error(fmt.Sprintf("%s API错误", e.serviceName), | 	e.logger.Error(fmt.Sprintf("%s API错误", e.serviceName), | ||||||
| 		zap.String("service", e.serviceName), | 		zap.String("service", e.serviceName), | ||||||
| 		zap.String("request_id", requestID), | 		zap.String("request_id", requestID), | ||||||
|  | 		zap.String("transaction_id", transactionID), | ||||||
| 		zap.String("api_code", apiCode), | 		zap.String("api_code", apiCode), | ||||||
| 		zap.Error(err), | 		zap.Error(err), | ||||||
| 		zap.Any("params", params), | 		zap.Any("params", params), | ||||||
| @@ -211,6 +229,20 @@ func (e *ExternalServiceLogger) LogError(requestID, apiCode string, err error, p | |||||||
| 	) | 	) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // LogErrorWithResponseID 记录包含响应ID的错误日志 | ||||||
|  | func (e *ExternalServiceLogger) LogErrorWithResponseID(requestID, transactionID, apiCode string, err error, params interface{}, responseID string) { | ||||||
|  | 	e.logger.Error(fmt.Sprintf("%s API错误", e.serviceName), | ||||||
|  | 		zap.String("service", e.serviceName), | ||||||
|  | 		zap.String("request_id", requestID), | ||||||
|  | 		zap.String("transaction_id", transactionID), | ||||||
|  | 		zap.String("api_code", apiCode), | ||||||
|  | 		zap.Error(err), | ||||||
|  | 		zap.Any("params", params), | ||||||
|  | 		zap.String("response_id", responseID), | ||||||
|  | 		zap.String("timestamp", time.Now().Format(time.RFC3339)), | ||||||
|  | 	) | ||||||
|  | } | ||||||
|  |  | ||||||
| // LogInfo 记录信息日志 | // LogInfo 记录信息日志 | ||||||
| func (e *ExternalServiceLogger) LogInfo(message string, fields ...zap.Field) { | func (e *ExternalServiceLogger) LogInfo(message string, fields ...zap.Field) { | ||||||
| 	allFields := []zap.Field{zap.String("service", e.serviceName)} | 	allFields := []zap.Field{zap.String("service", e.serviceName)} | ||||||
| @@ -244,7 +276,7 @@ func (e *ExternalServiceLogger) CleanupOldDateDirs() error { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	logDir := filepath.Join(e.config.LogDir, e.serviceName) | 	logDir := filepath.Join(e.config.LogDir, e.serviceName) | ||||||
| 	 |  | ||||||
| 	// 读取日志目录 | 	// 读取日志目录 | ||||||
| 	entries, err := os.ReadDir(logDir) | 	entries, err := os.ReadDir(logDir) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| @@ -256,7 +288,7 @@ func (e *ExternalServiceLogger) CleanupOldDateDirs() error { | |||||||
| 	if errorConfig, exists := e.config.LevelConfigs["error"]; exists && errorConfig.MaxAge > 0 { | 	if errorConfig, exists := e.config.LevelConfigs["error"]; exists && errorConfig.MaxAge > 0 { | ||||||
| 		maxAge = errorConfig.MaxAge | 		maxAge = errorConfig.MaxAge | ||||||
| 	} | 	} | ||||||
| 	 |  | ||||||
| 	cutoffTime := time.Now().AddDate(0, 0, -maxAge) | 	cutoffTime := time.Now().AddDate(0, 0, -maxAge) | ||||||
|  |  | ||||||
| 	for _, entry := range entries { | 	for _, entry := range entries { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user