Update README.md

This commit is contained in:
Nicole Dresselhaus 2017-07-05 13:31:30 +02:00 committed by GitHub
parent b4ecdc2bc0
commit 168a80e0ef
1 changed files with 75 additions and 0 deletions

View File

@ -99,3 +99,78 @@ Beispiel:
hiddenUIDForm :: UserId -> Form UserId
hiddenUIDForm uid = renderDivs $ areq hiddenField "" (Just uid)
```
ZETTEL 10
=========
Issue 1
-------
a) Implementieren Sie einen Login über Github. Github bietet Ihnen eine sogenannte OAuth Schnittstelle, durch die Sie sicher die Authentizität eines Benutzers überprüfen können.
In dem packet `yesod-auth-oauth2` ist bereits ein Github-OAuth PLugin vorhanden, dass Sie nun noch laden müssen. Falls Sie auf Github keine eigene Application erstellen wollen, können Sie die unten angegebenen Daten verwenden, um Ihre Application gegenüber Github zu authentifizieren.
```
Client ID
b52908be7f1c8b1d763f
Client Secret
15d7961bb26c7b4791999847aec81c5c125ec688
```
Diese leitet nach der Authentifizierung nach http://localhost:3000/ weiter.
b) Nachdem ein User sich nun per Github einloggen kann, sollten Sie dafür sorgen, dass der Github-Benutzername sowie die Mail Adresse ausgelesen und gespeichert werden.
Eventuell finden Sie folgende Resourcen interessant, wenn Sie nicht Wissen wo diese Daten abzufragen sind:
[Yesod.Auth.Creds](https://hackage.haskell.org/package/yesod-auth-1.4.17.2/docs/Yesod-Auth.html#t:Creds)
[Yesod.Auth.OAuth2.Github.toCreds](https://github.com/thoughtbot/yesod-auth-oauth2/blob/master/Yesod/Auth/OAuth2/Github.hs#L99)
Issue 2
-------
Es nutzen immer weniger Nutzer Ihren Social-Hub! Tag für Tag werden es weniger! Was nun?
#dasGehtBesser #sieWissenWasAufSieZuKommt #alleGutenDingeSindDrei
User wollen Hashtags!
a) Schreiben Sie einen Parser, der aus einem Text alle Wörter, die mit einem # beginnen,
in eine Liste parst. Wenden Sie diesen Parser auf jeden Post, der neu erstellt wird, an.
Da Yesod mit dem Datentyp Text arbeitet, sollten Sie statt `Data.Attoparsec.ByteString`
besser [Data.Attoparsec.Text](http://hackage.haskell.org/package/attoparsec-0.13.1.0/docs/Data-Attoparsec-Text.html) verwenden.
b) Nun müssen diese Tags noch persistent gespeichert werden. Erweitern Sie hierzu Ihr
Datenbankmodell. (Einen Vorschlag, wie das Aussehen könnte, finden Sie in der Datei
ER_II.pdf)
Issue 3
-------
Ihre Nutzer kommen immer noch nicht wieder....
Und plötzlich fällt ihnen ein warum! Man kann ja noch nicht nach Tags suchen!
a)
Legen Sie eine neue Seite an (Hinweise hierzu finden Sie auf Übungszettel 9 Issue 2),
die später als Suchseite für getaggte Inhalte genutzt werden soll. Diese Seite solte
nur für eingeloggte User erreichbar sein und im Menü sollte ein Link zu dieser Seite
zu finden sein.
b)
Lassen Sie nun die Tags in den Posts als Link anzeigen, der auf diese Suchseite verlinkt.
Auf der Suchseite sollte nun auch der Name des Tags zu lesen sein, auf den
geklickt worden ist.
https://www.yesodweb.com/book/routing-and-handlers#routing-and-handlers_types_of_pieces
Issue 4
-------
Implementieren Sie nun die Suchfunktion dieser Seite.
- Wenn man auf einen Tag geklickt hat soll die Ergebnisseite der Suche erscheinen (GET).
- Auf dieser Seite sollte ein Eingabefeld sein, mit dem man nach Tags suchen kann (POST).
- Hinweis: Nachdem Sie die Gültigkeit des Formulares überprüft haben können Sie auch einen Redirect auf die GET-Seite machen um den Code nicht doppelt zu schreiben.
- Unter dem Eingabefeld sollen die Ergebnisse angezeigt werden.
- Unter dieser Anzeige sollte die Timeline des Users, der den Post verfasst hat, verlinkt sein.