Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
H
haoban-manage3.0
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
haoban3.0
haoban-manage3.0
Commits
db8ab262
Commit
db8ab262
authored
Mar 12, 2024
by
徐高华
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'feature/xgh/20241月迭代' into 'master'
Feature/xgh/20241月迭代 See merge request
!1680
parents
ea75f974
2b73742f
Show whitespace changes
Inline
Side-by-side
Showing
19 changed files
with
433 additions
and
30 deletions
+433
-30
MemberUnionidRelatedDTO.java
...om/gic/haoban/manage/api/dto/MemberUnionidRelatedDTO.java
+20
-0
QwFrientNoticeDTO.java
...java/com/gic/haoban/manage/api/dto/QwFrientNoticeDTO.java
+10
-0
HaobanTimerApiService.java
.../gic/haoban/manage/api/service/HaobanTimerApiService.java
+9
-0
MemberUnionidRelatedApiService.java
...an/manage/api/service/MemberUnionidRelatedApiService.java
+2
-1
TabQywxErrorLogMapper.java
...oban/manage/service/dao/mapper/TabQywxErrorLogMapper.java
+5
-0
HBQwMonitorBO.java
...ava/com/gic/haoban/manage/service/pojo/HBQwMonitorBO.java
+31
-0
QywxErrorLogService.java
...ic/haoban/manage/service/service/QywxErrorLogService.java
+13
-0
TabQywxErrorLogServiceImpl.java
...nage/service/service/impl/TabQywxErrorLogServiceImpl.java
+61
-0
HaobanTimerApiServiceImpl.java
...e/service/service/out/impl/HaobanTimerApiServiceImpl.java
+14
-0
MemberUnionidRelatedApiServiceImpl.java
.../service/out/impl/MemberUnionidRelatedApiServiceImpl.java
+18
-14
MessageApiServiceImpl.java
...anage/service/service/out/impl/MessageApiServiceImpl.java
+19
-7
FriendSyncNewOperation.java
...an/manage/service/task/friend/FriendSyncNewOperation.java
+1
-1
HBQwMonitorUtils.java
.../com/gic/haoban/manage/service/util/HBQwMonitorUtils.java
+69
-0
InfluxDbMonitorUtils.java
.../gic/haoban/manage/service/util/InfluxDbMonitorUtils.java
+106
-0
TabHaobanStaffClerkRelationMapper.xml
...in/resources/mapper/TabHaobanStaffClerkRelationMapper.xml
+1
-1
TabQywxErrorLogMapper.xml
...rvice/src/main/resources/mapper/TabQywxErrorLogMapper.xml
+11
-2
GroupChatPlanController.java
...n/manage/web/controller/chat/GroupChatPlanController.java
+4
-4
ReceiveExcelVO.java
...ava/com/gic/haoban/manage/web/vo/chat/ReceiveExcelVO.java
+19
-0
SendExcelVO.java
...n/java/com/gic/haoban/manage/web/vo/chat/SendExcelVO.java
+20
-0
No files found.
haoban-manage3-api/src/main/java/com/gic/haoban/manage/api/dto/MemberUnionidRelatedDTO.java
View file @
db8ab262
...
@@ -50,8 +50,28 @@ public class MemberUnionidRelatedDTO implements Serializable{
...
@@ -50,8 +50,28 @@ public class MemberUnionidRelatedDTO implements Serializable{
private
Integer
addWay
;
private
Integer
addWay
;
private
String
wxUserId
;
private
int
retryTimes
;
private
boolean
isFlush
=
false
;
private
boolean
isFlush
=
false
;
public
int
getRetryTimes
()
{
return
retryTimes
;
}
public
void
setRetryTimes
(
int
retryTimes
)
{
this
.
retryTimes
=
retryTimes
;
}
public
String
getWxUserId
()
{
return
wxUserId
;
}
public
void
setWxUserId
(
String
wxUserId
)
{
this
.
wxUserId
=
wxUserId
;
}
public
boolean
isFlush
()
{
public
boolean
isFlush
()
{
return
isFlush
;
return
isFlush
;
}
}
...
...
haoban-manage3-api/src/main/java/com/gic/haoban/manage/api/dto/QwFrientNoticeDTO.java
View file @
db8ab262
...
@@ -51,6 +51,16 @@ public class QwFrientNoticeDTO implements Serializable {
...
@@ -51,6 +51,16 @@ public class QwFrientNoticeDTO implements Serializable {
// 是否从自建应用下的回调
// 是否从自建应用下的回调
private
int
selfCallback
=
0
;
private
int
selfCallback
=
0
;
private
int
retryTimes
;
public
int
getRetryTimes
()
{
return
retryTimes
;
}
public
void
setRetryTimes
(
int
retryTimes
)
{
this
.
retryTimes
=
retryTimes
;
}
public
int
getSelfCallback
()
{
public
int
getSelfCallback
()
{
return
selfCallback
;
return
selfCallback
;
}
}
...
...
haoban-manage3-api/src/main/java/com/gic/haoban/manage/api/service/HaobanTimerApiService.java
View file @
db8ab262
...
@@ -112,4 +112,13 @@ public interface HaobanTimerApiService {
...
@@ -112,4 +112,13 @@ public interface HaobanTimerApiService {
*/
*/
public
ServiceResponse
<
Void
>
groupChatQuitTimer
(
String
params
)
;
public
ServiceResponse
<
Void
>
groupChatQuitTimer
(
String
params
)
;
/**
* 加好友统计
* @param params
*/
public
void
addFrientMonitorTimer
(
String
params
)
;
public
void
doErrorFriendTimer
(
String
params
)
;
}
}
haoban-manage3-api/src/main/java/com/gic/haoban/manage/api/service/MemberUnionidRelatedApiService.java
View file @
db8ab262
...
@@ -161,9 +161,10 @@ public interface MemberUnionidRelatedApiService {
...
@@ -161,9 +161,10 @@ public interface MemberUnionidRelatedApiService {
* @param wxEnterpriseId
* @param wxEnterpriseId
* @param wxUserId
* @param wxUserId
* @param externalUserId
* @param externalUserId
* from 0 企微加好友通知 1刷新好友
* @return
* @return
*/
*/
ExternalUserDTO
getExternalUseridInfo
(
String
wxEnterpriseId
,
String
wxUserId
,
String
externalUserId
);
ExternalUserDTO
getExternalUseridInfo
(
String
wxEnterpriseId
,
String
wxUserId
,
String
externalUserId
,
int
from
);
/**
/**
* 清理外部联系人
* 清理外部联系人
...
...
haoban-manage3-service/src/main/java/com/gic/haoban/manage/service/dao/mapper/TabQywxErrorLogMapper.java
View file @
db8ab262
...
@@ -2,8 +2,10 @@ package com.gic.haoban.manage.service.dao.mapper;
...
@@ -2,8 +2,10 @@ package com.gic.haoban.manage.service.dao.mapper;
import
com.gic.haoban.manage.api.dto.qdto.QywxErrorLogListQDTO
;
import
com.gic.haoban.manage.api.dto.qdto.QywxErrorLogListQDTO
;
import
com.gic.haoban.manage.service.entity.TabQywxErrorLog
;
import
com.gic.haoban.manage.service.entity.TabQywxErrorLog
;
import
org.apache.ibatis.annotations.Param
;
import
org.springframework.stereotype.Repository
;
import
org.springframework.stereotype.Repository
;
import
java.util.Date
;
import
java.util.List
;
import
java.util.List
;
/**
/**
...
@@ -25,4 +27,7 @@ public interface TabQywxErrorLogMapper {
...
@@ -25,4 +27,7 @@ public interface TabQywxErrorLogMapper {
*/
*/
List
<
TabQywxErrorLog
>
queryListByPage
(
QywxErrorLogListQDTO
qywxErrorLogListQDTO
);
List
<
TabQywxErrorLog
>
queryListByPage
(
QywxErrorLogListQDTO
qywxErrorLogListQDTO
);
List
<
TabQywxErrorLog
>
listErrorFriend
(
@Param
(
"wxEnterpriseId"
)
String
wxEnterpriseId
,
@Param
(
"qywxErrorType"
)
int
type
,
@Param
(
"startDate"
)
Date
startDate
,
@Param
(
"endDate"
)
Date
endDate
)
;
}
}
haoban-manage3-service/src/main/java/com/gic/haoban/manage/service/pojo/HBQwMonitorBO.java
0 → 100644
View file @
db8ab262
package
com
.
gic
.
haoban
.
manage
.
service
.
pojo
;
public
class
HBQwMonitorBO
{
private
String
host
;
private
int
num
;
private
int
failNum
;
public
String
getHost
()
{
return
host
;
}
public
void
setHost
(
String
host
)
{
this
.
host
=
host
;
}
public
int
getNum
()
{
return
num
;
}
public
void
setNum
(
int
num
)
{
this
.
num
=
num
;
}
public
int
getFailNum
()
{
return
failNum
;
}
public
void
setFailNum
(
int
failNum
)
{
this
.
failNum
=
failNum
;
}
}
haoban-manage3-service/src/main/java/com/gic/haoban/manage/service/service/QywxErrorLogService.java
View file @
db8ab262
package
com
.
gic
.
haoban
.
manage
.
service
.
service
;
package
com
.
gic
.
haoban
.
manage
.
service
.
service
;
import
com.gic.api.base.commons.Page
;
import
com.gic.api.base.commons.Page
;
import
com.gic.haoban.manage.api.dto.QywxErrorLogDTO
;
import
com.gic.haoban.manage.api.dto.qdto.QywxErrorLogListQDTO
;
import
com.gic.haoban.manage.api.dto.qdto.QywxErrorLogListQDTO
;
import
com.gic.haoban.manage.service.entity.TabQywxErrorLog
;
import
com.gic.haoban.manage.service.entity.TabQywxErrorLog
;
import
com.gic.haoban.manage.service.pojo.bo.TabQywxErrorLogBO
;
import
com.gic.haoban.manage.service.pojo.bo.TabQywxErrorLogBO
;
...
@@ -33,4 +34,16 @@ public interface QywxErrorLogService {
...
@@ -33,4 +34,16 @@ public interface QywxErrorLogService {
*/
*/
List
<
TabQywxErrorLog
>
queryListByPage
(
QywxErrorLogListQDTO
qywxErrorLogListQDTO
);
List
<
TabQywxErrorLog
>
queryListByPage
(
QywxErrorLogListQDTO
qywxErrorLogListQDTO
);
/**
*
* @param wxEnterpriseId
* @param msg
* @param type 4自建 5第三方
*/
void
addFriendErrLog
(
String
wxEnterpriseId
,
String
msg
,
int
type
,
String
externalUserId
)
;
public
void
putToMq
(
QywxErrorLogDTO
dto
)
;
public
void
doFriendTimer
(
String
params
)
;
}
}
haoban-manage3-service/src/main/java/com/gic/haoban/manage/service/service/impl/TabQywxErrorLogServiceImpl.java
View file @
db8ab262
...
@@ -3,7 +3,21 @@ package com.gic.haoban.manage.service.service.impl;
...
@@ -3,7 +3,21 @@ package com.gic.haoban.manage.service.service.impl;
import
java.util.Date
;
import
java.util.Date
;
import
java.util.List
;
import
java.util.List
;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.JSONObject
;
import
com.gic.commons.util.CollectionUtil
;
import
com.gic.commons.util.DateUtil
;
import
com.gic.commons.util.GICMQClientUtil
;
import
com.gic.dubbo.entity.ProviderLocalTag
;
import
com.gic.haoban.manage.api.constants.Manage3Constants
;
import
com.gic.haoban.manage.api.dto.QwFrientNoticeDTO
;
import
com.gic.haoban.manage.api.dto.QywxErrorLogDTO
;
import
com.gic.haoban.manage.service.pojo.DealQywxExternalUserPojo
;
import
com.gic.mq.sdk.GicMQClient
;
import
org.apache.commons.collections.CollectionUtils
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.logging.log4j.LogManager
;
import
org.apache.logging.log4j.Logger
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
org.springframework.stereotype.Service
;
...
@@ -23,10 +37,13 @@ import com.gic.haoban.manage.service.service.QywxErrorLogService;
...
@@ -23,10 +37,13 @@ import com.gic.haoban.manage.service.service.QywxErrorLogService;
*/
*/
@Service
@Service
public
class
TabQywxErrorLogServiceImpl
implements
QywxErrorLogService
{
public
class
TabQywxErrorLogServiceImpl
implements
QywxErrorLogService
{
private
static
final
Logger
log
=
LogManager
.
getLogger
(
QywxErrorLogService
.
class
);
@Autowired
@Autowired
private
TabQywxErrorLogMapper
tabQywxErrorLogMapper
;
private
TabQywxErrorLogMapper
tabQywxErrorLogMapper
;
private
static
GicMQClient
clientInstance
=
GICMQClientUtil
.
getClientInstance
();
@Override
@Override
public
TabQywxErrorLogBO
insert
(
TabQywxErrorLogBO
tabQywxErrorLogBO
)
{
public
TabQywxErrorLogBO
insert
(
TabQywxErrorLogBO
tabQywxErrorLogBO
)
{
String
wxEnterpriseId
=
tabQywxErrorLogBO
.
getWxEnterpriseId
();
String
wxEnterpriseId
=
tabQywxErrorLogBO
.
getWxEnterpriseId
();
...
@@ -44,4 +61,48 @@ public class TabQywxErrorLogServiceImpl implements QywxErrorLogService {
...
@@ -44,4 +61,48 @@ public class TabQywxErrorLogServiceImpl implements QywxErrorLogService {
return
this
.
tabQywxErrorLogMapper
.
queryListByPage
(
qywxErrorLogListQDTO
);
return
this
.
tabQywxErrorLogMapper
.
queryListByPage
(
qywxErrorLogListQDTO
);
}
}
@Override
public
void
addFriendErrLog
(
String
wxEnterpriseId
,
String
msg
,
int
type
,
String
externalUserId
)
{
QywxErrorLogDTO
errLog
=
new
QywxErrorLogDTO
()
;
errLog
.
setWxEnterpriseId
(
wxEnterpriseId
);
errLog
.
setExternalUserId
(
externalUserId
);
errLog
.
setTraceId
(
ProviderLocalTag
.
tag
.
get
().
traceId
);
errLog
.
setQywxErrorType
(
type
);
errLog
.
setScenario
(
"加好友"
);
errLog
.
setErrorContent
(
msg
);
this
.
putToMq
(
errLog
);
}
@Override
public
void
putToMq
(
QywxErrorLogDTO
errLog
)
{
try
{
clientInstance
.
sendMessage
(
Manage3Constants
.
QYWX_ERROR_MSG
,
JSON
.
toJSONString
(
errLog
));
}
catch
(
Exception
e
)
{
log
.
error
(
"发送消息失败:{}"
,
e
.
getMessage
(),
e
);
}
}
@Override
public
void
doFriendTimer
(
String
params
)
{
log
.
info
(
"加好友异常重试"
);
Date
yesterday
=
DateUtil
.
addDay
(
new
Date
()
,
-
1
)
;
Date
start
=
DateUtil
.
getStartTimeOfDay
(
yesterday
)
;
Date
end
=
DateUtil
.
getEndTimeOfDay
(
yesterday
)
;
List
<
TabQywxErrorLog
>
list
=
this
.
tabQywxErrorLogMapper
.
listErrorFriend
(
null
,
4
,
start
,
end
)
;
if
(
CollectionUtils
.
isNotEmpty
(
list
))
{
String
mqName
=
"dealQywxExternalUserMq2"
;
for
(
TabQywxErrorLog
tab
:
list
)
{
try
{
DealQywxExternalUserPojo
dealQywxExternalUserPojo
=
new
DealQywxExternalUserPojo
();
dealQywxExternalUserPojo
.
setType
(
DealQywxExternalUserPojo
.
DealType
.
add
.
getType
());
if
(
StringUtils
.
isNotBlank
(
tab
.
getErrorContent
()))
{
dealQywxExternalUserPojo
.
setData
(
JSONObject
.
parseObject
(
tab
.
getErrorContent
(),
QwFrientNoticeDTO
.
class
));
clientInstance
.
sendMessage
(
mqName
,
JSONObject
.
toJSONString
(
dealQywxExternalUserPojo
));
}
}
catch
(
Exception
e
)
{
log
.
info
(
"异步处理异常:{}"
,
e
);
}
}
}
}
}
}
haoban-manage3-service/src/main/java/com/gic/haoban/manage/service/service/out/impl/HaobanTimerApiServiceImpl.java
View file @
db8ab262
package
com
.
gic
.
haoban
.
manage
.
service
.
service
.
out
.
impl
;
package
com
.
gic
.
haoban
.
manage
.
service
.
service
.
out
.
impl
;
import
com.gic.haoban.manage.service.service.QywxErrorLogService
;
import
com.gic.haoban.manage.service.service.chat.GroupChatDataService
;
import
com.gic.haoban.manage.service.service.chat.GroupChatDataService
;
import
com.gic.haoban.manage.service.util.HBQwMonitorUtils
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
org.springframework.stereotype.Service
;
...
@@ -27,6 +29,8 @@ public class HaobanTimerApiServiceImpl implements HaobanTimerApiService {
...
@@ -27,6 +29,8 @@ public class HaobanTimerApiServiceImpl implements HaobanTimerApiService {
private
ExternalMemberService
externalMemberService
;
private
ExternalMemberService
externalMemberService
;
@Autowired
@Autowired
private
GroupChatDataService
groupChatDataService
;
private
GroupChatDataService
groupChatDataService
;
@Autowired
private
QywxErrorLogService
qywxErrorLogService
;
@Override
@Override
...
@@ -88,4 +92,14 @@ public class HaobanTimerApiServiceImpl implements HaobanTimerApiService {
...
@@ -88,4 +92,14 @@ public class HaobanTimerApiServiceImpl implements HaobanTimerApiService {
this
.
groupChatDataService
.
groupChatQuitTimer
(
params
)
;
this
.
groupChatDataService
.
groupChatQuitTimer
(
params
)
;
return
ServiceResponse
.
success
();
return
ServiceResponse
.
success
();
}
}
@Override
public
void
addFrientMonitorTimer
(
String
params
)
{
HBQwMonitorUtils
.
addByTimer
();
}
@Override
public
void
doErrorFriendTimer
(
String
params
)
{
this
.
qywxErrorLogService
.
doFriendTimer
(
params
);
}
}
}
haoban-manage3-service/src/main/java/com/gic/haoban/manage/service/service/out/impl/MemberUnionidRelatedApiServiceImpl.java
View file @
db8ab262
...
@@ -4,7 +4,9 @@ import java.util.*;
...
@@ -4,7 +4,9 @@ import java.util.*;
import
java.util.concurrent.TimeUnit
;
import
java.util.concurrent.TimeUnit
;
import
java.util.stream.Collectors
;
import
java.util.stream.Collectors
;
import
com.gic.haoban.manage.service.service.*
;
import
com.gic.haoban.manage.service.util.EventUtils
;
import
com.gic.haoban.manage.service.util.EventUtils
;
import
com.gic.haoban.manage.service.util.HBQwMonitorUtils
;
import
org.apache.commons.collections.CollectionUtils
;
import
org.apache.commons.collections.CollectionUtils
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.logging.log4j.LogManager
;
import
org.apache.logging.log4j.LogManager
;
...
@@ -73,18 +75,6 @@ import com.gic.haoban.manage.service.pojo.ExternalUserPojo;
...
@@ -73,18 +75,6 @@ import com.gic.haoban.manage.service.pojo.ExternalUserPojo;
import
com.gic.haoban.manage.service.pojo.QywxTagSyncInfoPojo
;
import
com.gic.haoban.manage.service.pojo.QywxTagSyncInfoPojo
;
import
com.gic.haoban.manage.service.pojo.bo.hm.HmLinkBO
;
import
com.gic.haoban.manage.service.pojo.bo.hm.HmLinkBO
;
import
com.gic.haoban.manage.service.pojo.bo.hm.KeyDataLinkBO
;
import
com.gic.haoban.manage.service.pojo.bo.hm.KeyDataLinkBO
;
import
com.gic.haoban.manage.service.service.ClerkMainStoreRelatedService
;
import
com.gic.haoban.manage.service.service.ExternalClerkRelatedService
;
import
com.gic.haoban.manage.service.service.ExternalMemberService
;
import
com.gic.haoban.manage.service.service.KeyDataService
;
import
com.gic.haoban.manage.service.service.MemberUnionRelatedService
;
import
com.gic.haoban.manage.service.service.QywxSendService
;
import
com.gic.haoban.manage.service.service.SecretSettingService
;
import
com.gic.haoban.manage.service.service.StaffClerkRelationService
;
import
com.gic.haoban.manage.service.service.StaffService
;
import
com.gic.haoban.manage.service.service.WelcomeSendService
;
import
com.gic.haoban.manage.service.service.WxEnterpriseRelatedService
;
import
com.gic.haoban.manage.service.service.WxEnterpriseService
;
import
com.gic.haoban.manage.service.service.chat.GroupChatService
;
import
com.gic.haoban.manage.service.service.chat.GroupChatService
;
import
com.gic.haoban.manage.service.service.hm.HmLinkService
;
import
com.gic.haoban.manage.service.service.hm.HmLinkService
;
import
com.gic.haoban.manage.service.service.hm.WxUserAddLogService
;
import
com.gic.haoban.manage.service.service.hm.WxUserAddLogService
;
...
@@ -185,6 +175,8 @@ public class MemberUnionidRelatedApiServiceImpl implements MemberUnionidRelatedA
...
@@ -185,6 +175,8 @@ public class MemberUnionidRelatedApiServiceImpl implements MemberUnionidRelatedA
private
ExternalMemberService
externalMemberService
;
private
ExternalMemberService
externalMemberService
;
@Autowired
@Autowired
private
ClerkMainStoreRelatedApiService
clerkMainStoreRelatedApiService
;
private
ClerkMainStoreRelatedApiService
clerkMainStoreRelatedApiService
;
@Autowired
private
QywxErrorLogService
qywxErrorLogService
;
GicMQClient
instance
=
GICMQClientUtil
.
getClientInstance
();
GicMQClient
instance
=
GICMQClientUtil
.
getClientInstance
();
...
@@ -925,6 +917,7 @@ public class MemberUnionidRelatedApiServiceImpl implements MemberUnionidRelatedA
...
@@ -925,6 +917,7 @@ public class MemberUnionidRelatedApiServiceImpl implements MemberUnionidRelatedA
return
null
;
return
null
;
}
}
if
(
qwDTO
.
isSelf
())
{
if
(
qwDTO
.
isSelf
())
{
HBQwMonitorUtils
.
addForFriend
(
0
);
this
.
updateExternalStatus
(
dto
.
getExternalUserid
(),
dto
.
getStaffId
());
this
.
updateExternalStatus
(
dto
.
getExternalUserid
(),
dto
.
getStaffId
());
String
unionIdJson
=
qywxUserApiService
.
getCorpSelfExternalUseridInfo
(
qwDTO
.
getDkCorpid
(),
qwDTO
.
getSelfSecret
(),
dto
.
getExternalUserid
(),
qwDTO
.
getUrlHost
());
String
unionIdJson
=
qywxUserApiService
.
getCorpSelfExternalUseridInfo
(
qwDTO
.
getDkCorpid
(),
qwDTO
.
getSelfSecret
(),
dto
.
getExternalUserid
(),
qwDTO
.
getUrlHost
());
if
(
StringUtils
.
isBlank
(
unionIdJson
))
{
if
(
StringUtils
.
isBlank
(
unionIdJson
))
{
...
@@ -932,6 +925,12 @@ public class MemberUnionidRelatedApiServiceImpl implements MemberUnionidRelatedA
...
@@ -932,6 +925,12 @@ public class MemberUnionidRelatedApiServiceImpl implements MemberUnionidRelatedA
return
null
;
return
null
;
}
else
if
(
"1"
.
equals
(
unionIdJson
))
{
}
else
if
(
"1"
.
equals
(
unionIdJson
))
{
log
.
info
(
"接口调用被限制"
);
log
.
info
(
"接口调用被限制"
);
dto
.
setWxUserId
(
wxUserId
);
dto
.
setRetryTimes
(
dto
.
getRetryTimes
()+
1
);
if
(
dto
.
getRetryTimes
()<=
3
)
{
this
.
qywxErrorLogService
.
addFriendErrLog
(
wxEnterpriseId
,
JSONObject
.
toJSONString
(
dto
),
4
,
dto
.
getExternalUserid
());
}
HBQwMonitorUtils
.
addForFriend
(
1
);
throw
new
WxApiLimitException
(
"getCorpSelfExternalUseridInfo接口调用被限制"
);
throw
new
WxApiLimitException
(
"getCorpSelfExternalUseridInfo接口调用被限制"
);
}
}
ExternalUserPojo
pojo
=
getExternalUserPojo
(
unionIdJson
,
wxUserId
,
wxEnterpriseId
);
ExternalUserPojo
pojo
=
getExternalUserPojo
(
unionIdJson
,
wxUserId
,
wxEnterpriseId
);
...
@@ -960,8 +959,9 @@ public class MemberUnionidRelatedApiServiceImpl implements MemberUnionidRelatedA
...
@@ -960,8 +959,9 @@ public class MemberUnionidRelatedApiServiceImpl implements MemberUnionidRelatedA
if
(
SELF_APP
.
equals
(
suiteid
))
{
if
(
SELF_APP
.
equals
(
suiteid
))
{
externalUserDTO
=
this
.
getCorpSelfExternalUseridInfo
(
wxEnterpriseId
,
wxUserId
,
externalUserid
);
externalUserDTO
=
this
.
getCorpSelfExternalUseridInfo
(
wxEnterpriseId
,
wxUserId
,
externalUserid
);
}
else
{
}
else
{
HBQwMonitorUtils
.
addForFriend
(
0
);
this
.
updateExternalStatus
(
externalUserid
,
dto
.
getStaffId
());
this
.
updateExternalStatus
(
externalUserid
,
dto
.
getStaffId
());
externalUserDTO
=
this
.
getExternalUseridInfo
(
wxEnterpriseId
,
wxUserId
,
externalUserid
);
externalUserDTO
=
this
.
getExternalUseridInfo
(
wxEnterpriseId
,
wxUserId
,
externalUserid
,
0
);
}
}
checkQywxSettingApiService
.
saveFriendCallback
(
wxEnterpriseId
,
externalUserDTO
,
dto
);
checkQywxSettingApiService
.
saveFriendCallback
(
wxEnterpriseId
,
externalUserDTO
,
dto
);
if
(
externalUserDTO
==
null
)
{
if
(
externalUserDTO
==
null
)
{
...
@@ -1375,7 +1375,7 @@ public class MemberUnionidRelatedApiServiceImpl implements MemberUnionidRelatedA
...
@@ -1375,7 +1375,7 @@ public class MemberUnionidRelatedApiServiceImpl implements MemberUnionidRelatedA
}
}
@Override
@Override
public
ExternalUserDTO
getExternalUseridInfo
(
String
wxEnterpriseId
,
String
wxUserId
,
String
externalUserId
)
{
public
ExternalUserDTO
getExternalUseridInfo
(
String
wxEnterpriseId
,
String
wxUserId
,
String
externalUserId
,
int
from
)
{
log
.
info
(
"查询第三方:wxEnterpriseId:{},wxUserId:{},externalUserId:{}"
,
wxEnterpriseId
,
wxUserId
,
externalUserId
);
log
.
info
(
"查询第三方:wxEnterpriseId:{},wxUserId:{},externalUserId:{}"
,
wxEnterpriseId
,
wxUserId
,
externalUserId
);
WxEnterpriseQwDTO
qwDTO
=
this
.
wxEnterpriseService
.
getQwInfo
(
wxEnterpriseId
);
WxEnterpriseQwDTO
qwDTO
=
this
.
wxEnterpriseService
.
getQwInfo
(
wxEnterpriseId
);
if
(
qwDTO
==
null
)
{
if
(
qwDTO
==
null
)
{
...
@@ -1399,6 +1399,10 @@ public class MemberUnionidRelatedApiServiceImpl implements MemberUnionidRelatedA
...
@@ -1399,6 +1399,10 @@ public class MemberUnionidRelatedApiServiceImpl implements MemberUnionidRelatedA
return
null
;
return
null
;
}
else
if
(
"1"
.
equals
(
uJ
))
{
}
else
if
(
"1"
.
equals
(
uJ
))
{
log
.
info
(
"限制次数"
);
log
.
info
(
"限制次数"
);
if
(
from
==
0
)
{
this
.
qywxErrorLogService
.
addFriendErrLog
(
wxEnterpriseId
,
tabHaobanStaff
.
getStaffId
(),
5
,
externalUserId
);
HBQwMonitorUtils
.
addForFriend
(
1
);
}
throw
new
WxApiLimitException
(
"getExternalUseridInfo接口次数限制"
);
throw
new
WxApiLimitException
(
"getExternalUseridInfo接口次数限制"
);
}
}
String
name
=
""
;
String
name
=
""
;
...
...
haoban-manage3-service/src/main/java/com/gic/haoban/manage/service/service/out/impl/MessageApiServiceImpl.java
View file @
db8ab262
...
@@ -154,6 +154,20 @@ public class MessageApiServiceImpl implements MessageApiService {
...
@@ -154,6 +154,20 @@ public class MessageApiServiceImpl implements MessageApiService {
}
}
}
}
private
String
getWxEnterpriseId
(
String
corpid
)
{
String
wxEnterpriseId
=
null
;
TabHaobanWxApplication
wxApplication
=
wxApplicationService
.
selectByCorpId
(
corpid
);
if
(
null
==
wxApplication
)
{
TabHaobanWxEnterprise
wxEnterprise
=
this
.
wxEnterpriseService
.
getEnterpriseBycorpId
(
corpid
)
;
if
(
null
!=
wxEnterprise
)
{
wxEnterpriseId
=
wxEnterprise
.
getWxEnterpriseId
()
;
}
}
else
{
wxEnterpriseId
=
wxApplication
.
getWxEnterpriseId
();
}
return
wxEnterpriseId
;
}
@Override
@Override
public
void
dealWxMessage
(
String
param
)
{
public
void
dealWxMessage
(
String
param
)
{
QywxCallBackDTO
dto
=
JSON
.
parseObject
(
param
,
QywxCallBackDTO
.
class
);
QywxCallBackDTO
dto
=
JSON
.
parseObject
(
param
,
QywxCallBackDTO
.
class
);
...
@@ -163,12 +177,11 @@ public class MessageApiServiceImpl implements MessageApiService {
...
@@ -163,12 +177,11 @@ public class MessageApiServiceImpl implements MessageApiService {
log
.
info
(
"通讯录只处理自建应用回调 dto={}"
,
JSON
.
toJSONString
(
param
));
log
.
info
(
"通讯录只处理自建应用回调 dto={}"
,
JSON
.
toJSONString
(
param
));
return
;
return
;
}
}
TabHaobanWxApplication
wxApplication
=
wxApplicationService
.
selectByCorpId
(
dto
.
getAuthCorpId
())
;
String
wxEnterpriseId
=
this
.
getWxEnterpriseId
(
dto
.
getAuthCorpId
())
;
if
(
Objects
.
isNull
(
wxApplication
)
)
{
if
(
null
==
wxEnterpriseId
)
{
log
.
info
(
"授权企业不存在,{}"
,
dto
.
getAuthCorpId
());
log
.
info
(
"授权企业不存在,{}"
,
dto
.
getAuthCorpId
());
return
;
return
;
}
}
String
wxEnterpriseId
=
wxApplication
.
getWxEnterpriseId
();
WxEnterpriseQwDTO
qwDTO
=
this
.
wxEnterpriseService
.
getQwInfo
(
wxEnterpriseId
)
;
WxEnterpriseQwDTO
qwDTO
=
this
.
wxEnterpriseService
.
getQwInfo
(
wxEnterpriseId
)
;
if
(
qwDTO
.
isSelf
()
&&
dto
.
getSelfCallback
()==
0
)
{
if
(
qwDTO
.
isSelf
()
&&
dto
.
getSelfCallback
()==
0
)
{
log
.
info
(
"非自建应用回调"
);
log
.
info
(
"非自建应用回调"
);
...
@@ -437,12 +450,11 @@ public class MessageApiServiceImpl implements MessageApiService {
...
@@ -437,12 +450,11 @@ public class MessageApiServiceImpl implements MessageApiService {
String
authCorpId
=
qywxCallBackDTO
.
getAuthCorpId
();
String
authCorpId
=
qywxCallBackDTO
.
getAuthCorpId
();
DepartmentDTO
departmentDTO
=
new
DepartmentDTO
();
DepartmentDTO
departmentDTO
=
new
DepartmentDTO
();
departmentDTO
.
setIsStore
(
0
);
departmentDTO
.
setIsStore
(
0
);
TabHaobanWxApplication
wxApplication
=
wxApplicationService
.
selectByCorpId
(
authCorpId
)
;
String
wxEnterpriseId
=
this
.
getWxEnterpriseId
(
authCorpId
)
;
if
(
Objects
.
isNull
(
wxApplication
)
)
{
if
(
null
==
wxEnterpriseId
)
{
log
.
info
(
"授权企业不存在,{}"
,
qywxCallBackDTO
.
getAuthCorpId
()
);
log
.
info
(
"授权企业不存在,{}"
,
authCorpId
);
return
;
return
;
}
}
String
wxEnterpriseId
=
wxApplication
.
getWxEnterpriseId
();
WxEnterpriseQwDTO
qwDTO
=
this
.
wxEnterpriseService
.
getQwInfo
(
wxEnterpriseId
)
;
WxEnterpriseQwDTO
qwDTO
=
this
.
wxEnterpriseService
.
getQwInfo
(
wxEnterpriseId
)
;
SecretSettingDTO
secretSetting
=
secretSettingService
.
getSecretSetting
(
wxEnterpriseId
,
SecretSettingDTO
secretSetting
=
secretSettingService
.
getSecretSetting
(
wxEnterpriseId
,
SecretTypeEnum
.
CUSTOMIZED_APP
.
getVal
());
SecretTypeEnum
.
CUSTOMIZED_APP
.
getVal
());
...
...
haoban-manage3-service/src/main/java/com/gic/haoban/manage/service/task/friend/FriendSyncNewOperation.java
View file @
db8ab262
...
@@ -63,7 +63,7 @@ public class FriendSyncNewOperation implements BaseSyncOperation {
...
@@ -63,7 +63,7 @@ public class FriendSyncNewOperation implements BaseSyncOperation {
String
externalUserId
=
dataPre
.
getDataContent
();
String
externalUserId
=
dataPre
.
getDataContent
();
String
staffId
=
dataPre
.
getpDataId
()
;
String
staffId
=
dataPre
.
getpDataId
()
;
ExternalUserDTO
externalUserDTO
=
memberUnionidRelatedApiService
.
getExternalUseridInfo
(
wxEnterpriseId
,
wxUserId
,
externalUserId
);
ExternalUserDTO
externalUserDTO
=
memberUnionidRelatedApiService
.
getExternalUseridInfo
(
wxEnterpriseId
,
wxUserId
,
externalUserId
,
1
);
if
(
externalUserDTO
==
null
)
{
if
(
externalUserDTO
==
null
)
{
logger
.
info
(
"第三方外部联系人详情查询失败,staffId={},{},{}"
,
staffId
,
wxUserId
,
externalUserId
);
logger
.
info
(
"第三方外部联系人详情查询失败,staffId={},{},{}"
,
staffId
,
wxUserId
,
externalUserId
);
dealFlag
=
false
;
dealFlag
=
false
;
...
...
haoban-manage3-service/src/main/java/com/gic/haoban/manage/service/util/HBQwMonitorUtils.java
0 → 100644
View file @
db8ab262
package
com
.
gic
.
haoban
.
manage
.
service
.
util
;
import
com.gic.commons.util.IPUtil
;
import
com.gic.dubbo.util.DubboInvokeUtil
;
import
com.gic.haoban.manage.api.service.MemberUnionidRelatedApiService
;
import
com.gic.haoban.manage.service.pojo.HBQwMonitorBO
;
import
com.gic.redis.data.util.RedisUtil
;
import
org.apache.logging.log4j.LogManager
;
import
org.apache.logging.log4j.Logger
;
import
org.redisson.api.RAtomicLong
;
import
org.springframework.stereotype.Component
;
import
java.util.Arrays
;
import
java.util.List
;
/**
* 好办统计
*/
@Component
public
class
HBQwMonitorUtils
{
private
static
Logger
logger
=
LogManager
.
getLogger
(
HBQwMonitorUtils
.
class
);
private
static
final
List
<
String
>
keyList
=
Arrays
.
asList
(
"hbmonitor:friendNotice"
,
"hbmonitor:friendFail"
)
;
/**
* @param index 0加好友企微通知数量 1加好友查询企微接口限制数量
*/
public
static
void
addForFriend
(
int
index
)
{
String
ip
=
IPUtil
.
getLocalIP
();
logger
.
info
(
"addForFriend={}"
,
ip
);
String
key
=
keyList
.
get
(
index
)+
ip
;
RAtomicLong
cache
=
RedisUtil
.
getRedisClient
().
getAtomicLong
(
key
);
cache
.
addAndGet
(
1
);
}
public
static
Object
query
(
String
sql
)
{
return
InfluxDbMonitorUtils
.
getInstance
().
query
(
sql
);
}
public
static
void
addByTimer
()
{
List
<
String
>
ipList
=
DubboInvokeUtil
.
getServiceHostList
(
MemberUnionidRelatedApiService
.
class
)
;
logger
.
info
(
"add timer"
);
for
(
String
ip
:
ipList
)
{
int
totalNum
=
getNum
(
keyList
.
get
(
0
),
ip
)
;
int
failNum
=
getNum
(
keyList
.
get
(
1
),
ip
);
HBQwMonitorBO
bo
=
new
HBQwMonitorBO
()
;
bo
.
setHost
(
ip
);
bo
.
setNum
(
totalNum
);
bo
.
setFailNum
(
failNum
);
InfluxDbMonitorUtils
.
getInstance
().
friendAdd
(
bo
);
}
}
private
static
int
getNum
(
String
key
,
String
ip
)
{
key
=
key
+
ip
;
int
count
=
0
;
Object
countObj
=
RedisUtil
.
getCache
(
key
)
;
if
(
null
!=
countObj
)
{
count
=
Integer
.
valueOf
(
countObj
.
toString
())
;
}
RAtomicLong
cache
=
RedisUtil
.
getRedisClient
().
getAtomicLong
(
key
);
cache
.
addAndGet
(-
count
)
;
return
count
;
}
}
haoban-manage3-service/src/main/java/com/gic/haoban/manage/service/util/InfluxDbMonitorUtils.java
0 → 100644
View file @
db8ab262
package
com
.
gic
.
haoban
.
manage
.
service
.
util
;
import
com.gic.haoban.manage.service.pojo.HBQwMonitorBO
;
import
org.apache.logging.log4j.LogManager
;
import
org.apache.logging.log4j.Logger
;
import
org.influxdb.InfluxDB
;
import
org.influxdb.InfluxDBFactory
;
import
org.influxdb.dto.Point
;
import
org.influxdb.dto.Query
;
import
org.influxdb.dto.QueryResult
;
import
java.util.ArrayList
;
import
java.util.HashMap
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.concurrent.TimeUnit
;
public
class
InfluxDbMonitorUtils
{
private
static
Logger
logger
=
LogManager
.
getLogger
(
InfluxDbMonitorUtils
.
class
);
private
static
String
url
=
"http://10.0.2.9:8086"
;
private
static
InfluxDB
influxDB
;
private
static
final
String
DB_NAME
=
"haoban_info"
;
private
static
final
String
RP_NAME
=
"default"
;
private
static
volatile
InfluxDbMonitorUtils
instance
=
null
;
public
static
InfluxDbMonitorUtils
getInstance
()
{
if
(
instance
==
null
)
{
synchronized
(
InfluxDbMonitorUtils
.
class
)
{
if
(
instance
==
null
)
{
instance
=
new
InfluxDbMonitorUtils
();
}
}
}
return
instance
;
}
private
InfluxDbMonitorUtils
()
{
influxDB
=
InfluxDBFactory
.
connect
(
url
,
"inflxudb"
,
"inflxudb"
);
if
(!
influxDB
.
describeDatabases
().
contains
(
DB_NAME
))
{
influxDB
.
createDatabase
(
DB_NAME
);
influxDB
.
createRetentionPolicy
(
RP_NAME
,
DB_NAME
,
"7d"
,
1
,
true
);
}
influxDB
.
setDatabase
(
DB_NAME
);
influxDB
.
setRetentionPolicy
(
RP_NAME
);
}
public
InfluxDB
getInfluxDB
()
{
return
influxDB
;
}
public
void
friendAdd
(
HBQwMonitorBO
bo
)
{
influxDB
.
write
(
Point
.
measurement
(
"hb_qw_friend_monitor"
)
.
time
(
System
.
currentTimeMillis
(),
TimeUnit
.
MILLISECONDS
)
.
addField
(
"num"
,
bo
.
getNum
())
.
addField
(
"failNum"
,
bo
.
getFailNum
())
.
tag
(
"application"
,
"haoban-manage3"
)
.
tag
(
"host"
,
bo
.
getHost
())
.
build
());
}
/**
* 查询
*
* @param command 查询语句
*/
public
List
<
Map
<
String
,
Object
>>
query
(
String
command
)
{
QueryResult
query
=
influxDB
.
query
(
new
Query
(
command
,
DB_NAME
));
return
queryResultProcess
(
query
);
}
/**
* @param queryResult
* @desc 查询结果处理
*/
public
List
<
Map
<
String
,
Object
>>
queryResultProcess
(
QueryResult
queryResult
)
{
List
<
Map
<
String
,
Object
>>
mapList
=
new
ArrayList
<>();
List
<
QueryResult
.
Result
>
resultList
=
queryResult
.
getResults
();
//把查询出的结果集转换成对应的实体对象,聚合成list
for
(
QueryResult
.
Result
query
:
resultList
)
{
List
<
QueryResult
.
Series
>
seriesList
=
query
.
getSeries
();
if
(
seriesList
!=
null
&&
seriesList
.
size
()
!=
0
)
{
for
(
QueryResult
.
Series
series
:
seriesList
)
{
List
<
String
>
columns
=
series
.
getColumns
();
String
[]
keys
=
columns
.
toArray
(
new
String
[
columns
.
size
()]);
List
<
List
<
Object
>>
values
=
series
.
getValues
();
if
(
values
!=
null
&&
values
.
size
()
!=
0
)
{
for
(
List
<
Object
>
value
:
values
)
{
Map
<
String
,
Object
>
map
=
new
HashMap
(
keys
.
length
);
for
(
int
i
=
0
;
i
<
keys
.
length
;
i
++)
{
map
.
put
(
keys
[
i
],
value
.
get
(
i
));
}
mapList
.
add
(
map
);
}
}
}
}
}
return
mapList
;
}
}
haoban-manage3-service/src/main/resources/mapper/TabHaobanStaffClerkRelationMapper.xml
View file @
db8ab262
...
@@ -263,7 +263,7 @@
...
@@ -263,7 +263,7 @@
</foreach>
</foreach>
and a.status_flag = 1
and a.status_flag = 1
group by a.staff_id, a.clerk_id) as scr on scr.staff_id = ecr.staff_id
group by a.staff_id, a.clerk_id) as scr on scr.staff_id = ecr.staff_id
where ecr.status_flag = 1 AND ecr.`external_status`
= 1
where ecr.status_flag = 1 AND ecr.`external_status`
in (1 , 3)
and ecr.enterprise_id = #{enterpriseId,jdbcType=VARCHAR}
and ecr.enterprise_id = #{enterpriseId,jdbcType=VARCHAR}
and ecr.wx_enterprise_id=#{wxEnterpriseId}
and ecr.wx_enterprise_id=#{wxEnterpriseId}
and ecr.member_id in
and ecr.member_id in
...
...
haoban-manage3-service/src/main/resources/mapper/TabQywxErrorLogMapper.xml
View file @
db8ab262
...
@@ -82,8 +82,17 @@
...
@@ -82,8 +82,17 @@
</trim>
</trim>
</insert>
</insert>
<select
id=
"listErrorFriend"
resultMap=
"TabQywxErrorLogMap"
>
select
<include
refid=
"Base_Column_List"
/>
from tab_qywx_error_log where qywx_error_type = #{qywxErrorType}
and create_time
<![CDATA[ >= ]]>
#{startDate}
and create_time
<![CDATA[ <= ]]>
#{endDate}
<if
test=
"wxEnterpriseId != null and wxEnterpriseId != ''"
>
and wx_enterprise_id = #{wxEnterpriseId}
</if>
</select>
<!--通过实体作为筛选条件查询-->
<select
id=
"queryListByPage"
parameterType=
"com.gic.haoban.manage.api.dto.qdto.QywxErrorLogListQDTO"
<select
id=
"queryListByPage"
parameterType=
"com.gic.haoban.manage.api.dto.qdto.QywxErrorLogListQDTO"
resultMap=
"TabQywxErrorLogMap"
>
resultMap=
"TabQywxErrorLogMap"
>
select
select
...
@@ -97,7 +106,7 @@
...
@@ -97,7 +106,7 @@
and ( member_id = #{scenario} or external_user_id = #{scenario} )
and ( member_id = #{scenario} or external_user_id = #{scenario} )
</if>
</if>
<if
test=
"qywxErrorType != null"
>
<if
test=
"qywxErrorType != null"
>
and qywx_error_type =
#{qywxErrorType}
and qywx_error_type =
1
</if>
</if>
<if
test=
"startDate != null"
>
<if
test=
"startDate != null"
>
and create_time
<![CDATA[ >= ]]>
#{startDate}
and create_time
<![CDATA[ >= ]]>
#{startDate}
...
...
haoban-manage3-web/src/main/java/com/gic/haoban/manage/web/controller/chat/GroupChatPlanController.java
View file @
db8ab262
...
@@ -446,8 +446,8 @@ public class GroupChatPlanController {
...
@@ -446,8 +446,8 @@ public class GroupChatPlanController {
//设置sheet的表头与表名
//设置sheet的表头与表名
String
[]
groupChatListSheetHead
=
{
"任务名称"
,
"任务状态"
,
"已完成群主数"
,
"未完成群主数"
,
"完成率"
,
"已送达群数"
,
"任务开始时间"
,
"任务结束时间"
,
"创建人"
,
"创建时间"
};
String
[]
groupChatListSheetHead
=
{
"任务名称"
,
"任务状态"
,
"已完成群主数"
,
"未完成群主数"
,
"完成率"
,
"已送达群数"
,
"任务开始时间"
,
"任务结束时间"
,
"创建人"
,
"创建时间"
};
String
[]
sendSheetHead
=
{
"任务名称"
,
"发送人"
,
"关联导购"
,
"关联门店"
,
"完成状态"
,
"已送达客户群数"
,
"发送时间"
,
"任务开始时间"
,
"任务结束时间"
};
String
[]
sendSheetHead
=
{
"任务名称"
,
"发送人"
,
"关联导购"
,
"关联导购code"
,
"关联门店"
,
"关联门店code"
,
"完成状态"
,
"已送达客户群数"
,
"发送时间"
,
"任务开始时间"
,
"任务结束时间"
};
String
[]
receiveSheetHead
=
{
"任务名称"
,
"群名称"
,
"群人数"
,
"发送人"
,
"关联导购"
,
"关联
门店"
,
"发送状态"
,
"发送时间"
,
"任务开始时间"
,
"任务结束时间"
};
String
[]
receiveSheetHead
=
{
"任务名称"
,
"群名称"
,
"群人数"
,
"发送人"
,
"关联导购"
,
"关联
导购code"
,
"关联门店"
,
"关联门店code"
,
"发送状态"
,
"发送时间"
,
"任务开始时间"
,
"任务结束时间"
};
List
<
ExcelSheet
>
mysheet
=
new
ArrayList
<>();
List
<
ExcelSheet
>
mysheet
=
new
ArrayList
<>();
ExcelSheet
groupChatListExcel
=
new
ExcelSheet
(
"客户群发列表"
,
groupChatListSheetHead
,
changeGroupChatPlanExcelVOList
(
groupChatPlanExcelVOList
));
ExcelSheet
groupChatListExcel
=
new
ExcelSheet
(
"客户群发列表"
,
groupChatListSheetHead
,
changeGroupChatPlanExcelVOList
(
groupChatPlanExcelVOList
));
...
@@ -482,7 +482,7 @@ public class GroupChatPlanController {
...
@@ -482,7 +482,7 @@ public class GroupChatPlanController {
String
sendTime
=
DateUtil
.
formatString
(
vo
.
getSendTime
(),
DateUtil
.
FORMAT_DATETIME_19
);
String
sendTime
=
DateUtil
.
formatString
(
vo
.
getSendTime
(),
DateUtil
.
FORMAT_DATETIME_19
);
String
startTime
=
DateUtil
.
formatString
(
vo
.
getStartTime
(),
DateUtil
.
FORMAT_DATETIME_19
);
String
startTime
=
DateUtil
.
formatString
(
vo
.
getStartTime
(),
DateUtil
.
FORMAT_DATETIME_19
);
String
endTime
=
DateUtil
.
formatString
(
vo
.
getEndTime
(),
DateUtil
.
FORMAT_DATETIME_19
);
String
endTime
=
DateUtil
.
formatString
(
vo
.
getEndTime
(),
DateUtil
.
FORMAT_DATETIME_19
);
String
[]
a
=
{
vo
.
getName
(),
vo
.
getStaffName
(),
vo
.
getClerkName
(),
vo
.
getStoreName
(),
vo
.
getSendStatusExcel
(),
vo
.
getSendCount
()==
null
?
""
:
vo
.
getSendCount
().
toString
(),
sendTime
,
startTime
,
endTime
};
String
[]
a
=
{
vo
.
getName
(),
vo
.
getStaffName
(),
vo
.
getClerkName
(),
vo
.
getClerkCode
(),
vo
.
getStoreName
(),
vo
.
getStoreCode
(),
vo
.
getSendStatusExcel
(),
vo
.
getSendCount
()==
null
?
""
:
vo
.
getSendCount
().
toString
(),
sendTime
,
startTime
,
endTime
};
result
.
add
(
a
);
result
.
add
(
a
);
}
}
return
result
;
return
result
;
...
@@ -496,7 +496,7 @@ public class GroupChatPlanController {
...
@@ -496,7 +496,7 @@ public class GroupChatPlanController {
String
sendTime
=
DateUtil
.
formatString
(
vo
.
getSendTime
(),
DateUtil
.
FORMAT_DATETIME_19
);
String
sendTime
=
DateUtil
.
formatString
(
vo
.
getSendTime
(),
DateUtil
.
FORMAT_DATETIME_19
);
String
startTime
=
DateUtil
.
formatString
(
vo
.
getStartTime
(),
DateUtil
.
FORMAT_DATETIME_19
);
String
startTime
=
DateUtil
.
formatString
(
vo
.
getStartTime
(),
DateUtil
.
FORMAT_DATETIME_19
);
String
endTime
=
DateUtil
.
formatString
(
vo
.
getEndTime
(),
DateUtil
.
FORMAT_DATETIME_19
);
String
endTime
=
DateUtil
.
formatString
(
vo
.
getEndTime
(),
DateUtil
.
FORMAT_DATETIME_19
);
String
[]
a
=
{
vo
.
getName
(),
vo
.
getChatName
(),
vo
.
getChatTotalCount
()==
null
?
""
:
vo
.
getChatTotalCount
().
toString
(),
vo
.
getStaffName
(),
vo
.
getClerkName
(),
vo
.
get
StoreNam
e
(),
vo
.
getSendStatusExcel
(),
sendTime
,
startTime
,
endTime
};
String
[]
a
=
{
vo
.
getName
(),
vo
.
getChatName
(),
vo
.
getChatTotalCount
()==
null
?
""
:
vo
.
getChatTotalCount
().
toString
(),
vo
.
getStaffName
(),
vo
.
getClerkName
(),
vo
.
get
ClerkCode
(),
vo
.
getStoreName
(),
vo
.
getStoreCod
e
(),
vo
.
getSendStatusExcel
(),
sendTime
,
startTime
,
endTime
};
result
.
add
(
a
);
result
.
add
(
a
);
}
}
return
result
;
return
result
;
...
...
haoban-manage3-web/src/main/java/com/gic/haoban/manage/web/vo/chat/ReceiveExcelVO.java
View file @
db8ab262
...
@@ -36,10 +36,13 @@ public class ReceiveExcelVO implements Serializable {
...
@@ -36,10 +36,13 @@ public class ReceiveExcelVO implements Serializable {
* 关联导购
* 关联导购
*/
*/
private
String
clerkName
;
private
String
clerkName
;
private
String
clerkCode
;
/**
/**
* 关联门店
* 关联门店
*/
*/
private
String
storeName
;
private
String
storeName
;
private
String
storeCode
;
/**
/**
* 发送状态
* 发送状态
*/
*/
...
@@ -61,6 +64,22 @@ public class ReceiveExcelVO implements Serializable {
...
@@ -61,6 +64,22 @@ public class ReceiveExcelVO implements Serializable {
*/
*/
private
Date
endTime
;
private
Date
endTime
;
public
String
getClerkCode
()
{
return
clerkCode
;
}
public
void
setClerkCode
(
String
clerkCode
)
{
this
.
clerkCode
=
clerkCode
;
}
public
String
getStoreCode
()
{
return
storeCode
;
}
public
void
setStoreCode
(
String
storeCode
)
{
this
.
storeCode
=
storeCode
;
}
public
String
getName
()
{
public
String
getName
()
{
return
name
;
return
name
;
}
}
...
...
haoban-manage3-web/src/main/java/com/gic/haoban/manage/web/vo/chat/SendExcelVO.java
View file @
db8ab262
...
@@ -27,10 +27,14 @@ public class SendExcelVO implements Serializable{
...
@@ -27,10 +27,14 @@ public class SendExcelVO implements Serializable{
* 关联导购
* 关联导购
*/
*/
private
String
clerkName
;
private
String
clerkName
;
private
String
clerkCode
;
/**
/**
* 关联门店
* 关联门店
*/
*/
private
String
storeName
;
private
String
storeName
;
private
String
storeCode
;
/**
/**
* 完成状态
* 完成状态
*/
*/
...
@@ -56,6 +60,22 @@ public class SendExcelVO implements Serializable{
...
@@ -56,6 +60,22 @@ public class SendExcelVO implements Serializable{
*/
*/
private
Date
endTime
;
private
Date
endTime
;
public
String
getClerkCode
()
{
return
clerkCode
;
}
public
void
setClerkCode
(
String
clerkCode
)
{
this
.
clerkCode
=
clerkCode
;
}
public
String
getStoreCode
()
{
return
storeCode
;
}
public
void
setStoreCode
(
String
storeCode
)
{
this
.
storeCode
=
storeCode
;
}
public
String
getName
()
{
public
String
getName
()
{
return
name
;
return
name
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment