\documentclass[polish,edition=2024]{zpiday}

\usepackage{lipsum}
\usepackage{graphicx}
\usepackage{hyperref}
\usepackage{babel}
\usepackage{amsmath}
\usepackage{amssymb}
\usepackage{float}


\title{Innowacyjny system planowania wizyt i zarządzania kolejkami dla dziekanatu Wydziału Informatyki i Telekomunikacji Politechniki Wrocławskiej}
\acronym{UniQueue}
\supervisor{mgr inż. Krzysztof Stępniak}
\members{Dawid Glinkowski\orcid{0009-0008-4342-9663}\and Szymon Kielich\orcid{0009-0006-5459-2576} \and Rafał Bożek\orcid{0009-0006-6758-5199} \and Jakub Seredyński\orcid{0009-0003-9924-8793}}
\projectLogo{images/logo.pdf}

\begin{document}

\maketitle

\begin{abstract}
Celem projektu UniQueue było opracowanie alternatywnego, w pełni zdalnego systemu zarządzania kolejkami dla dziekanatu Wydziału Informatyki i Telekomunikacji Politechniki Wrocławskiej. System umożliwia studentom rezerwację wizyt na konkretną godzinę, zapisywanie się do dynamicznej kolejki, otrzymywanie powiadomień o jej aktualnym stanie oraz przewidywanym czasie wizyty. W ramach projektu zaimplementowano również intuicyjny interfejs dla pracowników dziekanatu oraz panel administracyjny, który pozwala na tworzenie raportów ze statystykami i zarządzanie systemem. Opracowany został także przystępny widok aktualnego stanu stanowisk i nadchodzących wizyt na wyświetlaczu przed dziekanatem. System minimalizuje czas oczekiwania, efektywnie zarządza ruchem oraz dostarcza aktualne informacje, co zwiększa efektywność komunikacji ze studentami. Projekt został dostosowany do wymagań uczelni, uwzględniając kwestie bezpieczeństwa i ochrony danych, a także integrację z istniejącą infrastrukturą uczelnianą, zapewniając możliwość dalszego rozwoju w kolejnych iteracjach. Wykorzystano nowoczesne technologie takie jak Kotlin z frameworkiem Spring oraz React.js z TypeScript. Projekt spotkał się z pozytywnym odbiorem ze strony interesariuszy, w tym Pani Kierownik Dziekanatu oraz osób odpowiedzialnych za wsparcie informatyczne na wydziale W4.
\end{abstract}

\section{Wstęp}

Dziekanat na uczelni wyższej pełni kluczową rolę w procesach administracyjnych związanych z obsługą studentów, takich jak odbiór dokumentów, przedłużenie ważności legitymacji studenckich czy składanie podań \cite{regulamin-studiow}. Aktualny system obsługi, oparty na fizycznym oczekiwaniu w kolejce przed wejściem, jest mało efektywny, co prowadzi do opóźnień i frustracji zarówno wśród studentów, jak i pracowników, a także wpływa na ruch pieszych w holu budynku C1. Dodatkowo, brak jasnej informacji o stanie kolejki oraz przewidywanym czasie oczekiwania utrudnia planowanie wizyt i efektywne zarządzanie czasem. Postępująca digitalizacja procesów administracyjnych w instytucjach edukacyjnych stawia przed uczelniami wyższymi wyzwania związane z usprawnieniem obsługi studentów. 

Efektywne zarządzanie ruchem petentów w dziekanatach ma kluczowe znaczenie dla poprawy jakości usług oraz satysfakcji studentów, \cite{digital-transformation-education}. W dobie rosnących oczekiwań wobec dostępności i szybkości realizacji usług administracyjnych, tradycyjne systemy obsługi stają się niewystarczające.

Projekt UniQueue ma na celu zautomatyzowanie procesów związanych z obsługą studentów, skrócenie czasu oczekiwania oraz zwiększenie efektywności pracy dziekanatu poprzez wdrożenie nowoczesnego systemu planowania wizyt i zarządzania kolejkami. Eliminuje on również konieczność korzystania z druku termotransferowego, co przyczynia się do większej dbałości o ekologię.

\subsection{Cele projektu}

Jednym z celów projektu UniQueue było usprawnienie procesu obsługi studenckiej poprzez wprowadzenie:

\begin{itemize}
    \item \textbf{Rezerwacji wizyt online}: Wprowadzenie możliwości rezerwacji wizyt na konkretną godzinę, uwzględniając:
    \begin{itemize}
        \item Godziny otwarcia dziekanatu (regularne i nieregularne),
        \item Przerwy tymczasowe i cykliczne,
        \item Zarezerwowane już terminy,
        \item Estymowany czas trwania wizyty.
    \end{itemize}
    \item \textbf{Dynamicznej kolejki biletowej}: Umożliwienie studentom bez rezerwacji zapisanie się do dodatkowej kolejki biletowej, z priorytetyzacją wizyt umówionych.
    \item \textbf{Cyfrowych tokenów}: Zastąpienie papierowych biletów cyfrowymi tokenami, eliminując konieczność fizycznego oczekiwania przed dziekanatem oraz minimalizując koszty druku. 
    \item \textbf{Zdalnych powiadomień}: Opracowanie modułu powiadomień o zbliżającej się wizycie poprzez e-mail oraz możliwość eksportu terminu do kalendarza.
    \item \textbf{Integracji z systemami uczelnianymi}: Autoryzacja 
    keycloak kontami AD wykorzystywanymi również w USOS/Active Directory, zapewniając jednolite logowanie i zgodność z polityką bezpieczeństwa uczelni \cite{keycloak}.
    \item \textbf{Bezpieczeństwa danych}: Minimalizacja przetwarzanych danych osobowych zgodnie z RODO, przetwarzając jedynie niezbędne informacje, czyli adres e-mail studenta \cite{rodo}.
    \item \textbf{Dostępności}: Zwiększenie dostępności systemu, w szczególności dla osób słabowidzących.
\end{itemize}

Projekt miał na celu nie tylko techniczne usprawnienie procesu, ale również zwiększenie zadowolenia użytkowników końcowych poprzez intuicyjny interfejs i łatwość obsługi, aby nie powodować dodatkowego obciążenia dla osób przyzwyczajonych do aktualnych rozwiązań \cite{dont-make-me-think}.

\begin{figure}[htbp]
    \centering
    \includegraphics[width=0.03\textwidth]{icons/Docker.pdf}
    \includegraphics[width=0.03\textwidth]{icons/Git.pdf}
    \includegraphics[width=0.03\textwidth]{icons/GitLab.pdf}
        \includegraphics[width=0.03\textwidth]{icons/Ubuntu.pdf}
    \includegraphics[width=0.03\textwidth]{icons/Gradle.pdf}
    \includegraphics[width=0.03\textwidth]{icons/HTML5.pdf}
    \includegraphics[width=0.03\textwidth]{icons/Java.pdf}
    \includegraphics[width=0.03\textwidth]{icons/JavaScript.pdf}
    \includegraphics[width=0.03\textwidth]{icons/JetBrains.pdf}
    \includegraphics[width=0.03\textwidth]{icons/Jira.pdf}
    \includegraphics[width=0.03\textwidth]{icons/Kotlin.pdf}
    \includegraphics[width=0.03\textwidth]{icons/Linux.pdf}
    \includegraphics[width=0.03\textwidth]{icons/Markdown.pdf}
    \includegraphics[width=0.03\textwidth]{icons/Nano.pdf}
    \includegraphics[width=0.03\textwidth]{icons/NGINX.pdf}
    \includegraphics[width=0.03\textwidth]{icons/NPM.pdf}
    \includegraphics[width=0.03\textwidth]{icons/PostgresSQL.pdf}
    \includegraphics[width=0.03\textwidth]{icons/React.pdf}
    \includegraphics[width=0.03\textwidth]{icons/Spring.pdf}
    \includegraphics[width=0.03\textwidth]{icons/SSH.pdf}
    \includegraphics[width=0.03\textwidth]{icons/Tailwind-CSS.pdf}
    \includegraphics[width=0.03\textwidth]{icons/TypeScript.pdf}
    \includegraphics[width=0.03\textwidth]{icons/Figma.pdf}
    \includegraphics[width=0.03\textwidth]{icons/Unified-Modelling-Language-(UML).pdf}
    \includegraphics[width=0.03\textwidth]{icons/Visual-Studio-Code-(VS-Code).pdf}
    \includegraphics[width=0.03\textwidth]{icons/YAML.pdf}
        \includegraphics[width=0.03\textwidth]{icons/Chrome.pdf}
    \caption{Technologie użyte w projekcie}
    \label{fig:technologie}
\end{figure}

\subsection{Wybrane technologie}

Do realizacji projektu wybrano następujące technologie:

\begin{itemize}
    \item \textbf{Backend}: Kotlin z wykorzystaniem Spring Framework, co zapewnia wydajność, skalowalność aplikacji oraz zgodność ze standardami branżowymi \cite{kotlin}, \cite{spring}.
    \item \textbf{Frontend}: React.js z TypeScript oraz Tailwind CSS, co umożliwia tworzenie nowoczesnych, responsywnych i dostępnych interfejsów użytkownika \cite{typescript}, \cite{tailwindcss}.
    \item \textbf{Baza danych}: PostgreSQL, oferująca zaawansowane możliwości przechowywania i zarządzania danymi oraz niezawodność \cite{postgresql}.
    \item \textbf{Autoryzacja}: Keycloak z protokołem OpenID Connect, zapewniający bezpieczne logowanie użytkowników i integrację z systemem SSO uczelni \cite{keycloak}.
    \item \textbf{Wyświetlanie informacji}: System Samsung MagicInfo na monitorze, umożliwiający centralne zarządzanie treściami wyświetlanymi na ekranach.
\end{itemize}

\section{Prace związane z tematem}

Przed przystąpieniem do realizacji projektu przeprowadzono analizę istniejących rozwiązań zarządzania kolejkami oraz literatury z zakresu teorii kolejek i zarządzania ruchem petentów, \cite{reduce-waiting-time}. Stwierdzono, że większość dostępnych systemów opiera się na statycznych rezerwacjach, nie uwzględniając dynamicznych zmian, takich jak opóźnienia, anulowanie wizyt czy zmienne obciążenie stanowisk. W odpowiedzi na te ograniczenia, UniQueue został zaprojektowany jako system dynamiczny, integrujący się z istniejącymi systemami uczelnianymi oraz dostosowujący się do bieżących warunków.

W ramach prac projektowych odbyły się liczne konsultacje z pracownikami dziekanatu w celu zidentyfikowania kluczowych potrzeb i wymagań. Na podstawie zebranych informacji ustalono priorytety funkcjonalności oraz dokonano wyboru technologii, które pozwolą na osiągnięcie zamierzonych celów \cite{simplicity-vs-complexity}.

Integracja z systemem Keycloak, wykorzystywanym przez Politechnikę Wrocławską jako metoda jednokrotnego logowania (SSO), umożliwia bezproblemowe włączenie UniQueue w istniejącą infrastrukturę uczelnianą \cite{keycloak}. Dzięki temu studenci mogą korzystać z systemu bez konieczności tworzenia dodatkowych kont, co zwiększa wygodę i bezpieczeństwo.

Na podstawie przeprowadzonego wywiadu wśród studentów stwierdzono, że zainteresowanie dedykowaną aplikacją mobilną jest niewielkie. W związku z tym zdecydowano się na zbudowanie responsywnej strony internetowej dostępnej zarówno na urządzeniach mobilnych, jak i stacjonarnych, co pozwala na zapewnienie dostępności dla wszystkich użytkowników z wielu platform. W celu wczesnej weryfikacji oczekiwań i wymagań, do stworzenia makiet interfejsów wykorzystano narzędzie Figma, co umożliwiło efektywne zbieranie opinii i dostosowywanie projektu do potrzeb użytkowników.

\section{Wyniki}

\subsection{Zaimplementowane funkcjonalności}

System UniQueue składa się z czterech głównych interfejsów:

\subsubsection{Interfejs dla studentów}

\begin{itemize}
    \item \textbf{Logowanie}: Możliwość logowania przez Active Directory uczelni lub wysyłanie próśb o wizytę dostarczaną bezpośrednio do pracownika dziekanatu poprzez formularz dla osób spoza uczelni.
    \item \textbf{Wybór typu wizyty}: Opcja zapisania się na wizytę na konkretną godzinę lub do dynamicznej kolejki biletowej.
    \item \textbf{Wybór tematu wizyty}: Na podstawie wybranego tematu system filtruje dostępne stanowiska obsługujące dany temat.
    \item \textbf{Zmiana języka}: Funkcjonalność zmiany języka interfejsu, z preferencjami zapisywanymi w bazie danych. Ustawienia językowe są propagowane do innych komponentów, takich jak eksportowane pliki ICS do kalendarza czy wybór odpowiedniego szablonu e-mail.
    \item \textbf{Responsywność i dostępność}: Strona jest skalowalna i responsywna, dostosowuje się do różnych urządzeń dzięki zaimplementowanemu mechanizmowi detekcji typu urządzenia.
    \item \textbf{Zarządzanie wizytami}: Na ekranie głównym wyświetlane są karty reprezentujące wizyty, którymi można zarządzać. W przypadku, gdy student jest już zapisany do kolejki, system uniemożliwia ponowne zapisanie się, prezentując informacje o aktualnej wizycie.
\end{itemize}

\begin{figure}[htbp]
    \centering
    \includegraphics[width=0.6\textwidth]{images/student.png}
    \caption{Interfejs dla studentów}
    \label{fig:interfejs-student}
\end{figure}

\subsubsection{Panel administracyjny}

\begin{itemize}
    \item \textbf{Zarządzanie stanowiskami}: Operacje CRUD (Create, Read, Update, Delete) dla stanowisk, w tym aktywacja, dezaktywacja oraz ukrywanie ich na ekranach dostępnych dla studentów.
    \item \textbf{Statystyki}: Moduł umożliwiający analizę danych dotyczących wizyt, obciążenia stanowisk oraz efektywności działania systemu, np. średnia dzienna liczba wizyt na stanowisko i średni czas trwania wizyty.
    \item \textbf{Zarządzanie tematami wizyt}: Definiowanie szczegółów tematów oraz przypisywanie ich do stanowisk.
    \item \textbf{Zarządzanie pracownikami}: Przypisywanie ról i uprawnień pracownikom korzystającym z systemu.
    \item \textbf{Konfiguracja systemu}: Ustalanie godzin otwarcia, przerw tymczasowych i cyklicznych.
\end{itemize}

\begin{figure}[htbp]
    \centering
    \includegraphics[width=0.5\textwidth]{images/admin.png}
    \includegraphics[width=0.5\textwidth]{images/admin2.png}
    \caption{Panel administracyjny}
    \label{fig:panel-admin}
\end{figure}

\subsubsection{Interfejs dla pracowników}

\begin{itemize}
    \item \textbf{Obsługa wizyt}: Rozpoczynanie, kończenie i pomijanie wizyt, ręczne dodawanie wizyt dla osób spoza uczelni.
    \item \textbf{Zarządzanie stanowiskiem}: Otwieranie i zamykanie stanowiska, planowanie przerw oraz przekierowywanie spraw do innych okienek.
    \item \textbf{Podgląd kolejki}: Monitorowanie stanu kolejki i zarządzanie jej przebiegiem w czasie rzeczywistym poprzez zapraszanie konkretnych petentów.
    \item \textbf{PWA}: umożliwia pobranie przypięcie do paska startowego i zapobiega przypadkowym zamknięciom.
    \item \textbf{Intuicyjny interfejs}: Interfejs został uproszczony, aby nie powodować dodatkowego obciążenia dla pracowników przyzwyczajonych do poprzedniego systemu. \cite{dont-make-me-think}
\end{itemize}

\begin{figure}[htbp]
    \centering
    \includegraphics[width=0.6\textwidth]{images/employee.png}
    \caption{Interfejs dla pracowników}
    \label{fig:interfejs-pracownik}
\end{figure}

\subsubsection{Interfejs na monitor}

\begin{itemize}
    \item \textbf{Wyświetlanie stanu kolejki}: Informacje o aktualnym stanie kolejek, nadchodzących wizytach oraz komunikaty dla studentów. Dane są aktualizowane w czasie rzeczywistym dzięki komunikacji przez WebSockety.
    \item \textbf{Moduł informacyjny}: Wyświetlanie treści informacyjnych oraz dostarczenie kodu QR do strony systemu w widocznym miejscu, co ułatwia i przyspiesza dotarcie do strony.
    \item \textbf{Dostępność}: Dostosowanie przystępności dla osób słabowidzących poprzez zwiększony kontrast i czytelność, co jest wymagane w przestrzeni publicznej.
\end{itemize}
\begin{figure}[htbp]
    \centering
    \includegraphics[width=0.5\textwidth]{images/tv.png}
    \caption{Monitor przed dziekanatem}
    \label{fig:tv}
\end{figure}
\begin{figure}[htbp]
    \centering
    \includegraphics[width=0.5\textwidth]{images/c4.png}
    \caption{Diagram architektury C4}
    \label{fig:c4}
\end{figure}
\subsection{Optymalizacje i wyzwania}

Podczas realizacji projektu zespół musiał sprostać różnym wyzwaniom:

\begin{itemize} 
    \item \textbf{Algorytmika}: Implementacja efektywnych algorytmów kolejkowania wizyt \cite{queueing-theory} do łączenia i znajdowania wolnych okien czasowych. Pierwszym krokiem w algorytmie jest określenie przedziałów czasu, w których stanowisko jest dostępne. Aby wyliczyć te przedziały trzeba najpierw podać okresy, które określają kiedy okienko jest czynne i odjąć od nich wszystkie przerwy, oraz inne wizyty. Można to wykonać w sposób naiwny, poprzez porównanie każdego dostępnego okresu z każdą przerwa, jednak złożoność takiego rozwiązania jest kwadratowa, czyli nieefektywna. 
Zastosowanym rozwiązaniem przez nas jest wpierw posortowanie osobno dostępnych godzin, oraz przerw według ich początków, oraz złączenie tych przedziałów które na siebie nachodzą i oznaczają to samo - przerwy z przerwami, godziny otwarcia z godzinami otwarcia. Poprzedni krok pozwala na porównywanie tylko tych dostępnych godzin i przerw, które na siebie nachodzą. Złożoność wyliczenia efektywnych godzin otwarcia wtedy jest liniowa, jednak wcześniej odbyło się sortowanie, więc końcowo złożoność wynosi \(O(n \log n + m \log m)\), gdzie \(n\) to liczba przedziałów otwarcia, a \(m\) to liczba przerw.
    \begin{figure}[H]
    \centering
    \includegraphics[width=0.7\textwidth]{images/alg.png}
    \caption{Wizualizacja problemu łączenia przedziałów}
    \label{fig:alg}
\end{figure}
    \item \textbf{Zmieniające się wymagania}: Przykładowo, początkowo zastosowano mechanizm autoryzacji mailowej dla osób spoza uczelni. Jednakże, na skutek uwag zgłoszonych przez interesariuszy, podjęto decyzję o zamknięciu tego rozwiązania i wprowadzeniu alternatywy w postaci formularza kontaktowego.
    \item \textbf{Ograniczenia infrastrukturalne}: Konieczność działania na starszych bibliotekach i użycia polyfilli ze względu na ograniczenia sprzętowe uczelni. Przykładowo, przeglądarka w playerze monitora obsługiwała jedynie standardy webowe do roku 2012, co wymagało zastosowania odpowiednich technologii \cite{postcss}.
    \item \textbf{Bezpieczeństwo}: Minimalizacja przetwarzanych danych osobowych do adresu e-mail oraz zgodność z RODO. Przeprowadzone zostaną audyty bezpieczeństwa i testy penetracyjne, potwierdzające skuteczność mechanizmów ochrony danych \cite{cybersecurity}.
    \item \textbf{Cache'owanie}: Przerwy z bieżącej daty są zapisywane w pamięci podręcznej (cache), który aktualizuje się w przypadku zmian w tabeli przerw, co przyspiesza dostęp do danych i odciąża bazę danych.
    \item \textbf{Kompatybilność przeglądarek}: Wykorzystanie PostCSS i zastąpienie nowoczesnych rozwiązań CSS starszymi odpowiednikami, co zapewniło kompatybilność z przeglądarkami o ograniczonej funkcjonalności \cite{postcss}.
    \item \textbf{Testowanie}: W każdym z czterech frontendów minimalne pokrycie testami to 80\% linii kodu, co zapewnia niezawodność systemu i ułatwia wykrywanie błędów.
\end{itemize}

\subsection{Integracje i wdrożenie}

System został zintegrowany z istniejącą infrastrukturą uczelni:

\begin{itemize}
    \item \textbf{Autoryzacja}: Aktualnie korzysta ze skonfigurowanego przez nas serwera autoryzacyjnego Keycloak, przygotowanego pod integrację z faktycznym systemem uczelnianym. Pozwala to na łatwe przejście do produkcyjnego środowiska uczelni.
    \item \textbf{Wyświetlanie informacji}: Integracja z systemem Samsung MagicInfo na monitorze, umożliwiającym centralne zarządzanie treściami i dostosowanie wyświetlanych informacji do potrzeb dziekanatu.
    \item \textbf{Wdrożenie}: System wdrożono na serwerze testowym, zabezpieczonym certyfikatem HTTPS, co zapewnia bezpieczną komunikację i zgodność z wymaganiami bezpieczeństwa uczelni.
    \item \textbf{Repozytorium}: Kod źródłowy zostanie umieszczony w prywatnym repozytorium uczelni, zgodnie z polityką bezpieczeństwa i procedurami uczelnianymi.
\end{itemize}

\section{Wnioski}

\subsection{Podsumowanie}

Projekt UniQueue zrealizował założone cele, tworząc zintegrowany i nowoczesny system zarządzania kolejkami dostosowany do specyficznych potrzeb dziekanatu Wydziału Informatyki i Telekomunikacji. System ten nie tylko zwiększa efektywność obsługi studentów i skraca czas oczekiwania, ale także poprawia komunikację pomiędzy dziekanatem a studentami oraz usprawnia pracę personelu administracyjnego.

Osiągnięte rezultaty potwierdzają, że wykorzystanie nowoczesnych technologii oraz bliska współpraca z użytkownikami końcowymi prowadzi do powstania rozwiązań spełniających realne potrzeby i oczekiwania. Projekt spotkał się z pozytywnym odbiorem ze strony interesariuszy, co świadczy o jego potencjale wdrożeniowym.

\subsection{Znaczenie i przyszłe implikacje}

UniQueue stanowi przykład udanego zastosowania nowoczesnych technologii informatycznych w sektorze edukacji wyższej. Wdrożenie systemu może przyczynić się do podniesienia jakości obsługi studentów, zwiększenia satysfakcji z usług administracyjnych oraz optymalizacji procesów wewnętrznych uczelni.

Ponadto, doświadczenia zdobyte podczas realizacji projektu mogą być wykorzystane przy opracowywaniu podobnych systemów w innych jednostkach uczelni lub w innych instytucjach publicznych. UniQueue może stać się inspiracją dla dalszych działań w kierunku cyfryzacji i automatyzacji procesów administracyjnych.

\subsection{Kierunki rozwoju}

Możliwe kierunki dalszego rozwoju projektu obejmują:

\begin{itemize}
    \item \textbf{Uczenie maszynowe}: Wykorzystanie algorytmów uczenia maszynowego do przewidywania czasu obsługi i automatycznej optymalizacji kolejek w zależności od natężenia ruchu \cite{dynamic-priority-scheduling}.
    \item \textbf{Rozszerzenie modułu powiadomień}: Wprowadzenie interaktywnych powiadomień SMS lub poprzez aplikację mobilną, co zwiększy dostępność informacji dla użytkowników.
    \item \textbf{Integracja z systemem USOS}: Automatyczne pobieranie danych studentów i harmonogramów zajęć, co usprawni proces rezerwacji wizyt i pozwoli na lepsze dostosowanie terminów.
    \item \textbf{Analiza danych}: Zaawansowane narzędzia analityczne do monitorowania wydajności systemu, satysfakcji użytkowników oraz identyfikacji obszarów do poprawy, umożliwiające ciągłe doskonalenie usług.
    \item \textbf{Integracja z kalendarzem}: Automatyczne dodawanie wizyt do kalendarza uczelnianego.
\end{itemize}

\subsection{Podziękowania}

Dziękujemy naszemu promotorowi, mgr inż. Krzysztofowi Stępniakowi, za cenne wskazówki przy konfiguracji testowego serwera autoryzacyjnego Keycloak, za umożliwienie testowania na monitorze z systemem MagicInfo oraz wsparcie w uzyskaniu certyfikatów HTTPS i domeny. Dziękujemy również zespołowi bezpieczeństwa informacji za możliwość przeprowadzenia testów naszej aplikacji oraz pracownikom dziekanatu za konstruktywne uwagi w trakcie realizacji projektu.

\begin{thebibliography}{99}

\bibitem{queueing-theory}
Donald Gross, \emph{Fundamentals of Queueing Theory}, 4th Edition, Wiley-Interscience, 2008.

\bibitem{reduce-waiting-time}
Wavetec, \emph{How to Reduce Waiting Time in Queues}: \url{https://www.wavetec.com/blog/queue-management/how-to-reduce-waiting-time-in-queues/}, 2021.

\bibitem{dynamic-priority-scheduling}
Wikipedia, \emph{Dynamic Priority Scheduling}: \url{https://en.wikipedia.org/wiki/Dynamic_priority_scheduling}, 2023.

\bibitem{dont-make-me-think}
Steve Krug, \emph{Don't Make Me Think: A Common Sense Approach to Web Usability}, 3rd Edition, New Riders Publishing, 2014.

\bibitem{keycloak}
Keycloak, \emph{Open Source Identity and Access Management}: \url{https://www.keycloak.org/}

\bibitem{spring}
Spring Framework: \url{https://spring.io/}

\bibitem{kotlin}
Kotlin Programming Language: \url{https://kotlinlang.org/}

\bibitem{typescript}
TypeScript: JavaScript With Syntax For Types: \url{https://www.typescriptlang.org/}

\bibitem{tailwindcss}
Tailwind CSS: \url{https://tailwindcss.com/}

\bibitem{postgresql}
PostgreSQL Database: \url{https://www.postgresql.org/}

\bibitem{rodo}
Rozporządzenie o Ochronie Danych Osobowych (RODO): \url{https://uodo.gov.pl/pl/404}

\bibitem{regulamin-studiow}
Politechnika Wrocławska, \emph{Regulamin Studiów}: \url{https://pwr.edu.pl/studenci/studia-1-i-2-stopnia/regulamin-studiow}

\bibitem{cybersecurity}
Future Processing, \emph{The Human Factor in Cybersecurity: The Greatest Challenge}: \url{https://www.future-processing.com/blog/the-human-factor-in-cybersecurity-the-greatest-challenge-part-i/}, 2020.

\bibitem{simplicity-vs-complexity}
LaunchNotes, \emph{Simplicity vs. Complexity in Product Development}: \url{https://www.launchnotes.com/blog/simplicity-vs-complexity-in-product-development-striking-the-right-balance}, 2021.

\bibitem{postcss}
PostCSS, \emph{A Tool for Transforming CSS with JavaScript}: \url{https://postcss.org/}

\bibitem{digital-transformation-education}
J. Wissema, \emph{Uniwersytet Trzeciej Generacji: Uczelnia XXI wieku}, Wydawnictwo Zante, 2009.

\end{thebibliography}

\end{document}