|  |  |  | 
|---|
|  |  |  | using System.Text; | 
|---|
|  |  |  | using System.Threading.Tasks; | 
|---|
|  |  |  | using WIDESEA_Core.Attributes; | 
|---|
|  |  |  | using WIDESEA_Core.CodeConfigEnum; | 
|---|
|  |  |  | using WIDESEA_Core.Const; | 
|---|
|  |  |  | using WIDESEA_Core.DB; | 
|---|
|  |  |  | using WIDESEA_Core.DB.Models; | 
|---|
|  |  |  | 
|---|
|  |  |  | CodeRuleAttribute? codeRuleAttribute = propertyInfo.GetCustomAttribute<CodeRuleAttribute>(); | 
|---|
|  |  |  | if (codeRuleAttribute != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | SqlSugarClient sugarClient = new SqlSugarClient(new ConnectionConfig | 
|---|
|  |  |  | if (propertyInfo.GetValue(entityInfo.EntityValue) == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ConfigId = MainDb.CurrentDbConnId, | 
|---|
|  |  |  | ConnectionString = DBContext.GetMainConnectionDb().Connection, | 
|---|
|  |  |  | IsAutoCloseConnection = true, | 
|---|
|  |  |  | DbType = MainDb.DbType, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | dynamic ruleConfig = sugarClient.Queryable(MainDb.CodeRuleConfig, "x").Where(nameof(CodeRuleAttribute.RuleCode), "=", codeRuleAttribute.RuleCode.ToString()).First(); | 
|---|
|  |  |  | if (ruleConfig != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | string code = CreateCodeByRule(ruleConfig, sugarClient); | 
|---|
|  |  |  | propertyInfo.SetValue(entityInfo.EntityValue, code, null); | 
|---|
|  |  |  | SqlSugarClient sugarClient = new SqlSugarClient(new ConnectionConfig | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ConfigId = MainDb.CurrentDbConnId, | 
|---|
|  |  |  | ConnectionString = DBContext.GetMainConnectionDb().Connection, | 
|---|
|  |  |  | IsAutoCloseConnection = true, | 
|---|
|  |  |  | DbType = MainDb.DbType, | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | dynamic ruleConfig = sugarClient.Queryable(MainDb.CodeRuleConfig, "x").Where(nameof(CodeRuleAttribute.RuleCode), "=", codeRuleAttribute.RuleCode.ToString()).First(); | 
|---|
|  |  |  | if (ruleConfig != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | string code = CreateCodeByRule(ruleConfig, sugarClient); | 
|---|
|  |  |  | propertyInfo.SetValue(entityInfo.EntityValue, code, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | SequenceAttirbute? sequenceAttirbute = propertyInfo.GetCustomAttribute<SequenceAttirbute>(); | 
|---|
|  |  |  | SequenceAttribute? sequenceAttirbute = propertyInfo.GetCustomAttribute<SequenceAttribute>(); | 
|---|
|  |  |  | if (sequenceAttirbute != null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (propertyInfo.GetValue(entityInfo.EntityValue)?.ObjToInt() <= 0) | 
|---|
|  |  |  | 
|---|
|  |  |  | int seq = sugarClient.Ado.GetScalar($"SELECT NEXT VALUE FOR {sequenceAttirbute.SequenceName}").ObjToInt(); | 
|---|
|  |  |  | propertyInfo.SetValue(entityInfo.EntityValue, seq, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (entityInfo.EntityValue is BaseEntity baseEntity) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | // 鏂板鎿嶄綔 | 
|---|
|  |  |  | if (entityInfo.OperationType == DataFilterType.InsertByObject) | 
|---|
|  |  |  | if (entityInfo.OperationType == DataFilterType.InsertByObject && entityInfo.PropertyName == nameof(BaseEntity.CreateDate)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (entityInfo.PropertyName == nameof(BaseEntity.CreateDate)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | baseEntity.CreateDate = DateTime.Now; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | baseEntity.CreateDate = DateTime.Now; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (entityInfo.OperationType == DataFilterType.UpdateByObject) | 
|---|
|  |  |  | if (entityInfo.OperationType == DataFilterType.UpdateByObject && entityInfo.PropertyName == nameof(BaseEntity.ModifyDate)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | baseEntity.ModifyDate = DateTime.Now; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (App.User?.UserId > 0) | 
|---|
|  |  |  | //if (App.User?.UserId > 0) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | switch (entityInfo.OperationType) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private static void UpdateConfigData(dynamic ruleConfig) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | if (entityInfo.EntityValue is IBaseHistoryEntity baseHistoryEntity) | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (entityInfo.OperationType == DataFilterType.InsertByObject && entityInfo.PropertyName == nameof(IBaseHistoryEntity.InsertTime)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | baseHistoryEntity.InsertTime = DateTime.Now; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | ruleConfig.ModifyDate = DateTime.Now; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | code = ruleConfig.Format; | 
|---|
|  |  |  | code = code.Replace($"[{CodeFormat.YYYY}]", now.Year.ToString().PadLeft(4, '0')); | 
|---|
|  |  |  | code = code.Replace($"[{CodeFormat.MM}]", now.Month.ToString().PadLeft(2, '0')); | 
|---|
|  |  |  | code = code.Replace($"[{CodeFormat.DD}]", now.Day.ToString().PadLeft(2, '0')); | 
|---|
|  |  |  | code = code.Replace($"[{CodeFormat.ST}]", ruleConfig.StartStr.ToString()); | 
|---|
|  |  |  | code = code.Replace($"[{CodeFormat.NUM}]", ruleConfig.CurrentVal.ToString().PadLeft(ruleConfig.Length ?? 0, '0')); | 
|---|
|  |  |  | code = code.Replace($"[{CodeFormatTypeEnum.YYYY}]", now.Year.ToString().PadLeft(4, '0')); | 
|---|
|  |  |  | code = code.Replace($"[{CodeFormatTypeEnum.MM}]", now.Month.ToString().PadLeft(2, '0')); | 
|---|
|  |  |  | code = code.Replace($"[{CodeFormatTypeEnum.DD}]", now.Day.ToString().PadLeft(2, '0')); | 
|---|
|  |  |  | code = code.Replace($"[{CodeFormatTypeEnum.ST}]", ruleConfig.StartStr.ToString()); | 
|---|
|  |  |  | code = code.Replace($"[{CodeFormatTypeEnum.NUM}]", ruleConfig.CurrentVal.ToString().PadLeft(ruleConfig.Length ?? 0, '0')); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | 
|---|
|  |  |  | sugarClient.Updateable(keyValuePairs).AS(MainDb.CodeRuleConfig).WhereColumns(nameof(ruleConfig.Id)).ExecuteCommand(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return code; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private static string GetWholeSql(SugarParameter[] paramArr, string sql) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | foreach (var param in paramArr) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | sql = sql.Replace(param.ParameterName, $@"'{param.Value.ObjToString()}'"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return sql; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private static string GetParas(SugarParameter[] pars) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | string key = "銆怱QL鍙傛暟銆戯細"; | 
|---|
|  |  |  | foreach (var param in pars) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | key += $"{param.ParameterName}:{param.Value}\n"; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return key; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|