CoreAPIHttpService.cs 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632
  1. using HTEXLib.COMM.Helpers;
  2. using Microsoft.AspNetCore.Hosting;
  3. using Microsoft.Extensions.Configuration;
  4. using Microsoft.Extensions.DependencyInjection;
  5. using Microsoft.Extensions.Hosting;
  6. using Microsoft.Extensions.Options;
  7. using OpenXmlPowerTools;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Configuration;
  11. using System.Dynamic;
  12. using System.IO;
  13. using System.Linq;
  14. using System.Net;
  15. using System.Net.Http;
  16. using System.Net.Http.Json;
  17. using System.Security.Policy;
  18. using System.Text;
  19. using System.Text.Json;
  20. using System.Threading.Tasks;
  21. using System.Web;
  22. using TEAMModelOS.Models;
  23. using TEAMModelOS.SDK.DI;
  24. using TEAMModelOS.SDK.Extension;
  25. using TEAMModelOS.SDK.Models;
  26. namespace TEAMModelOS.SDK
  27. {
  28. public class CoreAPIHttpServiceOptions
  29. {
  30. public string location { get; set; }
  31. public string url { get; set; }
  32. public string clientID { get; set; }
  33. public string clientSecret { get; set; }
  34. }
  35. public class CoreAPIHttpService
  36. {
  37. //private readonly IWebHostEnvironment _environment;
  38. public bool check=true;
  39. private SnowflakeId _snowflakeId;
  40. private readonly HttpClient _httpClient;
  41. public readonly CoreAPIHttpServiceOptions options;
  42. //private readonly IConfiguration _configuration;
  43. // private readonly DI.DingDing _dingDing;
  44. //public readonly Option _option;
  45. public CoreAPIHttpService(HttpClient httpClient, IConfiguration _configuration , SnowflakeId snowflakeId)
  46. {
  47. _httpClient = httpClient;
  48. string location = _configuration.GetValue<string>("Option:Location");
  49. string url = _configuration.GetValue<string>("HaBookAuth:CoreAPI");
  50. var clientID = _configuration.GetValue<string>("HaBookAuth:CoreService:clientID");
  51. var clientSecret = _configuration.GetValue<string>("HaBookAuth:CoreService:clientSecret");
  52. options = new CoreAPIHttpServiceOptions
  53. {
  54. location=location,
  55. url=url,
  56. clientID=clientID,
  57. clientSecret=clientSecret
  58. };
  59. //_environment = environment;
  60. _snowflakeId = snowflakeId;
  61. //_option = option?.Value;
  62. //_configuration = configuration;
  63. //_dingDing = dingDing;
  64. }
  65. public class CoreAPIToken {
  66. public string id_token { get; set; }
  67. public string access_token { get; set; }
  68. public string expires_in { get; set; }
  69. public string token_type { get; set; }
  70. }
  71. public async Task<(HttpStatusCode code , CoreAPIToken token )> GetCoreAPIoAuth2Token(Dictionary<string,object> data, string location, IConfiguration _configuration, DI.DingDing _dingDing) {
  72. try
  73. {
  74. var url = _configuration.GetValue<string>("HaBookAuth:CoreAPI");
  75. //url = "https://api2-rc.teammodel.cn";
  76. url = $"{url}/oauth2/token";
  77. var clientID = _configuration.GetValue<string>("HaBookAuth:CoreService:clientID");
  78. var clientSecret = _configuration.GetValue<string>("HaBookAuth:CoreService:clientSecret");
  79. if (location.Contains("China"))
  80. {
  81. location = "China";
  82. }
  83. else if (location.Contains("Global"))
  84. {
  85. location = "Global";
  86. }
  87. var client = _httpClient ;
  88. var token = await CoreTokenExtensions.CreateAccessToken(clientID, clientSecret, location);
  89. if (client.DefaultRequestHeaders.Contains("Authorization"))
  90. {
  91. client.DefaultRequestHeaders.Remove("Authorization");
  92. }
  93. client.DefaultRequestHeaders.Add("Authorization", $"Bearer {token.AccessToken}");
  94. HttpResponseMessage responseMessage = await client.PostAsJsonAsync(url, data);
  95. if (responseMessage.Content != null)
  96. {
  97. string content = await responseMessage.Content.ReadAsStringAsync();
  98. if (!string.IsNullOrWhiteSpace(content))
  99. {
  100. CoreAPIToken coreAPI = content.ToObject<CoreAPIToken>();
  101. return (responseMessage.StatusCode, coreAPI);
  102. }
  103. else
  104. {
  105. return (responseMessage.StatusCode, null);
  106. }
  107. }
  108. else
  109. {
  110. return (responseMessage.StatusCode, null);
  111. }
  112. }
  113. catch (Exception ex)
  114. {
  115. await _dingDing.SendBotMsg($"{location}验证码发送异常:\n{ex.Message}\n{ex.StackTrace}", DI.GroupNames.醍摩豆服務運維群組);
  116. return (HttpStatusCode.InternalServerError, null);
  117. }
  118. }
  119. /*
  120. hubName string Optional 指定要傳送到哪個訊息中樞,若沒給則不傳送端外通知,只會發送端內通知。(目前只有"hita"及"hita5"能使用)
  121. sender string Optional 發送訊息的來源端
  122. tags string array Required 接收對象或手機註冊的tag,ID或服務等...
  123. title string Optional 標題,會"直接"顯示於端外通知的title位置
  124. body string Optional 正文,會"直接"顯示於端外通知的body位置
  125. eventId string Optional 事件ID
  126. eventName string Optional 事件名稱
  127. data string Optional 額外資料
  128. 'request_school': vm.$t('notice.type1'), // 管理员收到他人申请加入的通知
  129. 'invite_school': vm.$t('notice.type2'), // 你收到学校邀请你的通知
  130. 'remove_school': vm.$t('notice.type3'), // 学校将你移除的通知
  131. 'request-join_school': vm.$t('notice.type1'), // 学校同意你的加入请求
  132. 'invite-join_school': vm.$t('notice.type2'), // 某人已同意你对他的邀请
  133. 'coedit_syllabus': vm.$t('notice.type4'), // 邀请课纲共编的通知
  134. 'share_syllabus': vm.$t('notice.type4'), // 个人课纲分享的通知
  135. 'transfer-admin_school': vm.$t('notice.type5'), // 管理员转移的通知
  136. 'scoring-arb_school': vm.$t('notice.type6'), // 仲裁卷阅卷任务分配通知
  137. 'scoring-err_school': vm.$t('notice.type6'), // 异常卷阅卷任务分配通知
  138. 'scoring-mark_school': vm.$t('notice.type6'), // 普通阅卷任务分配通知
  139. 'scan-join_groupList': vm.$t('notice.type7'), // 扫码加入名单通知
  140. 'scan-join_school': vm.$t('notice.type7'), // 扫码加入学校通知
  141. 'submitanswer_homework': vm.$t('notice.type8'), // 作业提交通知
  142. 'expire_lessonRecord': vm.$t('notice.type9'), // 课例过期通知
  143. */
  144. /// <summary>
  145. ///
  146. /// 發送端內外通知
  147. ///
  148. /// id: 教师id,name 教师名称,code 语系
  149. /// </summary>
  150. /// <param name="toTeachers"></param>
  151. /// <param name="notifyCode"></param>
  152. /// <param name="replaceData"></param>
  153. /// <param name="location"></param>
  154. /// <param name="_configuration"></param>
  155. /// <param name="_dingDing"></param>
  156. /// <returns></returns>
  157. public void PushNotify(List<IdNameCode> toTeachers , string notifyCode,string notifyType,Dictionary<string, object> replaceData,
  158. string location, IConfiguration _configuration, DI.DingDing _dingDing,string rootPath) {
  159. /*
  160. * IES5_Management shift-assist_school DelBeforeCopyAbility-mark_start copyAbility-mark_finish copyAbility-mark_start
  161. * transfer-admin_school invite-join_school invite_school request_school request-join_school remove_school scan-join_school
  162. * IES5_Course submitanswer_homework scan-join_groupList expire-school_lessonRecord
  163. * IES5_Task scoring-mark_school scoring-arb_school scoring-err_school
  164. * IES5_Contect coedit_syllabus share_syllabus
  165. {
  166. "hubName":"hita5",
  167. "sender":"ies5",
  168. "tags":["1595321354_IES5_Management"]
  169. "title":"",
  170. "body":"",
  171. "eventId":"",
  172. "eventName":"",
  173. "data":""action":{"type":"click\link","tokenbindtype":1,"url":"http://xxxx"}"
  174. }
  175. {
  176. "action":[ //陣列, 可以包含多個按鈕
  177. {
  178. "type":"click", //按鈕
  179. "label":"Ok", //按鈕的字
  180. "url":"https://www.teammodel.net?code=", // POST API
  181. "tokenbindtype":1 //附掛 code token到 utl 後面
  182. }
  183. ]
  184. }
  185. {
  186. "action": [
  187. {
  188. "type": "click",
  189. "label": "\\u67e5\\u770b",
  190. "url": "https:\\/\\/sokrates.teammodel.org\\/exhibition\\/tbavideo\\/check-with-habook\\/?to=aHR0cHM6Ly9zb2tyYXRlcy50ZWFtbW9kZWwub3JnL2V4aGliaXRpb24vdGJhdmlkZW8jL2NvbnRlbnQvMTM5MzU\\/Z3JvdXBJZHM9MTQxJmNoYW5uZWxJZD0xMzA=&ticket=",
  191. "tokenbindtype": 1
  192. }
  193. ]
  194. }
  195. */
  196. try
  197. {
  198. string lang = location.Contains("China") ? "zh-cn" : "en-us";
  199. toTeachers.FindAll(x => string.IsNullOrWhiteSpace(x.code) || (!x.code.Equals("zh-cn") && !x.code.Equals("zh-tw") && !x.code.Equals("en-us"))).ForEach(x => { x.code = lang; });
  200. var groups = toTeachers.GroupBy(x => x.code).Select(x => new { x.Key, list = x.ToList() });
  201. var clientID = _configuration.GetValue<string>("HaBookAuth:CoreService:clientID");
  202. var clientSecret = _configuration.GetValue<string>("HaBookAuth:CoreService:clientSecret");
  203. var url = _configuration.GetValue<string>("HaBookAuth:CoreAPI");
  204. string site = location;
  205. if (location.Contains("China"))
  206. {
  207. location = "China";
  208. }
  209. else if (location.Contains("Global"))
  210. {
  211. location = "Global";
  212. }
  213. replaceData.Add("notifyCode", notifyCode);
  214. replaceData.Add("location", site);
  215. if (replaceData.ContainsKey("schoolId"))
  216. {
  217. replaceData.Add("scope", "school");
  218. }
  219. else { replaceData.Add("scope", "private"); }
  220. var client = _httpClient;
  221. var token = CoreTokenExtensions.CreateAccessToken(clientID, clientSecret, location).Result;
  222. if (client.DefaultRequestHeaders.Contains("Authorization"))
  223. {
  224. client.DefaultRequestHeaders.Remove("Authorization");
  225. client.DefaultRequestHeaders.Add("Authorization", $"Bearer {token.AccessToken}");
  226. }
  227. else
  228. {
  229. client.DefaultRequestHeaders.Add("Authorization", $"Bearer {token.AccessToken}");
  230. }
  231. foreach (var group in groups)
  232. {
  233. string path =Path.Combine(rootPath, $"Lang/{group.Key}.json");
  234. var sampleJson = File.ReadAllBytes(path).AsSpan();
  235. Utf8JsonReader reader = new Utf8JsonReader(sampleJson);
  236. if (JsonDocument.TryParseValue(ref reader, out JsonDocument jsonDoc) && jsonDoc.RootElement.TryGetProperty(notifyCode, out JsonElement json))
  237. {
  238. List<string> msgs = json.ToObject<List<string>>();
  239. List<dynamic> actions = new List<dynamic>();
  240. if (msgs.IsNotEmpty())
  241. {
  242. dynamic action = new ExpandoObject();
  243. //处理action
  244. string urlAction = "";
  245. if (notifyCode.Equals("request_school") || notifyCode.Equals("invite_school")|| notifyCode.Equals("quit_school")) {
  246. if (site.Equals("Global")) {
  247. urlAction = "https://www.teammodel.net/core/process-notify";
  248. }
  249. if (site.Equals("Global-Test")|| site.Equals("Global-Dep"))
  250. {
  251. urlAction = "https://test.teammodel.net/core/process-notify";
  252. }
  253. if (site.Equals("China"))
  254. {
  255. urlAction = "https://www.teammodel.cn/core/process-notify";
  256. }
  257. if (site.Equals("China-Test")|| site.Equals("China-Dep"))
  258. {
  259. urlAction = "https://test.teammodel.cn/core/process-notify";
  260. }
  261. byte[] byts = Encoding.Unicode.GetBytes(replaceData.ToJsonString());
  262. var rdata=Convert.ToBase64String(byts);
  263. byte[] bs= Convert.FromBase64String(rdata);
  264. string data1 = Encoding.Unicode.GetString(bs);
  265. rdata = HttpUtility.UrlEncode(rdata, Encoding.UTF8);
  266. urlAction = $"{urlAction}?notifyCode={notifyCode}&data={rdata}";
  267. if (msgs.Count == 3)
  268. {
  269. string urlA = $"{urlAction}&notifyEvent=1&ticket=";
  270. actions.Add(new { type = "click", label = msgs[2], url = urlA, tokenbindtype = 1 });
  271. }
  272. if (msgs.Count == 4) {
  273. string urlA = $"{urlAction}&notifyEvent=1&ticket=";
  274. string urlB = $"{urlAction}&notifyEvent=2&ticket=";
  275. actions.Add(new { type = "click", label = msgs[2], url = urlA, tokenbindtype = 1 });
  276. actions.Add(new { type = "click", label = msgs[3], url = urlB, tokenbindtype = 1 });
  277. }
  278. }
  279. var tags = group.list.Select(x => $"{x.id}_{notifyType}");
  280. string data = new { value = replaceData }.ToJsonString();
  281. if (actions.Any()) {
  282. data=new { value = replaceData ,action=actions}.ToJsonString();
  283. }
  284. NotifyData notifyData = new NotifyData
  285. {
  286. hubName = "hita5",
  287. sender = "IES",
  288. tags = tags.ToList(),
  289. title = msgs[0],
  290. eventId = $"{notifyCode}-{_snowflakeId.NextId()}",
  291. eventName = $"{msgs[0]}",
  292. data = data
  293. };
  294. if (msgs.Count == 1)
  295. {
  296. notifyData.body = msgs[0];
  297. }
  298. else
  299. {
  300. replaceData.Keys.ToList().ForEach(x => {
  301. msgs[1] = msgs[1].Replace("{" + x + "}", $"{replaceData[x]}");
  302. });
  303. notifyData.body = msgs[1];
  304. }
  305. string result = "";
  306. HttpResponseMessage responseMessage = _httpClient.PostAsJsonAsync($"{url}/service/PushNotify", notifyData).Result;
  307. if (responseMessage.StatusCode == HttpStatusCode.OK)
  308. {
  309. string content = responseMessage.Content.ReadAsStringAsync().Result;
  310. result = content;
  311. }
  312. else
  313. {
  314. result = $"{responseMessage.StatusCode},推送返回的状态码。";
  315. }
  316. // _dingDing.SendBotMsg($"{location}站点发送消息:\n{url}/service/PushNotify \nheader: {token.AccessToken} \nresult:{result}\n params:{notifyData.ToJsonString()}", GroupNames.成都开发測試群組).GetAwaiter().GetResult();
  317. }
  318. }
  319. }
  320. } catch (Exception ex) {
  321. _ = _dingDing.SendBotMsg($"{location},通知V2发送异常\n{ex.Message}\n{ex.StackTrace}\n{replaceData.ToJsonString()}\n{toTeachers.ToJsonString()}\n{notifyCode}", GroupNames.醍摩豆服務運維群組);
  322. }
  323. }
  324. public class NotifyData {
  325. public string hubName { get; set; }
  326. public string sender { get; set; }
  327. public List<string> tags { get; set; } = new List<string>();
  328. public string title { get; set; }
  329. public string body { get; set; }
  330. public string eventId { get; set; }
  331. public string eventName { get; set; }
  332. public string data { get; set; }
  333. }
  334. /// <summary>
  335. /// 发送短信验证码
  336. /// </summary>
  337. /// <param name="clientID"></param>
  338. /// <param name="clientSecret"></param>
  339. /// <param name="location"></param>
  340. /// <param name="url"></param>
  341. /// <param name="data"></param>
  342. /// <returns></returns>
  343. public async Task<(HttpStatusCode code ,string content)> SendSmsPin(Dictionary<string, object> data, string location, IConfiguration _configuration, DI.DingDing _dingDing)
  344. {
  345. try {
  346. var url = _configuration.GetValue<string>("HaBookAuth:CoreAPI");
  347. //url = "https://api2-rc.teammodel.cn";
  348. url = $"{url}/service/sandsms/pin";
  349. var clientID = _configuration.GetValue<string>("HaBookAuth:CoreService:clientID");
  350. var clientSecret = _configuration.GetValue<string>("HaBookAuth:CoreService:clientSecret");
  351. if (location.Contains("China"))
  352. {
  353. location = "China";
  354. }
  355. else if (location.Contains("Global"))
  356. {
  357. location = "Global";
  358. }
  359. var client = _httpClient;
  360. var token = await CoreTokenExtensions.CreateAccessToken(clientID, clientSecret, location);
  361. if (client.DefaultRequestHeaders.Contains("Authorization"))
  362. {
  363. client.DefaultRequestHeaders.Remove("Authorization");
  364. }
  365. client.DefaultRequestHeaders.Add("Authorization", $"Bearer {token.AccessToken}");
  366. HttpResponseMessage responseMessage = await client.PostAsJsonAsync(url, data);
  367. if (responseMessage.Content != null)
  368. {
  369. string content = await responseMessage.Content.ReadAsStringAsync();
  370. if (!string.IsNullOrWhiteSpace(content))
  371. {
  372. return (responseMessage.StatusCode, content);
  373. }
  374. else {
  375. return (responseMessage.StatusCode, null);
  376. }
  377. }
  378. else {
  379. return (responseMessage.StatusCode, null);
  380. }
  381. } catch (Exception ex) {
  382. await _dingDing.SendBotMsg($"{location}验证码发送异常:\n{ex.Message}\n{ex.StackTrace}", DI.GroupNames.醍摩豆服務運維群組);
  383. return (HttpStatusCode.InternalServerError,null);
  384. }
  385. }
  386. /// <summary>
  387. /// 隐式登录
  388. /// </summary>
  389. /// <param name="clientID"></param>
  390. /// <param name="clientSecret"></param>
  391. /// <param name="location"></param>
  392. /// <param name="url"></param>
  393. /// <param name="data"></param>
  394. /// <returns></returns>
  395. public async Task<TmdidImplicit> Implicit( Dictionary<string,string> data,string location, IConfiguration _configuration)
  396. {
  397. var url = _configuration.GetValue<string>("HaBookAuth:CoreAPI");
  398. //url = "https://api2-rc.teammodel.cn";
  399. url = $"{url}/oauth2/implicit";
  400. var clientID = _configuration.GetValue<string>("HaBookAuth:CoreService:clientID");
  401. var clientSecret = _configuration.GetValue<string>("HaBookAuth:CoreService:clientSecret");
  402. if (location.Contains("China"))
  403. {
  404. location = "China";
  405. }
  406. else if (location.Contains("Global"))
  407. {
  408. location = "Global";
  409. }
  410. var client = _httpClient;
  411. var token = await CoreTokenExtensions.CreateAccessToken(clientID, clientSecret, location);
  412. if (client.DefaultRequestHeaders.Contains("Authorization"))
  413. {
  414. client.DefaultRequestHeaders.Remove("Authorization");
  415. }
  416. client.DefaultRequestHeaders.Add("Authorization", $"Bearer {token.AccessToken}");
  417. HttpResponseMessage responseMessage = await client.PostAsJsonAsync(url, data);
  418. if (responseMessage.StatusCode == HttpStatusCode.OK)
  419. {
  420. string content=await responseMessage.Content.ReadAsStringAsync();
  421. if (!string.IsNullOrEmpty(content))
  422. {
  423. TmdidImplicit tmdidImplicit = content.ToObject<TmdidImplicit>();
  424. return tmdidImplicit;
  425. }
  426. else
  427. {
  428. return null;
  429. }
  430. }
  431. else if (responseMessage.StatusCode == HttpStatusCode.Unauthorized)
  432. {
  433. return null;
  434. }
  435. else
  436. {
  437. return null;
  438. }
  439. }
  440. /// <summary>
  441. /// 获取多个用户信息
  442. /// </summary>
  443. /// <param name="clientID"></param>
  444. /// <param name="clientSecret"></param>
  445. /// <param name="location"></param>
  446. /// <param name="url"></param>
  447. /// <param name="data"></param>
  448. /// <returns></returns>
  449. public async Task<string> GetUserInfos(StringContent scontent, string name = "Default") {
  450. var clientID = options.clientID;
  451. var clientSecret = options.clientSecret;
  452. var location = options.location;
  453. var url = options.url;
  454. if (location.Contains("China"))
  455. { url =string.IsNullOrWhiteSpace(url)? "https://api2.teammodel.cn":url;
  456. location = "China";
  457. }
  458. else if (location.Contains("Global"))
  459. {
  460. url = string.IsNullOrWhiteSpace(url) ? "https://api2.teammodel.net" : url;
  461. location = "Global";
  462. }
  463. url = $"{url}/oauth2/getuserinfos";
  464. var client = _httpClient;
  465. var token = await CoreTokenExtensions.CreateAccessToken(clientID, clientSecret, location);
  466. if (client.DefaultRequestHeaders.Contains("Authorization"))
  467. {
  468. client.DefaultRequestHeaders.Remove("Authorization");
  469. }
  470. client.DefaultRequestHeaders.Add("Authorization", $"Bearer {token.AccessToken}");
  471. HttpResponseMessage responseMessage = await client.PostAsync(url, scontent);
  472. if (responseMessage.StatusCode == HttpStatusCode.OK)
  473. {
  474. string content = await responseMessage.Content.ReadAsStringAsync();
  475. if (!string.IsNullOrEmpty(content))
  476. {
  477. return content;
  478. }
  479. else
  480. {
  481. return null;
  482. }
  483. }
  484. else if (responseMessage.StatusCode == HttpStatusCode.Unauthorized)
  485. {
  486. return null;
  487. }
  488. else
  489. {
  490. return null;
  491. }
  492. }
  493. /// <summary>
  494. /// 获取单个用户信息
  495. /// </summary>
  496. /// <param name="clientID"></param>
  497. /// <param name="clientSecret"></param>
  498. /// <param name="location"></param>
  499. /// <param name="url"></param>
  500. /// <param name="data"></param>
  501. /// <returns></returns>
  502. public async Task<CoreUser> GetUserInfo(Dictionary<string, string> data, string location, IConfiguration _configuration)
  503. {
  504. var url = _configuration.GetValue<string>("HaBookAuth:CoreAPI");
  505. //url = "https://api2-rc.teammodel.cn";
  506. url = $"{url}/oauth2/getuserinfo";
  507. var clientID = _configuration.GetValue<string>("HaBookAuth:CoreService:clientID");
  508. var clientSecret = _configuration.GetValue<string>("HaBookAuth:CoreService:clientSecret");
  509. if (location.Contains("China"))
  510. {
  511. location = "China";
  512. }
  513. else if (location.Contains("Global"))
  514. {
  515. location = "Global";
  516. }
  517. var client = _httpClient;
  518. var token = await CoreTokenExtensions.CreateAccessToken(clientID, clientSecret, location);
  519. if (client.DefaultRequestHeaders.Contains("Authorization"))
  520. {
  521. client.DefaultRequestHeaders.Remove("Authorization");
  522. }
  523. client.DefaultRequestHeaders.Add("Authorization", $"Bearer {token.AccessToken}");
  524. HttpResponseMessage responseMessage = await client.PostAsJsonAsync(url, data);
  525. if (responseMessage.StatusCode == HttpStatusCode.OK)
  526. {
  527. string content = await responseMessage.Content.ReadAsStringAsync();
  528. if (!string.IsNullOrEmpty(content))
  529. {
  530. CoreUserInfo coreUserInfo = content.ToObject<CoreUserInfo>();
  531. if (coreUserInfo != null)
  532. {
  533. bool isActivate = !string.IsNullOrWhiteSpace(coreUserInfo.password) || !string.IsNullOrWhiteSpace(coreUserInfo.passwordOld);
  534. CoreUser coreUser = new CoreUser
  535. {
  536. isActivate = isActivate,
  537. id = coreUserInfo.id,
  538. vid = coreUserInfo.vid,
  539. mail = coreUserInfo.mail,
  540. mobile = coreUserInfo.mobile,
  541. name = coreUserInfo.name,
  542. picture = coreUserInfo.picture,
  543. habook = coreUserInfo.habook,
  544. wechat = coreUserInfo.wechat,
  545. facebook = coreUserInfo.facebook,
  546. google = coreUserInfo.google,
  547. ding = coreUserInfo.ding,
  548. apple = coreUserInfo.apple,
  549. };
  550. return coreUser;
  551. }
  552. else
  553. {
  554. return null;
  555. }
  556. }
  557. else {
  558. return null;
  559. }
  560. }
  561. else if (responseMessage.StatusCode == HttpStatusCode.Unauthorized)
  562. {
  563. return null;
  564. }
  565. else
  566. {
  567. return null;
  568. }
  569. }
  570. }
  571. public class TmdidImplicit
  572. {
  573. public string id_token { get; set; }
  574. public string access_token { get; set; }
  575. public string expires_in { get; set; }
  576. public string token_type { get; set; }
  577. }
  578. public class CoreUser
  579. {
  580. public string searchKey { get; set; }
  581. public string id { get; set; }
  582. public string vid { get; set; }
  583. public string mail { get; set; }
  584. public string mobile { get; set; }
  585. public string name { get; set; }
  586. public string picture { get; set; }
  587. public string habook { get; set; }
  588. public string wechat { get; set; }
  589. public string facebook { get; set; }
  590. public string google { get; set; }
  591. public string ding { get; set; }
  592. public string apple { get; set; }
  593. public bool isActivate { get; set; }
  594. }
  595. public class CoreUserInfo : CoreUser
  596. {
  597. public string area { get; set; }
  598. public string country { get; set; }
  599. public string type { get; set; }
  600. public string password { get; set; }
  601. public string salt { get; set; }
  602. public string passwordOld { get; set; }
  603. public string saltOld { get; set; }
  604. }
  605. }