Files
juipnet/Services/Hncore.Pass.Vpn/Service/AgentClient13Service.cs
“wanyongkang” e880156c63 水滴查看在线
2024-04-15 18:22:43 +08:00

517 lines
18 KiB
C#

using AngleSharp.Html.Parser;
using Hncore.Infrastructure.Common;
using Hncore.Infrastructure.Extension;
using Hncore.Infrastructure.Serializer;
using Hncore.Infrastructure.WebApi;
using Hncore.Pass.Vpn.Model;
using Hncore.Pass.Vpn.Request.Product;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
using System;
using System.Text;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.IO;
using System.Threading.Tasks;
using System.Security.Cryptography;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
namespace Hncore.Pass.Vpn.Service
{
public class AgentClient13Service:AgentClientBaseService
{
string LoginUrl { get; set; } = "api/login";
string LoginCodeUrl { get; set; } = "main/imgcode.html";
string RefrushTokenUrl { get; set; } = "agent/index.html";
string SingleAddUrl { get; set; } = "api/number";
string SingleReAddUrl { get; set; } = "api/number/renew";
string MuiltAddUrl { get; set; } = "agent/memberMuiltAdd.html";
string RefundUrl { get; set; } = "api/number/refund";
string UpdateUrl = "api/number/";//agent/memberUpdate/id/1155709.html
string OnlineUrl { get; set; } = "api/numberLine/";
string KIllUrl { get; set; } = "api/numberOffline";
string searchAccountUrl = "api/numberSingle/";
string searchTestAccountUrl = "api/numberSingle/";
string DeleteUrl { get; set; } = "api/number/refund";//1160862.html";
IHttpClientFactory m_HttpClientFactory;
public AgentClient13Service(IHttpClientFactory httpClientFactory):base(httpClientFactory)
{
m_HttpClientFactory = httpClientFactory;
}
public override async Task<int> RefrushStatus()
{
return 1;
}
public override async Task<(byte[], string)> GetCode()
{
var client = CreateHttpClient(false);
if (this.LoginUrl.NotHas()) return (null, "");
var getResp = await client.GetAsync(this.LoginUrl);
var cookie = this.GetCookie(getResp, "PHPSESSID");
if (cookie.Has())
{
client.DefaultRequestHeaders.Add("Cookie", cookie);
var ret = await client.GetByteArrayAsync(this.LoginCodeUrl + "?t=" + DateTime.Now.Millisecond);
return (ret, cookie);
}
return (null, "");
}
public override async Task<ApiResult> Login(AgentLoginRequest request)
{
return new ApiResult(request.Key);
}
public override bool CheckAccount(int productId,List<string> accounts)
{
return false;
}
/// <summary>
/// 新开
/// </summary>
/// <param name="packageId"></param>
/// <param name="account"></param>
/// <param name="pwd"></param>
/// <returns></returns>
public override async Task<ApiResult> NewAccount(string packageKey, string account, string pwd, int connCount = 1, int accountType = 1, int payCount = 1)
{
var remark = "";
if(account.Contains("-")){
string[] arrStr = account.Split('-');
account = arrStr[0];
remark = arrStr[1];
}
Random rd = new Random(Guid.NewGuid().GetHashCode());
int i = rd.Next();
var time_s = DateTime.Now.GetUnixTimeStamp();
var agentid = "admin1";
var nonce = MD5(time_s.ToString()) + i.ToString();
var apikey = "0c4641686764e0ee56ef54b16fddc966";
var sign = MD5(time_s+nonce+apikey);
var userid = "kh";
var url = "/api/raduserCreate?agentid="+agentid+"&ti="+time_s+"&nonce="+nonce+"&sign="+sign+"&userid="+userid+"&username="+account+"&password="+pwd+"&prdid=8&maxonline="+connCount+"&day="+packageKey+"&remark="+remark;
var client = CreateHttpClient();
var resp = await client.GetAsync(url);
var content = await resp.Content.ReadAsStringAsync();
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
var status = jo["errcode"].ToString();
if (status =="0")
{
return new ApiResult(ResultCode.C_SUCCESS);
}
else
{
return new ApiResult(ResultCode.C_INVALID_ERROR, "开户失败");
}
}
/// <summary>
/// 新开
/// </summary>
/// <param name="packageId"></param>
/// <param name="account"></param>
/// <param name="pwd"></param>
/// <returns></returns>
public override async Task<ApiResult> NewMuiltAccount(string packageKey, string account, string pwd, int connCount = 1, int accountType = 1,int startNum=0, int endNum=1 )
{
var client = CreateHttpClient();
var map = new Dictionary<string, string>(){
{"group","single" },
{"number",account },
{"password",pwd },
{"connect",connCount.ToString()},
{"interval","1"},
{"type",packageKey},
{"body","api"},
{"mobile","13073735878"}
};
var title = GetOpTitle("NewAccount", account);
LogHelper.Info(title, map.ToJson());
try
{
var resp = await client.PostAsForm(this.SingleAddUrl, map);
var content = await resp.Content.ReadAsStringAsync();
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
var status = jo["status"].ToString();
if (status =="400")
{
return new ApiResult(ResultCode.C_SUCCESS);
}
else
{
LogHelper.Error(title, content);
return new ApiResult(ResultCode.C_INVALID_ERROR, "开户失败");
}
}
catch (Exception ex)
{
LogHelper.Error(title, ex.Message);
return new ApiResult(ResultCode.C_INVALID_ERROR, "开户失败");
}
}
/// <summary>
/// 续费
/// </summary>
/// <param name="productId"></param>
/// <param name="account"></param>
/// <param name="pwd"></param>
/// <returns></returns>
public override async Task<ApiResult> NewReAccount(string packageKey, string account, int connCount, int payCount = 1)
{
var product_id = "";
var product_sub_id = "";
var product_item_id = "";
var type = "";
var days = "";
if(packageKey.Contains("-")){
string[] arrStr = packageKey.Split('-');
product_id = arrStr[0];
product_sub_id = arrStr[1];
product_item_id = arrStr[2];
days = arrStr[3];
if (product_id == "1") {
type = "0";
}
if (product_id == "2") {
type = "1";
}
}
Dictionary<string, string> map = new Dictionary<string, string>(){
{"product_id",product_id },
{"product_sub_id",product_sub_id },
{"product_item_id",product_item_id },
{"days",days },
{"type",type },
{"account",account },
};
map = signAct(map);
var client = CreateHttpClient();
var resp = await client.PostAsForm("https://jyip.net/open-api/account-renew", map);
var content = await resp.Content.ReadAsStringAsync();
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
var status = jo["code"].ToString();
if (status == "200")
{
return new ApiResult(1);
}
else
{
return new ApiResult(ResultCode.C_INVALID_ERROR, "续费失败");
}
}
/// <summary>
/// 删除账号
/// </summary>
/// <param name="productId"></param>
/// <param name="account"></param>
/// <returns></returns>
public override async Task<bool> DeleteAccount(string account)
{
var client = CreateHttpClient();
var infoRet = await this.GetAccountInfo(account, true);
if (infoRet.Code != ResultCode.C_SUCCESS)
return false;
var title = GetOpTitle("DeleteAccount", account);
LogHelper.Info(title, account);
try
{
var delete = this.DeleteUrl + infoRet.Data.Id + ".html";
var resp = await client.GetAsync(delete);
var content = await resp.Content.ReadAsStringAsync();
if (content.Has() && content.IndexOf("alert(\"删除成功\")") != -1)
{
return true;
}
else
{
LogHelper.Error(title, content);
return false;
}
}
catch (Exception ex)
{
LogHelper.Error(title, ex.Message);
return false;
}
}
/// <summary>
/// 得到账号信息
/// </summary>
/// <param name="productId"></param>
/// <param name="account"></param>
/// <returns></returns>
public override async Task<ApiResult<OriginAccountModel>> GetAccountInfo(string account,bool isTest=false)
{
Random rd = new Random(Guid.NewGuid().GetHashCode());
int i = rd.Next();
var time_s = DateTime.Now.GetUnixTimeStamp();
var agentid = "admin1";
var nonce = MD5(time_s.ToString()) + i.ToString();
var apikey = "0c4641686764e0ee56ef54b16fddc966";
var sign = MD5(time_s+nonce+apikey);
var url = "/api/raduserInfo?agentid="+agentid+"&ti="+time_s+"&nonce="+nonce+"&sign="+sign+"&username="+account;
var client = CreateHttpClient();
var resp = await client.GetAsync(url);
var content = await resp.Content.ReadAsStringAsync();
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
var status = jo["errcode"].ToString();
var data = jo["data"];
if (status =="0")
{
var trData = new OriginAccountModel
{
Id = "",
Account = data["username"].ToString(),
Pwd = data["password"].ToString(),
AccountType = "",
Package = "",
ConnectCount = "",
RegistTime = data["createtime"].ToString(),
EndTime = data["expiretime"].ToString(),
RestTime = "",
Amount = "",
Remark = "",
};
return new ApiResult<OriginAccountModel>(trData);
}
else
{
return new ApiResult<OriginAccountModel>(ResultCode.C_INVALID_ERROR, "没有查询到信息");
}
}
/// <summary>
/// 修改账号密码
/// </summary>
/// <param name="productId"></param>
/// <param name="account"></param>
/// <param name="pwd"></param>
/// <returns></returns>
public override async Task<bool> UpdateAccountPwd(string account, string pwd)
{
var account_r = "";
var type = "";
if(account.Contains("-")){
string[] arrStr = account.Split('-');
account_r = arrStr[0];
type = arrStr[1];
}
Dictionary<string, string> map = new Dictionary<string, string>(){
{"t_id","121" },
{"passwd",pwd },
{"account",account_r },
{"type",type },
};
map = signAct(map);
var client = CreateHttpClient();
var resp = await client.PostAsForm("https://jyip.net/open-api/edit-password", map);
var content = await resp.Content.ReadAsStringAsync();
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
var status = jo["code"].ToString();
if (status == "200")
{
return true;
}
else
{
return false;
}
}
/// <summary>
/// 退款
/// </summary>
/// <param name="packageId"></param>
/// <param name="account"></param>
/// <returns></returns>
public override async Task<ApiResult> Refund(string account, string packageKey, int days)
{
return new ApiResult(1);
}
/// <summary>
/// 是否在线
/// </summary>
/// <param name="productId"></param>
/// <param name="account"></param>
/// <returns></returns>
public override async Task<ApiResult<List<OriginAccountOnlineModel>>> OnLine(string account)
{
var acc = "";
var type = "";
string[] arrStr = account.Split('-');
acc = arrStr[0];
type = arrStr[1];
Dictionary<string, string> map = new Dictionary<string, string>(){
{"type",type },
{"account",acc },
};
map = signAct(map);
var client = CreateHttpClient();
var resp = await client.PostAsForm("https://jyip.net/open-api/account-is-online", map);
var content = await resp.Content.ReadAsStringAsync();
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
var status = jo["code"].ToString();
var retData = new List<OriginAccountOnlineModel>();
if (status == "200")
{
if(jo.ContainsKey("data")){
JObject jsondata1 = (JObject)JsonConvert.DeserializeObject(jo["data"].ToJson());
JObject jsondata = (JObject)JsonConvert.DeserializeObject(jsondata1[acc].ToJson());
if (jsondata["is_online"].ToString() == "1") {
var trData = new OriginAccountOnlineModel
{
Account = acc,
ServerIP = "",
LoginTime = "",
OnlineTime = "",
LoginIP = "",
UpStream = "",
DownStream = "",
Id= "{account:\""+acc+"\",type:\""+type.ToString()+"\"}",
};
retData.Add(trData);
}
}
return new ApiResult<List<OriginAccountOnlineModel>>(retData);
}
else
{
return new ApiResult<List<OriginAccountOnlineModel>>(ResultCode.C_INVALID_ERROR, "查询失败");
}
}
/// <summary>
/// 踢号
/// </summary>
/// <param name="productId"></param>
/// <param name="account"></param>
/// <returns></returns>
public override async Task<bool> KillOut( string id)
{
JObject userinfo = (JObject)JsonConvert.DeserializeObject(id);
Dictionary<string, string> map = new Dictionary<string, string>(){
{"type",userinfo["type"].ToString() },
{"user",userinfo["account"].ToString() },
};
map = signAct(map);
var client = CreateHttpClient();
var resp = await client.PostAsForm("https://jyip.net/open-api/kick-off-line", map);
var content = await resp.Content.ReadAsStringAsync();
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
var status = jo["code"].ToString();
if (status =="200")
{
return true;
}
return false;
}
/// <summary>
/// 是否存在
/// </summary>
/// <param name="account"></param>
/// <returns></returns>
public override async Task<bool> Exist(string account)
{
Dictionary<string, string> map = new Dictionary<string, string>();
map.Add("user", account);
map.Add("type", "0");
map = signAct(map);
var client = CreateHttpClient();
var resp = await client.PostAsForm("https://jyip.net/open-api//check-vpn-account-exists", map);
var content = await resp.Content.ReadAsStringAsync();
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
if (jo["code"].ToString() == "404") {
return false;
}
return true;
}
private static Dictionary<string, string> signAct(Dictionary<string, string> body)
{
var authStr="";
body.Add("st",DateTime.Now.GetUnixTimeStamp().ToString());
body.Add("app_id","49330ae23dad78f9");
body = body.OrderBy(kv => kv.Key).ToDictionary(kv => kv.Key, p => p.Value);
foreach (var item in body)
{
authStr=authStr+item.Value;
}
body.Add("sign",Md5(Md5(authStr)+"ddb4311a227fb118cacd63cc68416ab5"));
return body;
}
//Md5摘要
private static string Md5(string text)
{
MD5 md5 = new MD5CryptoServiceProvider();
byte[] fromData = System.Text.Encoding.UTF8.GetBytes(text);
byte[] targetData = md5.ComputeHash(fromData);
string byte2String = null;
for (int i = 0; i < targetData.Length; i++)
{
byte2String += targetData[i].ToString("x2");
}
return byte2String;
}
}
}