UserApp-Entwicklung/Tutorials/Beginner: Unterschied zwischen den Versionen

(Persönliche Anrede entfernt, Nutzer => Mitglied)
(Änderung 143821 von mrs fabelhaft (Diskussion) rückgängig gemacht.)
Markierung: Rückgängigmachung
 
Zeile 5: Zeile 5:
== Bevor es losgeht ==
== Bevor es losgeht ==


=== Entwickler werden ===
=== Werde Entwickler ===


Man stellt sicher, dass man ein Entwickler ist. Man gibt dazu '''/apps developer''' im Chat ein und erfüllt die Kriterien, falls man das noch nicht getan hat.
Stelle sicher, dass du ein Entwickler bist. Gib dazu '''/apps developer''' im Chat ein und erfülle die Kriterien, falls du das noch nicht getan hast.


=== Verwende die Desktop-App ===
=== Verwende die Desktop-App ===


Wir empfehlen stark, zum Entwickeln die Desktop-App auf dem Computer zu verwenden. Man kann die App [https://www.knuddels.de/stapp-win hier herunterladen].<br>
Wir empfehlen dir stark, zum Entwickeln die Desktop-App auf deinem Computer zu verwenden. Du kannst die App [https://www.knuddels.de/stapp-win hier herunterladen].<br>


== Die erste UserApp ==
== Die erste UserApp ==


=== Entwicklungs-Server ===
=== Entwicklungs-Server ===
Das Entwickeln beginnt auf dem Entwicklungs-Server. Man gibt '''/apps developer''' ein und wählt den Punkt '''Login auf Entwicklungs-Server''' aus. Jetzt sollte eine Desktop-Verknüpfung für den Login auf dem Entwicklungs-Server angelegt worden sein.<br>
Das Entwickeln beginnt auf dem Entwicklungs-Server. Gib '''/apps developer''' ein und wähle den Punkt '''Login auf Entwicklungs-Server''' aus. Jetzt sollte eine Desktop-Verknüpfung für den Login auf dem Entwicklungs-Server angelegt worden sein.<br>
Wenn man Knuddels über diese Verknüpfung startet, landet man nach dem Login auf dem Entwicklungs-Server. Hier kann man später in Ruhe an der UserApp tüfteln, bevor man die Änderungen auf dem Live-Server hochlädt.<br>
Wenn du Knuddels über diese Verknüpfung startest, landest du nach dem Login auf dem Entwicklungs-Server. Hier kannst du später in Ruhe an deiner UserApp tüfteln, bevor du deine Änderungen auf dem Live-Server hochlädst.<br>


Man loggt sich jetzt mit den Zugangsdaten auf dem  Entwicklungsserver ein, die James gesendet hat ('''Entwickler-Nick''' und '''Entwickler-Passwort''').
Logge dich jetzt mit den Zugangsdaten auf dem  Entwicklungsserver ein, die dir James gesendet hat ('''Entwickler-Nick''' und '''Entwickler-Passwort''').


   Tipp: Man kann die Zugangsdaten aus James' Nachricht mit Shift+Rechtsklick in das Chat-Fenster kopieren.
   Tipp: Du kannst die Zugangsdaten aus James' Nachricht mit Shift+Rechtsklick in das Chat-Fenster kopieren.


=== MyChannel ===
=== MyChannel ===


Nach dem Einloggen sollte sich automatisch das [[MyChannel]]-Edit Fenster öffnen. Ansonsten gibt man '''/mychannel''' ein.<br>
Nach dem Einloggen sollte sich automatisch das [[MyChannel]]-Edit Fenster öffnen. Ansonsten gib '''/mychannel''' ein.<br>
Man legt sich jetzt einen eigenen Channel an, in dem man gleich die erste UserApp installieren wird. Eine Info zu den Einstellungen erhält man durch Klicken auf den Titel des jeweiligen Feldes. Außer über den Channel-Namen muss man sich aber erstmal keine Gedanken machen (man kann dieses Fenster jederzeit wieder mit '''/mychannel''' öffnen). Man drückt anschließend auf '''Speichern''' und '''Schließen''' und betritt den MyChannel mit '''/go <eigener Channel-Name>'''.
Du legst dir jetzt einen eigenen Channel an, in dem du gleich deine erste UserApp installieren wirst. Eine Info zu den Einstellungen erhältst du durch Klicken auf den Titel des jeweiligen Feldes. Außer über deinen Channel-Namen musst du dir aber erstmal keine Gedanken machen (du kannst dieses Fenster jederzeit wieder mit '''/mychannel''' öffnen). Drücke anschließend auf '''Speichern''' und '''Schließen''' und betritt deinen MyChannel mit '''/go <dein eigener Channel-Name>'''.


=== Installation der UserApp ===
=== Installation der UserApp ===


Für dieses Tutorial hat man schon Dateien für eine Beispiel-UserApp namens "HeyThere" auf den Server geladen. Man installiert diese UserApp in dem MyChannel mit '''/apps install HeyThere'''. Man kann die UserApp später wieder aus dem Channel löschen.<br>
Für dieses Tutorial haben wir dir schon Dateien für eine Beispiel-UserApp namens "HeyThere" auf den Server geladen. Installiere diese UserApp in deinem MyChannel mit '''/apps install HeyThere'''. Du kannst die UserApp später wieder aus deinem Channel löschen.<br>


Es müsste sich nun automatisch das Konfigurationsfenster für die UserApp geöffnet haben. Ansonsten öffnet man es eigenständig mit  '''/apps''' und klickt auf den Namen der UserApp ("HeyThere").
Es müsste sich nun automatisch das Konfigurationsfenster für die UserApp geöffnet haben. Ansonsten öffne es selbst mit  '''/apps''' und klicke auf den Namen der UserApp ("HeyThere").
   Hinweis: Durch einen Bug kann es sein, dass das Fenster auf dem Entwicklungs-Server nichts anzeigt. Man schließt es einfach und öffnet es gleich nochmal mit '''/apps'''. Man hofft, diesen Bug bald beheben zu können.
   Hinweis: Durch einen Bug kann es sein, dass das Fenster auf dem Entwicklungs-Server nichts anzeigt. Schließe es einfach und öffne es gleich nochmal mit '''/apps'''. Wir hoffen, diesen Bug bald beheben zu können.


Im Menüpunkt "AppBot" kann man einen [[UserApp-Entwicklung/Doku/AppBot|AppBot]] erstellen und an die UserApp binden. Ein AppBot ist ein bisschen wie [[James|Butler James]], nur eben für die UserApp in dem jeweiligen Channel. Man drückt hierzu auf "hinzufügen" → "Nick anlegen", denkt sich einen Nicknamen aus und bestätigt.
Im Menüpunkt "AppBot" kannst du einen [[UserApp-Entwicklung/Doku/AppBot|AppBot]] erstellen und an deine UserApp binden. Ein AppBot ist ein bisschen wie [[James|Butler James]], nur eben für deine UserApp in deinem Channel. Drücke hierzu auf "hinzufügen" → "Nick anlegen", denk dir einen Nicknamen aus und bestätige.


Man startet jetzt die erste UserApp.
Starte jetzt deine erste UserApp.
   Falls sich kein entsprechendes Fenster öffnet, startet man die UserApp eigenständig, indem man im App-Menü auf '''aktivieren''' klickt.
   Falls sich kein entsprechendes Fenster öffnet, starte die UserApp selbst, indem du im App-Menü auf '''aktivieren''' klickst.
Man verlässt nun den Channel (indem man in einen anderen Channel geht) und betritt ihn dann wieder (z.B. mit '''/go <eigener Channel-Name>'''). Der AppBot sollte das Mitglied jetzt begrüßen!<br>
Verlasse nun deinen Channel (indem du in einen anderen Channel gehst) und betritt ihn dann wieder (z.B. mit '''/go <dein eigener Channel-Name>'''). Dein AppBot sollte dich jetzt begrüßen!<br>


Um mit dem Entwickeln zu starten, macht man mit dem nächsten Schritt weiter (FTP-Setup). Man kann auch schon mal einen Blick in die [http://developer.knuddels.de/docs/ UserApps-API-Dokumentation] werfen.<br>
Um mit dem Entwickeln zu starten, mach mit dem nächsten Schritt weiter (FTP-Setup). Du kannst auch schon mal einen Blick in die [http://developer.knuddels.de/docs/ UserApps-API-Dokumentation] werfen.<br>


Bestimmt wird es auch mal eine Stelle geben, an der man nicht weiter weiß. Zögert nicht, [http://forum.knuddels.de/ubbthreads.php?ubb=postlist&Board=272&page=1 im Forum] Fragen zu stellen, wenn mal etwas nicht klar ist! Die anderen Entwickler sind freundlich, gehen fair miteinander um und helfen sich gerne gegenseitig.
Bestimmt wird es auch mal eine Stelle geben, an der du nicht weiter weißt. Zögere nicht, [http://forum.knuddels.de/ubbthreads.php?ubb=postlist&Board=272&page=1 im Forum] Fragen zu stellen, wenn dir etwas nicht klar ist! Die anderen Entwickler sind freundlich, gehen fair miteinander um und helfen sich gerne gegenseitig.


== FTP-Setup ==
== FTP-Setup ==


Man benötigt für die UserApp-Entwicklung ein FTP-Programm, um die Dateien für die UserApp auf die Server von Knuddels hochzuladen.
Du benötigst für die UserApp-Entwicklung ein FTP-Programm, um die Dateien für deine UserApp auf die Server von Knuddels hochzuladen.


=== Was ist eigentlich FTP? ===
=== Was ist eigentlich FTP? ===


FTP (File Transfer Protocol) ist ein Protokoll, mit dem Daten zwischen zwei Computern im Internet ausgetauscht werden können.<br>
FTP (File Transfer Protocol) ist ein Protokoll, mit dem Daten zwischen zwei Computern im Internet ausgetauscht werden können.<br>
Zum Glück gibt es ganz einfache Programme, die hinter den Kulissen dieses Protokoll sprechen, sodass man die Dateien mit wenigen Klicks hochladen kann.
Zum Glück gibt es ganz einfache Programme, die hinter den Kulissen dieses Protokoll sprechen, sodass du die Dateien mit wenigen Klicks hochladen kannst.


=== Einrichtung des FTP-Zugangs ===
=== Einrichtung des FTP-Zugangs ===


Man wird die Dateien der UserApp auf zwei verschiedenen Servern hochladen:
Du wirst die Dateien deiner UserApp auf zwei verschiedenen Servern hochladen:
# auf dem '''Entwicklungs-Server''', unter der URL '''devappupload.knuddels.de'''
# auf dem '''Entwicklungs-Server''', unter der URL '''devappupload.knuddels.de'''
# auf dem '''Live-Server''', unter der URL '''appupload.knuddels.de'''
# auf dem '''Live-Server''', unter der URL '''appupload.knuddels.de'''


Für beide Server muss man sich jeweils eine Verbindung einrichten. Dafür braucht man ein FTP-Programm.
Für beide Server musst du dir jeweils eine Verbindung einrichten. Dafür brauchst du ein FTP-Programm.
Man schaut sich dazu [https://bitbucket.org/knuddels/user-apps/wiki/Bootstrap/FTP-Setup diese Erklärung] an.<br>
Schau dir dazu [https://bitbucket.org/knuddels/user-apps/wiki/Bootstrap/FTP-Setup diese Erklärung] an.<br>
'''Diese Erklärung zeigt allerdings nur die Verbindung zum Live-Server''' - verwendet für den Entwicklungs-Server stattdessen die URL '''devappupload.knuddels.de'''.<br>
'''Diese Erklärung zeigt allerdings nur die Verbindung zum Live-Server''' - verwende für den Entwicklungs-Server stattdessen die URL '''devappupload.knuddels.de'''.<br>


Als Zugangsdaten verwendet man die Zugangsdaten, die James einem geschickt hat ('''FTP-Nutzer''' und '''FTP-Passwort''').
Als Zugangsdaten verwendest du die Zugangsdaten, die James dir geschickt hat ('''FTP-Nutzer''' und '''FTP-Passwort''').


   Tipp: Man kann die Zugangsdaten aus James' Nachricht mit Shift+Rechtsklick in das Chat-Fenster kopieren.
   Tipp: Du kannst die Zugangsdaten aus James' Nachricht mit Shift+Rechtsklick in das Chat-Fenster kopieren.
   Unter '''/apps developer''' kann man sie außerdem erneut anfordern.
   Unter '''/apps developer''' kannst du sie außerdem erneut anfordern.


Achtet außerdem jeweils darauf, eine '''unverschlüsselte Verbindung''' zu wählen.
Achte außerdem jeweils darauf, eine '''unverschlüsselte Verbindung''' zu wählen.


== Beispiel-Code anschauen ==
== Beispiel-Code anschauen ==


Wenn man weiß, wie man Dateien über den FTP-Zugang von dem Server herunter- und hochladen kann, kann man sich jetzt anschauen, wie eine UserApp aufgebaut ist.<br>
Wenn du weißt, wie du Dateien über den FTP-Zugang von dem Server herunter- und hochladen kannst, kannst du dir jetzt anschauen, wie eine UserApp aufgebaut ist.<br>


Man loggt sich hierzu in dem FTP-Programm auf dem Entwicklungs-Server ein, navigiert in den Ordner '''ftp → HeyThere''' und lädt dort die Datei '''main.js''' herunter. Man kann diese Datei jetzt anschauen, verändern und dann wieder dort hochladen. So versteht man, wie alles funktioniert.<br>
Logge dich in deinem FTP-Programm auf dem Entwicklungs-Server ein, navigiere in den Ordner '''ftp → HeyThere''' und lade dort die Datei '''main.js''' herunter. Du kannst diese Datei jetzt anschauen, verändern und dann wieder dort hochladen. So verstehst du, wie alles funktioniert.<br>


Die '''main.js''' kann man sogar im normalen Texteditor anschauen und bearbeiten.<br>
Die '''main.js''' kannst du sogar im normalen Texteditor anschauen und bearbeiten.<br>
Empfehlenswert ist das aber nicht.
Empfehlenswert ist das aber nicht.
*Auf Windows kann man sich (zum Beispiel) [http://notepad-plus-plus.org/ Notepad++] herunterladen.
*Auf Windows kannst du dir (zum Beispiel) [http://notepad-plus-plus.org/ Notepad++] herunterladen.
* Auf macOS kann man sich (zum Beispiel) [https://itunes.apple.com/de/app/textwrangler/id404010395?mt=12 Textwrangler] herunterladen.
* Auf macOS kannst du dir (zum Beispiel) [https://itunes.apple.com/de/app/textwrangler/id404010395?mt=12 Textwrangler] herunterladen.
Diese Programme können einem das Entwickeln erleichtern. (Natürlich kann man auch eine IDE verwenden, wenn man sich damit auskennt.)<br>
Diese Programme können dir das Entwickeln erleichtern. (Natürlich kannst du auch eine IDE verwenden, wenn du dich damit auskennst.)<br>


Man schaut sich den Code jetzt an und nimmt einige Veränderungen vor.
Schau dir den Code jetzt an und nimm einige Veränderungen vor.


   Idee: Lass den AppBot Besucher abhängig von ihrem Geschlecht begrüßen! Zum Beispiel männliche Besucher mit "Hey Prinz <Nickname>" und weibliche Besucher mit "Hey Prinzessin <Nickname>".  
   Idee: Lass deinen AppBot Besucher abhängig von ihrem Geschlecht begrüßen! Zum Beispiel männliche Besucher mit "Hey Prinz <Nickname>" und weibliche Besucher mit "Hey Prinzessin <Nickname>". Findest du heraus, wie das geht?


→ Jetzt ist ein guter Zeitpunkt, die [https://developer.knuddels.de/docs/ API-Dokumentation] anzuschauen.
→ Jetzt ist ein guter Zeitpunkt, die [https://developer.knuddels.de/docs/ API-Dokumentation] anzuschauen.
Der Aufbau der '''main.js''' wird [https://bitbucket.org/knuddels/user-apps/wiki/Bootstrap/App-Erstellen hier] erklärt.
Der Aufbau der '''main.js''' wird [https://bitbucket.org/knuddels/user-apps/wiki/Bootstrap/App-Erstellen hier] erklärt.


Man geht danach folgendermaßen vor:
Gehe danach folgendermaßen vor:
# Man verändert die Datei und speichert sie.
# Verändere die Datei und speichere sie.
# Man lädt die Datei auf den FTP-Server hoch (ersetzt die alte '''main.js''').
# Lade die Datei auf den FTP-Server hoch (ersetze die alte '''main.js''').
# Man öffnet das App-Menü in dem Channel mit '''/apps''' und drückt auf '''update/restart'''. Die App fährt herunter und startet nach wenigen Sekunden erneut - mit dem neuen Code.
# Öffne das App-Menü in deinem Channel mit '''/apps''' und drücke auf '''update/restart'''. Deine App fährt herunter und startet nach wenigen Sekunden erneut - mit deinem neuen Code.


Im nächsten Schritt wird gezeigt, wie man Besucher abhängig von ihrem Geschlecht begrüßen kann.
Im nächsten Schritt wird gezeigt, wie man Besucher abhängig von ihrem Geschlecht begrüßen kann.
Zeile 99: Zeile 99:




== Begrüßt Besucher abhängig von ihrem Geschlecht ==
== Begrüße Besucher abhängig von ihrem Geschlecht ==


So kann man neuen Besuchern eine Begrüßungsnachricht abhängig von ihrem Geschlecht schicken:
So kannst du neuen Besuchern eine Begrüßungsnachricht abhängig von ihrem Geschlecht schicken:


'''main.js'''
'''main.js'''
Zeile 129: Zeile 129:
</pre>
</pre>


Schafft man es außerdem, die Besucher sowohl abhängig von ihrem Alter, als auch von ihrem Geschlecht zu begrüßen?   
Schaffst du es außerdem, die Besucher sowohl abhängig von ihrem Alter, als auch von ihrem Geschlecht zu begrüßen?   
→ Begrüße Besucher...
→ Begrüße Besucher...
* unter 18 Jahren mit: '''"Hallo Junge <Nickname>"''' bzw. '''"Hallo Mädchen <Nickname>"'''
* unter 18 Jahren mit: '''"Hallo Junge <Nickname>"''' bzw. '''"Hallo Mädchen <Nickname>"'''
Zeile 135: Zeile 135:
* über 60 Jahren mit: '''"Hallo Opa <Nickname>"''' bzw. '''"Hallo Oma <Nickname>"'''
* über 60 Jahren mit: '''"Hallo Opa <Nickname>"''' bzw. '''"Hallo Oma <Nickname>"'''


Man schaut in die [https://developer.knuddels.de/docs/ UserApps-API-Dokumentation], wenn man eine Funktion sucht.
Schau in die [https://developer.knuddels.de/docs/ UserApps-API-Dokumentation], wenn du eine Funktion suchst.
Den fertigen Code kann man sich hier herunterladen: [https://bitbucket.org/knuddels/user-apps/downloads/Beispielcode%20HeyThere%20-%20Stufe%202%20-%20Erweiterung.zip Begrüßung nach Alter und Geschlecht]<br>
Den fertigen Code kannst du dir hier herunterladen: [https://bitbucket.org/knuddels/user-apps/downloads/Beispielcode%20HeyThere%20-%20Stufe%202%20-%20Erweiterung.zip Begrüßung nach Alter und Geschlecht]<br>


Im nächsten Schritt lernt man, wie Besucher '''Knuddel''' an den AppBot transferieren können!
Im nächsten Schritt lernst du, wie Besucher '''Knuddel''' an deinen AppBot transferieren können!


== Knuddel überweisen ==
== Knuddel überweisen ==


Mitglieder können Knuddel an den AppBot überweisen. Diese Knuddel kann man sich dann später auf den eigenen Nick überweisen lassen. Hier lernt man, wie man das in der UserApp machen kann.
Nutzer können Knuddel an deinen AppBot überweisen. Diese Knuddel kannst du dir dann später auf deinen eigenen Nick überweisen lassen. Hier lernst du, wie du das in deiner UserApp machen kannst.


Der AppBot soll jedes neues Mitglied nach einem Knuddel fragen. Wenn er diesen bekommt, bedankt er sich bei dem Mitglied.
Der AppBot soll jeden neuen Nutzer nach einem Knuddel fragen. Wenn er diesen bekommt, bedankt er sich bei dem Nutzer.


   Auf dem Entwicklungs-Server hat der Nick so viele Knuddel, dass man das einfach testen kann.
   Auf dem Entwicklungs-Server hat dein Nick so viele Knuddel, dass du das einfach testen kannst.


'''main.js'''
'''main.js'''
Zeile 166: Zeile 166:
=== Erklärung: Was ist KCode? ===
=== Erklärung: Was ist KCode? ===


In '''App.onUserJoined''' wird dem Mitglied eine Nachricht mit seltsamen Zeichen gesendet:   
In '''App.onUserJoined''' wird dem Nutzer eine Nachricht mit seltsamen Zeichen gesendet:   


   "Gibst du mir _°BB°°>_heinen Knuddel|/appknuddel " + appBotNick.escapeKCode() + "<°°°_?"
   "Gibst du mir _°BB°°>_heinen Knuddel|/appknuddel " + appBotNick.escapeKCode() + "<°°°_?"


Das ist [[Formatierungen|KCode]]. Dieser Code wird vor dem Anzeigen umgewandelt, sodass die Mitglieder einen Link präsentiert bekommen, auf dessen Klick hin ein Befehl ausgeführt wird: Hier ist dieser Befehl '''/appknuddel <Nickname des AppBots>'''. Mit dem Klicken auf den Link überweist das Mitglied also einen Knuddel an den AppBot.
Das ist [[Formatierungen|KCode]]. Dieser Code wird vor dem Anzeigen umgewandelt, sodass die Nutzer einen Link präsentiert bekommen, auf dessen Klick hin ein Befehl ausgeführt wird: Hier ist dieser Befehl '''/appknuddel <Nickname des AppBots>'''. Mit dem Klicken auf den Link überweist der Nutzer also einen Knuddel an den AppBot.


'''appBotNick.escapeKCode()''' dient dazu, dass der Befehl auch bei Sonderzeichen im Nicknamen des AppBots richtig ausgeführt wird.
'''appBotNick.escapeKCode()''' dient dazu, dass der Befehl auch bei Sonderzeichen im Nicknamen deines AppBots richtig ausgeführt wird.


[[Formatierungen|→ Hier kann man sich anschauen, wie KCode funktioniert.]]
[[Formatierungen|→ Hier kannst du dir anschauen, wie KCode funktioniert.]]


   Idee für wahre Kapitalisten: Man kann den Besucher des Channels vielleicht dazu bringen, dem AppBot einen Knuddel zu schenken, wenn der AppBot dem Besucher nach einiger Zeit eine traurige Nachricht schreibt, falls er bis dahin keinen Knuddel von dem Besucher erhalten hat.
   Idee für wahre Kapitalisten: Du kannst den Besucher deines Channels vielleicht dazu bringen, dem AppBot einen Knuddel zu schenken, wenn der AppBot dem Besucher nach einiger Zeit eine traurige Nachricht schreibt, falls er bis dahin keinen Knuddel von dem Besucher erhalten hat.


Eine mögliche Lösung dieses Problems kann man sich hier anschauen: [https://bitbucket.org/knuddels/user-apps/downloads/Beispielcode%20HeyThere%20-%20Stufe%203%20-%20Erweiterung.zip Download Code-Beispiel (Traurige Nachricht vom AppBot)]<br>
Eine mögliche Lösung dieses Problems kannst du dir hier anschauen: [https://bitbucket.org/knuddels/user-apps/downloads/Beispielcode%20HeyThere%20-%20Stufe%203%20-%20Erweiterung.zip Download Code-Beispiel (Traurige Nachricht vom AppBot)]<br>


Im nächsten Schritt lernt man, wie man dauerhaft Daten über die Besucher speichern kann.
Im nächsten Schritt lernst du, wie du dauerhaft Daten über deine Besucher speichern kannst.


== UserPersistence: Nutzerdaten speichern ==
== UserPersistence: Nutzerdaten speichern ==


Wenn man sich beispielsweise dauerhaft merken will, wie viele Knuddel ein Mitglied jeweils schon an den AppBot überwiesen hat, braucht man eine Möglichkeit, zu jedem Mitglied eine Zahl zu speichern.<br>
Wenn du dir beispielsweise dauerhaft merken willst, wie viele Knuddel ein Nutzer jeweils schon deinem AppBot überwiesen hat, brauchst du eine Möglichkeit, zu jedem Nutzer eine Zahl zu speichern.<br>


   Allerdings kann man nicht einfach eine Variable in demCode haben, worüber man alles speichert - das wäre nämlich mit jedem Neustart der App wieder weg.
   Allerdings kannst du nicht einfach eine Variable in deinem Code haben, worüber du alles speicherst - das wäre nämlich mit jedem Neustart der App wieder weg.


In der [https://developer.knuddels.de/docs/ UserApps-API] gibt es genau dafür das Objekt [https://developer.knuddels.de/docs/classes/UserPersistence.html UserPersistence].
In der [https://developer.knuddels.de/docs/ UserApps-API] gibt es genau dafür das Objekt [https://developer.knuddels.de/docs/classes/UserPersistence.html UserPersistence].
Zeile 217: Zeile 217:
</pre>
</pre>


Die App merkt sich nun, wie viele Knuddel die Besucher bereits eingezahlt haben. Besonders gönnerische Besucher begrüßt er ehrerbietig!
Die App merkt sich nun, wie viele Knuddel deine Besucher bereits eingezahlt haben. Besonders gönnerische Besucher begrüßt er ehrerbietig!


== Der Fortschitt ==
== Dein Fortschitt ==


'''Man ist schon weit gekommen!'''
'''Du bist schon weit gekommen!'''


* Man hat gelernt, wie man sich auf dem Entwicklungs-Server anmeldet und eine App installiert.
* Du hast gelernt, wie man sich auf dem Entwicklungs-Server anmeldet und eine App installiert.
* Man hat sich mit FTP vertraut gemacht und kann die Dateien jetzt einfach an den Knuddels-Server senden.
* Du hast dich mit FTP vertraut gemacht und kannst deine Dateien jetzt einfach an den Knuddels-Server senden.
* Man weiß jetzt, wie man auf verschiedene Events in dem Channel reagiert.
* Du weißt jetzt, wie man auf verschiedene Events in deinem Channel reagiert.
* Man ist mit der Überweisung von Knuddel an den AppBot vertraut.
* Du bist mit der Überweisung von Knuddel an deinen AppBot vertraut.
* Man kann sich Daten über die Besucher dauerhaft speichern.
* Du kannst Daten über deine Besucher dauerhaft speichern.


Jetzt kann man die UserApp mal veröffentlichen! Dazu muss man die UserApp per FTP auf dem Live-Server hochladen - so wie schon vorher auf dem Entwicklungs-Server. Hierzu meldet man sich dann ganz normal bei Knuddels an und installiert die UserApp mit '''/apps install <UserApp-Name>''' in dem jeweiligen MyChannel.<br>
Jetzt kannst du deine UserApp mal veröffentlichen! Dazu musst du deine UserApp per FTP auf dem Live-Server hochladen - so wie schon vorher auf dem Entwicklungs-Server. Melde dich dann ganz normal bei Knuddels an und installiere deine UserApp mit '''/apps install <UserApp-Name>''' in deinem MyChannel.<br>


Und wenn man jetzt noch den MyChannel unter '''/mychannel''' veröffentlicht, können auch andere Mitglieder zufällig auf den MyChannel stoßen.<br>
Und wenn du jetzt noch deinen MyChannel unter '''/mychannel''' veröffentlichst, können auch andere Nutzer zufällig auf deinen MyChannel stoßen.<br>


== Wie geht's weiter? ==
== Wie geht's weiter? ==


Vielleicht hat man nun Lust, ein grafisches Spiel zu programmieren? Oder ein textbasiertes RPG?<br>
Vielleicht hast du Lust, ein grafisches Spiel zu programmieren? Oder ein textbasiertes RPG?<br>
Ab jetzt ist man sich selbst überlassen - und man kann sich natürlich jederzeit an die Community wenden.<br>
Ab jetzt bist du dir selbst überlassen - und kannst dich natürlich jederzeit an die Community wenden.<br>
Auf dem Entwickler-Portal [https://developer.knuddels.de/ developer.knuddels.de] findet man das meiste im Zusammenhang mit UserApps.
Auf dem Entwickler-Portal [https://developer.knuddels.de/ developer.knuddels.de] findest du das meiste im Zusammenhang mit UserApps.


[[UserApp-Entwicklung|→ Übersicht: UserApp-Entwicklung]]
[[UserApp-Entwicklung|→ Übersicht: UserApp-Entwicklung]]


[[Kategorie:UserApp-Entwicklung]]
[[Kategorie:UserApp-Entwicklung]]

Aktuelle Version vom 10. Oktober 2021, 12:16 Uhr

Einleitung

In diesem Tutorial lernst du Schritt für Schritt, deine erste UserApp zu programmieren.
Hier geht es darum, erstmal alles zum Laufen zu bringen und ein paar Basics zu vermitteln, sodass ab dann selbstständig weiterentwickelt werden kann.

Bevor es losgeht

Werde Entwickler

Stelle sicher, dass du ein Entwickler bist. Gib dazu /apps developer im Chat ein und erfülle die Kriterien, falls du das noch nicht getan hast.

Verwende die Desktop-App

Wir empfehlen dir stark, zum Entwickeln die Desktop-App auf deinem Computer zu verwenden. Du kannst die App hier herunterladen.

Die erste UserApp

Entwicklungs-Server

Das Entwickeln beginnt auf dem Entwicklungs-Server. Gib /apps developer ein und wähle den Punkt Login auf Entwicklungs-Server aus. Jetzt sollte eine Desktop-Verknüpfung für den Login auf dem Entwicklungs-Server angelegt worden sein.
Wenn du Knuddels über diese Verknüpfung startest, landest du nach dem Login auf dem Entwicklungs-Server. Hier kannst du später in Ruhe an deiner UserApp tüfteln, bevor du deine Änderungen auf dem Live-Server hochlädst.

Logge dich jetzt mit den Zugangsdaten auf dem Entwicklungsserver ein, die dir James gesendet hat (Entwickler-Nick und Entwickler-Passwort).

 Tipp: Du kannst die Zugangsdaten aus James' Nachricht mit Shift+Rechtsklick in das Chat-Fenster kopieren.

MyChannel

Nach dem Einloggen sollte sich automatisch das MyChannel-Edit Fenster öffnen. Ansonsten gib /mychannel ein.
Du legst dir jetzt einen eigenen Channel an, in dem du gleich deine erste UserApp installieren wirst. Eine Info zu den Einstellungen erhältst du durch Klicken auf den Titel des jeweiligen Feldes. Außer über deinen Channel-Namen musst du dir aber erstmal keine Gedanken machen (du kannst dieses Fenster jederzeit wieder mit /mychannel öffnen). Drücke anschließend auf Speichern und Schließen und betritt deinen MyChannel mit /go <dein eigener Channel-Name>.

Installation der UserApp

Für dieses Tutorial haben wir dir schon Dateien für eine Beispiel-UserApp namens "HeyThere" auf den Server geladen. Installiere diese UserApp in deinem MyChannel mit /apps install HeyThere. Du kannst die UserApp später wieder aus deinem Channel löschen.

Es müsste sich nun automatisch das Konfigurationsfenster für die UserApp geöffnet haben. Ansonsten öffne es selbst mit /apps und klicke auf den Namen der UserApp ("HeyThere").

 Hinweis: Durch einen Bug kann es sein, dass das Fenster auf dem Entwicklungs-Server nichts anzeigt. Schließe es einfach und öffne es gleich nochmal mit /apps. Wir hoffen, diesen Bug bald beheben zu können.

Im Menüpunkt "AppBot" kannst du einen AppBot erstellen und an deine UserApp binden. Ein AppBot ist ein bisschen wie Butler James, nur eben für deine UserApp in deinem Channel. Drücke hierzu auf "hinzufügen" → "Nick anlegen", denk dir einen Nicknamen aus und bestätige.

Starte jetzt deine erste UserApp.

 Falls sich kein entsprechendes Fenster öffnet, starte die UserApp selbst, indem du im App-Menü auf aktivieren klickst.

Verlasse nun deinen Channel (indem du in einen anderen Channel gehst) und betritt ihn dann wieder (z.B. mit /go <dein eigener Channel-Name>). Dein AppBot sollte dich jetzt begrüßen!

Um mit dem Entwickeln zu starten, mach mit dem nächsten Schritt weiter (FTP-Setup). Du kannst auch schon mal einen Blick in die UserApps-API-Dokumentation werfen.

Bestimmt wird es auch mal eine Stelle geben, an der du nicht weiter weißt. Zögere nicht, im Forum Fragen zu stellen, wenn dir etwas nicht klar ist! Die anderen Entwickler sind freundlich, gehen fair miteinander um und helfen sich gerne gegenseitig.

FTP-Setup

Du benötigst für die UserApp-Entwicklung ein FTP-Programm, um die Dateien für deine UserApp auf die Server von Knuddels hochzuladen.

Was ist eigentlich FTP?

FTP (File Transfer Protocol) ist ein Protokoll, mit dem Daten zwischen zwei Computern im Internet ausgetauscht werden können.
Zum Glück gibt es ganz einfache Programme, die hinter den Kulissen dieses Protokoll sprechen, sodass du die Dateien mit wenigen Klicks hochladen kannst.

Einrichtung des FTP-Zugangs

Du wirst die Dateien deiner UserApp auf zwei verschiedenen Servern hochladen:

  1. auf dem Entwicklungs-Server, unter der URL devappupload.knuddels.de
  2. auf dem Live-Server, unter der URL appupload.knuddels.de

Für beide Server musst du dir jeweils eine Verbindung einrichten. Dafür brauchst du ein FTP-Programm. Schau dir dazu diese Erklärung an.
Diese Erklärung zeigt allerdings nur die Verbindung zum Live-Server - verwende für den Entwicklungs-Server stattdessen die URL devappupload.knuddels.de.

Als Zugangsdaten verwendest du die Zugangsdaten, die James dir geschickt hat (FTP-Nutzer und FTP-Passwort).

 Tipp: Du kannst die Zugangsdaten aus James' Nachricht mit Shift+Rechtsklick in das Chat-Fenster kopieren.
 Unter /apps developer kannst du sie außerdem erneut anfordern.

Achte außerdem jeweils darauf, eine unverschlüsselte Verbindung zu wählen.

Beispiel-Code anschauen

Wenn du weißt, wie du Dateien über den FTP-Zugang von dem Server herunter- und hochladen kannst, kannst du dir jetzt anschauen, wie eine UserApp aufgebaut ist.

Logge dich in deinem FTP-Programm auf dem Entwicklungs-Server ein, navigiere in den Ordner ftp → HeyThere und lade dort die Datei main.js herunter. Du kannst diese Datei jetzt anschauen, verändern und dann wieder dort hochladen. So verstehst du, wie alles funktioniert.

Die main.js kannst du sogar im normalen Texteditor anschauen und bearbeiten.
Empfehlenswert ist das aber nicht.

  • Auf Windows kannst du dir (zum Beispiel) Notepad++ herunterladen.
  • Auf macOS kannst du dir (zum Beispiel) Textwrangler herunterladen.

Diese Programme können dir das Entwickeln erleichtern. (Natürlich kannst du auch eine IDE verwenden, wenn du dich damit auskennst.)

Schau dir den Code jetzt an und nimm einige Veränderungen vor.

 Idee: Lass deinen AppBot Besucher abhängig von ihrem Geschlecht begrüßen! Zum Beispiel männliche Besucher mit "Hey Prinz <Nickname>" und weibliche Besucher mit "Hey Prinzessin <Nickname>". Findest du heraus, wie das geht?

→ Jetzt ist ein guter Zeitpunkt, die API-Dokumentation anzuschauen. Der Aufbau der main.js wird hier erklärt.

Gehe danach folgendermaßen vor:

  1. Verändere die Datei und speichere sie.
  2. Lade die Datei auf den FTP-Server hoch (ersetze die alte main.js).
  3. Öffne das App-Menü in deinem Channel mit /apps und drücke auf update/restart. Deine App fährt herunter und startet nach wenigen Sekunden erneut - mit deinem neuen Code.

Im nächsten Schritt wird gezeigt, wie man Besucher abhängig von ihrem Geschlecht begrüßen kann.


Begrüße Besucher abhängig von ihrem Geschlecht

So kannst du neuen Besuchern eine Begrüßungsnachricht abhängig von ihrem Geschlecht schicken:

main.js

var App = (new function() {

    this.onUserJoined = function(user) {  // diese Funktion wird aufgerufen, wenn ein Nutzer den Channel betritt

        let gender = user.getGender();
        let nick  = user.getNick();
        let title;

        if (gender == Gender.Male) {
            title = "Prinz " + nick;
        } else if (gender == Gender.Female) {
            title = "Prinzessin " + nick;
        } else {  // der Nutzer hat sich nicht als männlich oder weiblich ausgegeben
            title = nick;
        }

        let message = "Hey " + title + ", willkommen im Channel! Du bist " + user.getAge() + " Jahre alt.";
        user.sendPrivateMessage(message);  // der AppBot sendet eine private Nachricht an den Nutzer
    }
}());

Schaffst du es außerdem, die Besucher sowohl abhängig von ihrem Alter, als auch von ihrem Geschlecht zu begrüßen? → Begrüße Besucher...

  • unter 18 Jahren mit: "Hallo Junge <Nickname>" bzw. "Hallo Mädchen <Nickname>"
  • zwischen 18 und 60 Jahren mit: "Hallo Herr <Nickname>" bzw. "Hallo Frau <Nickname>"
  • über 60 Jahren mit: "Hallo Opa <Nickname>" bzw. "Hallo Oma <Nickname>"

Schau in die UserApps-API-Dokumentation, wenn du eine Funktion suchst. Den fertigen Code kannst du dir hier herunterladen: Begrüßung nach Alter und Geschlecht

Im nächsten Schritt lernst du, wie Besucher Knuddel an deinen AppBot transferieren können!

Knuddel überweisen

Nutzer können Knuddel an deinen AppBot überweisen. Diese Knuddel kannst du dir dann später auf deinen eigenen Nick überweisen lassen. Hier lernst du, wie du das in deiner UserApp machen kannst.

Der AppBot soll jeden neuen Nutzer nach einem Knuddel fragen. Wenn er diesen bekommt, bedankt er sich bei dem Nutzer.

 Auf dem Entwicklungs-Server hat dein Nick so viele Knuddel, dass du das einfach testen kannst.

main.js

var App = (new function() {

    this.onUserJoined = function(user) {
        var appBotNick = KnuddelsServer.getDefaultBotUser().getNick();
        var message = "Gibst du mir _°BB°°>_heinen Knuddel|/appknuddel " + appBotNick.escapeKCode() + "<°°°_?";
        user.sendPrivateMessage(message);
    }

    this.onKnuddelReceived = function(sender, receiver, knuddelAmount, transferReason) {
        sender.sendPrivateMessage("Danke, " + sender.getNick() + "!");
    }
}());

Erklärung: Was ist KCode?

In App.onUserJoined wird dem Nutzer eine Nachricht mit seltsamen Zeichen gesendet:

 "Gibst du mir _°BB°°>_heinen Knuddel|/appknuddel " + appBotNick.escapeKCode() + "<°°°_?"

Das ist KCode. Dieser Code wird vor dem Anzeigen umgewandelt, sodass die Nutzer einen Link präsentiert bekommen, auf dessen Klick hin ein Befehl ausgeführt wird: Hier ist dieser Befehl /appknuddel <Nickname des AppBots>. Mit dem Klicken auf den Link überweist der Nutzer also einen Knuddel an den AppBot.

appBotNick.escapeKCode() dient dazu, dass der Befehl auch bei Sonderzeichen im Nicknamen deines AppBots richtig ausgeführt wird.

→ Hier kannst du dir anschauen, wie KCode funktioniert.

 Idee für wahre Kapitalisten: Du kannst den Besucher deines Channels vielleicht dazu bringen, dem AppBot einen Knuddel zu schenken, wenn der AppBot dem Besucher nach einiger Zeit eine traurige Nachricht schreibt, falls er bis dahin keinen Knuddel von dem Besucher erhalten hat.

Eine mögliche Lösung dieses Problems kannst du dir hier anschauen: Download Code-Beispiel (Traurige Nachricht vom AppBot)

Im nächsten Schritt lernst du, wie du dauerhaft Daten über deine Besucher speichern kannst.

UserPersistence: Nutzerdaten speichern

Wenn du dir beispielsweise dauerhaft merken willst, wie viele Knuddel ein Nutzer jeweils schon deinem AppBot überwiesen hat, brauchst du eine Möglichkeit, zu jedem Nutzer eine Zahl zu speichern.

 Allerdings kannst du nicht einfach eine Variable in deinem Code haben, worüber du alles speicherst - das wäre nämlich mit jedem Neustart der App wieder weg.

In der UserApps-API gibt es genau dafür das Objekt UserPersistence.

main.js

var App = (new function() {

    this.onUserJoined = function(user) {

        let userPersistence = user.getPersistence();
        let userSpending = userPersistence.getNumber("spending", 0);

        if (userSpending > 10) {
            user.sendPrivateMessage("Willkommen, gütiger Spender!");
        }

        var appBotNick = KnuddelsServer.getDefaultBotUser().getNick();
        var message = "Gibst du mir _°BB°°>_heinen Knuddel|/appknuddel " + appBotNick.escapeKCode() + "<°°°_?";
        user.sendPrivateMessage(message);
    }

    this.onKnuddelReceived = function(sender, receiver, knuddelAmount, transferReason) {
        sender.sendPrivateMessage("Danke, " + sender.getNick() + "!");

        let userPersistence = sender.getPersistence();
        userPersistence.addNumber("spending", knuddelAmount.asNumber());
    }
}());

Die App merkt sich nun, wie viele Knuddel deine Besucher bereits eingezahlt haben. Besonders gönnerische Besucher begrüßt er ehrerbietig!

Dein Fortschitt

Du bist schon weit gekommen!

  • Du hast gelernt, wie man sich auf dem Entwicklungs-Server anmeldet und eine App installiert.
  • Du hast dich mit FTP vertraut gemacht und kannst deine Dateien jetzt einfach an den Knuddels-Server senden.
  • Du weißt jetzt, wie man auf verschiedene Events in deinem Channel reagiert.
  • Du bist mit der Überweisung von Knuddel an deinen AppBot vertraut.
  • Du kannst Daten über deine Besucher dauerhaft speichern.

Jetzt kannst du deine UserApp mal veröffentlichen! Dazu musst du deine UserApp per FTP auf dem Live-Server hochladen - so wie schon vorher auf dem Entwicklungs-Server. Melde dich dann ganz normal bei Knuddels an und installiere deine UserApp mit /apps install <UserApp-Name> in deinem MyChannel.

Und wenn du jetzt noch deinen MyChannel unter /mychannel veröffentlichst, können auch andere Nutzer zufällig auf deinen MyChannel stoßen.

Wie geht's weiter?

Vielleicht hast du Lust, ein grafisches Spiel zu programmieren? Oder ein textbasiertes RPG?
Ab jetzt bist du dir selbst überlassen - und kannst dich natürlich jederzeit an die Community wenden.
Auf dem Entwickler-Portal developer.knuddels.de findest du das meiste im Zusammenhang mit UserApps.

→ Übersicht: UserApp-Entwicklung