update 广播信息中英翻译功能,用户个人中心apikey失效修改问题
This commit is contained in:
parent
5a8e59336a
commit
c698a8244c
|
@ -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);
|
||||
}
|
||||
|
||||
|
|
|
@ -47,8 +47,5 @@ public class ManageUserInfoDto {
|
|||
@ApiModelProperty(value = "交易金额",example = " 273920.9666238700")
|
||||
private BigDecimal amount;
|
||||
|
||||
@ApiModelProperty(value = "历史支付地址",example = "")
|
||||
private List<HistoryBalanceDto> historyBalance;
|
||||
|
||||
|
||||
}
|
||||
|
|
|
@ -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 ;
|
||||
}
|
|
@ -25,6 +25,8 @@ public class ManageBroadcast {
|
|||
|
||||
private String content;
|
||||
|
||||
private String contentEn;
|
||||
|
||||
private String createUser;
|
||||
|
||||
private String updateUser;
|
||||
|
|
|
@ -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();
|
||||
}
|
||||
|
|
|
@ -35,7 +35,7 @@ public interface ManageUserService{
|
|||
* @param manageUserInfoVo
|
||||
* @return
|
||||
*/
|
||||
R<ManageUserInfoDto> getUserInfo(ManageUserInfoVo manageUserInfoVo);
|
||||
R<WalletEarningsInfoDto> getUserInfo(ManageUserInfoVo manageUserInfoVo);
|
||||
|
||||
|
||||
/**
|
||||
|
|
|
@ -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){
|
||||
|
|
|
@ -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);
|
||||
}
|
||||
|
||||
|
|
|
@ -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 {
|
||||
}
|
||||
};
|
||||
|
||||
}
|
|
@ -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);
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -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 "";
|
||||
}
|
||||
|
||||
}
|
|
@ -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;
|
||||
}
|
||||
|
|
|
@ -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;
|
||||
}
|
||||
|
|
|
@ -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>
|
||||
|
|
|
@ -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);
|
||||
|
|
|
@ -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");
|
||||
|
||||
|
|
|
@ -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();
|
||||
|
|
Loading…
Reference in New Issue