NTP Analyzer  0.8.2
Analyze the operation of time servers
FilteredSqlDatabaseMapper.cs
Go to the documentation of this file.
1 //
2 // Copyright (c) 2013-2017 Carsten Sonne Larsen <cs@innolan.net>
3 //
4 // Permission is hereby granted, free of charge, to any person obtaining a copy
5 // of this software and associated documentation files (the "Software"), to deal
6 // in the Software without restriction, including without limitation the rights
7 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8 // copies of the Software, and to permit persons to whom the Software is
9 // furnished to do so, subject to the following conditions:
10 //
11 // The above copyright notice and this permission notice shall be included in
12 // all copies or substantial portions of the Software.
13 //
14 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
20 // THE SOFTWARE.
21 
22 using System;
23 using Ntp.Analyzer.Objects;
24 using Ntp.Common.Log;
25 using Ntp.Data.Provider;
26 
27 namespace Ntp.Analyzer.Data.Sql
28 {
32  public abstract class FilteredSqlDatabaseMapper<T> : SqlDatabaseMapper<T>
33  where T : PersistentObject
34  {
36  : base(log)
37  {
38  }
39 
45  public DateTime? FilterTime { get; set; }
46 
51  public Host FilterHost { get; set; }
52 
57  public Peer FilterPeer { get; set; }
58 
59  protected override string PrepareSql(string sql)
60  {
61  string preparedSql = base.PrepareSql(sql).Trim();
62 
63  if (FilterTime == null && FilterHost == null && FilterPeer == null)
64  return preparedSql;
65 
66  bool filterAdded = false;
67 
68  preparedSql += " WHERE ";
69 
70  if (FilterTime != null)
71  {
72  var time = FilterTime.Value.ToUniversalTime();
73  var datePart = SqlDatabaseFactory.Instance.DateAddMinutes("time", "zone");
74  preparedSql += $"{datePart} > \'{time.ToString("yyyy-MM-dd HH:mm:ss")}\'";
75  filterAdded = true;
76  }
77 
78  if (FilterHost != null)
79  {
80  if (filterAdded)
81  {
82  preparedSql += " AND ";
83  }
84 
85  preparedSql += $"hostId = {FilterHost.Id}";
86  filterAdded = true;
87  }
88 
89  if (FilterPeer == null)
90  return preparedSql;
91 
92  if (filterAdded)
93  {
94  preparedSql += " AND ";
95  }
96 
97  preparedSql += $"peerId = {FilterPeer.Id}";
98 
99  return preparedSql;
100  }
101  }
102 }
OR/M mapper for tables with a large amount of rows.
static SqlDatabaseFactory Instance
Base class for OR/M mappers. Can be used for mapping objects stored in SQL databases.
abstract string DateAddMinutes(string dateColumn, string minuteColumn)