222
schangxiang@126.com
2024-12-03 60a4de55deb1aeeb5621028a8f8c732c38027f81
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
// Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
//
// 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
//
// 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
 
namespace Admin.NET.Core.Service;
 
/// <summary>
/// APIJSON服务 🧩
/// </summary>
[ApiDescriptionSettings(Order = 100)]
public class APIJSONService : IDynamicApiController, ITransient
{
    private readonly ISqlSugarClient _db;
    private readonly IdentityService _identityService;
    private readonly TableMapper _tableMapper;
    private readonly SelectTable _selectTable;
 
    public APIJSONService(ISqlSugarClient db,
        IdentityService identityService,
        TableMapper tableMapper)
    {
        _db = db;
        _tableMapper = tableMapper;
        _identityService = identityService;
        _selectTable = new SelectTable(_identityService, _tableMapper, _db);
    }
 
    /// <summary>
    /// 统一查询入口 🔖
    /// </summary>
    /// <param name="jobject"></param>
    /// <remarks>参数:{"[]":{"SYSLOGOP":{}}}</remarks>
    /// <returns></returns>
    [HttpPost("get")]
    [DisplayName("APIJSON统一查询")]
    public JObject Query([FromBody] JObject jobject)
    {
        return _selectTable.Query(jobject);
    }
 
    /// <summary>
    /// 查询 🔖
    /// </summary>
    /// <param name="table"></param>
    /// <param name="jobject"></param>
    /// <returns></returns>
    [HttpPost("get/{table}")]
    [DisplayName("APIJSON查询")]
    public JObject QueryByTable([FromRoute] string table, [FromBody] JObject jobject)
    {
        var ht = new JObject
        {
            { table + "[]", jobject }
        };
 
        // 自动添加总计数量
        if (jobject["query"] != null && jobject["query"].ToString() != "0" && jobject["total@"] == null)
            ht.Add("total@", "");
 
        // 每页最大1000条数据
        if (jobject["count"] != null && int.Parse(jobject["count"].ToString()) > 1000)
            throw Oops.Bah("count分页数量最大不能超过1000");
 
        jobject.Remove("@debug");
 
        var hasTableKey = false;
        var ignoreConditions = new List<string> { "page", "count", "query" };
        var tableConditions = new JObject(); // 表的其它查询条件,比如过滤、字段等
        foreach (var item in jobject)
        {
            if (item.Key.Equals(table, StringComparison.CurrentCultureIgnoreCase))
            {
                hasTableKey = true;
                break;
            }
            if (!ignoreConditions.Contains(item.Key.ToLower()))
                tableConditions.Add(item.Key, item.Value);
        }
 
        foreach (var removeKey in tableConditions)
        {
            jobject.Remove(removeKey.Key);
        }
 
        if (!hasTableKey)
            jobject.Add(table, tableConditions);
 
        return Query(ht);
    }
 
    /// <summary>
    /// 新增 🔖
    /// </summary>
    /// <param name="tables">表对象或数组,若没有传Id则后端生成Id</param>
    /// <returns></returns>
    [HttpPost("add")]
    [DisplayName("APIJSON新增")]
    [UnitOfWork]
    public JObject Add([FromBody] JObject tables)
    {
        var ht = new JObject();
        foreach (var table in tables)
        {
            var talbeName = table.Key.Trim();
            var role = _identityService.GetRole();
            if (!role.Insert.Table.Contains(talbeName, StringComparer.CurrentCultureIgnoreCase))
                throw Oops.Bah($"没权限添加{talbeName}");
 
            JToken result;
            // 批量插入
            if (table.Value is JArray)
            {
                var ids = new List<object>();
                foreach (var record in table.Value)
                {
                    var cols = record.ToObject<JObject>();
                    var id = _selectTable.InsertSingle(talbeName, cols, role);
                    ids.Add(id);
                }
                result = JToken.FromObject(new { id = ids, count = ids.Count });
            }
            // 单条插入
            else
            {
                var cols = table.Value.ToObject<JObject>();
                var id = _selectTable.InsertSingle(talbeName, cols, role);
                result = JToken.FromObject(new { id });
            }
            ht.Add(talbeName, result);
        }
        return ht;
    }
 
    /// <summary>
    /// 更新(只支持Id作为条件) 🔖
    /// </summary>
    /// <param name="tables">支持多表、多Id批量更新</param>
    /// <returns></returns>
    [HttpPost("update")]
    [DisplayName("APIJSON更新")]
    [UnitOfWork]
    public JObject Edit([FromBody] JObject tables)
    {
        var ht = new JObject();
        foreach (var table in tables)
        {
            var tableName = table.Key.Trim();
            var role = _identityService.GetRole();
            var count = _selectTable.UpdateSingleTable(tableName, table.Value, role);
            ht.Add(tableName, JToken.FromObject(new { count }));
        }
        return ht;
    }
 
    /// <summary>
    /// 删除(支持非Id条件、支持批量) 🔖
    /// </summary>
    /// <param name="tables"></param>
    /// <returns></returns>
    [HttpPost("delete")]
    [DisplayName("APIJSON删除")]
    [UnitOfWork]
    public JObject Delete([FromBody] JObject tables)
    {
        var ht = new JObject();
        var role = _identityService.GetRole();
        foreach (var table in tables)
        {
            var talbeName = table.Key.Trim();
            if (role.Delete == null || role.Delete.Table == null)
                throw Oops.Bah("delete权限未配置");
            if (!role.Delete.Table.Contains(talbeName, StringComparer.CurrentCultureIgnoreCase))
                throw Oops.Bah($"没权限删除{talbeName}");
            //if (!value.ContainsKey("id"))
            //    throw Oops.Bah("未传主键id");
 
            var value = JObject.Parse(table.Value.ToString());
            var sb = new StringBuilder(100);
            var parameters = new List<SugarParameter>();
            foreach (var f in value)
            {
                if (f.Value is JArray)
                {
                    sb.Append($"{f.Key} in (@{f.Key}) and ");
                    var paraArray = FuncList.TransJArrayToSugarPara(f.Value);
                    parameters.Add(new SugarParameter($"@{f.Key}", paraArray));
                }
                else
                {
                    sb.Append($"{f.Key}=@{f.Key} and ");
                    parameters.Add(new SugarParameter($"@{f.Key}", FuncList.TransJObjectToSugarPara(f.Value)));
                }
            }
            if (!parameters.Any())
                throw Oops.Bah("请输入删除条件");
 
            var whereSql = sb.ToString().TrimEnd(" and ");
            var count = _db.Deleteable<object>().AS(talbeName).Where(whereSql, parameters).ExecuteCommand(); // 无实体删除
            value.Add("count", count); // 命中数量
            ht.Add(talbeName, value);
        }
        return ht;
    }
}