|
|
@ -0,0 +1,75 @@ |
|
|
|
|
|
|
|
using System; |
|
|
|
|
|
|
|
using System.Collections.Generic; |
|
|
|
|
|
|
|
using System.Linq; |
|
|
|
|
|
|
|
using System.Text; |
|
|
|
|
|
|
|
using System.Xml.Linq; |
|
|
|
|
|
|
|
using FLocal.Core; |
|
|
|
|
|
|
|
using FLocal.Core.DB; |
|
|
|
|
|
|
|
using FLocal.Core.DB.conditions; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace FLocal.Common.dataobjects { |
|
|
|
|
|
|
|
public class QuickLink : SqlObject<QuickLink> { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public class TableSpec : ISqlObjectTableSpec { |
|
|
|
|
|
|
|
public const string TABLE = "QuickLinks"; |
|
|
|
|
|
|
|
public const string FIELD_ID = "Id"; |
|
|
|
|
|
|
|
public const string FIELD_NAME = "Name"; |
|
|
|
|
|
|
|
public const string FIELD_URL = "Url"; |
|
|
|
|
|
|
|
public static readonly TableSpec instance = new TableSpec(); |
|
|
|
|
|
|
|
public string name { get { return TABLE; } } |
|
|
|
|
|
|
|
public string idName { get { return FIELD_ID; } } |
|
|
|
|
|
|
|
public void refreshSqlObject(int id) { Refresh(id); } |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
protected override ISqlObjectTableSpec table { get { return TableSpec.instance; } } |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private string _name; |
|
|
|
|
|
|
|
public string name { |
|
|
|
|
|
|
|
get { |
|
|
|
|
|
|
|
this.LoadIfNotLoaded(); |
|
|
|
|
|
|
|
return this._name; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private string _url; |
|
|
|
|
|
|
|
public string url { |
|
|
|
|
|
|
|
get { |
|
|
|
|
|
|
|
this.LoadIfNotLoaded(); |
|
|
|
|
|
|
|
return this._url; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private static Dictionary<string, int> name2id = new Dictionary<string,int>(); |
|
|
|
|
|
|
|
public static QuickLink LoadByName(string name) { |
|
|
|
|
|
|
|
if(!name2id.ContainsKey(name)) { |
|
|
|
|
|
|
|
lock(name2id) { |
|
|
|
|
|
|
|
if(!name2id.ContainsKey(name)) { |
|
|
|
|
|
|
|
List<string> ids = Config.instance.mainConnection.LoadIdsByConditions( |
|
|
|
|
|
|
|
TableSpec.instance, |
|
|
|
|
|
|
|
new ComparisonCondition( |
|
|
|
|
|
|
|
TableSpec.instance.getColumnSpec(TableSpec.FIELD_NAME), |
|
|
|
|
|
|
|
ComparisonType.EQUAL, |
|
|
|
|
|
|
|
name |
|
|
|
|
|
|
|
), |
|
|
|
|
|
|
|
Diapasone.unlimited |
|
|
|
|
|
|
|
); |
|
|
|
|
|
|
|
if(ids.Count > 1) { |
|
|
|
|
|
|
|
throw new CriticalException("not unique"); |
|
|
|
|
|
|
|
} else if(ids.Count == 1) { |
|
|
|
|
|
|
|
name2id[name] = int.Parse(ids[0]); |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
throw new NotFoundInDBException(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
return QuickLink.LoadById(name2id[name]); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
protected override void doFromHash(Dictionary<string, string> data) { |
|
|
|
|
|
|
|
this._name = data[TableSpec.FIELD_NAME]; |
|
|
|
|
|
|
|
this._url = data[TableSpec.FIELD_URL]; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |