fcs-virk/VrQueryMapper.cs
2022-02-24 11:56:29 +01:00

100 lines
No EOL
5.2 KiB
C#

// ***********************************************************************
// Assembly : FCS.Lib.Virk
// Author : FH
// Created : 02-21-2022
//
// Last Modified By : FH
// Last Modified On : 02-24-2022
// ***********************************************************************
// <copyright file="VrQueryMapper.cs" company="FCS">
// Copyright (C) 2022 FCS Frede's Computer Services.
// 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.Linq;
namespace FCS.Lib.Virk
{
/// <summary>
/// Class VrQueryMapper.
/// </summary>
public class VrQueryMapper
{
/// <summary>
/// Vrs the map query.
/// </summary>
/// <param name="query">The query.</param>
/// <returns>JObject.</returns>
public JObject VrMapQuery(VrQuery query)
{
if (string.IsNullOrWhiteSpace(query.VatNumber))
{
return new JObject(
new JProperty("_source",
new JArray(
"Vrvirksomhed.cvrNummer",
"Vrvirksomhed.virksomhedMetadata.nyesteNavn.navn",
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.conavn",
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.vejnavn",
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.husnummerFra",
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.husnummerTil",
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.postnummer",
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.postdistrikt",
"Vrvirksomhed.virksomhedsstatus")
),
new JProperty("query",
new JObject(new JProperty("bool",
new JObject(new JProperty("must",
new JArray(
new JObject(new JProperty("match",
new JObject(new JProperty(
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.postnummer",
new JObject(new JProperty("query", query.ZipCode),
new JProperty("_name", "postnummer")))))),
new JObject(new JProperty("match",
new JObject(new JProperty(
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.vejnavn",
new JObject(new JProperty("query", query.StreetName),
new JProperty("_name", "vejnavn")))))),
new JObject(new JProperty("match",
new JObject(new JProperty(
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.husnummerFra",
new JObject(new JProperty("query", query.HouseNumber),
new JProperty("_name", "husnummerFra"))))))
)))))),
new JProperty("size", 50));
}
return new JObject(
new JProperty("_source",
new JArray(
"Vrvirksomhed.cvrNummer",
"Vrvirksomhed.virksomhedMetadata.nyesteNavn.navn",
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.conavn",
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.vejnavn",
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.husnummerFra",
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.husnummerTil",
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.postnummer",
"Vrvirksomhed.virksomhedMetadata.nyesteBeliggenhedsadresse.postdistrikt",
"Vrvirksomhed.virksomhedsstatus")
),
new JProperty("query",
new JObject(new JProperty("term",
new JObject(new JProperty("Vrvirksomhed.cvrNummer", query.VatNumber))))));
}
}
}