aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Tango.BL/ObservablesContextExtension.cs
blob: 4c703a96b0e7ceb6912e3225969fcdc5a8742bfa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
using System;
using System.Collections.Generic;
using System.Data.SQLite;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Tango.Core;
using Tango.Settings;

namespace Tango.BL
{
    public partial class ObservablesContext
    {
        /// <summary>
        /// Initializes a new instance of the <see cref="ObservablesContext" /> class.
        /// </summary>
        /// <param name="path">The server file path.</param>
        /// <param name="isFile">if set to <c>true</c> will try to connect to an .mdf file.</param>
        public ObservablesContext(String path) : base(ComposeConnectionString(path))
        {

        }

        /// <summary>
        /// Initializes a new instance of the <see cref="ObservablesContext"/> class.
        /// </summary>
        /// <param name="sqliteConnection">The SQLite connection.</param>
        public ObservablesContext(SQLiteConnection sqliteConnection) : base(sqliteConnection, true)
        {

        }

        /// <summary>
        /// Composes the connection string.
        ///</summary>
        /// <param name="source">The source.</param>
        /// <param name="isFile">if set to <c>true</c> [is file].</param>
        /// <returns></returns>
        private static String ComposeConnectionString(String source)
        {
            if (!File.Exists(source))
            {
                return String.Format("Data Source={0};Initial Catalog=Tango;Integrated Security=True;", source);
            }
            else
            {
                return String.Format("Data Source=(LocalDB)\\MSSQLLocalDB;AttachDbFileName={0};Initial Catalog=Tango;Integrated Security=True;MultipleActiveResultSets=True;App=EntityFramework", Path.GetFullPath(source));
            }
        }

        /// <summary>
        /// Creates a default remote database context by the address specified in <see cref="SettingsManager.Default.DataBase.SQLServerAddress" />.
        /// </summary>
        /// <returns></returns>
        public static ObservablesContext CreateDefault()
        {
            return CreateDefault(SettingsManager.Default.GetOrCreate<CoreSettings>().DataBaseSource);
        }

        /// <summary>
        /// Creates a default remote database context by the address specified in <see cref="SettingsManager.Default.DataBase.SQLServerAddress" />.
        /// </summary>
        /// <returns></returns>
        public static ObservablesContext CreateDefault(String dataSource)
        {
            var source = dataSource;

            if (File.Exists(source) && Path.GetExtension(source).ToLower() == ".db")
            {
                var connection = new SQLiteConnection()
                {
                    ConnectionString = new SQLiteConnectionStringBuilder() { DataSource = Path.GetFullPath(source), ForeignKeys = true }.ConnectionString
                };

                return new ObservablesContext(connection);
            }
            else
            {
                return new ObservablesContext(source);
            }
        }

        /// <summary>
        /// Creates a default remote database context by the address specified in <see cref="SettingsManager.Default.DataBase.SQLServerAddress" />.
        /// </summary>
        /// <returns></returns>
        public static ObservablesContext CreateDefaultForWeb()
        {
            return new ObservablesContext("localhost\\SQLTWINE");
        }
    }
}