* Rename Umbraco.Core namespace to Umbraco.Cms.Core * Move extension methods in core project to Umbraco.Extensions * Move extension methods in core project to Umbraco.Extensions * Rename Umbraco.Examine namespace to Umbraco.Cms.Examine * Move examine extensions to Umbraco.Extensions namespace * Reflect changed namespaces in Builder and fix unit tests * Adjust namespace in Umbraco.ModelsBuilder.Embedded * Adjust namespace in Umbraco.Persistence.SqlCe * Adjust namespace in Umbraco.PublishedCache.NuCache * Align namespaces in Umbraco.Web.BackOffice * Align namespaces in Umbraco.Web.Common * Ensure that SqlCeSupport is still enabled after changing the namespace * Align namespaces in Umbraco.Web.Website * Align namespaces in Umbraco.Web.UI.NetCore * Align namespaces in Umbraco.Tests.Common * Align namespaces in Umbraco.Tests.UnitTests * Align namespaces in Umbraco.Tests.Integration * Fix errors caused by changed namespaces * Fix integration tests * Undo the Umbraco.Examine.Lucene namespace change This breaks integration tests on linux, since the namespace wont exists there because it's only used on windows. * Fix merge * Fix Merge
85 lines
2.7 KiB
C#
85 lines
2.7 KiB
C#
using System;
|
|
using System.Data;
|
|
using System.Data.Common;
|
|
using System.Linq;
|
|
using Microsoft.Extensions.Logging;
|
|
using StackExchange.Profiling.Data;
|
|
using Umbraco.Cms.Core;
|
|
using Umbraco.Core.Persistence.FaultHandling;
|
|
using Umbraco.Extensions;
|
|
|
|
namespace Umbraco.Core.Persistence
|
|
{
|
|
public static class DbConnectionExtensions
|
|
{
|
|
public static string DetectProviderNameFromConnectionString(string connectionString)
|
|
{
|
|
var builder = new DbConnectionStringBuilder { ConnectionString = connectionString };
|
|
var allKeys = builder.Keys.Cast<string>();
|
|
|
|
if (allKeys.InvariantContains("Data Source")
|
|
//this dictionary is case insensitive
|
|
&& builder["Data source"].ToString().InvariantContains(".sdf"))
|
|
{
|
|
return Cms.Core.Constants.DbProviderNames.SqlCe;
|
|
}
|
|
|
|
return Cms.Core.Constants.DbProviderNames.SqlServer;
|
|
}
|
|
|
|
public static bool IsConnectionAvailable(string connectionString, DbProviderFactory factory)
|
|
{
|
|
|
|
var connection = factory.CreateConnection();
|
|
|
|
if (connection == null)
|
|
throw new InvalidOperationException($"Could not create a connection for provider \"{factory}\".");
|
|
|
|
connection.ConnectionString = connectionString;
|
|
using (connection)
|
|
{
|
|
return connection.IsAvailable();
|
|
}
|
|
}
|
|
|
|
|
|
public static bool IsAvailable(this IDbConnection connection)
|
|
{
|
|
try
|
|
{
|
|
connection.Open();
|
|
connection.Close();
|
|
}
|
|
catch (DbException e)
|
|
{
|
|
// Don't swallow this error, the exception is super handy for knowing "why" its not available
|
|
StaticApplicationLogging.Logger.LogWarning(e, "Configured database is reporting as not being available.");
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Unwraps a database connection.
|
|
/// </summary>
|
|
/// <remarks>UmbracoDatabase wraps the original database connection in various layers (see
|
|
/// OnConnectionOpened); this unwraps and returns the original database connection.</remarks>
|
|
internal static IDbConnection UnwrapUmbraco(this IDbConnection connection)
|
|
{
|
|
var unwrapped = connection;
|
|
IDbConnection c;
|
|
do
|
|
{
|
|
c = unwrapped;
|
|
if (unwrapped is ProfiledDbConnection profiled) unwrapped = profiled.WrappedConnection;
|
|
if (unwrapped is RetryDbConnection retrying) unwrapped = retrying.Inner;
|
|
|
|
} while (c != unwrapped);
|
|
|
|
return unwrapped;
|
|
}
|
|
|
|
}
|
|
}
|