Compare commits

..

No commits in common. "de3bd9082290b8c63e237a8d4595d0c3bf1b881e" and "b161d83aace5750c1c6cdc8e86f576460e866e27" have entirely different histories.

15 changed files with 74 additions and 172 deletions

View File

@ -42,7 +42,8 @@
"ApiKey": "sk-8BvvhESZIkgUbiaaJhglPxFa4o2X9H3xEv9lXELrWWwGxHWY"
},
"ChatGpt": {
"Host": "https://api.oaibest.com/",
"Host": "https://api.g4f.icu/",
//"Host": "https://api.oaibest.com/",
"ApiKey": "sk-D15tBln31N7dI9Fi7lds7OySFv5tOEK7DMNsG5rY2E6DCr4s"
},
"DeepSeek": {

View File

@ -39,7 +39,7 @@
<PackageReference Include="Microsoft.AspNetCore.Authentication.JwtBearer" Version="8.0.18" />
<PackageReference Include="Mapster.DependencyInjection" Version="1.0.2-pre01" />
<PackageReference Include="Microsoft.IdentityModel.JsonWebTokens" Version="8.13.0" />
<PackageReference Include="AlibabaCloud.SDK.Vod20170321" Version="3.11.1" />
<PackageReference Include="AlibabaCloud.SDK.Vod20170321" Version="3.6.1" />
<PackageReference Include="Swashbuckle.AspNetCore" Version="9.0.3" />
<PackageReference Include="Microsoft.Extensions.Http" Version="8.0.0" />
<PackageReference Include="Microsoft.Extensions.Options.ConfigurationExtensions" Version="8.0.0" />

View File

@ -24,7 +24,8 @@ namespace VideoAnalysisCore.AICore.GPT
//public const string Gemini_3_Chat_thinking = "gemini-3-pro-preview-thinking";
public const string Gemini_3_Chat = "gemini-3.1-pro-preview";
//public const string Gemini_3_Chat_flash = "gemini-3-flash-preview";
//已失效
//public const string Gemini_31_Chat_flash = "gemini-3.1-flash-lite-preview";
public const string Gemini_31_Chat_flash = "gemini-3.1-flash-preview";
}
}

View File

@ -27,7 +27,6 @@ using Dm.util;
using static System.Net.Mime.MediaTypeNames;
using VideoAnalysisCore.AICore.GPT.DeepSeek;
using VideoAnalysisCore.AICore.GPT.Gemini;
using static System.Collections.Specialized.BitVector32;
namespace VideoAnalysisCore.AICore.GPT
{
@ -116,10 +115,10 @@ namespace VideoAnalysisCore.AICore.GPT
await _workflowManager.AddTaskLog(taskInfo.Id, "==>2.开始分析视频内容知识点");
List<VideoKnowRes> konwRes;
var knowOK = false;
//var chatClentArr = new GPTClient[] { chatGPTClient, geminiClient, bset_deepSeekClient };
var chatClentArr = new GPTClient[] { chatGPTClient, geminiClient, bset_deepSeekClient };
for (int i = 0; i < 3; i++)
{
konwRes = await chatGPTClient.ChatAsync<List<VideoKnowRes>>(taskInfo.Id.ToString(), knowMessages, "知识点");
konwRes = await chatClentArr[i].ChatAsync<List<VideoKnowRes>>(taskInfo.Id.ToString(), knowMessages, "知识点");
// 分析结果的片段数量与预期不匹配
if (questionRes.Count() != konwRes.Count()) continue;
for (int xi = 0; xi < konwRes.Count(); xi++)
@ -194,7 +193,7 @@ namespace VideoAnalysisCore.AICore.GPT
$"字幕列表 {rCaptionArr}。" +
$"输出格式 json字符串 对象格式{fileNameResFormat}";
var task = taskInfo.Id.ToString();
var fileNameInfoRes = await chatGPTClient.ChatAsync<FileNameInfo>(task, fileNamePostMessages, "授课章节");
var fileNameInfoRes = await geminiClient.ChatAsync<FileNameInfo>(task, fileNamePostMessages, "授课章节");
taskInfo.Sections = fileNameInfoRes.;
await videoTaskDB.AsUpdateable()
.SetColumns(it => it.Sections == fileNameInfoRes.)
@ -243,7 +242,7 @@ namespace VideoAnalysisCore.AICore.GPT
json {checkResFormat}
""";
return await chatGPTClient.ChatAsync<CheckMessageDto>(taskInfo.Id.ToString(), checkMessage, "结果检查",ChatGPTType.GPT54);
return await chatGPTClient.ChatAsync<CheckMessageDto>(taskInfo.Id.ToString(), checkMessage, "结果检查");
}
/// <summary>
/// 采用改进意见
@ -283,43 +282,11 @@ namespace VideoAnalysisCore.AICore.GPT
JSON{resFormat}
""";
//var improved = await geminiClient.ChatAsync<List<VideoKnowRes>>(taskInfo.Id.ToString(), message, "分段优化");
//if (improved is null || improved.Count() != questionRes.Count())
var improved = await geminiClient.ChatAsync<List<VideoKnowRes>>(taskInfo.Id.ToString(), message, "分段优化");
if (improved is null || improved.Count() != questionRes.Count())
return null;
//return improved.OrderBy(s => s.StartTime ?? 0).ToList();
}
private async Task<(string, List<KnowledgeInfo>)> GetKnowledgeInfos(VideoTask taskInfo,long Course_Id)
{
List<KnowledgeInfo>? knowledgeInfos =null;
string? sections = null;
for (int i = 0; i < 3; i++)
{
sections = await GetSections(taskInfo, Course_Id);
var know = await knowledgeInfoDB.GetFirstAsync(s => s.Course_Id == Course_Id && s.Name == sections);
if (know is null)
{
await _workflowManager.AddTaskLog(taskInfo.Id, $"==>识别的知识点无效 {sections}");
continue;
}
var kInfo = await knowledgeInfoDB.GetByIdAsync(know.Parent_Id);
if (know.Parent_Id == 0)
kInfo = know;
try
{
knowledgeInfos = await knowledgeInfoDB.AsQueryable()
.ToChildListAsync(s => s.Parent_Id, kInfo.Parent_Id == 0 ? kInfo.Id : kInfo.Parent_Id);
}
catch (Exception)
{
await _workflowManager.AddTaskLog(taskInfo.Id, $"==>识别的知识没有对应的子知识点 {sections } {kInfo?.Name}");
continue;
}
}
if(knowledgeInfos is null)
throw new Exception("多次识别后未能识别到有效课堂知识点=>" + sections);
return new(sections, knowledgeInfos);
return improved.OrderBy(s => s.StartTime ?? 0).ToList();
}
/// <summary>
@ -341,13 +308,12 @@ namespace VideoAnalysisCore.AICore.GPT
[
async (m)=>await bset_deepSeekClient
.ChatAsync<List<SenseVoiceInput>>(taskInfo.Id.ToString(), m, "优化字幕",ChatGPTType.Deepseek_v32,8_000),
//async (m)=>await bset_deepSeekClient
// .ChatAsync<List<SenseVoiceInput>>(taskInfo.Id.ToString(), m, "优化字幕",ChatGPTType.Deepseek_Chat,8_000),
//async (m)=>await chatGPTClient
// .ChatAsync<List<SenseVoiceInput>>(taskInfo.Id.ToString(), m, "优化字幕",ChatGPTType.GPT54_mini,16_000),
//async (m)=>await geminiClient
// .ChatAsync<List<SenseVoiceInput>>(taskInfo.Id.ToString(), m, "优化字幕",ChatGPTType.Gemini_3_Chat,16_000),
];
async (m)=>await bset_deepSeekClient
.ChatAsync<List<SenseVoiceInput>>(taskInfo.Id.ToString(), m, "优化字幕",ChatGPTType.Deepseek_Chat,8_000),
async (m)=>await chatGPTClient
.ChatAsync<List<SenseVoiceInput>>(taskInfo.Id.ToString(), m, "优化字幕",ChatGPTType.GPT54_mini,16_000),
async (m)=>await geminiClient
.ChatAsync<List<SenseVoiceInput>>(taskInfo.Id.ToString(), m, "优化字幕",ChatGPTType.Gemini_3_Chat,16_000), ];
await Parallel.ForAsync(0, totalCount,
new ParallelOptions()
#if DEBUG
@ -765,10 +731,24 @@ namespace VideoAnalysisCore.AICore.GPT
var captionsArr = JsonSerializer.Deserialize<SenseVoiceRes[]>(taskInfo.Captions);
//处理视频授课章节
var kr = await GetKnowledgeInfos(taskInfo, Course_Id);
var sections = kr.Item1;
List<KnowledgeInfo>? knowledgeInfos = kr.Item2;
var sections = await GetSections(taskInfo, Course_Id);
var know = await knowledgeInfoDB.GetFirstAsync(s => s.Course_Id == Course_Id && s.Name == sections);
if (know is null)
throw new Exception("未能找到对应知识点=>" + sections);
List<KnowledgeInfo>? knowledgeInfos = new List<KnowledgeInfo>();
var kInfo = await knowledgeInfoDB.GetByIdAsync(know.Parent_Id);
if (know.Parent_Id == 0)
kInfo = know;
try
{
knowledgeInfos = await knowledgeInfoDB.AsQueryable()
.ToChildListAsync(s => s.Parent_Id, kInfo.Parent_Id == 0 ? kInfo.Id : kInfo.Parent_Id);
}
catch (Exception)
{
throw new Exception("没有对应的子知识点=>" + sections + " " + kInfo?.Name);
}
//AI优化字幕
captionsArr = await OptimizeSubtitles(taskInfo, captionsArr, sections);
@ -782,7 +762,7 @@ namespace VideoAnalysisCore.AICore.GPT
}
var maxVideoTime = captions?.TimeBase?.LastOrDefault()?.End ?? 0;
List<VideoKnowRes>? questionRes = null;
var tryCount = 3;
var tryCount = 20;
var last改进意见 = string.Empty;
while (tryCount-- > 0)
{
@ -821,7 +801,7 @@ namespace VideoAnalysisCore.AICore.GPT
// }
//}
if (checkRes != null && checkRes.Score >= 88)
if (checkRes != null && checkRes.Score >= 90)
{
//写入知识点
await videoKonwPointDB.DeleteAsync(s => s.VideoTaskId == taskInfo.Id);
@ -842,7 +822,6 @@ namespace VideoAnalysisCore.AICore.GPT
TextBookVersionId = taskInfo.TextBookVersionId,
GradeSemester = taskInfo.GradeSemester,
GradeId = taskInfo.GradeId,
GradeYear = taskInfo.GradeYear,
}).ToList();
//尝试追加 作业布置分段
if (homework != null && !questionRes.Any(s => s.Stage == StageEnum..ToString()))
@ -859,7 +838,7 @@ namespace VideoAnalysisCore.AICore.GPT
continue;
}
}
if (tryCount < 1)
if (tryCount == 0)
{
throw new Exception("重试次数过多!");
}

View File

@ -46,7 +46,7 @@ namespace VideoAnalysisCore.AICore.GPT.Gemini
Message[] messageArr = [
new Message(postMessages,"user"),
];
model = model ?? ChatGPTType.Gemini_3_Chat;
model = model ?? ChatGPTType.Gemini_31_Chat_flash;
messageArr = messageArr.Where(s => s != null).ToArray();
var chatReq = new ChatRequest
{

View File

@ -81,7 +81,6 @@ namespace VideoAnalysisCore.Common
/// </summary>
public static string Task(object taskId) => BaseKey + "Info:" + taskId;
public static string IDTask => BaseKey + "Services:" + AppCommon.Config.ID;
public static string DeviceTaskLog(string deviceId) => BaseKey + "Services:" + deviceId;
/// <summary>
/// 在线设备Key集合 (已弃用,直接扫描 Heartbeat)
/// </summary>

View File

@ -94,7 +94,7 @@ namespace VideoAnalysisCore.Common
public override async Task TaskEnd(string task)
{
var tId = long.Parse(task);
//await base.TaskEnd(task);
await base.TaskEnd(task);
// TidySlide 工作流结束时清理文件
try

View File

@ -138,7 +138,6 @@ namespace VideoAnalysisCore.Controllers.Dto
/// 年级
/// </summary>
public GradeEnum? GradeId { get; set; }
public int? Trem { get; set; }
/// <summary>
/// 教育阶段
@ -347,39 +346,12 @@ namespace VideoAnalysisCore.Controllers.Dto
public class VideoKonwPointQueryReq
{
public long? CloudSchoolId { get; set; }
/// <summary>
/// 难度 [PN TK BJ]
/// </summary>
public CourselevelTypeEnum? CourseLevel { get; set; }
/// <summary>
/// 年级
/// </summary>
public GradeEnum? GradeId { get; set; }
/// <summary>
/// 毕业届
/// </summary>
public int? GradeYear { get; set; }
/// <summary>
/// 上下册
/// </summary>
public GradeSemesterEnum? GradeSemester { get; set; }
/// <summary>
/// 教材版本
/// </summary>
public long? TextBookVersionId { get; set; }
/// <summary>
/// 知识点名称
/// </summary>
public string[]? KnowPointStrArr { get; set; }
/// <summary>
/// 切片主题
/// </summary>
public string[]? KnowPointIdArr { get; set; }
public string? Theme { get; set; }
/// <summary>
/// 切片内容
/// </summary>
public string? Content { get; set; }
public int PageIndex { get; set; } = 0;
public int PageSize { get; set; } = 200;
@ -391,7 +363,6 @@ namespace VideoAnalysisCore.Controllers.Dto
/// 视频vid
/// </summary>
public long VideoTaskId { get; set; }
public string PlayUrl { get; set; }
/// <summary>
/// 分段
/// </summary>
@ -401,17 +372,10 @@ namespace VideoAnalysisCore.Controllers.Dto
public class VideoTaskStageRes
{
/// <summary>
/// 视频封面地址
/// </summary>
public string PreviewUrl { get; set; }
/// <summary>
/// 视频地址
/// </summary>
public string PlayUrl { get; set; }
/// <summary>
/// id
/// </summary>
[SugarColumn(IsPrimaryKey = true)]
public long Id { get; set; } = YitIdHelper.NextId();
/// <summary>
/// 视频任务id
@ -422,19 +386,23 @@ namespace VideoAnalysisCore.Controllers.Dto
/// 自定义Id [任务视频自定义id]
/// <see cref="VideoTask.TagId"/>
/// </summary>
[SugarColumn(Length = 500, IsNullable = true)]
public string? TagId { get; set; }
/// <summary>
/// 开始时间
/// </summary>
[SugarColumn(IsNullable = true)]
public float? StartTime { get; set; }
/// <summary>
/// 结束时间
/// </summary>
[SugarColumn(IsNullable = true)]
public float? EndTime { get; set; }
/// <summary>
/// 持续时间
/// </summary>
[SugarColumn(IsIgnore = true)]
public float? KeepTime => (EndTime ?? 0) - StartTime ?? 0;
/// <summary>
/// 主题
@ -443,11 +411,13 @@ namespace VideoAnalysisCore.Controllers.Dto
/// <summary>
/// 课程阶段
/// </summary>
[SugarColumn(IsIgnore = true)]
public virtual StageEnum? Stage { get; set; }
/// <summary>
/// 视频所属云校ID
/// <para><see cref="UserCenter.Model.CloudSchool"/> 用户中心的云校id</para>
/// </summary>
[SugarColumn(IsNullable = true)]
public long? CloudSchoolId { get; set; }
/// <summary>
/// 知识点
@ -462,12 +432,12 @@ namespace VideoAnalysisCore.Controllers.Dto
Data = [];
Total = 0;
}
public VideoTaskStageQueryRes(VideoTaskStageRes[] data, int total = 0)
public VideoTaskStageQueryRes(VideoTaskInfoRes[] data, int total = 0)
{
Data = data;
Total = total;
}
public int Total { get; set; }
public VideoTaskStageRes[] Data { get; set; }
public VideoTaskInfoRes[] Data { get; set; }
}
}

View File

@ -18,9 +18,7 @@ using VideoAnalysisCore.Model;
using VideoAnalysisCore.Controllers.Dto;
using VideoAnalysisCore.Model.Dto;
using SqlSugar;
using AlibabaCloud.SDK.Vod20170321;
using VideoAnalysisCore.Model.À¾¨ÖÇ¿â;
using AlibabaCloud.SDK.Vod20170321.Models;
namespace VideoAnalysisCore.Controllers
{
@ -36,7 +34,6 @@ namespace VideoAnalysisCore.Controllers
private readonly Repository<VideoTask> videoTaskDB;
private readonly Repository<CourseInfo> courseInfoDB;
private readonly Repository<VideoKonwPoint> videoKonwPointDB;
private readonly Client vodClient;
private readonly Repository<VideoTaskStage> videoTaskStageDB;
private readonly Repository<NodePackageInfo> nodePackageInfoDB;
private readonly Repository<VideoQuestion> videoQuestionDB;
@ -45,7 +42,7 @@ namespace VideoAnalysisCore.Controllers
public LJZK_Controller(IMapper mp, Repository<NodeSubscription> nodesubscriptionDB,
Repository<VideoTask> videoTaskDB = null, Repository<VideoKonwPoint> videoKonwPointDB = null
, Repository<NodePackageInfo> nodePackageInfoDB = null, Repository<VideoQuestion> videoQuestionDB = null, Repository<VideoQuestionKonw> videoQuestionKonwDB = null, Repository<CourseInfo> courseInfoDB = null, RedisManager redisManager = null, Repository<VideoTaskStage> videoTaskStageDB = null, Client vodClient = null)
, Repository<NodePackageInfo> nodePackageInfoDB = null, Repository<VideoQuestion> videoQuestionDB = null, Repository<VideoQuestionKonw> videoQuestionKonwDB = null, Repository<CourseInfo> courseInfoDB = null, RedisManager redisManager = null, Repository<VideoTaskStage> videoTaskStageDB = null)
{
this.mp = mp;
this.nodesubscriptionDB = nodesubscriptionDB;
@ -57,7 +54,6 @@ namespace VideoAnalysisCore.Controllers
this.courseInfoDB = courseInfoDB;
this.redisManager = redisManager;
this.videoTaskStageDB = videoTaskStageDB;
this.vodClient = vodClient;
}
@ -128,7 +124,6 @@ namespace VideoAnalysisCore.Controllers
HostIP = s.HostIP,
StageId = s.StageId,
GradeId = s.GradeId,
GradeYear = s.Trem==0?null : s.Trem,
GradeSemester = s.GradeSemester,
TextBookVersionId = s.TextBookVersionId,
};
@ -154,7 +149,6 @@ namespace VideoAnalysisCore.Controllers
GradeSemester =s .GradeSemester,
CourseLevel =s.CourseLevel,
GradeId = s.GradeId,
GradeYear = np.GradeYear,
});
}
await nodePackageInfoDB.InsertRangeAsync(nodePackages);
@ -303,7 +297,6 @@ namespace VideoAnalysisCore.Controllers
var stageQuery = videoTaskStageDB.AsQueryable();
stageQuery = stageQuery.WhereIF(req.CloudSchoolId.HasValue, s => s.CloudSchoolId == req.CloudSchoolId);
stageQuery = stageQuery.WhereIF(req.GradeYear.HasValue, s => s.GradeYear == req.GradeYear);
stageQuery = stageQuery.WhereIF(req.CourseLevel.HasValue, s => s.CourseLevel == req.CourseLevel);
stageQuery = stageQuery.WhereIF(req.GradeId.HasValue, s => s.GradeId == req.GradeId);
stageQuery = stageQuery.WhereIF(req.GradeSemester.HasValue, s => s.GradeSemester == req.GradeSemester);
@ -312,15 +305,15 @@ namespace VideoAnalysisCore.Controllers
stageQuery = stageQuery.WhereIF(!string.IsNullOrWhiteSpace(req.Content), s => s.Content.Contains(req.Content));
var pageIndex = req.PageIndex < 0 ? 0 : req.PageIndex;
var pageSize = req.PageSize <= 0 ? 50 : req.PageSize > 100 ?100 : req.PageSize;
string[]? knowArr = null;
if (req.KnowPointStrArr is not null && req.KnowPointStrArr.Length > 0)
var pageSize = req.PageSize <= 0 ? 200 : req.PageSize > 500 ? 500 : req.PageSize;
if (req.KnowPointIdArr is not null && req.KnowPointIdArr.Length > 0)
{
knowArr = req.KnowPointStrArr.Where(s => !string.IsNullOrWhiteSpace(s)).Select(s=>s.Trim()).Distinct().ToArray();
var knowArr = req.KnowPointIdArr.Where(s => !string.IsNullOrWhiteSpace(s)).Distinct().ToArray();
if (knowArr.Length > 0)
{
stageQuery = stageQuery.Where(s => SqlFunc.Subqueryable<VideoKonwPoint>()
.Where(k => k.StageId == s.Id && k.KnowPoint != null && knowArr.Contains(k.KnowPoint))
.Where(k => k.StageId == s.Id && k.KnowPointId != null && knowArr.Contains(k.KnowPointId))
.Any());
}
}
@ -333,8 +326,12 @@ namespace VideoAnalysisCore.Controllers
var taskIdArr = stagePageArr.Select(s => s.VideoTaskId).ToArray();
var kpQuery = videoKonwPointDB.AsQueryable()
.Where(s => taskIdArr.Contains(s.VideoTaskId) && s.KnowPointId != null);
if (knowArr !=null && knowArr.Length > 0)
if (req.KnowPointIdArr is not null && req.KnowPointIdArr.Length > 0)
{
var knowArr = req.KnowPointIdArr.Where(s => !string.IsNullOrWhiteSpace(s)).Distinct().ToArray();
if (knowArr.Length > 0)
kpQuery = kpQuery.Where(s => knowArr.Contains(s.KnowPointId));
}
var kpArr = await kpQuery
.Select(s => new { s.StageId, s.KnowPoint })
@ -343,12 +340,6 @@ namespace VideoAnalysisCore.Controllers
.GroupBy(s => s.StageId)
.ToDictionary(s => s.Key, s => s.Select(x => x.KnowPoint!).Distinct().ToArray());
//var gDataKey = stagePageArr.GroupBy(s => s.VideoTaskId).Select(s => s.Key).Distinct();
//var videoInfoQRes = vodClient.GetVideoInfos(new GetVideoInfosRequest()
//{
// VideoIds = string.Join(",", gDataKey)
//});
//var videoInfoRes = videoInfoQRes.Body.VideoList.ToDictionary(s => s.VideoId, s => s.CoverURL);
var data = stagePageArr.Select(s => new VideoTaskStageRes()
{
Id = s.Id,
@ -358,47 +349,23 @@ namespace VideoAnalysisCore.Controllers
EndTime = s.EndTime,
Theme = s.Theme,
CloudSchoolId = s.CloudSchoolId,
Stage=s.Stage,
//PreviewUrl= videoInfoRes.ContainsKey(s.VideoTaskId.ToString())? videoInfoRes[] :
KnowPoints = kpDic.ContainsKey(s.Id) ? kpDic[s.Id] : []
}).ToArray();
return Ok(new VideoTaskStageQueryRes()
{
Total = total,
Data = data
Data = data.GroupBy(s=>s.VideoTaskId)
.Select(s=>new VideoTaskInfoRes()
{
Stages = s.ToArray(),
VideoTaskId =s.Key
}).ToArray()
});
}
/// <summary>
/// 查询 视频切片
/// </summary>
/// <param name="videoTaskId">视频id</param>
/// <returns>视频地址</returns>
[HttpGet(Name = "GetVideoURL")]
public async Task<IActionResult> GetVideoURL(long videoTaskId)
{
if (videoTaskId ==0)
return BadRequest("参数不能为空");
var task =await videoTaskDB.GetByIdAsync(videoTaskId);
if (task is null)
return BadRequest("参数无效");
var videoInfo = await vodClient.GetPlayInfoAsync(new GetPlayInfoRequest()
{
VideoId = task.TagId,
Formats = "mp4",
OutputType = "cdn",
AuthTimeout = 3600 * 24 * 12,
});
if (videoInfo is null || videoInfo.StatusCode != 200 && !videoInfo.Body.PlayInfoList.PlayInfo.Any())
return BadRequest("获取存储的视频信息失败!");
return Ok(videoInfo.Body.PlayInfoList.PlayInfo.First().PlayURL);
}
}
}

View File

@ -527,7 +527,7 @@ namespace VideoAnalysisCore.Controllers
foreach (var deviceId in onlineDevices)
{
var key = RedisExpandKey.DeviceTaskLog(deviceId) ;
var key = RedisExpandKey.BaseKey + "Services:" + deviceId;
var tasks = redisManager.Redis.LRange<long>(key, 0, 999);
oldTaskArr.AddRange(tasks);
}
@ -535,7 +535,7 @@ namespace VideoAnalysisCore.Controllers
else
{
// 获取指定节点
var key = RedisExpandKey.DeviceTaskLog(model.DeviceId);
var key = RedisExpandKey.BaseKey + "Services:" + model.DeviceId;
oldTaskArr = redisManager.Redis.LRange<long>(key, 0, 999).ToList();
}

View File

@ -88,11 +88,6 @@ namespace VideoAnalysisCore.Model
[SugarColumn(IsNullable = true)]
public GradeEnum? GradeId { get; set; }
/// <summary>
/// 毕业届
/// </summary>
[SugarColumn(IsNullable = true)]
public int? GradeYear { get; set; }
/// <summary>
/// 教育阶段
/// </summary>
[SugarColumn(IsNullable = true)]

View File

@ -157,11 +157,6 @@ namespace VideoAnalysisCore.Model
[SugarColumn(IsNullable = true)]
public GradeEnum? GradeId { get; set; }
/// <summary>
/// 毕业届
/// </summary>
[SugarColumn(IsNullable = true)]
public int? GradeYear { get; set; }
/// <summary>
/// 年级册(上册/下册)
/// </summary>
[SugarColumn(IsNullable = true)]

View File

@ -94,11 +94,6 @@ namespace VideoAnalysisCore.Model
[SugarColumn(IsNullable = true)]
public GradeSemesterEnum? GradeSemester { get; set; }
/// <summary>
/// 毕业届
/// </summary>
[SugarColumn(IsNullable = true)]
public int? GradeYear { get; set; }
/// <summary>
/// 学科网的教材版本Id
/// </summary>
public long TextBookVersionId { get; set; }

View File

@ -11,7 +11,7 @@ namespace VideoAnalysisCore.Model.蓝鲸智库
/// <summary>
/// 蓝鲸智库 知识点表
/// </summary>
[SugarTable("knowledgeinfo_hy")]
[SugarTable("knowledgeinfo")]
[Tenant("1001")]
public class KnowledgeInfo
{

View File

@ -13,7 +13,7 @@
<ItemGroup>
<PackageReference Include="AlibabaCloud.SDK.Vod20170321" Version="3.11.1" />
<PackageReference Include="AlibabaCloud.SDK.Vod20170321" Version="3.6.1" />
<PackageReference Include="Aliyun.OSS.SDK.NetCore" Version="2.14.1" />
<PackageReference Include="Coravel" Version="6.0.2" />
<PackageReference Include="FreeRedis" Version="1.5.5" />