using System; using System.Collections.Generic; using System.Linq; using Kreta.DataAccess.Interfaces; using Kreta.Framework; using Kreta.Framework.Actions; using Kreta.Framework.Collections; using Kreta.Framework.Collections.Generic; using Kreta.Framework.Entities; using Kreta.Framework.Entities.Generic; using Kreta.Framework.Exceptions; namespace SDA.Kreta.Entities { /// /// Az UML modell ErtekelesMondatbank entitásának megvalósítása. /// /// A kód teljes egészében generált, kézi módosítása nem megengedett! [Entity("ErtekelesMondatbank")] // alapértelmezett EntityHistoryMode public class ErtekelesMondatbank : Entity, IErtekelesMondatbank { internal protected ErtekelesMondatbank() : base() { } public class AttributeInfo { public const string ErtekelesTipusa = "ErtekelesTipusa"; public const string EvfolyamTipusa = "EvfolyamTipusa"; public const string RovidNev = "RovidNev"; public const string Szoveg = "Szoveg"; public const string TipusId = "TipusId"; public const string Importalt = "Importalt"; } public class AttributeLengthInfo { public const int RovidNevLength = 3; public const int SzovegLength = 2147483647; } #region General private ErtekelesMondatbankDA m_DA = new ErtekelesMondatbankDA(); protected static ErtekelesMondatbank FakeErtekelesMondatbank { get; set; } public static ErtekelesMondatbank GiveAnInstance() { ErtekelesMondatbank result = FakeErtekelesMondatbank == null ? new ErtekelesMondatbank() : (ErtekelesMondatbank)FakeErtekelesMondatbank.MemberwiseClone(); result.Reset(); result.SetDefaultData(); return result; } protected void SetDefaultData() { if (UserContext.Instance != null) { if (UserContext.Instance.IntezmenyId > 0) { IntezmenyId = UserContext.Instance.IntezmenyId; } if (UserContext.Instance.AktivTanevId > 0) { TanevId = UserContext.Instance.AktivTanevId; } m_State = EntityState.Uninitialized; } } protected override IEntityDataAccessor GetDataAccessor() { return m_DA; } protected internal virtual IEntityDataAccessor InheritedDA { get { return null; } } [Obsolete("Ezt ne használjátok, mert mindenhova bele kellene fogalmazni a tanév szűrést is! Meg fog majd szűnni!")] public static IEntityCollection LoadAll() { return LoadWithFilter(""); } [Obsolete("Ezt ne használjátok, mert mindenhova bele kellene fogalmazni a tanév szűrést is! Meg fog majd szűnni!")] public static IEntityCollection LoadAll(ColumnFilterMode columnFilterMode, IEnumerable columns) { return LoadWithFilter("", columnFilterMode, columns); } [Obsolete("Ezt ne használjátok, mert mindenhova bele kellene fogalmazni a tanév szűrést is! Meg fog majd szűnni!")] public static IEntityCollection LoadWithFilter(string filter, Dictionary commandParameters = null) { var result = new EntityCollection(); new ErtekelesMondatbankDA().LoadWithFilter(result, filter, commandParameters); return result; } [Obsolete("Ezt ne használjátok, mert mindenhova bele kellene fogalmazni a tanév szűrést is! Meg fog majd szűnni!")] public static IEntityCollection LoadWithFilter(string filter, ColumnFilterMode columnFilterMode, IEnumerable columns, Dictionary commandParameters = null) { var result = new EntityCollection(); new ErtekelesMondatbankDA().LoadWithFilter(result, filter, columnFilterMode, columns, commandParameters); return result; } protected override void StoreOriginalValues() { base.StoreOriginalValues(); OriginalValues.Add("ErtekelesTipusa", (ErtekelesTipusa == null ? (object)DBNull.Value : (object)m_ErtekelesTipusa)); OriginalValues.Add("EvfolyamTipusa", (EvfolyamTipusa == null ? (object)DBNull.Value : (object)m_EvfolyamTipusa)); OriginalValues.Add("RovidNev", (RovidNev == null ? (object)DBNull.Value : (object)m_RovidNev)); OriginalValues.Add("Szoveg", (object)m_Szoveg); OriginalValues.Add("TipusId", (object)m_TipusId); OriginalValues.Add("Importalt", (object)m_Importalt); OriginalValues.Add("TantargyId", (m_TantargyId < 0 ? (object)DBNull.Value : (object)m_TantargyId)); OriginalValues.Add("IntezmenyId", (m_IntezmenyId < 0 ? (object)DBNull.Value : (object)m_IntezmenyId)); OriginalValues.Add("TanevId", (m_TanevId < 0 ? (object)DBNull.Value : (object)m_TanevId)); } #endregion #region Ellenőrzés protected override void Validate(bool skipValidateAttributes = false) { base.Validate(); if (!skipValidateAttributes) { // korlátos hosszúságú mezők ellenőrzése... if (m_RovidNev != null && m_RovidNev.Length > 3) { throw new InvalidEntityAttributeException("ErtekelesMondatbank", "RovidNev", EntityAttributeError.TooLong); } if (m_Szoveg != null && m_Szoveg.Length > 2147483647) { throw new InvalidEntityAttributeException("ErtekelesMondatbank", "Szoveg", EntityAttributeError.TooLong); } } // kötelező asszociációk ellenőrzése... if (m_IntezmenyId == -1) { throw new InvalidEntityAttributeException("ErtekelesMondatbank", "IntezmenyId", EntityAttributeError.Empty); } if (m_TanevId == -1) { throw new InvalidEntityAttributeException("ErtekelesMondatbank", "TanevId", EntityAttributeError.Empty); } } #endregion #region Alaphelyzetbe állítás protected override void Reset() { base.Reset(); // alaphelyzetbe állítjuk az egyszerű mezőket this.m_ErtekelesTipusa = null; this.m_EvfolyamTipusa = null; this.m_RovidNev = null; this.m_Szoveg = ""; this.m_TipusId = -1; this.m_Importalt = false; // alaphelyzetbe állítjuk az asszociációkból származó mezőket this.m_TantargyId = -1; this.m_Tantargy = null; // Entity this.m_ErtekelesMondatbankNyelv = null; // EntityCollection this.m_IntezmenyId = -1; this.m_Intezmeny = null; // Entity this.m_TanevId = -1; this.m_Tanev = null; // Entity } #endregion protected override void DeAssociateBeforeDelete(bool runHandler = false) { // Nem kaszkád törölhető asszociációk ellenőrzése, hogy üresek-e... // Tantargy esetében mi mutatunk a másikra: startrole: *, endrole: 0..1 if (this.ErtekelesMondatbankNyelv.Count > 0) { throw new EntityDeleteFailedException("ErtekelesMondatbank", "ErtekelesMondatbankNyelv", EntityUtil.GetAssociationDescription("T_ERTEKELESMONDATBANKNYELV_OSSZES", "C_ERTEKELESMONDATBANKID")); // nincs kapcsolotabla } // Intezmeny esetében mi mutatunk a másikra: startrole: *, endrole: 1 // Tanev esetében mi mutatunk a másikra: startrole: *, endrole: 1 // kaszkád törlések... } #region Mezők és tulajdonságok #region Egyszerű mezők #region ErtekelesTipusa protected internal int? /* DictionaryItem */ m_ErtekelesTipusa; /// /// Nincs definiálva megjegyzés. /// [EntityProperty("ErtekelesTipusa", EntityPropertyBaseType.ValueType, typeof(int /* DictionaryItem */), EntityCopyMethod.ShallowCopy)] [EntityDictionaryItemProperty("ErtekelesTipusa", "ErtekelesTipus", typeof(SDA.Kreta.Entities.ErtekelesTipus))] public virtual int? /* DictionaryItem */ ErtekelesTipusa { get { return m_ErtekelesTipusa; } set { CheckModifyable(); if (m_ErtekelesTipusa == value) return; m_ErtekelesTipusa = value; FieldModified("ErtekelesTipusa", value); } } #endregion #region EvfolyamTipusa protected internal int? /* DictionaryItem */ m_EvfolyamTipusa; /// /// Nincs definiálva megjegyzés. /// [EntityProperty("EvfolyamTipusa", EntityPropertyBaseType.ValueType, typeof(int /* DictionaryItem */), EntityCopyMethod.ShallowCopy)] [EntityDictionaryItemProperty("EvfolyamTipusa", "EvfolyamTipus", typeof(SDA.Kreta.Entities.EvfolyamTipus))] public virtual int? /* DictionaryItem */ EvfolyamTipusa { get { return m_EvfolyamTipusa; } set { CheckModifyable(); if (m_EvfolyamTipusa == value) return; m_EvfolyamTipusa = value; FieldModified("EvfolyamTipusa", value); } } #endregion #region RovidNev protected internal string m_RovidNev; /// /// Nincs definiálva megjegyzés. /// [EntityProperty("RovidNev", EntityPropertyBaseType.ValueType, typeof(string), EntityCopyMethod.ShallowCopy)] public virtual string RovidNev { get { return m_RovidNev; } set { CheckModifyable(); if (m_RovidNev == value) return; m_RovidNev = value; FieldModified("RovidNev", value); } } #endregion #region Szoveg protected internal string m_Szoveg; /// /// Nincs definiálva megjegyzés. /// [EntityProperty("Szoveg", EntityPropertyBaseType.ValueType, typeof(string), EntityCopyMethod.ShallowCopy)] public virtual string Szoveg { get { return m_Szoveg; } set { CheckModifyable(); if (m_Szoveg == value) return; m_Szoveg = value; FieldModified("Szoveg", value); } } #endregion #region TipusId protected internal int /* DictionaryItem */ m_TipusId; /// /// Nincs definiálva megjegyzés. /// [EntityProperty("TipusId", EntityPropertyBaseType.ValueType, typeof(int /* DictionaryItem */), EntityCopyMethod.ShallowCopy)] [EntityDictionaryItemProperty("TipusId", "ErtMondatbankTipus", typeof(SDA.Kreta.Entities.ErtMondatbankTipus))] public virtual int /* DictionaryItem */ TipusId { get { return m_TipusId; } set { CheckModifyable(); if (m_TipusId == value) return; m_TipusId = value; FieldModified("TipusId", value); } } #endregion #region Importalt protected internal bool m_Importalt; /// /// Nincs definiálva megjegyzés. /// [EntityProperty("Importalt", EntityPropertyBaseType.ValueType, typeof(bool), EntityCopyMethod.ShallowCopy)] public virtual bool Importalt { get { return m_Importalt; } set { CheckModifyable(); if (m_Importalt == value) return; m_Importalt = value; FieldModified("Importalt", value); } } #endregion #endregion #region Asszociációkkal kapcsolatos dolgok protected internal virtual bool LoadByErtekelesMondatbankNyelvId(int id) { return m_DA.LoadByErtekelesMondatbankNyelvId(id, this); } #region ErtekelesMondatbank (*) -> Tantargy (0..1) protected internal int m_TantargyId = -1; /// /// A(z) Tantargy asszociáció végpontjának ID-ja. /// /// /// - Insert() előtt célszerű kitölteni /// - Update() nincs rá hatással: ezt a mezőt nem frissíti /// - LoadByID() felhozza ezt a mezőt /// public virtual int TantargyId { get { return InternalTantargyId; } set { InternalTantargyId = value; } } /// /// Ez egy külön bejárat a DA számára /// internal int InternalTantargyId { get { if (m_Tantargy != null) { return m_Tantargy.ID; } else { return m_TantargyId;// XXX az meg nem teljesen OK } } set { CheckModifyable(); if (m_TantargyId != value) { m_TantargyId = value; m_Tantargy = null; FieldModified("TantargyId", value); } } } /// /// Ez egy külön bejárat a DA számára /// internal void ModifyTantargy(Tantargy value) { m_TantargyId = value != null ? value.ID : -1; m_Tantargy = value; FieldModified("TantargyId", value != null ? (object)value.ID : DBNull.Value); } protected internal void SetTantargy(Tantargy value) { m_Tantargy = value; if (value != null) { m_TantargyId = value.ID; } else { m_TantargyId = -1; } } protected Tantargy m_Tantargy = null; ITantargy IErtekelesMondatbank.Tantargy { get { return Tantargy; } set { Tantargy = value as Tantargy; } } /// /// Nincs definiálva megjegyzés. /// /// /// Az UML modellben szereplő ErtekelesMondatbank és Tantargy entitások közötti asszociáció megvalósítása. /// [EntityProperty("Tantargy", EntityPropertyBaseType.Entity, typeof(Tantargy), EntityCopyMethod.ShallowCopy)] public virtual Tantargy Tantargy { get { if ((m_Tantargy == null) && (m_TantargyId != -1)) { SDA.Kreta.Entities.Tantargy partner = SDA.Kreta.Entities.Tantargy.GiveAnInstance(); partner.LoadByID(m_TantargyId); this.SetTantargy(partner); } // természetesen null-t adunk vissza, ha nem tudtunk felhozni semmit return m_Tantargy; } set { CheckModifyable(); if (value != null) { if ((m_Tantargy == null) || (value.ID != m_Tantargy.ID)) { if (value.State != EntityState.Initialized) { throw new EntityStateException(value.State); } if ((this.State != EntityState.New)) { // Lista van a másik oldalon, úgyhogy a lista DA-ját használjuk SDA.Kreta.Entities.Tantargy_ErtekelesMondatbank_DA da = new Tantargy_ErtekelesMondatbank_DA(value); da.AddItem(this); this.SetTantargy(value); } else { this.SetTantargy(value); } FieldModified("TantargyId", value.ID); } } else { // ki kell törölni a kapcsolatot az adatbázisban this.SetTantargy(null); UpdateAssociations(); FieldModified("TantargyId", DBNull.Value); } } } #endregion #region ErtekelesMondatbank (*) -> Intezmeny (1) protected internal int m_IntezmenyId = -1; /// /// A(z) Intezmeny asszociáció végpontjának ID-ja. /// /// /// - Insert() előtt célszerű kitölteni /// - Update() nincs rá hatással: ezt a mezőt nem frissíti /// - LoadByID() felhozza ezt a mezőt /// public virtual int IntezmenyId { get { return InternalIntezmenyId; } set { InternalIntezmenyId = value; } } /// /// Ez egy külön bejárat a DA számára /// internal int InternalIntezmenyId { get { if (m_Intezmeny != null) { return m_Intezmeny.ID; } else { return m_IntezmenyId;// XXX az meg nem teljesen OK } } set { CheckModifyable(); if (m_IntezmenyId != value) { m_IntezmenyId = value; m_Intezmeny = null; FieldModified("IntezmenyId", value); } } } /// /// Ez egy külön bejárat a DA számára /// internal void ModifyIntezmeny(Intezmeny value) { m_IntezmenyId = value != null ? value.ID : -1; m_Intezmeny = value; FieldModified("IntezmenyId", value != null ? (object)value.ID : DBNull.Value); } protected internal void SetIntezmeny(Intezmeny value) { m_Intezmeny = value; if (value != null) { m_IntezmenyId = value.ID; } else { m_IntezmenyId = -1; } } protected Intezmeny m_Intezmeny = null; IIntezmeny IErtekelesMondatbank.Intezmeny { get { return Intezmeny; } set { Intezmeny = value as Intezmeny; } } /// /// Nincs definiálva megjegyzés. /// /// /// Az UML modellben szereplő ErtekelesMondatbank és Intezmeny entitások közötti asszociáció megvalósítása. /// [EntityProperty("Intezmeny", EntityPropertyBaseType.Entity, typeof(Intezmeny), EntityCopyMethod.ShallowCopy)] public virtual Intezmeny Intezmeny { get { if ((m_Intezmeny == null) && (m_IntezmenyId != -1)) { SDA.Kreta.Entities.Intezmeny partner = SDA.Kreta.Entities.Intezmeny.GiveAnInstance(); partner.LoadByID(m_IntezmenyId); this.SetIntezmeny(partner); } // természetesen null-t adunk vissza, ha nem tudtunk felhozni semmit return m_Intezmeny; } set { CheckModifyable(); if (value != null) { if ((m_Intezmeny == null) || (value.ID != m_Intezmeny.ID)) { if (value.State != EntityState.Initialized) { throw new EntityStateException(value.State); } if ((this.State != EntityState.New)) { // Lista van a másik oldalon, úgyhogy a lista DA-ját használjuk SDA.Kreta.Entities.Intezmeny_ErtekelesMondatbank_DA da = new Intezmeny_ErtekelesMondatbank_DA(value); da.AddItem(this); this.SetIntezmeny(value); } else { this.SetIntezmeny(value); } FieldModified("IntezmenyId", value.ID); } } else { // ki kell törölni a kapcsolatot az adatbázisban this.SetIntezmeny(null); UpdateAssociations(); FieldModified("IntezmenyId", DBNull.Value); } } } #endregion #region ErtekelesMondatbank (*) -> Tanev (1) protected internal int m_TanevId = -1; /// /// A(z) Tanev asszociáció végpontjának ID-ja. /// /// /// - Insert() előtt célszerű kitölteni /// - Update() nincs rá hatással: ezt a mezőt nem frissíti /// - LoadByID() felhozza ezt a mezőt /// public virtual int TanevId { get { return InternalTanevId; } set { InternalTanevId = value; } } /// /// Ez egy külön bejárat a DA számára /// internal int InternalTanevId { get { if (m_Tanev != null) { return m_Tanev.ID; } else { return m_TanevId;// XXX az meg nem teljesen OK } } set { CheckModifyable(); if (m_TanevId != value) { m_TanevId = value; m_Tanev = null; FieldModified("TanevId", value); } } } /// /// Ez egy külön bejárat a DA számára /// internal void ModifyTanev(Tanev value) { m_TanevId = value != null ? value.ID : -1; m_Tanev = value; FieldModified("TanevId", value != null ? (object)value.ID : DBNull.Value); } protected internal void SetTanev(Tanev value) { m_Tanev = value; if (value != null) { m_TanevId = value.ID; } else { m_TanevId = -1; } } protected Tanev m_Tanev = null; ITanev IErtekelesMondatbank.Tanev { get { return Tanev; } set { Tanev = value as Tanev; } } /// /// Nincs definiálva megjegyzés. /// /// /// Az UML modellben szereplő ErtekelesMondatbank és Tanev entitások közötti asszociáció megvalósítása. /// [EntityProperty("Tanev", EntityPropertyBaseType.Entity, typeof(Tanev), EntityCopyMethod.ShallowCopy)] public virtual Tanev Tanev { get { if ((m_Tanev == null) && (m_TanevId != -1)) { SDA.Kreta.Entities.Tanev partner = SDA.Kreta.Entities.Tanev.GiveAnInstance(); partner.LoadByID(m_TanevId); this.SetTanev(partner); } // természetesen null-t adunk vissza, ha nem tudtunk felhozni semmit return m_Tanev; } set { CheckModifyable(); if (value != null) { if ((m_Tanev == null) || (value.ID != m_Tanev.ID)) { if (value.State != EntityState.Initialized) { throw new EntityStateException(value.State); } if ((this.State != EntityState.New)) { // Lista van a másik oldalon, úgyhogy a lista DA-ját használjuk SDA.Kreta.Entities.Tanev_ErtekelesMondatbank_DA da = new Tanev_ErtekelesMondatbank_DA(value); da.AddItem(this); this.SetTanev(value); } else { this.SetTanev(value); } FieldModified("TanevId", value.ID); } } else { // ki kell törölni a kapcsolatot az adatbázisban this.SetTanev(null); UpdateAssociations(); FieldModified("TanevId", DBNull.Value); } } } #endregion #region ErtekelesMondatbank (1) -> ErtekelesMondatbankNyelv (0..*) protected IAssociatedEntityCollection m_ErtekelesMondatbankNyelv = null; IReadOnlyList IErtekelesMondatbank.ErtekelesMondatbankNyelv => ErtekelesMondatbankNyelv.Cast().ToList(); /// /// Nincs definiálva megjegyzés. /// /// /// Az UML modellben szereplő ErtekelesMondatbank és ErtekelesMondatbankNyelv entitások közötti asszociáció megvalósítása. /// [EntityProperty("ErtekelesMondatbankNyelv", EntityPropertyBaseType.EntityCollection, typeof(IAssociatedEntityCollection), EntityCopyMethod.DeepCopy, "ErtekelesMondatbankId")] public virtual IAssociatedEntityCollection ErtekelesMondatbankNyelv { get { if (m_ErtekelesMondatbankNyelv == null) { m_ErtekelesMondatbankNyelv = new AssociatedEntityCollection( new ErtekelesMondatbank_ErtekelesMondatbankNyelv_DA(this) ); m_ErtekelesMondatbankNyelv.Load(); } return m_ErtekelesMondatbankNyelv; } } #endregion #endregion #endregion } }