package com.api.aiyh_quanshi.service.Impl; import aiyh.utils.zwl.common.ToolUtil; import com.weaverboot.frame.ioc.anno.classAnno.WeaIocReplaceComponent; import com.weaverboot.frame.ioc.anno.methodAnno.WeaReplaceAfter; import com.weaverboot.frame.ioc.anno.methodAnno.WeaReplaceBefore; import com.weaverboot.frame.ioc.handler.replace.weaReplaceParam.impl.WeaAfterReplaceParam; import com.weaverboot.frame.ioc.handler.replace.weaReplaceParam.impl.WeaBeforeReplaceParam; import weaver.aiyh_quanshi.RequestApi; import weaver.aiyh_quanshi.entity.QsResponse; import weaver.conn.RecordSet; import java.util.Map; /** * 如不标注名称,则按类的全路径注入 */ @WeaIocReplaceComponent("deleteMetingService") public class DeleteMetingServiceImpl { ToolUtil toolUtil = new ToolUtil(); RequestApi requestApi = new RequestApi(); boolean flag = true; /** * 这是接口前置方法,这个方法会在接口执行前执行 * 前值方法必须用@WeaReplaceBefore,这里面有两个参数,第一个叫value,是你的api地址 * 第二个参数叫order,如果你有很多方法拦截的是一个api,那么这个就决定了执行顺序 * 前置方法的参数为WeaBeforeReplaceParam 这个类,里面有四个参数,request,response,请求参数的map,api的地址 */ @WeaReplaceBefore(value = "/api/meeting/monitor/delete", order = 1, description = "会议接口前拦截") public void before(WeaBeforeReplaceParam weaBeforeReplaceParam) { // 获取会议id Map paramMap = weaBeforeReplaceParam.getParamMap(); String ids = String.valueOf(paramMap.get("meetingids")); // 通过会议id获取全时会议id String query = "select * from meeting where id in (" + ids + ") and cancel != 1 and meetingstatus not in (2,4)"; RecordSet rs = new RecordSet(); rs.executeQuery(query); // 获取删除的会议的所有对应的全时id以及创建人 while (rs.next()) { String quanShiId = rs.getString("quan_shi_id"); String hrmId = rs.getString("contacter"); query = "select * from hrmresource where id = ?"; rs.executeQuery(query, hrmId); rs.next(); String creatorEmail = rs.getString("email"); QsResponse qsResponse = requestApi.cancelConference(quanShiId, creatorEmail); // 通过全时会议id对会议进行取消 if (!"0".equals(qsResponse.getStatus())) { // 取消失败 flag = false; } } } /** * 这个是接口后置方法,大概的用法跟前置方法差不多,稍有差别 * 注解名称为WeaReplaceAfter * 返回类型必须为String * 参数叫WeaAfterReplaceParam,这个类前四个参数跟前置方法的那个相同,不同的是多了一个叫data的String,这个是那个接口执行完返回的报文 * 你可以对那个报文进行操作,然后在这个方法里return回去 */ @WeaReplaceAfter(value = "/api/meeting/monitor/delete", order = 1) public String after(WeaAfterReplaceParam weaAfterReplaceParam) { //这个就是接口执行完的报文 String data = weaAfterReplaceParam.getData(); if (!flag) { // 取消会议失败 } return data; } }