Client design decisions 
 
-  there is always exactly one active patient
-  there is always exactly one active care provider
-  a model / view approach is used
-  the model gains access to the backend via a backend middleware
-  clinically meaningful classes are preferred where possible
-  plugins do not communicate directly, they use message passing
-  database connections are read only by default
-  all database access is transactioned at the serializable level
-  database access happens on demand where possible
-  there is no explicit locking of patient data in the backend
-  never place screen objects explicitly… let it all be taken care of (calculated) by wxPython sizers.