Initial_commit_SecMPS_v2

This commit is contained in:
2026-05-15 23:22:48 +08:00
commit 23ea4fe05f
13830 changed files with 298675 additions and 0 deletions

View File

@@ -0,0 +1,27 @@
/*
*Authorjxx
*Contact283591387@qq.com
*代码由框架生成,此处任何更改都可能导致被代码生成器覆盖
*所有业务编写全部应在Partial文件夹下Demo_OrderListService与IDemo_OrderListService中编写
*/
using VolPro.DbTest.IRepositories;
using VolPro.DbTest.IServices;
using VolPro.Core.BaseProvider;
using VolPro.Core.Extensions.AutofacManager;
using VolPro.Entity.DomainModels;
namespace VolPro.DbTest.Services
{
public partial class Demo_OrderListService : ServiceBase<Demo_OrderList, IDemo_OrderListRepository>
, IDemo_OrderListService, IDependency
{
public Demo_OrderListService(IDemo_OrderListRepository repository)
: base(repository)
{
Init(repository);
}
public static IDemo_OrderListService Instance
{
get { return AutofacContainerModule.GetService<IDemo_OrderListService>(); } }
}
}

View File

@@ -0,0 +1,27 @@
/*
*Authorjxx
*Contact283591387@qq.com
*代码由框架生成,此处任何更改都可能导致被代码生成器覆盖
*所有业务编写全部应在Partial文件夹下Demo_OrderService与IDemo_OrderService中编写
*/
using VolPro.DbTest.IRepositories;
using VolPro.DbTest.IServices;
using VolPro.Core.BaseProvider;
using VolPro.Core.Extensions.AutofacManager;
using VolPro.Entity.DomainModels;
namespace VolPro.DbTest.Services
{
public partial class Demo_OrderService : ServiceBase<Demo_Order, IDemo_OrderRepository>
, IDemo_OrderService, IDependency
{
public Demo_OrderService(IDemo_OrderRepository repository)
: base(repository)
{
Init(repository);
}
public static IDemo_OrderService Instance
{
get { return AutofacContainerModule.GetService<IDemo_OrderService>(); } }
}
}

View File

@@ -0,0 +1,41 @@
/*
*所有关于Demo_OrderList类的业务代码应在此处编写
*可使用repository.调用常用方法获取EF/Dapper等信息
*如果需要事务请使用repository.DbContextBeginTransaction
*也可使用DBServerProvider.手动获取数据库相关信息
*用户信息、权限、角色等使用UserContext.Current操作
*Demo_OrderListService对增、删、改查、导入、导出、审核业务代码扩展参照ServiceFunFilter
*/
using VolPro.Core.BaseProvider;
using VolPro.Core.Extensions.AutofacManager;
using VolPro.Entity.DomainModels;
using System.Linq;
using VolPro.Core.Utilities;
using System.Linq.Expressions;
using VolPro.Core.Extensions;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.AspNetCore.Http;
using VolPro.DbTest.IRepositories;
namespace VolPro.DbTest.Services
{
public partial class Demo_OrderListService
{
private readonly IHttpContextAccessor _httpContextAccessor;
private readonly IDemo_OrderListRepository _repository;//访问数据库
[ActivatorUtilitiesConstructor]
public Demo_OrderListService(
IDemo_OrderListRepository dbRepository,
IHttpContextAccessor httpContextAccessor
)
: base(dbRepository)
{
_httpContextAccessor = httpContextAccessor;
_repository = dbRepository;
//多租户会用到这init代码其他情况可以不用
//base.Init(dbRepository);
}
}
}

View File

@@ -0,0 +1,156 @@
/*
*所有关于Demo_Order类的业务代码应在此处编写
*可使用repository.调用常用方法获取EF/Dapper等信息
*如果需要事务请使用repository.DbContextBeginTransaction
*也可使用DBServerProvider.手动获取数据库相关信息
*用户信息、权限、角色等使用UserContext.Current操作
*Demo_OrderService对增、删、改查、导入、导出、审核业务代码扩展参照ServiceFunFilter
*/
using VolPro.Core.BaseProvider;
using VolPro.Core.Extensions.AutofacManager;
using VolPro.Entity.DomainModels;
using System.Linq;
using VolPro.Core.Utilities;
using System.Linq.Expressions;
using VolPro.Core.Extensions;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.AspNetCore.Http;
using VolPro.DbTest.IRepositories;
using System.Diagnostics.CodeAnalysis;
using SqlSugar;
using VolPro.Core.DbSqlSugar;
namespace VolPro.DbTest.Services
{
public partial class Demo_OrderService
{
private readonly IHttpContextAccessor _httpContextAccessor;
private readonly IDemo_OrderRepository _repository;//访问数据库
[ActivatorUtilitiesConstructor]
public Demo_OrderService(
IDemo_OrderRepository dbRepository,
IHttpContextAccessor httpContextAccessor
)
: base(dbRepository)
{
_httpContextAccessor = httpContextAccessor;
_repository = dbRepository;
//多租户会用到这init代码其他情况可以不用
//base.Init(dbRepository);
}
public override PageGridData<Demo_Order> GetPageData(PageDataOptions options)
{
QueryRelativeExpression = (ISugarQueryable<Demo_Order> queryable) =>
{
if (options.Value != null)
{
switch (options.Value.GetInt())
{
//新订单
case 1:
queryable = queryable = queryable.Where(c => c.OrderType == 1);
break;
//采购订单
case 2:
queryable = queryable = queryable.Where(c => c.OrderType == 2);
break;
//退货订单
case 3:
queryable = queryable = queryable.Where(c => c.OrderType == 3);
break;
default:
break;
}
}
// queryable = queryable = queryable.Where(c => c.OrderType == options.Value.GetInt());
//当前用户只能操作自己(与下级角色)创建的数据,如:查询、删除、修改等操作
//IQueryable<int> userQuery = RoleContext.GetCurrentAllChildUser();
//queryable = queryable.Where(x => x.CreateID == UserContext.Current.UserId || userQuery.Contains(x.CreateID ?? 0));
return queryable;
};
//查询table界面显示求和
SummaryExpress = (ISugarQueryable<Demo_Order> queryable) =>
{
//求和这里不需要group
return queryable.Select(x => new
{
//注意大小写和数据库字段大小写一样
TotalPrice =SqlFunc.AggregateSum(x.TotalPrice),
TotalQty = SqlFunc.AggregateSum(x.TotalQty)
})
.FirstOrDefault();
};
return base.GetPageData(options);
}
/// <summary>
/// 设置弹出框明细表的合计信息
/// </summary>
/// <typeparam name="Detail"></typeparam>
/// <param name="queryeable"></param>
/// <returns></returns>
protected override object GetDetailSummary<Detail>(ISugarQueryable<Detail> queryeable)
{
return ((ISugarQueryable<Demo_OrderList>)queryeable).Select(x => new
{
//Weight/Qty注意大小写和数据库字段大小写一样
Price = SqlFunc.AggregateAvg(x.Price),
Qty = SqlFunc.AggregateSum(x.Qty)
}).FirstOrDefault();
}
public override WebResponseContent Update(SaveModel saveModel)
{
return base.Update(saveModel);
}
public override WebResponseContent Add(SaveModel saveDataModel)
{
saveDataModel.MainData["OrderNo"] = "111";
WebResponseContent webResponse = new WebResponseContent();
// 在保存数据库前的操作,所有数据都验证通过了,这一步执行完就执行数据库保存
AddOnExecuting = (Demo_Order order, object list) =>
{
// order.OrderNo = GetOrderNo();
return webResponse.OK();
};
return base.Add(saveDataModel);
}
/// <summary>
/// 自动生成订单号
/// </summary>
/// <returns></returns>
public string GetOrderNo()
{
//lock/redis自增
DateTime dateNow = (DateTime)DateTime.Now.ToString("yyyy-MM-dd").GetDateTime();
//查询当天最新的订单号
string orderNo = repository.FindAsIQueryable(x => x.CreateDate > dateNow)
.OrderByDescending(x => x.OrderNo)
.Select(s => s.OrderNo)
.FirstOrDefault();
string rule = $"D{DateTime.Now.ToString("yyyyMMdd")}";
if (string.IsNullOrEmpty(orderNo))
{
rule += "00001";
}
else
{
rule += (orderNo.Substring(orderNo.Length - 5).GetInt() + 1).ToString("00000");
}
return rule;
}
}
}