Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
H
haikang-client
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
杨立
haikang-client
Commits
30027566
提交
30027566
authored
3月 23, 2022
作者:
wangqiang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
客户端优化
上级
2f7cf16c
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
51 行增加
和
47 行删除
+51
-47
ProgramController.java
...c/main/java/com/priusis/controller/ProgramController.java
+51
-47
没有找到文件。
apq-pc-client/src/main/java/com/priusis/controller/ProgramController.java
浏览文件 @
30027566
...
...
@@ -109,53 +109,57 @@ public class ProgramController {
@GetMapping
(
value
=
"{type}/list"
)
public
R
<
Page
<
Map
<
String
,
String
>>>
list
(
@PathVariable
@Pattern
(
regexp
=
"install|upgrade"
)
String
type
,
@RequestParam
(
required
=
false
,
defaultValue
=
"1"
)
Integer
current
,
@RequestParam
(
required
=
false
,
defaultValue
=
"10"
)
Integer
size
)
throws
IOException
{
String
mac
=
MacAddrUtil
.
get
();
if
(
StrUtil
.
isBlank
(
mac
))
return
R
.
error
(
"未获取到MAC地址"
);
String
url
=
gateway
+
StrUtil
.
format
(
type
.
equals
(
"install"
)
?
installUrl
:
upgradeUrl
,
mac
,
current
,
size
);
JSONObject
rsp
=
JSONUtil
.
parseObj
(
HttpUtil
.
get
(
url
));
if
(
ObjectUtil
.
notEqual
(
rsp
.
getInt
(
"code"
),
0
))
return
R
.
error
(
rsp
.
getStr
(
"msg"
));
Page
<
Map
<
String
,
String
>>
page
=
new
Page
<>();
page
.
setCurrent
(
current
).
setSize
(
size
).
setTotal
(
rsp
.
getLong
(
"total"
));
JSONArray
rows
=
rsp
.
getJSONArray
(
"rows"
);
if
(
CollUtil
.
isEmpty
(
rows
))
return
R
.
success
(
page
.
setRecords
(
Collections
.
emptyList
()));
List
<
Map
<
String
,
String
>>
programs
=
installedProgramCache
.
getPrograms
();
List
<
Map
<
String
,
String
>>
list
=
rows
.
stream
().
map
(
JSONObject
.
class
::
cast
)
.
map
(
o
->
{
Map
<
String
,
String
>
map
=
new
HashMap
<>();
map
.
put
(
"id"
,
o
.
getStr
(
type
.
equals
(
"install"
)
?
"installId"
:
"upgradeId"
));
map
.
put
(
"name"
,
StrUtil
.
subBefore
(
o
.
getStr
(
"fileName"
),
'.'
,
true
));
map
.
put
(
"size"
,
o
.
getStr
(
"fileSize"
));
map
.
put
(
"version"
,
o
.
getStr
(
"version"
));
map
.
put
(
"localVersion"
,
null
);
map
.
put
(
"url"
,
o
.
getStr
(
"url"
));
Long
id
=
Convert
.
toLong
(
map
.
get
(
"id"
));
String
key
=
type
+
"-"
+
id
;
map
.
put
(
"status"
,
SET
.
contains
(
key
)
?
"1"
:
MAP
.
containsKey
(
key
)
?
"2"
:
"0"
);
return
map
;
})
/*.peek(m -> */
.
peek
(
m
->
{
if
(
type
.
equals
(
"install"
))
{
programs
.
stream
()
.
filter
(
p
->
p
.
get
(
"name"
).
equalsIgnoreCase
(
m
.
get
(
"name"
)))
.
findFirst
()
.
ifPresent
(
p
->
m
.
put
(
"localVersion"
,
p
.
get
(
"version"
)));
}
else
{
programs
.
stream
()
.
collect
(
Collectors
.
toMap
(
p
->
StrUtil
.
similar
(
p
.
get
(
"name"
).
toLowerCase
(),
m
.
get
(
"name"
).
toLowerCase
()),
p
->
p
.
getOrDefault
(
"version"
,
""
),
(
l
,
r
)
->
r
))
.
entrySet
()
.
stream
()
.
max
(
Map
.
Entry
.
comparingByKey
())
.
filter
(
e
->
e
.
getKey
()
>=
MIN_MATCH
)
.
filter
(
e
->
StrUtil
.
isNotBlank
(
e
.
getValue
()))
.
ifPresent
(
e
->
m
.
put
(
"localVersion"
,
e
.
getValue
()));
}
})
.
collect
(
Collectors
.
toList
());
return
R
.
success
(
page
.
setRecords
(
list
));
@RequestParam
(
required
=
false
,
defaultValue
=
"10"
)
Integer
size
)
{
try
{
String
mac
=
MacAddrUtil
.
get
();
if
(
StrUtil
.
isBlank
(
mac
))
return
R
.
error
(
"未获取到MAC地址"
);
String
url
=
gateway
+
StrUtil
.
format
(
type
.
equals
(
"install"
)
?
installUrl
:
upgradeUrl
,
mac
,
current
,
size
);
JSONObject
rsp
=
JSONUtil
.
parseObj
(
HttpUtil
.
get
(
url
));
if
(
ObjectUtil
.
notEqual
(
rsp
.
getInt
(
"code"
),
0
))
return
R
.
error
(
rsp
.
getStr
(
"msg"
));
Page
<
Map
<
String
,
String
>>
page
=
new
Page
<>();
page
.
setCurrent
(
current
).
setSize
(
size
).
setTotal
(
rsp
.
getLong
(
"total"
));
JSONArray
rows
=
rsp
.
getJSONArray
(
"rows"
);
if
(
CollUtil
.
isEmpty
(
rows
))
return
R
.
success
(
page
.
setRecords
(
Collections
.
emptyList
()));
List
<
Map
<
String
,
String
>>
programs
=
installedProgramCache
.
getPrograms
();
List
<
Map
<
String
,
String
>>
list
=
rows
.
stream
().
map
(
JSONObject
.
class
::
cast
)
.
map
(
o
->
{
Map
<
String
,
String
>
map
=
new
HashMap
<>();
map
.
put
(
"id"
,
o
.
getStr
(
type
.
equals
(
"install"
)
?
"installId"
:
"upgradeId"
));
map
.
put
(
"name"
,
StrUtil
.
subBefore
(
o
.
getStr
(
"fileName"
),
'.'
,
true
));
map
.
put
(
"size"
,
o
.
getStr
(
"fileSize"
));
map
.
put
(
"version"
,
o
.
getStr
(
"version"
));
map
.
put
(
"localVersion"
,
null
);
map
.
put
(
"url"
,
o
.
getStr
(
"url"
));
Long
id
=
Convert
.
toLong
(
map
.
get
(
"id"
));
String
key
=
type
+
"-"
+
id
;
map
.
put
(
"status"
,
SET
.
contains
(
key
)
?
"1"
:
MAP
.
containsKey
(
key
)
?
"2"
:
"0"
);
return
map
;
})
/*.peek(m -> */
.
peek
(
m
->
{
if
(
type
.
equals
(
"install"
))
{
programs
.
stream
()
.
filter
(
p
->
p
.
get
(
"name"
).
equalsIgnoreCase
(
m
.
get
(
"name"
)))
.
findFirst
()
.
ifPresent
(
p
->
m
.
put
(
"localVersion"
,
p
.
get
(
"version"
)));
}
else
{
programs
.
stream
()
.
collect
(
Collectors
.
toMap
(
p
->
StrUtil
.
similar
(
p
.
get
(
"name"
).
toLowerCase
(),
m
.
get
(
"name"
).
toLowerCase
()),
p
->
p
.
getOrDefault
(
"version"
,
""
),
(
l
,
r
)
->
r
))
.
entrySet
()
.
stream
()
.
max
(
Map
.
Entry
.
comparingByKey
())
.
filter
(
e
->
e
.
getKey
()
>=
MIN_MATCH
)
.
filter
(
e
->
StrUtil
.
isNotBlank
(
e
.
getValue
()))
.
ifPresent
(
e
->
m
.
put
(
"localVersion"
,
e
.
getValue
()));
}
})
.
collect
(
Collectors
.
toList
());
return
R
.
success
(
page
.
setRecords
(
list
));
}
catch
(
IOException
e
)
{
log
.
error
(
"客户端系统异常"
,
e
);
return
R
.
error
(
"客户端正在初始化,请稍后再试!"
);
}
}
private
static
final
Set
<
String
>
SET
=
new
ConcurrentHashSet
<>();
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论