532 lines
21 KiB
C#
532 lines
21 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;
|
|
namespace Hncore.Pass.Vpn.Service
|
|
{
|
|
public class AgentClient16Service: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 AgentClient16Service(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)
|
|
{
|
|
string[] arrStr = packageKey.Split('.');
|
|
var time =arrStr[0];
|
|
var type =arrStr[1];
|
|
var speed =arrStr[2];
|
|
|
|
|
|
// 获取token
|
|
var url = "api/auth/access_token";
|
|
var client = CreateHttpClient();
|
|
var map = new Dictionary<string, string>(){
|
|
{"app_id","388" },
|
|
{"app_key","882453f7cdb7525a4362d1776e937086" },
|
|
};
|
|
var resp = await client.PostAsForm(url, map);
|
|
var content = await resp.Content.ReadAsStringAsync();
|
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
|
var token = jo["data"]["access_token"];
|
|
//正式请求
|
|
var url_p = "api/user/user_add_rand";
|
|
var client_p = CreateHttpClient();
|
|
var map_p = new Dictionary<string, string>(){
|
|
{"access_token",token.ToString() },
|
|
{"username",account},
|
|
{"userpass",pwd},
|
|
{"qq","123456789"},
|
|
{"time",time},
|
|
{"num",connCount.ToString()},
|
|
{"type",type},
|
|
{"ip",speed},
|
|
{"remark","api开通"},
|
|
};
|
|
var resp_p = await client_p.PostAsForm(url_p, map_p);
|
|
var content_p = await resp_p.Content.ReadAsStringAsync();
|
|
JObject jo_p = (JObject)JsonConvert.DeserializeObject(content_p);
|
|
Console.WriteLine("========================================开号============================================");
|
|
Console.WriteLine(content_p);
|
|
Console.WriteLine(jo_p);
|
|
Console.WriteLine("=====================================================================================");
|
|
var status = jo_p["data"]["addnew"].ToString();
|
|
if (status =="1")
|
|
{
|
|
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)
|
|
{
|
|
|
|
string[] arrStr = packageKey.Split('.');
|
|
var time =arrStr[0];
|
|
var type =arrStr[1];
|
|
var speed =arrStr[2];
|
|
|
|
// 获取token
|
|
var url = "api/auth/access_token";
|
|
var client = CreateHttpClient();
|
|
var map = new Dictionary<string, string>(){
|
|
{"app_id","388" },
|
|
{"app_key","882453f7cdb7525a4362d1776e937086" },
|
|
};
|
|
var resp = await client.PostAsForm(url, map);
|
|
var content = await resp.Content.ReadAsStringAsync();
|
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
|
var token = jo["data"]["access_token"];
|
|
//正式请求
|
|
var url_p = "api/user/user_renew_vpn";
|
|
var client_p = CreateHttpClient();
|
|
var map_p = new Dictionary<string, string>(){
|
|
// {"access_token",token.ToString() },
|
|
// {"username[]",account},
|
|
// {"usertype","1"},
|
|
// {"month","1"},
|
|
};
|
|
var resp_p = await client_p.PostAsForm(url_p, map_p);
|
|
var content_p = await resp_p.Content.ReadAsStringAsync();
|
|
JObject jo_p = (JObject)JsonConvert.DeserializeObject(content_p);
|
|
Console.WriteLine("========================================开号============================================");
|
|
Console.WriteLine(content_p);
|
|
Console.WriteLine(jo_p);
|
|
Console.WriteLine("=====================================================================================");
|
|
var status = jo_p["data"]["renew"].ToString();
|
|
if (status =="1")
|
|
{
|
|
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)
|
|
{
|
|
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 = "b220b83508db57f44e5ce86a7b34cae9";
|
|
var sign = MD5(time_s+nonce+apikey);
|
|
|
|
|
|
var url = "/api/raduserRefund?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();
|
|
Console.WriteLine("==============================================================");
|
|
Console.WriteLine(content);
|
|
Console.WriteLine("==============================================================");
|
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
|
var status = jo["errcode"].ToString();
|
|
|
|
if (status =="0")
|
|
{
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
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 = "b220b83508db57f44e5ce86a7b34cae9";
|
|
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)
|
|
{
|
|
|
|
// 获取token
|
|
var url = "api/auth/access_token";
|
|
var client = CreateHttpClient();
|
|
var map = new Dictionary<string, string>(){
|
|
{"app_id","388" },
|
|
{"app_key","882453f7cdb7525a4362d1776e937086" },
|
|
};
|
|
var resp = await client.PostAsForm(url, map);
|
|
var content = await resp.Content.ReadAsStringAsync();
|
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
|
var token = jo["data"]["access_token"];
|
|
//正式请求
|
|
var url_p = "api/user/user_repass";
|
|
var client_p = CreateHttpClient();
|
|
var map_p = new Dictionary<string, string>(){
|
|
{"access_token",token.ToString() },
|
|
{"username",account},
|
|
{"newpass",pwd},
|
|
};
|
|
var resp_p = await client_p.PostAsForm(url_p, map_p);
|
|
var content_p = await resp_p.Content.ReadAsStringAsync();
|
|
JObject jo_p = (JObject)JsonConvert.DeserializeObject(content_p);
|
|
return true;
|
|
|
|
}
|
|
/// <summary>
|
|
/// 退款
|
|
/// </summary>
|
|
/// <param name="packageId"></param>
|
|
/// <param name="account"></param>
|
|
/// <returns></returns>
|
|
public override async Task<ApiResult> Refund(string account, string packageKey, int days)
|
|
{
|
|
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 = "b220b83508db57f44e5ce86a7b34cae9";
|
|
var sign = MD5(time_s+nonce+apikey);
|
|
|
|
|
|
|
|
var url = "/api/raduserRefund?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();
|
|
Console.WriteLine("==============================================================");
|
|
Console.WriteLine(content);
|
|
Console.WriteLine("==============================================================");
|
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
|
var status = jo["errcode"].ToString();
|
|
|
|
if (status =="0")
|
|
{
|
|
return new ApiResult(1);
|
|
}
|
|
return new ApiResult(ResultCode.C_INVALID_ERROR, "退款失败");
|
|
|
|
}
|
|
/// <summary>
|
|
/// 是否在线
|
|
/// </summary>
|
|
/// <param name="productId"></param>
|
|
/// <param name="account"></param>
|
|
/// <returns></returns>
|
|
public override async Task<ApiResult<List<OriginAccountOnlineModel>>> OnLine(string account)
|
|
{
|
|
|
|
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 = "b220b83508db57f44e5ce86a7b34cae9";
|
|
var sign = MD5(time_s+nonce+apikey);
|
|
|
|
var url = "/api/raduserAcct?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 retData = new List<OriginAccountOnlineModel>();
|
|
if (status =="0")
|
|
{
|
|
if(jo.ContainsKey("data")){
|
|
foreach (var tr in jo["data"])
|
|
{
|
|
JObject jsondata = (JObject)JsonConvert.DeserializeObject(tr.ToJson());
|
|
|
|
var trData = new OriginAccountOnlineModel
|
|
{
|
|
Account = account,
|
|
ServerIP = jsondata["serverip"].ToString(),
|
|
LoginTime = jsondata["starttime"].ToString(),
|
|
OnlineTime = "",
|
|
LoginIP = jsondata["framedip"].ToString(),
|
|
UpStream = "",
|
|
DownStream = "",
|
|
Id= "{account:\""+account+"\",radacctid:\""+jsondata["radacctid"].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)
|
|
{
|
|
|
|
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 = "b220b83508db57f44e5ce86a7b34cae9";
|
|
var sign = MD5(time_s+nonce+apikey);
|
|
|
|
JObject userinfo = (JObject)JsonConvert.DeserializeObject(id);
|
|
|
|
var url = "/api/raduserDisconnect?agentid="+agentid+"&ti="+time_s+"&nonce="+nonce+"&sign="+sign+"&username="+userinfo["account"]+"&radacctid="+userinfo["radacctid"];
|
|
|
|
var client = CreateHttpClient();
|
|
var title = GetOpTitle("KillOut", id);
|
|
var info = "";
|
|
|
|
|
|
try
|
|
{
|
|
|
|
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 true;
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
LogHelper.Error(title, ex.Message + "-->info:" + info);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/// <summary>
|
|
/// 是否存在
|
|
/// </summary>
|
|
/// <param name="account"></param>
|
|
/// <returns></returns>
|
|
public override async Task<bool> Exist(string account)
|
|
{
|
|
|
|
// 获取token
|
|
var url = "api/auth/access_token";
|
|
var client = CreateHttpClient();
|
|
var map = new Dictionary<string, string>(){
|
|
{"app_id","388" },
|
|
{"app_key","882453f7cdb7525a4362d1776e937086" },
|
|
};
|
|
var resp = await client.PostAsForm(url, map);
|
|
var content = await resp.Content.ReadAsStringAsync();
|
|
JObject jo = (JObject)JsonConvert.DeserializeObject(content);
|
|
var token = jo["data"]["access_token"];
|
|
//正式请求
|
|
var url_p = "api/user/check_user";
|
|
var client_p = CreateHttpClient();
|
|
var map_p = new Dictionary<string, string>(){
|
|
{"access_token",token.ToString() },
|
|
{"username",account},
|
|
};
|
|
var resp_p = await client_p.PostAsForm(url_p, map_p);
|
|
var content_p = await resp_p.Content.ReadAsStringAsync();
|
|
JObject jo_p = (JObject)JsonConvert.DeserializeObject(content_p);
|
|
var is_exit = jo_p["data"]["check"];
|
|
|
|
if (is_exit.ToString() =="1")
|
|
{
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
}
|
|
}
|