|
@@ -0,0 +1,130 @@
|
|
1
|
+package com.njyunzhi.invoice.service.impl;
|
|
2
|
+
|
|
3
|
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
4
|
+import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
|
|
5
|
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
|
6
|
+import com.baomidou.mybatisplus.core.metadata.TableInfo;
|
|
7
|
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
8
|
+import com.baomidou.mybatisplus.extension.toolkit.SqlHelper;
|
|
9
|
+import com.njyunzhi.invoice.service.IBaseService;
|
|
10
|
+
|
|
11
|
+import java.io.Serializable;
|
|
12
|
+import java.time.LocalDateTime;
|
|
13
|
+import java.util.List;
|
|
14
|
+
|
|
15
|
+public class BaseServiceImpl<M extends BaseMapper<T>, T> extends ServiceImpl<M, T> implements IBaseService<T> {
|
|
16
|
+ @Override
|
|
17
|
+ public boolean removeLogicById(Serializable id) {
|
|
18
|
+
|
|
19
|
+ TableInfo tableInfo = SqlHelper.table(currentModelClass());
|
|
20
|
+ UpdateWrapper<T> updateWrapper = new UpdateWrapper<>();
|
|
21
|
+ updateWrapper.set("status", -1)
|
|
22
|
+ .eq(tableInfo.getKeyColumn(), id);
|
|
23
|
+
|
|
24
|
+ return update(updateWrapper);
|
|
25
|
+ }
|
|
26
|
+
|
|
27
|
+ @Override
|
|
28
|
+ public boolean removeLogicByUser(Serializable id, String userId, String userType) {
|
|
29
|
+
|
|
30
|
+ TableInfo tableInfo = SqlHelper.table(currentModelClass());
|
|
31
|
+ UpdateWrapper<T> updateWrapper = new UpdateWrapper<>();
|
|
32
|
+ updateWrapper.set("status", -1)
|
|
33
|
+ .set("delete_user_type", userType)
|
|
34
|
+ .set("delete_user", userId)
|
|
35
|
+ .set("delete_date", LocalDateTime.now())
|
|
36
|
+ .eq(tableInfo.getKeyColumn(), id);
|
|
37
|
+
|
|
38
|
+ return update(updateWrapper);
|
|
39
|
+ }
|
|
40
|
+
|
|
41
|
+ @Override
|
|
42
|
+ public boolean removeBy(String column, Object value, boolean notDelete) {
|
|
43
|
+ if (notDelete) {
|
|
44
|
+ UpdateWrapper<T> updateWrapper = new UpdateWrapper<>();
|
|
45
|
+ updateWrapper.set("status", -1);
|
|
46
|
+ updateWrapper.eq(column, value);
|
|
47
|
+ return update(updateWrapper);
|
|
48
|
+ } else {
|
|
49
|
+ QueryWrapper<T> queryWrapper = new QueryWrapper<>();
|
|
50
|
+ queryWrapper.eq(column, value);
|
|
51
|
+ return remove(queryWrapper);
|
|
52
|
+ }
|
|
53
|
+ }
|
|
54
|
+
|
|
55
|
+ @Override
|
|
56
|
+ public boolean canAccessData(Serializable id, String userId) {
|
|
57
|
+ TableInfo tableInfo = SqlHelper.table(currentModelClass());
|
|
58
|
+
|
|
59
|
+ String t = tableInfo.getTableName();
|
|
60
|
+// String k = tableInfo.getKeyColumn();
|
|
61
|
+ String kAlias = t + ".org_id";
|
|
62
|
+
|
|
63
|
+ String joinSQL = "INNER JOIN sys_user_data_scope s ON ( "+ kAlias +" = s.org_id OR "+t+".create_user = s.user_id )";
|
|
64
|
+ String whereSQL = "WHERE " + kAlias + " = '"+ id +"' AND s.user_id = '" + userId + "'";
|
|
65
|
+
|
|
66
|
+ String sql = joinSQL + " " + whereSQL;
|
|
67
|
+
|
|
68
|
+ QueryWrapper<T> wrapper = new QueryWrapper<>();
|
|
69
|
+ wrapper.last(sql);
|
|
70
|
+ return count(wrapper) > 0;
|
|
71
|
+ }
|
|
72
|
+
|
|
73
|
+ @Override
|
|
74
|
+ public boolean remvoeWithDataScope(Serializable id, String userId) {
|
|
75
|
+ TableInfo tableInfo = SqlHelper.table(currentModelClass());
|
|
76
|
+
|
|
77
|
+ String t = tableInfo.getTableName();
|
|
78
|
+ String k = tableInfo.getKeyColumn();
|
|
79
|
+ String kAlias = t + "." + k;
|
|
80
|
+
|
|
81
|
+ String joinSQL = "INNER JOIN sys_user_data_scope s ON ( "+ kAlias +" = s.org_id OR "+t+".create_user = s.user_id )";
|
|
82
|
+ String setSQL = "SET status = -1";
|
|
83
|
+ String whereSQL = "WHERE " + kAlias + " = '"+ id +"' AND s.user_id = '" + userId + "'";
|
|
84
|
+
|
|
85
|
+ String sql = joinSQL + " " + setSQL + " " + whereSQL;
|
|
86
|
+
|
|
87
|
+ UpdateWrapper<T> wrapper = new UpdateWrapper<>();
|
|
88
|
+ wrapper.last(sql);
|
|
89
|
+ return update(wrapper);
|
|
90
|
+ }
|
|
91
|
+
|
|
92
|
+ @Override
|
|
93
|
+ public int countBy(String column, Object value, boolean notDelete) {
|
|
94
|
+ QueryWrapper<T> queryWrapper = new QueryWrapper<>();
|
|
95
|
+ queryWrapper.eq(column, value);
|
|
96
|
+ queryWrapper.gt(notDelete, "status", -1);
|
|
97
|
+
|
|
98
|
+ return (int) count(queryWrapper);
|
|
99
|
+ }
|
|
100
|
+
|
|
101
|
+ @Override
|
|
102
|
+ public T getByButNot(String column, Object value, String col, Object val, boolean notDelete) {
|
|
103
|
+ QueryWrapper<T> queryWrapper = new QueryWrapper<>();
|
|
104
|
+ queryWrapper.eq(column, value);
|
|
105
|
+ queryWrapper.ne(col, val);
|
|
106
|
+ queryWrapper.gt(notDelete, "status", -1);
|
|
107
|
+ queryWrapper.last("limit 1");
|
|
108
|
+
|
|
109
|
+ return getOne(queryWrapper);
|
|
110
|
+ }
|
|
111
|
+
|
|
112
|
+ @Override
|
|
113
|
+ public T getExistBy(String column, Object value, boolean normal, boolean notDelete) {
|
|
114
|
+ QueryWrapper<T> queryWrapper = new QueryWrapper<>();
|
|
115
|
+ queryWrapper.eq(column, value);
|
|
116
|
+ queryWrapper.eq(normal, "status", 1);
|
|
117
|
+ queryWrapper.gt(notDelete, "status", -1);
|
|
118
|
+ queryWrapper.last("limit 1");
|
|
119
|
+ return getOne(queryWrapper);
|
|
120
|
+ }
|
|
121
|
+
|
|
122
|
+ @Override
|
|
123
|
+ public List<T> getListBy(String column, Object value, boolean normal, boolean notDelete) {
|
|
124
|
+ QueryWrapper<T> queryWrapper = new QueryWrapper<>();
|
|
125
|
+ queryWrapper.eq(column, value);
|
|
126
|
+ queryWrapper.eq(normal, "status", 1);
|
|
127
|
+ queryWrapper.gt(notDelete, "status", -1);
|
|
128
|
+ return list(queryWrapper);
|
|
129
|
+ }
|
|
130
|
+}
|