// Copyright (C) Stichting Deltares 2016. All rights reserved.
//
// This file is part of Ringtoets.
//
// Ringtoets is free software: you can redistribute it and/or modify
// it under the terms of the GNU 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 General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see .
//
// All names, logos, and references to "Deltares" are registered trademarks of
// Stichting Deltares and remain full property of Stichting Deltares at all times.
// All rights reserved.
using System;
using System.Collections.Generic;
using Core.Common.Base.IO;
using Core.Common.IO.Exceptions;
using Core.Common.IO.Readers;
using log4net;
using Ringtoets.Common.Data.Calculation;
using Ringtoets.Common.IO.Exceptions;
using Ringtoets.Common.IO.Properties;
using Ringtoets.Common.IO.Readers;
namespace Ringtoets.Common.IO.FileImporters
{
///
/// Base class for importing a calculation configuration from an XML file and
/// storing it on a .
///
public abstract class CalculationConfigurationImporter
: FileImporterBase
where TReadCalculation : class, IReadConfigurationItem
{
private static readonly ILog log = LogManager.GetLogger(typeof(CalculationConfigurationImporter));
///
/// Creates a new instance of .
///
/// The path to the file to import from.
/// The calculation group to update.
/// Thrown when any parameter is
/// null.
protected CalculationConfigurationImporter(string filePath, CalculationGroup importTarget)
: base(filePath, importTarget) {}
protected override void LogImportCanceledMessage()
{
log.Info(Resources.CalculationConfigurationImporter_LogImportCanceledMessage_Import_canceled_no_data_read);
}
protected override bool OnImport()
{
NotifyProgress(Resources.CalculationConfigurationImporter_ProgressText_Reading_configuration, 1, 3);
ReadResult readResult = ReadConfiguration();
if (readResult.CriticalErrorOccurred || Canceled)
{
return false;
}
NotifyProgress(Resources.CalculationConfigurationImporter_ProgressText_Validating_imported_data, 2, 3);
var validCalculationItems = new List();
foreach (IReadConfigurationItem readItem in readResult.Items)
{
if (Canceled)
{
return false;
}
ICalculationBase processedItem = ProcessReadItem(readItem);
if (processedItem != null)
{
validCalculationItems.Add(processedItem);
}
}
NotifyProgress(Resources.Importer_ProgressText_Adding_imported_data_to_data_model, 3, 3);
AddItemsToModel(validCalculationItems);
return true;
}
protected abstract ICollection ReadConfigurationItems(string filePath);
protected abstract ICalculationBase ProcessCalculation(TReadCalculation readCalculation);
private ReadResult ReadConfiguration()
{
try
{
return new ReadResult(false)
{
Items = ReadConfigurationItems(FilePath)
};
}
catch (Exception exception) when (exception is ArgumentException
|| exception is CriticalFileReadException)
{
string errorMessage = string.Format(Resources.CalculationConfigurationImporter_HandleCriticalFileReadError_Error_0_no_configuration_imported,
exception.Message);
log.Error(errorMessage, exception);
return new ReadResult(true);
}
}
private ICalculationBase ProcessReadItem(IReadConfigurationItem readItem)
{
var readCalculationGroup = readItem as ReadCalculationGroup;
if (readCalculationGroup != null)
{
return ProcessCalculationGroup(readCalculationGroup);
}
var readCalculation = readItem as TReadCalculation;
if (readCalculation != null)
{
return ProcessCalculationInternal(readCalculation);
}
return null;
}
private CalculationGroup ProcessCalculationGroup(ReadCalculationGroup readCalculationGroup)
{
var group = new CalculationGroup(readCalculationGroup.Name, true);
foreach (IReadConfigurationItem item in readCalculationGroup.Items)
{
ICalculationBase processedItem = ProcessReadItem(item);
if (processedItem != null)
{
group.Children.Add(processedItem);
}
}
return group;
}
private ICalculationBase ProcessCalculationInternal(TReadCalculation readCalculation)
{
try
{
return ProcessCalculation(readCalculation);
}
catch (CriticalFileValidationException e)
{
string message = string.Format(Resources.CalculationConfigurationImporter_ValidateCalculation_Error_message_0_calculation_1_skipped,
e.Message,
readCalculation.Name);
log.Error(message, e);
return null;
}
}
private void AddItemsToModel(IEnumerable validCalculationItems)
{
foreach (ICalculationBase validCalculationItem in validCalculationItems)
{
ImportTarget.Children.Add(validCalculationItem);
}
}
}
}