linhw 2024-05-29 17:00:03 +08:00
parent 058bcfcc04
commit 7feb5da469
7 changed files with 546 additions and 0 deletions

View File

@ -0,0 +1,114 @@
package com.ruoyi.app.controller;
import java.util.List;
import java.io.IOException;
import javax.servlet.http.HttpServletResponse;
import com.ruoyi.common.core.domain.R;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.ruoyi.common.log.annotation.Log;
import com.ruoyi.common.log.enums.BusinessType;
import com.ruoyi.common.security.annotation.RequiresPermissions;
import com.ruoyi.app.domain.AppMessage;
import com.ruoyi.app.service.IAppMessageService;
import com.ruoyi.common.core.web.controller.BaseController;
import com.ruoyi.common.core.web.domain.AjaxResult;
import com.ruoyi.common.core.utils.poi.ExcelUtil;
import com.ruoyi.common.core.web.page.TableDataInfo;
/**
* Controller
*
* @author wyh
* @date 2024-05-29
*/
@RestController
@RequestMapping("/message")
@Api(tags = "系统消息" , description = "系统消息")
public class AppMessageController extends BaseController
{
@Autowired
private IAppMessageService appMessageService;
/**
*
*/
@RequiresPermissions("app:message:list")
@GetMapping("/list")
@ApiOperation(value = "查询系统消息", notes = "查询系统消息", httpMethod = "GET")
public TableDataInfo list(AppMessage appMessage)
{
startPage();
List<AppMessage> list = appMessageService.selectAppMessageList(appMessage);
return getDataTable(list);
}
/**
*
*/
@RequiresPermissions("app:message:export")
@Log(title = "系统消息", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(HttpServletResponse response, AppMessage appMessage)
{
List<AppMessage> list = appMessageService.selectAppMessageList(appMessage);
ExcelUtil<AppMessage> util = new ExcelUtil<AppMessage>(AppMessage.class);
util.exportExcel(response, list, "系统消息数据");
}
/**
*
*/
@RequiresPermissions("app:message:query")
@GetMapping(value = "/{id}")
@ApiOperation(value = "获取系统消息详细信息", notes = "获取系统消息详细信息", httpMethod = "GET")
public AjaxResult getInfo(@PathVariable("id") Long id)
{
return success(appMessageService.selectAppMessageById(id));
}
/**
*
*/
@RequiresPermissions("app:message:add")
@ApiOperation(value = "新增系统消息", notes = "新增系统消息", httpMethod = "POST")
@Log(title = "系统消息", businessType = BusinessType.INSERT)
@PostMapping("/add")
public AjaxResult add(@RequestBody AppMessage appMessage)
{
return toAjax(appMessageService.insertAppMessage(appMessage));
}
/**
*
*/
@RequiresPermissions("app:message:edit")
@ApiOperation(value = "修改系统消息", notes = "修改系统消息", httpMethod = "PUT")
@Log(title = "系统消息", businessType = BusinessType.UPDATE)
@PutMapping("/edit")
public AjaxResult edit(@RequestBody AppMessage appMessage)
{
return toAjax(appMessageService.updateAppMessage(appMessage));
}
/**
*
*/
@RequiresPermissions("app:message:remove")
@Log(title = "系统消息", businessType = BusinessType.DELETE)
@DeleteMapping("/{ids}")
public AjaxResult remove(@PathVariable Long[] ids)
{
return toAjax(appMessageService.deleteAppMessageByIds(ids));
}
}

View File

@ -1,5 +1,6 @@
package com.ruoyi.app.domain;
import lombok.Data;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.apache.commons.lang3.builder.ToStringStyle;
import com.ruoyi.common.core.annotation.Excel;
@ -11,6 +12,7 @@ import com.ruoyi.common.core.web.domain.BaseEntity;
* @author wyh
* @date 2024-05-29
*/
@Data
public class AppFeedback extends BaseEntity
{
private static final long serialVersionUID = 1L;

View File

@ -0,0 +1,91 @@
package com.ruoyi.app.domain;
import lombok.Data;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.apache.commons.lang3.builder.ToStringStyle;
import com.ruoyi.common.core.annotation.Excel;
import com.ruoyi.common.core.web.domain.BaseEntity;
/**
* app_message
*
* @author wyh
* @date 2024-05-29
*/
@Data
public class AppMessage extends BaseEntity
{
private static final long serialVersionUID = 1L;
/** id */
private Long id;
/** 管理员id */
@Excel(name = "管理员id")
private Long userId;
/** 通知内容 */
@Excel(name = "通知内容")
private String content;
/** 图片 */
@Excel(name = "图片")
private String imgUrl;
@Excel(name = "头像")
private String avatarUrl;
@Excel(name = "用户名")
private String username;
public void setId(Long id)
{
this.id = id;
}
public Long getId()
{
return id;
}
public void setUserId(Long userId)
{
this.userId = userId;
}
public Long getUserId()
{
return userId;
}
public void setContent(String content)
{
this.content = content;
}
public String getContent()
{
return content;
}
public void setImgUrl(String imgUrl)
{
this.imgUrl = imgUrl;
}
public String getImgUrl()
{
return imgUrl;
}
@Override
public String toString() {
return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE)
.append("id", getId())
.append("userId", getUserId())
.append("content", getContent())
.append("imgUrl", getImgUrl())
.append("createTime", getCreateTime())
.append("updateTime", getUpdateTime())
.append("remark", getRemark())
.toString();
}
}

View File

@ -0,0 +1,62 @@
package com.ruoyi.app.mapper;
import java.util.List;
import com.ruoyi.app.domain.AppMessage;
/**
* Mapper
*
* @author wyh
* @date 2024-05-29
*/
public interface AppMessageMapper
{
/**
*
*
* @param id
* @return
*/
public AppMessage selectAppMessageById(Long id);
/**
*
*
* @param appMessage
* @return
*/
public List<AppMessage> selectAppMessageList(AppMessage appMessage);
public List<AppMessage> selectList(AppMessage appMessage);
/**
*
*
* @param appMessage
* @return
*/
public int insertAppMessage(AppMessage appMessage);
/**
*
*
* @param appMessage
* @return
*/
public int updateAppMessage(AppMessage appMessage);
/**
*
*
* @param id
* @return
*/
public int deleteAppMessageById(Long id);
/**
*
*
* @param ids
* @return
*/
public int deleteAppMessageByIds(Long[] ids);
}

View File

@ -0,0 +1,61 @@
package com.ruoyi.app.service;
import java.util.List;
import com.ruoyi.app.domain.AppMessage;
/**
* Service
*
* @author wyh
* @date 2024-05-29
*/
public interface IAppMessageService
{
/**
*
*
* @param id
* @return
*/
public AppMessage selectAppMessageById(Long id);
/**
*
*
* @param appMessage
* @return
*/
public List<AppMessage> selectAppMessageList(AppMessage appMessage);
/**
*
*
* @param appMessage
* @return
*/
public int insertAppMessage(AppMessage appMessage);
/**
*
*
* @param appMessage
* @return
*/
public int updateAppMessage(AppMessage appMessage);
/**
*
*
* @param ids
* @return
*/
public int deleteAppMessageByIds(Long[] ids);
/**
*
*
* @param id
* @return
*/
public int deleteAppMessageById(Long id);
}

View File

@ -0,0 +1,124 @@
package com.ruoyi.app.service.impl;
import java.util.List;
import com.ruoyi.app.domain.AppUser;
import com.ruoyi.app.mapper.AppUserMapper;
import com.ruoyi.common.core.utils.DateUtils;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.ruoyi.app.mapper.AppMessageMapper;
import com.ruoyi.app.domain.AppMessage;
import com.ruoyi.app.service.IAppMessageService;
/**
* Service
*
* @author wyh
* @date 2024-05-29
*/
@Service
public class AppMessageServiceImpl implements IAppMessageService
{
@Autowired
private AppMessageMapper appMessageMapper;
@Autowired
private AppUserMapper appUserMapper;
/**
*
*
* @param id
* @return
*/
@Override
public AppMessage selectAppMessageById(Long id)
{
return appMessageMapper.selectAppMessageById(id);
}
/**
*
*
* @param appMessage
* @return
*/
@Override
public List<AppMessage> selectAppMessageList(AppMessage appMessage)
{
return appMessageMapper.selectList(appMessage);
}
/**
*
*
* @param appMessage
* @return
*/
@Override
public int insertAppMessage(AppMessage appMessage)
{
appMessage.setCreateTime(DateUtils.getNowDate());
List<AppUser> appUsers = appUserMapper.selectAppUserList(new AppUser());
for (AppUser appUser : appUsers) {
if (appUser.getPushId() == null) {
continue;
}
HttpClient httpClient = HttpClients.createDefault();
String url = "https://tcb-am7ffkwasxkewhf-3cpy096b83a1.service.tcloudbase.com/urlPush/pushId?pushId=" + appUser.getPushId() + "&content=" + appMessage.getContent();
try {
HttpGet request = new HttpGet(url);
HttpResponse response = httpClient.execute(request);
// Get the response entity as a String
String jsonResponse = EntityUtils.toString(response.getEntity());
System.out.println(jsonResponse);
} catch (Exception e) {
e.printStackTrace();
}
}
return appMessageMapper.insertAppMessage(appMessage);
}
/**
*
*
* @param appMessage
* @return
*/
@Override
public int updateAppMessage(AppMessage appMessage)
{
appMessage.setUpdateTime(DateUtils.getNowDate());
return appMessageMapper.updateAppMessage(appMessage);
}
/**
*
*
* @param ids
* @return
*/
@Override
public int deleteAppMessageByIds(Long[] ids)
{
return appMessageMapper.deleteAppMessageByIds(ids);
}
/**
*
*
* @param id
* @return
*/
@Override
public int deleteAppMessageById(Long id)
{
return appMessageMapper.deleteAppMessageById(id);
}
}

View File

@ -0,0 +1,92 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ruoyi.app.mapper.AppMessageMapper">
<resultMap type="AppMessage" id="AppMessageResult">
<result property="id" column="id" />
<result property="userId" column="user_id" />
<result property="content" column="content" />
<result property="imgUrl" column="img_url" />
<result property="createTime" column="create_time" />
<result property="updateTime" column="update_time" />
<result property="remark" column="remark" />
</resultMap>
<sql id="selectAppMessageVo">
select id, user_id, content, img_url, create_time, update_time, remark from app_message
</sql>
<select id="selectAppMessageList" parameterType="AppMessage" resultMap="AppMessageResult">
<include refid="selectAppMessageVo"/>
<where>
<if test="userId != null "> and user_id = #{userId}</if>
<if test="content != null and content != ''"> and content = #{content}</if>
<if test="imgUrl != null and imgUrl != ''"> and img_url = #{imgUrl}</if>
</where>
</select>
<select id="selectList" parameterType="AppMessage" resultType="AppMessage">
select a.id, a.user_id as "userId", a.content, a.img_url as "imgUrl", a.create_time as "createTime",
u.username as "username",
u.avatar_url as "avatarUrl"
from app_message a
LEFT JOIN app_user u on u.id = a.user_id
<where>
<if test="userId != null "> and a.user_id = #{userId}</if>
<if test="username != null "> and u.username like concat('%',#{username},'%')</if>
<if test="content != null and content != ''"> and a.content like concat('%',#{content},'%')</if>
<if test="imgUrl != null and imgUrl != ''"> and a.img_url = #{imgUrl}</if>
</where>
</select>
<select id="selectAppMessageById" parameterType="Long" resultMap="AppMessageResult">
<include refid="selectAppMessageVo"/>
where id = #{id}
</select>
<insert id="insertAppMessage" parameterType="AppMessage" useGeneratedKeys="true" keyProperty="id">
insert into app_message
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="userId != null">user_id,</if>
<if test="content != null">content,</if>
<if test="imgUrl != null">img_url,</if>
<if test="createTime != null">create_time,</if>
<if test="updateTime != null">update_time,</if>
<if test="remark != null">remark,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="userId != null">#{userId},</if>
<if test="content != null">#{content},</if>
<if test="imgUrl != null">#{imgUrl},</if>
<if test="createTime != null">#{createTime},</if>
<if test="updateTime != null">#{updateTime},</if>
<if test="remark != null">#{remark},</if>
</trim>
</insert>
<update id="updateAppMessage" parameterType="AppMessage">
update app_message
<trim prefix="SET" suffixOverrides=",">
<if test="userId != null">user_id = #{userId},</if>
<if test="content != null">content = #{content},</if>
<if test="imgUrl != null">img_url = #{imgUrl},</if>
<if test="createTime != null">create_time = #{createTime},</if>
<if test="updateTime != null">update_time = #{updateTime},</if>
<if test="remark != null">remark = #{remark},</if>
</trim>
where id = #{id}
</update>
<delete id="deleteAppMessageById" parameterType="Long">
delete from app_message where id = #{id}
</delete>
<delete id="deleteAppMessageByIds" parameterType="String">
delete from app_message where id in
<foreach item="id" collection="array" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper>