servers module

StorageServer and PublicKeyServer implementations.

Note

Do not change any code in this file!

class servers.PublicKeyServer

Bases: object

Simple implementation of a public key server.

Exposes the put_public_key and get_public_key functions as defined in the specification.

Remember, public key server is trusted and will operate as such during grading as well.

Your Client class will be initialized with a PublicKeyServer object, through which you will access these methods.

Note

Do not modify this class! None of your changes will be used when we grade your implementation.

get_encryption_key(username)

Get the public encryption key associated with username.

Parameters:username (str) – The username to lookup the public key of.
Returns:The ElGamal key object containing the public key, or None if the user does not have a key registered with the PublicKeyServer.
get_signature_key(username)

Get the public signature key associated with username.

Parameters:username (str) – The username to lookup the public key of.
Returns:The RSA key object containing the public key, or None if the user does not have a key registered with the PublicKeyServer.
put_encryption_key(username, pubkey)

Set the public encryption key for your username.

Note

Must only be called once!

Note

Students should use base_client.BaseClient.generate_public_key_pairs() instead of calling this directly.

Parameters:
  • username (str) – Your client’s username
  • pubkey (An ElGamal key object) – Your ElGamal public key
put_signature_key(username, pubkey)

Set the public signature key for your username.

Note

Must only be called once!

Note

Students should use base_client.BaseClient.generate_public_key_pairs() instead of calling this directly.

Parameters:
  • username (str) – Your client’s username
  • pubkey (An RSA key object) – Your RSA public key
class servers.StorageServer

Bases: object

Simple implementation of a storage server using a key-value store.

Exposes the get, put, and delete functions as defined in the specification.

Remember, storage server is untrusted and can and will behave maliciously. Not this implementation though, but the one which will be used for grading.

Your Client class will be initialized with a StorageServer object, through which you will access these methods.

Note

Do not modify this class! None of your changes will be used when we grade your implementation.

delete(id)

Deletes the given id from the server.

Parameters:id (str) – The id to delete
get(id)

Retrieves the value stored at id

Parameters:id (str) – The id to get
Returns:The value, or None if id does not exist in the store
Return type:str or None
put(id, value)

Stores value at id

Parameters:
  • id (str) – The id to store value at
  • value (str) – The value to store
Returns:

True, if the put succeeded

Raises:

TypeError – If id or value are not strings