CoreAPIHttpService.cs 29 KB

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