Blame view

sys/Hh.Mes.Service/WebService/Configure/SysCompanyService.cs 13 KB
赖素文 authored
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
using Hh.Mes.Common.config;
using Hh.Mes.Common.log;
using Hh.Mes.Pojo.System;
using Hh.Mes.POJO.Entity;
using Hh.Mes.POJO.Response;
using Hh.Mes.Service.Repository;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Data;
using Hh.Mes.Common;
using System.Linq;

namespace Hh.Mes.Service.Configure
{
    /// <summary>
    /// 公司设置
    /// </summary>
    public class SysCompanyService : RepositorySqlSugar<base_company>
    {
        /// <summary>
        /// 新增  
        /// </summary>
        /// <returns></returns>
        public dynamic Ins(base_company model)
        {
            var response = new Response();
            return ExceptionsHelp.Instance.ExecuteT(() =>
            {
32
                if (Context.Queryable<base_company>().Where(x => x.isDelete == SystemVariable.AddOrUpdateFlag).Count() > 0)
赖素文 authored
33
34
35
36
37
38
39
                {
                    response.Status = false;
                    response.Message = "新增失败:公司默认只有一条,请不要重复添加!";
                    return response;
                }
                model.createBy = sysWebUser.Name;
                model.createTime = DateTime.Now;
40
                model.isDelete = SystemVariable.AddOrUpdateFlag;
赖素文 authored
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
                if (!Add(model))
                {
                    response.Status = false;
                    response.Message = SystemVariable.dataActionError;
                }
                return response;
            });
        }


        /// <summary>
        /// 根据主键数组 删除
        /// </summary>
        public dynamic DeleteByIds(int[] ids)
        {
            var response = new Response();
            return ExceptionsHelp.Instance.ExecuteT(() =>
            {
                if (GetSysCompanyOne() != null)
                {
                    response.Status = false;
                    response.Message = "删除失败:公司默认需要有一条数据";
                    return response;
                }

                if (Context.Deleteable<base_company>().In(ids).ExecuteCommand() == 0)
                {
                    response.Status = false;
                    response.Message = SystemVariable.dataActionError;
                }
                return response;
            });
        }

        /// <summary>
        /// 更新
        /// </summary>
        public dynamic UpdataById(base_company model)
        {
            var response = new Response();
            return ExceptionsHelp.Instance.ExecuteT(() =>
            {
                model.updateBy = sysWebUser.Name;
                model.updateTime = DateTime.Now;
                if (!Update(model))
                {
                    response.Status = false;
                    response.Message = SystemVariable.dataActionError;
                }
                return response;
            });
        }

        /// <summary>
        /// 返回公司表第一条数据
        /// </summary>
        /// <returns></returns>
        public base_company GetSysCompanyOne()
        {
100
            return Context.Queryable<base_company>().Take(1).First(x => x.isDelete == SystemVariable.AddOrUpdateFlag);
赖素文 authored
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
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
        }

        public List<sys_File> GetSysFile(int id)
        {
            var sql = string.Format("select * from sys_file where targetId={0}", id);

            var files = Context.Ado.SqlQuery<sys_File>(sql);
            return files;
        }



        /// <summary>
        ///  获取字典 select * from[dbo].[sys_dict_data] where dictType = 'url'
        /// </summary>
        /// <param name="dictLabel"></param>
        /// <param name="dictType">类型</param>
        /// <returns>返回dictValue 字段值</returns>
        public override string GetDictionaryDictValue(string dictLabel, string dictType = "GetUrl")
        {
            return Context.Queryable<sys_dict_data>().With(SqlWith.NoLock).Where(x => x.dictType == dictType && x.dictLabel == dictLabel).First()?.dictValue;
        }

        public dynamic Upload(IFormFileCollection file, IHostingEnvironment environment, sys_File model)
        {
            var response = new Response();
            return ExceptionsHelp.Instance.ExecuteT(() =>
            {
                List<sys_File> sysFiles = new List<sys_File>
                {
                    model
                };
                var result = UploadFile(file, environment, sysFiles);
                if (!result)
                {
                    response.Status = false;
                    response.Message = SystemVariable.dataActionError;
                }
                return response;
            });
        }


        /// <summary>
        /// 未完成工单信息
        /// </summary>
        /// <returns></returns>
        public dynamic UnfinishedOrderInfo()
        {
            var response = new Response();
            return ExceptionsHelp.Instance.ExecuteT(() =>
            {
                response.Status = false;
                double Percentage = Convert.ToDouble(AppSettings.GetAppSeting("UnfinishedOrderPercentage").Substring(0, AppSettings.GetAppSeting("UnfinishedOrderPercentage").IndexOf("%")));
                //#region 今日任务
                //var TodayUnfinishedOrderList = Context.Queryable<weld_detail_work_order>().Where(x => x.State < (int)EnumWelDetailStatus.释放完成 && SqlFunc.DateIsSame(x.createTime, DateTime.Now)).ToList();
                //var TodayOrderList = Context.Queryable<weld_detail_work_order>().Where(x => SqlFunc.DateIsSame(x.createTime, DateTime.Now)).ToList();

                //response.Message = $"今日任务未完成数:<span>【{TodayUnfinishedOrderList.Count}】</span>,今日任务数:<span>【{TodayOrderList.Count}】</span>,</br></br>";
                //if (TodayOrderList.Count != 0 && TodayUnfinishedOrderList.Count != 0)
                //    response.Message += $"今日任务未完成百分比:<span>【{((double)TodayUnfinishedOrderList.Count / (double)TodayOrderList.Count).ToString("0.0%")}】</span>。</br></br>";
                //else
                //    response.Message += $"今日任务未完成百分比:<span>【0.0%】</span>。</br></br>";
                //if (((double)TodayUnfinishedOrderList.Count / (double)TodayOrderList.Count) * 100 > Percentage)
                //{
                //    response.Status = true;
                //}
                //#endregion

                //#region 目前总任务
                //var AllUnfinishedOrderList = Context.Queryable<weld_detail_work_order>().Where(x => x.State < (int)EnumWelDetailStatus.释放完成 && x.createTime < Convert.ToDateTime(DateTime.Now.AddDays(1).ToString("yyyy-MM-dd"))).ToList();
                //var AllOrderList = Context.Queryable<weld_detail_work_order>().Where(x => x.createTime < Convert.ToDateTime(DateTime.Now.AddDays(1).ToString("yyyy-MM-dd"))).ToList();

                //response.Message += $"目前总任务未完成数:<span>【{AllUnfinishedOrderList.Count}】</span>,目前总任务数:<span>【{AllOrderList.Count}】</span>,</br></br>";

                //if (AllUnfinishedOrderList.Count != 0 && AllOrderList.Count != 0)
                //    response.Message += $"目前总任务未完成百分比:<span>【{((double)AllUnfinishedOrderList.Count / (double)AllOrderList.Count).ToString("0.0%")}】</span>。</br></br>";
                //else
                //    response.Message += $"目前总任务未完成百分比:<span>【0.0%】</span>。</br></br>";
                //if (((double)AllUnfinishedOrderList.Count / (double)AllOrderList.Count) * 100 > Percentage)
                //{
                //    response.Status = true;
                //}
                //#endregion

                return response;
            });
        }

        /// <summary>
        /// 主页面错误信息提示
        /// </summary>
        public dynamic LogTips()
        {
            var response = new Response();
            return ExceptionsHelp.Instance.ExecuteT(() =>
            {
                #region cpu,硬盘,内存
                var tempServerLog = string.Empty;//"cpu 使用率:80%,内存使用率:80%,C盘使用率:80%,"
                var cpu = ComputerHelp.GetCpuUsage();
                if (int.TryParse(cpu.Replace("%", ""), out int cpuUsage) && cpuUsage >= 80)
                {
                    tempServerLog += $"cpu 使用率:{cpu};";
                }
                var memory = ComputerHelp.GetMemery();
                if (int.TryParse(memory.Item4.Replace("%", ""), out int memoryUsage) && memoryUsage >= 80)
                {
                    tempServerLog += $"内存 使用率:{memory.Item4};";
                }
                var disk = ComputerHelp.GetDriveInfos();
                var driveInfos = disk.Where(x => ((x.TotalSize - x.TotalFreeSpace) * 100 / x.TotalSize) >= 80).Select(x => new
                {
                    dirName = x.Name,
                    usage = ((x.TotalSize - x.TotalFreeSpace) * 100 / x.TotalSize).ToString("N1") + "%"
                }).ToList();
                foreach (var item in driveInfos)
                {
                    tempServerLog += $"{item.dirName}盘使用率:{item.usage};";
                }
                #endregion

                //接口日志
                var log = @" select count(1) as total from sys_interface_log t (nolock) 
                             where t.flag is null 
225
                             and t.response NOT LIKE '%200%'
赖素文 authored
226
227
228
229
230
231
232
233
                             --and t.createTime>=convert(varchar(15),getdate(),111)
                             --and t.createTime<convert(varchar(15),DATEADD(day,1,getdate()),111)
                             --and (t.method='POST' or t.method='post') 
                             --and (t.response like '%500%' or t.response like '%由于连接%' )

                             select count(1) as total from sys_job_log t (nolock) 
                             where t.flag is null 
                             --and t.createTime>=convert(varchar(15),getdate(),111)
234
235
236
237
238
239
240
241
242
                             --and t.createTime<convert(varchar(15),DATEADD(day,1,getdate()),111)

                              select count(1) as total from sys_interface_log t (nolock) 
                             where t.flag is null and [system] ='app Android'
                             and t.response NOT LIKE '%200%'

                              select count(1) as total from sys_interface_log t (nolock) 
                             where t.flag is null and [system] ='api' and [type]  like 'API%'
                             and t.response NOT LIKE '%200%'";
赖素文 authored
243
244
245
246
247
248

                var ds = Context.Ado.GetDataSetAll(log);
                var interLog = ds.Tables[0].Rows[0]["total"].ToString();
                if (interLog == "0") interLog = "";
                var jobLog = ds.Tables[1].Rows[0]["total"].ToString();
                if (jobLog == "0") jobLog = "";
249
250
251
252
                var pdaLog = ds.Tables[2].Rows[0]["total"].ToString();
                if (pdaLog == "0") pdaLog = "";
                var upstreamLog = ds.Tables[3].Rows[0]["total"].ToString();
                if (upstreamLog == "0") upstreamLog = "";
赖素文 authored
253
254
255
256
257
258
                response.Result = new
                {
                    interLog,

                    jobLog,
259
260
261
262
                    pdaLog,

                    upstreamLog,
赖素文 authored
263
264
265
266
267
268
269
270
271
272
273
                    serverLog = string.IsNullOrWhiteSpace(tempServerLog) ? "" : tempServerLog
                };
                return response;
            });
        }

        public dynamic UpdateLogTips(string flag)
        {
            var response = new Response();
            return ExceptionsHelp.Instance.ExecuteT(() =>
            {
274
                if (flag == "inter")
赖素文 authored
275
276
277
                {
                    string sql = "update sys_interface_log set flag=1 where flag is null";
                    var result = base.Context.Ado.ExecuteCommand(sql);
278
                    return result > 0 ? response.ResponseSuccess() : response.ResponseError();
赖素文 authored
279
280
281
282
                }
                else if (flag == "job")
                {
                    string sql = "update sys_job_log set flag=1 where flag is null";
283
284
285
286
287
288
289
290
291
292
293
294
295
296
                    var result = base.Context.Ado.ExecuteCommand(sql);
                    return result > 0 ? response.ResponseSuccess() : response.ResponseError();
                }
                else if (flag == "upstream")
                {
                    string sql = "update sys_interface_log set flag=1 where flag is null and [system] ='api' and [type]  like 'API%'";
                    var result = base.Context.Ado.ExecuteCommand(sql);
                    return result > 0 ? response.ResponseSuccess() : response.ResponseError();
                }
                else if (flag == "pda")
                {
                    string sql = "update sys_interface_log set flag=1 where flag is null and [system] ='app Android'";
                    var result = base.Context.Ado.ExecuteCommand(sql);
                    return result > 0 ? response.ResponseSuccess() : response.ResponseError();
赖素文 authored
297
298
299
300
301
302
303
                }
                return response;
            });
        }

    }
}