diff options
author | Sergey Chebotar <s.chebotar@gmail.com> | 2021-11-11 16:54:02 +0300 |
---|---|---|
committer | Sergey Chebotar <s.chebotar@gmail.com> | 2021-11-11 16:54:02 +0300 |
commit | 475d981364aa18ba22d4d2f78f837d20af4df6a8 (patch) | |
tree | dfbe96d775cd1129a17de33c21c946ba2eeb1d6b /SkuAssist.cs | |
parent | 3be35e28f6e1c4477772ab74a18cbbdb45046224 (diff) | |
parent | e7d3fe2beae326a2380b4cfed7f33961f40d87ca (diff) |
Merge branch 'dev'
Diffstat (limited to 'SkuAssist.cs')
-rw-r--r-- | SkuAssist.cs | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/SkuAssist.cs b/SkuAssist.cs new file mode 100644 index 0000000..b873104 --- /dev/null +++ b/SkuAssist.cs @@ -0,0 +1,56 @@ +using System.Net.Http; +using System.Threading.Tasks; +using AngleSharp; +using System.Linq; +using System.Net; + +namespace Rehau.Sku.Assist +{ + static class SkuAssist + { + static private HttpClient _httpClient; + + public static void EnsureHttpInitialized() + { + if (_httpClient == null) + { + _httpClient = new HttpClient(); + } + } + + public static string GetSku(string request) + { + string url = "https://shop-rehau.ru/catalogsearch/result/?q=" + request; + HttpResponseMessage response = GetResponse(url).Result; + var document = GetDocument(response).Result; + + var name = document + .All + .Where(e => e.ClassName == "product-item__desc-top") + .Select(e => new { sku = e.Children[0].TextContent, name = e.Children[1].TextContent.Trim(new[] { '\n', ' ' }) }) + .Where(t => !t.sku.Any(c => char.IsLetter(c))) + .FirstOrDefault(); + + return name == null ? "Не найдено" : $"{name.name} ({name.sku})"; + } + + private static async Task<HttpResponseMessage> GetResponse(string url) + { + ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12 | SecurityProtocolType.Tls11 | SecurityProtocolType.Tls; + HttpResponseMessage response = await _httpClient.GetAsync(url); + response.EnsureSuccessStatusCode(); + return response; + } + + private static async Task<AngleSharp.Dom.IDocument> GetDocument(HttpResponseMessage response) + { + IConfiguration config = Configuration.Default; + IBrowsingContext context = BrowsingContext.New(config); + + string source = await response.Content.ReadAsStringAsync(); + return await context.OpenAsync(req => req.Content(source)); + } + } +} + + |