This commit is contained in:
“wanyongkang”
2021-08-05 14:25:17 +08:00
parent 475d0c9c2f
commit d8743ad632
4 changed files with 106 additions and 111 deletions

View File

@@ -209,7 +209,7 @@
this.sstp = '4433'; this.sstp = '4433';
break; break;
case 14: case 14:
this.l2tp = '91ip'; this.l2tp = '1234';
this.search_field = '天天IP'; this.search_field = '天天IP';
this.sstp = '4430'; this.sstp = '4430';
break; break;

View File

@@ -203,7 +203,7 @@
this.sstp = '4433'; this.sstp = '4433';
break; break;
case 14: case 14:
this.l2tp = '91ip'; this.l2tp = '1234';
this.search_field = '天天IP'; this.search_field = '天天IP';
this.sstp = '4430'; this.sstp = '4430';
break; break;

View File

@@ -21,24 +21,24 @@ namespace Hncore.Pass.Vpn.Service
{ {
public class AgentClient7Service : AgentClientBaseService public class AgentClient7Service : AgentClientBaseService
{ {
string apiId = "135"; string apiId = "89";
string apiKey = "7dayCFfY6zcwJa6QHtHbGQBRckjJbrbS"; string apiKey = "NFeK72yYXmPiGR86YeMCBRTWDxXkrQsd";
string LoginIndexUrl { get; set; } = "login"; string LoginIndexUrl { get; set; } = "login";
string LoginUrl { get; set; } = "login"; string LoginUrl { get; set; } = "login";
string LoginCodeUrl { get; set; } = ""; string LoginCodeUrl { get; set; } = "";
string RefrushTokenUrl { get; set; } = "my"; string RefrushTokenUrl { get; set; } = "my";
string SingleAddUrl { get; set; } = "api/add"; string SingleAddUrl { get; set; } = "api/add";
string SingleReAddUrl { get; set; } = "api/renewal"; string SingleReAddUrl { get; set; } = "v1/renewal";
string MuiltAddUrl { get; set; } = "agent/memberMuiltAdd.html"; string MuiltAddUrl { get; set; } = "agent/memberMuiltAdd.html";
string RefundUrl { get; set; } = "agent/memberRefundAct.html "; string RefundUrl { get; set; } = "agent/memberRefundAct.html ";
string UpdateUrl = "api/edit"; string UpdateUrl = "v1/edit";
string OnlineLoginUrl { get; set; } = "online"; string OnlineLoginUrl { get; set; } = "online";
string OnlineUrl { get; set; } = "ppp/oln?"; string OnlineUrl { get; set; } = "v1/oln";
string KIllUrl { get; set; } = "agent/disConnect2/radacctid/{0}.html"; string KIllUrl { get; set; } = "agent/disConnect2/radacctid/{0}.html";
string searchAccountUrl = "api/get"; string searchAccountUrl = "v1/get";
string DeleteUrl { get; set; } = "api/del";//1160862.html"; string DeleteUrl { get; set; } = "v1/refund";//1160862.html";
string ExistUrl = "api/verify"; string ExistUrl = "v1/verify";
IHttpClientFactory m_HttpClientFactory; IHttpClientFactory m_HttpClientFactory;
public AgentClient7Service(IHttpClientFactory httpClientFactory) : base(httpClientFactory) public AgentClient7Service(IHttpClientFactory httpClientFactory) : base(httpClientFactory)
{ {
@@ -97,7 +97,7 @@ namespace Hncore.Pass.Vpn.Service
private async Task<(string, string)> GetHomeCookie() private async Task<(string, string)> GetHomeCookie()
{ {
var client = CreateHttpClient(false); var client = CreateHttpClient(false);
client.BaseAddress = new Url("http://dl.91ip.vip/"); client.BaseAddress = new Url("https://yoyoapi.yoyoip.com/");
var getResp = await client.GetAsync(this.LoginIndexUrl); var getResp = await client.GetAsync(this.LoginIndexUrl);
var cookies = this.GetCookies(getResp); var cookies = this.GetCookies(getResp);
cookies = cookies.Replace("path=/;", "").Replace("httponly", "").Trim(); cookies = cookies.Replace("path=/;", "").Replace("httponly", "").Trim();
@@ -115,7 +115,7 @@ namespace Hncore.Pass.Vpn.Service
{ {
var tokens = await this.GetHomeCookie(); var tokens = await this.GetHomeCookie();
var client = CreateHttpClient(false); var client = CreateHttpClient(false);
client.BaseAddress = new Url("http://dl.91ip.vip/"); client.BaseAddress = new Url("https://yoyoapi.yoyoip.com");
client.DefaultRequestHeaders.Add("Connection", "keep-alive"); client.DefaultRequestHeaders.Add("Connection", "keep-alive");
client.DefaultRequestHeaders.Add("Upgrade-Insecure-Requests", "1"); client.DefaultRequestHeaders.Add("Upgrade-Insecure-Requests", "1");
var map = new Dictionary<string, string>(){ var map = new Dictionary<string, string>(){
@@ -179,10 +179,13 @@ namespace Hncore.Pass.Vpn.Service
/// <returns></returns> /// <returns></returns>
public override async Task<ApiResult> NewAccount(string packageKey, string account, string pwd, int connCount = 1, int accountType = 1, int payCount = 1) public override async Task<ApiResult> NewAccount(string packageKey, string account, string pwd, int connCount = 1, int accountType = 1, int payCount = 1)
{ {
var new_url = "v1/one";
var client = CreateHttpClient(); var client = CreateHttpClient();
var package = "m"; var package = "m";
var buyCount = "1"; var buyCount = "1";
if(packageKey =="m3"){ if(packageKey =="test"){
new_url = "v1/test";
} else if(packageKey =="m3"){
package = "m"; package = "m";
buyCount = "3"; buyCount = "3";
} else if(packageKey =="m12"){ } else if(packageKey =="m12"){
@@ -193,28 +196,31 @@ namespace Hncore.Pass.Vpn.Service
buyCount = payCount.ToString(); buyCount = payCount.ToString();
} }
var map = new SortedDictionary<string, string>(){ var map = new SortedDictionary<string, string>(){
{"user",account }, {"name",account },
{"passwd",pwd }, {"passwd",pwd },
{"num","1"}, {"num","1"},
{"conn_max",connCount.ToString() }, {"max_conn",connCount.ToString() },
{"test",packageKey=="test"?"1":"0" }, {"paytype",package },
{"type",packageKey=="test"?"d":package },
{"paynum",buyCount }, {"paynum",buyCount },
{"mobile","17719092232" }, {"mobile","13073735878" },
{"mark","api" },
}; };
var title = GetOpTitle("NewAccount", account); var title = GetOpTitle("NewAccount", account);
LogHelper.Info(title, map.ToJson());
try try
{ {
var resp = await client.GetAsync(this.SingleAddUrl+"?"+ Sign(map)); var resp = await client.GetAsync(new_url+"?"+ Sign(map));
var content = await resp.Content.ReadAsStringAsync(); var content = await resp.Content.ReadAsStringAsync();
JObject jo = (JObject)JsonConvert.DeserializeObject(content); JObject jo = (JObject)JsonConvert.DeserializeObject(content);
var status = jo["status"].ToString(); var status = jo["status"].ToString();
Console.WriteLine("==============================tiantian==========================================================");
Console.WriteLine(jo);
Console.WriteLine(status);
Console.WriteLine("========================================================================================");
if (status =="200") if (status =="200")
{ {
var retAccount=jo["data"].ToArray().FirstOrDefault(); var retAccount=jo["data"].ToArray().FirstOrDefault();
var id = retAccount["id"].ToString(); // var id = retAccount["name"].ToString();
return new ApiResult(ResultCode.C_SUCCESS) { Data=id}; return new ApiResult(ResultCode.C_SUCCESS);
} }
else else
{ {
@@ -239,7 +245,6 @@ namespace Hncore.Pass.Vpn.Service
/// <returns></returns> /// <returns></returns>
public override async Task<ApiResult> NewReAccount(string packageKey, string id, int connCount, int payCount = 1) public override async Task<ApiResult> NewReAccount(string packageKey, string id, int connCount, int payCount = 1)
{ {
var ret = await this.GetAccountInfo(id);
var package = "m"; var package = "m";
var buyCount = "1"; var buyCount = "1";
if(packageKey =="m3"){ if(packageKey =="m3"){
@@ -252,19 +257,13 @@ namespace Hncore.Pass.Vpn.Service
package = packageKey; package = packageKey;
buyCount = payCount.ToString(); buyCount = payCount.ToString();
} }
if (ret.Code != ResultCode.C_SUCCESS|| ret.Data==null)
{
return new ApiResult(ResultCode.C_INVALID_ERROR, "账户不存在,续费失败");
}
var client = CreateHttpClient(); var client = CreateHttpClient();
var map = new SortedDictionary<string, string>(){ var map = new SortedDictionary<string, string>(){
{"id",id }, //原始的账号的id {"names",id }, //原始的账号的id
{"type",package }, {"paytype",package },
{"paynum",buyCount }, {"paynum",buyCount },
}; };
var title = GetOpTitle("NewReAccount", id);
LogHelper.Info(title, map.ToJson());
try try
{ {
var resp = await client.GetAsync(this.SingleReAddUrl + "?" + Sign(map)); var resp = await client.GetAsync(this.SingleReAddUrl + "?" + Sign(map));
@@ -278,13 +277,11 @@ namespace Hncore.Pass.Vpn.Service
else else
{ {
var info = jo["info"].ToString(); var info = jo["info"].ToString();
LogHelper.Error(title, content);
return new ApiResult(ResultCode.C_INVALID_ERROR, info); return new ApiResult(ResultCode.C_INVALID_ERROR, info);
} }
} }
catch (Exception ex) catch (Exception ex)
{ {
LogHelper.Error(title, ex.Message);
return new ApiResult(ResultCode.C_INVALID_ERROR, "续费失败"); return new ApiResult(ResultCode.C_INVALID_ERROR, "续费失败");
} }
} }
@@ -294,15 +291,13 @@ namespace Hncore.Pass.Vpn.Service
/// <param name="productId"></param> /// <param name="productId"></param>
/// <param name="account"></param> /// <param name="account"></param>
/// <returns></returns> /// <returns></returns>
public override async Task<bool> DeleteAccount(string id) public override async Task<bool> DeleteAccount(string account)
{ {
var client = CreateHttpClient(); var client = CreateHttpClient();
var map = new SortedDictionary<string, string>(){ var map = new SortedDictionary<string, string>(){
{"id",id }, {"name",account },
}; };
var title = GetOpTitle("DeleteAccount", id);
LogHelper.Info(title, id);
try try
{ {
var resp = await client.GetAsync(this.DeleteUrl + "?" + Sign(map)); var resp = await client.GetAsync(this.DeleteUrl + "?" + Sign(map));
@@ -315,13 +310,11 @@ namespace Hncore.Pass.Vpn.Service
} }
else else
{ {
LogHelper.Error(title, content);
return false; return false;
} }
} }
catch (Exception ex) catch (Exception ex)
{ {
LogHelper.Error(title, ex.Message);
return false; return false;
} }
} }
@@ -335,44 +328,45 @@ namespace Hncore.Pass.Vpn.Service
{ {
var client = CreateHttpClient(); var client = CreateHttpClient();
var map = new SortedDictionary<string, string>(){ var map = new SortedDictionary<string, string>(){
{"id",id }, {"name",id },
}; };
var title = GetOpTitle("GetAccountInfo", id);
try try
{ {
var resp = await client.GetAsync(this.searchAccountUrl + "?" + Sign(map)); var resp = await client.GetAsync(this.searchAccountUrl + "?" + Sign(map));
var content = await resp.Content.ReadAsStringAsync(); var content = await resp.Content.ReadAsStringAsync();
JObject jo = (JObject)JsonConvert.DeserializeObject(content); JObject jo = (JObject)JsonConvert.DeserializeObject(content);
var status = jo["status"].ToString(); var status = jo["status"].ToString();
Console.WriteLine("====================================================");
Console.WriteLine(jo);
Console.WriteLine("====================================================");
if (status == "200") if (status == "200")
{ {
var data = jo["data"]; var data = jo["data"];
var trData = new OriginAccountModel var trData = new OriginAccountModel
{ {
Id = data["id"].ToString(), Id = data["name"].ToString(),
Account = data["user"].ToString(), Account = data["name"].ToString(),
Pwd = data["passwd"].ToString(), Pwd = data["passwd"].ToString(),
AccountType = data["type"].ToString(), AccountType = data["mark"].ToString(),
Package = "", Package = "",
ConnectCount = data["conn_max"].ToString(), ConnectCount = data["max_conn"].ToString(),
RegistTime = data["add_time"].ToString(), RegistTime = data["add_time"].ToString(),
EndTime = data["end_time"].ToString(), EndTime = data["end_time"].ToString(),
RestTime = "", RestTime = "",
Amount = data["money"].ToString(), Amount = data["balance"].ToString(),
Remark = data["details"].ToString(), Remark = data["mark"].ToString(),
}; };
return new ApiResult<OriginAccountModel>(trData); return new ApiResult<OriginAccountModel>(trData);
} }
else else
{ {
var info = jo["info"].ToString(); var info = jo["info"].ToString();
LogHelper.Error(title, content);
return new ApiResult<OriginAccountModel>(ResultCode.C_INVALID_ERROR, "没有查询到信息"); return new ApiResult<OriginAccountModel>(ResultCode.C_INVALID_ERROR, "没有查询到信息");
} }
} }
catch (Exception ex) catch (Exception ex)
{ {
LogHelper.Error(title, ex.Message);
return new ApiResult<OriginAccountModel>(ResultCode.C_INVALID_ERROR, "查询失败"); return new ApiResult<OriginAccountModel>(ResultCode.C_INVALID_ERROR, "查询失败");
} }
@@ -388,11 +382,9 @@ namespace Hncore.Pass.Vpn.Service
{ {
var client = CreateHttpClient(); var client = CreateHttpClient();
var map = new SortedDictionary<string, string>(){ var map = new SortedDictionary<string, string>(){
{"id",Raw }, {"name",account },
{"user",account },
{"passwd",pwd }, {"passwd",pwd },
}; };
LogHelper.Info(GetOpTitle("UpdateAccountPwd", account), map.ToJson());
try try
{ {
var resp = await client.GetAsync(this.UpdateUrl + "?" + Sign(map)); var resp = await client.GetAsync(this.UpdateUrl + "?" + Sign(map));
@@ -441,44 +433,44 @@ namespace Hncore.Pass.Vpn.Service
public override async Task<ApiResult<List<OriginAccountOnlineModel>>> OnLine(string account) public override async Task<ApiResult<List<OriginAccountOnlineModel>>> OnLine(string account)
{ {
var client = CreateHttpClient(); var client = CreateHttpClient();
// client.BaseAddress = new Url("http://dl.91ip.vip/"); var map = new SortedDictionary<string, string>(){
var title = GetOpTitle("OnLine", account); {"name",account },
var info = ""; };
try
{ var resp = await client.GetAsync(this.OnlineUrl + "?" + Sign(map));
var resp = await client.GetAsync(this.OnlineUrl+ "user="+account); var content = await resp.Content.ReadAsStringAsync();
var content = await resp.Content.ReadAsStringAsync(); JObject jo = (JObject)JsonConvert.DeserializeObject(content);
var parser = new HtmlParser();
var document = await parser.ParseDocumentAsync(content); var status = jo["status"].ToString();
var trs = document.QuerySelectorAll("table.table tr").ToList(); var retData = new List<OriginAccountOnlineModel>();
var retData = new List<OriginAccountOnlineModel>(); if (status =="200")
if (trs.Count() > 1) {
{ if(jo["data"]["total"].ToInt()>0){
foreach (var tr in trs.Skip(1)) foreach (var tr in jo["data"]["items"])
{ {
var tds = tr.QuerySelectorAll("td").ToList(); JObject jsondata = (JObject)JsonConvert.DeserializeObject(tr.ToJson());
var tdAccount = tds[0].FirstChild.TextContent;
if (tdAccount != account)
continue;
info = string.Join("", tds.Select(m => m.OuterHtml));
var trData = new OriginAccountOnlineModel var trData = new OriginAccountOnlineModel
{ {
Account = account, Account = account,
ServerIP = tds[1].TextContent, ServerIP = jsondata["ip"].ToString(),
OnlineTime = tds[2].TextContent, LoginTime = "",
OnlineTime = "",
LoginIP = jsondata["user_ip"].ToString(),
UpStream = "",
DownStream = "",
Id= jsondata["id"].ToString(),
}; };
var href = tr.LastElementChild.QuerySelector("a")?.Attributes["href"]?.Value;
trData.Id = href;
retData.Add(trData); retData.Add(trData);
} }
} }
return new ApiResult<List<OriginAccountOnlineModel>>(retData); return new ApiResult<List<OriginAccountOnlineModel>>(retData);
} }
catch (Exception ex) else
{ {
LogHelper.Error(title, ex.Message + "-->info:" + info); return new ApiResult<List<OriginAccountOnlineModel>>(ResultCode.C_INVALID_ERROR, "查询失败");
return new ApiResult<List<OriginAccountOnlineModel>>(ResultCode.C_INVALID_ERROR, "查询失败");
} }
} }
/// <summary> /// <summary>
@@ -492,9 +484,12 @@ namespace Hncore.Pass.Vpn.Service
var client = CreateHttpClient(); var client = CreateHttpClient();
var title = GetOpTitle("KillOut", id); var title = GetOpTitle("KillOut", id);
var info = ""; var info = "";
var map = new SortedDictionary<string, string>(){
{"id",id },
};
try try
{ {
var resp = await client.GetAsync(id); var resp = await client.GetAsync("v1/olnstop?" + Sign(map));
var content = await resp.Content.ReadAsStringAsync(); var content = await resp.Content.ReadAsStringAsync();
return true; return true;
} }

View File

@@ -137,7 +137,7 @@ namespace Hncore.Pass.Vpn.Service
var agent = GetAgent(product); var agent = GetAgent(product);
agent.Init(product.BaseUrl, product.Token); agent.Init(product.BaseUrl, product.Token);
var account = item.Account; var account = item.Account;
if (product.GroupNO == "g7") account = item.Raw; // if (product.GroupNO == "g7") account = item.Raw;
var ret = await agent.GetAccountInfo(account); var ret = await agent.GetAccountInfo(account);
if (ret.Code == ResultCode.C_SUCCESS) if (ret.Code == ResultCode.C_SUCCESS)
retList.Add(ret.Data as OriginAccountModel); retList.Add(ret.Data as OriginAccountModel);
@@ -150,12 +150,12 @@ namespace Hncore.Pass.Vpn.Service
var product = await m_ProductService.GetById(productId); var product = await m_ProductService.GetById(productId);
var agent = GetAgent(product); var agent = GetAgent(product);
agent.Init(product.BaseUrl, product.Token); agent.Init(product.BaseUrl, product.Token);
if (product.GroupNO == "g7") // if (product.GroupNO == "g7")
{ // {
var accountInfo = await GetProductAccount(productId, account); // var accountInfo = await GetProductAccount(productId, account);
if (accountInfo != null && accountInfo.Raw.Has()) // if (accountInfo != null && accountInfo.Raw.Has())
account = accountInfo.Raw; // account = accountInfo.Raw;
} // }
var ret = await agent.GetAccountInfo(account); var ret = await agent.GetAccountInfo(account);
if (ret.Code != ResultCode.C_SUCCESS && product.Id!=17&& product.Id!=13) return new ApiResult<OriginAccountModel>(ResultCode.C_NOT_EXISTS_ERROR, "账号不存在"); if (ret.Code != ResultCode.C_SUCCESS && product.Id!=17&& product.Id!=13) return new ApiResult<OriginAccountModel>(ResultCode.C_NOT_EXISTS_ERROR, "账号不存在");
if (pwd.Has()&&ret.Data.Pwd != pwd && product.Id!=17&& product.Id!=13) if (pwd.Has()&&ret.Data.Pwd != pwd && product.Id!=17&& product.Id!=13)
@@ -172,12 +172,12 @@ namespace Hncore.Pass.Vpn.Service
foreach (var item in accounts) foreach (var item in accounts)
{ {
var account = item; var account = item;
if (product.GroupNO == "g7") // if (product.GroupNO == "g7")
{ // {
var accountInfo = await GetProductAccount(productId, item); // var accountInfo = await GetProductAccount(productId, item);
if (accountInfo != null && accountInfo.Raw.Has()) // if (accountInfo != null && accountInfo.Raw.Has())
account = accountInfo.Raw; // account = accountInfo.Raw;
} // }
var ret = await agent.GetAccountInfo(account); var ret = await agent.GetAccountInfo(account);
if (ret.Code == ResultCode.C_SUCCESS) if (ret.Code == ResultCode.C_SUCCESS)
{ {
@@ -256,12 +256,12 @@ namespace Hncore.Pass.Vpn.Service
{ {
var package = await m_ProductPackageService.GetById(packageId); var package = await m_ProductPackageService.GetById(packageId);
var product = await m_ProductService.GetById(package.ProductId); var product = await m_ProductService.GetById(package.ProductId);
if (product.GroupNO == "g7") // if (product.GroupNO == "g7")
{ // {
var accountInfo = await GetProductAccount(package.ProductId, account); // var accountInfo = await GetProductAccount(package.ProductId, account);
if (accountInfo != null && accountInfo.Raw.Has()) // if (accountInfo != null && accountInfo.Raw.Has())
account = accountInfo.Raw; // account = accountInfo.Raw;
} // }
var agent = GetAgent(product); var agent = GetAgent(product);
agent.Init(product.BaseUrl, product.Token); agent.Init(product.BaseUrl, product.Token);
ApiResult flagResult = new ApiResult(ResultCode.C_SUCCESS); ApiResult flagResult = new ApiResult(ResultCode.C_SUCCESS);
@@ -312,12 +312,12 @@ namespace Hncore.Pass.Vpn.Service
var product = await m_ProductService.GetById(productId); var product = await m_ProductService.GetById(productId);
var agent = GetAgent(product); var agent = GetAgent(product);
agent.Init(product.BaseUrl, product.Token); agent.Init(product.BaseUrl, product.Token);
if (product.GroupNO == "g7") // if (product.GroupNO == "g7")
{ // {
var accountInfo = await GetProductAccount(productId, account); // var accountInfo = await GetProductAccount(productId, account);
if (accountInfo != null && accountInfo.Raw.Has()) // if (accountInfo != null && accountInfo.Raw.Has())
agent.Raw = accountInfo.Raw; // agent.Raw = accountInfo.Raw;
} // }
return await agent.UpdateAccountPwd(account, pwd); return await agent.UpdateAccountPwd(account, pwd);
} }
/// <summary> /// <summary>
@@ -332,11 +332,11 @@ namespace Hncore.Pass.Vpn.Service
var agent = GetAgent(product); var agent = GetAgent(product);
agent.Init(product.BaseUrl, product.Token); agent.Init(product.BaseUrl, product.Token);
var account = accountInfo.Account; var account = accountInfo.Account;
if (product.GroupNO == "g7") // if (product.GroupNO == "g7")
{ // {
if (accountInfo != null && accountInfo.Raw.Has()) // if (accountInfo != null && accountInfo.Raw.Has())
account = accountInfo.Raw; // account = accountInfo.Raw;
} // }
var flag = await agent.Refund(account, package.OriginKey, accountInfo.RestDay); var flag = await agent.Refund(account, package.OriginKey, accountInfo.RestDay);
return flag; return flag;
} }