-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathVrResponseParser.cs
executable file
·91 lines (80 loc) · 3.62 KB
/
VrResponseParser.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
// // ***********************************************************************
// // Solution : Inno.Api.v2
// // Assembly : FCS.Lib.Virk
// // Filename : VrResponseParser.cs
// // Created : 2025-01-03 14:01
// // Last Modified By : dev
// // Last Modified On : 2025-01-04 13:01
// // ***********************************************************************
// // <copyright company="Frede Hundewadt">
// // Copyright (C) 2010-2025 Frede Hundewadt
// // This program is free software: you can redistribute it and/or modify
// // it under the terms of the GNU Affero General Public License as
// // published by the Free Software Foundation, either version 3 of the
// // License, or (at your option) any later version.
// //
// // This program is distributed in the hope that it will be useful,
// // but WITHOUT ANY WARRANTY; without even the implied warranty of
// // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// // GNU Affero General Public License for more details.
// //
// // You should have received a copy of the GNU Affero General Public License
// // along with this program. If not, see [https://www.gnu.org/licenses]
// // </copyright>
// // <summary></summary>
// // ***********************************************************************
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
namespace FCS.Lib.Virk;
/// <summary>
/// Provides functionality to parse VR response data and extract relevant business information.
/// </summary>
/// <remarks>
/// This class is designed to handle JSON-formatted VR response data, typically returned from external services.
/// It parses the data to extract a collection of <see cref="VrVirksomhed" /> objects, which represent business
/// entities.
/// </remarks>
public class VrResponseParser
{
/// <summary>
/// Parses the VR response data and extracts a list of <see cref="VrVirksomhed" /> objects.
/// </summary>
/// <param name="responseData">
/// A JSON-formatted string containing the VR response data.
/// </param>
/// <returns>
/// A list of <see cref="VrVirksomhed" /> objects extracted from the response data.
/// If no valid data is found, an empty list is returned.
/// </returns>
/// <exception cref="JsonReaderException">
/// Thrown if the provided <paramref name="responseData" /> is not a valid JSON string.
/// </exception>
/// <exception cref="JsonSerializationException">
/// Thrown if the deserialization of a <see cref="VrVirksomhed" /> object fails.
/// </exception>
public List<VrVirksomhed> ParseVrResponse(string responseData)
{
var result = new List<VrVirksomhed>();
var cvrObject = JObject.Parse(responseData);
var numHits = (int)cvrObject.SelectToken("hits")?.SelectToken("total")!;
if (numHits == 0)
return result;
var cvrHits = cvrObject.SelectToken("hits")?.SelectToken("hits");
for (var i = 0; i < numHits; i++)
try
{
var cObject = cvrHits?[i]?["_source"] != null
? (JObject?)cvrHits[i]?["_source"]?["Vrvirksomhed"]
: null;
var jsonString = JsonConvert.SerializeObject(cObject);
var o = JsonConvert.DeserializeObject<VrVirksomhed>(jsonString);
if (o != null)
result.Add(o);
}
catch
{
return result;
}
return result;
}
}