update 广播信息中英翻译功能,用户个人中心apikey失效修改问题

This commit is contained in:
yyb 2025-07-02 16:18:06 +08:00
parent 5a8e59336a
commit c698a8244c
17 changed files with 504 additions and 61 deletions

View File

@ -32,7 +32,7 @@ public class ManageUserController {
private ManageUserService manageUserService;
@PostMapping("/list/info")
@ApiOperation(value = "管理系统:查询注册用户信息列表,包括邮箱、挖矿账号、起付额、挖矿账户状态")
@ApiOperation(value = "管理系统:查询注册用户信息列表,包括邮箱、挖矿账号、钱包地址、起付额、挖矿账户状态等信息")
@RequiresLogin
@RequiresRoles(value = {"back_admin","admin"}, logical = Logical.OR)
public TableDataInfo<ManageUserDto> listInfo(@RequestBody ManageUserVo manageUserVo){
@ -52,7 +52,7 @@ public class ManageUserController {
@ApiOperation(value = "管理系统:挖矿账户所有收益金额、时间、状态、转账地址")
@RequiresLogin
@RequiresRoles(value = {"back_admin","admin"}, logical = Logical.OR)
public R<ManageUserInfoDto> getUserInfo(@RequestBody ManageUserInfoVo manageUserInfoVo){
public R<WalletEarningsInfoDto> getUserInfo(@RequestBody ManageUserInfoVo manageUserInfoVo){
return manageUserService.getUserInfo(manageUserInfoVo);
}

View File

@ -47,8 +47,5 @@ public class ManageUserInfoDto {
@ApiModelProperty(value = "交易金额",example = " 273920.9666238700")
private BigDecimal amount;
@ApiModelProperty(value = "历史支付地址",example = "")
private List<HistoryBalanceDto> historyBalance;
}

View File

@ -0,0 +1,29 @@
package com.m2pool.manage.dto;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.List;
/**
* @Description 钱包收益详情信息返回对象
* @Date 2025/5/22 17:18
* @Author yyb
*/
@Builder
@Data
@NoArgsConstructor
@AllArgsConstructor
@ApiModel(value = "WalletEarningsInfoDto", description = "钱包收益详情信息返回对象")
public class WalletEarningsInfoDto {
@ApiModelProperty(value = "钱包历史地址集合",example = "")
List<HistoryBalanceDto> historyBalance;
@ApiModelProperty(value = "钱包收益信息集合",example = "")
List<ManageUserInfoDto> walletInInfo ;
}

View File

@ -25,6 +25,8 @@ public class ManageBroadcast {
private String content;
private String contentEn;
private String createUser;
private String updateUser;

View File

@ -33,7 +33,7 @@ public interface ManageBroadcastMapper extends BaseMapper<ManageBroadcast> {
* @return
*/
@DistributionDB
ManageUserInfoDto getUserInfo(@Param("user") String user,@Param("coin") String coin);
List<ManageUserInfoDto> getUserInfo(@Param("user") String user,@Param("coin") String coin, @Param("startDate") Date startDate, @Param("endDate") Date endDate);
/**
@ -80,4 +80,11 @@ public interface ManageBroadcastMapper extends BaseMapper<ManageBroadcast> {
*/
@HashRateDB
List<ManageMiningUserOnlineDto> getMinerUserOnlineStatus(@Param("minerUser") String minerUser, @Param("coin") String coin, @Param("startDate") Date startDate, @Param("endDate") Date endDate);
/**
* 获取广播信息列表
* @return
*/
List<ManageBroadcastDto> getListDataByPage();
}

View File

@ -35,7 +35,7 @@ public interface ManageUserService{
* @param manageUserInfoVo
* @return
*/
R<ManageUserInfoDto> getUserInfo(ManageUserInfoVo manageUserInfoVo);
R<WalletEarningsInfoDto> getUserInfo(ManageUserInfoVo manageUserInfoVo);
/**

View File

@ -13,11 +13,14 @@ import com.m2pool.manage.dto.ManageBroadcastDto;
import com.m2pool.manage.entity.ManageBroadcast;
import com.m2pool.manage.mapper.ManageBroadcastMapper;
import com.m2pool.manage.service.ManageBroadcastService;
import com.m2pool.manage.utils.TranslateUtils;
import com.m2pool.manage.vo.ManageBaseVo;
import com.m2pool.manage.vo.ManageBroadcastVo;
import com.m2pool.manage.vo.PageVo;
import jdk.nashorn.internal.ir.annotations.Reference;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.beans.Transient;
import java.time.LocalDateTime;
import java.util.List;
@ -30,6 +33,8 @@ import java.util.stream.Collectors;
public class ManageBroadcastServiceImpl extends ServiceImpl<ManageBroadcastMapper, ManageBroadcast> implements ManageBroadcastService {
@Resource
private ManageBroadcastMapper manageBroadcastMapper;
/**
* 获取所有广播信息
@ -38,21 +43,13 @@ public class ManageBroadcastServiceImpl extends ServiceImpl<ManageBroadcastMappe
*/
@Override
public TableDataInfo<ManageBroadcastDto> getListDataByPage(PageVo pageVo) {
PageHelper.startPage(pageVo.getPageNum(), pageVo.getPageSize());
List<ManageBroadcast> list = this.list(new LambdaQueryWrapper<ManageBroadcast>().eq(ManageBroadcast::getDel, false));
List<ManageBroadcastDto> collect = list.stream().map(broadcast -> ManageBroadcastDto.builder()
.content(broadcast.getContent())
.id(broadcast.getId())
.createUser(broadcast.getCreateUser())
.updateUser(broadcast.getUpdateUser())
.updateTime(broadcast.getUpdateTime())
.createTime(broadcast.getCreateTime())
.build()).collect(Collectors.toList());
PageHelper.clearPage();
return getDataTable(collect);
List<ManageBroadcastDto> listDataByPage = manageBroadcastMapper.getListDataByPage();
return getDataTable(listDataByPage);
}
private TableDataInfo<ManageBroadcastDto> getDataTable(List<ManageBroadcastDto> list)
private TableDataInfo<ManageBroadcastDto> getDataTable(List<ManageBroadcastDto> list)
{
TableDataInfo<ManageBroadcastDto> rspData = new TableDataInfo<ManageBroadcastDto>();
rspData.setCode(HttpStatus.SUCCESS);
@ -61,6 +58,7 @@ public class ManageBroadcastServiceImpl extends ServiceImpl<ManageBroadcastMappe
PageInfo<ManageBroadcastDto> pageInfo = new PageInfo<ManageBroadcastDto>(list);
rspData.setTotal(pageInfo.getTotal());
rspData.setTotalPage(pageInfo.getPages());
PageHelper.clearPage();
return rspData;
}
@ -78,16 +76,36 @@ public class ManageBroadcastServiceImpl extends ServiceImpl<ManageBroadcastMappe
List<ManageBroadcast> list = this.list(eq);
List<ManageBroadcastDto> collect = list.stream()
.map(broadcast -> ManageBroadcastDto.builder()
.content(broadcast.getContent())
.id(broadcast.getId())
.createUser(broadcast.getCreateUser())
.updateUser(broadcast.getUpdateUser())
.updateTime(broadcast.getUpdateTime())
.createTime(broadcast.getCreateTime())
.build()
).collect(Collectors.toList());
List<ManageBroadcastDto> collect;
if (manageBaseVo != null && "zh".equals(manageBaseVo.getLang())){
collect = list.stream().map(broadcast ->
ManageBroadcastDto.builder()
.content(broadcast.getContent())
.id(broadcast.getId())
.createUser(broadcast.getCreateUser())
.updateUser(broadcast.getUpdateUser())
.updateTime(broadcast.getUpdateTime())
.createTime(broadcast.getCreateTime())
.build()
).collect(Collectors.toList());
}else{
collect = list.stream().map(broadcast -> {
//如果英文为null需要翻译并保存一下
if("".equals(broadcast.getContentEn())){
broadcast.setContentEn(TranslateUtils.translate(broadcast.getContent(), "zh", "en"));
manageBroadcastMapper.updateById(broadcast);
}
return ManageBroadcastDto.builder()
.content(broadcast.getContentEn())
.id(broadcast.getId())
.createUser(broadcast.getCreateUser())
.updateUser(broadcast.getUpdateUser())
.updateTime(broadcast.getUpdateTime())
.createTime(broadcast.getCreateTime())
.build();
}).collect(Collectors.toList());
}
return R.success(collect);
}
@ -100,8 +118,10 @@ public class ManageBroadcastServiceImpl extends ServiceImpl<ManageBroadcastMappe
*/
@Override
public R<String> addBroadcast(ManageBroadcastVo broadcastVo) {
String translate = TranslateUtils.translate(broadcastVo.getContent(), "zh", "en");
ManageBroadcast broadcast = ManageBroadcast.builder()
.content(broadcastVo.getContent())
.contentEn(translate)
.createUser(SecurityUtils.getUsername())
.updateTime(LocalDateTime.now())
.build();
@ -128,9 +148,11 @@ public class ManageBroadcastServiceImpl extends ServiceImpl<ManageBroadcastMappe
@Override
public R<String> updateBroadcast(ManageBroadcastVo broadcastVo) {
String translate = TranslateUtils.translate(broadcastVo.getContent(), "zh", "en");
boolean b = this.updateById(ManageBroadcast.builder()
.id(broadcastVo.getId())
.content(broadcastVo.getContent())
.contentEn(translate)
.updateUser(SecurityUtils.getUsername())
.build());
if (b){

View File

@ -43,7 +43,6 @@ public class ManageUserServiceImpl implements ManageUserService {
public TableDataInfo<ManageUserDto> listInfo(ManageUserVo manageUserVo) {
PageHelper.startPage(manageUserVo.getPageNum(), manageUserVo.getPageSize());
List<ManageUserDto> manageUserDtos = manageBroadcastMapper.selectUserListByPage(manageUserVo.getCoin(), manageUserVo.getUser(), manageUserVo.getMinerUser());
PageHelper.clearPage();
return getDataTable(manageUserDtos);
}
@ -56,6 +55,7 @@ public class ManageUserServiceImpl implements ManageUserService {
PageInfo<ManageUserDto> pageInfo = new PageInfo<>(list);
rspData.setTotal(pageInfo.getTotal());
rspData.setTotalPage(pageInfo.getPages());
PageHelper.clearPage();
return rspData;
}
@ -95,18 +95,12 @@ public class ManageUserServiceImpl implements ManageUserService {
}
@Override
public R<ManageUserInfoDto> getUserInfo(ManageUserInfoVo manageUserInfoVo) {
ManageUserInfoDto manageUserInfoDto = manageBroadcastMapper.getUserInfo(manageUserInfoVo.getMinerUser(), manageUserInfoVo.getCoin());
public R<WalletEarningsInfoDto> getUserInfo(ManageUserInfoVo manageUserInfoVo) {
//获取挖矿账户历史收益记录
List<ManageUserInfoDto> walletInInfo = manageBroadcastMapper.getUserInfo(manageUserInfoVo.getMinerUser(), manageUserInfoVo.getCoin(), manageUserInfoVo.getStartDate(), manageUserInfoVo.getEndDate());
//获取挖矿账户历史地址
List<HistoryBalanceDto> historyBalance = manageBroadcastMapper.getHistoryBalance(manageUserInfoVo.getMinerUser(), manageUserInfoVo.getCoin());
if (manageUserInfoDto == null && !historyBalance.isEmpty()){
manageUserInfoDto = new ManageUserInfoDto();
manageUserInfoDto.setUser(manageUserInfoVo.getMinerUser());
manageUserInfoDto.setCoin(manageUserInfoVo.getCoin());
manageUserInfoDto.setHistoryBalance(historyBalance);
}else if(manageUserInfoDto !=null && !historyBalance.isEmpty()){
manageUserInfoDto.setHistoryBalance(historyBalance);
}
WalletEarningsInfoDto manageUserInfoDto = new WalletEarningsInfoDto(historyBalance,walletInInfo);
return R.success(manageUserInfoDto);
}

View File

@ -0,0 +1,159 @@
package com.m2pool.manage.utils;
import java.io.BufferedReader;
import java.io.Closeable;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLEncoder;
import java.security.KeyManagementException;
import java.security.NoSuchAlgorithmException;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import java.util.Map;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
class HttpGet {
protected static final int SOCKET_TIMEOUT = 10000; // 10S
protected static final String GET = "GET";
public static String get(String host, Map<String, String> params) {
try {
// 设置SSLContext
SSLContext sslcontext = SSLContext.getInstance("TLS");
sslcontext.init(null, new TrustManager[] { myX509TrustManager }, null);
String sendUrl = getUrlWithQueryString(host, params);
// System.out.println("URL:" + sendUrl);
URL uri = new URL(sendUrl); // 创建URL对象
HttpURLConnection conn = (HttpURLConnection) uri.openConnection();
if (conn instanceof HttpsURLConnection) {
((HttpsURLConnection) conn).setSSLSocketFactory(sslcontext.getSocketFactory());
}
conn.setConnectTimeout(SOCKET_TIMEOUT); // 设置相应超时
conn.setRequestMethod(GET);
int statusCode = conn.getResponseCode();
if (statusCode != HttpURLConnection.HTTP_OK) {
System.out.println("Http错误码" + statusCode);
}
// 读取服务器的数据
InputStream is = conn.getInputStream();
BufferedReader br = new BufferedReader(new InputStreamReader(is));
StringBuilder builder = new StringBuilder();
String line = null;
while ((line = br.readLine()) != null) {
builder.append(line);
}
String text = builder.toString();
close(br); // 关闭数据流
close(is); // 关闭数据流
conn.disconnect(); // 断开连接
return text;
} catch (MalformedURLException e) {
System.out.println("翻译失败URL错误"+e.getMessage());
} catch (IOException e) {
System.out.println("翻译失败IO错误"+e.getMessage());
} catch (KeyManagementException e) {
System.out.println("翻译失败,密钥错误"+e.getMessage());
} catch (NoSuchAlgorithmException e) {
System.out.println("翻译失败,算法错误"+e.getMessage());
}
return null;
}
public static String getUrlWithQueryString(String url, Map<String, String> params) {
if (params == null) {
return url;
}
StringBuilder builder = new StringBuilder(url);
if (url.contains("?")) {
builder.append("&");
} else {
builder.append("?");
}
int i = 0;
for (String key : params.keySet()) {
String value = params.get(key);
if (value == null) { // 过滤空的key
continue;
}
if (i != 0) {
builder.append('&');
}
builder.append(key);
builder.append('=');
builder.append(encode(value));
i++;
}
return builder.toString();
}
protected static void close(Closeable closeable) {
if (closeable != null) {
try {
closeable.close();
} catch (IOException e) {
System.out.println("关闭IO错误"+e.getMessage());
}
}
}
/**
* 对输入的字符串进行URL编码, 即转换为%20这种形式
*
* @param input 原文
* @return URL编码. 如果编码失败, 则返回原文
*/
public static String encode(String input) {
if (input == null) {
return "";
}
try {
return URLEncoder.encode(input, "utf-8");
} catch (UnsupportedEncodingException e) {
System.out.println("URL编码错误"+e.getMessage());
}
return input;
}
private static TrustManager myX509TrustManager = new X509TrustManager() {
@Override
public X509Certificate[] getAcceptedIssuers() {
return null;
}
@Override
public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
}
@Override
public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
}
};
}

View File

@ -0,0 +1,127 @@
package com.m2pool.manage.utils;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
/**
* MD5编码相关的类
*
* @author yyb
*
*/
public class MD5Utils {
// 首先初始化一个字符数组用来存放每个16进制字符
private static final char[] hexDigits = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd',
'e', 'f' };
/**
* 获得一个字符串的MD5值
*
* @param input 输入的字符串
* @return 输入字符串的MD5值
*
*/
public static String md5(String input) {
if (input == null)
return null;
try {
try {
// 拿到一个MD5转换器如果想要SHA1参数换成SHA1
MessageDigest messageDigest = MessageDigest.getInstance("MD5");
// 输入的字符串转换成字节数组
byte[] inputByteArray = input.getBytes("utf-8");
// inputByteArray是输入字符串转换得到的字节数组
messageDigest.update(inputByteArray);
// 转换并返回结果也是字节数组包含16个元素
byte[] resultByteArray = messageDigest.digest();
// 字符数组转换成字符串返回
return byteArrayToHex(resultByteArray);
} catch (UnsupportedEncodingException e) {
return null;
}
} catch (NoSuchAlgorithmException e) {
return null;
}
}
/**
* 获取文件的MD5值
*
* @param file
* @return
*/
public static String md5(File file) {
try {
if (!file.isFile()) {
System.err.println("文件" + file.getAbsolutePath() + "不存在或者不是文件");
return null;
}
FileInputStream in = new FileInputStream(file);
String result = md5(in);
in.close();
return result;
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return null;
}
public static String md5(InputStream in) {
try {
MessageDigest messagedigest = MessageDigest.getInstance("MD5");
byte[] buffer = new byte[1024];
int read = 0;
while ((read = in.read(buffer)) != -1) {
messagedigest.update(buffer, 0, read);
}
in.close();
String result = byteArrayToHex(messagedigest.digest());
return result;
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return null;
}
private static String byteArrayToHex(byte[] byteArray) {
// new一个字符数组这个就是用来组成结果字符串的解释一下一个byte是八位二进制也就是2位十六进制字符2的8次方等于16的2次方
char[] resultCharArray = new char[byteArray.length * 2];
// 遍历字节数组通过位运算位运算效率高转换成字符放到字符数组中去
int index = 0;
for (byte b : byteArray) {
resultCharArray[index++] = hexDigits[b >>> 4 & 0xf];
resultCharArray[index++] = hexDigits[b & 0xf];
}
// 字符数组组合成字符串返回
return new String(resultCharArray);
}
}

View File

@ -0,0 +1,56 @@
package com.m2pool.manage.utils;
import com.alibaba.nacos.shaded.com.google.gson.JsonArray;
import com.alibaba.nacos.shaded.com.google.gson.JsonObject;
import com.alibaba.nacos.shaded.com.google.gson.JsonParser;
import java.util.HashMap;
import java.util.Map;
public class TranslateUtils {
private static final String TRANS_API_HOST = "https://fanyi-api.baidu.com/api/trans/vip/translate";
private static String appid = "20250702002395339";
private static String securityKey ="yKbjIAIg_FpbdESYaE7A";
public static String translate(String query, String from, String to) {
Map<String, String> params = buildParams(query, from, to);
String s = HttpGet.get(TRANS_API_HOST, params);
return extractDstFromResponse(s);
}
private static Map<String, String> buildParams(String query, String from, String to) {
Map<String, String> params = new HashMap<String, String>();
params.put("q", query);
params.put("from", from);
params.put("to", to);
params.put("appid", appid);
// 随机数
String salt = String.valueOf(System.currentTimeMillis());
params.put("salt", salt);
// 签名
String src = appid + query + salt + securityKey; // 加密前的原文
params.put("sign", MD5Utils.md5(src));
return params;
}
private static String extractDstFromResponse(String response) {
try {
JsonObject jsonObject = JsonParser.parseString(response).getAsJsonObject();
JsonArray transResultArray = jsonObject.getAsJsonArray("trans_result");
if (transResultArray.size() > 0) {
JsonObject firstResult = transResultArray.get(0).getAsJsonObject();
return firstResult.get("dst").getAsString();
}
} catch (Exception e) {
System.out.println("翻译结果解析失败"+e.getMessage());
}
return "";
}
}

View File

@ -22,4 +22,8 @@ import java.time.LocalDateTime;
public class ManageBaseVo {
@ApiModelProperty(value = "id",example = "1")
private Long id;
@ApiModelProperty(value = "语言",example = "zh")
private String lang;
}

View File

@ -1,11 +1,15 @@
package com.m2pool.manage.vo;
import com.fasterxml.jackson.annotation.JsonFormat;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.format.annotation.DateTimeFormat;
import java.util.Date;
/**
* @Description 查询用户详情信请求对象
@ -26,4 +30,13 @@ public class ManageUserInfoVo {
@ApiModelProperty(value = "币种",example = "nexa",required = true)
private String coin;
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@ApiModelProperty(value = "开始时间",example = "2025-06-22")
private Date startDate;
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
@ApiModelProperty(value = "结束时间",example = "2025-06-22")
private Date endDate;
}

View File

@ -40,10 +40,22 @@
amount,
state
FROM
wallet_inv2
WHERE
coin = #{coin}
AND `user` = #{user};
wallet_in
<where>
coin = #{coin} AND `user` = #{user}
<choose>
<when test="startDate != null and endDate != null">
and `create_date` >= #{startDate} AND `create_date`<![CDATA[ <= ]]> #{endDate}
</when>
<otherwise>
and `create_date` >= DATE_SUB(NOW(), INTERVAL 1 MONTH)
</otherwise>
</choose>
</where>
</select>
<select id="getHistoryBalance" resultType="com.m2pool.manage.dto.HistoryBalanceDto">
@ -53,7 +65,8 @@
user_account_balance uab
LEFT JOIN user_miner_account uma ON uab.ma_id = uma.id
WHERE
uma.coin = #{coin} AND uma.miner_user=#{user} AND uab.status = 99
uma.coin = #{coin} AND uma.miner_user=#{user}
order by uab.status desc
</select>
<select id="getMiningUserInfo" resultType="com.m2pool.manage.dto.ManageMiningUserDto">
SELECT
@ -98,5 +111,17 @@
<select id="getAllMinerUserByCoin" resultType="java.lang.String">
select miner_user from user_miner_account where coin = #{coin} and `user` = #{user} and status = 0;
</select>
<select id="getListDataByPage" resultType="com.m2pool.manage.dto.ManageBroadcastDto">
SELECT
id,
content,
create_user as createUser,
update_user as updateUser,
update_time as updateTime,
create_time as createTime
FROM
manage_broadcast
where del =false
</select>
</mapper>

View File

@ -516,7 +516,11 @@ public class UserMinerServiceImpl implements UserMinserService {
}
}
int count = uaMapper.getApiKeyCountByUser(user);
List<UserApi> list = uaMapper.getAPIListByUser(user);
long count = list.stream().filter(e -> {
OpenApiKeyInfo openApiKeyInfo = openApiService.getOpenApiKeyInfo(e.getKey());
return openApiKeyInfo != null;
}).count();
if(count >= 5){
return AjaxResult.error("apiKey创建次数已达上限5");
}
@ -576,7 +580,10 @@ public class UserMinerServiceImpl implements UserMinserService {
return null;
}
List<UserApi> list = uaMapper.getAPIListByUser(user);
List<UserApiDto> returnList = list.stream().map(e -> {
List<UserApiDto> returnList = list.stream().filter(e -> {
OpenApiKeyInfo openApiKeyInfo = openApiService.getOpenApiKeyInfo(e.getKey());
return openApiKeyInfo != null;
}).map(e -> {
UserApiDto dto = new UserApiDto();
BeanUtils.copyProperties(e,dto);
if(StringUtils.isNull(e.getPerms())){
@ -661,8 +668,9 @@ public class UserMinerServiceImpl implements UserMinserService {
}
OpenApiKeyInfo info = openApiService.getOpenApiKeyInfo(userApi.getKey());
System.out.println("info:"+info);
boolean result = uaMapper.updateApiKey(vo,user);
if(result){
info.setApiIp(vo.getIp());
info.setPermissions(permsSet);

View File

@ -48,7 +48,7 @@ public class DataTask {
private static final Logger log = LoggerFactory.getLogger(DataTask.class);
@Scheduled(cron = "20 1,3,10,31,33,40 * * * ?")
@Scheduled(cron = "20 1,3,10,31,33,40 * * * ?")
public void NEXA30mDataToDB(){
//String nowStr = DateUtils.dateTimeNow("yyyy-MM-dd HH:mm:00");
@ -227,7 +227,7 @@ public class DataTask {
}
@Scheduled(cron = "0 1,3,5 0 * * ?")
@Scheduled(cron = "0 1,3,5 0 * * ?")
public void NEXADailyDataToDB(){
String nowStr = DateUtils.dateTimeNow(DateUtils.YYYY_MM_DD);
Date now = DateUtils.parseDate( nowStr);
@ -379,7 +379,7 @@ public class DataTask {
}
}
@Scheduled(cron = "50 0,1,30,31 * * * ?")
@Scheduled(cron = "50 0,1,30,31 * * * ?")
public void NEXAUserPowerRatioDataToDB(){
//String nowStr = DateUtils.dateTimeNow("yyyy-MM-dd HH:mm:00");
@ -405,7 +405,7 @@ public class DataTask {
@Scheduled(cron = "30 3 0/1 * * ?")
@Scheduled(cron = "30 3 0/1 * * ?")
//@Scheduled(cron = "0 0/2 * * * ?")
public void NEXALuckyDataToDB(){
log.info("nexa幸运值---定时任务开始");
@ -497,7 +497,7 @@ public class DataTask {
}
@Scheduled(cron = "11 1,3,11,31,33,41 * * * ?")
@Scheduled(cron = "11 1,3,11,31,33,41 * * * ?")
public void GRS30mDataToDB(){
//String nowStr = DateUtils.dateTimeNow("yyyy-MM-dd HH:mm:00");
@ -663,7 +663,7 @@ public class DataTask {
}
@Scheduled(cron = "1 1,3,5 0 * * ?")
@Scheduled(cron = "1 1,3,5 0 * * ?")
public void GRSDailyDataToDB(){
String nowStr = DateUtils.dateTimeNow(DateUtils.YYYY_MM_DD);
Date now = DateUtils.parseDate( nowStr);
@ -816,7 +816,7 @@ public class DataTask {
}
}
@Scheduled(cron = "51 0,1,30,31 * * * ?")
@Scheduled(cron = "51 0,1,30,31 * * * ?")
public void GRSUserPowerRatioDataToDB(){
//String nowStr = DateUtils.dateTimeNow("yyyy-MM-dd HH:mm:00");
@ -846,7 +846,7 @@ public class DataTask {
}
@Scheduled(cron = "31 3 0/1 * * ?")
@Scheduled(cron = "31 3 0/1 * * ?")
//@Scheduled(cron = "0 0/2 * * * ?")
public void GRSLuckyDataToDB(){
log.info("GRS幸运值---定时任务开始");
@ -909,7 +909,7 @@ public class DataTask {
dto.getLuck3d(),dto.getLuck7d(),dto.getLuck30d(),dto.getLuck90d());;
}
@Scheduled(cron = "12 1,3,12,31,33,42 * * * ?")
@Scheduled(cron = "12 1,3,12,31,33,42 * * * ?")
public void MONA30mDataToDB(){
//String nowStr = DateUtils.dateTimeNow("yyyy-MM-dd HH:mm:00");
@ -1072,7 +1072,7 @@ public class DataTask {
}
@Scheduled(cron = "2 1,3,5 0 * * ?")
@Scheduled(cron = "2 1,3,5 0 * * ?")
public void MONADailyDataToDB(){
String nowStr = DateUtils.dateTimeNow(DateUtils.YYYY_MM_DD);
Date now = DateUtils.parseDate( nowStr);
@ -1227,7 +1227,7 @@ public class DataTask {
}
}
@Scheduled(cron = "52 0,1,30,31 * * * ?")
@Scheduled(cron = "52 0,1,30,31 * * * ?")
public void MONAUserPowerRatioDataToDB(){
//String nowStr = DateUtils.dateTimeNow("yyyy-MM-dd HH:mm:00");

View File

@ -42,7 +42,7 @@ public class NeaxPriceTask {
private RedisService redisService;
//@Scheduled(cron = "0 0/1 * * * ?")
@Scheduled(cron = "0 0,3,30,33 * * * ?")
@Scheduled(cron = "0 0,3,30,33 * * * ?")
public void NEXAPriceToRedis()
{
Map<String, BigDecimal> map = getResultFromNetByAllCoins();