The first part of this assignment gives you hands-on experience in HTTP. In the second part you will make a head start with the design of your board game web application (which you will further develop in assignments 2 and 3).
Remember that this is a group assignment!
Enroll yourself into a group on Brightspace: head to Collaboration>>Groups and self-enroll into an available group; we have set up 500 groups in total. Pick a group and let your team member know the group name (e.g. CSE1 88), so both of you enroll into the same group. Whether you pick a group in the CSE1*/CSE2*/../CSE5* cluster does not matter; this is simply a way to get around the Brightspace restriction allowing only so many groups under the same category name.
Work efficiently as a team! If you have not programmed as a team before, read up on our introduction to Visual Studio Code. Use this assignment to set up a collaborative coding environment within your team. Assignment 2 will require extensive JavaScript programming that requires both team members to contribute.
If you get lost within the assignment, use this overview of deliverables to get back on track!
Task | Deliverables |
---|---|
1.1 | HTTP requests |
1.2 | Answer Q1.2 |
1.3 | Answer Q1.3 |
1.4 | Answer Q1.4 |
2.1 | Answer Q2.1 |
3.1 | Answer Q3.1 |
3.2 | Answer Q3.2 |
4.1 | Chosen game type |
4.2 | Four annotated game screens (include the game URL) |
4.3 | Description of six game features |
5.1 | Splash screen design (wireframe) |
5.2 | Game screen design (wireframe) |
5.3 | →→→ upload 5.1/5.2 to 💡 Brightspace forum |
6 | Two html files |
All deliverable text/imagery (apart from 6.) must be included in a single PDF file. The first page of this PDF must contain the names and student numbers of the two team members as well as the team name.
Submit your two html files in the form of a zipped folder.
The PDF and code have to be uploaded by one of the team members to 💡 Brightspace under CSE Web assessment (find the category your group belongs too) before the assessment session with the TAs. This means that the outcomes of Assignment 1, 2 and 3 are all uploaded to the same directory! Make sure to name your files with an A1 prefix!
To pass this assignment, you must have completed all tasks and be able to answer the questions of the TAs.
👉 Hints:
-
To store
telnet
's output to file (in addition to printing it on the console), you can use the commandtee
, e.g.telnet www.microsoft.com 80|tee out
will save all output to a file calledout
. -
Carriage return in the code snippets below indicates when an empty line is expected. Press
<Enter>
to add it. -
Be aware of the backspace key when telneting: while on a normal command line a backspace deletes the last character typed, within the
telnet
environment this key is forwarded to the server instead. In other words: do not use the backspace key when telneting. -
This exercise requires you to use
telnet
. If you use a Linux derivative (e.g. Ubuntu, older versions of Mac OS), open a terminal and you are good to go; for new Mac OS versions you may need to install telnet yourself. -
If you are a Windows user, use the Windows Subsystem for Linux or use the Virtual Machine provided to you in Q1 (the
root
password iscse&(]]
). The Virtual Machine can be downloaded using the following magnet link:magnet:?xt=urn:btih:83a92d258af74cb6b22d3e64ce26c38f6ca57416&dn=TUD-CSE-2018-2019.ova&tr=udp%3A%2F%2Ftracker.open-internet.nl%3A6969%2Fannounce
. As an alternative (if you really do not want to use Linux and stick to Windows), use Putty with the following settings:- Use the "Raw" connection type (not "Telnet").
- For "Close window on exit", use "Never".
- It may be useful to write your commands inside an editor first, and paste them by clicking the right mouse button inside the Putty session (which you start using the "Open" button).
Exercise:
Use telnet
to request the contents of the Dutch rainfall radar section of the weer.nl
website: weer.nl/regenradar/nederland. Start your conversation with the web server by typing the following into the terminal, and then perform HTTP requests to fetch the contents:
telnet weer.nl 80
Write down the HTTP requests you made, the returned responses (e.g. a page has moved or is faulty) until you receive the contents of the Dutch rainfall radar page. Always use HEAD
first to retrieve meta-data about the resource.
Does the content correspond to what you see when accessing the page with your browser? To check, save the response to a file, use .html
as file ending and open it with your browser.
What is the purpose of the X-UA-Compatible
or the X-Cache
tag in the header information (you should have seen one of the two or both - if you saw both, pick one to explain)?
Note: 1.3) amended November 16, 2018
What does the page's Cache-Control
directive mean?
While GET
and HEAD
are request methods accepted by virtually all web servers, PUT
, POST
and DELETE
are less often available, due to the implications these methods have on the server.
To test your skills in uploading data, we will make use of http://httpbin.org/, a service designed to test HTTP messages.
Below is an example of how to upload data to the server with PUT
:
telnet httpbin.org 80
PUT /put HTTP/1.1
host:httpbin.org
Content-type:text/plain
Content-length:12
<carriage return>
Hello World!
<carriage return>
Reminder: Carriage return in the code snippets indicates when an empty line is expected. Press <Enter>
to add it.
With this code, we have modified the resource accessible at /put
to now hold the string Hello World!
. The server sends back in the response the data just uploaded - the response is of content-type JSON; we are interested in the data
field, which should contain Hello World!
if everything worked correctly. Try it for yourself!
PUT
though is not only able to modify an existing resource, it can also create a resource on the server. The status code in the response tells us whether a resource was modified (200 OK
) or created (201 Create
). More information can be found on MDN. If you try to replace /put
in this exercise with another resource (e.g. /myfile
) you will see a 503 Service Unavailable
error: this server allows the modification of the resource accessible at /put
but not the creation of a new resource.
The Content-length
is exactly the number of characters (12 - we count the whitespace as well!) of Hello World!
. What happens if the Content-length
field is smaller or larger than the exact number of characters in the content?
Let us now try to request a page, that is set up with HTTP basic authentication.
First, open http://httpbin.org/basic-auth/user/passwd in your browser. You should see a dialogue, requesting username and password. Use user
as username and passwd
as password (it is just a coincidence that the actual username and password is the same as the URL path). Reload the web page - what happens now?
Now let's see how this works with actual HTTP messages. Start off with a HEAD
method to inspect the web page and document all following steps (requests and responses):
telnet httpbin.org 80
HEAD /basic-auth/user/passwd HTTP/1.1
host:httpbin.org
<carriage return>
Which status code do you receive now? Next, use the Authorization: Basic [base-64 encoded username/password string]
header field to provide username and password to the server. To encode the username and password, you can use any of the freely available base-64 en/decoders, e.g. https://codebeautify.org/base64-encode.
Remember that username and password need to be combined as username:password
before they are encoded in base-64.
Now close the TCP connection and start a new one, using again:
telnet httpbin.org 80
Request the same page - what happens? Is the behavior the same as reloading the page in the browser? Explain why / why not.
In this, and the upcoming two assignments, you will complete a web programming project. This year, this is the implementation of a classic board game.
The images above should serve as a first inspiration, you are by no means required to design your game board according to these examples.
You can choose from nine games:
- Ludo: 2-4 players
- Draughts: 2 players
- Chess - there are many variants available besides the default, pick one: 2-4 players depending on the variant
- Snakes and Ladders: 2-4 players
- Mastermind: 2 players
- Scrabble: 2-4 players
- Battleship: 2 players
- Reversi: 2 players
- Backgammon: 2 players
At the end of the three web assignments, your board game application will have the following functionalities:
- The game is for 2-4 players and in 2D.
- The game works in at least two major browsers (e.g. Firefox and Chrome).
- It works well in a modern browser used on a laptop/desktop device, i.e. we are considering screen resolutions of ~1366x768 or higher. In this project, we are not concerned about apps for mobile devices.
- Upon entering your web application's URL, a splash screen is shown that allows a user to see some statistics of the game (how many games are currently ongoing, how many users have started a game, etc. - pick three statistics you want to report), a brief description of how-to-play on your platform and a Play button (or something to that effect).
- Upon pressing Play, the user enters the game screen and waits for a sufficient number of other gamers to start playing. It is clear for the player that s/he is waiting for more players to enter the game.
- Once there are sufficiently many players, the game automatically starts and the players play against each other. Multiple games can take place at the same time.
- The splash and game screens need to look good (adhere to modern design standards); all required game elements need to be visible (e.g. if a game requires a dice, a dice element needs to be visible).
- Once a player makes a move, the validity of the move is checked and invalid moves are rejected. Once a player wins the game, this information is announced to all players participating in the game.
- Players see basic information about the ongoing game, e.g. the time passed since starting the game or number of lost/won pieces.
- Players are able to play the game in fullscreen mode.
- Players play the game with the mouse.
- Once a player drops out of a game, the game is aborted; this is announced to all players currently active in the game.
- Moves are animated (this can be as simple as changing the color of a token/piece) and have sound effects.
The list above should tell you that you have considerable (artistic) freedom. In each assignment, you are given a set of requirements (e.g. here are the three types of CSS rules you need to employ in your code).
The caveat is that no external libraries or frameworks are allowed, apart from jQuery. We allow jQuery
as it is used in the web course book; you can use it too, but are not required to.
Optionally: if you have incorporated the requirements listed above without any additional libraries/framework besides jQuery
and you want to keep improving your application by adding additional functionalities, you can indeed incorporate existing libraries/frameworks. Make sure to document clearly where in your code you employ them. The obvious next step to improve your app is the inclusion of a semi-intelligent computer opponent: while for the game of Ludo it would not be too difficult to come up with a number of rules to create a decent computer opponent, for chess this would not be possible in the time you have; here, a chess engine such as Stockfish helps.
If your team has a different idea and wants to implement another board game that has at least the functionalities listed above, please get explicit permission from the instructors before you start doing any work by emailing ([email protected]) your team ID and a short description of the game you have in mind.
First of all, settle on the game you will implement in your team.
Find four examples of your chosen board game (in 2D) that can be played online in a modern browser (laptop or desktop, not a mobile device). Consider the web application's design (focus on the game screen) based on the web design principles covered in class. Record the game URLs. Which design aspects stand out positively and which stand out negatively? Make a screenshot of each example and annotate the good and the bad.
Which game features in the examples of 4.2) stand out positively and which stand out negatively? (e.g. particular animations, sounds, information conveyed about the game to the players ...). Why? Discuss three positive and three negative features.
Having looked at at least four existing implementations of your chosen board game (Exercise 4.2), you are now in a position to design your own game interface. Similar to the wireframe example in the course book (check Chapter 2 if you have not done so yet) and the demo code wireframes, start designing your own application. Create one splash screen and one game screen. As pointed out already, your web application should be designed for the standard Desktop interface. Use the software of your choice to create those wireframes. If you do not have any software installed on your machine that can be used for this purpose ... online platforms specifically for wireframe design are just a web search away, e.g. the simple wireframe.cc or the more elaborate NinjaMock and Gliffy.
Create a design for the splash screen (also known as entry page): think of a name for your application, a short description & a logo. Feel free to use media (images, sound) with a Creative Commons license. You can start your resource search here.
Create a design for the game screen, keeping the requirements listed above in mind as well as your findings in Exercise 4.3). You have a lot of artistic freedom in designing the board and game information.
Once you have completed the design of your app, head over to CSE1500's 💡 Brightspace, go to Discussions and then the forum BOARD GAME APP DESIGNS. Create a thread with your team's name as subject/title (e.g. CSE234
) and post your team's proposed splash screen and game screen. Feel free to also add a paragraph describing your choices.
Similar to the course book, take your design as a starting point and create the respective two HTML documents. These documents should only contain HTML, no CSS or JavaScript. To get an idea on the expected amount of content, check game.html
and splash.html
of the demo board game. Ignore the few lines of code loading JavaScript and CSS files, these will be covered in Assignments 2 and 3 respectively.