Development of an internal social media platform with personalised dashboards for students
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

prototyp.tex 4.4KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. \chapter{Prototyp}
  2. \label{ch:prototyp}
  3. Um die wissenschaftliche Frage nicht nur zu beantworte, sondern zu beweisen, wird in dieser Arbeit die Methode des Prototypings genutzt. Der Prototyp dient zum experimentellen Arbeiten und sichert eine strukturell fundierte Umsetzung des darauf folgenden Endprodukts. Der Fokus liegt dabei zunächst auf der Funktionalität der Anwendung (vgl. [Abr16]). Prototyping wird als bevorzugte Methode gewählt um schnell ein Ergebnis zu erzielen. Zudem soll aufbauend auf Diesem ein Produkt realisiert werden, das als Erweiterung in das Netzwerk der Hochschule eingebaut werden soll.
  4. \section{Forschungsdesign}
  5. Das Kapitel zeigt eine kurze Übersicht der Vorgehensweise und den Leitfaden an den sich die Implementierung des Prototyps anlehnt.
  6. Zu Beginn der Arbeit wird, des sich aus der Forschungsfrage ergebenden Problems analysiert und alle wichtigen Anforderungen erfasst. Dies bildet die Basis für alle weitern notwendigen Schritte um am Ende eine sinnvolle Lösung bereitstellen zu können. Die Recherche dient der Sammlung aller notwendigen Werkzeuge und gibt einen Überblick über verschiedene Hilfsbibliotheken. Das Implementieren der Applikation kann nun auf Basis der Recherche durchgeführt werden. Dazu gehört das Testen verschiedener Bibliotheken und Erweiterungen um die bestmögliche Lösung zu eruieren. Abschlie"send wird die Funktionalität des Prototypen getestet und evaluiert ob die Forschungsfrage ausreichend beantwortet wird. Handlungsempfehlungen und mögliche Funktionen zum Erweitern finalisieren die Arbeit.
  7. \begin{figure}[!h]
  8. \centering
  9. \includegraphics[width=0.8\textwidth]{figures/forschungsdesign}
  10. \caption{Forschungsdesign}
  11. \hfill
  12. \end{figure}
  13. \section{Organisation}
  14. Grundlegender Aufbau der Website, Verwaltung der Daten evlt nochmal auf Taggable-Manager (ManyToMany) ...
  15. \subsection{Datenmodellierung}
  16. Die Struktur der bereits bestehenden Datenbank im Django-Framework und die Erweiterungen dessen werden hier genauer erläutert. Zunächst wird auf die Ergänzung des bestehenden \textit {UserModel} eingegangen, nachdem veranschaulicht die Arbeit das \textit {PostModel} und abschlie"send werden die Zusammenhänge der Modelle dargestellt.
  17. \textbf{UserModel:}
  18. \begin{addmargin}[25pt]{0pt} Hierbei ist das Authentifizierungssystem von Django mit einem \textit{UserModel} bereits angelegt. Dies muss für den Prototyp um das Feld \glqq tags \grqq erweitert werden, sodass ein Benutzer folgende Felder aufweist (vgl. [Dja18]):
  19. \begin{itemize}
  20. \item username, fist\_name, last\_name, email, groups, user\_permissions, is\_staff, is\_active, is\_superuser, last\_login, date\_joined, tags
  21. \end{itemize}
  22. In models.py ist der \textit{CustomUser} dafür verantwortlich das neue Feld mit dem \textit{Default-User} zu verknüpfen. Durch das \textit{OneToOneField} (siehe Abbildung 3.2.) wird die Verbindung zum schon bestehenden Modell hergestellt.
  23. \begin{figure}[!h]
  24. \centering
  25. \includegraphics[width=1\textwidth]{figures/custommodelcode}
  26. \caption{CustomUserModel in models.py}
  27. \hfill
  28. \end{figure}
  29. \end{addmargin}
  30. \textbf{PostModel:}
  31. \textbf{Gesamtmodellierung:}
  32. \subsection{Verwaltung im Administrator-Back-end}
  33. In diesem Kapitel wird beschrieben wie das Administrations-back-end genutzt werden kann. Es ist jedoch zu beachten, dass die Applikation vorwiegend von Dozenten und Angestellten der Hochschule ohne Administratorrechte verwendet werden soll. Die gestaffelten Berechtigungen werden im Kapitel \glqq Berechtigung der User \grqq genauer beschreiben.
  34. Ein Django-Projekt bildet bereits beim Einrichten, \textit{per Default}, eine Administrator-Oberfläche um die Inhalte der Website kontrollieren zu können. Nach der Migration von den oben genannten Modellen wird diese erweitert. Nich zu vergessen sind die externen Tabellen der installierten Add-on's, die nach der Migration das Back-end expandieren.
  35. \subsection{Berechtigung der User}
  36. Welche Berechtigungen gibt es im Prototyp, welche werden vom Active Directory übernommen?
  37. \section{Funktionen}
  38. User Stories einbinden als Grafik
  39. \subsection{Verwalten}
  40. Posts erstellen, editieren und löschen
  41. (draft-list und post new für Mitarbeiter)
  42. \subsection{Abonnieren}
  43. Tags als eingeloggter User abonnieren und verwalten Front-end und Admin-Backend?
  44. \subsection{Filtern}
  45. Tag-map? Filtern nach abonnierten Posts, alle Posts und Posts mit bestimmten Tags
  46. \subsection{Benachrichtigung}
  47. Mail-Benachrichtigung wöchentlich