Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
C
cmeeting
概览
概览
详情
活动
周期分析
版本库
存储库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
Issue Boards
Open sidebar
翟斌
cmeeting
Commits
b09e9994
提交
b09e9994
authored
11月 13, 2025
作者:
洪东保
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
debug
父级
febf6b90
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
85 行增加
和
3 行删除
+85
-3
src/main/java/com/cmeeting/email/EmailSender.java
+2
-2
src/main/java/com/cmeeting/job/CmeetingJob.java
+61
-0
src/main/java/com/cmeeting/job/EmailPushTask.java
+3
-1
src/main/java/com/cmeeting/service/impl/MeetingInfoServiceImpl.java
+19
-0
没有找到文件。
src/main/java/com/cmeeting/email/EmailSender.java
浏览文件 @
b09e9994
...
@@ -102,8 +102,8 @@ public class EmailSender {
...
@@ -102,8 +102,8 @@ public class EmailSender {
if
(
StringUtils
.
isEmpty
(
toEmail
))
{
if
(
StringUtils
.
isEmpty
(
toEmail
))
{
log
.
error
(
"收件邮箱为空,推送失败"
);
log
.
error
(
"收件邮箱为空,推送失败"
);
processLogService
.
log
(
meetingId
,
subMeetingId
,
"收件邮箱为空,推送失败。environment->"
+
environment
+
",testReceiver->"
+
testReceiver
+
",realEmail->"
+
emailPushBuilder
.
getToEmail
());
processLogService
.
log
(
meetingId
,
subMeetingId
,
"收件邮箱为空,推送失败。environment->"
+
environment
+
",testReceiver->"
+
testReceiver
+
",realEmail->"
+
emailPushBuilder
.
getToEmail
());
return
false
;
throw
new
RuntimeException
(
"收件邮箱为空,推送失败"
)
;
}
}
log
.
info
(
"准备开始邮件推送..."
);
log
.
info
(
"准备开始邮件推送..."
);
while
(
retryCount
.
intValue
()
<
MAX_RETRY
&&
isSent
!=
null
&&
!
isSent
)
{
while
(
retryCount
.
intValue
()
<
MAX_RETRY
&&
isSent
!=
null
&&
!
isSent
)
{
...
...
src/main/java/com/cmeeting/job/CmeetingJob.java
浏览文件 @
b09e9994
...
@@ -379,4 +379,65 @@ public class CmeetingJob {
...
@@ -379,4 +379,65 @@ public class CmeetingJob {
}
}
// @Scheduled(cron = "0 0 * * * ?")
public
void
errorStatisticsPush
()
{
log
.
info
(
"errorStatisticsPush"
);
Date
now
=
new
Date
();
Calendar
calendar
=
Calendar
.
getInstance
();
calendar
.
setTime
(
now
);
calendar
.
add
(
Calendar
.
HOUR_OF_DAY
,
-
1
);
Date
start
=
calendar
.
getTime
();
List
<
Integer
>
statusList
=
new
ArrayList
<>();
statusList
.
add
(
5
);
statusList
.
add
(
6
);
SimpleDateFormat
sdf
=
new
SimpleDateFormat
(
"yyyy-MM-dd HH:mm:ss"
);
List
<
MeetingInfo
>
meetingInfoList
=
meetingInfoService
.
list
(
new
LambdaQueryWrapper
<
MeetingInfo
>()
.
notIn
(
MeetingInfo:
:
getStatus
,
statusList
)
.
between
(
MeetingInfo:
:
getSyncTime
,
sdf
.
format
(
start
),
sdf
.
format
(
now
))
.
select
(
MeetingInfo:
:
getStatus
)
);
if
(
meetingInfoList
.
size
()
==
0
)
{
return
;
}
List
<
Integer
>
collect
=
meetingInfoList
.
stream
().
map
(
MeetingInfo:
:
getStatus
).
collect
(
Collectors
.
toList
());
if
(
collect
.
contains
(
0
)
||
collect
.
contains
(
4
))
{
return
;
}
int
sum
=
collect
.
size
();
int
geneError
=
0
;
int
pushEmailError
=
0
;
for
(
Integer
integer
:
collect
)
{
if
(
integer
==
1
){
geneError
++;
}
if
(
integer
==
4
){
pushEmailError
++;
}
}
if
(
sum
>
geneError
+
pushEmailError
)
{
return
;
}
String
subject
=
"会议纪要推送报警"
;
String
content
=
"<p data-olk-copy-source=\\\"MessageBody\\\">Dear all:<br> 附件为今天Cmeeting会议纪要生成和发送情况,烦请查收。</p>"
;
// List<StatisticsEmailPush.Attachment> attachments = new ArrayList<>();
// StatisticsEmailPush.Attachment attachment = new StatisticsEmailPush.Attachment();
// attachment.setName(subject);
// attachment.setBytes(IOUtils.toByteArray(Files.newInputStream(file.toPath())));
// attachments.add(attachment);
StatisticsEmailPush
emailPushBuilder
=
StatisticsEmailPush
.
builder
()
.
toEmails
(
statisticsEmailPushProperties
.
getToEmails
())
// .attachments(attachments)
.
subject
(
subject
)
.
content
(
content
)
.
build
();
emailSender
.
emailStatisticsPush
(
emailPushBuilder
);
}
}
}
src/main/java/com/cmeeting/job/EmailPushTask.java
浏览文件 @
b09e9994
...
@@ -150,7 +150,9 @@ public class EmailPushTask {
...
@@ -150,7 +150,9 @@ public class EmailPushTask {
e
.
printStackTrace
();
e
.
printStackTrace
();
log
.
error
(
"push email error: {}"
,
e
.
getMessage
());
log
.
error
(
"push email error: {}"
,
e
.
getMessage
());
int
currentRetryCount
=
retryCount
.
getAndIncrement
();
int
currentRetryCount
=
retryCount
.
getAndIncrement
();
if
(
currentRetryCount
<=
MAX_RETRY
)
{
if
(
currentRetryCount
>
MAX_RETRY
)
{
log
.
error
(
"达到最大重试次数:meetingId {}"
,
meetingId
);
}
else
{
// 指数退避
// 指数退避
try
{
try
{
Thread
.
sleep
((
long
)
Math
.
pow
(
2
,
currentRetryCount
)
*
1000
);
Thread
.
sleep
((
long
)
Math
.
pow
(
2
,
currentRetryCount
)
*
1000
);
...
...
src/main/java/com/cmeeting/service/impl/MeetingInfoServiceImpl.java
浏览文件 @
b09e9994
...
@@ -725,7 +725,26 @@ public class MeetingInfoServiceImpl extends ServiceImpl<MeetingInfoMapper, Meeti
...
@@ -725,7 +725,26 @@ public class MeetingInfoServiceImpl extends ServiceImpl<MeetingInfoMapper, Meeti
}
}
}
}
private
static
Map
<
String
,
String
>
DEPT_MAP
=
new
HashMap
<>(
20
);
static
{
DEPT_MAP
.
put
(
"10340"
,
"集团总部"
);
DEPT_MAP
.
put
(
"602700"
,
"能化板块"
);
DEPT_MAP
.
put
(
"616859"
,
"空港板块"
);
DEPT_MAP
.
put
(
"616766"
,
"集装箱集团"
);
DEPT_MAP
.
put
(
"616844"
,
"车辆板块"
);
DEPT_MAP
.
put
(
"616860"
,
"海工板块"
);
DEPT_MAP
.
put
(
"616861"
,
"产城板块"
);
DEPT_MAP
.
put
(
"640071"
,
"物流板块"
);
DEPT_MAP
.
put
(
"617560"
,
"融资租赁贵公司"
);
DEPT_MAP
.
put
(
"640075"
,
"财务公司"
);
DEPT_MAP
.
put
(
"641858"
,
"其他类型企业"
);
DEPT_MAP
.
put
(
"707435"
,
"集团创新企业"
);
DEPT_MAP
.
put
(
"686701"
,
"中集海工"
);
DEPT_MAP
.
put
(
"710972"
,
"中集资本"
);
DEPT_MAP
.
put
(
"711091"
,
"中集载具"
);
DEPT_MAP
.
put
(
"698023"
,
"中集同创"
);
}
/**
/**
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论