// ******************************************************************************//
// RAYTHEON PROPRIETARY: THIS DOCUMENT CONTAINS DATA OR INFORMATION
// PROPRIETARY TO RAYTHEON COMPANY AND IS RESTRICTED TO USE ONLY BY PERSONS
// AUTHORIZED BY RAYTHEON COMPANY IN WRITING TO USE IT. DISCLOSURE TO
// UNAUTHORIZED PERSONS WOULD LIKELY CAUSE SUBSTANTIAL COMPETITIVE HARM TO
// RAYTHEON COMPANY''S BUSINESS POSITION. NEITHER SAID DOCUMENT NOR ITS
// CONTENTS SHALL BE FURNISHED OR DISCLOSED TO OR COPIED OR USED BY PERSONS
// OUTSIDE RAYTHEON COMPANY WITHOUT THE EXPRESS WRITTEN APPROVAL OF RAYTHEON
// COMPANY.
//
// THIS PROPRIETARY NOTICE IS NOT APPLICABLE IF DELIVERED TO THE U.S. GOVERNMENT
//
// UNPUBLISHED WORK - COPYRIGHT RAYTHEON COMPANY.
//
// WARNING: THIS DOCUMENT CONTAINS TECHNICAL DATA AND / OR TECHNOLOGY WHOSE
// EXPORT OR DISCLOSURE TO NON-U.S. PERSONS, WHEREVER LOCATED, IS RESTRICTED
// BY THE INTERNATIONAL TRAFFIC IN ARMS REGULATIONS (ITAR) (22 C.F.R. SECTION
// 120-130) OR THE EXPORT ADMINISTRATION REGULATIONS (EAR) (15 C.F.R. SECTION
// 730-774). THIS DOCUMENT CANNOT BE EXPORTED (E.G., PROVIDED TO A SUPPLIER
// OUTSIDE OF THE UNITED STATES) OR DISCLOSED TO A NON-U.S. PERSON, WHEREVER
// LOCATED, UNTIL A FINAL JURISDICTION AND CLASSIFICATION DETERMINATION HAS
// BEEN COMPLETED AND APPROVED BY RAYTHEON, AND ANY REQUIRED U.S. GOVERNMENT
// APPROVALS HAVE BEEN OBTAINED. VIOLATIONS ARE SUBJECT TO SEVERE CRIMINAL
// PENALTIES.
//
// DOD 5220.22-M, INDUSTRIAL SECURITY MANUAL, CHAPTER 5, SECTION 1 THROUGH 9 :
// FOR CLASSIFIED DOCUMENTS FOLLOW THE PROCEDURES IN OR DOD 5200.1-R,
// INFORMATION SECURITY PROGRAM, CHAPTER 6. FOR UNCLASSIFIED, LIMITED DOCUMENTS
// DESTROY BY ANY METHOD THAT WILL PREVENT DISCLOSURE OF CONTENTS OR
// RECONSTRUCTION OF THE DOCUMENT.
// ****************************************************************************//
using System.Collections.Generic;
namespace Raytheon.Common
{
///
/// supported file types
///
public enum ConfigurationFileType
{
INI,
XML,
TOML,
JSON,
YAML,
OTHER
}
///
/// updated version of IConfiguration interface
/// allows reading and writing generic types as well as lists
///
public interface IConfigurationFile
{
///
/// reads a single generic type value from the file section
/// if value or section does not exist, will create one and will add the default value
///
///
///
///
///
///
T ReadValue(string section, string key, T defValue = default);
///
/// reads a single generic type value from the file section
/// if value doesn't exist, throw exception
///
///
///
///
string ReadValue(string section, string key);
///
/// reads a list of generic type values from the file section
/// if list or section does not exist, will create one and will populate with the default list
///
///
///
///
///
///
List ReadList(string section, string key, IList defList = null);
///
/// reads all available keys from the given section of configuration file
///
///
///
List ReadAllKeys(string section);
///
/// reads all available sections from configuration file
///
///
List ReadAllSections();
///
/// writes a single value of a generic type
///
///
///
///
///
void WriteValue(string section, string key, T lineToWrite);
///
/// writes a list of generic values
///
///
///
///
///
void WriteList(string section, string key, IList listToWrite);
///
/// checks if the value exists in the given section and given key
///
///
///
///
bool ValueExists(string section, string key);
///
/// configuration file name
///
string FileName { get; }
///
/// configuration file type
///
ConfigurationFileType ConfigurationFileType { get; }
}
}