aboutsummaryrefslogtreecommitdiff
path: root/SkuAssist.cs
diff options
context:
space:
mode:
authorSergey Chebotar <s.chebotar@gmail.com>2021-11-11 16:54:02 +0300
committerSergey Chebotar <s.chebotar@gmail.com>2021-11-11 16:54:02 +0300
commit475d981364aa18ba22d4d2f78f837d20af4df6a8 (patch)
treedfbe96d775cd1129a17de33c21c946ba2eeb1d6b /SkuAssist.cs
parent3be35e28f6e1c4477772ab74a18cbbdb45046224 (diff)
parente7d3fe2beae326a2380b4cfed7f33961f40d87ca (diff)
Merge branch 'dev'
Diffstat (limited to 'SkuAssist.cs')
-rw-r--r--SkuAssist.cs56
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));
+ }
+ }
+}
+
+