/* * Copyright 2017-2020 吴学文 and java110 team. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.java110.acct.cmd.invoiceEvent; import com.alibaba.fastjson.JSONObject; import com.java110.core.annotation.Java110Cmd; import com.java110.core.annotation.Java110Transactional; import com.java110.core.context.ICmdDataFlowContext; import com.java110.core.event.cmd.Cmd; import com.java110.core.event.cmd.CmdEvent; import com.java110.intf.acct.IInvoiceEventV1InnerServiceSMO; import com.java110.po.invoice.InvoiceEventPo; import com.java110.utils.exception.CmdException; import com.java110.utils.util.Assert; import com.java110.utils.util.BeanConvertUtil; import com.java110.vo.ResultVo; import org.springframework.beans.factory.annotation.Autowired; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * 类表述:更新 * 服务编码:invoiceEvent.updateInvoiceEvent * 请求路劲:/app/invoiceEvent.UpdateInvoiceEvent * add by 吴学文 at 2023-10-08 19:40:59 mail: 928255095@qq.com * open source address: https://gitee.com/wuxw7/MicroCommunity * 官网:http://www.homecommunity.cn * 温馨提示:如果您对此文件进行修改 请不要删除原有作者及注释信息,请补充您的 修改的原因以及联系邮箱如下 * // modify by 张三 at 2021-09-12 第10行在某种场景下存在某种bug 需要修复,注释10至20行 加入 20行至30行 */ /** * 发票事件更新命令类 * * 该类负责处理发票事件的更新操作,通过接收前端请求数据,验证参数有效性, * 并将数据更新到数据库中。使用事务保证数据一致性。 * * @author 吴学文 * @version 1.0 * @since 2023-10-08 */ @Java110Cmd(serviceCode = "invoiceEvent.updateInvoiceEvent") public class UpdateInvoiceEventCmd extends Cmd { /** * 日志记录器 */ private static Logger logger = LoggerFactory.getLogger(UpdateInvoiceEventCmd.class); /** * 发票事件服务接口 * 用于执行发票事件的数据库操作 */ @Autowired private IInvoiceEventV1InnerServiceSMO invoiceEventV1InnerServiceSMOImpl; /** * 参数验证方法 * * 验证请求参数中是否包含必要的字段,确保更新操作的数据完整性 * * @param event 命令事件对象,包含请求相关信息 * @param cmdDataFlowContext 命令数据流上下文,用于获取和设置请求响应数据 * @param reqJson 请求参数JSON对象,包含前端传递的参数数据 * @throws CmdException 当参数验证失败时抛出异常 */ @Override public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) { // 验证事件ID不能为空 Assert.hasKeyAndValue(reqJson, "eventId", "eventId不能为空"); // 验证小区ID不能为空 Assert.hasKeyAndValue(reqJson, "communityId", "communityId不能为空"); } /** * 执行命令方法 * * 处理发票事件的更新操作,将请求数据转换为实体对象并更新到数据库, * 使用事务保证操作的原子性 * * @param event 命令事件对象 * @param cmdDataFlowContext 命令数据流上下文 * @param reqJson 请求参数JSON对象 * @throws CmdException 当更新操作失败时抛出异常 */ @Override @Java110Transactional public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException { // 将JSON请求参数转换为发票事件实体对象 InvoiceEventPo invoiceEventPo = BeanConvertUtil.covertBean(reqJson, InvoiceEventPo.class); // 调用服务层方法更新发票事件数据 int flag = invoiceEventV1InnerServiceSMOImpl.updateInvoiceEvent(invoiceEventPo); // 检查更新操作是否成功,flag表示受影响的行数 if (flag < 1) { // 更新失败时抛出异常 throw new CmdException("更新数据失败"); } // 设置响应结果为成功 cmdDataFlowContext.setResponseEntity(ResultVo.success()); } }