You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

1.9 KiB

forum-security

Objectives

You must follow the same principles as the first subject.

For this project you must take into account the security of your forum.

  • You should implement a Hypertext Transfer Protocol Secure (HTTPS) protocol :

    • Encrypted connection : for this you will have to generate an SSL certificate, you can think of this like a identity card for your website. You can create your certificates or use "Certificate Authorities"(CA's)
  • You should encrypt :

    • Clients passwords
    • Database, for this will have to create a password for your database and encrypt the communication channel.
    • Clients session cookies should be unique. For instance, the session state is stored on the server and the session should present an unique identifier. This way the client has no direct access to it. Therefore, there is no way for attackers to read or tamper with session state.

This project will help you learn about :

  • HTTPS
  • Cipher suites
  • Encryption
    • password
    • session/cookies
    • Universal Unique Identifier (UUID)

Hints

Instructions

  • You must handle website errors, HTTPS status.
  • You must handle all sort of technical errors.
  • The code must respect the good practices.
  • It is recommend that the code should present a test file.

Allowed packages

  • All standard go packages are allowed.
  • golang.org/x/crypto/bcrypt
  • github.com/satori/go.uuid
  • github.com/mattn/go-sqlite3
  • golang.org/x/crypto/acme/autocert