Documentation Coverage Report
Current view: top level - Azure/Cqrs.Azure.DocumentDb/Factories - AzureDocumentDbDataStoreConnectionStringFactory.cs Hit Total Coverage
Version: 4.0 Artefacts: 8 8 100.0 %
Date: 2019-11-24 03:15:41

          Line data    Source code
       1             : #region Copyright
       2             : // // -----------------------------------------------------------------------
       3             : // // <copyright company="Chinchilla Software Limited">
       4             : // //   Copyright Chinchilla Software Limited. All rights reserved.
       5             : // // </copyright>
       6             : // // -----------------------------------------------------------------------
       7             : #endregion
       8             : 
       9             : using System;
      10             : using Chinchilla.Logging;
      11             : using Cqrs.Configuration;
      12             : using Cqrs.DataStores;
      13             : using Cqrs.Entities;
      14             : using Microsoft.Azure.Documents.Client;
      15             : 
      16             : namespace Cqrs.Azure.DocumentDb.Factories
      17             : {
      18             :         /// <summary>
      19             :         /// A factory for getting connections and database names for <see cref="IDataStore{TAuthenticationToken}"/> access.
      20             :         /// </summary>
      21             :         public class AzureDocumentDbDataStoreConnectionStringFactory : IAzureDocumentDbDataStoreConnectionStringFactory
      22           1 :         {
      23             :                 /// <summary>
      24             :                 /// Gets or sets the <see cref="ILogger"/>.
      25             :                 /// </summary>
      26             :                 protected ILogger Logger { get; private set; }
      27             : 
      28             :                 /// <summary>
      29             :                 /// Gets or sets the <see cref="IConfigurationManager"/>.
      30             :                 /// </summary>
      31             :                 protected IConfigurationManager ConfigurationManager { get; private set; }
      32             : 
      33             :                 /// <summary>
      34             :                 /// Instantiates a new instance of <see cref="AzureDocumentDbDataStoreConnectionStringFactory"/>.
      35             :                 /// </summary>
      36           1 :                 public AzureDocumentDbDataStoreConnectionStringFactory(ILogger logger, IConfigurationManager configurationManager)
      37             :                 {
      38             :                         Logger = logger;
      39             :                         ConfigurationManager = configurationManager;
      40             :                 }
      41             : 
      42             :                 /// <summary>
      43             :                 /// Gets the current <see cref="DocumentClient"/>.
      44             :                 /// </summary>
      45           1 :                 public virtual DocumentClient GetAzureDocumentDbConnectionClient()
      46             :                 {
      47             :                         Logger.LogDebug("Getting Azure document client", "AzureDocumentDbDataStoreConnectionStringFactory\\GetAzureDocumentDbConnectionClient");
      48             :                         try
      49             :                         {
      50             :                                 return new DocumentClient(GetAzureDocumentDbConnectionUrl(), GetAzureDocumentDbAuthorisationKey());
      51             :                         }
      52             :                         finally
      53             :                         {
      54             :                                 Logger.LogDebug("Getting Azure document client... Done", "AzureDocumentDbDataStoreConnectionStringFactory\\GetAzureDocumentDbConnectionClient");
      55             :                         }
      56             :                 }
      57             : 
      58             :                 /// <summary>
      59             :                 /// Gets the current database name.
      60             :                 /// </summary>
      61           1 :                 public virtual string GetAzureDocumentDbDatabaseName()
      62             :                 {
      63             :                         return ConfigurationManager.GetSetting("Cqrs.Azure.DocumentDb.DatabaseName") ?? "CqrsStore";
      64             :                 }
      65             : 
      66             :                 /// <summary>
      67             :                 /// Gets the current collection name.
      68             :                 /// </summary>
      69           1 :                 public virtual string GetAzureDocumentDbCollectionName()
      70             :                 {
      71             :                         return ConfigurationManager.GetSetting("Cqrs.Azure.DocumentDb.CollectionName") ?? "CqrsDataStore";
      72             :                 }
      73             : 
      74             :                 /// <summary>
      75             :                 /// Indicates if a different collection should be used per <see cref="IEntity"/>/<see cref="IDataStore{TData}"/> or a single collection used for all instances of <see cref="IDataStore{TData}"/> and <see cref="IDataStore{TData}"/>.
      76             :                 /// Setting this to true can become expensive as each <see cref="IEntity"/> will have it's own collection. Check the relevant SDK/pricing models.
      77             :                 /// </summary>
      78           1 :                 public virtual bool UseSingleCollectionForAllDataStores()
      79             :                 {
      80             :                         bool value;
      81             :                         if (!bool.TryParse(ConfigurationManager.GetSetting("Cqrs.Azure.DocumentDb.UseSingleCollectionForAllDataStores"), out value))
      82             :                                 value = true;
      83             :                         return value;
      84             :                 }
      85             : 
      86             :                 /// <summary>
      87             :                 /// Gets the current connection <see cref="Uri"/> from the <see cref="ConfigurationManager"/>.
      88             :                 /// </summary>
      89           1 :                 protected virtual Uri GetAzureDocumentDbConnectionUrl()
      90             :                 {
      91             :                         return new Uri(ConfigurationManager.GetSetting("Cqrs.Azure.DocumentDb.Url"));
      92             :                 }
      93             : 
      94             :                 /// <summary>
      95             :                 /// Gets the current connection authorisation key from the <see cref="ConfigurationManager"/>.
      96             :                 /// </summary>
      97           1 :                 protected virtual string GetAzureDocumentDbAuthorisationKey()
      98             :                 {
      99             :                         return ConfigurationManager.GetSetting("Cqrs.Azure.DocumentDb.AuthorisationKey");
     100             :                 }
     101             :         }
     102             : }

Generated by: LCOV version 1.13