- Course: Real-Time Web
- Minor: Web Design and Development (*login required)
- Course Coordinator: Justus Sturkenboom (@ju5tu5)
- Minor Coordinator(s): Joost Faber (@joostf) Koop Reynders (@KoopReynders)
- Lecturers: Justus Sturkenboom (@ju5tu5) & Lukas van Driel (@lukasvan3l)
- Student Assistants: Robin (@) & Wouter (@)
- Credit: 3 ECTS credits
- Academic year: 2020-2021
- Programme: Communication and Multimedia Design (full time bachelor)
- Language: Dutch instructions and English resources
During this course you will learn how to build a real-time application. You will learn techniques to setup an open connection between the client and the server. This will enable you to send data in real-time both ways, at the same time.
If you have questions:
- Look at the additional resources
- Use a search engine like startpage
- Ask questions on MS Teams (please help each other!)
- Contact a student-assisstant
- Contact a lecturer
After finishing this program you can:
- deal with real-time complexity;
- handle real-time client-server interaction;
- handle real-time data management;
- handle multi-user support.
Your efforts will be graded using a single point rubric (see below). You will have to pass the criterion (centre column) to pass the course. During the test you will be consulted and will be given feedback on things we think deficient and things we think are an improvement on the criterion.
Deficiency | Criterion | Improvement |
---|---|---|
Project Your app is working and published on Heroku. Your project is thoroughly documented in the README.md file in your repository. Included are a description of the data-lifecycle, real-time events and external data source used by your app. |
||
Complexity You’ve implemented enough real-time functionality for us to test your comprehension of the subject. A lot of functionality is self-written. You are able to manipulate online examples live. | ||
Client-server interaction By interacting with the app, a user can influence the data model of the server in real time by directly modifying data OR by influencing API requests between server and source. The student has set up the data manipulations. | ||
Data management The server maintains a data model and each client is continuously updated with the correct data. | ||
Multi-user support Multiple clients can connect to the server. Interaction works as expected and is not dependent on the number of clients. You can explain how your app approaches this. |
To keep things simple we use a daily schedule that will be used during normal course days. We make exceptions for checkups and assessments, on these days a different schedule will be given.
Time | Who | Activity |
---|---|---|
~09:00 | (Lukas, Justus, Robin, Wouter) | Standup |
09:30 | Tribe +(Lukas, Justus, Robin, Wouter) | Talk with crucial information (make sure you attend!) |
11:00 | Teams in MS Teams: (ex. R2D2 Team A) | Work on the (day)assignment |
Squad R2D2 Team B +(Justus, Wouter) | Standup | |
Squad SQUID Team B +(Lukas, Robin) | Standup | |
11:30 | Squad R2D2 Team C +(Justus, Wouter) | Standup |
Squad SQUID Team C +(Lukas, Robin) | Standup | |
12:00 | Squad R2D2 Team A +(Justus, Wouter) | Standup |
Squad SQUID Team A +(Lukas, Robin) | Standup | |
13:00 | Tribe +(Robin, Wouter) | Continue work on the (day)assignment |
16:00 | Squad R2D2 Team B +(Wouter) | Standup |
Squad SQUID Team B +(Robin) | Standup | |
16:15 | Squad R2D2 Team C +(Wouter) | Standup |
Squad SQUID Team C +(Robin) | Standup | |
16:30 | Squad R2D2 Team A +(Wouter) | Standup |
Squad SQUID Team A +(Robin) | Standup |
Goal: Build and deploy a simple but unique real-time app
Talk subjects: Hit the ground running... (slides) Course objective and explanation of the assignment, examples from last year, explanation of real-time, (live coded) bare bone chat app and deployment on Heroku.
Day assignment: (assignment) Make it so (as a team): Implement (code/style/discuss/deploy) basic chat (or other realtime) functionality on your teampage!
Talk subjects: My first realtime web app! (slides) Short recap, (local) data management, using (wire) flows for realtime web apps, (live coded) multi-user woordzoeker.
Day assignment: (assignment) Make it so (individually). i) Create (code/style/discuss/deploy) a chat app (or other realtime functionality) based on the examples and ii) add your own unique feature!
Goal: Store, manipulate and share data between server-client
Talk subjects: Data driven development?! (slides) Gastcollege Thijs Spijker Feedback about last week, final assignment and conditions (rubric), explanation of data management, (live coded) Long polling vs Websockets.
Day assignment: (assignment) (Proof of) Concept (individually). i) Create a (3 > 1) concept based on existing data from an API and ii) map this data using modelling techniques.
Talk subjects: Above all else, show the data. (slides) Securing real-time web apps, offline support, the publication/subscription model and (case study) Quek!
Day assignment: (assignment) Proof of concept (individually): i) Create (code/style/discuss/deploy) part of the core functionality for your concept and ii) show the corresponding data lifecycle diagram.
Instead of our talk we will have a peer review session. You will read, comment and fire issues on each others code. Doing this is really good for your programming insight and helps others refining/refactoring their code.
Time | Who | Activity |
---|---|---|
09:30 | Tribe +(Lukas, Justus, Robin, Wouter) | Peer review |
10:30 | Squad R2D2 Team B.1 +(Justus) | Checkup |
Squad R2D2 Team B.2 +(Wouter) | Checkup | |
Squad SQUID Team B.1 +(Lukas) | Checkup | |
Squad SQUID Team B.2 +(Robin) | Checkup | |
11:00 | Squad R2D2 Team C.1 +(Justus) | Checkup |
Squad R2D2 Team C.2 +(Wouter) | Checkup | |
Squad SQUID Team C.1 +(Lukas) | Checkup | |
Squad SQUID Team C.2 +(Robin) | Checkup | |
11:30 | Squad R2D2 Team A.1 +(Justus) | Checkup |
Squad R2D2 Team A.2 +(Wouter) | Checkup | |
Squad SQUID Team A.1 +(Lukas) | Checkup | |
Squad SQUID Team A.2 +(Robin) | Checkup |
Goal: Handle data sharing and multi-user support
Talk subjects: Roll your own... (slides) Data management, the functional programming trinity (map, filter and reduce). OAuth?! Day assignment: (assignment)
Talk subjects: Not ignoring the UI-Stack! (slides). Usability, feedback, feedforward etc. in real-time web apps, (case study) postNL loader and FAQ. Day assignment: (assignment)
We will have our final peer review session. You will read, comment and fire issues on each others code. Doing this helps others dotting the i’s on their project.
Time | Who | Activity |
---|---|---|
09:30 | Tribe +(Lukas, Justus, Robin, Wouter) | Peer review |
10:30 | Squad R2D2 Team B.1 +(Justus) | Checkup |
Squad R2D2 Team B.2 +(Wouter) | Checkup | |
Squad SQUID Team B.1 +(Lukas) | Checkup | |
Squad SQUID Team B.2 +(Robin) | Checkup | |
11:00 | Squad R2D2 Team C.1 +(Justus) | Checkup |
Squad R2D2 Team C.2 +(Wouter) | Checkup | |
Squad SQUID Team C.1 +(Lukas) | Checkup | |
Squad SQUID Team C.2 +(Robin) | Checkup | |
11:30 | Squad R2D2 Team A.1 +(Justus) | Checkup |
Squad R2D2 Team A.2 +(Wouter) | Checkup | |
Squad SQUID Team A.1 +(Lukas) | Checkup | |
Squad SQUID Team A.2 +(Robin) | Checkup |
Goal: Assess and wrap-up the course!
09.30 [Lukas, Justus] Assessments (scheduled) SQUID A.1/B.1/C.1 and R2D2 A.1/B.1/C.1
09.30 [Lukas, Justus] Assessments (scheduled) SQUID A.2/B.2/C.2 and R2D2 A.2/B.2/C.2
15.00 [Everyone] Wrap-up for the course. (drinks?!)