-
Notifications
You must be signed in to change notification settings - Fork 1
/
Zugriff.cs
279 lines (249 loc) · 8.8 KB
/
Zugriff.cs
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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
using diNo.diNoDataSetTableAdapters;
using log4net;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Windows.Forms;
namespace diNo
{
public class Zugriff
{
private static Zugriff _Instance = null;
private static readonly log4net.ILog log = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
public string Username { get; private set; }
public Lehrer lehrer = null; // angemeldeter Lehrer
public List<Klasse> Klassen { get; private set; } // Liste der angezeigten Klassen
public List<Fach> eigeneFaecher { get; private set; }
private List<Kurs> _eigeneKurse = null; // alle Kurse, die der angemeldete Lehrer unterrichtet
public Klasse eigeneKlasse { get; private set; } // Verweis auf die Klasse, in der der User Klassenleiter ist
public Dictionary<int, Schueler> markierteSchueler { get; private set; } // Schüler, die z.B. beim NotenCheck eine Meldung erzeugt haben
public Vorkommnisart selectedVorkommnisart;
public int AnzahlSchueler { get; private set; }
// folgende Nachschlagelisten dienen v.a. der Performance, damit die Objekte insgesamt nur 1x im Speicher angelegt werden müssen!
public Repository<Schueler> SchuelerRep = new Repository<Schueler>(Schueler.CreateSchueler);
public Repository<Kurs> KursRep = new Repository<Kurs>(Kurs.CreateKurs);
public Repository<Klasse> KlassenRep = new Repository<Klasse>(Klasse.CreateKlasse);
public Repository<Lehrer> LehrerRep = new Repository<Lehrer>(Lehrer.CreateLehrer); // aktuell nicht verwendet
public Repository<Fach> FachRep = new Repository<Fach>(Fach.CreateFach);
public diNoDataSet.GlobaleKonstantenRow globaleKonstanten;
private GlobaleStringsContainer globaleStrings = new GlobaleStringsContainer();
public int Schuljahr { get { return globaleKonstanten.Schuljahr; } }
public Sperrtyp Sperre { get { return (Sperrtyp)globaleKonstanten.Sperre; } }
public int aktZeitpunkt { get { return globaleKonstanten.aktZeitpunkt; } }
public Halbjahr aktHalbjahr { get { return (globaleKonstanten.aktZeitpunkt <= 2 ? Halbjahr.Erstes : Halbjahr.Zweites); } }
public DateTime Zeugnisdatum { get { return globaleKonstanten.Zeugnisdatum; } }
public LesemodusExcel Lesemodus { get { return (LesemodusExcel)globaleKonstanten.LeseModusExcel; } }
public bool SiehtAlles { get; private set; }
public bool HatVerwaltungsrechte { get; private set; }
public bool RptDruck = false;
public bool IsFBKempten = false;
public bool IsTestDB { get; private set; }
private bool NurAktive = true;
private Zugriff()
{
try // macht ggf. Ärger im Designer
{
string con = ConfigurationManager.ConnectionStrings[1].ConnectionString;
IsTestDB = con.Contains("localhost");
}
catch
{
IsTestDB = false;
}
try
{
Cursor.Current = Cursors.WaitCursor;
Klassen = new List<Klasse>();
markierteSchueler = new Dictionary<int, Schueler>();
Username = System.Security.Principal.WindowsIdentity.GetCurrent().Name;
if (Username == "CLAUSPC\\Claus")
{
Username = "SN\\ckonrad";
}
Username = Username.ToLower();
int pos = Username.IndexOf("\\"); // Domänennamen abschneiden
Username = Username.Remove(0, pos + 1);
log.Debug("Anmeldeversuch mit Benutzer=" + Username);
var lehrerResult = new LehrerTableAdapter().GetDataByWindowsname(Username);
if (lehrerResult.Count > 0) lehrer = new Lehrer(lehrerResult[0]);
else
{
MessageBox.Show("Keine Zugriffsberechtigung für Benutzer "+ Username + "!\nBitte wenden Sie sich an einen Administrator.", "diNo", MessageBoxButtons.OK, MessageBoxIcon.Error);
Application.ExitThread();
Environment.Exit(1);
}
SiehtAlles = (this.lehrer.HatRolle(Rolle.Admin) || this.lehrer.HatRolle(Rolle.Sekretariat) || this.lehrer.HatRolle(Rolle.Schulleitung));
HatVerwaltungsrechte = lehrer.HatRolle(Rolle.Admin) || lehrer.HatRolle(Rolle.Sekretariat);
log.Debug("Anmeldung fertig.");
// LoadSchueler(); erst in Klassenansicht, wegen Parameter nurAktive
LoadFaecher();
log.Debug("Fächer geladen.");
LoadLehrer();
log.Debug("Lehrer geladen.");
LoadGlobaleKonstanten();
IsFBKempten = getString(GlobaleStrings.SchulPLZ) == "87435";
log.Debug("Globales geladen.");
}
catch (Exception e)
{
MessageBox.Show(e.Message + "\n" + e.StackTrace, "diNo", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
finally
{
Cursor.Current = Cursors.Default;
}
}
public static Zugriff Instance
{
get
{
if (_Instance == null)
{
_Instance = new Zugriff();
}
return _Instance;
}
}
public void Refresh()
{
Refresh(NurAktive);
}
public void Refresh(bool nurAktive)
{
NurAktive = nurAktive;
SchuelerRep.Clear();
KlassenRep.Clear();
KursRep.Clear();
Klassen.Clear();
markierteSchueler.Clear();
eigeneKlasse = null;
LoadSchueler(nurAktive);
}
public bool IstNurNormalerLehrer
{
get
{
return this.lehrer.rollen.Count == 0;
}
}
public void LoadSchueler(bool nurAktive = true)
{
log.Debug("Schüler werden geladen.");
diNoDataSet.SchuelerDataTable sListe;
int NotStatus = nurAktive ? 1 : 255; // Status=1 bedeutet abgemeldet,
var ta = new SchuelerTableAdapter();
if (SiehtAlles)
sListe = ta.GetDataByStatus(NotStatus); // alle Schüler reinladen
else if (IstNurNormalerLehrer)
sListe = ta.GetDataByLehrerId(NotStatus, lehrer.Id); // nur eigene Schüler
else
sListe = ta.GetDataByLehrerIdFPASem(NotStatus, lehrer.Id); // Lehrer mit erweiterten Rollen
AnzahlSchueler = sListe.Count;
log.Debug(AnzahlSchueler + " Schüler gefunden.");
foreach (var sRow in sListe)
{
Klasse k;
Schueler s = new Schueler(sRow);
SchuelerRep.Add(s); // Schüler ins Repository aufnehmen
if (KlassenRep.Contains(sRow.KlasseId))
{
k = KlassenRep.Find(sRow.KlasseId);
}
else
{
k = new Klasse(sRow.KlasseId);
Klassen.Add(k);
KlassenRep.Add(k);
}
s.getKlasse = k; // dem Schüler die Klasseninstanz zuweisen, damit die nicht jedesmal neu erzeugt werden muss!
k.Schueler.Add(s); // und umgekehrt dieser Klasse den Schüler hinzufügen
}
// alles sortieren
Klassen.Sort((x, y) => x.Bezeichnung.CompareTo(y.Bezeichnung));
foreach (var klasse in Klassen)
{
klasse.Schueler.Sort((x, y) => x.NameVorname.CompareTo(y.NameVorname));
if (klasse.KlassenleiterId == lehrer.Id) eigeneKlasse = klasse;
}
log.Debug("Schüler geladen.");
}
// lädt Fächer des angemeldeten Lehrers
public void LoadFaecher()
{
eigeneFaecher = new List<Fach>();
var ta = new FachTableAdapter();
diNoDataSet.FachDataTable dtFach = SiehtAlles ? ta.GetData() : ta.GetDataByLehrerId(lehrer.Id);
foreach (var fRow in dtFach)
{
Fach f = new Fach(fRow);
eigeneFaecher.Add(f);
FachRep.Add(f);
}
}
public List<Kurs>eigeneKurse
{ get {
if (_eigeneKurse==null) // ausgelagert um eine Endlosschleife zu vermeiden
{
_eigeneKurse = new List<Kurs>();
var kta = new KursTableAdapter();
var dtKurs = kta.GetDataByLehrerId(lehrer.Id);
foreach (var rKurs in dtKurs)
{
Kurs k = new Kurs(rKurs);
_eigeneKurse.Add(k);
KursRep.Add(k);
}
}
return _eigeneKurse;
}
}
public void LoadLehrer()
{
diNoDataSet.LehrerDataTable dt;
var ta = new LehrerTableAdapter();
dt = ta.GetData();
foreach (var r in dt)
{
LehrerRep.Add(new Lehrer(r));
}
}
private void LoadGlobaleKonstanten()
{
globaleKonstanten = new GlobaleKonstantenTableAdapter().GetData()[0];
}
public string getString(GlobaleStrings g)
{
return globaleStrings.getString(g);
}
public void RefreshGlobalesStrings()
{
globaleStrings.Refresh();
}
public bool HatRolle(Rolle typ)
{
return lehrer.HatRolle(typ);
}
}
public enum Sperrtyp
{
Keine = 0,
Notenschluss = 1
}
public enum LesemodusExcel
{
NurAktuelleNoten = 0,
Vollstaendig = 1
}
public enum Rolle
{
Lehrer = 0,
Admin = 1,
Schulleitung = 2,
Sekretariat = 3,
Seminarfach = 4,
FpAWirtschaft = 5,
FpASozial = 6,
FpATechnik = 7,
FpAUmwelt = 8
}
}