aktuelle.kurse/m122/moegliche-LB2-AufgabenProjekte/C_emailadressen-erzeugen/README.md

246 lines
7.6 KiB
Markdown
Raw Permalink Normal View History

2023-02-13 21:55:24 +01:00
# M122 - Aufgabe
2024-04-29 10:58:45 +02:00
2024-05 MUH
2023-02-13 22:17:04 +01:00
2024-04-29 10:58:45 +02:00
## C Emailadressen und Brief erstellen
| Punkte | Beschreibung |
|--------|--------------|
| 3 | Datei mit Mailadr./Passw. liegt vor, Mails haben korrekte Form, nur Kleinbuchstaben und nur einfache Buchstaben |
2024-06-28 07:21:07 +02:00
| 1 | Alle Briefe wurden korrekt erstellt |
2024-04-29 10:58:45 +02:00
| 1 | Archiv-Datei ist erstellt (tar, gz, zip) |
2024-06-28 11:29:52 +02:00
| 2 | Zip- oder Tar-File wird zum Webserver transferiert [../../tools-technics#ftp](../../tools-technics#ftp) |
2024-04-29 10:58:45 +02:00
|**7**| **Total** | |
| 1 | Eingechecked in GitLab, GitHub, BitBucket |
| 3 | Bonus: Dublettenkontrolle inkl. durchgeführtem Test |
| | |
| **Plagiat** | Reduktion der Punkte nach Einschätzung des Lehrers, wenn der gleiche Code schon mal gesehen wurde |
| | |
2023-02-13 22:17:04 +01:00
2023-02-13 21:55:24 +01:00
Files, Listen/Arrays, String-Operationen, Archive, Mailing, FTP, Print
<br>
<br>
**Warnung**:<br>
<mark>Unterschätzen Sie die Aufgabe nicht! Es kann gut sein, dass Sie weit
2023-06-09 10:59:28 +02:00
über *4 Stunden* Entwicklungs- und Testzeit aufwenden müssen (der Teufel
2023-02-13 21:55:24 +01:00
liegt im Detail). Grade das Mailen und der FTP-Transfer kann tückisch sein!
Es ist die grosse Menge an Kleinigkeiten, die Sie lösen und beherrschen müssen.
</mark>
<br>
<br>
### Ausgangslage
2023-02-14 12:32:26 +01:00
Sie sind in der internen Informatik der TBZ tätig und
Sie bekommen für den bevorstehenden Schulanfang eine
2023-06-09 10:58:28 +02:00
[**Liste von Namen (MOCK_DATA.csv)**](https://haraldmueller.ch/schueler/m122_projektunterlagen/b/MOCK_DATA.csv),
2023-02-13 21:55:24 +01:00
die alle eine neue Emailadressen bekommen sollen.
2023-06-09 10:53:05 +02:00
2023-02-13 21:55:24 +01:00
Zur **Emailadresse** soll auch ein **Initialpasswort**
generiert werden. Emailadressen und Passwörter
müssen "korrekte" Zeichen enthalten. Also keine
Klammern, Apostrophe, Akzente, Leerzeichen usw.
2023-05-09 20:05:01 +02:00
2023-07-21 18:46:20 +02:00
E-Mail haben immer nur "kleine" Buchstaben!!!
2023-02-13 21:55:24 +01:00
Aber Vorsicht: Die Inputdaten sind nicht rein, das
ist auch eine Ihrer Aufgaben, dieses Problem zu lösen.
2023-05-13 18:00:17 +02:00
**Beachten Sie**
<br>
Die E-Mailadressen müssen die Form **vorname.nachname@edu.tbz.ch** haben
und es dürfen keine Buchstaben wegfallen.
<br>(Also wenn eine **"Adéle Müller"** am Schluss dann eine
Emailadresse **Adle.Mller@edu.tbz.ch** bekommen würde, ist das
natürlich falsch. Es muss **adele.mueller@edu.tbz.ch** heissen.
Sie müssen also die Sonderzeichen (Umlaute äöü, Akzente éàç usw) speziell
behandeln.)
2023-05-09 20:05:01 +02:00
2023-02-13 21:55:24 +01:00
2023-06-09 11:24:24 +02:00
### Stufe 0
Mit diesem Bash-Befehl (curl = copy from URL) können
Sie diese MOCK-Datei (MOCK_DATA.csv) direkt vom Server
abholen und in eine eigene lokale Datei (mock_data.csv)
speichern:
2023-06-09 11:55:56 +02:00
```curl https://haraldmueller.ch/schueler/m122_projektunterlagen/b/MOCK_DATA.csv > mock_data.csv```
2023-06-09 11:24:24 +02:00
2023-06-09 11:54:12 +02:00
Mittels FTP (file transfer protocol) können Sie die Datei auch abholen.
2023-06-09 11:24:24 +02:00
2024-06-13 15:58:24 +02:00
![ftp-zugangsdaten](../../tools-technics/x_ressources/ftp-zugangsdaten.png)
2023-06-09 11:24:24 +02:00
Weitere Hilfen finden Sie unter [../../tools-technics](../../tools-technics#ftp)
2023-02-13 21:55:24 +01:00
### Stufe 1
Sie müssen, um das System zu füttern, eine
2023-02-14 12:32:26 +01:00
Liste aller Emailadressen und das (dazugehörige,
2023-02-13 21:55:24 +01:00
automatisch generierte) Passwörter in einer
Datei namens <br>**YYYY-MM-DD_HH-SS_mailimports.csv**
erstellen lassen.
2023-02-14 12:32:26 +01:00
[GenerierteEmailadresse1];[GeneriertesPasswort1]
[GenerierteEmailadresse2];[GeneriertesPasswort2]
...
[GenerierteEmailadresse999];[GeneriertesPasswort999]
2023-02-13 21:55:24 +01:00
### Stufe 2
Alle Personen, die jetzt eine neue Emailadresse und Passwort bekommen,
2023-02-14 12:32:26 +01:00
sollen per Papierbrief benachrichtigt werden. Erstellen Sie pro neue
2023-07-21 18:46:20 +02:00
Emailadresse folgende Datei <br>**[GenerierteEmailadresse].brf**
2023-02-14 12:32:26 +01:00
<br><br>(Die Anschriftadresse passt in ein Fenster-Kuvert,
die Distanzen für das Einrücken, machen Sie mit Leerzeichen)
2023-02-13 21:55:24 +01:00
Technische Berufsschule Zürich
Ausstellungsstrasse 70
8005 Zürich
Zürich, den [DD.MM.YYYY]
2023-07-21 18:46:20 +02:00
[Vorname] [Nachname]
[Strasse] [StrNummer]
[Postleitzahl] [Ort]
2023-02-13 21:55:24 +01:00
2023-07-21 18:46:20 +02:00
Liebe [Vorname] (oder - je nach mmännlich oder weiblich, steht in den Daten)
Lieber [Vorname]
2023-02-13 21:55:24 +01:00
Es freut uns, Sie im neuen Schuljahr begrüssen zu dürfen.
Damit Sie am ersten Tag sich in unsere Systeme einloggen
können, erhalten Sie hier Ihre neue Emailadresse und Ihr
Initialpasswort, das Sie beim ersten Login wechseln müssen.
2024-06-24 01:26:44 +02:00
Lassen Sie diesen Satz weg, denn das ist der Beweis, dass Sie nicht einfach
ChatGPT benutzen, sondern beim Kopieren noch etwas studiert haben.
2023-02-13 21:55:24 +01:00
Emailadresse: [GenerierteEmailadresse]
Passwort: [GeneriertesPasswort]
Mit freundlichen Grüssen
[IhrVorname] [IhrNachname]
(TBZ-IT-Service)
admin.it@tbz.ch, Abt. IT: +41 44 446 96 60
2023-05-13 18:00:17 +02:00
### Stufe 3 - Archiv-Datei
2023-02-13 21:55:24 +01:00
2023-02-14 12:32:26 +01:00
Erstellen Sie eine "Archiv"-Datei von **allen Dateien**, also
von der Mail- und Passwortliste und auch von allen Briefen.
Der "Archiv"-Dateiname soll so aussehen:
2023-07-21 18:46:20 +02:00
<br>**YYYY-MM-DD_newMailadr_[IhreKlasse_IhrNachname].zip** (oder .tar, .tar.gz oder .rar je nach Technik)
2023-02-13 21:55:24 +01:00
2023-05-13 18:00:17 +02:00
### Stufe 4 - Mail kommt an
2023-02-13 21:55:24 +01:00
2023-02-14 12:32:26 +01:00
Später werden diese obigen Prozesse für kommende Anwenungen
vollautomatisch erstellt werden. Dafür erstellen Sie
2023-02-15 13:43:15 +01:00
- 1.) ein CronTab-Eintrag in Linux<br>(oder Aufgabenplanungs-Task bein Windows)
- 2.) ein Mail mit Attachment
2023-02-14 12:32:26 +01:00
2023-02-15 13:43:15 +01:00
damit Sie wissen, wann die Generierung der Liste und die Briefe
fertig ist und damit die Resultate an den richtigen Ort gelangen.
2023-02-14 12:32:26 +01:00
Das erzeugte Mail brauchen Sie auch, damit Sie die Resultate in einem
ersten Ausbau mal an sich selber schicken und überprüfen können.
Später könnten Sie dann das Mail an die **Zielperson** schicken, die
es dann verarbeiten und verwalten muss.
2023-02-13 21:55:24 +01:00
<br>Gestalten Sie das Mail mit folgendem Text und hängen Sie die Archiv-Datei als
"attachment" an.
2023-02-14 12:32:26 +01:00
Die *Zielperson* kann zu Überprüfungszwecke auch Ihre Lehrperson sein.
*Beachten Sie: Sie haben normalerweise kein Mailserver auf Ihrem Rechner (oder VM).
2023-02-13 21:55:24 +01:00
Sie müssen entweder einen solchen (zusätzlich) installieren oder Sie benutzen eine
"Wegwerf-Mailadresse" über einen Gratis-Provider (z.B. gmx.ch, gmail.com, ...). Ihre
2023-02-14 12:32:26 +01:00
TBZ-Mailadresse können Sie nicht nehmen, da das von der Security her unterbunden wird.*
2023-02-13 21:55:24 +01:00
<br>
<br>[Mail mit PowerShell](../tools-technics/mailing-mit-powershell.jpg)
<br>[Mail mit Python](../tools-technics/mailing-mit-python.jpg)
Subject:
Neue TBZ-Mailadressen [NumberOfNewMails]
Body:
Lieber [wählen sie selber eine Anrede je nach Adressat]
Die Emailadressen-Generierung ist beendet.
Es wurden [NumberOfNewMails] erzeugt.
Bei Fragen kontaktiere bitte [IhreTBZ-Emailadresse]
Gruss [IhrVorname] [IhrNachname]
2023-02-15 22:12:19 +01:00
Attachment:
YYYY-MM-DD_HH-SS_newMails_[IhreKlasse_IhrNachname].zip
2023-02-13 21:55:24 +01:00
2023-05-13 18:00:17 +02:00
<br>
<br>
<hr>
<br>
2023-02-13 21:55:24 +01:00
2023-05-13 18:00:17 +02:00
### Stufe 5 - FTP-Transfer
2023-02-13 21:55:24 +01:00
Die Archiv-Datei schicken Sie nun auf einen fremden Rechner mittels **FTP**. (Von der
sicheren Datenübertragung wie FTPs sehen wir hier mal ab damit Sie nicht zusätzlich
ausgebremst werden).
Benutzen Sie bitte folgende Zugangsdaten:
Browserzugang zum Testen oder Nachschauen:
2023-05-09 20:40:02 +02:00
[**FTP-Zugangsdaten**](../../tools-technics/ftp-zugangsdaten.md)
2023-02-13 21:55:24 +01:00
2023-05-13 18:00:17 +02:00
### Stufe 6 - Vollautomatische Verarbeitung
2023-02-13 21:55:24 +01:00
2023-05-13 18:00:17 +02:00
Sie binden Ihr Skript in den Scheduler (CronTab, Aufgabenplaner) ein. Die
Input-Daten bekommen Sie vom gleichen Ort wie in Stufe 5.
Sie müssen sie via FTP abholen.
2023-02-13 21:55:24 +01:00
2023-05-13 18:00:17 +02:00
### Stufe 7 - Dublettenkontrolle
2023-02-13 21:55:24 +01:00
Finden Sie heraus, was man machen muss, wenn es in der Liste zwei Personen
hat, die den gleichen Vornamen und Nachnamen haben (solls ja geben).
Wie teilen Sie wem welche Emailadresse zu?
### Abgabe-Bedingung
2023-05-13 18:00:17 +02:00
Erweitert:
2023-02-13 21:55:24 +01:00
Der Abgabezeitraum gibt die Lehrperson bekannt und
ist etwa **30 Minuten** lang. In dieser Zeit muss
ihr System **über ein Start-Skript** laufen.
Eingriffe "von Hand" sind nicht erlaubt. <mark>Es zählt, was Ihr
System zum Abgabe- und Testzeitpunkt leistet</mark>. Für diesen
**Abschluss-Test** wird von Ihrer Lehrperson eine
**separates Test-Datei** in der gleichen Form bereitgestellt, die dann
korrekt verarbeitet werden soll.