aboutsummaryrefslogtreecommitdiff
path: root/Source/Assistant/ParseUtil.cs
diff options
context:
space:
mode:
authorSerghei Cebotari <51533848+schebotar@users.noreply.github.com>2021-12-24 17:43:04 +0300
committerGitHub <noreply@github.com>2021-12-24 17:43:04 +0300
commit0525ec1b42d5857b740dd0dae7f6d9baeb7088d1 (patch)
tree5d9c814fd023395d894ce36a9040cf7f7330198c /Source/Assistant/ParseUtil.cs
parent8e5db1238ad3ed97f51d9f0a9c7de83c00a12983 (diff)
parent20cfbfcca3a779c04aecdca5e4b465651e2be42a (diff)
Merge pull request #8 from schebotar/dev
Dev
Diffstat (limited to 'Source/Assistant/ParseUtil.cs')
-rw-r--r--Source/Assistant/ParseUtil.cs44
1 files changed, 44 insertions, 0 deletions
diff --git a/Source/Assistant/ParseUtil.cs b/Source/Assistant/ParseUtil.cs
new file mode 100644
index 0000000..a93c658
--- /dev/null
+++ b/Source/Assistant/ParseUtil.cs
@@ -0,0 +1,44 @@
+using AngleSharp;
+using AngleSharp.Dom;
+using Newtonsoft.Json;
+using System.Linq;
+using System.Threading.Tasks;
+
+namespace RehauSku.Assistant
+{
+ static class ParseUtil
+ {
+ public async static Task<IDocument> ContentToDocAsync(string content)
+ {
+ IConfiguration config = Configuration.Default;
+ IBrowsingContext context = BrowsingContext.New(config);
+
+ return await context.OpenAsync(req => req.Content(content));
+ }
+
+ public static IProduct GetProduct(IDocument document)
+ {
+ string script = document
+ .Scripts
+ .Where(s => s.InnerHtml.Contains("dataLayer"))
+ .FirstOrDefault()
+ .InnerHtml;
+
+ string json = script
+ .Substring(script.IndexOf("push(") + 5)
+ .TrimEnd(new[] { ')', ';', '\n', ' ' });
+
+ if (!json.Contains("impressions"))
+ return null;
+
+ StoreResponce storeResponse = JsonConvert.DeserializeObject<StoreResponce>(json);
+ IProduct product = storeResponse
+ .Ecommerce
+ .Impressions
+ .Where(p => p.Id.IsRehauSku())
+ .FirstOrDefault();
+
+ return product;
+ }
+ }
+} \ No newline at end of file