revisioned.tex 97 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359
  1. % standard
  2. \documentclass[a4paper,11pt]{article}
  3. \usepackage[utf8]{inputenc}
  4. \usepackage[ngerman]{babel}
  5. \usepackage{titlesec}
  6. \setcounter{secnumdepth}{5}
  7. \setcounter{tocdepth}{5}
  8. \titleformat{\paragraph} {\normalfont\normalsize\bfseries}{\theparagraph}{1em}{}
  9. \titlespacing*{\paragraph}
  10. {0pt}{3.25ex plus 1ex minus .2ex}{1.5ex plus .2ex}
  11. %for linkt page numbers in table f content
  12. \usepackage[linktocpage=true]{hyperref}
  13. \hypersetup{%
  14. unicode,pdffitwindow,
  15. pdfkeywords = {pdf, LaTeX, hyperref, thumbnails},
  16. pdfauthor = {Brüder Grimm},
  17. bookmarksopen = true,
  18. bookmarksnumbered = true,
  19. pdfcenterwindow=true,
  20. pdffitwindow = true,
  21. pdfstartview=FitBV,
  22. pdfcreator = {pdflatex},
  23. colorlinks=true, breaklinks=true, %
  24. urlcolor=magenta, % color for \url
  25. filecolor=cyan, % color for file
  26. linkcolor=black, % color for \ref
  27. citecolor=magenta, %color for \cite
  28. menucolor=darkblue,
  29. breaklinks=true,anchorcolor=green
  30. }
  31. % for the Glossar
  32. \usepackage{glossaries}
  33. \renewcommand*{\glstextformat}[1]{\textcolor{blue}{#1}}
  34. % für Listings für Java
  35. \usepackage{listings}
  36. %lstset{numbers=left, %
  37. % numberstyle=\tiny, %
  38. % numbersep=5pt, %
  39. % keywordstyle=\color{black}\bfseries, %
  40. % stringstyle=\ttfamily, %
  41. % showstringspaces=false, %
  42. % basicstyle=\footnotesize, %
  43. % captionpos=b}
  44. %lstset{language=java}
  45. % geometry
  46. \usepackage{geometry}
  47. \geometry{ headsep=20pt,
  48. headheight=20pt,
  49. left=21mm,
  50. top=15mm,
  51. right=21mm,
  52. bottom=15mm,
  53. footskip=20pt,
  54. includeheadfoot}
  55. % for using wrapfigures
  56. \usepackage{wrapfig}
  57. % header and footer
  58. \usepackage{datetime}
  59. \newdateformat{dmy}{%
  60. \THEDAY.~\monthname[\THEMONTH] \THEYEAR}
  61. \usepackage{fancyhdr}
  62. \pagestyle{fancy}
  63. \lhead{Noah Vogt \& Simon Hammer}
  64. \chead{}
  65. %\rhead{\dmy\today}
  66. \lfoot{}
  67. \cfoot{Gymnasium Kirschgarten}
  68. \rfoot{Seite \thepage}
  69. \renewcommand{\footrulewidth}{.4pt}
  70. % fix figure positioning
  71. \usepackage{float}
  72. % larger inner table margin
  73. \renewcommand{\arraystretch}{1.4}
  74. % no paragraph indent
  75. \setlength{\parindent}{0em}
  76. \usepackage{comment}
  77. %for spacing
  78. \usepackage{setspace}
  79. \renewcommand{\baselinestretch}{1.5}
  80. % graphics package
  81. \usepackage{graphicx}
  82. \usepackage{multicol}
  83. \usepackage{multirow}
  84. % use sans serif font
  85. \usepackage{tgheros}
  86. \usepackage{mathptmx}
  87. % don't even ask what this is for, I have no idea (noah)
  88. \usepackage{bm} %italic \bm{\mathit{•}}
  89. \usepackage[hang]{footmisc}
  90. \usepackage{siunitx}
  91. \usepackage[font={small,it}]{caption}
  92. \sisetup{locale = DE, per-mode = fraction, separate-uncertainty, exponent-to-prefix, prefixes-as-symbols = false, scientific-notation=false
  93. }
  94. \newcommand{\ns}[4]{(\num[scientific-notation=false]{#1}\pm\num[scientific-notation=false]{#2})\cdot\num[]{e#3}\si{#4}}
  95. % show isbn in bibliography
  96. % \usepackage{natbib}
  97. % for quotes
  98. \newenvironment{nicequote}[2]{
  99. \begin{center}\begin{quote}\textit{#1}\\\par\raggedleft--- {#2}
  100. }{
  101. \end{quote}\end{center}
  102. }
  103. \makeindex
  104. % using \say{} for easier quoting
  105. \usepackage{dirtytalk}
  106. % for code snippits
  107. \usepackage{listings}
  108. \usepackage{color}
  109. \definecolor{dkgreen}{rgb}{0,0.6,0}
  110. \definecolor{gray}{rgb}{0.5,0.5,0.5}
  111. \definecolor{mauve}{rgb}{0.58,0,0.82}
  112. \definecolor{background}{rgb}{0.36,0.36,0.36}
  113. % define java code snippit style
  114. %\lstset{frame=tb,
  115. %language=Java,
  116. %aboveskip=3mm,
  117. %belowskip=3mm,
  118. %showstringspaces=false,
  119. %columns=flexible,
  120. %basicstyle={\small\ttfamily},
  121. %numbers=none,
  122. %numberstyle=\tiny\color{gray},
  123. %keywordstyle=\color{blue},
  124. %commentstyle=\color{dkgreen},
  125. %stringstyle=\color{mauve},
  126. %breaklines=true,
  127. %breakatwhitespace=true,
  128. %tabsize=3
  129. %}
  130. \lstset{
  131. numbersep=3pt,
  132. keywordstyle=\color{blue},
  133. commentstyle=\color{dkgreen},
  134. stringstyle=\color{mauve},
  135. backgroundcolor = \color{background},
  136. breaklines=true,
  137. numbers=left,
  138. numberstyle=\scriptsize\color{black},
  139. frame=none,
  140. basicstyle = \small\ttfamily,
  141. breaklines=true
  142. breakatwhitespace=false,
  143. columns=flexible,
  144. xleftmargin=0.5cm,framesep=8pt,framerule=0pt,
  145. aboveskip=3mm,
  146. belowskip=3mm,
  147. }
  148. %\usepackage[backend=biber,style=apa]{biblatex}
  149. \usepackage[
  150. backend=biber,
  151. style=alphabetic,
  152. sorting=ynt
  153. ]{biblatex}
  154. \addbibresource{lit/refs.bib}
  155. %========================Glossaries======================
  156. \makeglossaries
  157. \newglossaryentry{copyleft}{
  158. name=Copyleft-Softwarelizenzen,
  159. description={Wie bei permissiven Lizenzen können Sie das Programm für JEDEN Zweck ausführen, den Quellcode lesen, ändern und die Änderungen zu veröffentlichen. Der Trick liegt jedoch in den restriktiven Redistributionsbedingungen: Sie dürfen das Programm NUR verbreiten, wenn Ihre Version die gleichen Freiheiten bietet. Dies geschieht in der Regel dadurch, dass die Weitergabe nur unter der gleichen Lizenz erlaubt ist. Der Name ``copyleft'' ist eine offensichtliche Anspielung auf das Wort ``Copyright'', da es versucht, dessen Konzept genau umzukehren: Anstatt die nahezu weltweit vorhandenen Kopierrechtsgesetze dazu zu verwenden, Nutzerfreiheiten einzuschränken, werden Copyleft-Lizenzen dazu eingesetzt diese zu bewahren und erweitern. \cite{kumar2011}}
  160. }
  161. \newglossaryentry{permissive}{
  162. name=Permissive Softwarelizenzen,
  163. description={Mit diesen Lizenzen hat man das Recht das Programm für JEDEN Zweck zu benutzen, den Source Code zu lesen, ändern und seine Änderungen zu veröffentlichen. Ihr Name kommt von der Tatsache, dass sie ``permissiv'' sind, wenn es um ihre wenigen Einschränkungen geht: Sie schränken die Verbreitung des Quellcodes nicht sehr stark ein und erlauben es oft, die Software unter JEGLICHEN Bedingungen weiterzugeben. Das bedeutet es ist möglich, den Fork eines permissiv lizenzierten Programms proprietär zu machen. Das bedeutet, dass Sie den Code nicht davor schützen, in anderen Projekten, selbst wenn diese proprietär sind, verwendet zu werden, ohne etwas zurückzugeben zu müssen. Das ist ein eindeutiger Nachteil und der Grund, warum manche Leute - meist auf Imageboards \cite{8chan.moe} - diese Lizenzen als ``Cuck Licenses'' beschimpfen, so werden sich auch reichlich kritisiert auf diversen technologiebezogenen Blogposts\cite{cuckblog}.}
  164. }
  165. \newglossaryentry{fsf}{
  166. name=Free Software Foundation,
  167. description={dt. \say{Stiftung für freie Software}, ist eine von Richard Stallman\cite{rms} gegründete Stiftung, ursprünglich mit dem Ziel die Entwicklung des GNU Projekts zu finanzieren, was mittlerweile erweitert und erstetzt wurde durch die allgemeine Förderung und Entwicklung von \gls{freie Software}.} % TODO: change somehow to "freier"
  168. }
  169. \newglossaryentry{freie Software}{
  170. name=Freie Software,
  171. description={engl. \say{free software}, ist nach der Definition der \gls{fsf} Software, welche die vier von ihnen definierten Grundfreiheiten garantiert: Das Verwenden der Software für jeden Zweck (keine willkürlichen, z.B. geografischen Einschränkungen etc.), der Quellcode darf ohne Vertraulichkeitsvereinbarungen oder ähnliche Einschränkungen von allen untersucht und gelesen werden, darf beliebig modifiziert und angepasst werden und alle modifizierten sowie nichtmodifizierten Versionen der Software dürfen weitergegeben werden.\cite{freesoftware}}
  172. }
  173. \newglossaryentry{vcs}{
  174. plural=VCS,
  175. name=Version Control Systems,
  176. description={Ein System oder Programm, welches die Versionierung des Quellcodes einer Software verwaltet.}
  177. }
  178. \newglossaryentry{git}{
  179. name=Git,
  180. description={Ein populäres Programm, welches die Funktion eines \Gls{vcs} übernimmt und auf einem lokalen Gerät benutzt und installiert wird. Zusätzlich kann es auch auf einem Server installiert werden um die eigenen lokalen Änderungen hochzuladen, neue fremde Änderungen herunterladen und Änderungen zu synchronisieren, um mit mehreren Leuten kollaborativ an einem Softwareprojekt arbeiten zu können.\cite{git}}
  181. }
  182. \newglossaryentry{github}{
  183. name=GitHub,
  184. description={Die grösste, global öffentlich zugängliche Plattform für Hosting von Git Repositories. \cite{github}}
  185. }
  186. \newglossaryentry{branch}{
  187. name=branch,
  188. plural=branches,
  189. description={Beim \Gls{vcs} \Gls{git} handelt es sich hier um Eine abgetrennte Arbeitsachse, welche erlaubt verschieden Aufgaben in der Softwareentwicklung wie z.B. das Programmieren neuer Features getrennt oder parallel voneinander zu entwickeln um sie später wieder zusammenzuführen in einem \Gls{merge}. Weiterführend: \cite{branch}.}
  190. }
  191. \newglossaryentry{merge}{
  192. name=Git Merge,
  193. plural=mergen,
  194. description={Beim \Gls{vcs} \Gls{git} unterschiedliche \Gls{branch}es zusammenzuführen in einen neuen, ähnlich dem Reissverschlussprinzip bei der zwei Strassenspuren in eine einzige zusammengeführt werden \cite{github}.}
  195. }
  196. %TODO: anständige quelle finden, Noah: why ????
  197. \newglossaryentry{ide}{
  198. name=IDE,
  199. plural=Integrated Development Environment,
  200. description={Ein Programm, welches den Programmierer beim Programieren unterstütz indem es z.b textvorschläge gibt oder das compilen des codes übernimmt.}
  201. }
  202. \newglossaryentry{android-studio}{
  203. name=Android Studio,
  204. description={Ein von Google entwickeltes \gls{ide}, welches auf dem Editor IntelliJ IDEA basiert und für die Android Entwicklung spezialisiert wurde. \cite{android-studio}}
  205. }
  206. \newglossaryentry{adb}{
  207. name=Android Debugging Bridge,
  208. description={Eine Software mit verschiedenen Tools, mit der man mit einem physischen Android Gerät interagieren kann, welches per USB-Anschluss an den PC angeschlossen ist. Man kann z.B. Apps des angeschlossenen vom Computer aus löschen und neue installieren, Screenshots aufnehmen, oder Dateien transferieren.}
  209. }
  210. \newglossaryentry{emulator}{
  211. name=Emulator, plural=Emulatoren,
  212. description={Ein Emulator ist ein Programm, welches ein Gerät oder Betriebssystem simuliert, sodass man es innerhalb eines anderen Betriebssystems laufen lassen kann.}
  213. }
  214. \newglossaryentry{apk}{
  215. name=APK,
  216. description={APK steht für \say{Android Package}, welches dem Format entsprechen soll, in dem Software dem Android Betriebssystem entwickelt wird.}
  217. }
  218. \newglossaryentry{compiler}{
  219. name=Compiler,
  220. description={Ein Programm, welches den vom Menschen lesbaren Quellcode in die vom Computer ausführbare Form bringt.}
  221. }
  222. \newglossaryentry{sql}{
  223. name=SQL,
  224. description={Kurz für \say{Structure Query Language}, eine Sprache um einer Datenbank Befehle oder Anweisungen zu übermitteln. \cite{sqlInfo}}
  225. }
  226. %TODO: Quelle simon, Noah: @who?
  227. \newglossaryentry{sqlite}{
  228. name=SQLite,
  229. description={SQLite unterstütz viele Funktionen von SQL hat aber keinen eigene Serverprozesse und ist deshalb leichter an Systemressourcen.}
  230. }
  231. \newglossaryentry{library}{
  232. name=Library,
  233. plural=libraries,
  234. description={Eine Library (dt. Bibliothek) kann ist eine Sammlung von Programmen, Programmfunktionen und Skripts welche in einem anderen Programm verlinkt werden, um gewisse generische Funktionalitäten nicht jedes mal neu entwickeln zu müssen oder unnötig ein Klon davon in den Quellcode einfügen zu müssen. \cite{library}}
  235. }
  236. \newglossaryentry{server}{
  237. name=Server,
  238. description={Damit beschreibt man in der IT hauptsächlich diese beiden Dinge: Ein Programm, welches die ganze Zeit läuft, damit ein anderes Programm mit diesem interagieren kann, was dynamische Änderungen erlaubt. Die andere Bedeutung ist ein dedizierter Computer, auf welchem Serverprozesse laufen, beispielsweise ein Mailserver oder eine Website.}
  239. }
  240. \newglossaryentry{database}{
  241. name=Database,
  242. description={dt. Datenbank, ist ein System welches Daten effizient speichern und abrufbar machen kann.}
  243. }
  244. \newglossaryentry{query}{
  245. name=Query,plural=queries,
  246. description={Eine Anfrage inklusive Wert, welche an ein Programm, z.B. eine Datenbank gesendet werden.}
  247. }
  248. \newglossaryentry{entity}{
  249. name=Entity,plural=entities,
  250. description={Eine Entity speichert Informationen über ein Objekt ab. Z.b über eine Person wird ihr Alter und name gespeichert. Die Person ist das Objekt.}
  251. }
  252. \newglossaryentry{list}{
  253. name=List,
  254. description={Ein Datentyp welcher erlaubt mehrere einzelne Variablen aneinander zu ketten, was beispielsweise etwa so dargestellt werden kann: \texttt{List<Integer> = \{1, 3, 4, 5}\}.}
  255. }
  256. \newglossaryentry{recyclerview}{
  257. name=Recyclerview,
  258. description={Eine stark anpassbare ,durchscrollbare, dynamisch veränderbare Liste von die verschiedene Views und (Text-)Objekten.}
  259. }
  260. \newglossaryentry{view}{
  261. name=View,
  262. description={Im Kontext der Android Entwicklung ist eine View ein rechteckiges Fenster, welches auf dem Display, wobei es diverse Inhalte wie Buttons, Switches oder Text enthalten kann, angezeigt wird. \cite{view}}
  263. }
  264. \newglossaryentry{user interface}{
  265. name=User Interface,
  266. description={Oberbegriff für die ganze graphische Oberfläche, bestehend aus Inhalten wie Buttons, Text, Bildern mit welcher der Nutzer interagieren kann durch tippen, scrollen oder Tastatureingaben in Textfeldern.}
  267. }
  268. \newglossaryentry{email client}{
  269. name=Email Client,
  270. description={Ein Programm, welches Emails verwaltet, sendet und emphängt.}
  271. }
  272. \newglossaryentry{fragment}{
  273. name=Fragment,
  274. description={Eine Klasse, welche ein Teil des UI ist und sein eigenes Layout, sein eigener Lebenszyklus und seinen eigenen Input hatt. \cite{fragment}}
  275. }
  276. \newglossaryentry{observer}{
  277. name=Observer,
  278. description={Informiert die Klasse über ein änderung bei eine beobachtbaren Objekt. \cite{observer}}
  279. }
  280. \newglossaryentry{livedata}{
  281. name=LiveData,
  282. description={Eine Klasse, welche beobachtbar in einem gewissen Lebenszyklus ist und Daten speichern kann. \cite{livedata}}
  283. }
  284. \newglossaryentry{email writer}{
  285. name=Email Writer,
  286. description={Der Teil der App in welchem Emails entworfen werden könne.}
  287. }
  288. \newglossaryentry{intent}{
  289. name=Intent,
  290. description={Ein Intent kann genutz werden um Daten von Activity zu Activity zu schicken. \cite{intent}}
  291. }
  292. \usepackage{csquotes}
  293. %==================Commands===============================
  294. %Signatur
  295. \newcommand{\doublesignature}[3][Simon Hammer]{%
  296. \parbox{\textwidth}{
  297. \vspace{2cm}
  298. \centering Datum: #3 \\
  299. Ort: Basel-Stadt \\
  300. \parbox{7cm}{
  301. \centering
  302. \rule{6cm}{1pt}\\
  303. #1
  304. }
  305. \hfill
  306. \parbox{7cm}{
  307. \centering
  308. \rule{6cm}{1pt}\\
  309. #2
  310. }
  311. }
  312. }
  313. %==================begin document==========================
  314. \begin{document}
  315. \begin{titlepage}
  316. \centering
  317. \vspace{5cm}
  318. {\slshape\large snailmail \par}
  319. \vspace{0.1cm}
  320. {\huge\bfseries Eine Email-Client-App entwickeln \par}
  321. \vspace{0.5cm}
  322. {\Large eine Maturarbeit von \par}
  323. {\Large Noah Vogt \& Simon Hammer \par}
  324. {\Large aus der Klasse 4cg \par}
  325. \vspace{0.5cm}
  326. %{\Large Victor Yakhontov \& Daniel Bühler \par }
  327. \begin{figure}[H]
  328. \centering
  329. %\includegraphics[width=.8\textwidth]{../logo/version3d.png}
  330. \includegraphics[width=.7\textwidth]{../logo/version3d.png}
  331. \end{figure}
  332. \vspace{0.5cm}
  333. {\Large Betruungslehrkraft: Victor Yakhontov \par }
  334. {\Large Koreferent: Daniel Bühler \par}
  335. \vspace{0.5cm}
  336. {\large Geschrieben im Jahr 2021 \par}
  337. {\large Gymnasium Kirschgarten, Basel, CH \par}
  338. \end{titlepage}
  339. \tableofcontents
  340. \pagebreak
  341. \section{Vorwort}
  342. Die Informatik ist heutzutage all gegenwärtig. Sie umfasst schon einen sehr grossen Teil unseres Alltags und der Anteil wächst immer weiter. Da ist es Sinnvoll sich
  343. eine Zeit mit der Informatik beschäftigt zu haben. Und zur Informatik gehört natürlich auch das Programmieren. Die Fähigkeit zu Programmieren wird uns sicher in der
  344. Zukunft behilflich sein. Auch wenn es nur darum geht einfache Prozesse im eigenen Alltag zu automatisieren, wird es hilfreich sein.
  345. Noah hatte schon länger grosses Interesse am Programmieren. Ich hingegen begann Interesse an den Programmiersprachen zu entwickeln als wir im Unterricht
  346. Python lernten. Als die Zeit kam sich für ein Maturthema zu entscheiden, war für mich klar, ich würde eine App programmieren. Anfangs ging es mir darum eine
  347. nützliche App zu kreieren, welche ich selbst verbessern kann und meine Bedürfnisse perfekt abdeckt.
  348. Zu diesem Zeitpunkt störte es mich, dass es keine effiziente Edubs-Mail-App fürs Smartphone gab und ich wollte Sie selbst kreieren.
  349. Da ich aber wusste, dass ich mich nicht so gut auskenne, fragte ich bei Noah nach, wie er die Idee findet und ob er vielleicht mit mir diese Arbeit
  350. angehen würde.
  351. Da Noah schon länger keinen \gls{email client} auf seinem Smartphone installiert hatte, weil ihm keine der gerade verfügbaren Apps gefiel und er den Gedanke
  352. schon länger hatte, sich seinen eigene Email Client zu programmieren, traf sich das sehr gut und wir konnten uns einigen.
  353. Wir haben uns zusammen getan um einen Email Client zu programmieren, der auch auf älteren Geräten ohne Schwierigkeiten läuft. Schliesslich hatten wir beide
  354. eher ältere Smartphones, ebenfalls sollte die App Open Source sein.
  355. Dafür sprechen viele praktische und philosophisch-ethische Gründe, aber dazu später mehr.
  356. Bei den Funktionen waren wir uns auch einig und wir hatten eine Menge an Ideen, um einen vollumfänglichen Email Client zu erstellen. Der Name \textit{snail mail} ist in einem
  357. Brainstorming aus der wörtlichen Übersetzung von \textit{Schnecken Post} entstanden. Gedanke zu dem Design machten wir uns zuerst nicht,
  358. da wir es schlicht und funktional halten wollten.
  359. Wir hatten beide eine gewisse Vorstellung unserer App vor uns und ob wir diese erreicht haben wird sich im laufe dieser Arbeit herausstellen. \\
  360. {\setstretch{1.0}
  361. \textit{Hiermit erklären wir, die vorliegende Maturaarbeit selbst verfasst (sowie das in der Arbeit
  362. beschriebene Produkt selbst gestaltet bzw. das beschriebene Projekt selbst durchgeführt) zu
  363. haben. Stellen, die wörtlich oder sinngemäss anderen Veröffentlichungen oder anderen Quellen,
  364. insbesondere dem Internet, entnommen sind, sind als solche eindeutig und wiederauffindbar
  365. erkenntlich gemacht. Alle diese Quellen sind vollständig und abschliessend im
  366. Literaturverzeichnis aufgeführt. Die vorliegende Arbeit ist in gleicher oder ähnlicher Form noch
  367. nicht veröffentlicht. } \\
  368. \doublesignature{Noah Vogt}{18.10.21}
  369. }
  370. \newpage
  371. \section{Einleitung}
  372. \subsection{Arbeitskonzept}
  373. \subsubsection{Quellcode Modell}
  374. % TODO: too long, short a little (insg. ?)
  375. Um ein Programm zu programmieren, werden menschenlesbare Instruktionen in ein oder mehrere Textdateien geschrieben,
  376. die dann in Sprache, welche die Computerhardware interpretieren und ausführen kann, übersetzt.
  377. \begin{figure}[H]
  378. \centering
  379. \includegraphics[width=.8\textwidth]{media/Source2Executable.jpg}
  380. \caption{Quellcode (engl. ``source code'') wird in ausführbaren Maschinencode umgewandelt \cite{stallman2002}}
  381. \end{figure}
  382. Hier als Beispiel der Source Code zu einem simplen Programm \textit{helloworld.c} geschrieben in der Programmiersprache C, welches in der Konsole ein simples \say{Hello World} ausgibt:
  383. \lstset{language=C}
  384. \begin{lstlisting}
  385. #include <stdio.h>
  386. int main() {
  387. printf("Hello World\n");
  388. return 0;
  389. }
  390. \end{lstlisting}
  391. %TODO: idk mir sötte grundlegendi sache ned erkläre
  392. Ein Teil der kompilierten, ausführbaren Version des Programmes \textit{./helloworld} sieht aber so aus:
  393. \begin{lstlisting}
  394. 0011010001100000010111110110111101101100011001110110001001101111011011000110000101100100
  395. 1111101101111011101000111001101110010011000010101111100000000000000110100011100000111100
  396. 1101010110001100000000011011010110111101101100011100000111010001100101011001000110010100
  397. 0000010111001011111000000000000000000000011010010000000011001000101111101011111011011110
  398. 1100011001110110001001101111011011000110000101100100010111110110111101110100011100110111
  399. 0000000000000001101001001000001100001010111110111100001110101011001100101111101101110011
  400. \end{lstlisting}
  401. Wie zu sehen ist, geht bei diesem Prozess des Kompilierens die Lesbarkeit für den Menschen grösstenteils verloren. Um ein Programm ausführen können braucht der Nutzer also keinen Zugang zum Quellcode. Doch wenn er wissen will, was das Programm macht - es könnte ihn ausspionieren oder andere bösartige Dinge im Hintergrund machen - oder einfach das Programm verändern will, braucht er unbedingt Zugang zum Source Code.\\
  402. \subsubsection{Lizensierung}
  403. % ENG: The differences of different source code models and their licenses have been already discussed in this paper (?). The reason the GNU General Public License Version 3 (short: GPL v3) was chosen because it is one of the most popular and strongest copyleft licenses that suits the application.
  404. Grundsätzlich gibt es die Unterscheidung zwischen freien Softwarelizenzen und proprietären Softwarelizenzen. Doch auch bei Open Source Software gibt es verschiedene Lizenzmodelle welche gewählt werden können. Diese lassen sich ziemlich gut in zwei Kategorien unterteilen: in \gls{permissive} und in \gls{copyleft}.\\
  405. Die Autoren dieser App halten Copyleft Software in ethischer und praktischer Hinsicht für die beste Wahl bei der Softwarelizensierung, wehalb entschieden wurde für dieses Softwareprojekt die \textit{GNU General Public License (GPL) Version 3} \cite{GPLv3} der \gls{fsf} zu verwenden, da diese eine der bekanntesten, strengsten und somit effektivsten Copyleft-Lizenzen ist.
  406. \subsubsection{Philosophie (suckless)}
  407. \begin{nicequote}{Many (open source) hackers are proud if they achieve large amounts of code, because they believe the more lines of code they've written, the more progress they have made. The more progress they have made, the more skilled they are. This is simply a delusion.}{https://suckless.org Manifest \cite{suckless}}
  408. \end{nicequote}
  409. % ENG: (Nowadays) a lot of Open Source Developers pride themselves in writing software with much features that cater to the non-technical enduser. This results in having a large codebase, which gets bigger and bigger with every release. This makes it harder to maintaining the ever growing codebase, more and more bugs occurs, security and (most importantly) performance struggles under these conditions. This degrades the quality of software technology as it is the mainstream narrative to ``save time and money''.\\
  410. Eine grosse Anzahl Open-Source-Entwickler sind stolz darauf, Software mit scheinbar möglichst vielen Features zu schreiben. Dies führt zu einer grossen Codebasis, die mit jedem Release grösser und grösser wird. Dadurch wird es schwieriger, die ständig wachsende Codebasis zu unterhalten, es treten immer mehr Fehler auf, die Sicherheit und - vor allem - die Leistung leidet unter diesen Bedingungen. Dies führt zu einer Verschlechterung der Code-Qualität der Software, da es die gängige Praxis ist, ``Zeit und Geld zu sparen''. \cite{bhattacharya2020}\
  411. % ENG: This is where the \textit{suckless philosophy} comes in place: It aims at making software with simplicity in mind: Less source lines of code to not render the project unmaintainable in similar way as mentioned above. This way of programming is a lot more difficult, but the struggle is most of the time worth it. This coding philosophy also incentives (quality) code rewrites - which happens a lot less with bloated software counterparts - that gives the user more alternatives to choose from.
  412. Hier kommt die Philosophie des \textit{Suckless Philosphy} ins Spiel: Sie zielt darauf ab, Software mit Hinblick auf Einfachheit zu entwickeln: Weniger Quellcodezeilen, um das Projekt nicht in ähnlicher Weise unüberschaubar zu machen, wie oben erwähnt. Diese Art zu programmieren ist viel schwieriger, aber der Aufwand ist es meistens wert. Diese Programmierphilosophie bietet auch Anreize für das qualitativ hochwertige Neuschreiben von Programmen, was bei der sogenannten \textit{Bloated Software \cite{bhattacharya2020}} viel seltener vorkommt, dazu gibt es dem Benutzer mehr Alternativen zur Auswahl.
  413. \newpage
  414. \paragraph{Hintergründe, Technologisch, UNIX, KISS}
  415. Die \textit{Suckless Philosophie} ist aber längst nicht die erste Philosophie im Softwarebereich welche auf Simplizität beruht; so beispielsweise eine beliebte Definition der altbekannten \textit{UNIX Philosphy}:
  416. \begin{nicequote}{This is the Unix philosophy. Write programs that do one thing and do it well. Write programs to work together. Write programs that handle text streams, because that is a universal interface.}{A Quarter Century Of UNIX \cite{salus1994}}
  417. \end{nicequote}
  418. Bekannt ist auch das \textit{KISS Prinzip}: \say{Keep it simple, stupid}. Dieses Prinzip kommt ursprünglich vom U.S. Admiral Stroop, der das \say{Project KISS} 1960 ins Leben gerufen hatte, welches die Verlässlichkeit verbessern und die Kosten für amerikanische Militärausrüstungen senken soll. \cite{dalzell2009} Gerne wird diese Prinzip zitiert, wenn jemand der Meining ist, unnötige Komplexität sei vorhanden in einem Softwareprojekt.
  419. \begin{comment}
  420. \section{Programmier-Tools}
  421. \subsection{Hardware}
  422. \subsubsection{Smartphones}
  423. % ENG: We used different Models of Smartphones running different variants of the android operating system to install and test our app. It was also used to compare it and benchmark it against our competition (the already existing mail clients on android).
  424. Es wurden verschiedene Smartphone Modelle genutzt um die App auf verschiedenen Androidversionen testen zu können. Sie wurden auch genutzt um unsere App mit der Konkurrenz zu vergleichen und die
  425. Konkurrenz zu begutachten.
  426. \subsubsection{PC / Laptop}
  427. % ENG: The usage of computers was to the actual work of creating the software, documentation and the text of this paper (?).
  428. Der Gebrauch von Computern wurden gemacht um die Software, die Dokumentation und dieses Maturschreiben zu erstellen.
  429. \subsection{Software}
  430. Aufgrund dessen, dass ein umfassendes Programm entstehen soll, wird auch Gebrauch von einigen anderen Programmen, Bibliotheken und sonstigen Tools gemacht. In den nachfolgenden Seiten wird beschrieben welche Programme genutzt werden, wieso diese ausgewählt wurden und wie der Umgang mit ihnen war.
  431. \subsubsection{Programme}
  432. \paragraph{Version Control System}
  433. % ENG: For developing software above a certain level of complexity, it helps to use a so called VCS (Version Control System). This is a software/system that manages the versioning of software. This is useful so you don't have to for example create MANUALLY a new folder for every new version and copy the code with the new changes in there. This would be not very user friendly, wasteful of disk space and overall very inefficient. These systems also make it easy to synchronise projects to a remote server to allow for easy collaboration on multiple devices and for different developers.\\
  434. Für die Entwicklung von Software ab einer gewissen Komplexität ist es hilfreich, ein so genanntes VCS (Version Control System) zu verwenden. Dabei handelt es sich um eine Software/System, das die Versionierung von Software verwaltet. Das ist nützlich, damit man nicht für jede neue Version manuell einen neuen Ordner anlegen und den Code mit den neuen Änderungen dorthin kopieren muss. Das wäre nicht sehr benutzerfreundlich, würde Speicherplatz verschwenden und wäre insgesamt sehr ineffizient. Diese Systeme erleichtern meist auch die Synchronisierung von Projekten mit einem Webserver, um eine einfache Zusammenarbeit auf mehreren Geräten und für verschiedene Entwickler zu ermöglichen.\\
  435. \subparagraph{Git}
  436. % ENG: It also allow for additional advanced features like branching a repository, which means developing multiple features separately from each other to then later merge the changes together, when each of the features are working as expected.
  437. Git ist das für dieses Projekt verwendete VCS. Es ist das meistverbreitete Tool unter Softwareentwicklern und dabei ermöglicht auch zusätzliche fortgeschrittene Funktionen wie das \textit{Branching} eines Repositorys, was bedeutet, dass mehrere Funktionen getrennt voneinander entwickelt werden, um dann später die Änderungen zusammenzuführen, wenn jede der Funktionen wie erwartet funktioniert. So etwas sieht der \textit{Git Flow} generell und auch in diesem Projekt aus:
  438. \begin{figure}[H]
  439. \centering
  440. \includegraphics[width=.8\textwidth]{media/gitflow.png}
  441. \caption{parallele Featureentwicklung mit Git \cite{gitflowBlog}}
  442. \end{figure}
  443. \subparagraph{Github}
  444. % ENG: This is our remote git server. But is is more than just a git server, it is a popular platform with over 50 million (software) repositories that people search to find interesting software. So we can use this to make our software more searched and popular (but this is not considered of great importance).
  445. Das ist der hier verwendete Git Server. Aber eigentlich es mehr als nur ein einfacher Git-Server, denn es ist auch eine populäre Plattform mit über 238 Millionen Software Repos (Stand September 2021 \cite{githubRepoQuery}) welche gerne durchsucht werden, um interessante Software zu finden. Das kann also benutzt werden dieses Softwareprojekt berühmter zu machen, was aber nicht von hoher Wichtigkeit erachtet wird.
  446. \paragraph{IDE}
  447. % eng IDE stands for ``Integrated Development Environment''. This means a program where the coder edits, debugs the code. It provides more features than just editing text, but also advanced autocompletion features and warnings/suggestions that the programmer should do something differently because of various reasons of bad programming practice. These programs have a lot of great features, but are often buggy, resource hungry and slow, like our choice of IDE: Android Studio.
  448. IDE steht für ``Integrated Development Environment''. In diesem Programm editiert und debuggt der Programmiere seinen Code. Solche Software verfügt dabei um mehr Features als nur Texteditierung, sonden auch nützliche Autocompletion Features und gibt Warnungen oder Vorschläge, was der Programmier besser machen sollte. Solche Programme haben zwar viele nützliche Features, wovon wir nur einen Bruchteil kennen oder brauchen, sind aber oft buggy, resourcenhungrig und langsam. So auch die IDE Wahl dieses Projekts: Android Studio. Diese IDE wurde auch gewählt da sie stark optimiert und extra für die Androidentwicklung gemacht wurde.
  449. % \paragraph{Texteditor}
  450. % Text editors to have less ``advanced'' coding-related features, so they are not optimal for big projects with lots of files and graphical content.
  451. \paragraph{Android Emulator}
  452. % ENG: An emulator is a program that simulates an device/operating system so that you can run inside another operation system. We use an Android Emulator inside of our GNU/Linux running on our computer, so that we do can test our app without always having to transfer it to an actual phone running android natively.
  453. Ein Emulator ist ein Programm, welches ein Gerät oder Betriebssystem simuliert, sodass man es innerhalb eines anderen Betriebssystems laufen lassen kann. Für dieses Projekt wurde von Android Emulatoren Gebrauch gemacht, um die App gleich auf dem Computer testen zu können, wo man gerade am programmieren ist. So muss nicht ständig die App auf ein Smartphone transferiert werden, wo Android nativ läuft, nur um die App austesten zu können.
  454. \paragraph{Compiler}
  455. Um die \say{.apk}-Datei zu kompilieren, benutzen wir ein \textit{Build Automation Tool designed for multi-language programs} namens Gradle. Dieses Programm erleichtert den compile Prozess, da der Kompilationsprozess recht komplex wäre, wenn man ihn manuell machen würde. Man müsste alle Dependencies selber angeben, herunterladen und Up-to-Date halten. Durch die Verwendung solche Build-Automatisierungstools sparen wir zwar an Arbeit, und auch viel kürzer wäre das kompilieren ohne Gradle auch nicht.
  456. \paragraph{Installer / Packaging}
  457. % ENG: When we compiled our app using gradle, we get an .apk file as its output. APK stands for Android Package, which is the Package Format used for installing most of the software in Android. However, there are to sorts of apk that are compiled: a debug apk and a release apk. The debug version has extra features compiled in that help auditing bugs and new features not ready for using in the app available to users. The release Version has the current version number (?) added to it and is what you need to distribute of your working version to your users.
  458. Nachdem die App mit \textit{Gradle} kompiliert wurde, erhält man eine .apk-Datei als Output. APK steht für Android Package, was das Packaging Format ist um Software zu installieren auf Android. Dabei kann man die App aber auf zwei Arten kompilieren: eine \textit{debug APK} oder eine \textit{release APK}. Die Debug Version bekommt extra Features hinein kompiliert welche dem Entwickler helfen Bugs zu finden und zu prüfen. Diese Version wird verwendet um neue Features auszutesten, welche noch nicht bereit sind für die Nutzer. Die Release Version enthält die derzeitige Versionsnummer und ist das was man braucht, um eine funktionierende Version der App den Nutzern zur Verfügung zu stellen.
  459. \subparagraph{signing keys}
  460. % ENG: Nearly all Android Systems are configured to only allow application that are signed with a key from the developers. This is done for various reasons like security, compatibility checks and other . So before we can install our app on 99\% of Smartphones, we first have to sign it with our cryptographic key we have created. Of course, this is only needed for actual releases and not for using debugging version e.g. in your android emulator.
  461. Fast alle Android-Systeme sind so konfiguriert, dass sie nur Anwendungen zulassen, die mit einem Schlüssel des Entwicklers signiert sind. Die Argumentation, weshalb das bei Android benötigt wird ist Sicherheit: Durch das Kryptographische signieren von Apps werden potenziell schädliche Modifikationen nach Kompilation der App erschwert. Dieses Verhalten stört die meisten Appentwickler nicht und ist sogar eher erwünscht.\\
  462. Bevor wir also unsere App auf 99\% der Smartphones installieren können, müssen wir sie zunächst mit einem kryptografischen Schlüssel signieren, der von den Entwicklern dieser App erstellt wurde. Dies ist natürlich nur für die tatsächliche Veröffentlichung erforderlich und nicht für die Verwendung der Debugging-Version, z.B. in einem Android-Emulator.
  463. \subparagraph{Android Debugging Bridge}
  464. % ENG: This is a software tool to interact with android devices that are connected to a computer via usb. With it you can do useful thinks like screenshots, screen recordings, transferring files to and from your computer and installing / removing packages.
  465. Dies ist ein Software-Tool für die Interaktion mit Android-Geräten, die per USB mit dem Computer verbunden sind. Damit kann man nützliche Sachen wie Screenshots, Bildschirmaufnahmen, das Übertragen von Dateien und die (De-) Installation von Apps, resp. Softwarepaketen.
  466. \paragraph{Open Source Programme}
  467. Beim Programmieren kann es sehr hilfreich sein Programme zu haben welche, ähnliche Funktionen haben wie das Programm welches entstehen soll.
  468. Solche Vorlagen können beliebig getestet und verändert werden. Simon hatte zu Beginn Schwierigkeiten Java zu nutzen, um Programme zu schreiben, da er noch nicht viel
  469. Erfahrung mit dem Programmieren hatte. Um sich mit der Art der Sprache und des Programmierens vertieft auseinander zu setzen, begann er Email-Apps, welche Open Source
  470. waren, genauer zu Betrachten. Zu beginn haben diese Programme grosse Teile des Programms ausgemacht doch gegen Ende wurde sie so oft überarbeitet, dass es
  471. kaum noch eins zu eins Ausschnitte aus diesen Programmen gibt. \\
  472. Als Basisprogramm für die Roomdatabase hat Simon ein Open source Programm gebraucht, welches als Tutorial diente. \cite{roomApp}
  473. Stark davon betroffen sind die Dateien EmailViewModel.java, EmailViewHolder.java, CustomAdapter.java, EmailRepository.java, EmailRoomDatabase.java, Message.java, MessageDao.java
  474. und NewDraftMessageActivity.java. Bei diesen
  475. Dateien handelt es sich um fast Kopien des Basisprogramms, sie wurden stark erweitert und sie werden von anderen Funktionen aufgerufen.
  476. Die Dateien ArchiveFragment.java, GalleryFragment.java, HomeFragment.java, DraftFragment.java, SpamFragment.java und MainActivity.java beinhalten alle fünf Zeilen beginnend mit der
  477. Variabel mEmailViewModel vom Typ EmailViewModel. Diese fünf Zeilen sind jeweils auch aus dem Basisprogramm.
  478. Weiter beinhaltet die Datei MainActivity.java eine Funktion namens onActivityResult von Zeile 183-215, welche auch aus dem Basisprogramm stammen.
  479. Sehr ähnliche Zeilen befinden sich auch in der messageCreateFragment.java Datei von Zeile 120-140. Diese Stammen ursprünglich auch aus dem Basisprogramm, wurden aber natürlich bearbeitet. \\
  480. % \subsubsection{Librarys}
  481. % (bedeutung im glossar erklärt)
  482. \subsection{Recherche Tools / Quellen}
  483. \subsubsection{Internet}
  484. % ENG: In the world wide web we use search engines like DDG (duckduckgo.com), the Arch Linux Wiki, Wikipedia and more programming-related websites like SOV (stackoverlow.com).
  485. Um das Netz besser durchsuchen zu können, wurden Suchmaschinen wie DDG (duckduckgo.com), das Arch Linux Wiki, Wikipedia und programmierbezogene Internetseiten wie SOV (stackoverflow.com);
  486. \subsubsection{Bücher, Artikel}
  487. % ENG: We used different books and articles physically and digitally sometimes for the programming/coding process, but mostly for the text of this paper.
  488. Es wurde auch Nutzen gemacht von Büchern und Artikeln, in digitaler und physischer Form, ein wenig für den Programmierprozess, aber hauptsächlich für den Maturarbeitstext.
  489. \subsection{Dokumentation(-stools)}
  490. \subsubsection{Latex}
  491. % ENG: To write more formatting-demanding papers like in this paper it was made use of the typesetting engine LaTeX. This is a highly extensible and efficient way for getting your paper to look just like you want it.
  492. Um formatierungsintensivere Texte wie diese Arbeit zu schreiben, wurde das Satzprogramm LaTeX verwendet. Dies ist ein äußerst erweiterbarer und effizienter Weg, um eine Arbeit so aussehen zu lassen, wie man es exakt verlangt. Es wird nicht umsonst extensiv verwendet in naturwissenschaftlichen Artikeln, Büchern und Verlagen.
  493. \subsubsection{Pandoc}
  494. % ENG: This is program to convert from one document format to another. This is useful to write a document in format with very simple syntax (e.g. markdown) to convert it to a format that allows much better formatting (e.g. LaTeX) without having to use the more sophisticated syntax of the latter format. This is often used to write documentation or short texts with the minimal amount of time and effort to do so.
  495. Dies ist ein Programm zur Konvertierung von einem Dokumentformat in ein anderes. Dies ist nützlich, um ein Dokument in einem Format mit sehr einfacher Syntax (z.B. Markdown) zu schreiben und es in ein Format zu konvertieren, welches eine viel bessere Formatierung ermöglicht (z.B. LaTeX), ohne die anspruchsvollere Syntax des komplexeren Formats verwenden zu müssen. Dies wird häufig verwendet, um Dokumentationen oder kurze Texte mit minimalem Zeit- und Arbeitsaufwand zu schreiben. So auch bei dieser Arbeit.
  496. \end{comment}
  497. \subsection{Arbeitsziele}
  498. Wir wissen, was ein Email Client können muss, und haben nicht vor eine App zu designen, welche vollkommen überladen ist, mit Funktionen die keiner braucht.\\
  499. Die App soll die Basisfunktionen eines klassischen Email Clients erfüllen. Dazu gehören das Lesen, Schreiben, Empfangen und Versenden von Emails,
  500. das Öffnen und Anfügen von Anlagen, die Setzung einer Email-Signatur und das Erstellen und Speichern von Entwürfen.
  501. Ebenso soll er verschiedene Ordner unterstützen, wie z.B. einen Spam/Junk oder einen Archiv Ordner.
  502. Dazu soll es möglich sein E-Mails visuell sortieren zu können, beispielsweise indem die Ordner im Client nach Datum des Empfangs oder dem Absender sortiert werden können. E-Mails sollen markiert, gelöscht und weitergeleitet werden können und es soll eine Suchfunktion für jeden Mailordner geben. \\
  503. Ebenso soll es einen Account Manager geben, was voraus setzt, dass es möglich ist sich mit verschiedenen
  504. Accounts anzumelden und diese bei bedarf zu wechseln. Beim Anmelden einer E-Mail, soll es dem Nutzer leicht gemacht werden, mit eingebauten Konfigurationen für beliebte
  505. Emailprovider in der Schweiz. Darunter diese Anbieter: stud.edubs.ch, gmail.com, gmx.ch, outlook.com, yahoo.com, icloud.com, hotmail.com, web.de.
  506. \newpage
  507. Ein Element, welches fast jede App Heutzutage hat, sind Pushnachrichten, welche auch eingebaut werden sollen. Dabei sollen neue Nachrichten mit dem Absender und dem Beginn der E-Mail angezeigt werden.
  508. Dies soll ein weiteres Feature der App sein. Wie es für leichte Email-Clients oft üblich ist, werden Bilder erst angezeigt, sobald es der Nutzer ausdrücklich möchte. Dieses Verhalten soll in den App-Einstellungen steuerbar gemacht werden. Eine sehr praktische Funktion soll sein, dass E-Mail-Adressen gespeichert werden und beim schreiben einer neuen E-Mail direkt verfügbar sind und ausgewählt werden können. %Ob diese Funktion sinnvoll ist, ist fraglich, da viele Leute keine Emailaddressen auf der Kontaktapp ihres Handys speichern.
  509. \\
  510. Das letzte Feature soll sein, dass Links direkt in einem Browser geöffnet werden können. Die Einstellungen sollen zudem das Farblayout der App ändern können, die Synchronisationsintervalle ändern können, Einstellungen an den Pushnachrichten ändern können, Kontaktlisten verwalten und Einstellungen zu Privatsphäre beinhalten.
  511. Im Unterschied zur Konkurrenz soll diese App so programmiert werden, dass sie alle nötigen Grundfunktionen für einen Email Client auf dem Smartphone beinhaltet, aber schneller starten soll als die Apps der Konkurrenz, weniger Speicherplatz und Resourcen verbrauchen soll und nicht mit unnötigen Funktionen überladen sein. \\
  512. Ein Pluginmanager soll auch eingebaut werden, um weitere Funktionen, welche das Programm verlangsamen würden oder nicht für jedermann geeignet sind, hinzuzufügen können. Es existiert natürlich auch die Möglichkeit nach Abschluss dieser Arbeit die App zu verbessern und auf Nutzerwünsche anzupassen, doch hier wurden jetzt die ungefähren, geplanten Grundfunktionen genannt, um die Ziele der Funkionalität besser zu beleuchten.\\
  513. Wir haben uns viele Ziele gesetzt und dachten, dass wir auch mehr schaffen können. Weshalb dies nicht der Fall ist wird noch genauer betrachtet.
  514. \newpage
  515. \section{Arbeitsprozess}
  516. \subsection{Programmiermittel}
  517. Um ein Programm, mir grösserem Umfang, zu Entwickel, braucht es Hilfsmittel die sich auf genau das spezialisiert haben.
  518. Eines dieser Hilfsmittel sind \gls{vcs}. Diese sind eine sehr praktische Methode um Funktionen in ein Programm einzubauen, ohne das Risiko
  519. das Programm komplett zu Überarbeiten, wenn diese Funktion einen Fehler hervorruft. In diesem Fall wurde \Gls{git} als VCS genutzt, um für jegliche Funktionen
  520. einen eigenen \gls{branch} zu erstellen und diesen wieder mit dem Hauptbranch zu \glspl{merge}, wenn die Funktion fertig ist.\cite{git} \cite{github} \\
  521. \begin{figure}[H]
  522. \centering
  523. \includegraphics[width=.8\textwidth]{media/gitflow2.png}
  524. \caption{parallele Featureentwicklung mit Git \cite{gitflowBlog}}
  525. \end{figure}
  526. Um zu Zweit an einem Projekt gleichzeitig zu arbeiten, gibt es viel Möglichkeiten sich das aktualisierte Projekt zur Verfügung zu stellen. Die einfachste ist sich das
  527. Projekt immer wieder zu Mailen, wobei schon nur bei Textarbeiten dabei Probleme auftauchen können, weshalb bei diesem Projekt \Gls{github}
  528. verwendet wurde. Über GitHub konnten die einzelnen Versionen des Programms, welche durch den Gebrauch von \gls{git} entstanden sind, geteilt werden.
  529. Auf GitHub ist das Programm öffentlich und wird dadurch auch Open-Source. Es kann aber nicht durch eine dritte Person, ohne Einwilligung von Noah, in den Source-Code
  530. des Programms geschrieben werden. Falls dies aber der Fall gewesen wäre, würde die dritte Person als mitwirkende Person auf GitHub aufgelistet werden. \cite{github} \\
  531. Beim Programmieren einer Arbeit dieser Grösse, erweist es sich besonders nützlich ein \glspl{ide} zu verwenden. Es ist zu \gls{android-studio} gegriffen worden, weil sich dieses
  532. IDE speziell auf die android Entwicklung spezialisiert hat. \gls{android-studio} besitzt viele Hilfsmittel, welche das Programmieren einer Androidapp erleichtert. Zum beispiel ist der
  533. "Visual Layout Editor"\ eine grosse Hilfe beim Designen. \gls{android-studio} bringt auch einen \gls{compiler} und einen \gls{emulator} mit sich, womit eine \textit{debug} \gls{apk} und eine
  534. \textit{release} \gls{apk} version der App erstellt werden kann. Um die App zu testen, wurde öfters ein \textit{debug} APK File erstellt und auf einem \gls{emulator} aus \gls{android-studio}
  535. getestet. Mit \gls{android-studio} können auch Apps mit speziellen Keys unterzeichnet werden, damit sie im GooglePlayStore veröffentlicht werden können.
  536. Die App sollte aber nicht nur auf Emulatoren laufen, um auch das Gefühl des Designs besser zu empfinden oder den Gebrauch im Alltag zu testen, wurde eine \gls{adb} genutzt.
  537. Mit \gls{android-studio} können auch Daten über die Effizienz der App aufgenommen werden.
  538. \cite{android-studio} \\
  539. Open-Source Programme wurden bei dieser Arbeit öfters genutzt, um gewisse Funktionen einzubauen und ein Gefühl für das Programmieren solcher Funktionen zu bekommen. Die Programme
  540. waren sehr
  541. hilfreich beim Lernen, da wir teilweise noch gar keine Erfahrung in gewissen Bereichen hatten. Was genau aus diesen Programmen entnommen wurde und um welche Programme es sich handelt, wird
  542. genauer im Anhang besprochen.
  543. \subsection{Programmstruktur}
  544. \begin{comment}
  545. \subsubsection{Sicherheit / Security (Features)}
  546. % ENG: Considering that on 99\% of consumer smartphones the users do not even have root access (but which the ``owner'' of the smartphone software do have), people that are concerned with privacy or security would not use their important mailboxes on their smartphone anyway, but rather on their better secured computer running a Free Software Operating System etc.\\
  547. In Anbetracht der Tatsache, dass auf 99\% der Consumer-Smartphones die Benutzer nicht einmal Root-Zugriff haben (den aber der ``Besitzer'' der Smartphone-Software hat), würden Leute, die auf Privatsphäre oder Sicherheit bedacht sind, ihre wichtigen Mailboxen ohnehin nicht auf ihrem Smartphone benutzen, sondern eher auf ihrem besser gesicherten Computer, auf dem ein reines Freies-Software-Betriebssystem läuft usw.\\
  548. % ENG: Also taking in mind that the email protocol was written in a time with a still very limited access to computers, privacy and security where not in mind of its creators at the time is quite understandable. Why it still lasted to this day in this state is compromised on one side by networking effects and on the other side that simply most people neither know to technical detail nor care.\\
  549. wenn man bedenkt, dass das E-Mail-Protokoll in einer Zeit geschrieben wurde, in der der Zugang zu Computern noch sehr eingeschränkt war und Datenschutz und Sicherheit nicht im Sinne seiner Schöpfer waren, ist das durchaus verständlich. Warum es sich bis heute in diesem Zustand gehalten hat, liegt zum einen an den \textit{Networking Effects} und zum anderen daran, dass die meisten Menschen die technischen Details einfach nicht kennen und/oder sich nicht darum kümmern.\\
  550. % ENG: Nowadays it is possible to encrypt to content (body) of an email, but not the metadata, here the specification of the email protocol is to blame. This and just the fact that is was not BUILT as a secure or private way of messaging, makes emails not useful for these kinds of conversation. If you want to send your friends new plans on overtaking the world and establishing a global catholic monarchy without wanting anyone to know, your are a fool if you use email for that(granted, this is an over exaggerated example, but I hope the idea is clear).\\
  551. Heutzutage ist es möglich, den Inhalt (Text) einer E-Mail zu verschlüsseln, nicht aber die Metadaten; hier ist die Spezifikation des E-Mail-Protokolls schuld. Dies und die Tatsache, dass es nicht als sichere oder private Art der Nachrichtenübermittlung konzipiert wurde, macht E-Mails für diese Art von Konversation unbrauchbar. Wenn Sie Ihren Freunden neue Pläne für die Übernahme der Welt und die Errichtung einer globalen katholischen Monarchie schicken wollen, ohne dass jemand davon erfährt, sind Sie ein Narr, wenn Sie dafür E-Mails verwenden (zugegeben, das ist ein übertriebenes Beispiel, aber ich hoffe, der Gedanke ist klar).\\
  552. % ENG: So the conclusion for our application project is to not bloat up our app with hard-to-use security functions that just bloat the app and codebase unnecessarily. However we use sane security-focused default now further explained.
  553. Die Schlussfolgerung für unser Anwendungsprojekt ist also, unsere Anwendung nicht mit schwer zu verwendenden Sicherheitsfunktionen aufzublähen, die die Anwendung und die Codebasis nur unnötig aufblähen. Es sollten jedoch vernünftige, auf Sicherheit ausgerichtete Standardeinstellungen genutzt werden, die u.a. jetzt näher erläutert werden.
  554. %\subsubsection{PRIVATE MODE, Sandbox}
  555. % ENG: When storing user settings (and data?), you can choose between different permission modes in android. We choose PRIVATE MODE, which means that apps with user permissions can not see its content. But Google, root users, and apps with root access can easily bypass this restriction of the android permission system.\\
  556. %Wenn man Nutzereinstellungen- und Daten speichert in Android, kann der Entwickler zwischen verschieden Berechtigungsmodi wählen. In diesem Project wurde der sogenannte \textit{PRIVATE MODE} gewählt. Dieser bewirkt, dass andere Apps mit Nutzerberechtigungen (also a alle von einem Nutzer installierten Apps) den Inhalt dieser Daten nicht sehen können. Aber Google, Root-Nutzer und Apps mit Root-Zugriff können diese Einschränkung des \textit{Android Permission Systems} ohne weitere Probleme umgehen.\\
  557. \subsubsection{Code Kompaktheit}
  558. % ENG: This is something that we have absolutely achieved, we used so much less SLOC than any of the competing email clients on android.(compare use of libraries, and if we used more or less than the other apps) This is also very crucial to stand with our initial goal and the suckless philosophy. While we used \~ 4000 SLOC, other apps use a whopping 300'000 SLOC.
  559. Das ist etwas, was im Laufe diese Projekts ziemlich gut eingehalten wurde: Es wurden viel weniger SLOC geschrieben als bei den konkurrierenden Email Clients auf Android. Das ist ein sehr wichtiger Massstab um das initiale Ziel der \textit{Suckless Philosophy} so gut wie möglich zu erreichen. Während dieses Projekt nur \~ 4000 SLOC Zeilen Code aufzuweisen hat, sind es bei anderen Apps gar über 300'000 SLOC.
  560. \subsubsection{Maintaining}
  561. % ENG: Our codebase should be very easy to maintain: The main things you would have to do is check if the dependencies are up to date and if they can be considered deprecated.\\
  562. Die Codebasis dieses Projektes sollte sehr einfach zu maintainen sein: Die wichtigsten Punkte dabei sind, dass der Maintainer schaut, dass die Dependencies auf der neusten Version sind und ob sie als obsolet oder veraltet angesehen werden müssten.\\
  563. % ENG: Even if this project gets abandoned by their original developers - or as some people call that: when it get orphaned - and if someone finds it and likes it, he can easily read through it and understand the code without too much effort needed of understanding the codebase. Would the same be the case for bloated programs like thunderbird? I don't think so either.
  564. % TODO: get source to term 'orphaned packages'
  565. Selbst wenn das Projekt aufgegeben werden sollte bei seinen ursprünglichen Entwicklern und jemand das Projekt findet und es ihm gefällt kann er dann recht einfach und schnell die Codebase durchlesen und sie ohne allzu grossen Aufwand verstehen. Wäre das auch der Fall bei bloated Software wie thunderbird? Das glaube ich auch nicht.
  566. \subsubsection{less bug/error-prone}
  567. % ENG: This is thanks to the suckless nature of our coding philosophy, but also our execution. It could be the case however that bad practices may have been used as the initial project owner did not have a lot of experience of
  568. Es ist grösstenteils der suckless-basierten Codingphilosophie zu verdanken, aber auch der Umsetzung. Es könnte jedoch der Fall sein, dass schlechte \textit{Coding Practices} verwendet wurden, da die beiden initialen Entwickler dieses Projekts nur eine beschränkte Erfahrung mit der Androidentwicklung mit der Java-Programmiersprache hatten.
  569. \end{comment}
  570. %\subsection{Informationsbeschaffung}
  571. % TODO: in den rest des texts integrieren
  572. %Zu beginn der Arbeit konnten Noah und Simon noch kein Java. Noah kannte sich gut aus mit Programmiersprachen und konnte es deshalb mit Java ruhig angehen.
  573. %Simon hingegen wusste, dass er noch viel zu lernen hatte. Er erhoffte sich die Grundlagen im Informatik Unterricht zu lernen.
  574. %Simon lernte auch einige dinge, jedoch ging ihm das zu langsam und er schaute sich nach anderen Lernmöglichkeiten um.
  575. %Zu diesem Zeitpunkt konnten einige Schüler an einem Programm mitmachen, bei welchem sie in die Uni gingen und gewisse
  576. %Vorlesungen besuchen konnten. Ein Klassenkamerad von Simon konnte von diesem Programm profitieren und besuchte Informatik.
  577. %Dort lernte er in einem unglaublichen Tempo Java, weshalb Simon seinen Klassenkameraden fragte ob er seine Unterlagen ausleihen konnte.
  578. %Sein Klassenkamerad war so freundlich und übermittelte ihm die Unterlagen. So konnte Simon auf effektive weise Java lernen. \\
  579. %
  580. %Persönlich hatte Noah schon Erfahrung mit verschieden Programmiersprachen. Am ähnlichsten zu Java waren dabei meiner Einschätzung nach C und C++, welche eine teilweise ähnliche Sytax gegenüber Java aufweisen. Wirklich etwas mit Java gemacht hat er bei der Pluginprogrammierung für Minecraft und im EF (Ergänzungsfach Informatik) am GKG (Gymnasium Kirschgarten).\\
  581. %
  582. %Als nächstes ging es darum wie eine App aufgebaut ist und wie zwei Personen Zweitgleich an einem
  583. %Programm arbeiten konnten. Dafür musste sich Simon über Git/Github informieren. Noah hatte ihm ein Video empfohlen, welches
  584. %Simon studieren soll und er soll kleine Übungen mit Git ausprobieren um ein Gefühl dafür zu bekommen. Die beiden Informierten
  585. %sich über verschiedene Plattformen wie eine App funktioniert und wie sie aufgebaut ist. \\
  586. %
  587. %Es ging langsam voran und die beiden begannen mit technischen Einstellungen. Als erstes
  588. %wurde Android Studio und eine ADB installiert. Noah hat sogar eine Anleitung zur Installation von ADB geschrieben.
  589. %Um diese auszuprobieren und die Grundlage zu schaffen auf welcher Simon und Noah die nächsten paar Monaten arbeiten werden, haben sie ein
  590. %Testprogramm erstellt namens "Hello World". Es war ein ganz simples Programm das nur zum Testen der Infrastruktur diente.
  591. %Sie haben ein Gradle.build file erstellt, dies dauerte erstaunlich lange. Später erkannten sie das diese Verhalten sehr üblich für
  592. %Gradle ist. Nach einiger Zeit haben es beide geschafft ein apk file zu besitzen, welches erfolgreich die "Hello World" app beinhaltete und ausführt.
  593. %Anschliessend erstellte Noah ein GitHub repository in welchem die beiden das Programm teilen werden. \\
  594. % \textbf{ https://www.youtube.com/watch?v=2sjqTHE0zok} nur um später zu makieren.
  595. \subsubsection{Hauptziele}
  596. Gemäss den Zielen soll die App eine Verbindung mit einem Server erstellen können und mit ihm Interagieren können. Heisst sie soll die Informationen, über einen Account, die der
  597. Nutzer eingibt, überprüfen können und weiter die Emails die ein Nutzer auf einem \gls{server} hat herunterladen. Ebenso soll die App Nachrichten weiter über einen Server verschicken können.
  598. Um das zu realisieren, haben sich die Autoren nach passenden \glspl{library} für Java umgeschaut. Das Resultat dieser Suche waren zwei Libraries.
  599. %TODO: noah schrib wurum mir die libraries ned gange sind und wurum mir uf python umgstiege sind.
  600. Weil nach dem herunterladen der Nachrichten vom Server viele Daten gespeichert werden müssen, muss eine Möglichkeit her, wie diese Daten möglichst schnell,
  601. und der Einfachheit halber mit einer gewissen Abstraktion, in einer sinnvollen Datenstruktur gespeichert werden können. Dazu taugte eine \gls{database}. Um dies zu erreichen
  602. lass sich einer der Autoren in ein Buch ein. Dieses Buch soll ihm Aufschluss über das erstellen einer Database geben.
  603. Es wurde klar, dass eine Database für Android meist mit \gls{sql} oder \gls{sqlite} geschrieben wird. Jedoch sind diese Sprachen nicht wirklich handlich und es
  604. liess sich auch nicht mit dem Zeitplan verknüpfen eine weitere Programmiersprache zu lernen. Weshalb zu Room gegriffen wurde. Room ist eine abstrakte Klasse über SQLite
  605. und kann mit dieser Kommunizieren. Mit ihr können SQL \glspl{query} fast vollständig in Java geschrieben und ausgeführt werden. Ebenso ist Room für die Fehlersucher besser geeignet,
  606. weil es beim Compilen der App die SQL queries und \glspl{entity} überprüft. \cite{roomInfo} \\
  607. \begingroup
  608. \setlength{\intextsep}{7pt}
  609. \setlength{\columnsep}{15pt}
  610. \begin{wrapfigure}{r}{6cm}
  611. \centering
  612. \includegraphics[scale=.12]{media/RecyclerViewScreenshot.png}
  613. \caption{Beispiel vom RecyclerView}
  614. \end{wrapfigure}
  615. \nohyphenation
  616. Damit die heruntergeladenen und gespeicherten Nachrichten auch Angezeigt werden können benötigt es ein Interface. Dieses sollte so schlicht und ordentlich wie möglich gehalten werden.
  617. Die \gls{recyclerview} Library ist eine optimale Möglichkeit Daten in Form von Nachrichten als eine Auflistung zu zeigen. Sie bringt einen Vorteil gegenüber einer \gls{list} mit und zwar
  618. verwendet sie \glspl{view}, die Angezeigt wurden, wieder. Was dem Recyclerviewer einen Vorteil im Punkt Effizienz gegenüber der Liste bringt. \cite{recyclerViewRecycle}
  619. Neben der Recyclerview Library werden auch andere libraries gebraucht um das \gls{user interface} zu erstellen. Einer dieser libraries ist Material oder Material Design.
  620. Den Autoren hat sie schlicht gefallen und sie ist nicht schwer zu benutzen, weshalb diese Library genutzt wurde. Sie ist nach ganz klaren Prinzipien aufgebaut
  621. und von Google erstellt worden um hochwertige Designs zu kreieren. \cite{materialDesigne}
  622. \endgroup
  623. \subsubsection{Aufbau}
  624. Die App kann grob in drei Teile unterteil werden. In \textit{User Interface}, in \textit{Database} und in \textit{Serververbindung}.
  625. \begingroup
  626. \setlength{\intextsep}{7pt}
  627. \setlength{\columnsep}{15pt}
  628. \begin{wrapfigure}{r}{10cm}
  629. \centering
  630. \includegraphics[scale=.52]{media/AppStructureFull.png}
  631. \caption{Grob Aufbau der App}
  632. \end{wrapfigure}
  633. \nohyphenation
  634. Diese drei Komponenten bilden zusammen die App, wobei der Teil der Serververbindung nicht immer aktiv ist. Er wird von dem User Interface
  635. aufgerufen, wenn zum Beispiel sich ein neuer Nutzer mit einem Emailaccount anmelden möchte. Dann werden die Accountdaten an de Server geschickt und überprüft.
  636. Wenn diese korrekt sind werden alle Nachrichten, die dieser Nutzer auf dem Server hat, heruntergeladen und weiter an die Database gegeben. Abgesehen von dem
  637. Speichern der Nachrichten die frisch vom Server kommen, macht die Database nur noch zwei dinge. Sie kann, durch das Interface entstandene, Nachrichten so abspeichern, dass sie
  638. vom \textit{User Interface} im Ordner \textit{Draft} angezeigt werden. Und die \textit{Database} kann weiter gespeicherte Nachrichten bearbeiten so, dass sie vom
  639. \textit{User Interface} in eine anderen Ordner angezeigt werden.
  640. \endgroup
  641. \newpage
  642. \subsubsection{Startup UI}
  643. %I then made the app more functional, so that you have a base GUI with a drawer, a menu in the bottom and in the drawer navigation menu you can tap on the «Add Email» Button and a popup window will come up asking you for name, email and password. Even the save and cancel button work. Now we only need a functionality to save this information to a string somewhere in the main activity.\\
  644. \begin{figure}[H]
  645. \centering
  646. \includegraphics[width=.32\textwidth]{media/drawer.jpeg}
  647. \includegraphics[width=.32\textwidth]{media/inbox.jpeg}
  648. \includegraphics[width=.32\textwidth]{media/fitted-create-message.png}
  649. \caption{die Startup UI von snailmail}
  650. \end{figure}
  651. Wenn man die App startet sieht man als allererstes die durchscrollbare Inbox (siehe mittleres Bild links), hier mit vollkommen arbiträren Testdaten. Bei den 3 Menüpunkten soll im weiteren Laufe der Entwicklung noch die Funktionalität hinzugefügt werden, Emails zu sortieren und durchsuchen.\\
  652. Wenn man im Bild in der Mitte unten rechts das Pluszeichen antippt, erscheint ein Fenster, wo man eine neue Email schreiben kann (Bild rechts). Man kann sie entweder versenden, oder als Entwurf speichern. Wenn der Nutzer sich mit einem Account angemeldet hat, wird die Adresse des Absenders, im Bild entspricht das dem Textfeld mit dem Platzhalter \say{From (Email)}, automatisch mit der aktuellen Email Adresse vervollständigt.\\
  653. Wenn man im mittleren Bild oben links auf das sogenannte \say{Hamburgermenü} drückt, oder wie auf vielen anderen Apps auch von links nach rechts swiped (dt. streicht) erscheint der sog. \say{Drawer} (im Bild links ersichtlich). Dort sieht man den eingeloggten Account, die verschiedenen Mailboxen und ein paar Buttons, um zu den Einstellungen zu gelangen (unten links), einen neuen Email Account hinzufügen (unten Mitte) und um zum Account Manager zu gelangen (durchs tippen auf das Profilbild). Dort kann auf eine andere Mailbox klicken, sodass diese ausgewählt und geöffnet wird.
  654. \subsubsection{Account Management}
  655. Wenn man im Drawer den \textit{Add Email Button} drückt, erscheint ein Pop-up Fenster , wo man seine Anmeldedaten für ein neues Email Konto angeben kann. Da ein Mailserver aber auch von gewissen Standardeinstellungen wie beispielsweise vom standardmässigen IMAP Port 993 (wie definiert von der Internet Society in der IMAP Spezifikation rfc9501 \cite{rfc9501}) abweichen kann, werden in diesem Fenster die zuerst die Standardeinstellungen getestet, indem eine kurze Anfrage an den Server ausgeführt wird. Zuerst wird geschaut, dass nicht bereits ein Account mit der gleichen Email Adresse wie der zu Hinzufügende, wobei dann eine Meldung erscheint für den Nutzer. Dann werden die Anmeldedaten anschliessend mit der Funktion \textit{checkConnection} überprüft, um zu schauen ob man sich mit diesen zum Mailserver verbinden kann.\\
  656. \lstset{language=python}
  657. \begin{lstlisting}
  658. def checkConnection(host, username, password, port):
  659. try:
  660. connection = imaplib.IMAP4_SSL(host, port)
  661. connection.login(username, password)
  662. connection.logout()
  663. return True
  664. except Exception as e:
  665. print("host: " + host)
  666. print("username: " + username)
  667. print("port: " + str(port))
  668. print(str(e))
  669. return False
  670. \end{lstlisting}
  671. Wenn die Anfrage erfolgreich ist, werden die Anmeldedaten in der App gespeichert. Wenn nicht, erscheint ein neues Dialogfenster, wo der Nutzer gefragt wird, ob er noch erweiterte Angaben angeben will um die diese dann testen zu können.\\
  672. Wie schon in Punkt 3.2.3 erwähnt, muss man im \textit{Drawer} auf das Profil klicken, umd zum Account Manager zu gelangen wo dann ein Dialogfenster erscheint. Zuerst wird der Benutzer vom Programm angewiesen mit der Nachricht \say{select Account} ein Konto im, wenn man darauf tippt, Drop-Down Menü auszuwählen. Dann kann er eine Aktion ausführen, indem er einer der korrespondierenden Knöpfe drückt, oder mit \say{exit}-Button das Dialogfenster wieder schliessen.\\
  673. \begin{figure}[H]
  674. \centering
  675. \includegraphics[width=.32\textwidth]{media/plain-add-email.jpeg}
  676. \includegraphics[width=.32\textwidth]{media/advanced-add-email.jpeg}
  677. \includegraphics[width=.32\textwidth]{media/plain-account-manager.jpeg}
  678. \caption{das Account Management}
  679. \end{figure}
  680. Der Nutzer kann entweder den ausgewählten Account löschen, zu ihm wechseln, oder seine Server Settings ändern. Beim letzteren erscheint das gleiche Menü wie den erweiterten Einstellungen, um einen neuen Account hinzuzufügen. Wenn der Nutzer seine neuen Mailservereinstellungen speichern will, wird zuerst geschaut, ob die App sich immer noch verbinden kann mit dem Mailserver. Wenn nicht, erscheint eine Fehlermeldung für den Nutzer und die neuen Angaben werden \textit{nicht} gespeichert.\\
  681. Zur Hilfe wir im Dialog des Account Managers die ganze Zeit zur Hilfe den aktuell aktiven Account anzeigt. Nach jeder der Account Manager Aktionen werden immer noch diese Anzeige und die Textfelder im Drawer, wo der Nutzer seinen zur Zeit aktiven Email Account sehen kann, in Echtzeit aktualisiert.
  682. \subsubsection{Recyclerviewer}
  683. % TODO: mehr allgemein erklären
  684. Ein Recyclerviewer ist in fünf grundlegende Teile aufgeteilt.
  685. \begin{enumerate}
  686. %TODO: dütsch? +Bild
  687. \item Das recyclerview Objekt, welches ein Container ist und in das User Interface eingebaut wird.
  688. Es beinhaltet verschiedene Views, welche nochmals unterteilt werden können. In einer View wird in diesem
  689. Fall eine Nachricht eingebaut mir dem Absender, der Absende Zeit, einem Betreff und dem Endsender der Nachricht.
  690. \end{enumerate}
  691. %\endgroup
  692. \begin{enumerate}
  693. \setcounter{enumi}{1}
  694. \item Der Layout manager. Er ist für die form einer einzelnen View verantwortlich.
  695. Der Layout manager kann auch wieder in drei Arten unterteilt werden. Der Linearlayout Manager sorgt für eine
  696. Horizontale oder vertikale unterteilung einer View. Hingegen führt der Gridlayout Manager zu einer horizontalen
  697. und vertikalen Unterteilung der View. Für den Email-Client bietet er die
  698. beste oberfläche um Nachrichten darzustellen. Es gibt nämlich noch den den Staggeredgridlayout Manager, welcher
  699. für eine versetze unterteilung der View sorgen kann. Dies ist aber für einen Email Client unbrauchbar.
  700. \begin{figure}[H]
  701. \centering
  702. \includegraphics[width=.4\textwidth]{media/RecyclerviewLayoutManagerCropt.jpeg}
  703. \caption{Layout Manager Recyclerview \cite{LayoutManagerPicture}}
  704. \end{figure}
  705. \item Der View Holder beschreibt die Position einer View oder Metadaten innerhalb des Recyclerviewers.
  706. \item Der Adaper ist wohl eines der wichtigsten Teile des Recyclerviewer. Er sorgt für das erstellen des ViewHolder-Objekt und
  707. bindet auch die Daten aus der Database an den View Holder
  708. \item Die Database ist das Herzstück dieser App und wird auch für den Recyclerviewer verwendet um die
  709. Views mit den richtigen Informationen zu füllen.
  710. \end{enumerate}
  711. Die Wahl des Layout Manager wurde sehr schnell getroffen. Es war klar, dass eine Nachricht nicht nur eine Information auf horizontaler Ebene anzeigen muss sondern
  712. z.b auch das Datum nicht versetzt angezeigt werden soll. Weshalb der Gridlayout Manager gewählt wurde.
  713. % \textbf{https://github.com/android/views-widgets-samples/tree/main/RecyclerView} Recyclerviewer beispiel \\
  714. Mit Hilfe eines Open-Source Programm, welches eine Demonstration eines RecyclerViewers war, haben sich die Autoren über diesen Informiert. \cite{RecViewApp}
  715. Nach dem dieses Programm ausgetestet und beliebig modifiziert wurde, sollte es in die App eingebaut werden.
  716. Der erste Versuch scheiterte daran,
  717. dass die App abstürzte ohne einen Error zu melden. Und nach einiger Zeit war die beste Lösung wieder an einen Punkt zu gehen, an welchem die App noch funktionierte, nur ohne vollständigen
  718. Recyclerviewer. Es dauerte einen ganzen Monat bis eine weitere Version mit Recyclerviewer bereit war. Nur diesmal funktionierte die App. \\
  719. \textbf{Weiss ned ob de abschnitt so sinn macht @Simon}
  720. Der Recyclerviewer war an diesem Punkt sehr simpel. Er konnte eine vorbestimmte menge an Views anzeigen, welche in einem Loop generiert wurden, lass die Informationen aus
  721. einer sehr simplen Database aus und er konnte noch nicht aktualisiert werden. Die Informationen konnten nur einmal eingelesen werden und der View-Holder wurde in der gleichen Klasse wie
  722. der Adapter definiert. \\
  723. Die Database bestand zu diesem Zeitpunkt aus nur einer Klasse, welche fünf Strings definierte, diese einlesen konnte und auch wieder ausgeben konnte. Mit dieser Klasse wurde
  724. ein Objekt erstellt, welches in einer Arraylist, durch einen Loop, eingelesen wurde und jeweils die gleichen fünf Strings überkam. \\
  725. In der Klasse des Adapters wurde durch den ViewHolder die richtigen Textviews ausgewählt, die Views kreiert und mit den Informationen, welche der Adapter bekam, gefüllt. \\
  726. In der Mainactivity wurde dies alles in der onCreate() Funktion ausgeführt, was zur Folge hatte, das der ganze vorgang nur beim Öffnen der App ablieft, da die Funktion onCreate()
  727. nur einmal bei der ersten Ausführung der App aufgerufen wird. So konnte der Recyclerviewer erst nur einmalig mit Informationen versehen werde.
  728. Der CustomAdapter war am Anfang der App dafür zuständig die Daten, welche in einer einfache Klasse abgespeichert wurden, über den
  729. \textit{Constructor} dem ViewHolder weiter zu geben, welcher dann diese Informationen an eine View im Recyclerviewer band. Im verlaufe der Zeit wurde
  730. der Adapter angepasst und erweitert. Dies hatte Simon auch sehr grossen Spass gemacht da er auch wirklich alles verstand, jedoch als die Database entstand war der alte
  731. CustomAdapter überflüssig und wurde ersetzt. Der neue CustomAdapter regelt seine Aufgaben jetzt ein wenig anderst. Zwar viel effizienter mit weniger Code aber nicht
  732. so Transparent. Der CustomAdapter wird wie der Recyclerviewer in jedem \gls{fragment} für den zugehörigen \textit{Ordner} neu Aufgerufen und überschreibt den CustomAdapter
  733. aus der Mainactivity.
  734. \subsubsection{Input Validation}
  735. % TODO: explain chain of popup windows
  736. \begin{wrapfigure}{r}{5cm}
  737. \centering
  738. \includegraphics[width=.18\textwidth]{media/inputValidation.png}
  739. \caption{Input Validation}
  740. \end{wrapfigure}
  741. Bei den meisten Textfeldern, wo der Benutzer etwas eingeben kann gibt es in snailmail und es sinnvoll gecheckt werden kann gibt es eine \textit{Input Validation}. Dort wird gecheckt, ob die Eingabe korrekt ist, also ob der Nutzer eine z.B. gütlige Emailaddresse eingegeben hat oder dass er ein Eingabefeld nicht leer lässt. Das Feld mit der falschen Eingabe wird rot markiert und der Nutzer weiss somit, an welcher Stelle er seine Eingabe korrigieren muss. Diese Praxis ist mittlerweile weitverbreitet und auf mobilen graphischen Oberflächen wurde diese von den Autoren als sinnvoll erachtet, weshalb sie auch in ihrer App davon Nutzen gemacht haben.
  742. \subsubsection{Datenbank}
  743. % Nachdem die Grundbausteine für den Recyclerviewer gelegt wurden, war es Zeit eine Database zu erstellen, welche die Informationen der Server
  744. % Speichern kann, da ein Ziel war POP3 anzubieten. Und mit IMAP muss die geöffnete Nachricht auch einmalig gespeichert werden. Dafür bietet sich eine Dabase gut an.
  745. % \textbf{nicht sicher ob das Stimmt was ich hier schreibe}\\
  746. %TODO: zeigen wie Nachrichten eingelesen werden
  747. Ein \textit{relational database management system} ist ein Databasesystem in welchem die Informationen als \textit{tables} gespeichert werden.
  748. Ein \textit{table} besteht aus Reihen und Spalten. Eine Reihe repräsentiert jeweils ein Object der Database und eine Spalte repräsentiert ein Wert eines Attributes. Im Fall dieser App
  749. gibt es 9 Attribute und einen Objectkey. \cite{riccardi2001} \\
  750. \begin{tabular}{ |p{1.6cm} |p{1.1cm} |p{1.1cm} |p{1.05cm} |p{1.15cm} |p{1.15cm} |p{1.25cm} |p{1.75cm} |p{1.25cm} |p{1.15cm}|}
  751. \hline
  752. \multicolumn{10}{|c|}{Database Table} \\
  753. \hline
  754. ObejctKey &To & cc & bcc & from & date & subject & textContent & folder & seen \\
  755. \hline
  756. 01 &Valentin& null & null & Lennard & 01.03.13 & Schule & Hallo Herr & Draft & true \\
  757. \hline
  758. \end{tabular} \\
  759. Der Objektkey wird dafür genutzt das Objekt zu identifizieren und aufzurufen. Es können auch weitere dinge mit dem Objektkey gemacht werde.
  760. Je nach dem wie die Database eingelesen wird, kann am Objektkey festgestellt werden, zu welchem Zeitpunkt eine Objekt erstellt wurde. Bis auf seen und dem ObjektKey sind
  761. alle Attribute Strings.
  762. \textit{To} ist das Attribute, welches angibt an wen die Email geschickt werden soll, \textit{From} ist das genaue gegenstück dazu. \textit{Cc} und \textit{bcc} sind die
  763. Email-Adressen, welche die Emails auch bekommen. Der einzige unterschied ist, dass bei \textit{bcc} diese Adressen nicht einsehbar sind und somit nicht bekannt ist wer diese Email auch liest.
  764. \textit{Date} gibt das Datum an, an welchem die Email verschickt wurde. \textit{Subject} ist ein Betreff für die Email und \textit{textContent} ist der Text welcher in der Email verfasst wurde.
  765. Mit dem Attribut \textit{seen} war geplant, das es von false zu true wechseln zu lassen, wenn der Nutzer eine ungelesene Nachricht öffnet. Dazu sollte dann die Schriftart,
  766. in welcher die Nachricht im Recyclerviewer angezeigt wird, geändert werden. Leider hat diese Funktion es nicht in die App geschafft, aufgrund Zeitmangels und der eher
  767. geringen Wichtigkeit dieser Funktion. Dennoch wird sie sicher nach der Abgabe dieser Arbeit noch eingebaut. \\
  768. Die Attribute \textit{To}, \textit{from}, \textit{date}, \textit{folder} und \textit{seen} wurden im Databaseconstructor als @NonNull definiert, heisst sie müssen eingelesen werden und können
  769. nicht null sein. Das macht soweit Sinn, weil eine Email, bis auf \textit{seen}, nicht ohne diese Angaben versendet werden können und ohne zu wissen in welchem Ordner die Email einzuordnen ist,
  770. kann die Email auch nicht richtig angezeigt werden. \\
  771. Als letztes gibt es noch das Attribut \textit{folder}, es gibt an, von welcher Art die Email ist. Es gibt in der App fünf Ordner. Sie heissen \textit{Draft}, \textit{Sent}
  772. \textit{Inbox}, \textit{Spam} und \textit{Archive}. Die Database kann nach einzelnen Attributen ausgelesen werden. So können die Emails mit den richtigen
  773. folder Attributen, in den richtigen Ordnern angezeigt werden. Jeder Ordner hat sein eigenes Fragment, welches aufgerufen wird, wenn der Ordner ausgewählt wird.
  774. Wenn ein solches Fragment aufgerufen wird, wird auch die Database mit den richtigen Befehlen neu ausgelesen. \\
  775. %Für Android gibt es nicht viele Sprachen um eine Database zu erstellen. Die bekannteste ist SQLite .Jedoch ist SQLite nicht sehr simple und es kann sehr komplex werden, wenn
  776. %die Database bis auf bytes genau Programmiert werden soll. Ebenfalls lag es nicht im Zeitplan eine weitere Programmiersprache zu lernen. Nach kurzer
  777. %recherche stellte sich heraus, dass es eine Library gibt, welche den Umgang mit SQLite vereinfacht und diese sogar mehr Sicherheit bietet.\\
  778. \begingroup
  779. \setlength{\intextsep}{10pt}
  780. \setlength{\columnsep}{15pt}
  781. \begin{wrapfigure}{r}{8cm}
  782. \centering
  783. \includegraphics[width=.4\textwidth]{media/RoomStructure.png}
  784. \caption{Room Struktur \cite{appStructurePicture}}
  785. \end{wrapfigure}
  786. Room ist eine Art Schicht über der SQLiteDatabase.
  787. Room besteht grundsätzlich aus drei Teilen. Die Database dient als Hauptzugriffspunkt für die gespeicherten Daten der App. Sie ist mit @Database markiert.
  788. Eine \textit{Entity} repräsentiert einen \textit{table} in der Database und die \textit{DAO} Klasse beinhaltet die Methoden um auf die Database zu zu greifen. Sie kommuniziert
  789. mit SQLite um de Zugriff auf die Daten zu ermöglichen \cite{roomStructure}
  790. \paragraph{MessageDao}
  791. In der \textit{DAO}-Klasse können SQL statements verwendet werden. Um auf die Database zu zugreifen und nur Gewisse
  792. Objekte zu erfassen, braucht es SQL. Mit diesen Codezeilen kann dann nach den \textit{Ordnern} in der Spalte \textit{folder} gesucht werden.
  793. SQL ist in diesem Fall sehr selbsterklärend,
  794. dennoch werden wir darauf eingehen.\\
  795. \lstset{language=SQL}
  796. \begin{lstlisting}
  797. /* get Draft messages*/
  798. @Query("SELECT * FROM message_table WHERE folder LIKE 'Draft' ORDER BY date ASC")
  799. LiveData<List<Message>> getDraftMessages();
  800. \end{lstlisting}
  801. \textit{Querys} sind anfragen an die Database nach Informationen. Sie können auf verschiedene \textit{tables} zugreifen und Informationen abgleichen und auswählen.
  802. In einer DAO von Room werden die SQL-statements mit @Query markiert. SELECT heisst, dass etwas ausgewählt werden soll und mit * ist gemeint alles. Mit FROM wird angegeben von
  803. welchem table, in diesem Fall vom message\_table. Mit WHERE können Spalten der Entity ausgewählt werden. Hier wird die \textit{folder} Spalte
  804. gewählt um mit LIKE ein Attribut zu bestimmen. So wird nun ein Attribut namens 'Draft' gewählt. Mit ORDER By kann die Ausgabe noch sortiert werden. So wird die Ausgabe anhand der Spalte 'date'
  805. aufsteigen Sortiert. \cite{queryExpl}
  806. Dieses Query wird über das Repository und das Viewmodel, welche gleich erklärt werden, im Fragment Draft ausgeführt. Dieses Fragment wird aufgerufen, wenn de Nutzer
  807. auf den Ordner Draft drückt. Also ist es so, wenn dieser Ordner aufgerufen wird, wird die Database nach dem Wert 'Draft' im Attribut \textit{folder} abgefragt.
  808. \subsubsection{Repository/ViewModel}
  809. \begingroup
  810. \setlength{\intextsep}{1pt}
  811. \setlength{\columnsep}{4pt}
  812. \begin{wrapfigure}{r}{6.5cm}
  813. \centering
  814. \includegraphics[width=.4\textwidth]{media/RepositoryDataInput.png}
  815. \caption{EmailViewModel and Repository
  816. \cite{appStructurePicture}}
  817. \end{wrapfigure}
  818. Damit die Database die Daten einlesen kann, braucht es eine Repository. Über das Repository werden normalerweise Daten aus aller Art von Datenquellen eingelesen. Jedoch
  819. werden in diesem Fall keine Daten vom Server direkt im Repository eingelesen, denn sie gehen zuerst über das Viewmodel.
  820. Weil das herunterladen der Daten vom Mailserver leider erst sehr spät funktioniert hatte,
  821. haben sich die Autoren dazu entschlossen das einlesen der Daten über das Viewmodel zu mache. Dieses hat eine sehr ähnliche Funktion,
  822. es leitet die Daten ebenfalls weiter, nur gibt es \gls{livedata} zurück, was dazu führt, dass in der Mainactivity oder im entsprechenden Fragment ein \gls{observer}
  823. eingebaut werden kann. Dieser informiert die klasse dann über Veränderungen in der Databse, um sie dann im Recyclerviewer anzeigen zu lassen.
  824. \cite{appStructurePicture}
  825. Dies ist die Funktion welche an einer Variable vom Typ EmailViewModel ausgeführt wird. In dem Fragment 'HomeFragment' in der
  826. onCreateView Funktion, welcher immer ausgeführt wird wenn dieses Fragment aufgerufen wird.
  827. \lstset{language=java}
  828. \begin{lstlisting}
  829. mEmailViewModel = new ViewModelProvider(this).get(EmailViewModel.class);
  830. mEmailViewModel.getInboxMessage().observe(getViewLifecycleOwner(), messages -> {
  831. /* Update the cached copy of the messages in the adapter*/
  832. adapter.submitList(messages);
  833. });
  834. \end{lstlisting}
  835. \begingroup
  836. \nohyphenation
  837. Die Funktion getInboxMessage() ist in der Klasse EmailViewModel und EmailRepository definiert und gibt
  838. LiveData \textless List \textless Message \textgreater \textgreater zurück, was soviel ist wie eine Liste der Objekte in der Database, eingebettet
  839. in LiveData.
  840. \endgroup
  841. \lstset{language=java}
  842. \begin{lstlisting}
  843. public LiveData<List<Message>> getInboxMessage(){ return mInboxMessage;}
  844. \end{lstlisting}
  845. \lstset{language=java}
  846. \begin{lstlisting}
  847. private LiveData<List<Message>> mInboxMessage;
  848. public EmailViewModel(Application application) {
  849. super(application);
  850. mEmailRepository = new EmailRepository(application);
  851. mInboxMessage = mEmailRepository.getInboxMessages();
  852. }
  853. public LiveData<List<Message>> getInboxMessage(){ return mInboxMessage;}
  854. \end{lstlisting}
  855. \lstset{language=java}
  856. \begin{lstlisting}
  857. private LiveData<List<Message>> mInboxMessage;
  858. public EmailRepository(Application application) {
  859. EmailRoomDatabase db = EmailRoomDatabase.getDatabase(application);
  860. messageDao = db.messageDao();
  861. mInboxMessage = messageDao.getInboxMessages();
  862. }
  863. public LiveData<List<Message>> getInboxMessages() {
  864. return mInboxMessage;
  865. }
  866. \end{lstlisting}
  867. Es ist ein Schlange welche sich durch EmialViewModel und EmailRepository zieht. In de beiden \textit{Constructor} wird etwa das gleiche gemacht. Im EmailRepository
  868. werden die Query aus dem MessageDAO ausgeführt um die Daten in Variablen für jeden Ordner zu speichern. Und im EmailViewModel werden, durch Funktionen aus dem Repository
  869. die Variablen abgerufen und wieder neu gespeichert um am Schluss diese Variablen in einem Fragment aufzurufen und dem Adapter gegeben. Wie es am Anfang dieser Seite beschrieben
  870. ist.
  871. \subsubsection{Draft Messages}
  872. \begingroup
  873. \setlength{\intextsep}{5pt}
  874. \setlength{\columnsep}{4pt}
  875. \begin{wrapfigure}{r}{6cm}
  876. \centering
  877. \includegraphics[width=.3\textwidth]{media/EWAttention.png}
  878. \caption{Email Writer}
  879. \end{wrapfigure}
  880. %\begin{wrapfigure}{r}{9cm}
  881. % \centering
  882. % \includegraphics[width=.55\textwidth, height=.55\textwidth]{media/AppStructure.png}
  883. % \caption{App Structure \cite{appStructurePicture}}
  884. %\end{wrapfigure}
  885. \nohyphenation
  886. Vorhin wurde beschrieben, wie Daten aus der Database ausgelesen werden, wie sie eingelesen werden und wie sie gespeichert werden. Jetzt wird kurz
  887. noch gezeigt, wann und wie Entwürfe unter dem name 'Drafts' gespeichert werden. \\
  888. Nachdem eine Nachricht geschrieben wurde, kann sie versendet werden oder auch gespeichert werden, wenn im \gls{email writer} das Kreuz gewählt wird, wird der Nutzer
  889. gefragt, ob er die Nachricht abspeichern möchte. Wenn er die Nachricht speichern will, werden im MessageCreateFragment, welches dem Email Writer entspricht, die
  890. eingegebenen Informationen ausgelesen. Über einen \gls{intent} werden diese Informationen weiter an die MainActivity gesendet und dort
  891. mit dem \textit{Folder} Attribut 'Draft' in die Database eingelesen.\\
  892. \endgroup
  893. %TODO: alles um de Server mit Python und repository etc. Dänkfähler mit Aktualisierung vo de Ordner
  894. \subsubsection{Server Connection}
  895. \begin{figure}[H]
  896. \center
  897. \includegraphics[width=.7\textwidth]{media/connection-diagram.png}
  898. \caption{Diagramm Email Versand}
  899. \end{figure}
  900. \phantom{.} \\ % hack to fix line wrapping in the next paragraph
  901. Vereinfacht funktioniert der Versand von Emails wie im obigen Diagramm: Ein Nutzer der eine Email versenden will interagiert mit seinem Mail Client und gibt durch ihn den Befehlt die Email zu versenden. Der Email Client verschickt die Mail an den SMTP Server des sendenden Nutzers, wo dieser zum SMTP Server des empfangenden Nutzers gelangt, von dort aus zu seinem IMAP oder POP3 Server. Wenn der Mail Client des Empfängers eine Anfrage an seinem SMTP / POP 3 macht, kann er diese einlesen und der Nutzer kann nun seine neue Email lesen.\\
  902. Das Versenden von Mails wird in der App einzeln gemacht: Für jede zu sendende Email wird die Funktion \textit{sendStarttls} (siehe folgend) aufgerufen. Zuerst wird der der SSL Kontext initialisiert, dann werden die Angaben der Mail zu einer korrekt kodierten und formatierten Nachricht umgewandelt und schliesslich mit der \textit{smtplib} Bibliothek versendet.
  903. \lstset{language=python}
  904. \begin{lstlisting}
  905. def sendStarttls(host, sendingMail, receivingMail, password, message="",
  906. subject="", port=587, cc=[], bcc=[]):
  907. context = ssl.create_default_context()
  908. if type(cc) is not str:
  909. cc = ",".join(cc)
  910. if type(bcc) is not str:
  911. bcc = ",".join(bcc)
  912. utf8Message = ("Subject: " + subject + "\nCC: " + cc + "\nBCC: " + bcc +
  913. "\n\n" + message)
  914. decoded = utf8Message.encode('cp1252').decode('utf-8')
  915. with smtplib.SMTP(host, port) as serverConnection:
  916. serverConnection.starttls(context=context)
  917. serverConnection.login(sendingMail, password)
  918. serverConnection.sendmail(sendingMail, receivingMail, decoded)
  919. \end{lstlisting}
  920. \subsection{Umsetzung}
  921. \subsubsection{Bugs}
  922. % Erklärung woher, warum falsch, wie gelöst
  923. Programmierfehler schleichen sich in jedem Softwareprojekt ab einer gewissen Komplexitätsstufe ein. Damit hatten auch die Entwickler diese Projektes zu kämpfen. Hier dazu ein kleines Beispiel:\\
  924. % GUI stuff -> oneliner commit
  925. Als der RecyclerViewer das erste Mal eingebunden werden konnte, ohne dass die App nach dem Öffnen direkt abstürzt, war das Problem, dass am oberen Teil des UI, Inhalte abgeschnitten waren. Das konnte gelöst werden, indem diese Codezeile in der Datei \textit{app/src/main/res/layout/activity\_main.xml} an der richtigen Stelle eingefügt wurde:
  926. \lstset{language=XML}
  927. \begin{lstlisting}
  928. android:paddingTop="50dp"
  929. \end{lstlisting}
  930. Es gab sehr viele Bugs, erst recht gegen Ende der Matur, weil dort erst die meisten Funktionen fertig wurden.
  931. Ein Bug der bis Heute nicht gelöst werden konnte, ist das löschen des \textit{Tables} in der Database. Eigentlich sollte dies eine
  932. Leichtigkeit sein, dennoch war es den Autoren nicht möglich ein einfaches Room/SQL statement zu finden, welche alle Informationen in der Database löscht. \\
  933. Die Lösung zu diesem Problem hat leider auch einen Hacken. Es muss nämlich jeder Ordner einmal ausgewählt werden, bevor alle Nachrichten gelöscht werden können.
  934. Die Lösung an sich war, dass wenn einer der Ordner geöffnet wird, alles Nachrichten in diesem Ordner in einer Liste gespeichert werden. Wenn dann die Option "Delete all Folder"
  935. gewählt wird, wird ein Loop gestartet, welcher durch die Liste geht und jede Nachricht einzeln ausgibt. Diese Nachricht wird dann über Umwege an die MessageDAO Klasse gebracht
  936. und dort kann eine einzelne Nachricht dann gelöscht werden. Es ist eine Umständliche Lösung und nichtmal ausgereift. Dennoch besser als wenn es nicht möglich wäre. \\
  937. Vor kurzer Zeit war dieser Bug noch störender, denn die Nachrichten mussten auch gelöscht werden, wenn ein neuer Account angemeldet wurde. Jedoch
  938. konnten das umgangen werden, sobald der Account Manager aufkam. Mit diesem mussten die Nachrichten einfach auch nach dem Account abgerufen werden und die Nachrichten
  939. wurden nicht mehr gelöscht. Es wurden einfach nur die Richtigen angezeigt. \\
  940. Wir sind uns ziemlich sicher, dass es weiter Bugs in der App geben wird, da wir nicht genügend Zeit für das debugging eingeplant haben.
  941. \subsubsection{Probleme / Hiccups}
  942. % RecyclerViewer, shit java IMAP libraries
  943. Probleme waren die unnötig vielen Layouts, welche entstanden bei unserer App. Vielleicht hätten diese minimiert werden können, wenn die Entwickler eine siginfikant höhere Erfahrung im Bereich der Android Entwicklung hätten, oder wenn die verschiedenen Inhalte beim Aufrufen weniger Layouts generieren würden, oder diese könnten besser wieder referenziert werden.\\
  944. Mit gewissen Biobliotheken sind auch Probleme entstanden, dazu wird später in diesem Text noch das Problem mit den Email-Bibliotheken geschildert.
  945. \subsubsection{Kommunikation}
  946. Die Menge an Kommunikation hat sich eingependelt zwischen den Anforderungen, Bedürfnissen und sozialen Kapazitäten der beiden Autoren. Einer wollte eher etwas mehr Dialog, der andere weniger. Das gegenseitige Vertrauen war aber auch soweit vorhanden, dass man sicher ziemlich sicher sein konnte, dass der andere gewisse abgemachte Zeiten einhält und Nachrichten nicht unnötig lange unbeantwortet lässt.\\
  947. Es konnten auch gute Strukturen für die Kommunikation geschaffen werden, so wurde eine \textit{diary}, also eine Art Tage- oder Logbuch verwendet, um den Arbeitsprozess zu dokumentieren, was sich insbesondere bei den Anfängen des Projektes als nützlich herausstellte. Auf diesem Dokument und der \textit{Git Commit History} basiert die Dokumentation dieser Arbeit.\\
  948. Sowohl im Programm-Quellcode der App als auch im Quellcode dieser Arbeit haben die beiden Autoren Notizen in Form von Codekommentaren gemacht - teilweise sich sogar gegenseitig- voll nach dem Motto: \say{Hey, kannst du das dann dort noch einfügen? Du kannst das ja besser als ich.}\\
  949. Auch haben sich die beiden zeitweise Montags zusammen hingesetzt und den Arbeitsprozess in dieser Weise zu besprechen und um sich die nächsten Aufgaben zu verteilen.\\
  950. Insgesamt verlief die Kommunikation doch reichhaltig, obwohl einer der beiden Autoren doch etwas überdurchschnittlich schwer digital erreichbar ist. Die grobe Aufteilung des Programmes um daran zu entwickeln um dann die Komponenten wieder zusammenzufügen hatte etwas von dem typischen Modularität und des Touches der Linuxphilosophie.
  951. % TODO: bruche mir de satz mit de 'linuxphilosophie' @simon? weiss grad iwie nid. Doch ich find dä super
  952. \subsubsection{Namensfindung}
  953. Für die App musste auch noch ein Name her, doch die allerlängste Zeit hatten die beiden Autoren entweder keine Idee oder der Name wurde schon von einer anderen App verwendet. Doch als einer der beiden Autoren seinen Vater fragte nach Namensideen, war einer der Vorschläge \say{Schneckenpost}. Dies ist natürlich eine offensichtliche ironische Anspielung darauf, dass unsere App schneller sein soll als die meisten Apps. Doch da ein englischer Name erwünscht war, wurde es einfach direkt übersetzt in \say{snail mail}. Nun war nur noch die Frage, wie man es darstellen sollte, etwa \say{SnailMail} (CamelCase), \say{snailMail} (mixedCase), \say{Snail Mail}, \say{snail mail} oder \say{snailmail}. Es wurde sich für das letzte entschieden, da dies das wichtigste Designkonzept der App am besten wiederspiegelt: Die Einfachheit. Gleich wie die App lautet auch übrigens der Name des GitHub Repositorys der App:\\
  954. \url{https://github.com/noahvogt/snailmail}
  955. \subsection{Testing}
  956. % TODO: provide testing data + text
  957. Zum Testen gibt es soweit nicht sehr viel zu sagen, da die Autoren fortlaufen das Programm ausprobiert haben und die Resultate direkt wieder in das Programm flossen.
  958. Es hätte keinen wirklich mehrwert gehabt die 'Ergebnisse' solcher einfachen Test zu dokumentieren. Wofür die Zeit leider nicht richtig gereicht hat, war das
  959. richtige testen der App im Alltag. Da die App noch nicht wirklich fertig ist und die neuste Version auch erst vor kurzem entstand, konnte die App nicht an bekannte geben werde
  960. und ein Paar Tage getestet werden. Das Interface wurde getestet aber darüber hinaus leider nicht viel.
  961. \section{Resultate}
  962. \subsection{Vergleich mit unseren ursprünglichen Zielen}
  963. Das User Interface ist erfreulich gut im Einklang mit den ursprünglichen Zielen, es ist wirklich simpel ohne irgendwelchen unnötigen Schnickschnack. Simpel ist das GUI also, doch wie steht es mit der Bedienbarkeit? Dazu haben wir Freunde und Bekannte eingespannt, ihnen ein Handy mit der App in die Hand gedrückt und gesagt sie sollen einen Mailaccount einrichten, um dies herauszufinden. Dabei haben sich die meisten gut und schnell zurechtgefunden, obwohl die App ja noch nicht fertig ist.\\
  964. Die App selber ist wie von uns in den Zielen vorgegeben Free Software. Doch erst kürzlich kam auf, dass die von diesem Projekt verwendete \say{chaquopy} Bibliothek proprietär ist, und somit indirekt ein Konflikt mit den ursprünglichen Zielen steht: Es wurde zwar nicht expilizit angegeben, dass alle Bibliotheken zwingend auch Open Source sein sollen, doch es ist nicht im Sinne der Autoren eine nichtfreie Library zu verwenden. Im Laufe der weiteren Softwareentwicklung wird dieser Fehler noch unbedingt behoben werden müssen. Dieser Missstand ist auch teilweise dem Dependencymanagement von Gradle anzulasten, da dieser immer nur die binäre Version herunterlädt und der Source Code von Dependencies nirgends gescheit verlinkt ist.\\
  965. Die wichtigsten Funktionen der App wurden erreicht, es können Emails geschrieben, gelesen werden, es hat verschiedene Mailboxen und man kann seine Email Accounts gut managen, also hinzufügen, ändern und entfernen. Doch gewisse Features, nämlich Pushnachrichten, Suchfunktionen, HTML output parsing, ein visuelles Atribut, wo zu sehen ist, ob eine Nachricht gelesen wurde, fehlen noch ganz und Funktionen wie die Einstellungen, das synchronisieren der Datenbank mit dem Mailserver und die Anhangfunkionalität sind noch nicht fertiggestellt. Es gibt auch noch gewisse Bugs bei der Entstehung von \say{edge cases} \cite{edgecase} bei bestimmten, einzelnen Emails.\\
  966. Ursprünglich wurde zusätzlich ein Pluginmanager - dabei angelehnt an die Funktionsweise von vim-plug\cite{plug} - geplant einzubauen, doch diese Idee wurde mittlerweile verworfen, da es als weitaus sinnvoller und effizienter, von den Autoren, angesehen wurde, einfach klassische Patches zu verwenden. Ähnlich wie dies bei der suckless.org Software ist. \cite{dwm}
  967. \subsection{Vergleich mit der Konkurrenz}
  968. Es ist gar nicht so einfach diese App zu vergleichen mit ihrer Konkurrenz, da sie noch nicht fertig entwickelt ist. Aus diesem Standpunkt heraus vergleichen wir nur die fertigen Funktionen mit der Konkurrenz.\\
  969. Im Vergleich mit der Konkurrenz, sticht sie heraus durch ihre simple Art, so wie das geplant war. Die Funktionalitäten sind dabei auch wesentlich rüdimentärer, oder besser gesagt mehr \say{suckless} als die der Konkurrenz. Die Farben und das Layout des User Interface sollte zwar simpel sein, doch das visuelle Zusammenspielen von Farben und dem Layout haben gewisse Konkurrenzprodukte, welche immerhin auch von Fortune 500 Unternehmen entwickelt werden, zweifelsohne besser umgesetzt als die Autoren dieser App.
  970. \subsection{Vor- und Nachteile unserer App}
  971. \subsubsection{Pro}
  972. Für die Nutzung der App sprechen simple Nutzeroberfläche und Codebasis, welche nach Fertigstellung der initialen Entwicklung eine der besten simplen Email Client werden sollte.
  973. \subsubsection{Kontra}
  974. Dagegen sprechen, dass gewisse Funktionen welche laut den Autoren nicht in einen Emailclient gehören nicht vorhanden sind, wie beispielsweise die Funktionalität RSS Feeds zu lesen, wie es der allseits bekannte Mailclient Thunderbird .\cite{thunderbird}
  975. \section{Selbstreflexion}
  976. \subsection{Was Gut Lief}
  977. % komm., vcs, java syntax (allg.)
  978. Das Arbeiten mit \textit{Git} als \textit{Version Control System} verlief gut und half enorm beim Arbeitsprozess und dessen Strukturierung. Mit der Syntax der verwendeten Programmier- und Markupsprachen Java, Python und XML konnte gut umgegangen werden, obwohl die beiden noch recht wenig Erfahrung mit Java hatten. Die Codestruktur fanden sie den Umständen entsprechen gut und sinnvoll.
  979. \subsection{Was Schlecht Lief}
  980. % ******* java shit tier libraries
  981. Dass es keine mit Gradle funktionierede, ausreichend dokumentierte und/oder nicht veraltete IMAP- und Emailbibliotheken für Java gibt. Deshalb wichen wir auf die um Welten besser funktionierende Pythonbibliotheken \textit{imap} und \textit{emaillib} aus. Dazu mussten wir eine Library namens \textit{Chaquopy} benutzen, um Python als Bytecode kompiliert in unsere Java App einbauen zu können. Das ist natürlich unschön, aber die Funktionalität hatte die oberste Priorität.\\
  982. Etwas das nicht direkt schlecht lief aber sehr viel Zeit brauchte ist, dass wenn ich (Simon) zum Beispiel eine Database für den Recyclerviewer gemacht habe, zwar nur eine Testversion,
  983. ich diese im späteren verlauf komplett überarbeiten durfte. Es war zwar nur eine Testversion aber dass diese so weit von einer professionelle Database entfernt war, war mit nicht klar.
  984. In so einer Situation war ich nicht nur bei der Database. Mit dem Recyclerviewer hatte ich solche Probleme sogar öfters. Oft hat zwar noch nicht viel funktioniert aber ich musste den Recyclerviewer
  985. öfters komplett umschreiben. \\
  986. %TODO:@Noah dinni Meinig dezue?
  987. Etwas das sicher hätte besser laufen sollen, war das Zeitmanagement. Ich glaub aber auch, das uns nicht ganz klar war, wie viel
  988. noch vor uns liegt. Wir waren fast immer in Zeitverzögerung. Immer Sommer dachten wir noch wir wären perfekt in der Zeit und dies wurde uns auch bestätigt. Jedoch
  989. als wir aus den Sommerferien kamen, wurde uns bewusst wie viel es noch zu tu gibt. Wir haben alles gegeben, jedoch wurde die App leider nicht Fertig.
  990. \subsection{Was Wir Gleich Machen Würden}
  991. % As long as java is not deprecated in the future for android programming, we would still use it as it is the most ``native'' way of programming. The new java clone/fork of google, Kotlin, would be a worse choice in our eyes, as your are even more dependent on google code, which you are already by using android.
  992. Wenn wir diese in die Vergangenheit reisen könnten und die App von Neuem machen könnten, würden wir am Userdesign nichts ändern, und auch weiterhin mit \textit{Git} als \textit{VCS} arbeiten und für jedes noch nicht einsatzbereite Feature einen neuen \textit{Branch} machen. Die Arbeitsweise an sich hat sich aus unserer Sicht bewährt und ist ein passabler Weg, kollaborativ an einem Softwareprojekt zu arbeiten.
  993. \subsection{Was Wir Anders Machen Würden}
  994. % As java is much slower than language that can be compiled into native binaries we would try to use more C or C++ libraries to improve speed and portability.
  995. Code der in Java geschrieben wurde, kann nicht nativ auf einer Maschine laufen, sondern muss durch eine virtuelle Maschine, die \textit{Java Virtual Machine (JVM)} während der Ausführung in nativen Code umgewandelt werden. Deshalb würde bei einem Rewrite wohl besser mehr Code in C oder C++ geschrieben werden, um die Geschwindigkeit und Portabilität zu erhöhen. Java komplett wegzulassen ist aber weder vorgesehen noch praktisch sinnvoll umsetzbar. \\
  996. Uns ist öfters gesagt worden, dass das managen der Zeit sehr wichtig ist. Wir sind davon ausgegangen, dass wir dies auch gut eingeplant haben. Dem war leider nicht so und wir
  997. würden uns mehr gedankten machen beim Planen wie auch, wie lange wir an einem Problem arbeiten bevor wir das Feature entfernen, als das wir sehr lange daran arbeiten.
  998. % use more c libs for speed and less java
  999. \subsection{abschliessende persönliche Schlussfolgerung}
  1000. Wir haben das Gefühl, einen guten ersten Einblick in die native Android Programmierung mit Java und Python bekommen zu haben. Wir haben uns vertraut gemacht mit den Vorzügen aber auch Nachteilen dieser Art von Programmierung und der Plattform Android.\\
  1001. Wir sind zwar etwas enttäuscht, dass wir nicht alle geplanten Ziele erreicht haben, doch wir haben noch genug Motivation die App in den nächsten paar Wochen und Monaten fertigzustellen. Denn die Arbeit hat uns insgesamt doch gefallen, trotz einigen Motivationstiefs, sodass wir auch gerne unseren Freunden und Familie von ihr erzählt haben.
  1002. Wir können sicher sage, dass wir jetzt eine Smartphone App als grösseres Projekt ansehen als das was wir dachten. Eine App ist nicht so simple wie wir erwartet haben.\\
  1003. Was uns auch noch sehr gefallen hat ist das Arbeiten mit dem Version Control System \textit{Git} und der Plattfrom \textit{Github}, denn so konnte man gut den Fortschritt sehen und tracken, schliesslich machte das kollaborative Arbeiten an einem Projekt dieser Grösse besonderns Sinn und konnte gut Nutzen machen von der Funktionalität dieses Systems.
  1004. Dazu war das eine sehr gute Lehre wie später in grösseren Teams solche Programme entstehen. Wir sind jetzt sicher etwas besser ausgerüstet als andere.
  1005. \section{Danksagung}
  1006. Wir (Simon und Noah) möchten uns bei unserer Betreuungslehrperson Dr. Viktor Yakonthov, und unserem Koreferenten D. Bühler bedanken, dass sie uns die Arbeit haben durchführen lassen und ihre Bereitschaft, zu helfen bei allfälligen Fragen, gezeigt haben.
  1007. %TODO:Anhang
  1008. \clearpage
  1009. \printglossary
  1010. \newpage
  1011. \printbibliography
  1012. \end{document}